@banzamel/mineralui 1.11.1 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/README.md +1 -1
  2. package/dist/MConflictIllustration-DfNfvv7Q.cjs +2 -0
  3. package/dist/MConflictIllustration-DfNfvv7Q.cjs.map +1 -0
  4. package/dist/{MConflictIllustration-Ctggjn7z.js → MConflictIllustration-Drsm8_8C.js} +41 -99
  5. package/dist/MConflictIllustration-Drsm8_8C.js.map +1 -0
  6. package/dist/{cards-CvgcQCAP.js → cards-C2t-pM0r.js} +12 -11
  7. package/dist/cards-C2t-pM0r.js.map +1 -0
  8. package/dist/{cards-O0osWbUF.cjs → cards-D7_hH3Q8.cjs} +2 -2
  9. package/dist/cards-D7_hH3Q8.cjs.map +1 -0
  10. package/dist/cards.cjs +1 -1
  11. package/dist/cards.js +1 -1
  12. package/dist/components/inputs/MInputUrl/MInputUrl.d.ts +3 -0
  13. package/dist/components/inputs/MInputUrl/MInputUrl.types.d.ts +27 -0
  14. package/dist/components/inputs/MInputUrl/index.d.ts +2 -0
  15. package/dist/components/inputs/index.d.ts +2 -0
  16. package/dist/{dropdowns-C9jREjLg.js → dropdowns-BJ8s18h2.js} +2 -2
  17. package/dist/dropdowns-BJ8s18h2.js.map +1 -0
  18. package/dist/{dropdowns-BP2HBR-x.cjs → dropdowns-BLd4lyr6.cjs} +2 -2
  19. package/dist/dropdowns-BLd4lyr6.cjs.map +1 -0
  20. package/dist/dropdowns.cjs +1 -1
  21. package/dist/dropdowns.js +1 -1
  22. package/dist/{form-D5F1kTIA.cjs → form-Bni0Gf_s.cjs} +2 -2
  23. package/dist/{form-D5F1kTIA.cjs.map → form-Bni0Gf_s.cjs.map} +1 -1
  24. package/dist/{form-CWoOQ_qo.js → form-CFhDAU18.js} +2 -2
  25. package/dist/{form-CWoOQ_qo.js.map → form-CFhDAU18.js.map} +1 -1
  26. package/dist/form.cjs +1 -1
  27. package/dist/form.js +1 -1
  28. package/dist/i18n/frameworkTexts.d.ts +0 -29
  29. package/dist/illustrations/index.d.ts +0 -1
  30. package/dist/illustrations.cjs +1 -1
  31. package/dist/illustrations.js +2 -2
  32. package/dist/index.cjs +1 -1
  33. package/dist/index.js +42 -42
  34. package/dist/inputs-BpdfT9Hp.cjs +2 -0
  35. package/dist/inputs-BpdfT9Hp.cjs.map +1 -0
  36. package/dist/{inputs-bbwdb6m3.js → inputs-CyDoEfL3.js} +333 -284
  37. package/dist/inputs-CyDoEfL3.js.map +1 -0
  38. package/dist/inputs.cjs +1 -1
  39. package/dist/inputs.js +3 -3
  40. package/dist/style-runtime.cjs +1 -1
  41. package/dist/style-runtime.js +1 -1
  42. package/dist/styles.css +1 -1
  43. package/dist/utils/validators.d.ts +14 -0
  44. package/dist/utils.cjs +1 -1
  45. package/dist/utils.js +2 -2
  46. package/dist/{validators-DRhikiAi.cjs → validators-B6yWdsu2.cjs} +2 -2
  47. package/dist/{validators-DRhikiAi.cjs.map → validators-B6yWdsu2.cjs.map} +1 -1
  48. package/dist/{validators-D5OCyV2h.js → validators-DVYOtFnw.js} +19 -2
  49. package/dist/{validators-D5OCyV2h.js.map → validators-DVYOtFnw.js.map} +1 -1
  50. package/package.json +1 -1
  51. package/dist/MConflictIllustration-CfYeZVmf.cjs +0 -2
  52. package/dist/MConflictIllustration-CfYeZVmf.cjs.map +0 -1
  53. package/dist/MConflictIllustration-Ctggjn7z.js.map +0 -1
  54. package/dist/cards-CvgcQCAP.js.map +0 -1
  55. package/dist/cards-O0osWbUF.cjs.map +0 -1
  56. package/dist/dropdowns-BP2HBR-x.cjs.map +0 -1
  57. package/dist/dropdowns-C9jREjLg.js.map +0 -1
  58. package/dist/illustrations/scenes/MCookieConsentIllustration.d.ts +0 -2
  59. package/dist/inputs-D38ib0gM.cjs +0 -2
  60. package/dist/inputs-D38ib0gM.cjs.map +0 -1
  61. package/dist/inputs-bbwdb6m3.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdowns-BJ8s18h2.js","names":[],"sources":["../src/components/dropdowns/MSelect/MSelect.tsx","../src/components/dropdowns/MAutocomplete/MAutocomplete.tsx","../src/i18n/frameworkTexts.ts","../src/utils/colorRgbVar.ts","../src/components/dropdowns/MDatePicker/MDatePicker.tsx","../src/components/dropdowns/MTimePicker/MTimePicker.tsx","../src/components/dropdowns/MDateRangePicker/MDateRangePicker.tsx"],"sourcesContent":["import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MSelectProps, MSelectOption} from './MSelect.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useKeyboardNav} from '../../../utils/useKeyboardNav'\nimport {MCheckbox} from '../../controls'\nimport {MSpinner, MTag} from '../../feedback'\nimport {MChevronDownIcon, MCloseIcon} from '../../../icons'\nimport './MSelect.css'\n\n// Render a selectable list with optional search, grouping and multi-select tags.\nexport function MSelect({\n options,\n value,\n defaultValue,\n onChange,\n multiple = false,\n searchable = false,\n placeholder = 'MSelect...',\n disabled = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n fullWidth = false,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n loading = false,\n clearable = false,\n maxHeight = 300,\n noOptionsText = 'No options',\n renderOption,\n renderValue,\n className,\n style,\n}: MSelectProps) {\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState<string | string[]>(defaultValue ?? (multiple ? [] : ''))\n const [search, setSearch] = useState('')\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const currentValue = value !== undefined ? value : internalValue\n const hasError = error || !!errorText\n\n // Normalize the public value into a string array for rendering and selection logic.\n const selectedValues = useMemo(() => {\n if (Array.isArray(currentValue)) return currentValue\n return currentValue ? [currentValue] : []\n }, [currentValue])\n\n const selectedOptions = useMemo(\n () => options.filter((o) => selectedValues.includes(o.value)),\n [options, selectedValues]\n )\n\n // Filter options locally when the searchable mode is active.\n const filteredOptions = useMemo(() => {\n if (!searchable || !search) return options\n const lower = search.toLowerCase()\n return options.filter((o) => o.label.toLowerCase().includes(lower))\n }, [options, searchable, search])\n\n // Group options\n // Preserve group headers without changing the flat keyboard navigation index map.\n const groupedOptions = useMemo(() => {\n const groups = new Map<string, MSelectOption[]>()\n for (const opt of filteredOptions) {\n const key = opt.group ?? ''\n if (!groups.has(key)) groups.set(key, [])\n groups.get(key)!.push(opt)\n }\n return groups\n }, [filteredOptions])\n\n const flatFiltered = filteredOptions\n\n // MToggle or replace the current selection depending on the mode.\n const handleSelect = useCallback(\n (index: number) => {\n const opt = flatFiltered[index]\n if (!opt || opt.disabled) return\n\n if (multiple) {\n const arr = Array.isArray(currentValue) ? currentValue : []\n const newVal = arr.includes(opt.value) ? arr.filter((v) => v !== opt.value) : [...arr, opt.value]\n if (value === undefined) setInternalValue(newVal)\n onChange?.(newVal)\n } else {\n if (value === undefined) setInternalValue(opt.value)\n onChange?.(opt.value)\n setOpen(false)\n setSearch('')\n }\n },\n [flatFiltered, multiple, currentValue, value, onChange]\n )\n\n const {activeIndex, setActiveIndex, resetIndex, onKeyDown} = useKeyboardNav({\n itemCount: flatFiltered.length,\n onSelect: handleSelect,\n onClose: () => {\n setOpen(false)\n setSearch('')\n },\n isOpen: open,\n })\n\n // Open the popover and reset keyboard navigation when the trigger is used.\n const handleTriggerClick = useCallback(() => {\n if (disabled) return\n setOpen((v) => !v)\n resetIndex()\n }, [disabled, resetIndex])\n\n // Reset the current selection without closing the outer field wrapper.\n const handleClear = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n const empty = multiple ? [] : ''\n if (value === undefined) setInternalValue(empty)\n onChange?.(empty)\n },\n [multiple, value, onChange]\n )\n\n // Render tags, labels or the placeholder based on the current selection state.\n const displayValue = useMemo(() => {\n if (renderValue && selectedOptions.length > 0) {\n return renderValue(multiple ? selectedOptions : selectedOptions[0])\n }\n if (multiple && selectedOptions.length > 0) {\n return (\n <span className=\"tags\">\n {selectedOptions.map((o) => (\n <MTag key={o.value} label={o.label} color={color} size={size} variant=\"solid\" />\n ))}\n </span>\n )\n }\n if (!multiple && selectedOptions.length > 0) {\n return selectedOptions[0].label\n }\n return <span className=\"placeholder\">{placeholder}</span>\n }, [selectedOptions, multiple, renderValue, placeholder, color, size])\n\n return (\n <div className={cn('select', color && `color-${color}`, fullWidth && 'full-width', className)} style={style}>\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={handleTriggerClick}\n onKeyDown={onKeyDown as unknown as React.KeyboardEventHandler}\n tabIndex={disabled ? -1 : 0}\n role=\"combobox\"\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-invalid={hasError || undefined}\n id={id}\n >\n <span className=\"value\">{displayValue}</span>\n\n {loading && <MSpinner size=\"sm\" color={color} />}\n\n {clearable && selectedValues.length > 0 && !loading && !disabled && (\n <button\n type=\"button\"\n className=\"clear-btn clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label=\"Clear selection\"\n >\n <MCloseIcon />\n </button>\n )}\n\n <span className={cn('arrow', open && 'open')} aria-hidden=\"true\">\n <MChevronDownIcon />\n </span>\n </div>\n\n {/* Hidden input for form submission */}\n {name && (\n <input\n type=\"hidden\"\n name={name}\n value={Array.isArray(currentValue) ? currentValue.join(',') : currentValue}\n />\n )}\n\n <MPopover\n className={'select-popover'}\n open={open}\n anchorRef={triggerRef}\n onClose={() => {\n setOpen(false)\n setSearch('')\n }}\n matchWidth\n placement=\"bottom-start\"\n >\n <div style={{maxHeight}} className=\"dropdown\">\n {searchable && (\n <div className=\"search-box\">\n <input\n type=\"text\"\n className=\"search-input\"\n placeholder=\"Search...\"\n value={search}\n onChange={(e) => {\n setSearch(e.target.value)\n setActiveIndex(0)\n }}\n onKeyDown={onKeyDown as unknown as React.KeyboardEventHandler}\n autoFocus\n />\n </div>\n )}\n\n {flatFiltered.length === 0 ? (\n <div className=\"no-options\">{noOptionsText}</div>\n ) : (\n <div className=\"options-list\" role=\"listbox\">\n {[...groupedOptions.entries()].map(([group, opts]) => (\n <div key={group}>\n {group && <div className=\"group-header\">{group}</div>}\n {opts.map((opt) => {\n const flatIndex = flatFiltered.indexOf(opt)\n const isActive = flatIndex === activeIndex\n const isSelected = selectedValues.includes(opt.value)\n return (\n <div\n key={opt.value}\n className={cn(\n 'option',\n isActive && 'active',\n isSelected && 'selected',\n opt.disabled && 'disabled'\n )}\n onClick={() => !opt.disabled && handleSelect(flatIndex)}\n onMouseEnter={() => setActiveIndex(flatIndex)}\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={opt.disabled}\n >\n {multiple && (\n <MCheckbox\n checked={isSelected}\n size=\"sm\"\n color={color}\n clickEffect=\"none\"\n className=\"select-check\"\n />\n )}\n {renderOption ? renderOption(opt, isActive, isSelected) : opt.label}\n </div>\n )\n })}\n </div>\n ))}\n </div>\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MAutocompleteProps} from './MAutocomplete.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useKeyboardNav} from '../../../utils/useKeyboardNav'\nimport {useDebouncedCallback} from '../../../utils/useDebounce'\nimport {MSpinner, MTag} from '../../feedback'\nimport {MCloseIcon} from '../../../icons'\nimport './MAutocomplete.css'\n\n// Resolve labels for primitive string options without extra configuration.\nfunction defaultGetLabel<T>(option: T): string {\n if (typeof option === 'string') return option\n return String(option)\n}\n\n// Resolve values for primitive string options without extra configuration.\nfunction defaultGetValue<T>(option: T): string {\n if (typeof option === 'string') return option\n return String(option)\n}\n\n// Apply a basic case-insensitive filter when the caller does not provide one.\nfunction defaultFilter<T>(options: T[], input: string, getLabel: (o: T) => string): T[] {\n if (!input) return options\n const lower = input.toLowerCase()\n return options.filter((o) => getLabel(o).toLowerCase().includes(lower))\n}\n\n// Render a searchable suggestion list with optional multi-tag behavior.\nexport function MAutocomplete<T = string>({\n options,\n value,\n onChange,\n getOptionLabel = defaultGetLabel,\n getOptionValue = defaultGetValue,\n filterOptions,\n multiple = false,\n debounceMs = 0,\n onInputChange,\n loading = false,\n loadingText = 'Loading...',\n noOptionsText = 'No options',\n placeholder = 'Type to search...',\n disabled = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n fullWidth = false,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n maxHeight = 300,\n renderOption,\n renderTags,\n className,\n style,\n}: MAutocompleteProps<T>) {\n const [open, setOpen] = useState(false)\n const [inputValue, setInputValue] = useState('')\n const wrapperRef = useRef<HTMLDivElement>(null)\n const inputRef = useRef<HTMLInputElement>(null)\n\n const hasError = error || !!errorText\n\n // Normalize the public value into an array for tag and selection rendering.\n const selectedValues = useMemo(() => {\n if (value == null) return []\n return Array.isArray(value) ? value.filter((item) => item != null) : [value]\n }, [value])\n\n // Filter suggestions locally unless the caller owns that logic.\n const filtered = useMemo(() => {\n if (filterOptions) return filterOptions(options, inputValue)\n return defaultFilter(options, inputValue, getOptionLabel)\n }, [options, inputValue, filterOptions, getOptionLabel])\n\n const debouncedInputChange = useDebouncedCallback((val: string) => onInputChange?.(val), debounceMs)\n\n // Update the visible query and optionally notify async search logic.\n const handleInputChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setInputValue(e.target.value)\n debouncedInputChange(e.target.value)\n if (!open) setOpen(true)\n },\n [open, debouncedInputChange]\n )\n\n // Apply a selected option to single or multiple value modes.\n const handleSelect = useCallback(\n (index: number) => {\n const opt = filtered[index]\n if (!opt) return\n\n if (multiple) {\n const arr = [...selectedValues]\n const val = getOptionValue(opt)\n const existIdx = arr.findIndex((v) => getOptionValue(v) === val)\n if (existIdx >= 0) {\n arr.splice(existIdx, 1)\n } else {\n arr.push(opt)\n }\n onChange?.(arr)\n setInputValue('')\n inputRef.current?.focus()\n } else {\n onChange?.(opt)\n setInputValue(getOptionLabel(opt))\n setOpen(false)\n }\n },\n [filtered, multiple, selectedValues, getOptionValue, getOptionLabel, onChange]\n )\n\n // Remove a selected tag by index in multiple mode.\n const handleRemoveTag = useCallback(\n (index: number) => {\n const arr = [...selectedValues]\n arr.splice(index, 1)\n onChange?.(multiple ? arr : (arr[0] ?? ('' as unknown as T)))\n },\n [selectedValues, onChange, multiple]\n )\n\n const {\n activeIndex,\n setActiveIndex,\n resetIndex,\n onKeyDown: navKeyDown,\n } = useKeyboardNav({\n itemCount: filtered.length,\n onSelect: handleSelect,\n onClose: () => setOpen(false),\n isOpen: open,\n })\n\n // Combine tag removal and list navigation.\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n // Backspace removes last tag in multiple\n if (e.key === 'Backspace' && multiple && !inputValue && selectedValues.length > 0) {\n handleRemoveTag(selectedValues.length - 1)\n return\n }\n navKeyDown(e as unknown as React.KeyboardEvent)\n },\n [inputValue, multiple, selectedValues, navKeyDown, handleRemoveTag]\n )\n\n // Clear the input query and the selected value(s) together.\n const handleClear = useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation()\n setInputValue('')\n onChange?.(multiple ? ([] as unknown as T) : ('' as unknown as T))\n inputRef.current?.focus()\n },\n [multiple, onChange]\n )\n\n return (\n <div\n className={cn('autocomplete', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={wrapperRef}\n className={cn(\n 'input-wrapper',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => inputRef.current?.focus()}\n >\n {multiple &&\n selectedValues.length > 0 &&\n (renderTags ? (\n renderTags(selectedValues, handleRemoveTag)\n ) : (\n <span className=\"tags\">\n {selectedValues.map((v, i) => (\n <MTag\n key={getOptionValue(v)}\n label={getOptionLabel(v)}\n color={color}\n size={size}\n variant=\"solid\"\n closable\n onClose={() => handleRemoveTag(i)}\n />\n ))}\n </span>\n ))}\n\n <input\n ref={inputRef}\n type=\"text\"\n className=\"input\"\n value={inputValue}\n onChange={handleInputChange}\n onFocus={() => {\n setOpen(true)\n resetIndex()\n }}\n onKeyDown={handleKeyDown}\n placeholder={selectedValues.length > 0 ? '' : placeholder}\n disabled={disabled}\n id={id}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-invalid={hasError || undefined}\n autoComplete=\"off\"\n />\n\n {loading && <MSpinner size=\"sm\" color={color} />}\n\n {clearable && (selectedValues.length > 0 || inputValue) && !loading && !disabled && (\n <button type=\"button\" className=\"clear-btn clear-btn-base\" onClick={handleClear} tabIndex={-1}>\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && <input type=\"hidden\" name={name} value={selectedValues.map(getOptionValue).join(',')} />}\n\n <MPopover\n className={cn('autocomplete-popover', color && `color-${color}`)}\n open={open && (filtered.length > 0 || loading || !!inputValue)}\n anchorRef={wrapperRef}\n onClose={() => setOpen(false)}\n matchWidth\n placement=\"bottom-start\"\n >\n <div style={{maxHeight}} className=\"dropdown\">\n {loading ? (\n <div className=\"loading-msg\">{loadingText}</div>\n ) : filtered.length === 0 ? (\n <div className=\"no-options\">{noOptionsText}</div>\n ) : (\n <div className=\"options-list\" role=\"listbox\">\n {filtered.map((opt, i) => {\n const isActive = i === activeIndex\n const isSelected = selectedValues.some((v) => getOptionValue(v) === getOptionValue(opt))\n return (\n <div\n key={getOptionValue(opt)}\n className={cn('option', isActive && 'active', isSelected && 'selected')}\n onClick={() => handleSelect(i)}\n onMouseEnter={() => setActiveIndex(i)}\n role=\"option\"\n aria-selected={isSelected}\n >\n {renderOption ? renderOption(opt, isActive) : getOptionLabel(opt)}\n </div>\n )\n })}\n </div>\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n","import {useCallback, useMemo} from 'react'\nimport {useOptionalMI18n} from './MI18nProvider'\n\nfunction useTranslate() {\n const i18n = useOptionalMI18n()\n\n return useCallback((key: string, fallback: string) => i18n?.t(key, fallback) ?? fallback, [i18n])\n}\n\nexport interface MDatePickerTexts {\n today: string\n clear: string\n previousMonth: string\n nextMonth: string\n}\n\nexport interface MDateRangePickerTexts extends MDatePickerTexts {\n rangeSubtitle: string\n defaultRangePlaceholder: string\n presets: {\n today: string\n days2: string\n days3: string\n days7: string\n days14: string\n days31: string\n thisMonth: string\n previousMonth: string\n months2: string\n months3: string\n months6: string\n year1: string\n }\n}\n\nexport interface MCalendarBoardTexts {\n monthView: string\n weekView: string\n previousWeek: string\n nextWeek: string\n emptyStateText: string\n timelineTitle: string\n timelineEmptyState: string\n allDay: string\n allDayTab: string\n timelineTab: string\n itemsCount: (count: number) => string\n}\n\nexport interface MFileManagerTexts {\n home: string\n searchPlaceholder: string\n emptyText: string\n folders: string\n noFoldersAvailable: string\n currentFolder: string\n filteredBy: (query: string) => string\n listView: string\n gridView: string\n folder: string\n file: string\n preview: string\n path: string\n selectItemToInspect: string\n itemsCount: (count: number) => string\n rename: string\n moveTo: string\n delete: string\n download: string\n newFolder: string\n}\n\nexport function useMDatePickerTexts(): MDatePickerTexts {\n const t = useTranslate()\n\n return useMemo(\n () => ({\n today: t('mineralui.datePicker.today', 'Today'),\n clear: t('mineralui.datePicker.clear', 'Clear'),\n previousMonth: t('mineralui.datePicker.previousMonth', 'Previous month'),\n nextMonth: t('mineralui.datePicker.nextMonth', 'Next month'),\n }),\n [t]\n )\n}\n\nexport function useMDateRangePickerTexts(): MDateRangePickerTexts {\n const t = useTranslate()\n\n return useMemo(\n () => ({\n today: t('mineralui.dateRangePicker.today', 'Today'),\n clear: t('mineralui.dateRangePicker.clear', 'Clear'),\n previousMonth: t('mineralui.dateRangePicker.previousMonth', 'Previous month'),\n nextMonth: t('mineralui.dateRangePicker.nextMonth', 'Next month'),\n rangeSubtitle: t('mineralui.dateRangePicker.rangeSubtitle', 'Select start and end dates in one panel.'),\n defaultRangePlaceholder: t('mineralui.dateRangePicker.defaultRangePlaceholder', 'Select date range...'),\n presets: {\n today: t('mineralui.dateRangePicker.presets.today', 'Today'),\n days2: t('mineralui.dateRangePicker.presets.days2', '2 days'),\n days3: t('mineralui.dateRangePicker.presets.days3', '3 days'),\n days7: t('mineralui.dateRangePicker.presets.days7', '7 days'),\n days14: t('mineralui.dateRangePicker.presets.days14', '14 days'),\n days31: t('mineralui.dateRangePicker.presets.days31', '31 days'),\n thisMonth: t('mineralui.dateRangePicker.presets.thisMonth', 'This month'),\n previousMonth: t('mineralui.dateRangePicker.presets.previousMonth', 'Previous month'),\n months2: t('mineralui.dateRangePicker.presets.months2', '2 months'),\n months3: t('mineralui.dateRangePicker.presets.months3', '3 months'),\n months6: t('mineralui.dateRangePicker.presets.months6', '6 months'),\n year1: t('mineralui.dateRangePicker.presets.year1', '1 year'),\n },\n }),\n [t]\n )\n}\n\nexport function useMCalendarBoardTexts(): MCalendarBoardTexts {\n const t = useTranslate()\n\n return useMemo(\n () => ({\n monthView: t('mineralui.calendarBoard.monthView', 'Month'),\n weekView: t('mineralui.calendarBoard.weekView', 'Week'),\n previousWeek: t('mineralui.calendarBoard.previousWeek', 'Previous week'),\n nextWeek: t('mineralui.calendarBoard.nextWeek', 'Next week'),\n emptyStateText: t('mineralui.calendarBoard.emptyStateText', 'No events for the selected day.'),\n timelineTitle: t('mineralui.calendarBoard.timelineTitle', 'Daily timeline'),\n timelineEmptyState: t('mineralui.calendarBoard.timelineEmptyState', 'No events in this hour.'),\n allDay: t('mineralui.calendarBoard.allDay', 'All day'),\n allDayTab: t('mineralui.calendarBoard.allDayTab', 'All day'),\n timelineTab: t('mineralui.calendarBoard.timelineTab', 'Hourly timeline'),\n itemsCount: (count) =>\n t('mineralui.calendarBoard.itemsCount', '{count} items').replace('{count}', String(count)),\n }),\n [t]\n )\n}\n\nexport function useMFileManagerTexts(): MFileManagerTexts {\n const t = useTranslate()\n\n return useMemo(\n () => ({\n home: t('mineralui.fileManager.home', 'Home'),\n searchPlaceholder: t('mineralui.fileManager.searchPlaceholder', 'Search in folder...'),\n emptyText: t('mineralui.fileManager.emptyText', 'This folder is empty.'),\n folders: t('mineralui.fileManager.folders', 'Folders'),\n noFoldersAvailable: t('mineralui.fileManager.noFoldersAvailable', 'No folders available.'),\n currentFolder: t('mineralui.fileManager.currentFolder', 'Current folder'),\n filteredBy: (query) =>\n t('mineralui.fileManager.filteredBy', 'Filtered by \"{query}\"').replace('{query}', query),\n listView: t('mineralui.fileManager.listView', 'List'),\n gridView: t('mineralui.fileManager.gridView', 'Grid'),\n folder: t('mineralui.fileManager.folder', 'Folder'),\n file: t('mineralui.fileManager.file', 'File'),\n preview: t('mineralui.fileManager.preview', 'Preview'),\n path: t('mineralui.fileManager.path', 'Path'),\n selectItemToInspect: t(\n 'mineralui.fileManager.selectItemToInspect',\n 'Select a file or folder to inspect its details.'\n ),\n itemsCount: (count) =>\n t('mineralui.fileManager.itemsCount', '{count} items').replace('{count}', String(count)),\n rename: t('mineralui.fileManager.rename', 'Rename'),\n moveTo: t('mineralui.fileManager.moveTo', 'Move to...'),\n delete: t('mineralui.fileManager.delete', 'Delete'),\n download: t('mineralui.fileManager.download', 'Download'),\n newFolder: t('mineralui.fileManager.newFolder', 'New folder'),\n }),\n [t]\n )\n}\n\n// Cookie-consent texts moved to @banzamel/honey in mineralui-pro 2.0.0.\n// Consumers that need to retheme cookie copy now pass `texts` directly to\n// `<CookieConsentProvider>` from `@banzamel/honey`.\n","const COLOR_MAP: Record<string, string> = {\n primary: 'var(--mineral-primary-rgb)',\n neutral: 'var(--mineral-neutral-rgb)',\n success: 'var(--mineral-success-rgb)',\n error: 'var(--mineral-error-rgb)',\n warning: 'var(--mineral-warning-rgb)',\n info: 'var(--mineral-info-rgb)',\n light: 'var(--mineral-light-rgb)',\n dark: 'var(--mineral-dark-color-rgb)',\n news: 'var(--mineral-news-rgb)',\n}\n\nexport function colorRgbVar(color: string | undefined): string {\n return COLOR_MAP[color ?? 'primary'] ?? COLOR_MAP.primary\n}\n","import {useState, useRef, useCallback, useMemo, useEffect} from 'react'\nimport type * as React from 'react'\nimport type {MDatePickerProps} from './MDatePicker.types'\nimport type {MDateFormat} from '../../inputs'\nimport {MInput} from '../../inputs'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useMDatePickerTexts} from '../../../i18n/frameworkTexts'\nimport {useDocumentLocale} from '../../../utils/locale'\nimport type {ValidationResult} from '../../../utils/validators'\nimport {parseDateString, validateDate} from '../../../utils/validators'\nimport {stripNonDigits, formatDateInput} from '../../../utils/formatters'\nimport {colorRgbVar} from '../../../utils/colorRgbVar'\nimport {\n formatDate,\n daysInMonth,\n firstDayOfMonth,\n isSameDay,\n isDateInRange,\n getDayNames,\n getMonthNames,\n addMonths,\n stripTime,\n combineDateAndTime,\n formatHiddenDateValue,\n formatTimeWithFormat,\n parseTimeWithFormat,\n} from '../../../utils/dateUtils'\nimport {\n MCalendarIcon,\n MChevronLeftIcon as ChevronLeftGlyphIcon,\n MChevronRightIcon as ChevronRightGlyphIcon,\n} from '../../../icons'\nimport './MDatePicker.css'\n\nconst DATE_UNAVAILABLE_ERROR = 'Date is unavailable'\nconst INVALID_TIME_ERROR = 'Invalid time'\n\ntype Meridiem = 'AM' | 'PM'\n\ntype MDatePickerInputConfig = {\n inputFormat: MDateFormat\n separator: '/' | '.' | '-'\n}\n\ntype ParsedInputState =\n | {status: 'empty'}\n | {status: 'partial'; datePart: string; timePart: string}\n | {status: 'invalid'; datePart: string; timePart: string; result: ValidationResult}\n | {status: 'valid'; datePart: string; timePart: string; value: Date}\n\nfunction toDate(value: Date | string | undefined): Date | null {\n if (!value) return null\n if (value instanceof Date) return isNaN(value.getTime()) ? null : new Date(value.getTime())\n\n const date = new Date(value)\n return isNaN(date.getTime()) ? null : date\n}\n\nfunction normalizeDatePickerFormat(format: string): MDatePickerInputConfig {\n const normalizedFormat = format.replace(/DD/g, 'dd').replace(/YYYY/g, 'yyyy')\n const tokens = normalizedFormat.match(/dd|MM|yyyy/g)\n const detectedSeparator = normalizedFormat.match(/[^dMy]/)?.[0]\n const separator =\n detectedSeparator === '/' || detectedSeparator === '.' || detectedSeparator === '-' ? detectedSeparator : '.'\n const order = tokens?.join('/')\n\n switch (order) {\n case 'MM/dd/yyyy':\n return {inputFormat: 'MM/DD/YYYY', separator}\n case 'yyyy/MM/dd':\n return {inputFormat: 'YYYY/MM/DD', separator}\n case 'dd/MM/yyyy':\n default:\n return {inputFormat: 'DD/MM/YYYY', separator}\n }\n}\n\nfunction getDefaultTimePlaceholder(format: '24h' | '12h', showSeconds: boolean): string {\n if (format === '12h') {\n return showSeconds ? 'hh:mm:ss AM' : 'hh:mm AM'\n }\n\n return showSeconds ? 'HH:MM:SS' : 'HH:MM'\n}\n\nfunction getInputPlaceholder(\n basePlaceholder: string | undefined,\n dateFormat: string,\n withTime: boolean,\n timeFormat: '24h' | '12h',\n showSeconds: boolean,\n timePlaceholder?: string\n): string {\n if (basePlaceholder) {\n return basePlaceholder\n }\n\n if (!withTime) {\n return dateFormat\n }\n\n return `${dateFormat} ${timePlaceholder ?? getDefaultTimePlaceholder(timeFormat, showSeconds)}`\n}\n\nfunction formatDisplayValue(\n date: Date | null,\n options: {\n format: string\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n }\n): string {\n if (!date) return ''\n\n const datePart = formatDate(stripTime(date), options.format)\n\n if (!options.withTime) {\n return datePart\n }\n\n return `${datePart} ${formatTimeWithFormat(\n date.getHours(),\n date.getMinutes(),\n date.getSeconds(),\n options.showSeconds,\n options.timeFormat\n )}`\n}\n\nfunction formatTimeDraft(digits: string, showSeconds: boolean): string {\n if (!digits) return ''\n\n if (digits.length <= 2) return digits\n if (digits.length <= 4) return `${digits.slice(0, 2)}:${digits.slice(2)}`\n if (!showSeconds) return `${digits.slice(0, 2)}:${digits.slice(2, 4)}`\n return `${digits.slice(0, 2)}:${digits.slice(2, 4)}:${digits.slice(4, 6)}`\n}\n\nfunction normalizeMeridiemDraft(value: string): string {\n const letters = value.toUpperCase().replace(/[^APM]/g, '')\n\n if (!letters) return ''\n if (letters.startsWith('AM')) return 'AM'\n if (letters.startsWith('PM')) return 'PM'\n if (letters.startsWith('A')) return 'A'\n if (letters.startsWith('P')) return 'P'\n\n return ''\n}\n\nfunction splitInputValue(value: string, withTime: boolean) {\n const trimmed = value.trim()\n\n if (!trimmed) {\n return {datePart: '', timePart: ''}\n }\n\n if (!withTime) {\n return {datePart: trimmed, timePart: ''}\n }\n\n const firstSpaceIndex = trimmed.indexOf(' ')\n\n if (firstSpaceIndex === -1) {\n return {datePart: trimmed, timePart: ''}\n }\n\n return {\n datePart: trimmed.slice(0, firstSpaceIndex).trim(),\n timePart: trimmed.slice(firstSpaceIndex + 1).trim(),\n }\n}\n\nfunction formatTypedInput(\n rawValue: string,\n options: {\n inputFormat: MDateFormat\n separator: '/' | '.' | '-'\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n }\n) {\n const normalizedValue = rawValue.toUpperCase()\n const digits = stripNonDigits(normalizedValue)\n const dateDigits = digits.slice(0, 8)\n const timeDigits = options.withTime ? digits.slice(8, 8 + (options.showSeconds ? 6 : 4)) : ''\n const datePart = formatDateInput(dateDigits, options.inputFormat, options.separator)\n\n if (!options.withTime) {\n return {formatted: datePart, datePart, timePart: ''}\n }\n\n const timeBase = formatTimeDraft(timeDigits, options.showSeconds)\n const meridiem = options.timeFormat === '12h' ? normalizeMeridiemDraft(normalizedValue) : ''\n const timePart = `${timeBase}${meridiem ? `${timeBase ? ' ' : ''}${meridiem}` : ''}`.trim()\n\n if (!datePart) {\n return {formatted: timePart, datePart: '', timePart}\n }\n\n // Preserve the space delimiter once the date is complete so the user can keep typing the time.\n const dateComplete = dateDigits.length === 8\n const userTypedSpaceAfterDate = /\\s/.test(normalizedValue.slice(datePart.length))\n const showSpace = timePart || (dateComplete && userTypedSpaceAfterDate)\n\n return {\n formatted: showSpace ? `${datePart} ${timePart}` : datePart,\n datePart,\n timePart,\n }\n}\n\nfunction getTimeDraftFromDate(date: Date | null, showSeconds: boolean): string {\n if (!date) return ''\n return formatTimeWithFormat(date.getHours(), date.getMinutes(), date.getSeconds(), showSeconds, '24h')\n}\n\nfunction parseInputValue(\n value: string,\n options: {\n inputFormat: MDateFormat\n minDate: Date | null\n maxDate: Date | null\n withTime: boolean\n timeFormat: '24h' | '12h'\n showSeconds: boolean\n isDisabled: (date: Date) => boolean\n }\n): ParsedInputState {\n const {datePart, timePart} = splitInputValue(value, options.withTime)\n\n if (!datePart && !timePart) {\n return {status: 'empty'}\n }\n\n const validation = validateDate(datePart, {\n format: options.inputFormat,\n minDate: options.minDate ?? undefined,\n maxDate: options.maxDate ?? undefined,\n })\n\n if (!validation.valid) {\n return validation.error === 'Incomplete date'\n ? {status: 'partial', datePart, timePart}\n : {status: 'invalid', datePart, timePart, result: validation}\n }\n\n const parsedDate = parseDateString(datePart, options.inputFormat)\n\n if (!parsedDate) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: 'Invalid date'}}\n }\n\n if (options.isDisabled(parsedDate)) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: DATE_UNAVAILABLE_ERROR}}\n }\n\n if (!options.withTime) {\n return {status: 'valid', datePart, timePart: '', value: stripTime(parsedDate)}\n }\n\n if (!timePart) {\n return {\n status: 'valid',\n datePart,\n timePart: '',\n value: combineDateAndTime(parsedDate, '', {format: options.timeFormat, showSeconds: options.showSeconds}),\n }\n }\n\n const parsedTime = parseTimeWithFormat(timePart, options.timeFormat)\n\n if (!parsedTime) {\n return {status: 'invalid', datePart, timePart, result: {valid: false, error: INVALID_TIME_ERROR}}\n }\n\n return {\n status: 'valid',\n datePart,\n timePart,\n value: combineDateAndTime(parsedDate, timePart, {format: options.timeFormat, showSeconds: options.showSeconds}),\n }\n}\n\nfunction to12HourParts(value: {hours: number; minutes: number; seconds: number}) {\n const meridiem: Meridiem = value.hours >= 12 ? 'PM' : 'AM'\n const hours = value.hours % 12 || 12\n return {hours, minutes: value.minutes, seconds: value.seconds, meridiem}\n}\n\nfunction to24HourValue(hours: number, meridiem: Meridiem): number {\n if (meridiem === 'AM') {\n return hours === 12 ? 0 : hours\n }\n\n return hours === 12 ? 12 : hours + 12\n}\n\nexport function MDatePicker({\n value,\n defaultValue,\n onChange,\n format = 'dd.MM.yyyy',\n locale: localeOverride,\n min,\n max,\n disabledDates,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n withTime = false,\n validateOnBlur = true,\n validateOnChange = false,\n onValidationChange,\n timeFormat = '24h',\n showSeconds = false,\n minuteStep = 1,\n timePlaceholder,\n inline = false,\n showTodayButton = true,\n firstDayOfWeek = 1,\n fullWidth = false,\n className,\n style,\n}: MDatePickerProps) {\n const locale = useDocumentLocale(localeOverride)\n const texts = useMDatePickerTexts()\n const {inputFormat, separator} = useMemo(() => normalizeDatePickerFormat(format), [format])\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState<Date | null>(() => toDate(defaultValue))\n const [validationState, setValidationState] = useState<ValidationResult>({valid: true})\n const [touched, setTouched] = useState(false)\n const selectedValue = value !== undefined ? toDate(value) : internalValue\n const [inputValue, setInputValue] = useState(() =>\n formatDisplayValue(selectedValue, {format, withTime, timeFormat, showSeconds})\n )\n const [draftTimeValue, setDraftTimeValue] = useState(() => getTimeDraftFromDate(selectedValue, showSeconds))\n const [viewDate, setViewDate] = useState(() => {\n const baseDate = selectedValue ? stripTime(selectedValue) : new Date()\n return new Date(baseDate.getFullYear(), baseDate.getMonth(), 1)\n })\n const [viewMode, setViewMode] = useState<'days' | 'months'>('days')\n const anchorRef = useRef<HTMLDivElement>(null)\n const selectedValueKey = selectedValue?.getTime() ?? null\n const minDate = toDate(min)\n const maxDate = toDate(max)\n const hasError = error || (touched && !validationState.valid)\n const resolvedErrorText = errorText || (touched && !validationState.valid ? validationState.error : undefined)\n const dayNames = getDayNames(locale, firstDayOfWeek)\n const monthNames = getMonthNames(locale)\n\n useEffect(() => {\n setInputValue(formatDisplayValue(selectedValue, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(selectedValue, showSeconds))\n if (selectedValue) {\n const normalizedDate = stripTime(selectedValue)\n setViewDate(new Date(normalizedDate.getFullYear(), normalizedDate.getMonth(), 1))\n }\n }, [format, selectedValueKey, showSeconds, timeFormat, withTime])\n\n const isDisabled = useCallback(\n (date: Date): boolean => {\n if (!isDateInRange(date, minDate, maxDate)) return true\n if (Array.isArray(disabledDates)) {\n return disabledDates.some((disabledDate) => isSameDay(disabledDate, date))\n }\n if (typeof disabledDates === 'function') {\n return disabledDates(date)\n }\n return false\n },\n [disabledDates, maxDate, minDate]\n )\n\n const emitValidation = useCallback(\n (result: ValidationResult) => {\n setValidationState(result)\n onValidationChange?.(result)\n },\n [onValidationChange]\n )\n\n const commitValue = useCallback(\n (nextValue: Date | null) => {\n if (value === undefined) {\n setInternalValue(nextValue)\n }\n\n onChange?.(nextValue)\n },\n [onChange, value]\n )\n\n const parsedInputState = useMemo(\n () =>\n parseInputValue(inputValue, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n }),\n [inputFormat, inputValue, isDisabled, maxDate, minDate, showSeconds, timeFormat, withTime]\n )\n\n const currentDateForPanel = useMemo(() => {\n if (parsedInputState.status === 'valid') {\n return stripTime(parsedInputState.value)\n }\n\n return selectedValue ? stripTime(selectedValue) : null\n }, [parsedInputState, selectedValue])\n\n const currentTimeForPanel = useMemo(() => {\n if (!withTime) return null\n\n const timeSource =\n parsedInputState.status !== 'empty' && parsedInputState.timePart\n ? parsedInputState.timePart\n : draftTimeValue || getTimeDraftFromDate(selectedValue, showSeconds)\n\n return parseTimeWithFormat(timeSource, timeFormat) ?? {hours: 0, minutes: 0, seconds: 0}\n }, [draftTimeValue, parsedInputState, selectedValue, showSeconds, timeFormat, withTime])\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const nextTyped = formatTypedInput(event.target.value, {\n inputFormat,\n separator,\n withTime,\n timeFormat,\n showSeconds,\n })\n\n setInputValue(nextTyped.formatted)\n setDraftTimeValue(nextTyped.timePart)\n\n const nextParsedState = parseInputValue(nextTyped.formatted, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (nextParsedState.status === 'empty') {\n emitValidation({valid: true})\n commitValue(null)\n return\n }\n\n if (nextParsedState.status === 'invalid' && validateOnChange) {\n emitValidation(nextParsedState.result)\n } else if (nextParsedState.status === 'valid') {\n emitValidation({valid: true})\n setViewDate(new Date(nextParsedState.value.getFullYear(), nextParsedState.value.getMonth(), 1))\n // Hold the commit until the time is fully typed so the formatter doesn't pad\n // partial minutes/seconds (e.g. \"21:3\" → \"21:03\") and overwrite the cursor while typing.\n // Blur falls back to 00:00 via the INVALID_TIME_ERROR retry if the user never finishes.\n const requiredTimeDigits = showSeconds ? 6 : 4\n const typedTimeDigits = withTime ? stripNonDigits(event.target.value).slice(8).length : 0\n const timeComplete = !withTime || typedTimeDigits >= requiredTimeDigits\n if (timeComplete) {\n commitValue(nextParsedState.value)\n }\n }\n },\n [\n commitValue,\n emitValidation,\n inputFormat,\n isDisabled,\n maxDate,\n minDate,\n separator,\n showSeconds,\n timeFormat,\n validateOnChange,\n withTime,\n ]\n )\n\n const handleInputBlur = useCallback(() => {\n setTouched(true)\n\n const nextParsedState = parseInputValue(inputValue, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (nextParsedState.status === 'empty') {\n emitValidation({valid: true})\n return\n }\n\n if (nextParsedState.status === 'partial') {\n if (validateOnBlur) {\n emitValidation({valid: false, error: 'Incomplete date'})\n }\n return\n }\n\n if (nextParsedState.status === 'invalid') {\n // Out-of-range time entry (e.g. 48:69) clamps to 00:00 on blur instead of staying invalid.\n if (withTime && nextParsedState.result.error === INVALID_TIME_ERROR && nextParsedState.datePart) {\n const fallbackTimePart = formatTimeWithFormat(0, 0, 0, showSeconds, timeFormat)\n const retry = parseInputValue(`${nextParsedState.datePart} ${fallbackTimePart}`, {\n inputFormat,\n minDate,\n maxDate,\n withTime,\n timeFormat,\n showSeconds,\n isDisabled,\n })\n\n if (retry.status === 'valid') {\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(retry.value, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(retry.value, showSeconds))\n commitValue(retry.value)\n return\n }\n }\n\n if (validateOnBlur) {\n emitValidation(nextParsedState.result)\n }\n return\n }\n\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(nextParsedState.value, {format, withTime, timeFormat, showSeconds}))\n setDraftTimeValue(getTimeDraftFromDate(nextParsedState.value, showSeconds))\n commitValue(nextParsedState.value)\n }, [\n commitValue,\n emitValidation,\n format,\n inputFormat,\n inputValue,\n isDisabled,\n maxDate,\n minDate,\n showSeconds,\n timeFormat,\n validateOnBlur,\n withTime,\n ])\n\n const handleInputKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (['Backspace', 'Delete', 'Tab', 'ArrowLeft', 'ArrowRight', 'Home', 'End', 'Enter'].includes(event.key)) {\n return\n }\n\n if (event.ctrlKey || event.metaKey) {\n return\n }\n\n const allowCharacter = withTime ? /^[0-9\\s:./-APMapm]$/ : /^[0-9./-]$/\n\n if (!allowCharacter.test(event.key)) {\n event.preventDefault()\n }\n },\n [withTime]\n )\n\n const handleClear = useCallback(() => {\n setInputValue('')\n setDraftTimeValue('')\n setTouched(false)\n emitValidation({valid: true})\n commitValue(null)\n }, [commitValue, emitValidation])\n\n const handleTogglePopover = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault()\n event.stopPropagation()\n\n if (disabled || readOnly || inline) return\n\n setOpen((current) => !current)\n },\n [disabled, inline, readOnly]\n )\n\n const handleSelectDate = useCallback(\n (date: Date) => {\n if (isDisabled(date)) return\n\n const nextTime = withTime ? draftTimeValue || formatTimeWithFormat(0, 0, 0, showSeconds, timeFormat) : ''\n const nextValue = withTime\n ? combineDateAndTime(date, nextTime, {format: timeFormat, showSeconds})\n : stripTime(date)\n\n setTouched(true)\n emitValidation({valid: true})\n setDraftTimeValue(nextTime)\n setInputValue(formatDisplayValue(nextValue, {format, withTime, timeFormat, showSeconds}))\n setViewDate(new Date(date.getFullYear(), date.getMonth(), 1))\n commitValue(nextValue)\n\n if (!withTime && !inline) {\n setOpen(false)\n }\n },\n [commitValue, draftTimeValue, emitValidation, format, inline, isDisabled, showSeconds, timeFormat, withTime]\n )\n\n const handleToday = useCallback(() => {\n const today = stripTime(new Date())\n\n if (isDisabled(today)) return\n\n handleSelectDate(today)\n }, [handleSelectDate, isDisabled])\n\n const hours = useMemo(() => {\n if (!withTime) return []\n\n const items: number[] = []\n const maxHour = timeFormat === '12h' ? 12 : 23\n const startHour = timeFormat === '12h' ? 1 : 0\n\n for (let index = startHour; index <= maxHour; index += 1) {\n items.push(index)\n }\n\n return items\n }, [timeFormat, withTime])\n\n const minutes = useMemo(() => {\n if (!withTime) return []\n\n const items: number[] = []\n\n for (let index = 0; index < 60; index += minuteStep) {\n items.push(index)\n }\n\n return items\n }, [minuteStep, withTime])\n\n const seconds = useMemo(() => {\n if (!withTime || !showSeconds) return []\n\n const items: number[] = []\n\n for (let index = 0; index < 60; index += 1) {\n items.push(index)\n }\n\n return items\n }, [showSeconds, withTime])\n\n const handleTimeSelection = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n const formattedTime = formatTimeWithFormat(hoursValue, minutesValue, secondsValue, showSeconds, timeFormat)\n const nextDate = currentDateForPanel\n\n setTouched(true)\n setDraftTimeValue(formattedTime)\n\n if (!nextDate) {\n setInputValue(formattedTime)\n return\n }\n\n const nextValue = combineDateAndTime(nextDate, formattedTime, {format: timeFormat, showSeconds})\n\n emitValidation({valid: true})\n setInputValue(formatDisplayValue(nextValue, {format, withTime, timeFormat, showSeconds}))\n commitValue(nextValue)\n },\n [commitValue, currentDateForPanel, emitValidation, format, showSeconds, timeFormat, withTime]\n )\n\n const handleMeridiemChange = useCallback(\n (meridiem: Meridiem) => {\n const currentHours = currentTimeForPanel ? to12HourParts(currentTimeForPanel).hours : 12\n const nextHours = to24HourValue(currentHours, meridiem)\n\n handleTimeSelection(nextHours, currentTimeForPanel?.minutes ?? 0, currentTimeForPanel?.seconds ?? 0)\n },\n [currentTimeForPanel, handleTimeSelection]\n )\n\n const calendarDays = useMemo(() => {\n const year = viewDate.getFullYear()\n const month = viewDate.getMonth()\n const totalDays = daysInMonth(year, month)\n let startDay = firstDayOfMonth(year, month)\n\n if (firstDayOfWeek === 1) {\n startDay = startDay === 0 ? 6 : startDay - 1\n }\n\n const days: Array<{date: Date; currentMonth: boolean}> = []\n const prevMonth = month === 0 ? 11 : month - 1\n const prevYear = month === 0 ? year - 1 : year\n const prevDays = daysInMonth(prevYear, prevMonth)\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push({date: new Date(prevYear, prevMonth, prevDays - index), currentMonth: false})\n }\n\n for (let day = 1; day <= totalDays; day += 1) {\n days.push({date: new Date(year, month, day), currentMonth: true})\n }\n\n const remaining = 42 - days.length\n const nextMonth = month === 11 ? 0 : month + 1\n const nextYear = month === 11 ? year + 1 : year\n\n for (let day = 1; day <= remaining; day += 1) {\n days.push({date: new Date(nextYear, nextMonth, day), currentMonth: false})\n }\n\n return days\n }, [firstDayOfWeek, viewDate])\n\n const today = stripTime(new Date())\n const selectedDate = selectedValue ? stripTime(selectedValue) : currentDateForPanel\n\n const renderCalendar = () => (\n <div className=\"calendar\">\n <div className=\"calendar-header\">\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, -1))}\n aria-label={texts.previousMonth}\n >\n <ChevronLeftGlyphIcon />\n </button>\n <button\n type=\"button\"\n className=\"header-title\"\n onClick={() => setViewMode((current) => (current === 'days' ? 'months' : 'days'))}\n >\n {monthNames[viewDate.getMonth()]} {viewDate.getFullYear()}\n </button>\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, 1))}\n aria-label={texts.nextMonth}\n >\n <ChevronRightGlyphIcon />\n </button>\n </div>\n\n {viewMode === 'days' ? (\n <>\n <div className=\"day-names\">\n {dayNames.map((dayName) => (\n <span key={dayName} className=\"day-name\">\n {dayName}\n </span>\n ))}\n </div>\n\n <div className=\"day-grid\">\n {calendarDays.map(({date, currentMonth}, index) => {\n const isSelected = selectedDate ? isSameDay(date, selectedDate) : false\n const isToday = isSameDay(date, today)\n const disabledDay = isDisabled(date)\n\n return (\n <button\n key={`${date.toISOString()}-${index}`}\n type=\"button\"\n className={cn(\n 'day',\n !currentMonth && 'other-month',\n isToday && 'today',\n isSelected && 'selected',\n disabledDay && 'disabled'\n )}\n onClick={() => handleSelectDate(date)}\n disabled={disabledDay}\n tabIndex={-1}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </>\n ) : (\n <div className=\"month-grid\">\n {monthNames.map((monthName, index) => (\n <button\n key={monthName}\n type=\"button\"\n className={cn('month-cell', viewDate.getMonth() === index && 'selected')}\n onClick={() => {\n setViewDate(new Date(viewDate.getFullYear(), index, 1))\n setViewMode('days')\n }}\n >\n {monthName.slice(0, 3)}\n </button>\n ))}\n </div>\n )}\n\n {showTodayButton && (\n <div className=\"footer\">\n <button type=\"button\" className=\"today-btn\" onClick={handleToday}>\n {texts.today}\n </button>\n </div>\n )}\n </div>\n )\n\n const renderTimePanel = () => {\n if (!withTime) return null\n\n const displayTime = currentTimeForPanel ? to12HourParts(currentTimeForPanel) : null\n\n return (\n <div className=\"date-picker-time-panel\">\n <div className=\"date-picker-time-header\">Time</div>\n <div className=\"date-picker-time-columns\">\n <TimeColumn\n items={hours}\n selected={timeFormat === '12h' ? displayTime?.hours : currentTimeForPanel?.hours}\n onSelect={(hoursValue) =>\n handleTimeSelection(\n timeFormat === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n currentTimeForPanel?.minutes ?? 0,\n currentTimeForPanel?.seconds ?? 0\n )\n }\n label=\"Hr\"\n />\n <TimeColumn\n items={minutes}\n selected={currentTimeForPanel?.minutes}\n onSelect={(minutesValue) =>\n handleTimeSelection(\n currentTimeForPanel?.hours ?? 0,\n minutesValue,\n currentTimeForPanel?.seconds ?? 0\n )\n }\n label=\"Min\"\n />\n {showSeconds && (\n <TimeColumn\n items={seconds}\n selected={currentTimeForPanel?.seconds}\n onSelect={(secondsValue) =>\n handleTimeSelection(\n currentTimeForPanel?.hours ?? 0,\n currentTimeForPanel?.minutes ?? 0,\n secondsValue\n )\n }\n label=\"Sec\"\n />\n )}\n {timeFormat === '12h' && (\n <TimeColumn\n items={['AM', 'PM']}\n selected={displayTime?.meridiem}\n onSelect={handleMeridiemChange}\n label=\"AM/PM\"\n />\n )}\n </div>\n </div>\n )\n }\n\n const renderPopoverContent = () => (\n <div className={cn('date-picker-popover-content', withTime && 'with-time')}>\n {renderCalendar()}\n {renderTimePanel()}\n </div>\n )\n\n const maxLength = withTime ? (timeFormat === '12h' ? (showSeconds ? 22 : 19) : showSeconds ? 19 : 16) : 10\n const inputPlaceholder = getInputPlaceholder(\n placeholder,\n format,\n withTime,\n timeFormat,\n showSeconds,\n timePlaceholder\n )\n\n if (inline) {\n return (\n <div\n className={cn('date-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n <MInput\n value={inputValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n onClear={handleClear}\n type=\"text\"\n inputMode={withTime ? 'text' : 'numeric'}\n autoComplete=\"off\"\n maxLength={maxLength}\n placeholder={inputPlaceholder}\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n variant={variant}\n size={size}\n color={color}\n label={label}\n helperText={helperText}\n error={hasError}\n errorText={resolvedErrorText}\n required={required}\n clearable={clearable}\n fullWidth={fullWidth}\n />\n {renderPopoverContent()}\n {name && selectedValue && (\n <input\n type=\"hidden\"\n name={name}\n value={formatHiddenDateValue(selectedValue, withTime, showSeconds)}\n />\n )}\n </div>\n )\n }\n\n return (\n <div\n className={cn('date-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n <div ref={anchorRef} className=\"date-picker-input-anchor\">\n <MInput\n value={inputValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n onKeyDown={handleInputKeyDown}\n onClear={handleClear}\n type=\"text\"\n inputMode={withTime ? 'text' : 'numeric'}\n autoComplete=\"off\"\n maxLength={maxLength}\n placeholder={inputPlaceholder}\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n variant={variant}\n size={size}\n color={color}\n label={label}\n helperText={helperText}\n error={hasError}\n errorText={resolvedErrorText}\n required={required}\n clearable={clearable}\n fullWidth={fullWidth}\n endIcon={\n <button\n type=\"button\"\n className=\"date-picker-toggle\"\n onMouseDown={(event) => event.preventDefault()}\n onClick={handleTogglePopover}\n aria-label=\"Open calendar\"\n disabled={disabled || readOnly}\n >\n <MCalendarIcon />\n </button>\n }\n />\n </div>\n\n {name && selectedValue && (\n <input type=\"hidden\" name={name} value={formatHiddenDateValue(selectedValue, withTime, showSeconds)} />\n )}\n\n <MPopover\n className=\"date-picker-popover\"\n style={{'--color-rgb': colorRgbVar(color)} as React.CSSProperties}\n open={open}\n anchorRef={anchorRef}\n onClose={() => setOpen(false)}\n placement=\"bottom-start\"\n >\n {renderPopoverContent()}\n </MPopover>\n </div>\n )\n}\n\nfunction TimeColumn<T extends number | Meridiem>({\n items,\n selected,\n onSelect,\n label,\n}: {\n items: T[]\n selected?: T\n onSelect: (value: T) => void\n label: string\n}) {\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (selected === undefined || !listRef.current) return\n\n const element = listRef.current.querySelector(`[data-value=\"${selected}\"]`) as HTMLElement | null\n\n if (element) {\n const list = listRef.current\n list.scrollTop = element.offsetTop - list.clientHeight / 2 + element.offsetHeight / 2\n }\n }, [selected])\n\n const renderValue = (value: T) => (typeof value === 'number' ? value.toString().padStart(2, '0') : value)\n\n return (\n <div className=\"date-picker-time-column\">\n <div className=\"date-picker-time-column-label\">{label}</div>\n <div ref={listRef} className=\"date-picker-time-column-list\">\n {items.map((item) => (\n <button\n key={item}\n type=\"button\"\n data-value={item}\n className={cn('date-picker-time-column-item', item === selected && 'selected')}\n onClick={() => onSelect(item)}\n >\n {renderValue(item)}\n </button>\n ))}\n </div>\n </div>\n )\n}\n","import {useState, useRef, useCallback, useMemo, useEffect} from 'react'\nimport type * as React from 'react'\nimport type {MTimePickerProps} from './MTimePicker.types'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {MClockIcon, MCloseIcon} from '../../../icons'\nimport {formatTime, parseTime} from '../../../utils/dateUtils'\nimport './MTimePicker.css'\n\ntype ParsedTimeValue = {hours: number; minutes: number; seconds: number}\ntype Meridiem = 'AM' | 'PM'\n\nfunction to12HourParts(value: ParsedTimeValue) {\n const meridiem: Meridiem = value.hours >= 12 ? 'PM' : 'AM'\n const hours = value.hours % 12 || 12\n return {hours, minutes: value.minutes, seconds: value.seconds, meridiem}\n}\n\nfunction to24HourValue(hours: number, meridiem: Meridiem): number {\n if (meridiem === 'AM') {\n return hours === 12 ? 0 : hours\n }\n return hours === 12 ? 12 : hours + 12\n}\n\nfunction formatTimeValue(\n hours: number,\n minutes: number,\n seconds: number,\n showSeconds: boolean,\n format: '24h' | '12h'\n): string {\n if (format === '24h') {\n return formatTime(hours, minutes, seconds, showSeconds)\n }\n\n const parts = to12HourParts({hours, minutes, seconds})\n const base = `${parts.hours.toString().padStart(2, '0')}:${parts.minutes.toString().padStart(2, '0')}`\n const withSeconds = showSeconds ? `${base}:${parts.seconds.toString().padStart(2, '0')}` : base\n return `${withSeconds} ${parts.meridiem}`\n}\n\nfunction parseTimeValue(value: string, format: '24h' | '12h'): ParsedTimeValue | null {\n if (format === '24h') {\n return parseTime(value)\n }\n\n const normalized = value.trim().toUpperCase()\n const match = normalized.match(/^(\\d{1,2}):(\\d{2})(?::(\\d{2}))?\\s*(AM|PM)$/)\n if (match) {\n const hours = parseInt(match[1], 10)\n const minutes = parseInt(match[2], 10)\n const seconds = match[3] ? parseInt(match[3], 10) : 0\n const meridiem = match[4] as Meridiem\n\n if (hours < 1 || hours > 12 || minutes > 59 || seconds > 59) {\n return null\n }\n\n return {hours: to24HourValue(hours, meridiem), minutes, seconds}\n }\n\n return parseTime(value)\n}\n\n// Compare time tuples so min/max checks can stay string-format agnostic.\nfunction compareTimeParts(\n left: {hours: number; minutes: number; seconds: number},\n right: {hours: number; minutes: number; seconds: number}\n): number {\n if (left.hours !== right.hours) return left.hours - right.hours\n if (left.minutes !== right.minutes) return left.minutes - right.minutes\n return left.seconds - right.seconds\n}\n\n// Check whether a time falls within optional min and max boundaries.\nfunction isTimeInRange(\n value: {hours: number; minutes: number; seconds: number},\n min?: {hours: number; minutes: number; seconds: number} | null,\n max?: {hours: number; minutes: number; seconds: number} | null\n): boolean {\n return (!min || compareTimeParts(value, min) >= 0) && (!max || compareTimeParts(value, max) <= 0)\n}\n\n// Render a time input backed by scrollable hour, minute and second columns.\nexport function MTimePicker({\n value,\n defaultValue,\n onChange,\n format = '24h',\n showSeconds = false,\n minuteStep = 1,\n min,\n max,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n fullWidth = false,\n className,\n style,\n}: MTimePickerProps) {\n const [open, setOpen] = useState(false)\n const [internalValue, setInternalValue] = useState(defaultValue ?? '')\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const currentValue = value !== undefined ? value : internalValue\n const hasError = error || !!errorText\n const parsed = parseTimeValue(currentValue, format)\n const minTime = parseTimeValue(min ?? '', format)\n const maxTime = parseTimeValue(max ?? '', format)\n const displayTime = parsed ? to12HourParts(parsed) : null\n const displayValue = parsed\n ? formatTimeValue(parsed.hours, parsed.minutes, parsed.seconds, showSeconds, format)\n : currentValue\n\n // Build the visible hour list based on the selected time format.\n const hours = useMemo(() => {\n const items: number[] = []\n const maxHour = format === '12h' ? 12 : 23\n const startHour = format === '12h' ? 1 : 0\n for (let index = startHour; index <= maxHour; index++) {\n items.push(index)\n }\n return items\n }, [format])\n\n // Build the minute list using the configured step size.\n const minutes = useMemo(() => {\n const items: number[] = []\n for (let index = 0; index < 60; index += minuteStep) {\n items.push(index)\n }\n return items\n }, [minuteStep])\n\n // Build the seconds list only when the picker exposes seconds.\n const seconds = useMemo(() => {\n if (!showSeconds) return []\n const items: number[] = []\n for (let index = 0; index < 60; index++) {\n items.push(index)\n }\n return items\n }, [showSeconds])\n\n // Reuse range validation for list rendering and direct text input.\n const isSelectable = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n return isTimeInRange({hours: hoursValue, minutes: minutesValue, seconds: secondsValue}, minTime, maxTime)\n },\n [maxTime, minTime]\n )\n\n // Apply the selected time and keep uncontrolled usage in sync.\n const handleSelect = useCallback(\n (hoursValue: number, minutesValue: number, secondsValue: number = 0) => {\n if (!isSelectable(hoursValue, minutesValue, secondsValue)) return\n const time = formatTimeValue(hoursValue, minutesValue, secondsValue, showSeconds, format)\n if (value === undefined) setInternalValue(time)\n onChange?.(time)\n },\n [format, isSelectable, onChange, showSeconds, value]\n )\n\n const handleInputChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const raw = event.target.value\n if (value === undefined) setInternalValue(raw)\n },\n [value]\n )\n\n // Normalize manual input once the user leaves the field.\n const handleInputBlur = useCallback(() => {\n const nextValue = parseTimeValue(currentValue, format)\n if (nextValue && isTimeInRange(nextValue, minTime, maxTime)) {\n const time = formatTimeValue(nextValue.hours, nextValue.minutes, nextValue.seconds, showSeconds, format)\n if (value === undefined) setInternalValue(time)\n onChange?.(time)\n }\n }, [currentValue, format, maxTime, minTime, onChange, showSeconds, value])\n\n const handleMeridiemChange = useCallback(\n (meridiem: Meridiem) => {\n const currentHours = displayTime?.hours ?? 12\n const minutesValue = parsed?.minutes ?? 0\n const secondsValue = parsed?.seconds ?? 0\n const nextHours = to24HourValue(currentHours, meridiem)\n handleSelect(nextHours, minutesValue, secondsValue)\n },\n [displayTime?.hours, handleSelect, parsed?.minutes, parsed?.seconds]\n )\n\n // Clear the current time without closing the trigger first.\n const handleClear = useCallback(\n (event: React.MouseEvent) => {\n event.stopPropagation()\n if (value === undefined) setInternalValue('')\n onChange?.('')\n },\n [onChange, value]\n )\n\n return (\n <div\n className={cn('time picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'time trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => !disabled && !readOnly && setOpen(true)}\n >\n <span className=\"time icon\">\n <MClockIcon />\n </span>\n <input\n type=\"text\"\n className=\"time input\"\n value={displayValue}\n onChange={handleInputChange}\n onBlur={handleInputBlur}\n placeholder={\n placeholder ??\n (format === '12h'\n ? showSeconds\n ? 'hh:mm:ss AM'\n : 'hh:mm AM'\n : showSeconds\n ? 'HH:MM:SS'\n : 'HH:MM')\n }\n disabled={disabled}\n readOnly={readOnly}\n id={id}\n aria-invalid={hasError || undefined}\n />\n {clearable && currentValue && !disabled && (\n <button\n type=\"button\"\n className=\"time clear clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label=\"Clear time\"\n >\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && <input type=\"hidden\" name={name} value={displayValue} />}\n\n <MPopover\n className=\"time picker popover\"\n open={open}\n anchorRef={triggerRef}\n onClose={() => setOpen(false)}\n placement=\"bottom-start\"\n >\n <div className=\"time columns\">\n <TimeColumn\n items={hours}\n selected={format === '12h' ? displayTime?.hours : parsed?.hours}\n onSelect={(hoursValue) =>\n handleSelect(\n format === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n parsed?.minutes ?? 0,\n parsed?.seconds ?? 0\n )\n }\n isDisabled={(hoursValue) =>\n !isSelectable(\n format === '12h'\n ? to24HourValue(hoursValue, displayTime?.meridiem ?? 'AM')\n : hoursValue,\n parsed?.minutes ?? 0,\n parsed?.seconds ?? 0\n )\n }\n label=\"Hr\"\n />\n <TimeColumn\n items={minutes}\n selected={parsed?.minutes}\n onSelect={(minutesValue) =>\n handleSelect(parsed?.hours ?? 0, minutesValue, parsed?.seconds ?? 0)\n }\n isDisabled={(minutesValue) =>\n !isSelectable(parsed?.hours ?? 0, minutesValue, parsed?.seconds ?? 0)\n }\n label=\"Min\"\n />\n {showSeconds && (\n <TimeColumn\n items={seconds}\n selected={parsed?.seconds}\n onSelect={(secondsValue) =>\n handleSelect(parsed?.hours ?? 0, parsed?.minutes ?? 0, secondsValue)\n }\n isDisabled={(secondsValue) =>\n !isSelectable(parsed?.hours ?? 0, parsed?.minutes ?? 0, secondsValue)\n }\n label=\"Sec\"\n />\n )}\n {format === '12h' && (\n <TimeColumn\n items={['AM', 'PM']}\n selected={displayTime?.meridiem}\n onSelect={handleMeridiemChange}\n label=\"AM/PM\"\n />\n )}\n </div>\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"time bottom\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"time helper\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n\n// Render one scrollable time column and keep the selected value centered.\nfunction TimeColumn<T extends number | Meridiem>({\n items,\n selected,\n onSelect,\n isDisabled,\n label,\n}: {\n items: T[]\n selected?: T\n onSelect: (value: T) => void\n isDisabled?: (value: T) => boolean\n label: string\n}) {\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (selected === undefined || !listRef.current) return\n const element = listRef.current.querySelector(`[data-value=\"${selected}\"]`) as HTMLElement | null\n if (element) {\n const list = listRef.current\n list.scrollTop = element.offsetTop - list.clientHeight / 2 + element.offsetHeight / 2\n }\n }, [selected])\n\n const renderValue = (value: T) => (typeof value === 'number' ? value.toString().padStart(2, '0') : value)\n\n return (\n <div className=\"time column\">\n <div className=\"time column label\">{label}</div>\n <div ref={listRef} className=\"time column list\">\n {items.map((item) => {\n const disabled = isDisabled?.(item) ?? false\n return (\n <button\n key={item}\n type=\"button\"\n data-value={item}\n className={cn('time column item', item === selected && 'selected', disabled && 'disabled')}\n onClick={() => onSelect(item)}\n disabled={disabled}\n >\n {renderValue(item)}\n </button>\n )\n })}\n </div>\n </div>\n )\n}\n","import {useCallback, useEffect, useMemo, useRef, useState} from 'react'\nimport type * as React from 'react'\nimport {MPopover} from '../../primitives'\nimport {cn} from '../../../utils/cn'\nimport {useMDateRangePickerTexts} from '../../../i18n/frameworkTexts'\nimport {useDocumentLocale} from '../../../utils/locale'\nimport {MCalendarIcon, MChevronLeftIcon, MChevronRightIcon, MCloseIcon} from '../../../icons'\nimport {\n addMonths,\n daysInMonth,\n firstDayOfMonth,\n formatDate,\n getDayNames,\n getMonthNames,\n isDateInRange,\n isSameDay,\n stripTime,\n} from '../../../utils/dateUtils'\nimport type {MDateRangePickerProps, MDateRangePreset} from './MDateRangePicker.types'\nimport {colorRgbVar} from '../../../utils/colorRgbVar'\nimport './MDateRangePicker.css'\n\nfunction toDate(value: Date | string | null | undefined): Date | null {\n if (!value) return null\n if (value instanceof Date) return stripTime(value)\n const date = new Date(value)\n return isNaN(date.getTime()) ? null : stripTime(date)\n}\n\nfunction sortRange(start: Date, end: Date) {\n return start.getTime() <= end.getTime() ? {start, end} : {start: end, end: start}\n}\n\nfunction isBetween(date: Date, start: Date | null, end: Date | null) {\n if (!start || !end) return false\n const time = date.getTime()\n return time > start.getTime() && time < end.getTime()\n}\n\nfunction formatRangeLabel(start: Date | null, end: Date | null, format: string) {\n if (start && end) {\n return `${formatDate(start, format)} - ${formatDate(end, format)}`\n }\n\n if (start) {\n return `${formatDate(start, format)} - ...`\n }\n\n return ''\n}\n\nfunction startOfMonth(date: Date) {\n return new Date(date.getFullYear(), date.getMonth(), 1)\n}\n\nfunction endOfMonth(date: Date) {\n return new Date(date.getFullYear(), date.getMonth() + 1, 0)\n}\n\nfunction daysAgo(days: number): Date {\n const date = stripTime(new Date())\n date.setDate(date.getDate() - (days - 1))\n return date\n}\n\nfunction monthsAgo(months: number): Date {\n const today = stripTime(new Date())\n return new Date(today.getFullYear(), today.getMonth() - months, today.getDate())\n}\n\nfunction getDefaultPresets(texts: ReturnType<typeof useMDateRangePickerTexts>): MDateRangePreset[] {\n const today = stripTime(new Date())\n const previousMonthDate = new Date(today.getFullYear(), today.getMonth() - 1, 1)\n\n return [\n {label: texts.presets.today, value: {start: today, end: today}},\n {label: texts.presets.days2, value: {start: daysAgo(2), end: today}},\n {label: texts.presets.days3, value: {start: daysAgo(3), end: today}},\n {label: texts.presets.days7, value: {start: daysAgo(7), end: today}},\n {label: texts.presets.days14, value: {start: daysAgo(14), end: today}},\n {label: texts.presets.days31, value: {start: daysAgo(31), end: today}},\n {label: texts.presets.thisMonth, value: {start: startOfMonth(today), end: endOfMonth(today)}},\n {\n label: texts.presets.previousMonth,\n value: {start: startOfMonth(previousMonthDate), end: endOfMonth(previousMonthDate)},\n },\n {label: texts.presets.months2, value: {start: monthsAgo(2), end: today}},\n {label: texts.presets.months3, value: {start: monthsAgo(3), end: today}},\n {label: texts.presets.months6, value: {start: monthsAgo(6), end: today}},\n {label: texts.presets.year1, value: {start: monthsAgo(12), end: today}},\n ]\n}\n\nfunction buildCalendarDays(viewDate: Date, firstDayOfWeek: 0 | 1) {\n const year = viewDate.getFullYear()\n const month = viewDate.getMonth()\n const totalDays = daysInMonth(year, month)\n let startDay = firstDayOfMonth(year, month)\n\n if (firstDayOfWeek === 1) {\n startDay = startDay === 0 ? 6 : startDay - 1\n }\n\n const days = [] as Array<{date: Date; currentMonth: boolean}>\n\n const previousMonth = month === 0 ? 11 : month - 1\n const previousYear = month === 0 ? year - 1 : year\n const previousMonthDays = daysInMonth(previousYear, previousMonth)\n\n for (let index = startDay - 1; index >= 0; index -= 1) {\n days.push({date: new Date(previousYear, previousMonth, previousMonthDays - index), currentMonth: false})\n }\n\n for (let day = 1; day <= totalDays; day += 1) {\n days.push({date: new Date(year, month, day), currentMonth: true})\n }\n\n const remaining = 42 - days.length\n const nextMonth = month === 11 ? 0 : month + 1\n const nextYear = month === 11 ? year + 1 : year\n\n for (let day = 1; day <= remaining; day += 1) {\n days.push({date: new Date(nextYear, nextMonth, day), currentMonth: false})\n }\n\n return days\n}\n\n// Render a single control for start and end date selection inside one calendar popover.\nexport function MDateRangePicker({\n value,\n defaultValue,\n onChange,\n format = 'dd.MM.yyyy',\n locale: localeOverride,\n min,\n max,\n disabledDates,\n placeholder,\n disabled = false,\n readOnly = false,\n name,\n id,\n variant = 'outlined',\n size = 'md',\n color,\n label,\n helperText,\n errorText,\n error = false,\n required = false,\n clearable = false,\n inline = false,\n showTodayButton = true,\n presets = false,\n presetsSidebar = false,\n firstDayOfWeek = 1,\n fullWidth = false,\n allowSameDay = true,\n className,\n style,\n}: MDateRangePickerProps) {\n const locale = useDocumentLocale(localeOverride)\n const controlledRange = value\n ? {\n start: toDate(value.start),\n end: toDate(value.end),\n }\n : null\n const [internalRange, setInternalRange] = useState(() => ({\n start: toDate(defaultValue?.start),\n end: toDate(defaultValue?.end),\n }))\n const [hoveredDate, setHoveredDate] = useState<Date | null>(null)\n const [open, setOpen] = useState(false)\n const triggerRef = useRef<HTMLDivElement>(null)\n\n const selectedRange = controlledRange ?? internalRange\n const startDate = selectedRange.start\n const endDate = selectedRange.end\n const minDate = toDate(min)\n const maxDate = toDate(max)\n const hasError = error || !!errorText\n const texts = useMDateRangePickerTexts()\n const dayNames = getDayNames(locale, firstDayOfWeek)\n const monthNames = getMonthNames(locale)\n const availablePresets = useMemo(() => {\n if (presets === true || (presetsSidebar && !presets)) {\n return getDefaultPresets(texts)\n }\n\n if (Array.isArray(presets)) {\n return presets\n }\n\n return []\n }, [presets, presetsSidebar, texts])\n\n const [viewDate, setViewDate] = useState(() => {\n const baseDate = startDate ?? new Date()\n return new Date(baseDate.getFullYear(), baseDate.getMonth(), 1)\n })\n\n const startTime = startDate?.getTime() ?? null\n useEffect(() => {\n if (!startTime) return\n const d = new Date(startTime)\n setViewDate(new Date(d.getFullYear(), d.getMonth(), 1))\n }, [startTime])\n\n const isDisabled = useCallback(\n (date: Date): boolean => {\n if (!isDateInRange(date, minDate, maxDate)) return true\n if (Array.isArray(disabledDates)) {\n return disabledDates.some((disabledDate) => isSameDay(disabledDate, date))\n }\n if (typeof disabledDates === 'function') {\n return disabledDates(date)\n }\n return false\n },\n [disabledDates, maxDate, minDate]\n )\n\n const commitRange = useCallback(\n (nextRange: {start: Date | null; end: Date | null}) => {\n if (value === undefined) {\n setInternalRange(nextRange)\n }\n onChange?.(nextRange)\n },\n [onChange, value]\n )\n\n const handleDayClick = useCallback(\n (date: Date) => {\n if (isDisabled(date)) return\n\n if (!startDate || (startDate && endDate)) {\n commitRange({start: date, end: null})\n setHoveredDate(null)\n return\n }\n\n if (!allowSameDay && isSameDay(date, startDate)) {\n return\n }\n\n const orderedRange = sortRange(startDate, date)\n commitRange(orderedRange)\n setHoveredDate(null)\n\n if (!inline) {\n setOpen(false)\n }\n },\n [allowSameDay, commitRange, endDate, inline, isDisabled, startDate]\n )\n\n const handleClear = useCallback(\n (event: React.MouseEvent) => {\n event.stopPropagation()\n commitRange({start: null, end: null})\n setHoveredDate(null)\n },\n [commitRange]\n )\n\n const handleToday = useCallback(() => {\n const today = stripTime(new Date())\n if (isDisabled(today)) return\n commitRange({start: today, end: today})\n setViewDate(new Date(today.getFullYear(), today.getMonth(), 1))\n setHoveredDate(null)\n if (!inline) {\n setOpen(false)\n }\n }, [commitRange, inline, isDisabled])\n\n const handlePresetClick = useCallback(\n (preset: MDateRangePreset) => {\n const start = toDate(preset.value.start)\n const end = toDate(preset.value.end)\n\n if (!start || !end) {\n return\n }\n\n const orderedRange = sortRange(start, end)\n\n if (isDisabled(orderedRange.start) || isDisabled(orderedRange.end)) {\n return\n }\n\n commitRange(orderedRange)\n setViewDate(new Date(orderedRange.start.getFullYear(), orderedRange.start.getMonth(), 1))\n setHoveredDate(null)\n\n if (!inline) {\n setOpen(false)\n }\n },\n [commitRange, inline, isDisabled]\n )\n\n const previewEnd = startDate && !endDate ? hoveredDate : null\n const firstMonth = viewDate\n const secondMonth = addMonths(viewDate, 1)\n const today = stripTime(new Date())\n\n const displayValue = useMemo(() => formatRangeLabel(startDate, endDate, format), [endDate, format, startDate])\n\n const calendarMonths = useMemo(\n () =>\n [firstMonth, secondMonth].map((monthDate) => ({\n monthDate,\n days: buildCalendarDays(monthDate, firstDayOfWeek),\n })),\n [firstDayOfWeek, firstMonth, secondMonth]\n )\n\n const summaryText =\n startDate && endDate\n ? `${formatDate(startDate, format)} - ${formatDate(endDate, format)}`\n : startDate\n ? `${formatDate(startDate, format)} - ...`\n : (placeholder ?? texts.defaultRangePlaceholder)\n\n const showSidebar = presetsSidebar && availablePresets.length > 0\n const showInlinePresets = !presetsSidebar && availablePresets.length > 0\n\n const renderPresetsSidebar = () => (\n <div className=\"presets-sidebar\">\n {availablePresets.map((preset) => (\n <button\n key={preset.label}\n type=\"button\"\n className=\"preset-sidebar-btn\"\n onClick={() => handlePresetClick(preset)}\n >\n {preset.label}\n </button>\n ))}\n </div>\n )\n\n const renderCalendarContent = () => (\n <div className=\"calendar-body\">\n <div className=\"calendar-top\">\n <div className=\"calendar-caption\">\n <span className=\"caption-title\">\n {monthNames[firstMonth.getMonth()]} {firstMonth.getFullYear()}\n </span>\n <span className=\"caption-subtitle\">{texts.rangeSubtitle}</span>\n </div>\n <div className=\"nav-actions\">\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, -1))}\n aria-label={texts.previousMonth}\n >\n <MChevronLeftIcon />\n </button>\n <button\n type=\"button\"\n className=\"nav-btn\"\n onClick={() => setViewDate(addMonths(viewDate, 1))}\n aria-label={texts.nextMonth}\n >\n <MChevronRightIcon />\n </button>\n </div>\n </div>\n\n {showInlinePresets && (\n <div className=\"presets\">\n {availablePresets.map((preset) => (\n <button\n key={preset.label}\n type=\"button\"\n className=\"preset-btn\"\n onClick={() => handlePresetClick(preset)}\n >\n {preset.label}\n </button>\n ))}\n </div>\n )}\n\n <div className=\"months\">\n {calendarMonths.map(({monthDate, days}) => (\n <div key={monthDate.toISOString()} className=\"month-panel\">\n <div className=\"month-title\">\n {monthNames[monthDate.getMonth()]} {monthDate.getFullYear()}\n </div>\n <div className=\"day-names\">\n {dayNames.map((dayName) => (\n <span key={`${monthDate.toISOString()}-${dayName}`} className=\"day-name\">\n {dayName}\n </span>\n ))}\n </div>\n <div className=\"day-grid\">\n {days.map(({date, currentMonth}, index) => {\n const disabledDay = isDisabled(date)\n const selectedStart = startDate ? isSameDay(date, startDate) : false\n const selectedEnd = endDate ? isSameDay(date, endDate) : false\n const inRange = isBetween(date, startDate, endDate)\n const previewRangeData =\n !endDate && startDate && previewEnd ? sortRange(startDate, previewEnd) : null\n const previewRange = previewRangeData\n ? isBetween(date, previewRangeData.start, previewRangeData.end)\n : false\n const previewEdge = previewRangeData\n ? isSameDay(date, previewRangeData.start) || isSameDay(date, previewRangeData.end)\n : false\n\n return (\n <button\n key={`${monthDate.toISOString()}-${index}`}\n type=\"button\"\n className={cn(\n 'day',\n !currentMonth && 'other-month',\n isSameDay(date, today) && 'today',\n selectedStart && 'range-start selected',\n selectedEnd && 'range-end selected',\n inRange && 'in-range',\n previewRange && !previewEdge && 'preview-range',\n disabledDay && 'disabled'\n )}\n onClick={() => handleDayClick(date)}\n onMouseEnter={() => startDate && !endDate && setHoveredDate(date)}\n onFocus={() => startDate && !endDate && setHoveredDate(date)}\n disabled={disabledDay}\n tabIndex={-1}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </div>\n ))}\n </div>\n\n <div className=\"footer\">\n <span className=\"summary\">{summaryText}</span>\n <div className=\"footer-actions\">\n {clearable && (startDate || endDate) && (\n <button\n type=\"button\"\n className=\"footer-btn\"\n onClick={(event) => {\n event.preventDefault()\n commitRange({start: null, end: null})\n setHoveredDate(null)\n }}\n >\n {texts.clear}\n </button>\n )}\n {showTodayButton && (\n <button type=\"button\" className=\"footer-btn\" onClick={handleToday}>\n {texts.today}\n </button>\n )}\n </div>\n </div>\n </div>\n )\n\n const renderCalendar = () => (\n <div className={cn('date-range-calendar', showSidebar && 'with-sidebar')}>\n {showSidebar && renderPresetsSidebar()}\n {renderCalendarContent()}\n </div>\n )\n\n if (inline) {\n return (\n <div\n className={cn('date-range-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label className={cn('field-label', hasError && 'error', required && 'required')}>{label}</label>\n )}\n {renderCalendar()}\n </div>\n )\n }\n\n return (\n <div\n className={cn('date-range-picker', color && `color-${color}`, fullWidth && 'full-width', className)}\n style={style}\n >\n {label && (\n <label\n htmlFor={id}\n className={cn('field-label', open && 'focused', hasError && 'error', required && 'required')}\n >\n {label}\n </label>\n )}\n\n <div\n ref={triggerRef}\n className={cn(\n 'trigger',\n `field-${variant}`,\n `field-${size}`,\n open && 'focused',\n hasError && 'error',\n disabled && 'disabled'\n )}\n onClick={() => !disabled && !readOnly && setOpen(true)}\n >\n <span className=\"icon\">\n <MCalendarIcon />\n </span>\n <input\n type=\"text\"\n className=\"input\"\n value={displayValue}\n placeholder={placeholder ?? texts.defaultRangePlaceholder}\n disabled={disabled}\n readOnly\n id={id}\n aria-invalid={hasError || undefined}\n />\n {clearable && (startDate || endDate) && !disabled && (\n <button\n type=\"button\"\n className=\"clear-btn clear-btn-base\"\n onClick={handleClear}\n tabIndex={-1}\n aria-label={texts.clear}\n >\n <MCloseIcon />\n </button>\n )}\n </div>\n\n {name && startDate && endDate && (\n <input\n type=\"hidden\"\n name={name}\n value={`${startDate.toISOString().split('T')[0]}:${endDate.toISOString().split('T')[0]}`}\n />\n )}\n\n <MPopover\n className={'date-range-picker-popover'}\n style={{'--color-rgb': colorRgbVar(color)} as React.CSSProperties}\n open={open}\n anchorRef={triggerRef}\n onClose={() => {\n setOpen(false)\n setHoveredDate(null)\n }}\n placement=\"bottom-start\"\n >\n {renderCalendar()}\n </MPopover>\n\n {(errorText || helperText) && (\n <div className=\"bottom-row\">\n {errorText ? (\n <span className=\"field-error\" role=\"alert\">\n {errorText}\n </span>\n ) : (\n <span className=\"helper-text\">{helperText}</span>\n )}\n </div>\n )}\n </div>\n )\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const e=require(`./MI18nProvider-bf1G7lTP.cjs`),t=require(`./icons-BHFwX7ri.cjs`),n=require(`./cn-CU5TNITO.cjs`),r=require(`./validators-DRhikiAi.cjs`),i=require(`./formatters-CNjg_h7-.cjs`),a=require(`./dateUtils-Dq1vaA-D.cjs`),o=require(`./useGhostText-BFaUUKid.cjs`),s=require(`./useKeyboardNav-CtGPfQX7.cjs`),c=require(`./MPopover-BbgAAM5Z.cjs`),l=require(`./MButton-ouB6903s.cjs`),u=require(`./MCheckbox-Cbk5hwzJ.cjs`),d=require(`./MTag-Dez1GOX0.cjs`),f=require(`./MInput-ClHpIrDG.cjs`),p=require(`./locale-CJWWjFm-.cjs`);require(`./core-B2klLGki.cjs`);let m=require(`react`),h=require(`react/jsx-runtime`);function g({options:e,value:r,defaultValue:i,onChange:a,multiple:o=!1,searchable:f=!1,placeholder:p=`MSelect...`,disabled:g=!1,name:ee,id:te,variant:ne=`outlined`,size:_=`md`,color:v,fullWidth:re=!1,label:ie,helperText:y,errorText:ae,error:b=!1,required:oe=!1,loading:se=!1,clearable:ce=!1,maxHeight:x=300,noOptionsText:S=`No options`,renderOption:C,renderValue:w,className:T,style:E}){let[D,O]=(0,m.useState)(!1),[k,A]=(0,m.useState)(i??(o?[]:``)),[j,M]=(0,m.useState)(``),le=(0,m.useRef)(null),N=r===void 0?k:r,P=b||!!ae,F=(0,m.useMemo)(()=>Array.isArray(N)?N:N?[N]:[],[N]),I=(0,m.useMemo)(()=>e.filter(e=>F.includes(e.value)),[e,F]),L=(0,m.useMemo)(()=>{if(!f||!j)return e;let t=j.toLowerCase();return e.filter(e=>e.label.toLowerCase().includes(t))},[e,f,j]),R=(0,m.useMemo)(()=>{let e=new Map;for(let t of L){let n=t.group??``;e.has(n)||e.set(n,[]),e.get(n).push(t)}return e},[L]),z=L,B=(0,m.useCallback)(e=>{let t=z[e];if(!(!t||t.disabled))if(o){let e=Array.isArray(N)?N:[],n=e.includes(t.value)?e.filter(e=>e!==t.value):[...e,t.value];r===void 0&&A(n),a?.(n)}else r===void 0&&A(t.value),a?.(t.value),O(!1),M(``)},[z,o,N,r,a]),{activeIndex:V,setActiveIndex:H,resetIndex:ue,onKeyDown:de}=s.t({itemCount:z.length,onSelect:B,onClose:()=>{O(!1),M(``)},isOpen:D}),U=(0,m.useCallback)(()=>{g||(O(e=>!e),ue())},[g,ue]),fe=(0,m.useCallback)(e=>{e.stopPropagation();let t=o?[]:``;r===void 0&&A(t),a?.(t)},[o,r,a]),W=(0,m.useMemo)(()=>w&&I.length>0?w(o?I:I[0]):o&&I.length>0?(0,h.jsx)(`span`,{className:`tags`,children:I.map(e=>(0,h.jsx)(d.t,{label:e.label,color:v,size:_,variant:`solid`},e.value))}):!o&&I.length>0?I[0].label:(0,h.jsx)(`span`,{className:`placeholder`,children:p}),[I,o,w,p,v,_]);return(0,h.jsxs)(`div`,{className:n.t(`select`,v&&`color-${v}`,re&&`full-width`,T),style:E,children:[ie&&(0,h.jsx)(`label`,{htmlFor:te,className:n.t(`field-label`,D&&`focused`,P&&`error`,oe&&`required`),children:ie}),(0,h.jsxs)(`div`,{ref:le,className:n.t(`trigger`,`field-${ne}`,`field-${_}`,D&&`focused`,P&&`error`,g&&`disabled`),onClick:U,onKeyDown:de,tabIndex:g?-1:0,role:`combobox`,"aria-expanded":D,"aria-haspopup":`listbox`,"aria-invalid":P||void 0,id:te,children:[(0,h.jsx)(`span`,{className:`value`,children:W}),se&&(0,h.jsx)(l.r,{size:`sm`,color:v}),ce&&F.length>0&&!se&&!g&&(0,h.jsx)(`button`,{type:`button`,className:`clear-btn clear-btn-base`,onClick:fe,tabIndex:-1,"aria-label":`Clear selection`,children:(0,h.jsx)(t.Ki,{})}),(0,h.jsx)(`span`,{className:n.t(`arrow`,D&&`open`),"aria-hidden":`true`,children:(0,h.jsx)(t.Hi,{})})]}),ee&&(0,h.jsx)(`input`,{type:`hidden`,name:ee,value:Array.isArray(N)?N.join(`,`):N}),(0,h.jsx)(c.t,{className:`select-popover`,open:D,anchorRef:le,onClose:()=>{O(!1),M(``)},matchWidth:!0,placement:`bottom-start`,children:(0,h.jsxs)(`div`,{style:{maxHeight:x},className:`dropdown`,children:[f&&(0,h.jsx)(`div`,{className:`search-box`,children:(0,h.jsx)(`input`,{type:`text`,className:`search-input`,placeholder:`Search...`,value:j,onChange:e=>{M(e.target.value),H(0)},onKeyDown:de,autoFocus:!0})}),z.length===0?(0,h.jsx)(`div`,{className:`no-options`,children:S}):(0,h.jsx)(`div`,{className:`options-list`,role:`listbox`,children:[...R.entries()].map(([e,t])=>(0,h.jsxs)(`div`,{children:[e&&(0,h.jsx)(`div`,{className:`group-header`,children:e}),t.map(e=>{let t=z.indexOf(e),r=t===V,i=F.includes(e.value);return(0,h.jsxs)(`div`,{className:n.t(`option`,r&&`active`,i&&`selected`,e.disabled&&`disabled`),onClick:()=>!e.disabled&&B(t),onMouseEnter:()=>H(t),role:`option`,"aria-selected":i,"aria-disabled":e.disabled,children:[o&&(0,h.jsx)(u.t,{checked:i,size:`sm`,color:v,clickEffect:`none`,className:`select-check`}),C?C(e,r,i):e.label]},e.value)})]},e))})]})}),(ae||y)&&(0,h.jsx)(`div`,{className:`bottom-row`,children:ae?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:ae}):(0,h.jsx)(`span`,{className:`helper-text`,children:y})})]})}function ee(e){return typeof e==`string`?e:String(e)}function te(e){return typeof e==`string`?e:String(e)}function ne(e,t,n){if(!t)return e;let r=t.toLowerCase();return e.filter(e=>n(e).toLowerCase().includes(r))}function _({options:e,value:r,onChange:i,getOptionLabel:a=ee,getOptionValue:u=te,filterOptions:f,multiple:p=!1,debounceMs:g=0,onInputChange:_,loading:v=!1,loadingText:re=`Loading...`,noOptionsText:ie=`No options`,placeholder:y=`Type to search...`,disabled:ae=!1,name:b,id:oe,variant:se=`outlined`,size:ce=`md`,color:x,fullWidth:S=!1,label:C,helperText:w,errorText:T,error:E=!1,required:D=!1,clearable:O=!1,maxHeight:k=300,renderOption:A,renderTags:j,className:M,style:le}){let[N,P]=(0,m.useState)(!1),[F,I]=(0,m.useState)(``),L=(0,m.useRef)(null),R=(0,m.useRef)(null),z=E||!!T,B=(0,m.useMemo)(()=>r==null?[]:Array.isArray(r)?r.filter(e=>e!=null):[r],[r]),V=(0,m.useMemo)(()=>f?f(e,F):ne(e,F,a),[e,F,f,a]),H=o.r(e=>_?.(e),g),ue=(0,m.useCallback)(e=>{I(e.target.value),H(e.target.value),N||P(!0)},[N,H]),de=(0,m.useCallback)(e=>{let t=V[e];if(t)if(p){let e=[...B],n=u(t),r=e.findIndex(e=>u(e)===n);r>=0?e.splice(r,1):e.push(t),i?.(e),I(``),R.current?.focus()}else i?.(t),I(a(t)),P(!1)},[V,p,B,u,a,i]),U=(0,m.useCallback)(e=>{let t=[...B];t.splice(e,1),i?.(p?t:t[0]??``)},[B,i,p]),{activeIndex:fe,setActiveIndex:W,resetIndex:G,onKeyDown:pe}=s.t({itemCount:V.length,onSelect:de,onClose:()=>P(!1),isOpen:N}),me=(0,m.useCallback)(e=>{if(e.key===`Backspace`&&p&&!F&&B.length>0){U(B.length-1);return}pe(e)},[F,p,B,pe,U]),K=(0,m.useCallback)(e=>{e.stopPropagation(),I(``),i?.(p?[]:``),R.current?.focus()},[p,i]);return(0,h.jsxs)(`div`,{className:n.t(`autocomplete`,x&&`color-${x}`,S&&`full-width`,M),style:le,children:[C&&(0,h.jsx)(`label`,{htmlFor:oe,className:n.t(`field-label`,N&&`focused`,z&&`error`,D&&`required`),children:C}),(0,h.jsxs)(`div`,{ref:L,className:n.t(`input-wrapper`,`field-${se}`,`field-${ce}`,N&&`focused`,z&&`error`,ae&&`disabled`),onClick:()=>R.current?.focus(),children:[p&&B.length>0&&(j?j(B,U):(0,h.jsx)(`span`,{className:`tags`,children:B.map((e,t)=>(0,h.jsx)(d.t,{label:a(e),color:x,size:ce,variant:`solid`,closable:!0,onClose:()=>U(t)},u(e)))})),(0,h.jsx)(`input`,{ref:R,type:`text`,className:`input`,value:F,onChange:ue,onFocus:()=>{P(!0),G()},onKeyDown:me,placeholder:B.length>0?``:y,disabled:ae,id:oe,"aria-expanded":N,"aria-haspopup":`listbox`,"aria-invalid":z||void 0,autoComplete:`off`}),v&&(0,h.jsx)(l.r,{size:`sm`,color:x}),O&&(B.length>0||F)&&!v&&!ae&&(0,h.jsx)(`button`,{type:`button`,className:`clear-btn clear-btn-base`,onClick:K,tabIndex:-1,children:(0,h.jsx)(t.Ki,{})})]}),b&&(0,h.jsx)(`input`,{type:`hidden`,name:b,value:B.map(u).join(`,`)}),(0,h.jsx)(c.t,{className:n.t(`autocomplete-popover`,x&&`color-${x}`),open:N&&(V.length>0||v||!!F),anchorRef:L,onClose:()=>P(!1),matchWidth:!0,placement:`bottom-start`,children:(0,h.jsx)(`div`,{style:{maxHeight:k},className:`dropdown`,children:v?(0,h.jsx)(`div`,{className:`loading-msg`,children:re}):V.length===0?(0,h.jsx)(`div`,{className:`no-options`,children:ie}):(0,h.jsx)(`div`,{className:`options-list`,role:`listbox`,children:V.map((e,t)=>{let r=t===fe,i=B.some(t=>u(t)===u(e));return(0,h.jsx)(`div`,{className:n.t(`option`,r&&`active`,i&&`selected`),onClick:()=>de(t),onMouseEnter:()=>W(t),role:`option`,"aria-selected":i,children:A?A(e,r):a(e)},u(e))})})})}),(T||w)&&(0,h.jsx)(`div`,{className:`bottom-row`,children:T?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:T}):(0,h.jsx)(`span`,{className:`helper-text`,children:w})})]})}function v(){let t=e.r();return(0,m.useCallback)((e,n)=>t?.t(e,n)??n,[t])}function re(){let e=v();return(0,m.useMemo)(()=>({today:e(`mineralui.datePicker.today`,`Today`),clear:e(`mineralui.datePicker.clear`,`Clear`),previousMonth:e(`mineralui.datePicker.previousMonth`,`Previous month`),nextMonth:e(`mineralui.datePicker.nextMonth`,`Next month`)}),[e])}function ie(){let e=v();return(0,m.useMemo)(()=>({today:e(`mineralui.dateRangePicker.today`,`Today`),clear:e(`mineralui.dateRangePicker.clear`,`Clear`),previousMonth:e(`mineralui.dateRangePicker.previousMonth`,`Previous month`),nextMonth:e(`mineralui.dateRangePicker.nextMonth`,`Next month`),rangeSubtitle:e(`mineralui.dateRangePicker.rangeSubtitle`,`Select start and end dates in one panel.`),defaultRangePlaceholder:e(`mineralui.dateRangePicker.defaultRangePlaceholder`,`Select date range...`),presets:{today:e(`mineralui.dateRangePicker.presets.today`,`Today`),days2:e(`mineralui.dateRangePicker.presets.days2`,`2 days`),days3:e(`mineralui.dateRangePicker.presets.days3`,`3 days`),days7:e(`mineralui.dateRangePicker.presets.days7`,`7 days`),days14:e(`mineralui.dateRangePicker.presets.days14`,`14 days`),days31:e(`mineralui.dateRangePicker.presets.days31`,`31 days`),thisMonth:e(`mineralui.dateRangePicker.presets.thisMonth`,`This month`),previousMonth:e(`mineralui.dateRangePicker.presets.previousMonth`,`Previous month`),months2:e(`mineralui.dateRangePicker.presets.months2`,`2 months`),months3:e(`mineralui.dateRangePicker.presets.months3`,`3 months`),months6:e(`mineralui.dateRangePicker.presets.months6`,`6 months`),year1:e(`mineralui.dateRangePicker.presets.year1`,`1 year`)}}),[e])}var y={primary:`var(--mineral-primary-rgb)`,neutral:`var(--mineral-neutral-rgb)`,success:`var(--mineral-success-rgb)`,error:`var(--mineral-error-rgb)`,warning:`var(--mineral-warning-rgb)`,info:`var(--mineral-info-rgb)`,light:`var(--mineral-light-rgb)`,dark:`var(--mineral-dark-color-rgb)`,news:`var(--mineral-news-rgb)`};function ae(e){return y[e??`primary`]??y.primary}var b=`Date is unavailable`,oe=`Invalid time`;function se(e){if(!e)return null;if(e instanceof Date)return isNaN(e.getTime())?null:new Date(e.getTime());let t=new Date(e);return isNaN(t.getTime())?null:t}function ce(e){let t=e.replace(/DD/g,`dd`).replace(/YYYY/g,`yyyy`),n=t.match(/dd|MM|yyyy/g),r=t.match(/[^dMy]/)?.[0],i=r===`/`||r===`.`||r===`-`?r:`.`;switch(n?.join(`/`)){case`MM/dd/yyyy`:return{inputFormat:`MM/DD/YYYY`,separator:i};case`yyyy/MM/dd`:return{inputFormat:`YYYY/MM/DD`,separator:i};default:return{inputFormat:`DD/MM/YYYY`,separator:i}}}function x(e,t){return e===`12h`?t?`hh:mm:ss AM`:`hh:mm AM`:t?`HH:MM:SS`:`HH:MM`}function S(e,t,n,r,i,a){return e||(n?`${t} ${a??x(r,i)}`:t)}function C(e,t){if(!e)return``;let n=a.o(a._(e),t.format);return t.withTime?`${n} ${a.l(e.getHours(),e.getMinutes(),e.getSeconds(),t.showSeconds,t.timeFormat)}`:n}function w(e,t){return e?e.length<=2?e:e.length<=4?`${e.slice(0,2)}:${e.slice(2)}`:t?`${e.slice(0,2)}:${e.slice(2,4)}:${e.slice(4,6)}`:`${e.slice(0,2)}:${e.slice(2,4)}`:``}function T(e){let t=e.toUpperCase().replace(/[^APM]/g,``);return t?t.startsWith(`AM`)?`AM`:t.startsWith(`PM`)?`PM`:t.startsWith(`A`)?`A`:t.startsWith(`P`)?`P`:``:``}function E(e,t){let n=e.trim();if(!n)return{datePart:``,timePart:``};if(!t)return{datePart:n,timePart:``};let r=n.indexOf(` `);return r===-1?{datePart:n,timePart:``}:{datePart:n.slice(0,r).trim(),timePart:n.slice(r+1).trim()}}function D(e,t){let n=e.toUpperCase(),r=i.u(n),a=r.slice(0,8),o=t.withTime?r.slice(8,8+(t.showSeconds?6:4)):``,s=i.i(a,t.inputFormat,t.separator);if(!t.withTime)return{formatted:s,datePart:s,timePart:``};let c=w(o,t.showSeconds),l=t.timeFormat===`12h`?T(n):``,u=`${c}${l?`${c?` `:``}${l}`:``}`.trim();if(!s)return{formatted:u,datePart:``,timePart:u};let d=a.length===8,f=/\s/.test(n.slice(s.length));return{formatted:u||d&&f?`${s} ${u}`:s,datePart:s,timePart:u}}function O(e,t){return e?a.l(e.getHours(),e.getMinutes(),e.getSeconds(),t,`24h`):``}function k(e,t){let{datePart:n,timePart:i}=E(e,t.withTime);if(!n&&!i)return{status:`empty`};let o=r.a(n,{format:t.inputFormat,minDate:t.minDate??void 0,maxDate:t.maxDate??void 0});if(!o.valid)return o.error===`Incomplete date`?{status:`partial`,datePart:n,timePart:i}:{status:`invalid`,datePart:n,timePart:i,result:o};let s=r.i(n,t.inputFormat);return s?t.isDisabled(s)?{status:`invalid`,datePart:n,timePart:i,result:{valid:!1,error:b}}:t.withTime?i?a.g(i,t.timeFormat)?{status:`valid`,datePart:n,timePart:i,value:a.r(s,i,{format:t.timeFormat,showSeconds:t.showSeconds})}:{status:`invalid`,datePart:n,timePart:i,result:{valid:!1,error:oe}}:{status:`valid`,datePart:n,timePart:``,value:a.r(s,``,{format:t.timeFormat,showSeconds:t.showSeconds})}:{status:`valid`,datePart:n,timePart:``,value:a._(s)}:{status:`invalid`,datePart:n,timePart:i,result:{valid:!1,error:`Invalid date`}}}function A(e){let t=e.hours>=12?`PM`:`AM`;return{hours:e.hours%12||12,minutes:e.minutes,seconds:e.seconds,meridiem:t}}function j(e,t){return t===`AM`?e===12?0:e:e===12?12:e+12}function M({value:e,defaultValue:r,onChange:o,format:s=`dd.MM.yyyy`,locale:l,min:u,max:d,disabledDates:g,placeholder:ee,disabled:te=!1,readOnly:ne=!1,name:_,id:v,variant:ie=`outlined`,size:y=`md`,color:b,label:x,helperText:w,errorText:T,error:E=!1,required:M=!1,clearable:N=!1,withTime:P=!1,validateOnBlur:F=!0,validateOnChange:I=!1,onValidationChange:L,timeFormat:R=`24h`,showSeconds:z=!1,minuteStep:B=1,timePlaceholder:V,inline:H=!1,showTodayButton:ue=!0,firstDayOfWeek:de=1,fullWidth:U=!1,className:fe,style:W}){let G=p.t(l),pe=re(),{inputFormat:me,separator:K}=(0,m.useMemo)(()=>ce(s),[s]),[he,ge]=(0,m.useState)(!1),[_e,ve]=(0,m.useState)(()=>se(r)),[ye,be]=(0,m.useState)({valid:!0}),[xe,q]=(0,m.useState)(!1),J=e===void 0?_e:se(e),[Se,Ce]=(0,m.useState)(()=>C(J,{format:s,withTime:P,timeFormat:R,showSeconds:z})),[we,Te]=(0,m.useState)(()=>O(J,z)),[Y,Ee]=(0,m.useState)(()=>{let e=J?a._(J):new Date;return new Date(e.getFullYear(),e.getMonth(),1)}),[De,Oe]=(0,m.useState)(`days`),ke=(0,m.useRef)(null),Ae=J?.getTime()??null,je=se(u),Me=se(d),Ne=E||xe&&!ye.valid,Pe=T||(xe&&!ye.valid?ye.error:void 0),Fe=a.u(G,de),Ie=a.d(G);(0,m.useEffect)(()=>{if(Ce(C(J,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Te(O(J,z)),J){let e=a._(J);Ee(new Date(e.getFullYear(),e.getMonth(),1))}},[s,Ae,z,R,P]);let X=(0,m.useCallback)(e=>a.f(e,je,Me)?Array.isArray(g)?g.some(t=>a.p(t,e)):typeof g==`function`?g(e):!1:!0,[g,Me,je]),Z=(0,m.useCallback)(e=>{be(e),L?.(e)},[L]),Q=(0,m.useCallback)(t=>{e===void 0&&ve(t),o?.(t)},[o,e]),Le=(0,m.useMemo)(()=>k(Se,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X}),[me,Se,X,Me,je,z,R,P]),Re=(0,m.useMemo)(()=>Le.status===`valid`?a._(Le.value):J?a._(J):null,[Le,J]),$=(0,m.useMemo)(()=>P?a.g(Le.status!==`empty`&&Le.timePart?Le.timePart:we||O(J,z),R)??{hours:0,minutes:0,seconds:0}:null,[we,Le,J,z,R,P]),ze=(0,m.useCallback)(e=>{let t=D(e.target.value,{inputFormat:me,separator:K,withTime:P,timeFormat:R,showSeconds:z});Ce(t.formatted),Te(t.timePart);let n=k(t.formatted,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X});if(n.status===`empty`){Z({valid:!0}),Q(null);return}if(n.status===`invalid`&&I)Z(n.result);else if(n.status===`valid`){Z({valid:!0}),Ee(new Date(n.value.getFullYear(),n.value.getMonth(),1));let t=z?6:4,r=P?i.u(e.target.value).slice(8).length:0;(!P||r>=t)&&Q(n.value)}},[Q,Z,me,X,Me,je,K,z,R,I,P]),Be=(0,m.useCallback)(()=>{q(!0);let e=k(Se,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X});if(e.status===`empty`){Z({valid:!0});return}if(e.status===`partial`){F&&Z({valid:!1,error:`Incomplete date`});return}if(e.status===`invalid`){if(P&&e.result.error===oe&&e.datePart){let t=a.l(0,0,0,z,R),n=k(`${e.datePart} ${t}`,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X});if(n.status===`valid`){Z({valid:!0}),Ce(C(n.value,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Te(O(n.value,z)),Q(n.value);return}}F&&Z(e.result);return}Z({valid:!0}),Ce(C(e.value,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Te(O(e.value,z)),Q(e.value)},[Q,Z,s,me,Se,X,Me,je,z,R,F,P]),Ve=(0,m.useCallback)(e=>{[`Backspace`,`Delete`,`Tab`,`ArrowLeft`,`ArrowRight`,`Home`,`End`,`Enter`].includes(e.key)||e.ctrlKey||e.metaKey||(P?/^[0-9\s:./-APMapm]$/:/^[0-9./-]$/).test(e.key)||e.preventDefault()},[P]),He=(0,m.useCallback)(()=>{Ce(``),Te(``),q(!1),Z({valid:!0}),Q(null)},[Q,Z]),Ue=(0,m.useCallback)(e=>{e.preventDefault(),e.stopPropagation(),!(te||ne||H)&&ge(e=>!e)},[te,H,ne]),We=(0,m.useCallback)(e=>{if(X(e))return;let t=P?we||a.l(0,0,0,z,R):``,n=P?a.r(e,t,{format:R,showSeconds:z}):a._(e);q(!0),Z({valid:!0}),Te(t),Ce(C(n,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Ee(new Date(e.getFullYear(),e.getMonth(),1)),Q(n),!P&&!H&&ge(!1)},[Q,we,Z,s,H,X,z,R,P]),Ge=(0,m.useCallback)(()=>{let e=a._(new Date);X(e)||We(e)},[We,X]),Ke=(0,m.useMemo)(()=>{if(!P)return[];let e=[],t=R===`12h`?12:23,n=+(R===`12h`);for(let r=n;r<=t;r+=1)e.push(r);return e},[R,P]),qe=(0,m.useMemo)(()=>{if(!P)return[];let e=[];for(let t=0;t<60;t+=B)e.push(t);return e},[B,P]),Je=(0,m.useMemo)(()=>{if(!P||!z)return[];let e=[];for(let t=0;t<60;t+=1)e.push(t);return e},[z,P]),Ye=(0,m.useCallback)((e,t,n=0)=>{let r=a.l(e,t,n,z,R),i=Re;if(q(!0),Te(r),!i){Ce(r);return}let o=a.r(i,r,{format:R,showSeconds:z});Z({valid:!0}),Ce(C(o,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Q(o)},[Q,Re,Z,s,z,R,P]),Xe=(0,m.useCallback)(e=>{Ye(j($?A($).hours:12,e),$?.minutes??0,$?.seconds??0)},[$,Ye]),Ze=(0,m.useMemo)(()=>{let e=Y.getFullYear(),t=Y.getMonth(),n=a.i(e,t),r=a.a(e,t);de===1&&(r=r===0?6:r-1);let i=[],o=t===0?11:t-1,s=t===0?e-1:e,c=a.i(s,o);for(let e=r-1;e>=0;--e)i.push({date:new Date(s,o,c-e),currentMonth:!1});for(let r=1;r<=n;r+=1)i.push({date:new Date(e,t,r),currentMonth:!0});let l=42-i.length,u=t===11?0:t+1,d=t===11?e+1:e;for(let e=1;e<=l;e+=1)i.push({date:new Date(d,u,e),currentMonth:!1});return i},[de,Y]),Qe=a._(new Date),$e=J?a._(J):Re,et=()=>(0,h.jsxs)(`div`,{className:`calendar`,children:[(0,h.jsxs)(`div`,{className:`calendar-header`,children:[(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>Ee(a.t(Y,-1)),"aria-label":pe.previousMonth,children:(0,h.jsx)(t.Wi,{})}),(0,h.jsxs)(`button`,{type:`button`,className:`header-title`,onClick:()=>Oe(e=>e===`days`?`months`:`days`),children:[Ie[Y.getMonth()],` `,Y.getFullYear()]}),(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>Ee(a.t(Y,1)),"aria-label":pe.nextMonth,children:(0,h.jsx)(t.Ui,{})})]}),De===`days`?(0,h.jsxs)(h.Fragment,{children:[(0,h.jsx)(`div`,{className:`day-names`,children:Fe.map(e=>(0,h.jsx)(`span`,{className:`day-name`,children:e},e))}),(0,h.jsx)(`div`,{className:`day-grid`,children:Ze.map(({date:e,currentMonth:t},r)=>{let i=$e?a.p(e,$e):!1,o=a.p(e,Qe),s=X(e);return(0,h.jsx)(`button`,{type:`button`,className:n.t(`day`,!t&&`other-month`,o&&`today`,i&&`selected`,s&&`disabled`),onClick:()=>We(e),disabled:s,tabIndex:-1,children:e.getDate()},`${e.toISOString()}-${r}`)})})]}):(0,h.jsx)(`div`,{className:`month-grid`,children:Ie.map((e,t)=>(0,h.jsx)(`button`,{type:`button`,className:n.t(`month-cell`,Y.getMonth()===t&&`selected`),onClick:()=>{Ee(new Date(Y.getFullYear(),t,1)),Oe(`days`)},children:e.slice(0,3)},e))}),ue&&(0,h.jsx)(`div`,{className:`footer`,children:(0,h.jsx)(`button`,{type:`button`,className:`today-btn`,onClick:Ge,children:pe.today})})]}),tt=()=>{if(!P)return null;let e=$?A($):null;return(0,h.jsxs)(`div`,{className:`date-picker-time-panel`,children:[(0,h.jsx)(`div`,{className:`date-picker-time-header`,children:`Time`}),(0,h.jsxs)(`div`,{className:`date-picker-time-columns`,children:[(0,h.jsx)(le,{items:Ke,selected:R===`12h`?e?.hours:$?.hours,onSelect:t=>Ye(R===`12h`?j(t,e?.meridiem??`AM`):t,$?.minutes??0,$?.seconds??0),label:`Hr`}),(0,h.jsx)(le,{items:qe,selected:$?.minutes,onSelect:e=>Ye($?.hours??0,e,$?.seconds??0),label:`Min`}),z&&(0,h.jsx)(le,{items:Je,selected:$?.seconds,onSelect:e=>Ye($?.hours??0,$?.minutes??0,e),label:`Sec`}),R===`12h`&&(0,h.jsx)(le,{items:[`AM`,`PM`],selected:e?.meridiem,onSelect:Xe,label:`AM/PM`})]})]})},nt=()=>(0,h.jsxs)(`div`,{className:n.t(`date-picker-popover-content`,P&&`with-time`),children:[et(),tt()]}),rt=P?R===`12h`?z?22:19:z?19:16:10,it=S(ee,s,P,R,z,V);return H?(0,h.jsxs)(`div`,{className:n.t(`date-picker`,b&&`color-${b}`,U&&`full-width`,fe),style:W,children:[(0,h.jsx)(f.t,{value:Se,onChange:ze,onBlur:Be,onKeyDown:Ve,onClear:He,type:`text`,inputMode:P?`text`:`numeric`,autoComplete:`off`,maxLength:rt,placeholder:it,disabled:te,readOnly:ne,id:v,variant:ie,size:y,color:b,label:x,helperText:w,error:Ne,errorText:Pe,required:M,clearable:N,fullWidth:U}),nt(),_&&J&&(0,h.jsx)(`input`,{type:`hidden`,name:_,value:a.s(J,P,z)})]}):(0,h.jsxs)(`div`,{className:n.t(`date-picker`,b&&`color-${b}`,U&&`full-width`,fe),style:W,children:[(0,h.jsx)(`div`,{ref:ke,className:`date-picker-input-anchor`,children:(0,h.jsx)(f.t,{value:Se,onChange:ze,onBlur:Be,onKeyDown:Ve,onClear:He,type:`text`,inputMode:P?`text`:`numeric`,autoComplete:`off`,maxLength:rt,placeholder:it,disabled:te,readOnly:ne,id:v,variant:ie,size:y,color:b,label:x,helperText:w,error:Ne,errorText:Pe,required:M,clearable:N,fullWidth:U,endIcon:(0,h.jsx)(`button`,{type:`button`,className:`date-picker-toggle`,onMouseDown:e=>e.preventDefault(),onClick:Ue,"aria-label":`Open calendar`,disabled:te||ne,children:(0,h.jsx)(t.Pi,{})})})}),_&&J&&(0,h.jsx)(`input`,{type:`hidden`,name:_,value:a.s(J,P,z)}),(0,h.jsx)(c.t,{className:`date-picker-popover`,style:{"--color-rgb":ae(b)},open:he,anchorRef:ke,onClose:()=>ge(!1),placement:`bottom-start`,children:nt()})]})}function le({items:e,selected:t,onSelect:r,label:i}){let a=(0,m.useRef)(null);(0,m.useEffect)(()=>{if(t===void 0||!a.current)return;let e=a.current.querySelector(`[data-value="${t}"]`);if(e){let t=a.current;t.scrollTop=e.offsetTop-t.clientHeight/2+e.offsetHeight/2}},[t]);let o=e=>typeof e==`number`?e.toString().padStart(2,`0`):e;return(0,h.jsxs)(`div`,{className:`date-picker-time-column`,children:[(0,h.jsx)(`div`,{className:`date-picker-time-column-label`,children:i}),(0,h.jsx)(`div`,{ref:a,className:`date-picker-time-column-list`,children:e.map(e=>(0,h.jsx)(`button`,{type:`button`,"data-value":e,className:n.t(`date-picker-time-column-item`,e===t&&`selected`),onClick:()=>r(e),children:o(e)},e))})]})}function N(e){let t=e.hours>=12?`PM`:`AM`;return{hours:e.hours%12||12,minutes:e.minutes,seconds:e.seconds,meridiem:t}}function P(e,t){return t===`AM`?e===12?0:e:e===12?12:e+12}function F(e,t,n,r,i){if(i===`24h`)return a.c(e,t,n,r);let o=N({hours:e,minutes:t,seconds:n}),s=`${o.hours.toString().padStart(2,`0`)}:${o.minutes.toString().padStart(2,`0`)}`;return`${r?`${s}:${o.seconds.toString().padStart(2,`0`)}`:s} ${o.meridiem}`}function I(e,t){if(t===`24h`)return a.h(e);let n=e.trim().toUpperCase().match(/^(\d{1,2}):(\d{2})(?::(\d{2}))?\s*(AM|PM)$/);if(n){let e=parseInt(n[1],10),t=parseInt(n[2],10),r=n[3]?parseInt(n[3],10):0,i=n[4];return e<1||e>12||t>59||r>59?null:{hours:P(e,i),minutes:t,seconds:r}}return a.h(e)}function L(e,t){return e.hours===t.hours?e.minutes===t.minutes?e.seconds-t.seconds:e.minutes-t.minutes:e.hours-t.hours}function R(e,t,n){return(!t||L(e,t)>=0)&&(!n||L(e,n)<=0)}function z({value:e,defaultValue:r,onChange:i,format:a=`24h`,showSeconds:o=!1,minuteStep:s=1,min:l,max:u,placeholder:d,disabled:f=!1,readOnly:p=!1,name:g,id:ee,variant:te=`outlined`,size:ne=`md`,color:_,label:v,helperText:re,errorText:ie,error:y=!1,required:ae=!1,clearable:b=!1,fullWidth:oe=!1,className:se,style:ce}){let[x,S]=(0,m.useState)(!1),[C,w]=(0,m.useState)(r??``),T=(0,m.useRef)(null),E=e===void 0?C:e,D=y||!!ie,O=I(E,a),k=I(l??``,a),A=I(u??``,a),j=O?N(O):null,M=O?F(O.hours,O.minutes,O.seconds,o,a):E,le=(0,m.useMemo)(()=>{let e=[],t=a===`12h`?12:23,n=+(a===`12h`);for(let r=n;r<=t;r++)e.push(r);return e},[a]),L=(0,m.useMemo)(()=>{let e=[];for(let t=0;t<60;t+=s)e.push(t);return e},[s]),z=(0,m.useMemo)(()=>{if(!o)return[];let e=[];for(let t=0;t<60;t++)e.push(t);return e},[o]),V=(0,m.useCallback)((e,t,n=0)=>R({hours:e,minutes:t,seconds:n},k,A),[A,k]),H=(0,m.useCallback)((t,n,r=0)=>{if(!V(t,n,r))return;let s=F(t,n,r,o,a);e===void 0&&w(s),i?.(s)},[a,V,i,o,e]),ue=(0,m.useCallback)(t=>{let n=t.target.value;e===void 0&&w(n)},[e]),de=(0,m.useCallback)(()=>{let t=I(E,a);if(t&&R(t,k,A)){let n=F(t.hours,t.minutes,t.seconds,o,a);e===void 0&&w(n),i?.(n)}},[E,a,A,k,i,o,e]),U=(0,m.useCallback)(e=>{let t=j?.hours??12,n=O?.minutes??0,r=O?.seconds??0;H(P(t,e),n,r)},[j?.hours,H,O?.minutes,O?.seconds]),fe=(0,m.useCallback)(t=>{t.stopPropagation(),e===void 0&&w(``),i?.(``)},[i,e]);return(0,h.jsxs)(`div`,{className:n.t(`time picker`,_&&`color-${_}`,oe&&`full-width`,se),style:ce,children:[v&&(0,h.jsx)(`label`,{htmlFor:ee,className:n.t(`field-label`,x&&`focused`,D&&`error`,ae&&`required`),children:v}),(0,h.jsxs)(`div`,{ref:T,className:n.t(`time trigger`,`field-${te}`,`field-${ne}`,x&&`focused`,D&&`error`,f&&`disabled`),onClick:()=>!f&&!p&&S(!0),children:[(0,h.jsx)(`span`,{className:`time icon`,children:(0,h.jsx)(t.Ni,{})}),(0,h.jsx)(`input`,{type:`text`,className:`time input`,value:M,onChange:ue,onBlur:de,placeholder:d??(a===`12h`?o?`hh:mm:ss AM`:`hh:mm AM`:o?`HH:MM:SS`:`HH:MM`),disabled:f,readOnly:p,id:ee,"aria-invalid":D||void 0}),b&&E&&!f&&(0,h.jsx)(`button`,{type:`button`,className:`time clear clear-btn-base`,onClick:fe,tabIndex:-1,"aria-label":`Clear time`,children:(0,h.jsx)(t.Ki,{})})]}),g&&(0,h.jsx)(`input`,{type:`hidden`,name:g,value:M}),(0,h.jsx)(c.t,{className:`time picker popover`,open:x,anchorRef:T,onClose:()=>S(!1),placement:`bottom-start`,children:(0,h.jsxs)(`div`,{className:`time columns`,children:[(0,h.jsx)(B,{items:le,selected:a===`12h`?j?.hours:O?.hours,onSelect:e=>H(a===`12h`?P(e,j?.meridiem??`AM`):e,O?.minutes??0,O?.seconds??0),isDisabled:e=>!V(a===`12h`?P(e,j?.meridiem??`AM`):e,O?.minutes??0,O?.seconds??0),label:`Hr`}),(0,h.jsx)(B,{items:L,selected:O?.minutes,onSelect:e=>H(O?.hours??0,e,O?.seconds??0),isDisabled:e=>!V(O?.hours??0,e,O?.seconds??0),label:`Min`}),o&&(0,h.jsx)(B,{items:z,selected:O?.seconds,onSelect:e=>H(O?.hours??0,O?.minutes??0,e),isDisabled:e=>!V(O?.hours??0,O?.minutes??0,e),label:`Sec`}),a===`12h`&&(0,h.jsx)(B,{items:[`AM`,`PM`],selected:j?.meridiem,onSelect:U,label:`AM/PM`})]})}),(ie||re)&&(0,h.jsx)(`div`,{className:`time bottom`,children:ie?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:ie}):(0,h.jsx)(`span`,{className:`time helper`,children:re})})]})}function B({items:e,selected:t,onSelect:r,isDisabled:i,label:a}){let o=(0,m.useRef)(null);(0,m.useEffect)(()=>{if(t===void 0||!o.current)return;let e=o.current.querySelector(`[data-value="${t}"]`);if(e){let t=o.current;t.scrollTop=e.offsetTop-t.clientHeight/2+e.offsetHeight/2}},[t]);let s=e=>typeof e==`number`?e.toString().padStart(2,`0`):e;return(0,h.jsxs)(`div`,{className:`time column`,children:[(0,h.jsx)(`div`,{className:`time column label`,children:a}),(0,h.jsx)(`div`,{ref:o,className:`time column list`,children:e.map(e=>{let a=i?.(e)??!1;return(0,h.jsx)(`button`,{type:`button`,"data-value":e,className:n.t(`time column item`,e===t&&`selected`,a&&`disabled`),onClick:()=>r(e),disabled:a,children:s(e)},e)})})]})}function V(e){if(!e)return null;if(e instanceof Date)return a._(e);let t=new Date(e);return isNaN(t.getTime())?null:a._(t)}function H(e,t){return e.getTime()<=t.getTime()?{start:e,end:t}:{start:t,end:e}}function ue(e,t,n){if(!t||!n)return!1;let r=e.getTime();return r>t.getTime()&&r<n.getTime()}function de(e,t,n){return e&&t?`${a.o(e,n)} - ${a.o(t,n)}`:e?`${a.o(e,n)} - ...`:``}function U(e){return new Date(e.getFullYear(),e.getMonth(),1)}function fe(e){return new Date(e.getFullYear(),e.getMonth()+1,0)}function W(e){let t=a._(new Date);return t.setDate(t.getDate()-(e-1)),t}function G(e){let t=a._(new Date);return new Date(t.getFullYear(),t.getMonth()-e,t.getDate())}function pe(e){let t=a._(new Date),n=new Date(t.getFullYear(),t.getMonth()-1,1);return[{label:e.presets.today,value:{start:t,end:t}},{label:e.presets.days2,value:{start:W(2),end:t}},{label:e.presets.days3,value:{start:W(3),end:t}},{label:e.presets.days7,value:{start:W(7),end:t}},{label:e.presets.days14,value:{start:W(14),end:t}},{label:e.presets.days31,value:{start:W(31),end:t}},{label:e.presets.thisMonth,value:{start:U(t),end:fe(t)}},{label:e.presets.previousMonth,value:{start:U(n),end:fe(n)}},{label:e.presets.months2,value:{start:G(2),end:t}},{label:e.presets.months3,value:{start:G(3),end:t}},{label:e.presets.months6,value:{start:G(6),end:t}},{label:e.presets.year1,value:{start:G(12),end:t}}]}function me(e,t){let n=e.getFullYear(),r=e.getMonth(),i=a.i(n,r),o=a.a(n,r);t===1&&(o=o===0?6:o-1);let s=[],c=r===0?11:r-1,l=r===0?n-1:n,u=a.i(l,c);for(let e=o-1;e>=0;--e)s.push({date:new Date(l,c,u-e),currentMonth:!1});for(let e=1;e<=i;e+=1)s.push({date:new Date(n,r,e),currentMonth:!0});let d=42-s.length,f=r===11?0:r+1,p=r===11?n+1:n;for(let e=1;e<=d;e+=1)s.push({date:new Date(p,f,e),currentMonth:!1});return s}function K({value:e,defaultValue:r,onChange:i,format:o=`dd.MM.yyyy`,locale:s,min:l,max:u,disabledDates:d,placeholder:f,disabled:g=!1,readOnly:ee=!1,name:te,id:ne,variant:_=`outlined`,size:v=`md`,color:re,label:y,helperText:b,errorText:oe,error:se=!1,required:ce=!1,clearable:x=!1,inline:S=!1,showTodayButton:C=!0,presets:w=!1,presetsSidebar:T=!1,firstDayOfWeek:E=1,fullWidth:D=!1,allowSameDay:O=!0,className:k,style:A}){let j=p.t(s),M=e?{start:V(e.start),end:V(e.end)}:null,[le,N]=(0,m.useState)(()=>({start:V(r?.start),end:V(r?.end)})),[P,F]=(0,m.useState)(null),[I,L]=(0,m.useState)(!1),R=(0,m.useRef)(null),z=M??le,B=z.start,U=z.end,fe=V(l),W=V(u),G=se||!!oe,K=ie(),he=a.u(j,E),ge=a.d(j),_e=(0,m.useMemo)(()=>w===!0||T&&!w?pe(K):Array.isArray(w)?w:[],[w,T,K]),[ve,ye]=(0,m.useState)(()=>{let e=B??new Date;return new Date(e.getFullYear(),e.getMonth(),1)}),be=B?.getTime()??null;(0,m.useEffect)(()=>{if(!be)return;let e=new Date(be);ye(new Date(e.getFullYear(),e.getMonth(),1))},[be]);let xe=(0,m.useCallback)(e=>a.f(e,fe,W)?Array.isArray(d)?d.some(t=>a.p(t,e)):typeof d==`function`?d(e):!1:!0,[d,W,fe]),q=(0,m.useCallback)(t=>{e===void 0&&N(t),i?.(t)},[i,e]),J=(0,m.useCallback)(e=>{if(!xe(e)){if(!B||B&&U){q({start:e,end:null}),F(null);return}!O&&a.p(e,B)||(q(H(B,e)),F(null),S||L(!1))}},[O,q,U,S,xe,B]),Se=(0,m.useCallback)(e=>{e.stopPropagation(),q({start:null,end:null}),F(null)},[q]),Ce=(0,m.useCallback)(()=>{let e=a._(new Date);xe(e)||(q({start:e,end:e}),ye(new Date(e.getFullYear(),e.getMonth(),1)),F(null),S||L(!1))},[q,S,xe]),we=(0,m.useCallback)(e=>{let t=V(e.value.start),n=V(e.value.end);if(!t||!n)return;let r=H(t,n);xe(r.start)||xe(r.end)||(q(r),ye(new Date(r.start.getFullYear(),r.start.getMonth(),1)),F(null),S||L(!1))},[q,S,xe]),Te=B&&!U?P:null,Y=ve,Ee=a.t(ve,1),De=a._(new Date),Oe=(0,m.useMemo)(()=>de(B,U,o),[U,o,B]),ke=(0,m.useMemo)(()=>[Y,Ee].map(e=>({monthDate:e,days:me(e,E)})),[E,Y,Ee]),Ae=B&&U?`${a.o(B,o)} - ${a.o(U,o)}`:B?`${a.o(B,o)} - ...`:f??K.defaultRangePlaceholder,je=T&&_e.length>0,Me=!T&&_e.length>0,Ne=()=>(0,h.jsx)(`div`,{className:`presets-sidebar`,children:_e.map(e=>(0,h.jsx)(`button`,{type:`button`,className:`preset-sidebar-btn`,onClick:()=>we(e),children:e.label},e.label))}),Pe=()=>(0,h.jsxs)(`div`,{className:`calendar-body`,children:[(0,h.jsxs)(`div`,{className:`calendar-top`,children:[(0,h.jsxs)(`div`,{className:`calendar-caption`,children:[(0,h.jsxs)(`span`,{className:`caption-title`,children:[ge[Y.getMonth()],` `,Y.getFullYear()]}),(0,h.jsx)(`span`,{className:`caption-subtitle`,children:K.rangeSubtitle})]}),(0,h.jsxs)(`div`,{className:`nav-actions`,children:[(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>ye(a.t(ve,-1)),"aria-label":K.previousMonth,children:(0,h.jsx)(t.Wi,{})}),(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>ye(a.t(ve,1)),"aria-label":K.nextMonth,children:(0,h.jsx)(t.Ui,{})})]})]}),Me&&(0,h.jsx)(`div`,{className:`presets`,children:_e.map(e=>(0,h.jsx)(`button`,{type:`button`,className:`preset-btn`,onClick:()=>we(e),children:e.label},e.label))}),(0,h.jsx)(`div`,{className:`months`,children:ke.map(({monthDate:e,days:t})=>(0,h.jsxs)(`div`,{className:`month-panel`,children:[(0,h.jsxs)(`div`,{className:`month-title`,children:[ge[e.getMonth()],` `,e.getFullYear()]}),(0,h.jsx)(`div`,{className:`day-names`,children:he.map(t=>(0,h.jsx)(`span`,{className:`day-name`,children:t},`${e.toISOString()}-${t}`))}),(0,h.jsx)(`div`,{className:`day-grid`,children:t.map(({date:t,currentMonth:r},i)=>{let o=xe(t),s=B?a.p(t,B):!1,c=U?a.p(t,U):!1,l=ue(t,B,U),u=!U&&B&&Te?H(B,Te):null,d=u?ue(t,u.start,u.end):!1,f=u?a.p(t,u.start)||a.p(t,u.end):!1;return(0,h.jsx)(`button`,{type:`button`,className:n.t(`day`,!r&&`other-month`,a.p(t,De)&&`today`,s&&`range-start selected`,c&&`range-end selected`,l&&`in-range`,d&&!f&&`preview-range`,o&&`disabled`),onClick:()=>J(t),onMouseEnter:()=>B&&!U&&F(t),onFocus:()=>B&&!U&&F(t),disabled:o,tabIndex:-1,children:t.getDate()},`${e.toISOString()}-${i}`)})})]},e.toISOString()))}),(0,h.jsxs)(`div`,{className:`footer`,children:[(0,h.jsx)(`span`,{className:`summary`,children:Ae}),(0,h.jsxs)(`div`,{className:`footer-actions`,children:[x&&(B||U)&&(0,h.jsx)(`button`,{type:`button`,className:`footer-btn`,onClick:e=>{e.preventDefault(),q({start:null,end:null}),F(null)},children:K.clear}),C&&(0,h.jsx)(`button`,{type:`button`,className:`footer-btn`,onClick:Ce,children:K.today})]})]})]}),Fe=()=>(0,h.jsxs)(`div`,{className:n.t(`date-range-calendar`,je&&`with-sidebar`),children:[je&&Ne(),Pe()]});return S?(0,h.jsxs)(`div`,{className:n.t(`date-range-picker`,re&&`color-${re}`,D&&`full-width`,k),style:A,children:[y&&(0,h.jsx)(`label`,{className:n.t(`field-label`,G&&`error`,ce&&`required`),children:y}),Fe()]}):(0,h.jsxs)(`div`,{className:n.t(`date-range-picker`,re&&`color-${re}`,D&&`full-width`,k),style:A,children:[y&&(0,h.jsx)(`label`,{htmlFor:ne,className:n.t(`field-label`,I&&`focused`,G&&`error`,ce&&`required`),children:y}),(0,h.jsxs)(`div`,{ref:R,className:n.t(`trigger`,`field-${_}`,`field-${v}`,I&&`focused`,G&&`error`,g&&`disabled`),onClick:()=>!g&&!ee&&L(!0),children:[(0,h.jsx)(`span`,{className:`icon`,children:(0,h.jsx)(t.Pi,{})}),(0,h.jsx)(`input`,{type:`text`,className:`input`,value:Oe,placeholder:f??K.defaultRangePlaceholder,disabled:g,readOnly:!0,id:ne,"aria-invalid":G||void 0}),x&&(B||U)&&!g&&(0,h.jsx)(`button`,{type:`button`,className:`clear-btn clear-btn-base`,onClick:Se,tabIndex:-1,"aria-label":K.clear,children:(0,h.jsx)(t.Ki,{})})]}),te&&B&&U&&(0,h.jsx)(`input`,{type:`hidden`,name:te,value:`${B.toISOString().split(`T`)[0]}:${U.toISOString().split(`T`)[0]}`}),(0,h.jsx)(c.t,{className:`date-range-picker-popover`,style:{"--color-rgb":ae(re)},open:I,anchorRef:R,onClose:()=>{L(!1),F(null)},placement:`bottom-start`,children:Fe()}),(oe||b)&&(0,h.jsx)(`div`,{className:`bottom-row`,children:oe?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:oe}):(0,h.jsx)(`span`,{className:`helper-text`,children:b})})]})}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return z}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return K}});
2
- //# sourceMappingURL=dropdowns-BP2HBR-x.cjs.map
1
+ const e=require(`./MI18nProvider-bf1G7lTP.cjs`),t=require(`./icons-BHFwX7ri.cjs`),n=require(`./cn-CU5TNITO.cjs`),r=require(`./validators-B6yWdsu2.cjs`),i=require(`./formatters-CNjg_h7-.cjs`),a=require(`./dateUtils-Dq1vaA-D.cjs`),o=require(`./useGhostText-BFaUUKid.cjs`),s=require(`./useKeyboardNav-CtGPfQX7.cjs`),c=require(`./MPopover-BbgAAM5Z.cjs`),l=require(`./MButton-ouB6903s.cjs`),u=require(`./MCheckbox-Cbk5hwzJ.cjs`),d=require(`./MTag-Dez1GOX0.cjs`),f=require(`./MInput-ClHpIrDG.cjs`),p=require(`./locale-CJWWjFm-.cjs`);require(`./core-B2klLGki.cjs`);let m=require(`react`),h=require(`react/jsx-runtime`);function g({options:e,value:r,defaultValue:i,onChange:a,multiple:o=!1,searchable:f=!1,placeholder:p=`MSelect...`,disabled:g=!1,name:ee,id:te,variant:ne=`outlined`,size:_=`md`,color:v,fullWidth:re=!1,label:ie,helperText:y,errorText:ae,error:b=!1,required:oe=!1,loading:se=!1,clearable:ce=!1,maxHeight:x=300,noOptionsText:S=`No options`,renderOption:C,renderValue:w,className:T,style:E}){let[D,O]=(0,m.useState)(!1),[k,A]=(0,m.useState)(i??(o?[]:``)),[j,M]=(0,m.useState)(``),le=(0,m.useRef)(null),N=r===void 0?k:r,P=b||!!ae,F=(0,m.useMemo)(()=>Array.isArray(N)?N:N?[N]:[],[N]),I=(0,m.useMemo)(()=>e.filter(e=>F.includes(e.value)),[e,F]),L=(0,m.useMemo)(()=>{if(!f||!j)return e;let t=j.toLowerCase();return e.filter(e=>e.label.toLowerCase().includes(t))},[e,f,j]),R=(0,m.useMemo)(()=>{let e=new Map;for(let t of L){let n=t.group??``;e.has(n)||e.set(n,[]),e.get(n).push(t)}return e},[L]),z=L,B=(0,m.useCallback)(e=>{let t=z[e];if(!(!t||t.disabled))if(o){let e=Array.isArray(N)?N:[],n=e.includes(t.value)?e.filter(e=>e!==t.value):[...e,t.value];r===void 0&&A(n),a?.(n)}else r===void 0&&A(t.value),a?.(t.value),O(!1),M(``)},[z,o,N,r,a]),{activeIndex:V,setActiveIndex:H,resetIndex:ue,onKeyDown:de}=s.t({itemCount:z.length,onSelect:B,onClose:()=>{O(!1),M(``)},isOpen:D}),U=(0,m.useCallback)(()=>{g||(O(e=>!e),ue())},[g,ue]),fe=(0,m.useCallback)(e=>{e.stopPropagation();let t=o?[]:``;r===void 0&&A(t),a?.(t)},[o,r,a]),W=(0,m.useMemo)(()=>w&&I.length>0?w(o?I:I[0]):o&&I.length>0?(0,h.jsx)(`span`,{className:`tags`,children:I.map(e=>(0,h.jsx)(d.t,{label:e.label,color:v,size:_,variant:`solid`},e.value))}):!o&&I.length>0?I[0].label:(0,h.jsx)(`span`,{className:`placeholder`,children:p}),[I,o,w,p,v,_]);return(0,h.jsxs)(`div`,{className:n.t(`select`,v&&`color-${v}`,re&&`full-width`,T),style:E,children:[ie&&(0,h.jsx)(`label`,{htmlFor:te,className:n.t(`field-label`,D&&`focused`,P&&`error`,oe&&`required`),children:ie}),(0,h.jsxs)(`div`,{ref:le,className:n.t(`trigger`,`field-${ne}`,`field-${_}`,D&&`focused`,P&&`error`,g&&`disabled`),onClick:U,onKeyDown:de,tabIndex:g?-1:0,role:`combobox`,"aria-expanded":D,"aria-haspopup":`listbox`,"aria-invalid":P||void 0,id:te,children:[(0,h.jsx)(`span`,{className:`value`,children:W}),se&&(0,h.jsx)(l.r,{size:`sm`,color:v}),ce&&F.length>0&&!se&&!g&&(0,h.jsx)(`button`,{type:`button`,className:`clear-btn clear-btn-base`,onClick:fe,tabIndex:-1,"aria-label":`Clear selection`,children:(0,h.jsx)(t.Ki,{})}),(0,h.jsx)(`span`,{className:n.t(`arrow`,D&&`open`),"aria-hidden":`true`,children:(0,h.jsx)(t.Hi,{})})]}),ee&&(0,h.jsx)(`input`,{type:`hidden`,name:ee,value:Array.isArray(N)?N.join(`,`):N}),(0,h.jsx)(c.t,{className:`select-popover`,open:D,anchorRef:le,onClose:()=>{O(!1),M(``)},matchWidth:!0,placement:`bottom-start`,children:(0,h.jsxs)(`div`,{style:{maxHeight:x},className:`dropdown`,children:[f&&(0,h.jsx)(`div`,{className:`search-box`,children:(0,h.jsx)(`input`,{type:`text`,className:`search-input`,placeholder:`Search...`,value:j,onChange:e=>{M(e.target.value),H(0)},onKeyDown:de,autoFocus:!0})}),z.length===0?(0,h.jsx)(`div`,{className:`no-options`,children:S}):(0,h.jsx)(`div`,{className:`options-list`,role:`listbox`,children:[...R.entries()].map(([e,t])=>(0,h.jsxs)(`div`,{children:[e&&(0,h.jsx)(`div`,{className:`group-header`,children:e}),t.map(e=>{let t=z.indexOf(e),r=t===V,i=F.includes(e.value);return(0,h.jsxs)(`div`,{className:n.t(`option`,r&&`active`,i&&`selected`,e.disabled&&`disabled`),onClick:()=>!e.disabled&&B(t),onMouseEnter:()=>H(t),role:`option`,"aria-selected":i,"aria-disabled":e.disabled,children:[o&&(0,h.jsx)(u.t,{checked:i,size:`sm`,color:v,clickEffect:`none`,className:`select-check`}),C?C(e,r,i):e.label]},e.value)})]},e))})]})}),(ae||y)&&(0,h.jsx)(`div`,{className:`bottom-row`,children:ae?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:ae}):(0,h.jsx)(`span`,{className:`helper-text`,children:y})})]})}function ee(e){return typeof e==`string`?e:String(e)}function te(e){return typeof e==`string`?e:String(e)}function ne(e,t,n){if(!t)return e;let r=t.toLowerCase();return e.filter(e=>n(e).toLowerCase().includes(r))}function _({options:e,value:r,onChange:i,getOptionLabel:a=ee,getOptionValue:u=te,filterOptions:f,multiple:p=!1,debounceMs:g=0,onInputChange:_,loading:v=!1,loadingText:re=`Loading...`,noOptionsText:ie=`No options`,placeholder:y=`Type to search...`,disabled:ae=!1,name:b,id:oe,variant:se=`outlined`,size:ce=`md`,color:x,fullWidth:S=!1,label:C,helperText:w,errorText:T,error:E=!1,required:D=!1,clearable:O=!1,maxHeight:k=300,renderOption:A,renderTags:j,className:M,style:le}){let[N,P]=(0,m.useState)(!1),[F,I]=(0,m.useState)(``),L=(0,m.useRef)(null),R=(0,m.useRef)(null),z=E||!!T,B=(0,m.useMemo)(()=>r==null?[]:Array.isArray(r)?r.filter(e=>e!=null):[r],[r]),V=(0,m.useMemo)(()=>f?f(e,F):ne(e,F,a),[e,F,f,a]),H=o.r(e=>_?.(e),g),ue=(0,m.useCallback)(e=>{I(e.target.value),H(e.target.value),N||P(!0)},[N,H]),de=(0,m.useCallback)(e=>{let t=V[e];if(t)if(p){let e=[...B],n=u(t),r=e.findIndex(e=>u(e)===n);r>=0?e.splice(r,1):e.push(t),i?.(e),I(``),R.current?.focus()}else i?.(t),I(a(t)),P(!1)},[V,p,B,u,a,i]),U=(0,m.useCallback)(e=>{let t=[...B];t.splice(e,1),i?.(p?t:t[0]??``)},[B,i,p]),{activeIndex:fe,setActiveIndex:W,resetIndex:G,onKeyDown:pe}=s.t({itemCount:V.length,onSelect:de,onClose:()=>P(!1),isOpen:N}),me=(0,m.useCallback)(e=>{if(e.key===`Backspace`&&p&&!F&&B.length>0){U(B.length-1);return}pe(e)},[F,p,B,pe,U]),K=(0,m.useCallback)(e=>{e.stopPropagation(),I(``),i?.(p?[]:``),R.current?.focus()},[p,i]);return(0,h.jsxs)(`div`,{className:n.t(`autocomplete`,x&&`color-${x}`,S&&`full-width`,M),style:le,children:[C&&(0,h.jsx)(`label`,{htmlFor:oe,className:n.t(`field-label`,N&&`focused`,z&&`error`,D&&`required`),children:C}),(0,h.jsxs)(`div`,{ref:L,className:n.t(`input-wrapper`,`field-${se}`,`field-${ce}`,N&&`focused`,z&&`error`,ae&&`disabled`),onClick:()=>R.current?.focus(),children:[p&&B.length>0&&(j?j(B,U):(0,h.jsx)(`span`,{className:`tags`,children:B.map((e,t)=>(0,h.jsx)(d.t,{label:a(e),color:x,size:ce,variant:`solid`,closable:!0,onClose:()=>U(t)},u(e)))})),(0,h.jsx)(`input`,{ref:R,type:`text`,className:`input`,value:F,onChange:ue,onFocus:()=>{P(!0),G()},onKeyDown:me,placeholder:B.length>0?``:y,disabled:ae,id:oe,"aria-expanded":N,"aria-haspopup":`listbox`,"aria-invalid":z||void 0,autoComplete:`off`}),v&&(0,h.jsx)(l.r,{size:`sm`,color:x}),O&&(B.length>0||F)&&!v&&!ae&&(0,h.jsx)(`button`,{type:`button`,className:`clear-btn clear-btn-base`,onClick:K,tabIndex:-1,children:(0,h.jsx)(t.Ki,{})})]}),b&&(0,h.jsx)(`input`,{type:`hidden`,name:b,value:B.map(u).join(`,`)}),(0,h.jsx)(c.t,{className:n.t(`autocomplete-popover`,x&&`color-${x}`),open:N&&(V.length>0||v||!!F),anchorRef:L,onClose:()=>P(!1),matchWidth:!0,placement:`bottom-start`,children:(0,h.jsx)(`div`,{style:{maxHeight:k},className:`dropdown`,children:v?(0,h.jsx)(`div`,{className:`loading-msg`,children:re}):V.length===0?(0,h.jsx)(`div`,{className:`no-options`,children:ie}):(0,h.jsx)(`div`,{className:`options-list`,role:`listbox`,children:V.map((e,t)=>{let r=t===fe,i=B.some(t=>u(t)===u(e));return(0,h.jsx)(`div`,{className:n.t(`option`,r&&`active`,i&&`selected`),onClick:()=>de(t),onMouseEnter:()=>W(t),role:`option`,"aria-selected":i,children:A?A(e,r):a(e)},u(e))})})})}),(T||w)&&(0,h.jsx)(`div`,{className:`bottom-row`,children:T?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:T}):(0,h.jsx)(`span`,{className:`helper-text`,children:w})})]})}function v(){let t=e.r();return(0,m.useCallback)((e,n)=>t?.t(e,n)??n,[t])}function re(){let e=v();return(0,m.useMemo)(()=>({today:e(`mineralui.datePicker.today`,`Today`),clear:e(`mineralui.datePicker.clear`,`Clear`),previousMonth:e(`mineralui.datePicker.previousMonth`,`Previous month`),nextMonth:e(`mineralui.datePicker.nextMonth`,`Next month`)}),[e])}function ie(){let e=v();return(0,m.useMemo)(()=>({today:e(`mineralui.dateRangePicker.today`,`Today`),clear:e(`mineralui.dateRangePicker.clear`,`Clear`),previousMonth:e(`mineralui.dateRangePicker.previousMonth`,`Previous month`),nextMonth:e(`mineralui.dateRangePicker.nextMonth`,`Next month`),rangeSubtitle:e(`mineralui.dateRangePicker.rangeSubtitle`,`Select start and end dates in one panel.`),defaultRangePlaceholder:e(`mineralui.dateRangePicker.defaultRangePlaceholder`,`Select date range...`),presets:{today:e(`mineralui.dateRangePicker.presets.today`,`Today`),days2:e(`mineralui.dateRangePicker.presets.days2`,`2 days`),days3:e(`mineralui.dateRangePicker.presets.days3`,`3 days`),days7:e(`mineralui.dateRangePicker.presets.days7`,`7 days`),days14:e(`mineralui.dateRangePicker.presets.days14`,`14 days`),days31:e(`mineralui.dateRangePicker.presets.days31`,`31 days`),thisMonth:e(`mineralui.dateRangePicker.presets.thisMonth`,`This month`),previousMonth:e(`mineralui.dateRangePicker.presets.previousMonth`,`Previous month`),months2:e(`mineralui.dateRangePicker.presets.months2`,`2 months`),months3:e(`mineralui.dateRangePicker.presets.months3`,`3 months`),months6:e(`mineralui.dateRangePicker.presets.months6`,`6 months`),year1:e(`mineralui.dateRangePicker.presets.year1`,`1 year`)}}),[e])}var y={primary:`var(--mineral-primary-rgb)`,neutral:`var(--mineral-neutral-rgb)`,success:`var(--mineral-success-rgb)`,error:`var(--mineral-error-rgb)`,warning:`var(--mineral-warning-rgb)`,info:`var(--mineral-info-rgb)`,light:`var(--mineral-light-rgb)`,dark:`var(--mineral-dark-color-rgb)`,news:`var(--mineral-news-rgb)`};function ae(e){return y[e??`primary`]??y.primary}var b=`Date is unavailable`,oe=`Invalid time`;function se(e){if(!e)return null;if(e instanceof Date)return isNaN(e.getTime())?null:new Date(e.getTime());let t=new Date(e);return isNaN(t.getTime())?null:t}function ce(e){let t=e.replace(/DD/g,`dd`).replace(/YYYY/g,`yyyy`),n=t.match(/dd|MM|yyyy/g),r=t.match(/[^dMy]/)?.[0],i=r===`/`||r===`.`||r===`-`?r:`.`;switch(n?.join(`/`)){case`MM/dd/yyyy`:return{inputFormat:`MM/DD/YYYY`,separator:i};case`yyyy/MM/dd`:return{inputFormat:`YYYY/MM/DD`,separator:i};default:return{inputFormat:`DD/MM/YYYY`,separator:i}}}function x(e,t){return e===`12h`?t?`hh:mm:ss AM`:`hh:mm AM`:t?`HH:MM:SS`:`HH:MM`}function S(e,t,n,r,i,a){return e||(n?`${t} ${a??x(r,i)}`:t)}function C(e,t){if(!e)return``;let n=a.o(a._(e),t.format);return t.withTime?`${n} ${a.l(e.getHours(),e.getMinutes(),e.getSeconds(),t.showSeconds,t.timeFormat)}`:n}function w(e,t){return e?e.length<=2?e:e.length<=4?`${e.slice(0,2)}:${e.slice(2)}`:t?`${e.slice(0,2)}:${e.slice(2,4)}:${e.slice(4,6)}`:`${e.slice(0,2)}:${e.slice(2,4)}`:``}function T(e){let t=e.toUpperCase().replace(/[^APM]/g,``);return t?t.startsWith(`AM`)?`AM`:t.startsWith(`PM`)?`PM`:t.startsWith(`A`)?`A`:t.startsWith(`P`)?`P`:``:``}function E(e,t){let n=e.trim();if(!n)return{datePart:``,timePart:``};if(!t)return{datePart:n,timePart:``};let r=n.indexOf(` `);return r===-1?{datePart:n,timePart:``}:{datePart:n.slice(0,r).trim(),timePart:n.slice(r+1).trim()}}function D(e,t){let n=e.toUpperCase(),r=i.u(n),a=r.slice(0,8),o=t.withTime?r.slice(8,8+(t.showSeconds?6:4)):``,s=i.i(a,t.inputFormat,t.separator);if(!t.withTime)return{formatted:s,datePart:s,timePart:``};let c=w(o,t.showSeconds),l=t.timeFormat===`12h`?T(n):``,u=`${c}${l?`${c?` `:``}${l}`:``}`.trim();if(!s)return{formatted:u,datePart:``,timePart:u};let d=a.length===8,f=/\s/.test(n.slice(s.length));return{formatted:u||d&&f?`${s} ${u}`:s,datePart:s,timePart:u}}function O(e,t){return e?a.l(e.getHours(),e.getMinutes(),e.getSeconds(),t,`24h`):``}function k(e,t){let{datePart:n,timePart:i}=E(e,t.withTime);if(!n&&!i)return{status:`empty`};let o=r.a(n,{format:t.inputFormat,minDate:t.minDate??void 0,maxDate:t.maxDate??void 0});if(!o.valid)return o.error===`Incomplete date`?{status:`partial`,datePart:n,timePart:i}:{status:`invalid`,datePart:n,timePart:i,result:o};let s=r.i(n,t.inputFormat);return s?t.isDisabled(s)?{status:`invalid`,datePart:n,timePart:i,result:{valid:!1,error:b}}:t.withTime?i?a.g(i,t.timeFormat)?{status:`valid`,datePart:n,timePart:i,value:a.r(s,i,{format:t.timeFormat,showSeconds:t.showSeconds})}:{status:`invalid`,datePart:n,timePart:i,result:{valid:!1,error:oe}}:{status:`valid`,datePart:n,timePart:``,value:a.r(s,``,{format:t.timeFormat,showSeconds:t.showSeconds})}:{status:`valid`,datePart:n,timePart:``,value:a._(s)}:{status:`invalid`,datePart:n,timePart:i,result:{valid:!1,error:`Invalid date`}}}function A(e){let t=e.hours>=12?`PM`:`AM`;return{hours:e.hours%12||12,minutes:e.minutes,seconds:e.seconds,meridiem:t}}function j(e,t){return t===`AM`?e===12?0:e:e===12?12:e+12}function M({value:e,defaultValue:r,onChange:o,format:s=`dd.MM.yyyy`,locale:l,min:u,max:d,disabledDates:g,placeholder:ee,disabled:te=!1,readOnly:ne=!1,name:_,id:v,variant:ie=`outlined`,size:y=`md`,color:b,label:x,helperText:w,errorText:T,error:E=!1,required:M=!1,clearable:N=!1,withTime:P=!1,validateOnBlur:F=!0,validateOnChange:I=!1,onValidationChange:L,timeFormat:R=`24h`,showSeconds:z=!1,minuteStep:B=1,timePlaceholder:V,inline:H=!1,showTodayButton:ue=!0,firstDayOfWeek:de=1,fullWidth:U=!1,className:fe,style:W}){let G=p.t(l),pe=re(),{inputFormat:me,separator:K}=(0,m.useMemo)(()=>ce(s),[s]),[he,ge]=(0,m.useState)(!1),[_e,ve]=(0,m.useState)(()=>se(r)),[ye,be]=(0,m.useState)({valid:!0}),[xe,q]=(0,m.useState)(!1),J=e===void 0?_e:se(e),[Se,Ce]=(0,m.useState)(()=>C(J,{format:s,withTime:P,timeFormat:R,showSeconds:z})),[we,Te]=(0,m.useState)(()=>O(J,z)),[Y,Ee]=(0,m.useState)(()=>{let e=J?a._(J):new Date;return new Date(e.getFullYear(),e.getMonth(),1)}),[De,Oe]=(0,m.useState)(`days`),ke=(0,m.useRef)(null),Ae=J?.getTime()??null,je=se(u),Me=se(d),Ne=E||xe&&!ye.valid,Pe=T||(xe&&!ye.valid?ye.error:void 0),Fe=a.u(G,de),Ie=a.d(G);(0,m.useEffect)(()=>{if(Ce(C(J,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Te(O(J,z)),J){let e=a._(J);Ee(new Date(e.getFullYear(),e.getMonth(),1))}},[s,Ae,z,R,P]);let X=(0,m.useCallback)(e=>a.f(e,je,Me)?Array.isArray(g)?g.some(t=>a.p(t,e)):typeof g==`function`?g(e):!1:!0,[g,Me,je]),Z=(0,m.useCallback)(e=>{be(e),L?.(e)},[L]),Q=(0,m.useCallback)(t=>{e===void 0&&ve(t),o?.(t)},[o,e]),Le=(0,m.useMemo)(()=>k(Se,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X}),[me,Se,X,Me,je,z,R,P]),Re=(0,m.useMemo)(()=>Le.status===`valid`?a._(Le.value):J?a._(J):null,[Le,J]),$=(0,m.useMemo)(()=>P?a.g(Le.status!==`empty`&&Le.timePart?Le.timePart:we||O(J,z),R)??{hours:0,minutes:0,seconds:0}:null,[we,Le,J,z,R,P]),ze=(0,m.useCallback)(e=>{let t=D(e.target.value,{inputFormat:me,separator:K,withTime:P,timeFormat:R,showSeconds:z});Ce(t.formatted),Te(t.timePart);let n=k(t.formatted,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X});if(n.status===`empty`){Z({valid:!0}),Q(null);return}if(n.status===`invalid`&&I)Z(n.result);else if(n.status===`valid`){Z({valid:!0}),Ee(new Date(n.value.getFullYear(),n.value.getMonth(),1));let t=z?6:4,r=P?i.u(e.target.value).slice(8).length:0;(!P||r>=t)&&Q(n.value)}},[Q,Z,me,X,Me,je,K,z,R,I,P]),Be=(0,m.useCallback)(()=>{q(!0);let e=k(Se,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X});if(e.status===`empty`){Z({valid:!0});return}if(e.status===`partial`){F&&Z({valid:!1,error:`Incomplete date`});return}if(e.status===`invalid`){if(P&&e.result.error===oe&&e.datePart){let t=a.l(0,0,0,z,R),n=k(`${e.datePart} ${t}`,{inputFormat:me,minDate:je,maxDate:Me,withTime:P,timeFormat:R,showSeconds:z,isDisabled:X});if(n.status===`valid`){Z({valid:!0}),Ce(C(n.value,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Te(O(n.value,z)),Q(n.value);return}}F&&Z(e.result);return}Z({valid:!0}),Ce(C(e.value,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Te(O(e.value,z)),Q(e.value)},[Q,Z,s,me,Se,X,Me,je,z,R,F,P]),Ve=(0,m.useCallback)(e=>{[`Backspace`,`Delete`,`Tab`,`ArrowLeft`,`ArrowRight`,`Home`,`End`,`Enter`].includes(e.key)||e.ctrlKey||e.metaKey||(P?/^[0-9\s:./-APMapm]$/:/^[0-9./-]$/).test(e.key)||e.preventDefault()},[P]),He=(0,m.useCallback)(()=>{Ce(``),Te(``),q(!1),Z({valid:!0}),Q(null)},[Q,Z]),Ue=(0,m.useCallback)(e=>{e.preventDefault(),e.stopPropagation(),!(te||ne||H)&&ge(e=>!e)},[te,H,ne]),We=(0,m.useCallback)(e=>{if(X(e))return;let t=P?we||a.l(0,0,0,z,R):``,n=P?a.r(e,t,{format:R,showSeconds:z}):a._(e);q(!0),Z({valid:!0}),Te(t),Ce(C(n,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Ee(new Date(e.getFullYear(),e.getMonth(),1)),Q(n),!P&&!H&&ge(!1)},[Q,we,Z,s,H,X,z,R,P]),Ge=(0,m.useCallback)(()=>{let e=a._(new Date);X(e)||We(e)},[We,X]),Ke=(0,m.useMemo)(()=>{if(!P)return[];let e=[],t=R===`12h`?12:23,n=+(R===`12h`);for(let r=n;r<=t;r+=1)e.push(r);return e},[R,P]),qe=(0,m.useMemo)(()=>{if(!P)return[];let e=[];for(let t=0;t<60;t+=B)e.push(t);return e},[B,P]),Je=(0,m.useMemo)(()=>{if(!P||!z)return[];let e=[];for(let t=0;t<60;t+=1)e.push(t);return e},[z,P]),Ye=(0,m.useCallback)((e,t,n=0)=>{let r=a.l(e,t,n,z,R),i=Re;if(q(!0),Te(r),!i){Ce(r);return}let o=a.r(i,r,{format:R,showSeconds:z});Z({valid:!0}),Ce(C(o,{format:s,withTime:P,timeFormat:R,showSeconds:z})),Q(o)},[Q,Re,Z,s,z,R,P]),Xe=(0,m.useCallback)(e=>{Ye(j($?A($).hours:12,e),$?.minutes??0,$?.seconds??0)},[$,Ye]),Ze=(0,m.useMemo)(()=>{let e=Y.getFullYear(),t=Y.getMonth(),n=a.i(e,t),r=a.a(e,t);de===1&&(r=r===0?6:r-1);let i=[],o=t===0?11:t-1,s=t===0?e-1:e,c=a.i(s,o);for(let e=r-1;e>=0;--e)i.push({date:new Date(s,o,c-e),currentMonth:!1});for(let r=1;r<=n;r+=1)i.push({date:new Date(e,t,r),currentMonth:!0});let l=42-i.length,u=t===11?0:t+1,d=t===11?e+1:e;for(let e=1;e<=l;e+=1)i.push({date:new Date(d,u,e),currentMonth:!1});return i},[de,Y]),Qe=a._(new Date),$e=J?a._(J):Re,et=()=>(0,h.jsxs)(`div`,{className:`calendar`,children:[(0,h.jsxs)(`div`,{className:`calendar-header`,children:[(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>Ee(a.t(Y,-1)),"aria-label":pe.previousMonth,children:(0,h.jsx)(t.Wi,{})}),(0,h.jsxs)(`button`,{type:`button`,className:`header-title`,onClick:()=>Oe(e=>e===`days`?`months`:`days`),children:[Ie[Y.getMonth()],` `,Y.getFullYear()]}),(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>Ee(a.t(Y,1)),"aria-label":pe.nextMonth,children:(0,h.jsx)(t.Ui,{})})]}),De===`days`?(0,h.jsxs)(h.Fragment,{children:[(0,h.jsx)(`div`,{className:`day-names`,children:Fe.map(e=>(0,h.jsx)(`span`,{className:`day-name`,children:e},e))}),(0,h.jsx)(`div`,{className:`day-grid`,children:Ze.map(({date:e,currentMonth:t},r)=>{let i=$e?a.p(e,$e):!1,o=a.p(e,Qe),s=X(e);return(0,h.jsx)(`button`,{type:`button`,className:n.t(`day`,!t&&`other-month`,o&&`today`,i&&`selected`,s&&`disabled`),onClick:()=>We(e),disabled:s,tabIndex:-1,children:e.getDate()},`${e.toISOString()}-${r}`)})})]}):(0,h.jsx)(`div`,{className:`month-grid`,children:Ie.map((e,t)=>(0,h.jsx)(`button`,{type:`button`,className:n.t(`month-cell`,Y.getMonth()===t&&`selected`),onClick:()=>{Ee(new Date(Y.getFullYear(),t,1)),Oe(`days`)},children:e.slice(0,3)},e))}),ue&&(0,h.jsx)(`div`,{className:`footer`,children:(0,h.jsx)(`button`,{type:`button`,className:`today-btn`,onClick:Ge,children:pe.today})})]}),tt=()=>{if(!P)return null;let e=$?A($):null;return(0,h.jsxs)(`div`,{className:`date-picker-time-panel`,children:[(0,h.jsx)(`div`,{className:`date-picker-time-header`,children:`Time`}),(0,h.jsxs)(`div`,{className:`date-picker-time-columns`,children:[(0,h.jsx)(le,{items:Ke,selected:R===`12h`?e?.hours:$?.hours,onSelect:t=>Ye(R===`12h`?j(t,e?.meridiem??`AM`):t,$?.minutes??0,$?.seconds??0),label:`Hr`}),(0,h.jsx)(le,{items:qe,selected:$?.minutes,onSelect:e=>Ye($?.hours??0,e,$?.seconds??0),label:`Min`}),z&&(0,h.jsx)(le,{items:Je,selected:$?.seconds,onSelect:e=>Ye($?.hours??0,$?.minutes??0,e),label:`Sec`}),R===`12h`&&(0,h.jsx)(le,{items:[`AM`,`PM`],selected:e?.meridiem,onSelect:Xe,label:`AM/PM`})]})]})},nt=()=>(0,h.jsxs)(`div`,{className:n.t(`date-picker-popover-content`,P&&`with-time`),children:[et(),tt()]}),rt=P?R===`12h`?z?22:19:z?19:16:10,it=S(ee,s,P,R,z,V);return H?(0,h.jsxs)(`div`,{className:n.t(`date-picker`,b&&`color-${b}`,U&&`full-width`,fe),style:W,children:[(0,h.jsx)(f.t,{value:Se,onChange:ze,onBlur:Be,onKeyDown:Ve,onClear:He,type:`text`,inputMode:P?`text`:`numeric`,autoComplete:`off`,maxLength:rt,placeholder:it,disabled:te,readOnly:ne,id:v,variant:ie,size:y,color:b,label:x,helperText:w,error:Ne,errorText:Pe,required:M,clearable:N,fullWidth:U}),nt(),_&&J&&(0,h.jsx)(`input`,{type:`hidden`,name:_,value:a.s(J,P,z)})]}):(0,h.jsxs)(`div`,{className:n.t(`date-picker`,b&&`color-${b}`,U&&`full-width`,fe),style:W,children:[(0,h.jsx)(`div`,{ref:ke,className:`date-picker-input-anchor`,children:(0,h.jsx)(f.t,{value:Se,onChange:ze,onBlur:Be,onKeyDown:Ve,onClear:He,type:`text`,inputMode:P?`text`:`numeric`,autoComplete:`off`,maxLength:rt,placeholder:it,disabled:te,readOnly:ne,id:v,variant:ie,size:y,color:b,label:x,helperText:w,error:Ne,errorText:Pe,required:M,clearable:N,fullWidth:U,endIcon:(0,h.jsx)(`button`,{type:`button`,className:`date-picker-toggle`,onMouseDown:e=>e.preventDefault(),onClick:Ue,"aria-label":`Open calendar`,disabled:te||ne,children:(0,h.jsx)(t.Pi,{})})})}),_&&J&&(0,h.jsx)(`input`,{type:`hidden`,name:_,value:a.s(J,P,z)}),(0,h.jsx)(c.t,{className:`date-picker-popover`,style:{"--color-rgb":ae(b)},open:he,anchorRef:ke,onClose:()=>ge(!1),placement:`bottom-start`,children:nt()})]})}function le({items:e,selected:t,onSelect:r,label:i}){let a=(0,m.useRef)(null);(0,m.useEffect)(()=>{if(t===void 0||!a.current)return;let e=a.current.querySelector(`[data-value="${t}"]`);if(e){let t=a.current;t.scrollTop=e.offsetTop-t.clientHeight/2+e.offsetHeight/2}},[t]);let o=e=>typeof e==`number`?e.toString().padStart(2,`0`):e;return(0,h.jsxs)(`div`,{className:`date-picker-time-column`,children:[(0,h.jsx)(`div`,{className:`date-picker-time-column-label`,children:i}),(0,h.jsx)(`div`,{ref:a,className:`date-picker-time-column-list`,children:e.map(e=>(0,h.jsx)(`button`,{type:`button`,"data-value":e,className:n.t(`date-picker-time-column-item`,e===t&&`selected`),onClick:()=>r(e),children:o(e)},e))})]})}function N(e){let t=e.hours>=12?`PM`:`AM`;return{hours:e.hours%12||12,minutes:e.minutes,seconds:e.seconds,meridiem:t}}function P(e,t){return t===`AM`?e===12?0:e:e===12?12:e+12}function F(e,t,n,r,i){if(i===`24h`)return a.c(e,t,n,r);let o=N({hours:e,minutes:t,seconds:n}),s=`${o.hours.toString().padStart(2,`0`)}:${o.minutes.toString().padStart(2,`0`)}`;return`${r?`${s}:${o.seconds.toString().padStart(2,`0`)}`:s} ${o.meridiem}`}function I(e,t){if(t===`24h`)return a.h(e);let n=e.trim().toUpperCase().match(/^(\d{1,2}):(\d{2})(?::(\d{2}))?\s*(AM|PM)$/);if(n){let e=parseInt(n[1],10),t=parseInt(n[2],10),r=n[3]?parseInt(n[3],10):0,i=n[4];return e<1||e>12||t>59||r>59?null:{hours:P(e,i),minutes:t,seconds:r}}return a.h(e)}function L(e,t){return e.hours===t.hours?e.minutes===t.minutes?e.seconds-t.seconds:e.minutes-t.minutes:e.hours-t.hours}function R(e,t,n){return(!t||L(e,t)>=0)&&(!n||L(e,n)<=0)}function z({value:e,defaultValue:r,onChange:i,format:a=`24h`,showSeconds:o=!1,minuteStep:s=1,min:l,max:u,placeholder:d,disabled:f=!1,readOnly:p=!1,name:g,id:ee,variant:te=`outlined`,size:ne=`md`,color:_,label:v,helperText:re,errorText:ie,error:y=!1,required:ae=!1,clearable:b=!1,fullWidth:oe=!1,className:se,style:ce}){let[x,S]=(0,m.useState)(!1),[C,w]=(0,m.useState)(r??``),T=(0,m.useRef)(null),E=e===void 0?C:e,D=y||!!ie,O=I(E,a),k=I(l??``,a),A=I(u??``,a),j=O?N(O):null,M=O?F(O.hours,O.minutes,O.seconds,o,a):E,le=(0,m.useMemo)(()=>{let e=[],t=a===`12h`?12:23,n=+(a===`12h`);for(let r=n;r<=t;r++)e.push(r);return e},[a]),L=(0,m.useMemo)(()=>{let e=[];for(let t=0;t<60;t+=s)e.push(t);return e},[s]),z=(0,m.useMemo)(()=>{if(!o)return[];let e=[];for(let t=0;t<60;t++)e.push(t);return e},[o]),V=(0,m.useCallback)((e,t,n=0)=>R({hours:e,minutes:t,seconds:n},k,A),[A,k]),H=(0,m.useCallback)((t,n,r=0)=>{if(!V(t,n,r))return;let s=F(t,n,r,o,a);e===void 0&&w(s),i?.(s)},[a,V,i,o,e]),ue=(0,m.useCallback)(t=>{let n=t.target.value;e===void 0&&w(n)},[e]),de=(0,m.useCallback)(()=>{let t=I(E,a);if(t&&R(t,k,A)){let n=F(t.hours,t.minutes,t.seconds,o,a);e===void 0&&w(n),i?.(n)}},[E,a,A,k,i,o,e]),U=(0,m.useCallback)(e=>{let t=j?.hours??12,n=O?.minutes??0,r=O?.seconds??0;H(P(t,e),n,r)},[j?.hours,H,O?.minutes,O?.seconds]),fe=(0,m.useCallback)(t=>{t.stopPropagation(),e===void 0&&w(``),i?.(``)},[i,e]);return(0,h.jsxs)(`div`,{className:n.t(`time picker`,_&&`color-${_}`,oe&&`full-width`,se),style:ce,children:[v&&(0,h.jsx)(`label`,{htmlFor:ee,className:n.t(`field-label`,x&&`focused`,D&&`error`,ae&&`required`),children:v}),(0,h.jsxs)(`div`,{ref:T,className:n.t(`time trigger`,`field-${te}`,`field-${ne}`,x&&`focused`,D&&`error`,f&&`disabled`),onClick:()=>!f&&!p&&S(!0),children:[(0,h.jsx)(`span`,{className:`time icon`,children:(0,h.jsx)(t.Ni,{})}),(0,h.jsx)(`input`,{type:`text`,className:`time input`,value:M,onChange:ue,onBlur:de,placeholder:d??(a===`12h`?o?`hh:mm:ss AM`:`hh:mm AM`:o?`HH:MM:SS`:`HH:MM`),disabled:f,readOnly:p,id:ee,"aria-invalid":D||void 0}),b&&E&&!f&&(0,h.jsx)(`button`,{type:`button`,className:`time clear clear-btn-base`,onClick:fe,tabIndex:-1,"aria-label":`Clear time`,children:(0,h.jsx)(t.Ki,{})})]}),g&&(0,h.jsx)(`input`,{type:`hidden`,name:g,value:M}),(0,h.jsx)(c.t,{className:`time picker popover`,open:x,anchorRef:T,onClose:()=>S(!1),placement:`bottom-start`,children:(0,h.jsxs)(`div`,{className:`time columns`,children:[(0,h.jsx)(B,{items:le,selected:a===`12h`?j?.hours:O?.hours,onSelect:e=>H(a===`12h`?P(e,j?.meridiem??`AM`):e,O?.minutes??0,O?.seconds??0),isDisabled:e=>!V(a===`12h`?P(e,j?.meridiem??`AM`):e,O?.minutes??0,O?.seconds??0),label:`Hr`}),(0,h.jsx)(B,{items:L,selected:O?.minutes,onSelect:e=>H(O?.hours??0,e,O?.seconds??0),isDisabled:e=>!V(O?.hours??0,e,O?.seconds??0),label:`Min`}),o&&(0,h.jsx)(B,{items:z,selected:O?.seconds,onSelect:e=>H(O?.hours??0,O?.minutes??0,e),isDisabled:e=>!V(O?.hours??0,O?.minutes??0,e),label:`Sec`}),a===`12h`&&(0,h.jsx)(B,{items:[`AM`,`PM`],selected:j?.meridiem,onSelect:U,label:`AM/PM`})]})}),(ie||re)&&(0,h.jsx)(`div`,{className:`time bottom`,children:ie?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:ie}):(0,h.jsx)(`span`,{className:`time helper`,children:re})})]})}function B({items:e,selected:t,onSelect:r,isDisabled:i,label:a}){let o=(0,m.useRef)(null);(0,m.useEffect)(()=>{if(t===void 0||!o.current)return;let e=o.current.querySelector(`[data-value="${t}"]`);if(e){let t=o.current;t.scrollTop=e.offsetTop-t.clientHeight/2+e.offsetHeight/2}},[t]);let s=e=>typeof e==`number`?e.toString().padStart(2,`0`):e;return(0,h.jsxs)(`div`,{className:`time column`,children:[(0,h.jsx)(`div`,{className:`time column label`,children:a}),(0,h.jsx)(`div`,{ref:o,className:`time column list`,children:e.map(e=>{let a=i?.(e)??!1;return(0,h.jsx)(`button`,{type:`button`,"data-value":e,className:n.t(`time column item`,e===t&&`selected`,a&&`disabled`),onClick:()=>r(e),disabled:a,children:s(e)},e)})})]})}function V(e){if(!e)return null;if(e instanceof Date)return a._(e);let t=new Date(e);return isNaN(t.getTime())?null:a._(t)}function H(e,t){return e.getTime()<=t.getTime()?{start:e,end:t}:{start:t,end:e}}function ue(e,t,n){if(!t||!n)return!1;let r=e.getTime();return r>t.getTime()&&r<n.getTime()}function de(e,t,n){return e&&t?`${a.o(e,n)} - ${a.o(t,n)}`:e?`${a.o(e,n)} - ...`:``}function U(e){return new Date(e.getFullYear(),e.getMonth(),1)}function fe(e){return new Date(e.getFullYear(),e.getMonth()+1,0)}function W(e){let t=a._(new Date);return t.setDate(t.getDate()-(e-1)),t}function G(e){let t=a._(new Date);return new Date(t.getFullYear(),t.getMonth()-e,t.getDate())}function pe(e){let t=a._(new Date),n=new Date(t.getFullYear(),t.getMonth()-1,1);return[{label:e.presets.today,value:{start:t,end:t}},{label:e.presets.days2,value:{start:W(2),end:t}},{label:e.presets.days3,value:{start:W(3),end:t}},{label:e.presets.days7,value:{start:W(7),end:t}},{label:e.presets.days14,value:{start:W(14),end:t}},{label:e.presets.days31,value:{start:W(31),end:t}},{label:e.presets.thisMonth,value:{start:U(t),end:fe(t)}},{label:e.presets.previousMonth,value:{start:U(n),end:fe(n)}},{label:e.presets.months2,value:{start:G(2),end:t}},{label:e.presets.months3,value:{start:G(3),end:t}},{label:e.presets.months6,value:{start:G(6),end:t}},{label:e.presets.year1,value:{start:G(12),end:t}}]}function me(e,t){let n=e.getFullYear(),r=e.getMonth(),i=a.i(n,r),o=a.a(n,r);t===1&&(o=o===0?6:o-1);let s=[],c=r===0?11:r-1,l=r===0?n-1:n,u=a.i(l,c);for(let e=o-1;e>=0;--e)s.push({date:new Date(l,c,u-e),currentMonth:!1});for(let e=1;e<=i;e+=1)s.push({date:new Date(n,r,e),currentMonth:!0});let d=42-s.length,f=r===11?0:r+1,p=r===11?n+1:n;for(let e=1;e<=d;e+=1)s.push({date:new Date(p,f,e),currentMonth:!1});return s}function K({value:e,defaultValue:r,onChange:i,format:o=`dd.MM.yyyy`,locale:s,min:l,max:u,disabledDates:d,placeholder:f,disabled:g=!1,readOnly:ee=!1,name:te,id:ne,variant:_=`outlined`,size:v=`md`,color:re,label:y,helperText:b,errorText:oe,error:se=!1,required:ce=!1,clearable:x=!1,inline:S=!1,showTodayButton:C=!0,presets:w=!1,presetsSidebar:T=!1,firstDayOfWeek:E=1,fullWidth:D=!1,allowSameDay:O=!0,className:k,style:A}){let j=p.t(s),M=e?{start:V(e.start),end:V(e.end)}:null,[le,N]=(0,m.useState)(()=>({start:V(r?.start),end:V(r?.end)})),[P,F]=(0,m.useState)(null),[I,L]=(0,m.useState)(!1),R=(0,m.useRef)(null),z=M??le,B=z.start,U=z.end,fe=V(l),W=V(u),G=se||!!oe,K=ie(),he=a.u(j,E),ge=a.d(j),_e=(0,m.useMemo)(()=>w===!0||T&&!w?pe(K):Array.isArray(w)?w:[],[w,T,K]),[ve,ye]=(0,m.useState)(()=>{let e=B??new Date;return new Date(e.getFullYear(),e.getMonth(),1)}),be=B?.getTime()??null;(0,m.useEffect)(()=>{if(!be)return;let e=new Date(be);ye(new Date(e.getFullYear(),e.getMonth(),1))},[be]);let xe=(0,m.useCallback)(e=>a.f(e,fe,W)?Array.isArray(d)?d.some(t=>a.p(t,e)):typeof d==`function`?d(e):!1:!0,[d,W,fe]),q=(0,m.useCallback)(t=>{e===void 0&&N(t),i?.(t)},[i,e]),J=(0,m.useCallback)(e=>{if(!xe(e)){if(!B||B&&U){q({start:e,end:null}),F(null);return}!O&&a.p(e,B)||(q(H(B,e)),F(null),S||L(!1))}},[O,q,U,S,xe,B]),Se=(0,m.useCallback)(e=>{e.stopPropagation(),q({start:null,end:null}),F(null)},[q]),Ce=(0,m.useCallback)(()=>{let e=a._(new Date);xe(e)||(q({start:e,end:e}),ye(new Date(e.getFullYear(),e.getMonth(),1)),F(null),S||L(!1))},[q,S,xe]),we=(0,m.useCallback)(e=>{let t=V(e.value.start),n=V(e.value.end);if(!t||!n)return;let r=H(t,n);xe(r.start)||xe(r.end)||(q(r),ye(new Date(r.start.getFullYear(),r.start.getMonth(),1)),F(null),S||L(!1))},[q,S,xe]),Te=B&&!U?P:null,Y=ve,Ee=a.t(ve,1),De=a._(new Date),Oe=(0,m.useMemo)(()=>de(B,U,o),[U,o,B]),ke=(0,m.useMemo)(()=>[Y,Ee].map(e=>({monthDate:e,days:me(e,E)})),[E,Y,Ee]),Ae=B&&U?`${a.o(B,o)} - ${a.o(U,o)}`:B?`${a.o(B,o)} - ...`:f??K.defaultRangePlaceholder,je=T&&_e.length>0,Me=!T&&_e.length>0,Ne=()=>(0,h.jsx)(`div`,{className:`presets-sidebar`,children:_e.map(e=>(0,h.jsx)(`button`,{type:`button`,className:`preset-sidebar-btn`,onClick:()=>we(e),children:e.label},e.label))}),Pe=()=>(0,h.jsxs)(`div`,{className:`calendar-body`,children:[(0,h.jsxs)(`div`,{className:`calendar-top`,children:[(0,h.jsxs)(`div`,{className:`calendar-caption`,children:[(0,h.jsxs)(`span`,{className:`caption-title`,children:[ge[Y.getMonth()],` `,Y.getFullYear()]}),(0,h.jsx)(`span`,{className:`caption-subtitle`,children:K.rangeSubtitle})]}),(0,h.jsxs)(`div`,{className:`nav-actions`,children:[(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>ye(a.t(ve,-1)),"aria-label":K.previousMonth,children:(0,h.jsx)(t.Wi,{})}),(0,h.jsx)(`button`,{type:`button`,className:`nav-btn`,onClick:()=>ye(a.t(ve,1)),"aria-label":K.nextMonth,children:(0,h.jsx)(t.Ui,{})})]})]}),Me&&(0,h.jsx)(`div`,{className:`presets`,children:_e.map(e=>(0,h.jsx)(`button`,{type:`button`,className:`preset-btn`,onClick:()=>we(e),children:e.label},e.label))}),(0,h.jsx)(`div`,{className:`months`,children:ke.map(({monthDate:e,days:t})=>(0,h.jsxs)(`div`,{className:`month-panel`,children:[(0,h.jsxs)(`div`,{className:`month-title`,children:[ge[e.getMonth()],` `,e.getFullYear()]}),(0,h.jsx)(`div`,{className:`day-names`,children:he.map(t=>(0,h.jsx)(`span`,{className:`day-name`,children:t},`${e.toISOString()}-${t}`))}),(0,h.jsx)(`div`,{className:`day-grid`,children:t.map(({date:t,currentMonth:r},i)=>{let o=xe(t),s=B?a.p(t,B):!1,c=U?a.p(t,U):!1,l=ue(t,B,U),u=!U&&B&&Te?H(B,Te):null,d=u?ue(t,u.start,u.end):!1,f=u?a.p(t,u.start)||a.p(t,u.end):!1;return(0,h.jsx)(`button`,{type:`button`,className:n.t(`day`,!r&&`other-month`,a.p(t,De)&&`today`,s&&`range-start selected`,c&&`range-end selected`,l&&`in-range`,d&&!f&&`preview-range`,o&&`disabled`),onClick:()=>J(t),onMouseEnter:()=>B&&!U&&F(t),onFocus:()=>B&&!U&&F(t),disabled:o,tabIndex:-1,children:t.getDate()},`${e.toISOString()}-${i}`)})})]},e.toISOString()))}),(0,h.jsxs)(`div`,{className:`footer`,children:[(0,h.jsx)(`span`,{className:`summary`,children:Ae}),(0,h.jsxs)(`div`,{className:`footer-actions`,children:[x&&(B||U)&&(0,h.jsx)(`button`,{type:`button`,className:`footer-btn`,onClick:e=>{e.preventDefault(),q({start:null,end:null}),F(null)},children:K.clear}),C&&(0,h.jsx)(`button`,{type:`button`,className:`footer-btn`,onClick:Ce,children:K.today})]})]})]}),Fe=()=>(0,h.jsxs)(`div`,{className:n.t(`date-range-calendar`,je&&`with-sidebar`),children:[je&&Ne(),Pe()]});return S?(0,h.jsxs)(`div`,{className:n.t(`date-range-picker`,re&&`color-${re}`,D&&`full-width`,k),style:A,children:[y&&(0,h.jsx)(`label`,{className:n.t(`field-label`,G&&`error`,ce&&`required`),children:y}),Fe()]}):(0,h.jsxs)(`div`,{className:n.t(`date-range-picker`,re&&`color-${re}`,D&&`full-width`,k),style:A,children:[y&&(0,h.jsx)(`label`,{htmlFor:ne,className:n.t(`field-label`,I&&`focused`,G&&`error`,ce&&`required`),children:y}),(0,h.jsxs)(`div`,{ref:R,className:n.t(`trigger`,`field-${_}`,`field-${v}`,I&&`focused`,G&&`error`,g&&`disabled`),onClick:()=>!g&&!ee&&L(!0),children:[(0,h.jsx)(`span`,{className:`icon`,children:(0,h.jsx)(t.Pi,{})}),(0,h.jsx)(`input`,{type:`text`,className:`input`,value:Oe,placeholder:f??K.defaultRangePlaceholder,disabled:g,readOnly:!0,id:ne,"aria-invalid":G||void 0}),x&&(B||U)&&!g&&(0,h.jsx)(`button`,{type:`button`,className:`clear-btn clear-btn-base`,onClick:Se,tabIndex:-1,"aria-label":K.clear,children:(0,h.jsx)(t.Ki,{})})]}),te&&B&&U&&(0,h.jsx)(`input`,{type:`hidden`,name:te,value:`${B.toISOString().split(`T`)[0]}:${U.toISOString().split(`T`)[0]}`}),(0,h.jsx)(c.t,{className:`date-range-picker-popover`,style:{"--color-rgb":ae(re)},open:I,anchorRef:R,onClose:()=>{L(!1),F(null)},placement:`bottom-start`,children:Fe()}),(oe||b)&&(0,h.jsx)(`div`,{className:`bottom-row`,children:oe?(0,h.jsx)(`span`,{className:`field-error`,role:`alert`,children:oe}):(0,h.jsx)(`span`,{className:`helper-text`,children:b})})]})}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return z}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return K}});
2
+ //# sourceMappingURL=dropdowns-BLd4lyr6.cjs.map