You've already forked joomla_test
							
							
		
			
				
	
	
		
			108 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * @package     Joomla.Platform
 | |
|  * @subpackage  Form
 | |
|  *
 | |
|  * @copyright   Copyright (C) 2005 - 2013 Open Source Matters, Inc. All rights reserved.
 | |
|  * @license     GNU General Public License version 2 or later; see LICENSE
 | |
|  */
 | |
| 
 | |
| defined('JPATH_PLATFORM') or die;
 | |
| 
 | |
| JFormHelper::loadFieldClass('groupedlist');
 | |
| 
 | |
| /**
 | |
|  * Form Field class for the Joomla Platform.
 | |
|  *
 | |
|  * @package     Joomla.Platform
 | |
|  * @subpackage  Form
 | |
|  * @since       11.1
 | |
|  */
 | |
| class JFormFieldTimezone extends JFormFieldGroupedList
 | |
| {
 | |
| 
 | |
| 	/**
 | |
| 	 * The form field type.
 | |
| 	 *
 | |
| 	 * @var    string
 | |
| 	 * @since  11.1
 | |
| 	 */
 | |
| 	protected $type = 'Timezone';
 | |
| 
 | |
| 	/**
 | |
| 	 * The list of available timezone groups to use.
 | |
| 	 *
 | |
| 	 * @var    array
 | |
| 	 *
 | |
| 	 * @since  11.1
 | |
| 	 */
 | |
| 	protected static $zones = array('Africa', 'America', 'Antarctica', 'Arctic', 'Asia', 'Atlantic', 'Australia', 'Europe', 'Indian', 'Pacific');
 | |
| 
 | |
| 	/**
 | |
| 	 * Method to get the time zone field option groups.
 | |
| 	 *
 | |
| 	 * @return  array  The field option objects as a nested array in groups.
 | |
| 	 *
 | |
| 	 * @since   11.1
 | |
| 	 */
 | |
| 	protected function getGroups()
 | |
| 	{
 | |
| 		$groups = array();
 | |
| 
 | |
| 		$keyField = $this->element['key_field'] ? (string) $this->element['key_field'] : 'id';
 | |
| 		$keyValue = $this->form->getValue($keyField);
 | |
| 
 | |
| 		// If the timezone is not set use the server setting.
 | |
| 		if (strlen($this->value) == 0 && empty($keyValue))
 | |
| 		{
 | |
| 			$this->value = JFactory::getConfig()->get('offset');
 | |
| 		}
 | |
| 
 | |
| 		// Get the list of time zones from the server.
 | |
| 		$zones = DateTimeZone::listIdentifiers();
 | |
| 
 | |
| 		// Build the group lists.
 | |
| 		foreach ($zones as $zone)
 | |
| 		{
 | |
| 
 | |
| 			// Time zones not in a group we will ignore.
 | |
| 			if (strpos($zone, '/') === false)
 | |
| 			{
 | |
| 				continue;
 | |
| 			}
 | |
| 
 | |
| 			// Get the group/locale from the timezone.
 | |
| 			list ($group, $locale) = explode('/', $zone, 2);
 | |
| 
 | |
| 			// Only use known groups.
 | |
| 			if (in_array($group, self::$zones))
 | |
| 			{
 | |
| 
 | |
| 				// Initialize the group if necessary.
 | |
| 				if (!isset($groups[$group]))
 | |
| 				{
 | |
| 					$groups[$group] = array();
 | |
| 				}
 | |
| 
 | |
| 				// Only add options where a locale exists.
 | |
| 				if (!empty($locale))
 | |
| 				{
 | |
| 					$groups[$group][$zone] = JHtml::_('select.option', $zone, str_replace('_', ' ', $locale), 'value', 'text', false);
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		// Sort the group lists.
 | |
| 		ksort($groups);
 | |
| 		foreach ($groups as &$location)
 | |
| 		{
 | |
| 			sort($location);
 | |
| 		}
 | |
| 
 | |
| 		// Merge any additional groups in the XML definition.
 | |
| 		$groups = array_merge(parent::getGroups(), $groups);
 | |
| 
 | |
| 		return $groups;
 | |
| 	}
 | |
| }
 | 
