0byt3m1n1
Path:
/
data
/
applications
/
aps.bak
/
joomla
/
1.7.2-0
/
standard
/
htdocs
/
libraries
/
joomla
/
html
/
[
Home
]
File: html.php
<?php /** * @package Joomla.Platform * @subpackage HTML * * @copyright Copyright (C) 2005 - 2011 Open Source Matters, Inc. All rights reserved. * @license GNU General Public License version 2 or later; see LICENSE */ defined('JPATH_PLATFORM') or die; JHtml::addIncludePath(JPATH_PLATFORM.'/joomla/html/html'); jimport('joomla.environment.uri'); jimport('joomla.environment.browser'); jimport('joomla.filesystem.file'); /** * Utility class for all HTML drawing classes * * @package Joomla.Platform * @subpackage HTML * @since 11.1 */ abstract class JHtml { /** * Option values related to the generation of HTML output. Recognized * options are: * fmtDepth, integer. The current indent depth. * fmtEol, string. The end of line string, default is linefeed. * fmtIndent, string. The string to use for indentation, default is * tab. * * @var array * @since 11.1 */ static $formatOptions = array( 'format.depth' => 0, 'format.eol' => "\n", 'format.indent' => "\t" ); /** * An array to hold included paths * * @var array * @since 11.1 */ protected static $includePaths = array(); /** * An array to hold method references * * @var array * @since 11.1 */ protected static $registry = array(); /** * Method to extract a key * * @param string $key The name of helper method to load, (prefix).(class).function * prefix and class are optional and can be used to load custom * html helpers. * * @return array Contains lowercase key, prefix, file, function. * @since 11.1 */ protected static function extract($key) { $key = preg_replace('#[^A-Z0-9_\.]#i', '', $key); // Check to see whether we need to load a helper file $parts = explode('.', $key); $prefix = (count($parts) == 3 ? array_shift($parts) : 'JHtml'); $file = (count($parts) == 2 ? array_shift($parts) : ''); $func = array_shift($parts); return array(strtolower($prefix.'.'.$file.'.'.$func), $prefix, $file, $func); } /** * Class loader method * * Additional arguments may be supplied and are passed to the sub-class. * Additional include paths are also able to be specified for third-party use * * @param string $key The name of helper method to load, (prefix).(class).function * prefix and class are optional and can be used to load custom * html helpers. * * @return mixed JHtml::call($function, $args) or False on error * @since 11.1 */ public static function _($key) { list($key, $prefix, $file, $func) = self::extract($key); if (array_key_exists($key, self::$registry)) { $function = self::$registry[$key]; $args = func_get_args(); // Remove function name from arguments array_shift($args); return JHtml::call($function, $args); } $className = $prefix.ucfirst($file); if (!class_exists($className)) { jimport('joomla.filesystem.path'); if ($path = JPath::find(JHtml::$includePaths, strtolower($file).'.php')) { require_once $path; if (!class_exists($className)) { JError::raiseError(500, JText::sprintf('JLIB_HTML_ERROR_NOTFOUNDINFILE', $className, $func)); return false; } } else { JError::raiseError(500, JText::sprintf('JLIB_HTML_ERROR_NOTSUPPORTED_NOFILE', $prefix, $file)); return false; } } $toCall = array($className, $func); if (is_callable($toCall)) { JHtml::register($key, $toCall); $args = func_get_args(); // Remove function name from arguments array_shift($args); return JHtml::call($toCall, $args); } else { JError::raiseError(500, JText::sprintf('JLIB_HTML_ERROR_NOTSUPPORTED', $className, $func)); return false; } } /** * Registers a function to be called with a specific key * * @param string The name of the key * @param string Function or method * * @return boolean True if the function is callable * @since 11.1 */ public static function register($key, $function) { list($key) = self::extract($key); if (is_callable($function)) { self::$registry[$key] = $function; return true; } return false; } /** * Removes a key for a method from registry. * * @param string The name of the key * * @return boolean True if a set key is unset * @since 11.1 */ public static function unregister($key) { list($key) = self::extract($key); if (isset(self::$registry[$key])) { unset(self::$registry[$key]); return true; } return false; } /** * Test if the key is registered. * * @param string The name of the key * * @return boolean True if the key is registered. * @since 11.1 */ public static function isRegistered($key) { list($key) = self::extract($key); return isset(self::$registry[$key]); } /** * Function caller method * * @param string Function or method to call * @param array Arguments to be passed to function * * @return mixed Function result or false on error. * @since 11.1 * @see http://php.net/manual/en/function.call-user-func-array.php */ protected static function call($function, $args) { if (is_callable($function)) { // PHP 5.3 workaround $temp = array(); foreach ($args AS &$arg) { $temp[] = &$arg; } return call_user_func_array($function, $temp); } else { JError::raiseError(500, JText::_('JLIB_HTML_ERROR_FUNCTION_NOT_SUPPORTED')); return false; } } /** * Write a <a></a> element * * @param string $url The relative URL to use for the href attribute * @param string $text The target attribute to use * @param array $attribs An associative array of attributes to add * * @return string <a></a> string * @since 11.1 */ public static function link($url, $text, $attribs = null) { if (is_array($attribs)) { $attribs = JArrayHelper::toString($attribs); } return '<a href="'.$url.'" '.$attribs.'>'.$text.'</a>'; } /** * Write a <iframe></iframe> element * * @param string $url The relative URL to use for the src attribute * @param string $name The target attribute to use * @param array $attribs An associative array of attributes to add * @param string $noFrames The message to display if the iframe tag is not supported * * @return string <iframe></iframe> element or message if not supported * @since 11.1 */ public static function iframe($url, $name, $attribs = null, $noFrames = '') { if (is_array($attribs)) { $attribs = JArrayHelper::toString($attribs); } return '<iframe src="'.$url.'" '.$attribs.' name="'.$name.'">'.$noFrames.'</iframe>'; } /** * Compute the files to be include * @param string $file path to file * @param boolean $relative path to file is relative to /media folder * @param boolean $detect_browser detect browser to include specific browser js files * @param folder $folder folder name to search into (images, css, js, ...) * @see JBrowser * * @return array files to be included * @since 11.1 */ protected static function _includeRelativeFiles($file, $relative, $detect_browser, $folder) { // If http is present in filename if (strpos($file, 'http') === 0) { $includes = array($file); } else { // Detect browser and compute potential files if ($detect_browser) { $navigator = JBrowser::getInstance(); $browser = $navigator->getBrowser(); $major = $navigator->getMajor(); $minor = $navigator->getMinor(); $ext = JFile::getExt($file); $strip = JFile::stripExt($file); // Try to include files named filename.ext, filename_browser.ext, filename_browser_major.ext, filename_browser_major_minor.ext // where major and minor are the browser version names $potential = array($file, $strip.'_'.$browser.'.'.$ext, $strip.'_'.$browser.'_'.$major.'.'.$ext, $strip.'_'.$browser.'_'.$major.'_'.$minor.'.'.$ext); } else { $potential = array($file); } // If relative search in template directory or media directory if($relative) { // Get the template $app = JFactory::getApplication(); $template = $app->getTemplate(); // Prepare array of files $includes = array(); // For each potential files foreach ($potential as $file) { // If the file is in the template folder if (file_exists(JPATH_THEMES . "/$template/$folder/$file")) { $includes[] = JURI::base(true) . "/templates/$template/$folder/$file"; } else { // If the file contains any /: it can be in an media extension subfolder if (strpos($file, '/')) { // Divide the file extracting the extension as the first part before / list($extension, $file) = explode('/', $file, 2); // If the file yet contains any /: it can be a plugin if (strpos($file, '/')) { // Divide the file extracting the element as the first part before / list($element, $file) = explode('/', $file, 2); // Try to deal with plugins group in the media folder if (file_exists(JPATH_ROOT . "/media/$extension/$element/$folder/$file")) { $includes[] = JURI::root(true) . "/media/$extension/$element/$folder/$file"; } // Try to deal with classical file in a a media subfolder called element elseif (file_exists(JPATH_ROOT . "/media/$extension/$folder/$element/$file")) { $includes[] = JURI::root(true) . "/media/$extension/$folder/$element/$file"; } // Try to deal with system files in the template folder elseif (file_exists(JPATH_THEMES . "/$template/$folder/system/$element/$file")) { $includes[] = JURI::root(true) . "/templates/$template/$folder/system/$element/$file"; } // Try to deal with system files in the media folder elseif (file_exists(JPATH_ROOT . "/media/system/$folder/$element/$file")) { $includes[] = JURI::root(true) . "/media/system/$folder/$element/$file"; } } // Try to deals in the extension media folder elseif (file_exists(JPATH_ROOT . "/media/$extension/$folder/$file")) { $includes[] = JURI::root(true) . "/media/$extension/$folder/$file"; } // Try to deal with system files in the template folder elseif (file_exists(JPATH_THEMES . "/$template/$folder/system/$file")) { $includes[] = JURI::root(true) . "/templates/$template/$folder/system/$file"; } // Try to deal with system files in the media folder elseif (file_exists(JPATH_ROOT . "/media/system/$folder/$file")) { $includes[] = JURI::root(true) . "/media/system/$folder/$file"; } } // Try to deal with system files in the media folder elseif (file_exists(JPATH_ROOT . "/media/system/$folder/$file")) { $includes[] = JURI::root(true) . "/media/system/$folder/$file"; } } } } // If not relative and http is not present in filename else { $includes = array(); foreach ($potential as $file) { if (file_exists(JPATH_ROOT . "/$file")) { $includes[] = JURI::root(true) . "/$file"; } } } } return $includes; } /** * Write a <img></img> element * * @param string $file The relative or absolute URL to use for the src attribute * @param string $attribs The target attribute to use * @param array $relative An associative array of attributes to add * @param boolean $path_only If set to true, it tries to find an override for the file in the template * * @return string * @since 11.1 */ public static function image($file, $alt, $attribs = null, $relative = false, $path_only = false) { if (is_array($attribs)) { $attribs = JArrayHelper::toString($attribs); } $includes = self::_includeRelativeFiles($file, $relative, false, 'images'); // If only path is required if($path_only) { if (count($includes)) { return $includes[0]; } else { return null; } } else { return '<img src="'.(count($includes) ? $includes[0] : '').'" alt="'.$alt.'" '.$attribs.' />'; } } /** * Write a <link rel="stylesheet" style="text/css" /> element * * @param string path to file * @param array attributes to be added to the stylesheet * @param boolean path to file is relative to /media folder * @param boolean return the path to the file only * @param boolean detect browser to include specific browser css files * will try to include file, file_*browser*, file_*browser*_*major*, file_*browser*_*major*_*minor* * <table> * <tr><th>Navigator</th> <th>browser</th> <th>major.minor</th></tr> * * <tr><td>Safari 3.0.x</td> <td>konqueror</td> <td>522.x</td></tr> * <tr><td>Safari 3.1.x and 3.2.x</td> <td>konqueror</td> <td>525.x</td></tr> * <tr><td>Safari 4.0 to 4.0.2</td> <td>konqueror</td> <td>530.x</td></tr> * <tr><td>Safari 4.0.3 to 4.0.4</td> <td>konqueror</td> <td>531.x</td></tr> * <tr><td>iOS 4.0 Safari</td> <td>konqueror</td> <td>532.x</td></tr> * <tr><td>Safari 5.0</td> <td>konqueror</td> <td>533.x</td></tr> * * <tr><td>Google Chrome 1.0</td> <td>konqueror</td> <td>528.x</td></tr> * <tr><td>Google Chrome 2.0</td> <td>konqueror</td> <td>530.x</td></tr> * <tr><td>Google Chrome 3.0 and 4.x</td> <td>konqueror</td> <td>532.x</td></tr> * <tr><td>Google Chrome 5.0</td> <td>konqueror</td> <td>533.x</td></tr> * * <tr><td>Internet Explorer 5.5</td> <td>msie</td> <td>5.5</td></tr> * <tr><td>Internet Explorer 6.x</td> <td>msie</td> <td>6.x</td></tr> * <tr><td>Internet Explorer 7.x</td> <td>msie</td> <td>7.x</td></tr> * <tr><td>Internet Explorer 8.x</td> <td>msie</td> <td>8.x</td></tr> * * <tr><td>Firefox</td> <td>mozilla</td> <td>5.0</td></tr> * </table> * a lot of others * @see JBrowser * * @return mixed nothing if $path_only is false, null, path or array of path if specific css browser files were detected * @since 11.1 */ public static function stylesheet($file, $attribs = array(), $relative = false, $path_only = false, $detect_browser = true) { // Need to adjust for the change in API from 1.5 to 1.6. // Function stylesheet($filename, $path = 'media/system/css/', $attribs = array()) if (is_string($attribs)) { // Assume this was the old $path variable. $file = $attribs.$file; } if (is_array($relative)) { // Assume this was the old $attribs variable. $attribs = $relative; $relative = false; } $includes = self::_includeRelativeFiles($file, $relative, $detect_browser, 'css'); // If only path is required if ($path_only) { if (count($includes)==0) { return null; } elseif (count($includes)==1) { return $includes[0]; } else { return $includes; } } // If inclusion is required else { $document = JFactory::getDocument(); foreach ($includes as $include) { $document->addStylesheet($include, 'text/css', null, $attribs); } } } /** * Write a <script></script> element * @param string path to file * @param boolean load the JS framework * @param boolean path to file is relative to /media folder * @param boolean return the path to the file only * @param boolean detect browser to include specific browser js files * * @return mixed nothing if $path_only is false, null, path or array of path if specific js browser files were detected * @see JHtml::stylesheet * @since 11.1 */ public static function script($file, $framework = false, $relative = false, $path_only = false, $detect_browser = true) { JHtml::core(); // Need to adjust for the change in API from 1.5 to 1.6. // function script($filename, $path = 'media/system/js/', $mootools = true) if (is_string($framework)) { // Assume this was the old $path variable. $file = $framework.$file; $framework = $relative; } // Include MooTools framework if ($framework) { JHtml::_('behavior.framework'); } $includes = self::_includeRelativeFiles($file, $relative, $detect_browser, 'js'); // If only path is required if ($path_only) { if (count($includes)==0) { return null; } elseif (count($includes)==1) { return $includes[0]; } else { return $includes; } } // If inclusion is required else { $document = JFactory::getDocument(); foreach ($includes as $include) { $document->addScript($include); } } } /** * * @param boolean $debug True if debugging is enabled. * * @return void * @since 11.1 */ public static function core($debug = null) { // If no debugging value is set, use the configuration setting if ($debug === null) { $debug = JFactory::getConfig()->get('debug'); } $uncompressed = $debug ? '-uncompressed' : ''; $document = JFactory::getDocument(); $document->addScript(JURI::root(true).'/media/system/js/core'.$uncompressed.'.js'); } /** * Set format related options. * * Updates the formatOptions array with all valid values in the passed * array. See {@see JHtml::$formatOptions} for details. * * @param array $options Option key/value pairs. * * @return void * @since 11.1 */ public static function setFormatOptions($options) { foreach ($options as $key => $val) { if (isset(self::$formatOptions[$key])) { self::$formatOptions[$key] = $val; } } } /** * Returns formated date according to a given format and time zone. * * @param string String in a format accepted by date(), defaults to "now". * @param string Format optional format for strftime * @param mixed Time zone to be used for the date. Special cases: boolean true for user * setting, boolean false for server setting. * * @return string A date translated by the given format and time zone. * @see strftime * @since 11.1 */ public static function date($input = 'now', $format = null, $tz = true, $gregorian=false) { // Get some system objects. $config = JFactory::getConfig(); $user = JFactory::getUser(); // UTC date converted to user time zone. if ($tz === true) { // Get a date object based on UTC. $date = JFactory::getDate($input, 'UTC'); // Set the correct time zone based on the user configuration. $date->setTimeZone(new DateTimeZone($user->getParam('timezone', $config->get('offset')))); } // UTC date converted to server time zone. elseif ($tz === false) { // Get a date object based on UTC. $date = JFactory::getDate($input, 'UTC'); // Set the correct time zone based on the server configuration. $date->setTimeZone(new DateTimeZone($config->get('offset'))); } // No date conversion. elseif ($tz === null) { $date = JFactory::getDate($input); } // UTC date converted to given time zone. else { // Get a date object based on UTC. $date = JFactory::getDate($input, 'UTC'); // Set the correct time zone based on the server configuration. $date->setTimeZone(new DateTimeZone($tz)); } // If no format is given use the default locale based format. if (!$format) { $format = JText::_('DATE_FORMAT_LC1'); } if ($gregorian) { return $date->format($format, true); } else { return $date->calendar($format, true); } } /** * Creates a tooltip with an image as button * * @param string $tooltip The tip string * @param mixed $title The title of the tooltip or an associative array with keys contained in {'title','image','text','href','alt'} and values * corresponding to parameters of the same name. * @param string $image The image for the tip, if no text is provided * @param string $text The text for the tip * @param string $href An URL that will be used to create the link * @param string $alt The alt attribute for img tag * * @return string * @since 11.1 */ public static function tooltip($tooltip, $title = '', $image = 'tooltip.png', $text = '', $href = '', $alt = 'Tooltip', $class = 'hasTip') { if (is_array($title)) { if (isset($title['image'])) { $image = $title['image']; } if (isset($title['text'])) { $text = $title['text']; } if (isset($title['href'])) { $href = $title['href']; } if (isset($title['alt'])) { $alt = $title['alt']; } if (isset($title['class'])) { $class = $title['class']; } if (isset($title['title'])) { $title = $title['title']; } else { $title = ''; } } $tooltip = htmlspecialchars($tooltip, ENT_COMPAT, 'UTF-8'); $title = htmlspecialchars($title, ENT_COMPAT, 'UTF-8'); $alt = htmlspecialchars($alt, ENT_COMPAT, 'UTF-8'); if (!$text) { $text = self::image($image, $alt, null, true); } if ($href) { $tip = '<a href="' . $href . '">' . $text . '</a>'; } else { $tip = $text; } if ($title) { $tooltip = $title.'::'.$tooltip; } return '<span class="'.$class.'" title="' . $tooltip . '">'.$tip.'</span>'; } /** * Displays a calendar control field * * @param string $value The date value * @param string $name The name of the text field * @param string $id The id of the text field * @param string $format The date format * @param array $attribs Additional HTML attributes * * @return * @since 11.1 */ public static function calendar($value, $name, $id, $format = '%Y-%m-%d', $attribs = null) { static $done; if ($done === null) { $done = array(); } $readonly = isset($attribs['readonly']) && $attribs['readonly'] == 'readonly'; $disabled = isset($attribs['disabled']) && $attribs['disabled'] == 'disabled'; if (is_array($attribs)) { $attribs = JArrayHelper::toString($attribs); } if ((!$readonly) && (!$disabled)) { // Load the calendar behavior JHtml::_('behavior.calendar'); JHtml::_('behavior.tooltip'); // Only display the triggers once for each control. if (!in_array($id, $done)) { $document = JFactory::getDocument(); $document->addScriptDeclaration('window.addEvent(\'domready\', function() {Calendar.setup({ // Id of the input field inputField: "'.$id.'", // Format of the input field ifFormat: "'.$format.'", // Trigger for the calendar (button ID) button: "'.$id.'_img", // Alignment (defaults to "Bl") align: "Tl", singleClick: true, firstDay: '.JFactory::getLanguage()->getFirstDay().' });});'); $done[] = $id; } } return '<input type="text" title="'.(0!==(int)$value ? JHtml::_('date',$value):'').'" name="'.$name.'" id="'.$id.'" value="'.htmlspecialchars($value, ENT_COMPAT, 'UTF-8').'" '.$attribs.' />'. ($readonly ? '' : JHtml::_('image','system/calendar.png', JText::_('JLIB_HTML_CALENDAR'), array( 'class' => 'calendar', 'id' => $id.'_img'), true)); } /** * Add a directory where JHtml should search for helpers. You may * either pass a string or an array of directories. * * @param string A path to search. * * @return array An array with directory elements * @since 11.1 */ public static function addIncludePath($path = '') { // Force path to array settype($path, 'array'); // Loop through the path directories foreach ($path as $dir) { if (!empty($dir) && !in_array($dir, JHtml::$includePaths)) { array_unshift(JHtml::$includePaths, JPath::clean($dir)); } } return JHtml::$includePaths; } }