@grafana/ui
Version:
Grafana Components Library
1 lines • 9.19 kB
Source Map (JSON)
{"version":3,"file":"TimeZonePicker.mjs","sources":["../../../../src/components/DateTimePickers/TimeZonePicker.tsx"],"sourcesContent":["import { toLower, isEmpty, isString } from 'lodash';\nimport { useMemo, useCallback } from 'react';\n\nimport {\n SelectableValue,\n getTimeZoneInfo,\n TimeZoneInfo,\n getTimeZoneGroups,\n GroupedTimeZones,\n TimeZone,\n InternalTimeZones,\n} from '@grafana/data';\nimport { t } from '@grafana/i18n';\n\nimport { Select } from '../Select/Select';\n\nimport { TimeZoneGroup } from './TimeZonePicker/TimeZoneGroup';\nimport { formatUtcOffset } from './TimeZonePicker/TimeZoneOffset';\nimport { CompactTimeZoneOption, WideTimeZoneOption, SelectableZone } from './TimeZonePicker/TimeZoneOption';\n\nexport interface Props {\n onChange: (timeZone?: TimeZone) => void;\n value?: TimeZone;\n width?: number;\n autoFocus?: boolean;\n onBlur?: () => void;\n includeInternal?: boolean | InternalTimeZones[];\n disabled?: boolean;\n inputId?: string;\n menuShouldPortal?: boolean;\n openMenuOnFocus?: boolean;\n}\n\n/**\n * https://developers.grafana.com/ui/latest/index.html?path=/docs/date-time-pickers-timezonepicker--docs\n */\nexport const TimeZonePicker = (props: Props) => {\n const {\n onChange,\n width,\n autoFocus = false,\n onBlur,\n value,\n includeInternal = false,\n disabled = false,\n inputId,\n menuShouldPortal = true,\n openMenuOnFocus = true,\n } = props;\n const groupedTimeZones = useTimeZones(includeInternal);\n const selected = useSelectedTimeZone(groupedTimeZones, value);\n const filterBySearchIndex = useFilterBySearchIndex();\n const TimeZoneOption = width && width <= 45 ? CompactTimeZoneOption : WideTimeZoneOption;\n\n const onChangeTz = useCallback(\n (selectable: SelectableValue<string>) => {\n if (!selectable || !isString(selectable.value)) {\n return onChange(value);\n }\n onChange(selectable.value);\n },\n [onChange, value]\n );\n\n return (\n <Select\n inputId={inputId}\n value={selected}\n placeholder={t('time-picker.zone.select-search-input', 'Type to search (country, city, abbreviation)')}\n autoFocus={autoFocus}\n menuShouldPortal={menuShouldPortal}\n openMenuOnFocus={openMenuOnFocus}\n width={width}\n filterOption={filterBySearchIndex}\n options={groupedTimeZones}\n onChange={onChangeTz}\n onBlur={onBlur}\n components={{ Option: TimeZoneOption, Group: TimeZoneGroup }}\n disabled={disabled}\n aria-label={t('time-picker.zone.select-aria-label', 'Time zone picker')}\n />\n );\n};\n\ninterface SelectableZoneGroup extends SelectableValue<string> {\n options: SelectableZone[];\n}\n\nconst useTimeZones = (includeInternal: boolean | InternalTimeZones[]): SelectableZoneGroup[] => {\n const now = Date.now();\n\n const timeZoneGroups = useMemo(() => {\n return getTimeZoneGroups(includeInternal).map((group: GroupedTimeZones) => {\n const options = group.zones.reduce((options: SelectableZone[], zone) => {\n const info = getTimeZoneInfo(zone, now);\n\n if (!info) {\n return options;\n }\n\n const name = info.name.replace(/_/g, ' ');\n\n options.push({\n label: name,\n value: info.zone,\n searchIndex: getSearchIndex(name, info, now),\n });\n\n return options;\n }, []);\n\n return {\n label: group.name,\n options,\n };\n });\n }, [includeInternal, now]);\n\n return timeZoneGroups;\n};\n\nconst useSelectedTimeZone = (\n groups: SelectableZoneGroup[],\n timeZone: TimeZone | undefined\n): SelectableZone | undefined => {\n return useMemo(() => {\n if (timeZone === undefined) {\n return undefined;\n }\n\n const tz = toLower(timeZone);\n\n const group = groups.find((group) => {\n if (!group.label) {\n return isInternal(tz);\n }\n return tz.startsWith(toLower(group.label));\n });\n\n return group?.options.find((option) => {\n if (isEmpty(tz)) {\n return option.value === InternalTimeZones.default;\n }\n return toLower(option.value) === tz;\n });\n }, [groups, timeZone]);\n};\n\nconst isInternal = (timeZone: TimeZone): boolean => {\n switch (timeZone) {\n case InternalTimeZones.default:\n case InternalTimeZones.localBrowserTime:\n case InternalTimeZones.utc:\n return true;\n\n default:\n return false;\n }\n};\n\nconst useFilterBySearchIndex = () => {\n return useCallback((option: SelectableValue, searchQuery: string) => {\n if (!searchQuery || !option.data || !option.data.searchIndex) {\n return true;\n }\n return option.data.searchIndex.indexOf(toLower(searchQuery)) > -1;\n }, []);\n};\n\nconst getSearchIndex = (label: string, info: TimeZoneInfo, timestamp: number): string => {\n const parts: string[] = [\n toLower(info.zone),\n toLower(info.abbreviation),\n toLower(formatUtcOffset(timestamp, info.zone)),\n ];\n\n if (label !== info.zone) {\n parts.push(toLower(label));\n }\n\n for (const country of info.countries) {\n parts.push(toLower(country.name));\n parts.push(toLower(country.code));\n }\n\n return parts.join('|');\n};\n"],"names":["options","group"],"mappings":";;;;;;;;;;;AAoCO,MAAM,cAAA,GAAiB,CAAC,KAAA,KAAiB;AAC9C,EAAA,MAAM;AAAA,IACJ,QAAA;AAAA,IACA,KAAA;AAAA,IACA,SAAA,GAAY,KAAA;AAAA,IACZ,MAAA;AAAA,IACA,KAAA;AAAA,IACA,eAAA,GAAkB,KAAA;AAAA,IAClB,QAAA,GAAW,KAAA;AAAA,IACX,OAAA;AAAA,IACA,gBAAA,GAAmB,IAAA;AAAA,IACnB,eAAA,GAAkB;AAAA,GACpB,GAAI,KAAA;AACJ,EAAA,MAAM,gBAAA,GAAmB,aAAa,eAAe,CAAA;AACrD,EAAA,MAAM,QAAA,GAAW,mBAAA,CAAoB,gBAAA,EAAkB,KAAK,CAAA;AAC5D,EAAA,MAAM,sBAAsB,sBAAA,EAAuB;AACnD,EAAA,MAAM,cAAA,GAAiB,KAAA,IAAS,KAAA,IAAS,EAAA,GAAK,qBAAA,GAAwB,kBAAA;AAEtE,EAAA,MAAM,UAAA,GAAa,WAAA;AAAA,IACjB,CAAC,UAAA,KAAwC;AACvC,MAAA,IAAI,CAAC,UAAA,IAAc,CAAC,QAAA,CAAS,UAAA,CAAW,KAAK,CAAA,EAAG;AAC9C,QAAA,OAAO,SAAS,KAAK,CAAA;AAAA,MACvB;AACA,MAAA,QAAA,CAAS,WAAW,KAAK,CAAA;AAAA,IAC3B,CAAA;AAAA,IACA,CAAC,UAAU,KAAK;AAAA,GAClB;AAEA,EAAA,uBACE,GAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,OAAA;AAAA,MACA,KAAA,EAAO,QAAA;AAAA,MACP,WAAA,EAAa,CAAA,CAAE,sCAAA,EAAwC,8CAA8C,CAAA;AAAA,MACrG,SAAA;AAAA,MACA,gBAAA;AAAA,MACA,eAAA;AAAA,MACA,KAAA;AAAA,MACA,YAAA,EAAc,mBAAA;AAAA,MACd,OAAA,EAAS,gBAAA;AAAA,MACT,QAAA,EAAU,UAAA;AAAA,MACV,MAAA;AAAA,MACA,UAAA,EAAY,EAAE,MAAA,EAAQ,cAAA,EAAgB,OAAO,aAAA,EAAc;AAAA,MAC3D,QAAA;AAAA,MACA,YAAA,EAAY,CAAA,CAAE,oCAAA,EAAsC,kBAAkB;AAAA;AAAA,GACxE;AAEJ;AAMA,MAAM,YAAA,GAAe,CAAC,eAAA,KAA0E;AAC9F,EAAA,MAAM,GAAA,GAAM,KAAK,GAAA,EAAI;AAErB,EAAA,MAAM,cAAA,GAAiB,QAAQ,MAAM;AACnC,IAAA,OAAO,iBAAA,CAAkB,eAAe,CAAA,CAAE,GAAA,CAAI,CAAC,KAAA,KAA4B;AACzE,MAAA,MAAM,UAAU,KAAA,CAAM,KAAA,CAAM,MAAA,CAAO,CAACA,UAA2B,IAAA,KAAS;AACtE,QAAA,MAAM,IAAA,GAAO,eAAA,CAAgB,IAAA,EAAM,GAAG,CAAA;AAEtC,QAAA,IAAI,CAAC,IAAA,EAAM;AACT,UAAA,OAAOA,QAAAA;AAAA,QACT;AAEA,QAAA,MAAM,IAAA,GAAO,IAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,MAAM,GAAG,CAAA;AAExC,QAAAA,SAAQ,IAAA,CAAK;AAAA,UACX,KAAA,EAAO,IAAA;AAAA,UACP,OAAO,IAAA,CAAK,IAAA;AAAA,UACZ,WAAA,EAAa,cAAA,CAAe,IAAA,EAAM,IAAA,EAAM,GAAG;AAAA,SAC5C,CAAA;AAED,QAAA,OAAOA,QAAAA;AAAA,MACT,CAAA,EAAG,EAAE,CAAA;AAEL,MAAA,OAAO;AAAA,QACL,OAAO,KAAA,CAAM,IAAA;AAAA,QACb;AAAA,OACF;AAAA,IACF,CAAC,CAAA;AAAA,EACH,CAAA,EAAG,CAAC,eAAA,EAAiB,GAAG,CAAC,CAAA;AAEzB,EAAA,OAAO,cAAA;AACT,CAAA;AAEA,MAAM,mBAAA,GAAsB,CAC1B,MAAA,EACA,QAAA,KAC+B;AAC/B,EAAA,OAAO,QAAQ,MAAM;AACnB,IAAA,IAAI,aAAa,KAAA,CAAA,EAAW;AAC1B,MAAA,OAAO,KAAA,CAAA;AAAA,IACT;AAEA,IAAA,MAAM,EAAA,GAAK,QAAQ,QAAQ,CAAA;AAE3B,IAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,IAAA,CAAK,CAACC,MAAAA,KAAU;AACnC,MAAA,IAAI,CAACA,OAAM,KAAA,EAAO;AAChB,QAAA,OAAO,WAAW,EAAE,CAAA;AAAA,MACtB;AACA,MAAA,OAAO,EAAA,CAAG,UAAA,CAAW,OAAA,CAAQA,MAAAA,CAAM,KAAK,CAAC,CAAA;AAAA,IAC3C,CAAC,CAAA;AAED,IAAA,OAAO,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,OAAA,CAAQ,IAAA,CAAK,CAAC,MAAA,KAAW;AACrC,MAAA,IAAI,OAAA,CAAQ,EAAE,CAAA,EAAG;AACf,QAAA,OAAO,MAAA,CAAO,UAAU,iBAAA,CAAkB,OAAA;AAAA,MAC5C;AACA,MAAA,OAAO,OAAA,CAAQ,MAAA,CAAO,KAAK,CAAA,KAAM,EAAA;AAAA,IACnC,CAAA,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,MAAA,EAAQ,QAAQ,CAAC,CAAA;AACvB,CAAA;AAEA,MAAM,UAAA,GAAa,CAAC,QAAA,KAAgC;AAClD,EAAA,QAAQ,QAAA;AAAU,IAChB,KAAK,iBAAA,CAAkB,OAAA;AAAA,IACvB,KAAK,iBAAA,CAAkB,gBAAA;AAAA,IACvB,KAAK,iBAAA,CAAkB,GAAA;AACrB,MAAA,OAAO,IAAA;AAAA,IAET;AACE,MAAA,OAAO,KAAA;AAAA;AAEb,CAAA;AAEA,MAAM,yBAAyB,MAAM;AACnC,EAAA,OAAO,WAAA,CAAY,CAAC,MAAA,EAAyB,WAAA,KAAwB;AACnE,IAAA,IAAI,CAAC,eAAe,CAAC,MAAA,CAAO,QAAQ,CAAC,MAAA,CAAO,KAAK,WAAA,EAAa;AAC5D,MAAA,OAAO,IAAA;AAAA,IACT;AACA,IAAA,OAAO,OAAO,IAAA,CAAK,WAAA,CAAY,QAAQ,OAAA,CAAQ,WAAW,CAAC,CAAA,GAAI,CAAA,CAAA;AAAA,EACjE,CAAA,EAAG,EAAE,CAAA;AACP,CAAA;AAEA,MAAM,cAAA,GAAiB,CAAC,KAAA,EAAe,IAAA,EAAoB,SAAA,KAA8B;AACvF,EAAA,MAAM,KAAA,GAAkB;AAAA,IACtB,OAAA,CAAQ,KAAK,IAAI,CAAA;AAAA,IACjB,OAAA,CAAQ,KAAK,YAAY,CAAA;AAAA,IACzB,OAAA,CAAQ,eAAA,CAAgB,SAAA,EAAW,IAAA,CAAK,IAAI,CAAC;AAAA,GAC/C;AAEA,EAAA,IAAI,KAAA,KAAU,KAAK,IAAA,EAAM;AACvB,IAAA,KAAA,CAAM,IAAA,CAAK,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,EAC3B;AAEA,EAAA,KAAA,MAAW,OAAA,IAAW,KAAK,SAAA,EAAW;AACpC,IAAA,KAAA,CAAM,IAAA,CAAK,OAAA,CAAQ,OAAA,CAAQ,IAAI,CAAC,CAAA;AAChC,IAAA,KAAA,CAAM,IAAA,CAAK,OAAA,CAAQ,OAAA,CAAQ,IAAI,CAAC,CAAA;AAAA,EAClC;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,GAAG,CAAA;AACvB,CAAA;;;;"}