Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More →
Socket
Sign inDemoInstall
Socket

react-timezone-select

Package Overview
Dependencies
Maintainers
1
Versions
101
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-timezone-select - npm Package Compare versions

Comparing version 0.9.15 to 0.10.1

dist/index.d.ts

385

dist/index.js

@@ -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',

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡ī¸ by Socket Inc