phpvms/app/Support/Timezonelist.php

166 lines
5.5 KiB
PHP
Raw Normal View History

2018-08-24 23:16:23 +08:00
<?php
/**
* MIT License
* Copyright (c) 2017 Anh Đỗ
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
2018-08-24 23:16:23 +08:00
namespace App\Support;
use DateTimeZone;
/**
* This library is from:
* https://github.com/JackieDo/Timezone-List
*
* With some changes to suite the formatting, etc that we need
*/
class Timezonelist
2018-08-24 23:16:23 +08:00
{
/**
* Whitespace seperate
*/
const WHITESPACE_SEP = '&nbsp;&nbsp;&nbsp;&nbsp;';
/**
* Popular timezones
*
* @var array
*/
protected $popularTimezones = [
'GMT' => 'GMT timezone',
'UTC' => 'UTC timezone',
];
/**
* All continents of the world
*
* @var array
*/
protected $continents = [
'Africa' => DateTimeZone::AFRICA,
'America' => DateTimeZone::AMERICA,
'Antarctica' => DateTimeZone::ANTARCTICA,
'Arctic' => DateTimeZone::ARCTIC,
'Asia' => DateTimeZone::ASIA,
'Atlantic' => DateTimeZone::ATLANTIC,
'Australia' => DateTimeZone::AUSTRALIA,
'Europe' => DateTimeZone::EUROPE,
'Indian' => DateTimeZone::INDIAN,
'Pacific' => DateTimeZone::PACIFIC,
];
2018-08-24 23:16:23 +08:00
/**
* Format to display timezones
*
2018-08-27 00:40:04 +08:00
* @param string $timezone
* @param string $continent
* @param bool $htmlencode
*
2018-08-27 02:50:08 +08:00
* @throws \Exception
* @throws \Exception
2018-08-27 02:51:47 +08:00
*
* @return string
2018-08-24 23:16:23 +08:00
*/
2018-08-27 00:40:04 +08:00
protected function formatTimezone($timezone, $continent, $htmlencode = true)
2018-08-24 23:16:23 +08:00
{
2018-08-27 00:40:04 +08:00
$time = new \DateTimeImmutable(null, new DateTimeZone($timezone));
2018-08-24 23:16:23 +08:00
$offset = $time->format('P');
if ($htmlencode) {
2018-08-27 02:51:47 +08:00
$offset = str_replace(['-', '+'], [' &minus; ', ' &plus; '], $offset);
2018-08-24 23:16:23 +08:00
}
2018-08-27 02:50:08 +08:00
$timezone = substr($timezone, \strlen($continent) + 1);
2018-08-27 02:51:47 +08:00
$timezone = str_replace(['St_', '_'], ['St. ', ' '], $timezone);
2018-08-27 02:50:08 +08:00
return '(GMT/UTC'.$offset.')'.self::WHITESPACE_SEP.$timezone;
2018-08-24 23:16:23 +08:00
}
/**
* Create a GMT timezone select element for form
*
* @param string $name
* @param string $selected
2018-08-27 00:40:04 +08:00
* @param mixed $attr
* @param bool $htmlencode
*
2018-08-24 23:16:23 +08:00
* @return string
*/
2018-08-27 00:40:04 +08:00
public function create($name, $selected = '', $attr = '', $htmlencode = true)
2018-08-24 23:16:23 +08:00
{
// Attributes for select element
$attrSet = '';
2018-08-24 23:16:23 +08:00
if (!empty($attr)) {
2018-08-27 02:50:08 +08:00
if (\is_array($attr)) {
2018-08-24 23:16:23 +08:00
foreach ($attr as $attr_name => $attr_value) {
2018-08-27 00:40:04 +08:00
$attrSet .= ' '.$attr_name.'="'.$attr_value.'"';
2018-08-24 23:16:23 +08:00
}
} else {
2018-08-27 00:40:04 +08:00
$attrSet = ' '.$attr;
2018-08-24 23:16:23 +08:00
}
}
// start select element
2018-08-27 00:40:04 +08:00
$listbox = '<select name="'.$name.'"'.$attrSet.'>';
2018-08-24 23:16:23 +08:00
// Add popular timezones
$listbox .= '<optgroup label="General">';
foreach ($this->popularTimezones as $key => $value) {
2018-08-27 02:50:08 +08:00
$selected_attr = ($selected === $key) ? ' selected="selected"' : '';
2018-08-27 00:40:04 +08:00
$listbox .= '<option value="'.$key.'"'.$selected_attr.'>'.$value.'</option>';
2018-08-24 23:16:23 +08:00
}
$listbox .= '</optgroup>';
// Add all timezone of continents
foreach ($this->continents as $continent => $mask) {
$timezones = DateTimeZone::listIdentifiers($mask);
// start optgroup tag
2018-08-27 00:40:04 +08:00
$listbox .= '<optgroup label="'.$continent.'">';
2018-08-24 23:16:23 +08:00
// create option tags
foreach ($timezones as $timezone) {
2018-08-27 02:50:08 +08:00
$selected_attr = ($selected === $timezone) ? ' selected="selected"' : '';
2018-08-27 00:40:04 +08:00
$listbox .= '<option value="'.$timezone.'"'.$selected_attr.'>';
2018-08-24 23:16:23 +08:00
$listbox .= $this->formatTimezone($timezone, $continent, $htmlencode);
$listbox .= '</option>';
}
// end optgroup tag
$listbox .= '</optgroup>';
}
// end select element
$listbox .= '</select>';
return $listbox;
}
/**
* Create a timezone array
*
* @param bool $htmlencode
2018-08-27 00:40:04 +08:00
*
2018-08-24 23:16:23 +08:00
* @return mixed
*/
2018-08-27 00:40:04 +08:00
public function toArray($htmlencode = false)
2018-08-24 23:16:23 +08:00
{
$list = [];
// Add popular timezones to list
foreach ($this->popularTimezones as $key => $value) {
$list['General'][$key] = $value;
}
// Add all timezone of continents to list
foreach ($this->continents as $continent => $mask) {
$timezones = DateTimeZone::listIdentifiers($mask);
foreach ($timezones as $timezone) {
$list[$continent][$timezone] = $this->formatTimezone($timezone, $continent, $htmlencode);
}
}
return $list;
}
2018-08-27 00:40:04 +08:00
}