react-timezone-select
Advanced tools
Comparing version 0.9.15 to 0.10.1
@@ -1,227 +0,162 @@ | ||
"use strict"; | ||
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports["default"] = exports.i18nTimezones = void 0; | ||
var _react = _interopRequireWildcard(require("react")); | ||
var _reactSelect = _interopRequireDefault(require("react-select")); | ||
var _spacetime = _interopRequireDefault(require("spacetime")); | ||
var _spacetimeInformal = require("spacetime-informal"); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } | ||
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } | ||
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } | ||
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } | ||
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } | ||
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | ||
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } | ||
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } | ||
function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } | ||
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } | ||
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } | ||
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } | ||
var i18nTimezones = { | ||
'Pacific/Midway': 'Midway Island, Samoa', | ||
'Pacific/Honolulu': 'Hawaii', | ||
'America/Juneau': 'Alaska', | ||
'America/Boise': 'Mountain Time', | ||
'America/Dawson': 'Dawson, Yukon', | ||
'America/Chihuahua': 'Chihuahua, La Paz, Mazatlan', | ||
'America/Phoenix': 'Arizona', | ||
'America/Chicago': 'Central Time', | ||
'America/Regina': 'Saskatchewan', | ||
'America/Mexico_City': 'Guadalajara, Mexico City, Monterrey', | ||
'America/Belize': 'Central America', | ||
'America/Detroit': 'Eastern Time', | ||
'America/Bogota': 'Bogota, Lima, Quito', | ||
'America/Caracas': 'Caracas, La Paz', | ||
'America/Santiago': 'Santiago', | ||
'America/St_Johns': 'Newfoundland and Labrador', | ||
'America/Sao_Paulo': 'Brasilia', | ||
'America/Tijuana': 'Tijuana, Pacific Time', | ||
'America/Argentina/Buenos_Aires': 'Buenos Aires, Georgetown', | ||
'America/Godthab': 'Greenland', | ||
'Atlantic/Azores': 'Azores', | ||
'Atlantic/Cape_Verde': 'Cape Verde Islands', | ||
GMT: 'Dublin, Edinburgh, Lisbon, London', | ||
'Africa/Casablanca': 'Casablanca, Monrovia', | ||
'Atlantic/Canary': 'Canary Islands', | ||
'Europe/Belgrade': 'Belgrade, Bratislava, Budapest, Ljubljana, Prague', | ||
'Europe/Sarajevo': 'Sarajevo, Skopje, Warsaw, Zagreb', | ||
'Europe/Brussels': 'Brussels, Copenhagen, Madrid, Paris', | ||
'Europe/Amsterdam': 'Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna', | ||
'Africa/Algiers': 'West Central Africa', | ||
'Europe/Bucharest': 'Bucharest', | ||
'Africa/Cairo': 'Cairo', | ||
'Europe/Helsinki': 'Helsinki, Kiev, Riga, Sofia, Tallinn, Vilnius', | ||
'Europe/Athens': 'Athens, Istanbul, Minsk', | ||
'Asia/Jerusalem': 'Jerusalem', | ||
'Africa/Harare': 'Harare, Pretoria', | ||
'Europe/Moscow': 'Moscow, St. Petersburg, Volgograd', | ||
'Asia/Kuwait': 'Kuwait, Riyadh', | ||
'Africa/Nairobi': 'Nairobi', | ||
'Asia/Baghdad': 'Baghdad', | ||
'Asia/Tehran': 'Tehran', | ||
'Asia/Dubai': 'Abu Dhabi, Muscat', | ||
'Asia/Baku': 'Baku, Tbilisi, Yerevan', | ||
'Asia/Kabul': 'Kabul', | ||
'Asia/Yekaterinburg': 'Ekaterinburg', | ||
'Asia/Karachi': 'Islamabad, Karachi, Tashkent', | ||
'Asia/Kolkata': 'Chennai, Kolkata, Mumbai, New Delhi', | ||
'Asia/Kathmandu': 'Kathmandu', | ||
'Asia/Dhaka': 'Astana, Dhaka', | ||
'Asia/Colombo': 'Sri Jayawardenepura', | ||
'Asia/Almaty': 'Almaty, Novosibirsk', | ||
'Asia/Rangoon': 'Yangon Rangoon', | ||
'Asia/Bangkok': 'Bangkok, Hanoi, Jakarta', | ||
'Asia/Krasnoyarsk': 'Krasnoyarsk', | ||
'Asia/Shanghai': 'Beijing, Chongqing, Hong Kong SAR, Urumqi', | ||
'Asia/Kuala_Lumpur': 'Kuala Lumpur, Singapore', | ||
'Asia/Taipei': 'Taipei', | ||
'Australia/Perth': 'Perth', | ||
'Asia/Irkutsk': 'Irkutsk, Ulaanbaatar', | ||
'Asia/Seoul': 'Seoul', | ||
'Asia/Tokyo': 'Osaka, Sapporo, Tokyo', | ||
'Asia/Yakutsk': 'Yakutsk', | ||
'Australia/Darwin': 'Darwin', | ||
'Australia/Adelaide': 'Adelaide', | ||
'Australia/Sydney': 'Canberra, Melbourne, Sydney', | ||
'Australia/Brisbane': 'Brisbane', | ||
'Australia/Hobart': 'Hobart', | ||
'Asia/Vladivostok': 'Vladivostok', | ||
'Pacific/Guam': 'Guam, Port Moresby', | ||
'Asia/Magadan': 'Magadan, Solomon Islands, New Caledonia', | ||
'Asia/Kamchatka': 'Kamchatka, Marshall Islands', | ||
'Pacific/Fiji': 'Fiji Islands', | ||
'Pacific/Auckland': 'Auckland, Wellington', | ||
'Pacific/Tongatapu': "Nuku'alofa" | ||
import * as React from 'react'; | ||
import Select from 'react-select'; | ||
import spacetime from 'spacetime'; | ||
import { display } from 'spacetime-informal'; | ||
export const i18nTimezones = { | ||
'Pacific/Midway': 'Midway Island, Samoa', | ||
'Pacific/Honolulu': 'Hawaii', | ||
'America/Juneau': 'Alaska', | ||
'America/Boise': 'Mountain Time', | ||
'America/Dawson': 'Dawson, Yukon', | ||
'America/Chihuahua': 'Chihuahua, La Paz, Mazatlan', | ||
'America/Phoenix': 'Arizona', | ||
'America/Chicago': 'Central Time', | ||
'America/Regina': 'Saskatchewan', | ||
'America/Mexico_City': 'Guadalajara, Mexico City, Monterrey', | ||
'America/Belize': 'Central America', | ||
'America/Detroit': 'Eastern Time', | ||
'America/Bogota': 'Bogota, Lima, Quito', | ||
'America/Caracas': 'Caracas, La Paz', | ||
'America/Santiago': 'Santiago', | ||
'America/St_Johns': 'Newfoundland and Labrador', | ||
'America/Sao_Paulo': 'Brasilia', | ||
'America/Tijuana': 'Tijuana, Pacific Time', | ||
'America/Argentina/Buenos_Aires': 'Buenos Aires, Georgetown', | ||
'America/Godthab': 'Greenland', | ||
'Atlantic/Azores': 'Azores', | ||
'Atlantic/Cape_Verde': 'Cape Verde Islands', | ||
GMT: 'Dublin, Edinburgh, Lisbon, London', | ||
'Africa/Casablanca': 'Casablanca, Monrovia', | ||
'Atlantic/Canary': 'Canary Islands', | ||
'Europe/Belgrade': 'Belgrade, Bratislava, Budapest, Ljubljana, Prague', | ||
'Europe/Sarajevo': 'Sarajevo, Skopje, Warsaw, Zagreb', | ||
'Europe/Brussels': 'Brussels, Copenhagen, Madrid, Paris', | ||
'Europe/Amsterdam': 'Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna', | ||
'Africa/Algiers': 'West Central Africa', | ||
'Europe/Bucharest': 'Bucharest', | ||
'Africa/Cairo': 'Cairo', | ||
'Europe/Helsinki': 'Helsinki, Kiev, Riga, Sofia, Tallinn, Vilnius', | ||
'Europe/Athens': 'Athens, Istanbul, Minsk', | ||
'Asia/Jerusalem': 'Jerusalem', | ||
'Africa/Harare': 'Harare, Pretoria', | ||
'Europe/Moscow': 'Moscow, St. Petersburg, Volgograd', | ||
'Asia/Kuwait': 'Kuwait, Riyadh', | ||
'Africa/Nairobi': 'Nairobi', | ||
'Asia/Baghdad': 'Baghdad', | ||
'Asia/Tehran': 'Tehran', | ||
'Asia/Dubai': 'Abu Dhabi, Muscat', | ||
'Asia/Baku': 'Baku, Tbilisi, Yerevan', | ||
'Asia/Kabul': 'Kabul', | ||
'Asia/Yekaterinburg': 'Ekaterinburg', | ||
'Asia/Karachi': 'Islamabad, Karachi, Tashkent', | ||
'Asia/Kolkata': 'Chennai, Kolkata, Mumbai, New Delhi', | ||
'Asia/Kathmandu': 'Kathmandu', | ||
'Asia/Dhaka': 'Astana, Dhaka', | ||
'Asia/Colombo': 'Sri Jayawardenepura', | ||
'Asia/Almaty': 'Almaty, Novosibirsk', | ||
'Asia/Rangoon': 'Yangon Rangoon', | ||
'Asia/Bangkok': 'Bangkok, Hanoi, Jakarta', | ||
'Asia/Krasnoyarsk': 'Krasnoyarsk', | ||
'Asia/Shanghai': 'Beijing, Chongqing, Hong Kong SAR, Urumqi', | ||
'Asia/Kuala_Lumpur': 'Kuala Lumpur, Singapore', | ||
'Asia/Taipei': 'Taipei', | ||
'Australia/Perth': 'Perth', | ||
'Asia/Irkutsk': 'Irkutsk, Ulaanbaatar', | ||
'Asia/Seoul': 'Seoul', | ||
'Asia/Tokyo': 'Osaka, Sapporo, Tokyo', | ||
'Asia/Yakutsk': 'Yakutsk', | ||
'Australia/Darwin': 'Darwin', | ||
'Australia/Adelaide': 'Adelaide', | ||
'Australia/Sydney': 'Canberra, Melbourne, Sydney', | ||
'Australia/Brisbane': 'Brisbane', | ||
'Australia/Hobart': 'Hobart', | ||
'Asia/Vladivostok': 'Vladivostok', | ||
'Pacific/Guam': 'Guam, Port Moresby', | ||
'Asia/Magadan': 'Magadan, Solomon Islands, New Caledonia', | ||
'Asia/Kamchatka': 'Kamchatka, Marshall Islands', | ||
'Pacific/Fiji': 'Fiji Islands', | ||
'Pacific/Auckland': 'Auckland, Wellington', | ||
'Pacific/Tongatapu': "Nuku'alofa", | ||
}; | ||
exports.i18nTimezones = i18nTimezones; | ||
var TimezoneSelect = function TimezoneSelect(_ref) { | ||
var value = _ref.value, | ||
onBlur = _ref.onBlur, | ||
onChange = _ref.onChange, | ||
_ref$labelStyle = _ref.labelStyle, | ||
labelStyle = _ref$labelStyle === void 0 ? 'original' : _ref$labelStyle, | ||
timezones = _ref.timezones, | ||
props = _objectWithoutProperties(_ref, ["value", "onBlur", "onChange", "labelStyle", "timezones"]); | ||
var _useState = (0, _react.useState)({}), | ||
_useState2 = _slicedToArray(_useState, 2), | ||
selectedTimezone = _useState2[0], | ||
setSelectedTimezone = _useState2[1]; | ||
timezones = timezones || i18nTimezones; | ||
var getOptions = (0, _react.useMemo)(function () { | ||
var options = []; | ||
Object.entries(timezones).reduce(function (obj, entry) { | ||
var a = _spacetime["default"].now()["goto"](entry[0]); | ||
var tz = a.timezone(); | ||
var tzDisplay = (0, _spacetimeInformal.display)(entry[0]); | ||
var abbrev = entry[0]; | ||
var altName = entry[0]; | ||
if (tzDisplay && tzDisplay.daylight && tzDisplay.standard) { | ||
abbrev = a.isDST() ? tzDisplay.daylight.abbrev : tzDisplay.standard.abbrev; | ||
altName = a.isDST() ? tzDisplay.daylight.name : tzDisplay.standard.name; | ||
} | ||
obj.push({ | ||
name: entry[0], | ||
label: entry[1], | ||
offset: tz.current.offset, | ||
abbrev: abbrev, | ||
altName: altName | ||
}); | ||
return obj; | ||
}).sort(function (a, b) { | ||
return a.offset - b.offset; | ||
}).map(function (tz) { | ||
if (tz.offset === undefined) return false; | ||
var label = ''; | ||
var min = tz.offset * 60; | ||
var hr = "".concat(min / 60 ^ 0, ":") + (min % 60 === 0 ? '00' : Math.abs(min % 60)); | ||
var prefix = "(GMT".concat(hr.includes('-') ? hr : "+".concat(hr), ") ").concat(tz.label); | ||
switch (labelStyle) { | ||
case 'original': | ||
label = prefix; | ||
break; | ||
case 'altName': | ||
label = "".concat(prefix, " ").concat(!tz.altName.includes('/') ? "(".concat(tz.altName, ")") : ''); | ||
break; | ||
case 'abbrev': | ||
label = "".concat(prefix, " \n ").concat(tz.abbrev.length < 5 ? "(".concat(tz.abbrev, ")") : ''); | ||
break; | ||
default: | ||
label = "".concat(prefix); | ||
} | ||
options.push({ | ||
value: tz.name, | ||
label: label, | ||
abbrev: tz.abbrev, | ||
altName: tz.altName | ||
}); | ||
}); | ||
return options; | ||
}, [labelStyle]); | ||
var handleChange = function handleChange(tz) { | ||
setSelectedTimezone(tz); | ||
onChange && onChange(tz); | ||
}; | ||
var constructTz = function constructTz(value) { | ||
var returnTz; | ||
if (value.value && value.label) { | ||
returnTz = value; | ||
} else if (value.value && !value.label) { | ||
returnTz = getOptions.find(function (tz) { | ||
return tz.value === value.value; | ||
}); | ||
} else if (typeof value === 'string' && !selectedTimezone.label) { | ||
returnTz = getOptions.find(function (tz) { | ||
return tz.value === value; | ||
}); | ||
} | ||
return returnTz; | ||
}; | ||
return /*#__PURE__*/_react["default"].createElement(_reactSelect["default"], _extends({ | ||
value: constructTz(value), | ||
onChange: handleChange, | ||
options: getOptions, | ||
onBlur: onBlur | ||
}, props)); | ||
const TimezoneSelect = ({ value, onBlur, onChange, labelStyle = 'original', timezones, ...props }) => { | ||
timezones = timezones || i18nTimezones; | ||
const getOptions = React.useMemo(() => { | ||
const options = []; | ||
console.log(Object.entries(timezones)); | ||
Object.entries(timezones) | ||
.reduce((obj, entry) => { | ||
const a = spacetime.now().goto(entry[0]); | ||
const tz = a.timezone(); | ||
const tzDisplay = display(entry[0]); | ||
let abbrev = entry[0]; | ||
let altName = entry[0]; | ||
if (tzDisplay && tzDisplay.daylight && tzDisplay.standard) { | ||
abbrev = a.isDST() | ||
? tzDisplay.daylight.abbrev | ||
: tzDisplay.standard.abbrev; | ||
altName = a.isDST() | ||
? tzDisplay.daylight.name | ||
: tzDisplay.standard.name; | ||
} | ||
obj.push({ | ||
name: entry[0], | ||
label: entry[1], | ||
offset: tz.current.offset, | ||
abbrev: abbrev, | ||
altName: altName, | ||
}); | ||
return obj; | ||
}, {}) | ||
.sort((a, b) => { | ||
return a.offset - b.offset; | ||
}) | ||
.map((tz) => { | ||
if (tz.offset === undefined) | ||
return false; | ||
let label = ''; | ||
const min = tz.offset * 60; | ||
const hr = `${(min / 60) ^ 0}:` + (min % 60 === 0 ? '00' : Math.abs(min % 60)); | ||
const prefix = `(GMT${hr.includes('-') ? hr : `+${hr}`}) ${tz.label}`; | ||
switch (labelStyle) { | ||
case 'original': | ||
label = prefix; | ||
break; | ||
case 'altName': | ||
label = `${prefix} ${!tz.altName.includes('/') ? `(${tz.altName})` : ''}`; | ||
break; | ||
case 'abbrev': | ||
label = `${prefix} | ||
${tz.abbrev.length < 5 ? `(${tz.abbrev})` : ''}`; | ||
break; | ||
default: | ||
label = `${prefix}`; | ||
} | ||
options.push({ | ||
value: tz.name, | ||
label: label, | ||
abbrev: tz.abbrev, | ||
altName: tz.altName, | ||
}); | ||
}); | ||
return options; | ||
}, [labelStyle, timezones]); | ||
const handleChange = (tz) => { | ||
onChange && onChange(tz); | ||
}; | ||
const normalizeTz = (value) => { | ||
let returnTz; | ||
if (typeof value === 'string') { | ||
returnTz = getOptions.find(tz => tz.value === value); | ||
} | ||
else if (value.value && !value.label) { | ||
returnTz = getOptions.find(tz => tz.value === value.value); | ||
} | ||
else { | ||
returnTz = value; | ||
} | ||
return returnTz; | ||
}; | ||
return (React.createElement(Select, Object.assign({ value: normalizeTz(value), onChange: handleChange, options: getOptions, onBlur: onBlur }, props))); | ||
}; | ||
var _default = TimezoneSelect; | ||
exports["default"] = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["i18nTimezones","GMT","TimezoneSelect","value","onBlur","onChange","labelStyle","timezones","props","selectedTimezone","setSelectedTimezone","getOptions","options","Object","entries","reduce","obj","entry","a","spacetime","now","tz","timezone","tzDisplay","abbrev","altName","daylight","standard","isDST","name","push","label","offset","current","sort","b","map","undefined","min","hr","Math","abs","prefix","includes","length","handleChange","constructTz","returnTz","find"],"mappings":"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","sourcesContent":["import React, { useState, useMemo } from 'react'\nimport Select from 'react-select'\nimport spacetime from 'spacetime'\nimport { display } from 'spacetime-informal'\n\nexport const i18nTimezones = {\n  'Pacific/Midway': 'Midway Island, Samoa',\n  'Pacific/Honolulu': 'Hawaii',\n  'America/Juneau': 'Alaska',\n  'America/Boise': 'Mountain Time',\n  'America/Dawson': 'Dawson, Yukon',\n  'America/Chihuahua': 'Chihuahua, La Paz, Mazatlan',\n  'America/Phoenix': 'Arizona',\n  'America/Chicago': 'Central Time',\n  'America/Regina': 'Saskatchewan',\n  'America/Mexico_City': 'Guadalajara, Mexico City, Monterrey',\n  'America/Belize': 'Central America',\n  'America/Detroit': 'Eastern Time',\n  'America/Bogota': 'Bogota, Lima, Quito',\n  'America/Caracas': 'Caracas, La Paz',\n  'America/Santiago': 'Santiago',\n  'America/St_Johns': 'Newfoundland and Labrador',\n  'America/Sao_Paulo': 'Brasilia',\n  'America/Tijuana': 'Tijuana, Pacific Time',\n  'America/Argentina/Buenos_Aires': 'Buenos Aires, Georgetown',\n  'America/Godthab': 'Greenland',\n  'Atlantic/Azores': 'Azores',\n  'Atlantic/Cape_Verde': 'Cape Verde Islands',\n  GMT: 'Dublin, Edinburgh, Lisbon, London',\n  'Africa/Casablanca': 'Casablanca, Monrovia',\n  'Atlantic/Canary': 'Canary Islands',\n  'Europe/Belgrade': 'Belgrade, Bratislava, Budapest, Ljubljana, Prague',\n  'Europe/Sarajevo': 'Sarajevo, Skopje, Warsaw, Zagreb',\n  'Europe/Brussels': 'Brussels, Copenhagen, Madrid, Paris',\n  'Europe/Amsterdam': 'Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna',\n  'Africa/Algiers': 'West Central Africa',\n  'Europe/Bucharest': 'Bucharest',\n  'Africa/Cairo': 'Cairo',\n  'Europe/Helsinki': 'Helsinki, Kiev, Riga, Sofia, Tallinn, Vilnius',\n  'Europe/Athens': 'Athens, Istanbul, Minsk',\n  'Asia/Jerusalem': 'Jerusalem',\n  'Africa/Harare': 'Harare, Pretoria',\n  'Europe/Moscow': 'Moscow, St. Petersburg, Volgograd',\n  'Asia/Kuwait': 'Kuwait, Riyadh',\n  'Africa/Nairobi': 'Nairobi',\n  'Asia/Baghdad': 'Baghdad',\n  'Asia/Tehran': 'Tehran',\n  'Asia/Dubai': 'Abu Dhabi, Muscat',\n  'Asia/Baku': 'Baku, Tbilisi, Yerevan',\n  'Asia/Kabul': 'Kabul',\n  'Asia/Yekaterinburg': 'Ekaterinburg',\n  'Asia/Karachi': 'Islamabad, Karachi, Tashkent',\n  'Asia/Kolkata': 'Chennai, Kolkata, Mumbai, New Delhi',\n  'Asia/Kathmandu': 'Kathmandu',\n  'Asia/Dhaka': 'Astana, Dhaka',\n  'Asia/Colombo': 'Sri Jayawardenepura',\n  'Asia/Almaty': 'Almaty, Novosibirsk',\n  'Asia/Rangoon': 'Yangon Rangoon',\n  'Asia/Bangkok': 'Bangkok, Hanoi, Jakarta',\n  'Asia/Krasnoyarsk': 'Krasnoyarsk',\n  'Asia/Shanghai': 'Beijing, Chongqing, Hong Kong SAR, Urumqi',\n  'Asia/Kuala_Lumpur': 'Kuala Lumpur, Singapore',\n  'Asia/Taipei': 'Taipei',\n  'Australia/Perth': 'Perth',\n  'Asia/Irkutsk': 'Irkutsk, Ulaanbaatar',\n  'Asia/Seoul': 'Seoul',\n  'Asia/Tokyo': 'Osaka, Sapporo, Tokyo',\n  'Asia/Yakutsk': 'Yakutsk',\n  'Australia/Darwin': 'Darwin',\n  'Australia/Adelaide': 'Adelaide',\n  'Australia/Sydney': 'Canberra, Melbourne, Sydney',\n  'Australia/Brisbane': 'Brisbane',\n  'Australia/Hobart': 'Hobart',\n  'Asia/Vladivostok': 'Vladivostok',\n  'Pacific/Guam': 'Guam, Port Moresby',\n  'Asia/Magadan': 'Magadan, Solomon Islands, New Caledonia',\n  'Asia/Kamchatka': 'Kamchatka, Marshall Islands',\n  'Pacific/Fiji': 'Fiji Islands',\n  'Pacific/Auckland': 'Auckland, Wellington',\n  'Pacific/Tongatapu': \"Nuku'alofa\",\n}\n\nconst TimezoneSelect = ({\n  value,\n  onBlur,\n  onChange,\n  labelStyle = 'original',\n  timezones,\n  ...props\n}) => {\n  const [selectedTimezone, setSelectedTimezone] = useState({})\n  timezones = timezones || i18nTimezones\n  const getOptions = useMemo(() => {\n    const options = []\n    Object.entries(timezones)\n      .reduce((obj, entry) => {\n        const a = spacetime.now().goto(entry[0])\n        const tz = a.timezone()\n        const tzDisplay = display(entry[0])\n        let abbrev = entry[0]\n        let altName = entry[0]\n        if (tzDisplay && tzDisplay.daylight && tzDisplay.standard) {\n          abbrev = a.isDST()\n            ? tzDisplay.daylight.abbrev\n            : tzDisplay.standard.abbrev\n          altName = a.isDST()\n            ? tzDisplay.daylight.name\n            : tzDisplay.standard.name\n        }\n        obj.push({\n          name: entry[0],\n          label: entry[1],\n          offset: tz.current.offset,\n          abbrev: abbrev,\n          altName: altName,\n        })\n        return obj\n      })\n      .sort((a, b) => {\n        return a.offset - b.offset\n      })\n      .map(tz => {\n        if (tz.offset === undefined) return false\n        let label = ''\n        const min = tz.offset * 60\n        const hr =\n          `${(min / 60) ^ 0}:` + (min % 60 === 0 ? '00' : Math.abs(min % 60))\n        const prefix = `(GMT${hr.includes('-') ? hr : `+${hr}`}) ${tz.label}`\n\n        switch (labelStyle) {\n          case 'original':\n            label = prefix\n            break\n          case 'altName':\n            label = `${prefix} ${\n              !tz.altName.includes('/') ? `(${tz.altName})` : ''\n            }`\n            break\n          case 'abbrev':\n            label = `${prefix} \n            ${tz.abbrev.length < 5 ? `(${tz.abbrev})` : ''}`\n            break\n          default:\n            label = `${prefix}`\n        }\n        options.push({\n          value: tz.name,\n          label: label,\n          abbrev: tz.abbrev,\n          altName: tz.altName,\n        })\n      })\n    return options\n  }, [labelStyle])\n\n  const handleChange = tz => {\n    setSelectedTimezone(tz)\n    onChange && onChange(tz)\n  }\n\n  const constructTz = value => {\n    let returnTz\n    if (value.value && value.label) {\n      returnTz = value\n    } else if (value.value && !value.label) {\n      returnTz = getOptions.find(tz => tz.value === value.value)\n    } else if (typeof value === 'string' && !selectedTimezone.label) {\n      returnTz = getOptions.find(tz => tz.value === value)\n    }\n    return returnTz\n  }\n\n  return (\n    <Select\n      value={constructTz(value)}\n      onChange={handleChange}\n      options={getOptions}\n      onBlur={onBlur}\n      {...props}\n    />\n  )\n}\n\nexport default TimezoneSelect\n"]} | ||
export default TimezoneSelect; | ||
//# sourceMappingURL=index.js.map |
{ | ||
"name": "react-timezone-select", | ||
"version": "0.9.15", | ||
"version": "0.10.1", | ||
"description": "Usable, dynamic React Timezone Select", | ||
@@ -8,7 +8,5 @@ "main": "dist/index.js", | ||
"start": "webpack serve --mode development", | ||
"transpile": "babel src -d dist -s inline --copy-files", | ||
"prepublishOnly": "npm run transpile", | ||
"build": "webpack --mode production", | ||
"deploy": "gh-pages -d examples/dist", | ||
"postpublish": "npm run build && npm run deploy" | ||
"prepublish": "tsc", | ||
"build": "tsc --project ./tsconfig.json", | ||
"deploy": "gh-pages -d example/dist" | ||
}, | ||
@@ -24,2 +22,3 @@ "author": "Nico Domino <yo@ndo.dev>", | ||
}, | ||
"license": "MIT", | ||
"keywords": [ | ||
@@ -34,3 +33,3 @@ "react", | ||
], | ||
"license": "MIT", | ||
"types": "./dist/index.d.ts", | ||
"module": "./dist/index.js", | ||
@@ -45,20 +44,22 @@ "exports": { | ||
"dependencies": { | ||
"react-select": "^3.2.0", | ||
"spacetime": "^6.12.2", | ||
"react-select": "^4.0.2", | ||
"spacetime": "^6.12.3", | ||
"spacetime-informal": "^0.5.0" | ||
}, | ||
"devDependencies": { | ||
"@babel/cli": "^7.12.10", | ||
"@babel/core": "^7.12.10", | ||
"@babel/plugin-proposal-class-properties": "^7.12.1", | ||
"@babel/preset-env": "^7.12.11", | ||
"@babel/preset-react": "^7.12.10", | ||
"babel-loader": "^8.2.2", | ||
"@types/react": "^17.0.1", | ||
"@types/react-dom": "^17.0.0", | ||
"@types/react-select": "^4.0.13", | ||
"css-loader": "^5.0.1", | ||
"gh-pages": "^3.1.0", | ||
"html-webpack-plugin": "^4.5.1", | ||
"html-webpack-plugin": "^5.0.0", | ||
"prettier": "^2.2.1", | ||
"react": "^17.0.1", | ||
"react-dom": "^17.0.1", | ||
"source-map-loader": "^2.0.0", | ||
"style-loader": "^2.0.0", | ||
"webpack": "^5.16.0", | ||
"webpack-cli": "^4.4.0", | ||
"ts-loader": "^8.0.15", | ||
"typescript": "^4.1.3", | ||
"webpack": "^5.21.1", | ||
"webpack-cli": "^4.5.0", | ||
"webpack-dev-server": "^3.11.2" | ||
@@ -65,0 +66,0 @@ }, |
@@ -22,3 +22,3 @@ # đâ react-timezone-select | ||
There is also a [Codesandbox](https://codesandbox.io/s/react-timezone-select-usage-z37hf) usage example for adjusting the timezone of a selected `spacetime` object, like how one might use this in a real app. | ||
There is another Demo available on [Codesandbox](https://codesandbox.io/s/react-timezone-select-usage-z37hf) showing how to adjust the timezone of a selected `spacetime` object, like how one might use this in a real app. | ||
@@ -28,3 +28,3 @@ ## đī¸ Installing | ||
```bash | ||
npm install --save-prod react-timezone-select | ||
npm install react-timezone-select | ||
``` | ||
@@ -64,10 +64,2 @@ | ||
<br /> | ||
<span style={{ marginLeft: '20px', fontWeight: '500' }}> | ||
altName: '{selectedTimezone.altName}' | ||
</span> | ||
<br /> | ||
<span style={{ marginLeft: '20px', fontWeight: '500' }}> | ||
abbrev: '{selectedTimezone.abbrev}' | ||
</span> | ||
<br /> | ||
{'}'} | ||
@@ -85,2 +77,4 @@ </div> | ||
> Update **v0.10.1+** we're now built with Typescript! | ||
- `value` - `{ value: string, label: string, altName: string, abbrev: string }` | ||
@@ -118,3 +112,3 @@ - `onBlur` - `() => void` | ||
timezones={{ | ||
...i18nTimezones | ||
...i18nTimezones, | ||
'America/Lima': 'Pittsburgh', | ||
@@ -121,0 +115,0 @@ 'Europe/Berlin': 'Frankfurt', |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
6
19924
16
182
127
1
+ Added@emotion/babel-plugin@11.13.5(transitive)
+ Added@emotion/cache@11.13.5(transitive)
+ Added@emotion/hash@0.9.2(transitive)
+ Added@emotion/memoize@0.9.0(transitive)
+ Added@emotion/react@11.13.5(transitive)
+ Added@emotion/serialize@1.3.3(transitive)
+ Added@emotion/sheet@1.4.0(transitive)
+ Added@emotion/unitless@0.10.0(transitive)
+ Added@emotion/use-insertion-effect-with-fallbacks@1.1.0(transitive)
+ Added@emotion/utils@1.4.2(transitive)
+ Added@emotion/weak-memoize@0.4.0(transitive)
+ Addedbabel-plugin-macros@3.1.0(transitive)
+ Addedcosmiconfig@7.1.0(transitive)
+ Addedescape-string-regexp@4.0.0(transitive)
+ Addedhoist-non-react-statics@3.3.2(transitive)
+ Addedreact-select@4.3.1(transitive)
+ Addedstylis@4.2.0(transitive)
- Removed@emotion/cache@10.0.29(transitive)
- Removed@emotion/core@10.3.1(transitive)
- Removed@emotion/css@10.0.27(transitive)
- Removed@emotion/hash@0.8.0(transitive)
- Removed@emotion/memoize@0.7.4(transitive)
- Removed@emotion/serialize@0.11.16(transitive)
- Removed@emotion/sheet@0.9.4(transitive)
- Removed@emotion/stylis@0.8.5(transitive)
- Removed@emotion/unitless@0.7.5(transitive)
- Removed@emotion/utils@0.11.3(transitive)
- Removed@emotion/weak-memoize@0.2.5(transitive)
- Removedbabel-plugin-emotion@10.2.2(transitive)
- Removedbabel-plugin-macros@2.8.0(transitive)
- Removedbabel-plugin-syntax-jsx@6.18.0(transitive)
- Removedcosmiconfig@6.0.0(transitive)
- Removedcsstype@2.6.21(transitive)
- Removedescape-string-regexp@1.0.5(transitive)
- Removedreact-select@3.2.0(transitive)
Updatedreact-select@^4.0.2
Updatedspacetime@^6.12.3