@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-BLd4lyr6.cjs","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,3 +1,3 @@
1
1
  const {ensureStyles}=require('./style-runtime.cjs')
2
2
  ensureStyles()
3
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./dropdowns-BP2HBR-x.cjs`);exports.MAutocomplete=e.i,exports.MDatePicker=e.r,exports.MDateRangePicker=e.t,exports.MSelect=e.a,exports.MTimePicker=e.n;
3
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./dropdowns-BLd4lyr6.cjs`);exports.MAutocomplete=e.i,exports.MDatePicker=e.r,exports.MDateRangePicker=e.t,exports.MSelect=e.a,exports.MTimePicker=e.n;
package/dist/dropdowns.js CHANGED
@@ -1,4 +1,4 @@
1
1
  import {ensureStyles} from './style-runtime.js'
2
2
  ensureStyles()
3
- import { a as e, i as t, n, r, t as i } from "./dropdowns-C9jREjLg.js";
3
+ import { a as e, i as t, n, r, t as i } from "./dropdowns-BJ8s18h2.js";
4
4
  export { t as MAutocomplete, r as MDatePicker, i as MDateRangePicker, e as MSelect, n as MTimePicker };
@@ -1,2 +1,2 @@
1
- const e=require(`./validators-DRhikiAi.cjs`);require(`./core-B2klLGki.cjs`);let t=require(`react`),n=require(`react/jsx-runtime`);var r=(0,t.createContext)(null);function i(){return(0,t.useContext)(r)}function a({initialValues:i={},onSubmit:a,onChange:o,validationMode:s=`onBlur`,children:c,className:l,style:u,noValidate:d=!0,...f}){let[p,m]=(0,t.useState)({...i}),[h,g]=(0,t.useState)({}),[_,v]=(0,t.useState)({}),[y,b]=(0,t.useState)(!1),x=(0,t.useRef)(new Map),S=(0,t.useCallback)(e=>{x.current.set(e.name,e)},[]),C=(0,t.useCallback)(e=>{x.current.delete(e)},[]),w=(0,t.useCallback)((t,n)=>{let r=x.current.get(t);if(!r)return{valid:!0};let i=n===void 0?p[t]:n,a=i==null?``:String(i);if(r.required){let t=e.g(a);if(!t.valid)return t}if(r.validate)for(let e of r.validate){let t=e(a);if(!t.valid)return t}return{valid:!0}},[p]),T=(0,t.useCallback)(e=>{let t=w(e);return g(n=>{if(t.valid){let t={...n};return delete t[e],t}return{...n,[e]:t.error}}),t},[w]),E=(0,t.useCallback)(()=>{let e=!0,t={};for(let[n]of x.current){let r=w(n);r.valid||(e=!1,t[n]=r.error)}g(t);let n={};for(let[e]of x.current)n[e]=!0;return v(n),e},[w]),D=(0,t.useCallback)((e,t)=>{m(n=>{let r={...n,[e]:t};return o?.(r),r}),s===`onChange`&&_[e]&&setTimeout(()=>T(e),0)},[o,s,_,T]),O=(0,t.useCallback)((e,t)=>{g(n=>({...n,[e]:t}))},[]),k=(0,t.useCallback)((e,t)=>{v(n=>({...n,[e]:t})),s===`onBlur`&&t&&T(e)},[s,T]),A=(0,t.useCallback)(()=>{m({...i}),g({}),v({}),b(!1)},[i]),j=(0,t.useCallback)(async e=>{if(e.preventDefault(),y||!E())return;b(!0);let t={setSubmitting:b,resetForm:A,setFieldError:O};try{await a?.(p,t)}finally{b(!1)}},[y,E,p,a,A,O]),M=(0,t.useMemo)(()=>({values:p,errors:h,touched:_,registerField:S,unregisterField:C,setFieldValue:D,setFieldError:O,setFieldTouched:k,validateField:T,validateAll:E,resetForm:A,isSubmitting:y}),[p,h,_,S,C,D,O,k,T,E,A,y]);return(0,n.jsx)(r.Provider,{value:M,children:(0,n.jsx)(`form`,{onSubmit:j,noValidate:d,className:`form${l?` ${l}`:``}`,style:u,...f,children:typeof c==`function`?c(M):c})})}function o(e,n){let r=i();(0,t.useEffect)(()=>{if(r)return r.registerField({name:e,validate:n?.validate,required:n?.required}),()=>r.unregisterField(e)},[r,e,n?.validate,n?.required]);let a=(0,t.useCallback)(t=>{r?.setFieldValue(e,t)},[r,e]),o=(0,t.useCallback)(()=>{r?.setFieldTouched(e,!0)},[r,e]);return{value:r?.values[e]??``,error:r?.errors[e],touched:r?.touched[e]??!1,onChange:a,onBlur:o}}Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return a}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return o}});
2
- //# sourceMappingURL=form-D5F1kTIA.cjs.map
1
+ const e=require(`./validators-B6yWdsu2.cjs`);require(`./core-B2klLGki.cjs`);let t=require(`react`),n=require(`react/jsx-runtime`);var r=(0,t.createContext)(null);function i(){return(0,t.useContext)(r)}function a({initialValues:i={},onSubmit:a,onChange:o,validationMode:s=`onBlur`,children:c,className:l,style:u,noValidate:d=!0,...f}){let[p,m]=(0,t.useState)({...i}),[h,g]=(0,t.useState)({}),[_,v]=(0,t.useState)({}),[y,b]=(0,t.useState)(!1),x=(0,t.useRef)(new Map),S=(0,t.useCallback)(e=>{x.current.set(e.name,e)},[]),C=(0,t.useCallback)(e=>{x.current.delete(e)},[]),w=(0,t.useCallback)((t,n)=>{let r=x.current.get(t);if(!r)return{valid:!0};let i=n===void 0?p[t]:n,a=i==null?``:String(i);if(r.required){let t=e.g(a);if(!t.valid)return t}if(r.validate)for(let e of r.validate){let t=e(a);if(!t.valid)return t}return{valid:!0}},[p]),T=(0,t.useCallback)(e=>{let t=w(e);return g(n=>{if(t.valid){let t={...n};return delete t[e],t}return{...n,[e]:t.error}}),t},[w]),E=(0,t.useCallback)(()=>{let e=!0,t={};for(let[n]of x.current){let r=w(n);r.valid||(e=!1,t[n]=r.error)}g(t);let n={};for(let[e]of x.current)n[e]=!0;return v(n),e},[w]),D=(0,t.useCallback)((e,t)=>{m(n=>{let r={...n,[e]:t};return o?.(r),r}),s===`onChange`&&_[e]&&setTimeout(()=>T(e),0)},[o,s,_,T]),O=(0,t.useCallback)((e,t)=>{g(n=>({...n,[e]:t}))},[]),k=(0,t.useCallback)((e,t)=>{v(n=>({...n,[e]:t})),s===`onBlur`&&t&&T(e)},[s,T]),A=(0,t.useCallback)(()=>{m({...i}),g({}),v({}),b(!1)},[i]),j=(0,t.useCallback)(async e=>{if(e.preventDefault(),y||!E())return;b(!0);let t={setSubmitting:b,resetForm:A,setFieldError:O};try{await a?.(p,t)}finally{b(!1)}},[y,E,p,a,A,O]),M=(0,t.useMemo)(()=>({values:p,errors:h,touched:_,registerField:S,unregisterField:C,setFieldValue:D,setFieldError:O,setFieldTouched:k,validateField:T,validateAll:E,resetForm:A,isSubmitting:y}),[p,h,_,S,C,D,O,k,T,E,A,y]);return(0,n.jsx)(r.Provider,{value:M,children:(0,n.jsx)(`form`,{onSubmit:j,noValidate:d,className:`form${l?` ${l}`:``}`,style:u,...f,children:typeof c==`function`?c(M):c})})}function o(e,n){let r=i();(0,t.useEffect)(()=>{if(r)return r.registerField({name:e,validate:n?.validate,required:n?.required}),()=>r.unregisterField(e)},[r,e,n?.validate,n?.required]);let a=(0,t.useCallback)(t=>{r?.setFieldValue(e,t)},[r,e]),o=(0,t.useCallback)(()=>{r?.setFieldTouched(e,!0)},[r,e]);return{value:r?.values[e]??``,error:r?.errors[e],touched:r?.touched[e]??!1,onChange:a,onBlur:o}}Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return a}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return o}});
2
+ //# sourceMappingURL=form-Bni0Gf_s.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-D5F1kTIA.cjs","names":[],"sources":["../src/components/form/MForm/FormContext.ts","../src/components/form/MForm/MForm.tsx","../src/components/form/MForm/useFormField.ts"],"sourcesContent":["import {createContext, useContext} from 'react'\nimport type {MFormContextValue} from './MForm.types'\n\nexport const FormContext = createContext<MFormContextValue | null>(null)\n\n// Read the nearest form context to integrate custom fields with shared state.\nexport function useFormContext(): MFormContextValue | null {\n return useContext(FormContext)\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MFormProps, MFieldRegistration, MFormContextValue, MFormHelpers} from './MForm.types'\nimport {FormContext} from './FormContext'\nimport {validateRequired} from '../../../utils/validators'\nimport type {ValidationResult} from '../../../utils/validators'\nimport './MForm.css'\n\n// Coordinate form values, validation state and submit helpers through context.\nexport function MForm({\n initialValues = {},\n onSubmit,\n onChange,\n validationMode = 'onBlur',\n children,\n className,\n style,\n noValidate = true,\n ...rest\n}: MFormProps) {\n const [values, setValues] = useState<Record<string, unknown>>({...initialValues})\n const [errors, setErrors] = useState<Record<string, string>>({})\n const [touched, setTouched] = useState<Record<string, boolean>>({})\n const [isSubmitting, setIsSubmitting] = useState(false)\n const fieldsRef = useRef<Map<string, MFieldRegistration>>(new Map())\n\n // Track mounted fields so validation stays aligned with active inputs.\n const registerField = useCallback((reg: MFieldRegistration) => {\n fieldsRef.current.set(reg.name, reg)\n }, [])\n\n const unregisterField = useCallback((name: string) => {\n fieldsRef.current.delete(name)\n }, [])\n\n // Run required and custom validators without mutating visible error state yet.\n const validateFieldInternal = useCallback(\n (name: string, val?: unknown): ValidationResult => {\n const reg = fieldsRef.current.get(name)\n if (!reg) return {valid: true}\n\n const fieldValue = val !== undefined ? val : values[name]\n const strValue = fieldValue != null ? String(fieldValue) : ''\n\n // Required check\n if (reg.required) {\n const reqResult = validateRequired(strValue)\n if (!reqResult.valid) return reqResult\n }\n\n // Custom validators\n if (reg.validate) {\n for (const validator of reg.validate) {\n const result = validator(strValue)\n if (!result.valid) return result\n }\n }\n\n return {valid: true}\n },\n [values]\n )\n\n // Persist the latest validation result for a single field.\n const validateField = useCallback(\n (name: string): ValidationResult => {\n const result = validateFieldInternal(name)\n setErrors((prev) => {\n if (result.valid) {\n const next = {...prev}\n delete next[name]\n return next\n }\n return {...prev, [name]: result.error!}\n })\n return result\n },\n [validateFieldInternal]\n )\n\n // Validate every registered field before submit.\n const validateAll = useCallback((): boolean => {\n let allValid = true\n const newErrors: Record<string, string> = {}\n\n for (const [name] of fieldsRef.current) {\n const result = validateFieldInternal(name)\n if (!result.valid) {\n allValid = false\n newErrors[name] = result.error!\n }\n }\n\n setErrors(newErrors)\n // Mark all as touched\n const allTouched: Record<string, boolean> = {}\n for (const [name] of fieldsRef.current) {\n allTouched[name] = true\n }\n setTouched(allTouched)\n\n return allValid\n }, [validateFieldInternal])\n\n // Update field values and trigger onChange or validation according to mode.\n const setFieldValue = useCallback(\n (name: string, val: unknown) => {\n setValues((prev) => {\n const next = {...prev, [name]: val}\n onChange?.(next)\n return next\n })\n\n if (validationMode === 'onChange' && touched[name]) {\n // Defer validation to next tick so values are updated\n setTimeout(() => validateField(name), 0)\n }\n },\n [onChange, validationMode, touched, validateField]\n )\n\n const setFieldError = useCallback((name: string, error: string) => {\n setErrors((prev) => ({...prev, [name]: error}))\n }, [])\n\n // Mark fields as touched so blur validation can start surfacing errors.\n const setFieldTouched = useCallback(\n (name: string, isTouched: boolean) => {\n setTouched((prev) => ({...prev, [name]: isTouched}))\n if (validationMode === 'onBlur' && isTouched) {\n validateField(name)\n }\n },\n [validationMode, validateField]\n )\n\n const resetForm = useCallback(() => {\n setValues({...initialValues})\n setErrors({})\n setTouched({})\n setIsSubmitting(false)\n }, [initialValues])\n\n // Guard submit flow with validation and a single in-flight submission state.\n const handleSubmit = useCallback(\n async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault()\n if (isSubmitting) return\n\n const valid = validateAll()\n if (!valid) return\n\n setIsSubmitting(true)\n const helpers: MFormHelpers = {\n setSubmitting: setIsSubmitting,\n resetForm,\n setFieldError,\n }\n\n try {\n await onSubmit?.(values, helpers)\n } finally {\n setIsSubmitting(false)\n }\n },\n [isSubmitting, validateAll, values, onSubmit, resetForm, setFieldError]\n )\n\n // Memoize the public form context to limit downstream re-renders.\n const ctx = useMemo<MFormContextValue>(\n () => ({\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n }),\n [\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n ]\n )\n\n return (\n <FormContext.Provider value={ctx}>\n <form\n onSubmit={handleSubmit}\n noValidate={noValidate}\n className={`form${className ? ` ${className}` : ''}`}\n style={style}\n {...rest}\n >\n {typeof children === 'function' ? children(ctx) : children}\n </form>\n </FormContext.Provider>\n )\n}\n","import {useEffect, useCallback} from 'react'\nimport {useFormContext} from './FormContext'\nimport type {ValidatorFn} from '../../../utils/validators'\n\nexport interface MUseFormFieldOptions {\n validate?: ValidatorFn[]\n required?: boolean\n}\n\nexport interface MUseFormFieldReturn {\n value: unknown\n error: string | undefined\n touched: boolean\n onChange: (value: unknown) => void\n onBlur: () => void\n}\n\n// Connect a field name to the nearest form context and expose field-level helpers.\nexport function useFormField(name: string, options?: MUseFormFieldOptions): MUseFormFieldReturn {\n const ctx = useFormContext()\n\n // Register the field definition so the form can validate and reset it centrally.\n useEffect(() => {\n if (!ctx) return\n ctx.registerField({\n name,\n validate: options?.validate,\n required: options?.required,\n })\n return () => ctx.unregisterField(name)\n }, [ctx, name, options?.validate, options?.required])\n\n // Forward value updates into the form state.\n const onChange = useCallback(\n (val: unknown) => {\n ctx?.setFieldValue(name, val)\n },\n [ctx, name]\n )\n\n // Mark the field as touched when the control loses focus.\n const onBlur = useCallback(() => {\n ctx?.setFieldTouched(name, true)\n }, [ctx, name])\n\n return {\n value: ctx?.values[name] ?? '',\n error: ctx?.errors[name],\n touched: ctx?.touched[name] ?? false,\n onChange,\n onBlur,\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"form-Bni0Gf_s.cjs","names":[],"sources":["../src/components/form/MForm/FormContext.ts","../src/components/form/MForm/MForm.tsx","../src/components/form/MForm/useFormField.ts"],"sourcesContent":["import {createContext, useContext} from 'react'\nimport type {MFormContextValue} from './MForm.types'\n\nexport const FormContext = createContext<MFormContextValue | null>(null)\n\n// Read the nearest form context to integrate custom fields with shared state.\nexport function useFormContext(): MFormContextValue | null {\n return useContext(FormContext)\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MFormProps, MFieldRegistration, MFormContextValue, MFormHelpers} from './MForm.types'\nimport {FormContext} from './FormContext'\nimport {validateRequired} from '../../../utils/validators'\nimport type {ValidationResult} from '../../../utils/validators'\nimport './MForm.css'\n\n// Coordinate form values, validation state and submit helpers through context.\nexport function MForm({\n initialValues = {},\n onSubmit,\n onChange,\n validationMode = 'onBlur',\n children,\n className,\n style,\n noValidate = true,\n ...rest\n}: MFormProps) {\n const [values, setValues] = useState<Record<string, unknown>>({...initialValues})\n const [errors, setErrors] = useState<Record<string, string>>({})\n const [touched, setTouched] = useState<Record<string, boolean>>({})\n const [isSubmitting, setIsSubmitting] = useState(false)\n const fieldsRef = useRef<Map<string, MFieldRegistration>>(new Map())\n\n // Track mounted fields so validation stays aligned with active inputs.\n const registerField = useCallback((reg: MFieldRegistration) => {\n fieldsRef.current.set(reg.name, reg)\n }, [])\n\n const unregisterField = useCallback((name: string) => {\n fieldsRef.current.delete(name)\n }, [])\n\n // Run required and custom validators without mutating visible error state yet.\n const validateFieldInternal = useCallback(\n (name: string, val?: unknown): ValidationResult => {\n const reg = fieldsRef.current.get(name)\n if (!reg) return {valid: true}\n\n const fieldValue = val !== undefined ? val : values[name]\n const strValue = fieldValue != null ? String(fieldValue) : ''\n\n // Required check\n if (reg.required) {\n const reqResult = validateRequired(strValue)\n if (!reqResult.valid) return reqResult\n }\n\n // Custom validators\n if (reg.validate) {\n for (const validator of reg.validate) {\n const result = validator(strValue)\n if (!result.valid) return result\n }\n }\n\n return {valid: true}\n },\n [values]\n )\n\n // Persist the latest validation result for a single field.\n const validateField = useCallback(\n (name: string): ValidationResult => {\n const result = validateFieldInternal(name)\n setErrors((prev) => {\n if (result.valid) {\n const next = {...prev}\n delete next[name]\n return next\n }\n return {...prev, [name]: result.error!}\n })\n return result\n },\n [validateFieldInternal]\n )\n\n // Validate every registered field before submit.\n const validateAll = useCallback((): boolean => {\n let allValid = true\n const newErrors: Record<string, string> = {}\n\n for (const [name] of fieldsRef.current) {\n const result = validateFieldInternal(name)\n if (!result.valid) {\n allValid = false\n newErrors[name] = result.error!\n }\n }\n\n setErrors(newErrors)\n // Mark all as touched\n const allTouched: Record<string, boolean> = {}\n for (const [name] of fieldsRef.current) {\n allTouched[name] = true\n }\n setTouched(allTouched)\n\n return allValid\n }, [validateFieldInternal])\n\n // Update field values and trigger onChange or validation according to mode.\n const setFieldValue = useCallback(\n (name: string, val: unknown) => {\n setValues((prev) => {\n const next = {...prev, [name]: val}\n onChange?.(next)\n return next\n })\n\n if (validationMode === 'onChange' && touched[name]) {\n // Defer validation to next tick so values are updated\n setTimeout(() => validateField(name), 0)\n }\n },\n [onChange, validationMode, touched, validateField]\n )\n\n const setFieldError = useCallback((name: string, error: string) => {\n setErrors((prev) => ({...prev, [name]: error}))\n }, [])\n\n // Mark fields as touched so blur validation can start surfacing errors.\n const setFieldTouched = useCallback(\n (name: string, isTouched: boolean) => {\n setTouched((prev) => ({...prev, [name]: isTouched}))\n if (validationMode === 'onBlur' && isTouched) {\n validateField(name)\n }\n },\n [validationMode, validateField]\n )\n\n const resetForm = useCallback(() => {\n setValues({...initialValues})\n setErrors({})\n setTouched({})\n setIsSubmitting(false)\n }, [initialValues])\n\n // Guard submit flow with validation and a single in-flight submission state.\n const handleSubmit = useCallback(\n async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault()\n if (isSubmitting) return\n\n const valid = validateAll()\n if (!valid) return\n\n setIsSubmitting(true)\n const helpers: MFormHelpers = {\n setSubmitting: setIsSubmitting,\n resetForm,\n setFieldError,\n }\n\n try {\n await onSubmit?.(values, helpers)\n } finally {\n setIsSubmitting(false)\n }\n },\n [isSubmitting, validateAll, values, onSubmit, resetForm, setFieldError]\n )\n\n // Memoize the public form context to limit downstream re-renders.\n const ctx = useMemo<MFormContextValue>(\n () => ({\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n }),\n [\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n ]\n )\n\n return (\n <FormContext.Provider value={ctx}>\n <form\n onSubmit={handleSubmit}\n noValidate={noValidate}\n className={`form${className ? ` ${className}` : ''}`}\n style={style}\n {...rest}\n >\n {typeof children === 'function' ? children(ctx) : children}\n </form>\n </FormContext.Provider>\n )\n}\n","import {useEffect, useCallback} from 'react'\nimport {useFormContext} from './FormContext'\nimport type {ValidatorFn} from '../../../utils/validators'\n\nexport interface MUseFormFieldOptions {\n validate?: ValidatorFn[]\n required?: boolean\n}\n\nexport interface MUseFormFieldReturn {\n value: unknown\n error: string | undefined\n touched: boolean\n onChange: (value: unknown) => void\n onBlur: () => void\n}\n\n// Connect a field name to the nearest form context and expose field-level helpers.\nexport function useFormField(name: string, options?: MUseFormFieldOptions): MUseFormFieldReturn {\n const ctx = useFormContext()\n\n // Register the field definition so the form can validate and reset it centrally.\n useEffect(() => {\n if (!ctx) return\n ctx.registerField({\n name,\n validate: options?.validate,\n required: options?.required,\n })\n return () => ctx.unregisterField(name)\n }, [ctx, name, options?.validate, options?.required])\n\n // Forward value updates into the form state.\n const onChange = useCallback(\n (val: unknown) => {\n ctx?.setFieldValue(name, val)\n },\n [ctx, name]\n )\n\n // Mark the field as touched when the control loses focus.\n const onBlur = useCallback(() => {\n ctx?.setFieldTouched(name, true)\n }, [ctx, name])\n\n return {\n value: ctx?.values[name] ?? '',\n error: ctx?.errors[name],\n touched: ctx?.touched[name] ?? false,\n onChange,\n onBlur,\n }\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { g as e } from "./validators-D5OCyV2h.js";
1
+ import { g as e } from "./validators-DVYOtFnw.js";
2
2
  import { createContext as t, useCallback as n, useContext as r, useEffect as i, useMemo as a, useRef as o, useState as s } from "react";
3
3
  import { jsx as c } from "react/jsx-runtime";
4
4
  //#region src/components/form/MForm/FormContext.ts
@@ -164,4 +164,4 @@ function f(e, t) {
164
164
  //#endregion
165
165
  export { d as n, u as r, f as t };
166
166
 
167
- //# sourceMappingURL=form-CWoOQ_qo.js.map
167
+ //# sourceMappingURL=form-CFhDAU18.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-CWoOQ_qo.js","names":[],"sources":["../src/components/form/MForm/FormContext.ts","../src/components/form/MForm/MForm.tsx","../src/components/form/MForm/useFormField.ts"],"sourcesContent":["import {createContext, useContext} from 'react'\nimport type {MFormContextValue} from './MForm.types'\n\nexport const FormContext = createContext<MFormContextValue | null>(null)\n\n// Read the nearest form context to integrate custom fields with shared state.\nexport function useFormContext(): MFormContextValue | null {\n return useContext(FormContext)\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MFormProps, MFieldRegistration, MFormContextValue, MFormHelpers} from './MForm.types'\nimport {FormContext} from './FormContext'\nimport {validateRequired} from '../../../utils/validators'\nimport type {ValidationResult} from '../../../utils/validators'\nimport './MForm.css'\n\n// Coordinate form values, validation state and submit helpers through context.\nexport function MForm({\n initialValues = {},\n onSubmit,\n onChange,\n validationMode = 'onBlur',\n children,\n className,\n style,\n noValidate = true,\n ...rest\n}: MFormProps) {\n const [values, setValues] = useState<Record<string, unknown>>({...initialValues})\n const [errors, setErrors] = useState<Record<string, string>>({})\n const [touched, setTouched] = useState<Record<string, boolean>>({})\n const [isSubmitting, setIsSubmitting] = useState(false)\n const fieldsRef = useRef<Map<string, MFieldRegistration>>(new Map())\n\n // Track mounted fields so validation stays aligned with active inputs.\n const registerField = useCallback((reg: MFieldRegistration) => {\n fieldsRef.current.set(reg.name, reg)\n }, [])\n\n const unregisterField = useCallback((name: string) => {\n fieldsRef.current.delete(name)\n }, [])\n\n // Run required and custom validators without mutating visible error state yet.\n const validateFieldInternal = useCallback(\n (name: string, val?: unknown): ValidationResult => {\n const reg = fieldsRef.current.get(name)\n if (!reg) return {valid: true}\n\n const fieldValue = val !== undefined ? val : values[name]\n const strValue = fieldValue != null ? String(fieldValue) : ''\n\n // Required check\n if (reg.required) {\n const reqResult = validateRequired(strValue)\n if (!reqResult.valid) return reqResult\n }\n\n // Custom validators\n if (reg.validate) {\n for (const validator of reg.validate) {\n const result = validator(strValue)\n if (!result.valid) return result\n }\n }\n\n return {valid: true}\n },\n [values]\n )\n\n // Persist the latest validation result for a single field.\n const validateField = useCallback(\n (name: string): ValidationResult => {\n const result = validateFieldInternal(name)\n setErrors((prev) => {\n if (result.valid) {\n const next = {...prev}\n delete next[name]\n return next\n }\n return {...prev, [name]: result.error!}\n })\n return result\n },\n [validateFieldInternal]\n )\n\n // Validate every registered field before submit.\n const validateAll = useCallback((): boolean => {\n let allValid = true\n const newErrors: Record<string, string> = {}\n\n for (const [name] of fieldsRef.current) {\n const result = validateFieldInternal(name)\n if (!result.valid) {\n allValid = false\n newErrors[name] = result.error!\n }\n }\n\n setErrors(newErrors)\n // Mark all as touched\n const allTouched: Record<string, boolean> = {}\n for (const [name] of fieldsRef.current) {\n allTouched[name] = true\n }\n setTouched(allTouched)\n\n return allValid\n }, [validateFieldInternal])\n\n // Update field values and trigger onChange or validation according to mode.\n const setFieldValue = useCallback(\n (name: string, val: unknown) => {\n setValues((prev) => {\n const next = {...prev, [name]: val}\n onChange?.(next)\n return next\n })\n\n if (validationMode === 'onChange' && touched[name]) {\n // Defer validation to next tick so values are updated\n setTimeout(() => validateField(name), 0)\n }\n },\n [onChange, validationMode, touched, validateField]\n )\n\n const setFieldError = useCallback((name: string, error: string) => {\n setErrors((prev) => ({...prev, [name]: error}))\n }, [])\n\n // Mark fields as touched so blur validation can start surfacing errors.\n const setFieldTouched = useCallback(\n (name: string, isTouched: boolean) => {\n setTouched((prev) => ({...prev, [name]: isTouched}))\n if (validationMode === 'onBlur' && isTouched) {\n validateField(name)\n }\n },\n [validationMode, validateField]\n )\n\n const resetForm = useCallback(() => {\n setValues({...initialValues})\n setErrors({})\n setTouched({})\n setIsSubmitting(false)\n }, [initialValues])\n\n // Guard submit flow with validation and a single in-flight submission state.\n const handleSubmit = useCallback(\n async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault()\n if (isSubmitting) return\n\n const valid = validateAll()\n if (!valid) return\n\n setIsSubmitting(true)\n const helpers: MFormHelpers = {\n setSubmitting: setIsSubmitting,\n resetForm,\n setFieldError,\n }\n\n try {\n await onSubmit?.(values, helpers)\n } finally {\n setIsSubmitting(false)\n }\n },\n [isSubmitting, validateAll, values, onSubmit, resetForm, setFieldError]\n )\n\n // Memoize the public form context to limit downstream re-renders.\n const ctx = useMemo<MFormContextValue>(\n () => ({\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n }),\n [\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n ]\n )\n\n return (\n <FormContext.Provider value={ctx}>\n <form\n onSubmit={handleSubmit}\n noValidate={noValidate}\n className={`form${className ? ` ${className}` : ''}`}\n style={style}\n {...rest}\n >\n {typeof children === 'function' ? children(ctx) : children}\n </form>\n </FormContext.Provider>\n )\n}\n","import {useEffect, useCallback} from 'react'\nimport {useFormContext} from './FormContext'\nimport type {ValidatorFn} from '../../../utils/validators'\n\nexport interface MUseFormFieldOptions {\n validate?: ValidatorFn[]\n required?: boolean\n}\n\nexport interface MUseFormFieldReturn {\n value: unknown\n error: string | undefined\n touched: boolean\n onChange: (value: unknown) => void\n onBlur: () => void\n}\n\n// Connect a field name to the nearest form context and expose field-level helpers.\nexport function useFormField(name: string, options?: MUseFormFieldOptions): MUseFormFieldReturn {\n const ctx = useFormContext()\n\n // Register the field definition so the form can validate and reset it centrally.\n useEffect(() => {\n if (!ctx) return\n ctx.registerField({\n name,\n validate: options?.validate,\n required: options?.required,\n })\n return () => ctx.unregisterField(name)\n }, [ctx, name, options?.validate, options?.required])\n\n // Forward value updates into the form state.\n const onChange = useCallback(\n (val: unknown) => {\n ctx?.setFieldValue(name, val)\n },\n [ctx, name]\n )\n\n // Mark the field as touched when the control loses focus.\n const onBlur = useCallback(() => {\n ctx?.setFieldTouched(name, true)\n }, [ctx, name])\n\n return {\n value: ctx?.values[name] ?? '',\n error: ctx?.errors[name],\n touched: ctx?.touched[name] ?? false,\n onChange,\n onBlur,\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"form-CFhDAU18.js","names":[],"sources":["../src/components/form/MForm/FormContext.ts","../src/components/form/MForm/MForm.tsx","../src/components/form/MForm/useFormField.ts"],"sourcesContent":["import {createContext, useContext} from 'react'\nimport type {MFormContextValue} from './MForm.types'\n\nexport const FormContext = createContext<MFormContextValue | null>(null)\n\n// Read the nearest form context to integrate custom fields with shared state.\nexport function useFormContext(): MFormContextValue | null {\n return useContext(FormContext)\n}\n","import {useState, useRef, useCallback, useMemo} from 'react'\nimport type * as React from 'react'\nimport type {MFormProps, MFieldRegistration, MFormContextValue, MFormHelpers} from './MForm.types'\nimport {FormContext} from './FormContext'\nimport {validateRequired} from '../../../utils/validators'\nimport type {ValidationResult} from '../../../utils/validators'\nimport './MForm.css'\n\n// Coordinate form values, validation state and submit helpers through context.\nexport function MForm({\n initialValues = {},\n onSubmit,\n onChange,\n validationMode = 'onBlur',\n children,\n className,\n style,\n noValidate = true,\n ...rest\n}: MFormProps) {\n const [values, setValues] = useState<Record<string, unknown>>({...initialValues})\n const [errors, setErrors] = useState<Record<string, string>>({})\n const [touched, setTouched] = useState<Record<string, boolean>>({})\n const [isSubmitting, setIsSubmitting] = useState(false)\n const fieldsRef = useRef<Map<string, MFieldRegistration>>(new Map())\n\n // Track mounted fields so validation stays aligned with active inputs.\n const registerField = useCallback((reg: MFieldRegistration) => {\n fieldsRef.current.set(reg.name, reg)\n }, [])\n\n const unregisterField = useCallback((name: string) => {\n fieldsRef.current.delete(name)\n }, [])\n\n // Run required and custom validators without mutating visible error state yet.\n const validateFieldInternal = useCallback(\n (name: string, val?: unknown): ValidationResult => {\n const reg = fieldsRef.current.get(name)\n if (!reg) return {valid: true}\n\n const fieldValue = val !== undefined ? val : values[name]\n const strValue = fieldValue != null ? String(fieldValue) : ''\n\n // Required check\n if (reg.required) {\n const reqResult = validateRequired(strValue)\n if (!reqResult.valid) return reqResult\n }\n\n // Custom validators\n if (reg.validate) {\n for (const validator of reg.validate) {\n const result = validator(strValue)\n if (!result.valid) return result\n }\n }\n\n return {valid: true}\n },\n [values]\n )\n\n // Persist the latest validation result for a single field.\n const validateField = useCallback(\n (name: string): ValidationResult => {\n const result = validateFieldInternal(name)\n setErrors((prev) => {\n if (result.valid) {\n const next = {...prev}\n delete next[name]\n return next\n }\n return {...prev, [name]: result.error!}\n })\n return result\n },\n [validateFieldInternal]\n )\n\n // Validate every registered field before submit.\n const validateAll = useCallback((): boolean => {\n let allValid = true\n const newErrors: Record<string, string> = {}\n\n for (const [name] of fieldsRef.current) {\n const result = validateFieldInternal(name)\n if (!result.valid) {\n allValid = false\n newErrors[name] = result.error!\n }\n }\n\n setErrors(newErrors)\n // Mark all as touched\n const allTouched: Record<string, boolean> = {}\n for (const [name] of fieldsRef.current) {\n allTouched[name] = true\n }\n setTouched(allTouched)\n\n return allValid\n }, [validateFieldInternal])\n\n // Update field values and trigger onChange or validation according to mode.\n const setFieldValue = useCallback(\n (name: string, val: unknown) => {\n setValues((prev) => {\n const next = {...prev, [name]: val}\n onChange?.(next)\n return next\n })\n\n if (validationMode === 'onChange' && touched[name]) {\n // Defer validation to next tick so values are updated\n setTimeout(() => validateField(name), 0)\n }\n },\n [onChange, validationMode, touched, validateField]\n )\n\n const setFieldError = useCallback((name: string, error: string) => {\n setErrors((prev) => ({...prev, [name]: error}))\n }, [])\n\n // Mark fields as touched so blur validation can start surfacing errors.\n const setFieldTouched = useCallback(\n (name: string, isTouched: boolean) => {\n setTouched((prev) => ({...prev, [name]: isTouched}))\n if (validationMode === 'onBlur' && isTouched) {\n validateField(name)\n }\n },\n [validationMode, validateField]\n )\n\n const resetForm = useCallback(() => {\n setValues({...initialValues})\n setErrors({})\n setTouched({})\n setIsSubmitting(false)\n }, [initialValues])\n\n // Guard submit flow with validation and a single in-flight submission state.\n const handleSubmit = useCallback(\n async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault()\n if (isSubmitting) return\n\n const valid = validateAll()\n if (!valid) return\n\n setIsSubmitting(true)\n const helpers: MFormHelpers = {\n setSubmitting: setIsSubmitting,\n resetForm,\n setFieldError,\n }\n\n try {\n await onSubmit?.(values, helpers)\n } finally {\n setIsSubmitting(false)\n }\n },\n [isSubmitting, validateAll, values, onSubmit, resetForm, setFieldError]\n )\n\n // Memoize the public form context to limit downstream re-renders.\n const ctx = useMemo<MFormContextValue>(\n () => ({\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n }),\n [\n values,\n errors,\n touched,\n registerField,\n unregisterField,\n setFieldValue,\n setFieldError,\n setFieldTouched,\n validateField,\n validateAll,\n resetForm,\n isSubmitting,\n ]\n )\n\n return (\n <FormContext.Provider value={ctx}>\n <form\n onSubmit={handleSubmit}\n noValidate={noValidate}\n className={`form${className ? ` ${className}` : ''}`}\n style={style}\n {...rest}\n >\n {typeof children === 'function' ? children(ctx) : children}\n </form>\n </FormContext.Provider>\n )\n}\n","import {useEffect, useCallback} from 'react'\nimport {useFormContext} from './FormContext'\nimport type {ValidatorFn} from '../../../utils/validators'\n\nexport interface MUseFormFieldOptions {\n validate?: ValidatorFn[]\n required?: boolean\n}\n\nexport interface MUseFormFieldReturn {\n value: unknown\n error: string | undefined\n touched: boolean\n onChange: (value: unknown) => void\n onBlur: () => void\n}\n\n// Connect a field name to the nearest form context and expose field-level helpers.\nexport function useFormField(name: string, options?: MUseFormFieldOptions): MUseFormFieldReturn {\n const ctx = useFormContext()\n\n // Register the field definition so the form can validate and reset it centrally.\n useEffect(() => {\n if (!ctx) return\n ctx.registerField({\n name,\n validate: options?.validate,\n required: options?.required,\n })\n return () => ctx.unregisterField(name)\n }, [ctx, name, options?.validate, options?.required])\n\n // Forward value updates into the form state.\n const onChange = useCallback(\n (val: unknown) => {\n ctx?.setFieldValue(name, val)\n },\n [ctx, name]\n )\n\n // Mark the field as touched when the control loses focus.\n const onBlur = useCallback(() => {\n ctx?.setFieldTouched(name, true)\n }, [ctx, name])\n\n return {\n value: ctx?.values[name] ?? '',\n error: ctx?.errors[name],\n touched: ctx?.touched[name] ?? false,\n onChange,\n onBlur,\n }\n}\n"],"mappings":"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"}
package/dist/form.cjs CHANGED
@@ -1,3 +1,3 @@
1
1
  const {ensureStyles}=require('./style-runtime.cjs')
2
2
  ensureStyles()
3
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./form-D5F1kTIA.cjs`);exports.MForm=e.n,exports.useFormContext=e.r,exports.useFormField=e.t;
3
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./form-Bni0Gf_s.cjs`);exports.MForm=e.n,exports.useFormContext=e.r,exports.useFormField=e.t;
package/dist/form.js CHANGED
@@ -1,4 +1,4 @@
1
1
  import {ensureStyles} from './style-runtime.js'
2
2
  ensureStyles()
3
- import { n as e, r as t, t as n } from "./form-CWoOQ_qo.js";
3
+ import { n as e, r as t, t as n } from "./form-CFhDAU18.js";
4
4
  export { e as MForm, t as useFormContext, n as useFormField };
@@ -57,36 +57,7 @@ export interface MFileManagerTexts {
57
57
  download: string;
58
58
  newFolder: string;
59
59
  }
60
- export interface MCookieConsentTexts {
61
- bannerTitle: string;
62
- bannerDescription: string;
63
- manage: string;
64
- preferencesTitle: string;
65
- preferencesDescription: string;
66
- acceptAll: string;
67
- rejectAll: string;
68
- preferences: string;
69
- savePreferences: string;
70
- close: string;
71
- requiredLabel: string;
72
- necessaryLabel: string;
73
- necessaryDescription: string;
74
- preferencesLabel: string;
75
- preferencesDescriptionLabel: string;
76
- analyticsLabel: string;
77
- analyticsDescription: string;
78
- marketingLabel: string;
79
- marketingDescription: string;
80
- declarationTitle: string;
81
- declarationDescription: string;
82
- noDeclarationItems: string;
83
- searchDeclaration: string;
84
- triggerLabel: string;
85
- detectedCookiesLabel: string;
86
- noDetectedCookies: string;
87
- }
88
60
  export declare function useMDatePickerTexts(): MDatePickerTexts;
89
61
  export declare function useMDateRangePickerTexts(): MDateRangePickerTexts;
90
62
  export declare function useMCalendarBoardTexts(): MCalendarBoardTexts;
91
63
  export declare function useMFileManagerTexts(): MFileManagerTexts;
92
- export declare function useMCookieConsentTexts(): MCookieConsentTexts;