@jenesei-software/jenesei-kit-react 1.3.36 → 1.3.37
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.
- package/build/area-preview.cjs.js +1 -1
- package/build/area-preview.es.js +1 -1
- package/build/area-skeleton.cjs.js +1 -1
- package/build/area-skeleton.es.js +1 -1
- package/build/build-info.txt +3 -3
- package/build/{component-Cao-X0at.cjs → component-Al542qT6.cjs} +2 -2
- package/build/{component-Cao-X0at.cjs.map → component-Al542qT6.cjs.map} +1 -1
- package/build/{component-DsLJSX6q.cjs → component-B-SJnPIV.cjs} +2 -2
- package/build/{component-DsLJSX6q.cjs.map → component-B-SJnPIV.cjs.map} +1 -1
- package/build/{component-C6JGm-CG.js → component-B4K-5Uid.js} +2 -2
- package/build/{component-C6JGm-CG.js.map → component-B4K-5Uid.js.map} +1 -1
- package/build/{component-DZbtSeCS.cjs → component-BI4m1lxA.cjs} +2 -2
- package/build/{component-DZbtSeCS.cjs.map → component-BI4m1lxA.cjs.map} +1 -1
- package/build/{component-DkO36zGe.cjs → component-BWf1DkB4.cjs} +2 -2
- package/build/{component-DkO36zGe.cjs.map → component-BWf1DkB4.cjs.map} +1 -1
- package/build/{component-BGAYOt_R.cjs → component-BWlNRKFO.cjs} +2 -2
- package/build/{component-BGAYOt_R.cjs.map → component-BWlNRKFO.cjs.map} +1 -1
- package/build/{component-BTPma8cy.js → component-B_Y6BI1X.js} +2 -2
- package/build/{component-BTPma8cy.js.map → component-B_Y6BI1X.js.map} +1 -1
- package/build/{component-COXlMHO8.cjs → component-BjSoavQj.cjs} +2 -2
- package/build/{component-COXlMHO8.cjs.map → component-BjSoavQj.cjs.map} +1 -1
- package/build/component-C21J5f8X.cjs +2 -0
- package/build/{component-C8NWMxxo.cjs.map → component-C21J5f8X.cjs.map} +1 -1
- package/build/{component-DrO-3u2I.js → component-C3F1XZOy.js} +3 -3
- package/build/{component-DrO-3u2I.js.map → component-C3F1XZOy.js.map} +1 -1
- package/build/{component-DcOrj2ff.js → component-CHaQiMJk.js} +3 -3
- package/build/{component-DcOrj2ff.js.map → component-CHaQiMJk.js.map} +1 -1
- package/build/{component-CEZKgFH6.cjs → component-COS_bXHW.cjs} +2 -2
- package/build/{component-CEZKgFH6.cjs.map → component-COS_bXHW.cjs.map} +1 -1
- package/build/{component-9fzcSAV7.js → component-D1d3wJ1v.js} +2 -2
- package/build/{component-9fzcSAV7.js.map → component-D1d3wJ1v.js.map} +1 -1
- package/build/{component-BWvIUzNG.js → component-D96dGS7Z.js} +2 -2
- package/build/{component-BWvIUzNG.js.map → component-D96dGS7Z.js.map} +1 -1
- package/build/{component-CS0uHwL5.js → component-DDu2Cdhf.js} +110 -99
- package/build/component-DDu2Cdhf.js.map +1 -0
- package/build/{component-CwKwQY3p.cjs → component-DNpRC40L.cjs} +2 -2
- package/build/{component-CwKwQY3p.cjs.map → component-DNpRC40L.cjs.map} +1 -1
- package/build/{component-qR0HPUpL.cjs → component-DSFp1IyF.cjs} +2 -2
- package/build/{component-qR0HPUpL.cjs.map → component-DSFp1IyF.cjs.map} +1 -1
- package/build/{component-Dcn4OKm7.js → component-DZs-w197.js} +2 -2
- package/build/{component-Dcn4OKm7.js.map → component-DZs-w197.js.map} +1 -1
- package/build/{component-CHp7GYey.js → component-DzQBSEjg.js} +3 -3
- package/build/{component-CHp7GYey.js.map → component-DzQBSEjg.js.map} +1 -1
- package/build/{component-BPtJjkt0.cjs → component-KYPJqdFp.cjs} +2 -2
- package/build/{component-BPtJjkt0.cjs.map → component-KYPJqdFp.cjs.map} +1 -1
- package/build/{component-C9Uf5Bc0.js → component-L0B2qZfu.js} +2 -2
- package/build/{component-C9Uf5Bc0.js.map → component-L0B2qZfu.js.map} +1 -1
- package/build/component-accordion.cjs.js +1 -1
- package/build/component-accordion.es.js +2 -2
- package/build/component-button-group.cjs.js +1 -1
- package/build/component-button-group.es.js +2 -2
- package/build/component-button.cjs.js +1 -1
- package/build/component-button.es.js +1 -1
- package/build/component-checkbox-group.cjs.js +1 -1
- package/build/component-checkbox-group.es.js +2 -2
- package/build/component-checkbox.cjs.js +1 -1
- package/build/component-checkbox.es.js +2 -2
- package/build/component-date-picker.cjs.js +1 -1
- package/build/component-date-picker.es.js +2 -2
- package/build/component-icon.cjs.js +1 -1
- package/build/component-icon.es.js +1 -1
- package/build/component-image-button.cjs.js +1 -1
- package/build/component-image-button.es.js +1 -1
- package/build/component-image-select.cjs.js +1 -1
- package/build/component-image-select.es.js +2 -2
- package/build/component-image-slider.cjs.js +1 -1
- package/build/component-image-slider.es.js +2 -2
- package/build/component-image.cjs.js +1 -1
- package/build/component-image.es.js +2 -2
- package/build/component-input-otp.cjs.js +1 -1
- package/build/component-input-otp.es.js +2 -2
- package/build/component-input.cjs.js +1 -1
- package/build/component-input.es.js +2 -2
- package/build/{component-D3jtUpu3.js → component-l5nAOPmU.js} +2 -2
- package/build/{component-D3jtUpu3.js.map → component-l5nAOPmU.js.map} +1 -1
- package/build/component-pagination.cjs.js +1 -1
- package/build/component-pagination.es.js +1 -1
- package/build/component-range.cjs.js +1 -1
- package/build/component-range.es.js +2 -2
- package/build/component-select.cjs.js +1 -1
- package/build/component-select.es.js +1 -1
- package/build/component-textarea.cjs.js +1 -1
- package/build/component-textarea.es.js +1 -1
- package/build/component-toggle.cjs.js +1 -1
- package/build/component-toggle.es.js +2 -2
- package/build/component-tooltip.cjs.js +1 -1
- package/build/component-tooltip.es.js +1 -1
- package/build/component-typography.cjs.js +1 -1
- package/build/component-typography.es.js +1 -1
- package/build/{component.constants-DEtpkwiA.js → component.constants-BpYppAAQ.js} +49 -29
- package/build/component.constants-BpYppAAQ.js.map +1 -0
- package/build/{component.constants-QEk9PcRK.cjs → component.constants-Cvek1vXL.cjs} +2 -2
- package/build/component.constants-Cvek1vXL.cjs.map +1 -0
- package/build/{component.constants-Dulpp7av.js → component.constants-DHHHaT_5.js} +2 -2
- package/build/{component.constants-Dulpp7av.js.map → component.constants-DHHHaT_5.js.map} +1 -1
- package/build/{component.constants-D80V6i-m.cjs → component.constants-sz4yGy0y.cjs} +2 -2
- package/build/{component.constants-D80V6i-m.cjs.map → component.constants-sz4yGy0y.cjs.map} +1 -1
- package/build/{component.types-KTSAVZtM.cjs → component.types-CULsdZpM.cjs} +2 -2
- package/build/{component.types-KTSAVZtM.cjs.map → component.types-CULsdZpM.cjs.map} +1 -1
- package/build/{component.types-BbfCiww_.js → component.types-TeXqILe2.js} +2 -2
- package/build/{component.types-BbfCiww_.js.map → component.types-TeXqILe2.js.map} +1 -1
- package/build/consts.cjs.js +1 -1
- package/build/consts.es.js +1 -1
- package/build/context-app.cjs.js +1 -1
- package/build/context-app.es.js +2 -2
- package/build/context-dialog.cjs.js +1 -1
- package/build/context-dialog.d.ts +31 -26
- package/build/context-dialog.es.js +2 -2
- package/build/context-sonner.cjs.js +1 -1
- package/build/context-sonner.es.js +2 -2
- package/build/{context.constants-Bh-ajJM2.js → context.constants-4eKvVwha.js} +3 -3
- package/build/{context.constants-Bh-ajJM2.js.map → context.constants-4eKvVwha.js.map} +1 -1
- package/build/context.constants-CAlZQBvG.cjs +32 -0
- package/build/context.constants-CAlZQBvG.cjs.map +1 -0
- package/build/{context.constants-CDgzMcxb.cjs → context.constants-D9hGtc0A.cjs} +2 -2
- package/build/{context.constants-CDgzMcxb.cjs.map → context.constants-D9hGtc0A.cjs.map} +1 -1
- package/build/{context.constants-Nfy-8Qzj.js → context.constants-DRDMvlln.js} +51 -29
- package/build/context.constants-DRDMvlln.js.map +1 -0
- package/build/{context.hooks-BIfYPHOA.cjs → context.hooks-2SMzc0Vc.cjs} +2 -2
- package/build/{context.hooks-BIfYPHOA.cjs.map → context.hooks-2SMzc0Vc.cjs.map} +1 -1
- package/build/{context.hooks-Dx80dbrI.js → context.hooks-CZOS7JGV.js} +2 -2
- package/build/{context.hooks-Dx80dbrI.js.map → context.hooks-CZOS7JGV.js.map} +1 -1
- package/build/context.hooks-CdUNX5DP.cjs +2 -0
- package/build/context.hooks-CdUNX5DP.cjs.map +1 -0
- package/build/{context.hooks-CxwYYLmV.js → context.hooks-CjH6Plw7.js} +17 -14
- package/build/context.hooks-CjH6Plw7.js.map +1 -0
- package/build/{context.hooks-BG1tp2nc.js → context.hooks-DEfRvBpX.js} +2 -2
- package/build/{context.hooks-BG1tp2nc.js.map → context.hooks-DEfRvBpX.js.map} +1 -1
- package/build/{context.hooks-BpQriPdQ.cjs → context.hooks-DpBSd_p-.cjs} +2 -2
- package/build/{context.hooks-BpQriPdQ.cjs.map → context.hooks-DpBSd_p-.cjs.map} +1 -1
- package/build/hooks-use-deep-compare-memoize.cjs.js +1 -1
- package/build/hooks-use-deep-compare-memoize.d.ts +1 -1
- package/build/hooks-use-deep-compare-memoize.es.js +1 -1
- package/build/index.cjs.js +1 -1
- package/build/index.d.ts +34 -27
- package/build/index.es.js +20 -20
- package/build/style-error.cjs.js +1 -1
- package/build/style-error.es.js +1 -1
- package/build/style-theme.cjs.js +1 -1
- package/build/style-theme.es.js +1 -1
- package/build/use-C7vngeRk.js +882 -0
- package/build/use-C7vngeRk.js.map +1 -0
- package/build/use-CtW8HmXH.cjs +16 -0
- package/build/use-CtW8HmXH.cjs.map +1 -0
- package/build/{use-Cglz8LOj.js → use-Df6UuwJp.js} +59 -45
- package/build/{use-Cglz8LOj.js.map → use-Df6UuwJp.js.map} +1 -1
- package/build/use-zW3LuRc_.cjs +2 -0
- package/build/use-zW3LuRc_.cjs.map +1 -0
- package/package.json +3 -1
- package/build/component-C8NWMxxo.cjs +0 -2
- package/build/component-CS0uHwL5.js.map +0 -1
- package/build/component.constants-DEtpkwiA.js.map +0 -1
- package/build/component.constants-QEk9PcRK.cjs.map +0 -1
- package/build/context.constants-BWZS-di6.cjs +0 -32
- package/build/context.constants-BWZS-di6.cjs.map +0 -1
- package/build/context.constants-Nfy-8Qzj.js.map +0 -1
- package/build/context.hooks-C-jAj7Vc.cjs +0 -2
- package/build/context.hooks-C-jAj7Vc.cjs.map +0 -1
- package/build/context.hooks-CxwYYLmV.js.map +0 -1
- package/build/use-C1l0O0Qo.cjs +0 -2
- package/build/use-C1l0O0Qo.cjs.map +0 -1
- package/build/use-DGVoIo0g.cjs +0 -16
- package/build/use-DGVoIo0g.cjs.map +0 -1
- package/build/use-DT0XgvJT.js +0 -25
- package/build/use-DT0XgvJT.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component.types-BbfCiww_.js","sources":["../src/components/date-picker/component.tsx","../src/components/date-picker/component.types.ts"],"sourcesContent":["import { Button } from '@local/components/button';\nimport { Ripple } from '@local/components/ripple';\nimport { SelectMonth, SelectYear } from '@local/components/select';\nimport { Stack } from '@local/components/stack';\nimport { ErrorMessage } from '@local/styles/error';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport moment, { Moment } from 'moment';\nimport {\n ChangeEvent,\n Fragment,\n KeyboardEvent,\n RefObject,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { Popover, usePopover } from '../popover';\nimport { Typography } from '../typography';\nimport {\n DateDayProps,\n DateDropdownDay,\n DateDropdownDayOfWeek,\n DateDropdownDays,\n DateDropdownList,\n DateInput,\n DateInputButton,\n DateInputButtonClear,\n DateInputWrapper,\n DatePickerMode,\n DatePickerProps,\n DatePickerType,\n DatePickerVariant,\n DateWrapper,\n WeekItem,\n} from '.';\n\nconst weekOrder: WeekItem['value'][] = ['mo', 'tu', 'we', 'th', 'fr', 'sa', 'su'];\n\nexport const DatePicker = (props: DatePickerProps) => {\n const { onChange } = props;\n const theme = useTheme();\n\n const [valueMoment, setValueMoment] = useState<null | Moment>(null);\n const [dateDefaultMoment, setDateDefaultMoment] = useState<Moment>(moment(props.dateDefault).utc());\n\n const [input, setInput] = useState<Record<DatePickerVariant, string>>({\n [DatePickerVariant.DD]: '',\n [DatePickerVariant.MM]: '',\n [DatePickerVariant.YYYY]: '',\n });\n\n useEffect(() => {\n refInputValue.current = input;\n }, [input]);\n\n const isHasInput = useMemo(\n () =>\n input[DatePickerVariant.DD] !== '' || input[DatePickerVariant.MM] !== '' || input[DatePickerVariant.YYYY] !== '',\n [input],\n );\n\n const onClearInput = useCallback(() => {\n setInput({\n [DatePickerVariant.DD]: '',\n [DatePickerVariant.MM]: '',\n [DatePickerVariant.YYYY]: '',\n });\n }, []);\n\n const [activeSegment, setActiveSegment] = useState<DatePickerVariant | null>(null);\n const [isError, setIsError] = useState(false);\n\n const mode: DatePickerMode = useMemo(() => {\n if (!props.mode || props.mode.length === 0) {\n return [DatePickerVariant.DD, DatePickerVariant.MM, DatePickerVariant.YYYY];\n }\n\n const hasDuplicates = new Set(props.mode).size !== props.mode.length;\n\n if (hasDuplicates) {\n return [DatePickerVariant.DD, DatePickerVariant.MM, DatePickerVariant.YYYY];\n }\n\n return props.mode;\n }, [props.mode]);\n\n const type: DatePickerType = useMemo(() => {\n if (!props.type) {\n return 'manualAndSelect';\n }\n\n return props.type;\n }, [props.type]);\n\n const dataDate = useMemo(() => {\n const segments = [DatePickerVariant.DD, DatePickerVariant.MM, DatePickerVariant.YYYY];\n\n const result = Object.fromEntries(\n segments.map((segment) => [\n segment,\n {\n type: segment,\n value: input[segment],\n placeholder:\n props.locale.inputs[\n segment === DatePickerVariant.DD ? 'day' : segment === DatePickerVariant.MM ? 'month' : 'year'\n ],\n isFirst: mode[0] === segment,\n isLast: mode[mode.length - 1] === segment,\n segmentNext: getNextSegment(segment, mode),\n segmentPrev: getPrevSegment(segment, mode),\n onNextSegment: () => setActiveSegment(getNextSegment(segment, mode)),\n onPrevSegment: () => setActiveSegment(getPrevSegment(segment, mode)),\n setValue: (value: string) => setInput((prev) => ({ ...prev, [segment]: value })),\n setActive: () => setActiveSegment(segment),\n },\n ]),\n ) as Record<\n DatePickerVariant,\n {\n type: DatePickerVariant;\n value: string;\n placeholder: string;\n isFirst: boolean;\n isLast: boolean;\n segmentNext: DatePickerVariant | null;\n segmentPrev: DatePickerVariant | null;\n onNextSegment: () => void;\n onPrevSegment: () => void;\n setValue: (value: string) => void;\n setActive: () => void;\n }\n >;\n\n const resultSort = mode.map((segment) => result[segment]).filter(Boolean);\n\n return { sort: resultSort, default: result };\n }, [props, mode, input]);\n\n const daysInWeek = useMemo(() => {\n return weekOrder.map((key, index) => {\n const found = props.locale.weeks.find((w) => w.value === key);\n return {\n index,\n label: found?.localeShort ?? key.toUpperCase(),\n };\n });\n }, [props.locale.weeks]);\n\n const daysInMonth: DateDayProps[] = useMemo(() => {\n const dateToday = moment.utc();\n const dateValue = valueMoment ?? dateDefaultMoment;\n const dateStartOfMonth = dateValue.clone().startOf('month');\n const dateEndOfMonth = dateValue.clone().endOf('month');\n const dateMin = props.dateMin ? moment.utc(props.dateMin) : null;\n const dateMax = props.dateMax ? moment.utc(props.dateMax) : null;\n\n const dateVisibleDayFirst = dateStartOfMonth.clone().subtract(dateStartOfMonth.isoWeekday() - 1, 'days');\n const dateVisibleDayLast = dateEndOfMonth.clone().add(7 - dateEndOfMonth.isoWeekday(), 'days');\n\n const result: DateDayProps[] = [];\n const dateCurrent = dateVisibleDayFirst.clone();\n\n while (dateCurrent <= dateVisibleDayLast) {\n const isCurrentMonth = dateCurrent.isBetween(dateStartOfMonth, dateEndOfMonth, 'day', '[]');\n result.push({\n value: dateCurrent.valueOf(),\n labelString: dateCurrent.format('dd'),\n labelNumber: dateCurrent.date(),\n dayOfWeek: dateCurrent.isoWeekday(),\n isWeekend: [6, 7].includes(dateCurrent.isoWeekday()),\n weekOfMonth: Math.ceil((result.length + 1) / 7),\n isToday: dateCurrent.isSame(dateToday, 'day'),\n isCurrentMonth,\n isDisabled: !!(\n (dateMin && dateCurrent.isBefore(dateMin, 'day')) ||\n (dateMax && dateCurrent.isAfter(dateMax, 'day'))\n ),\n });\n\n dateCurrent.add(1, 'day');\n }\n\n return result;\n }, [valueMoment, dateDefaultMoment, props.dateMax, props.dateMin]);\n\n const rows = useMemo(() => getCountSevens(daysInMonth.length) + 1, [daysInMonth]);\n\n const sizeRadius = useMemo(() => KEY_SIZE_DATA[props.size].radius, [props.size]);\n const sizePadding = useMemo(() => KEY_SIZE_DATA[props.size].padding, [props.size]);\n\n const height = useMemo(() => 40 + rows * 28 + (rows - 1) * 6 + sizePadding * 2, [sizePadding, rows]);\n\n const isHasValue = useMemo(() => valueMoment !== null, [valueMoment]);\n\n const isBlockNextMonth = useMemo(() => {\n const nextMonth = (valueMoment ?? dateDefaultMoment).clone().add(1, 'month').startOf('month');\n const isBeforeEndDate = props.dateMax ? nextMonth.isAfter(moment.utc(props.dateMax), 'month') : false;\n return isBeforeEndDate;\n }, [valueMoment, props.dateMax, dateDefaultMoment]);\n\n const isBlockPrevMonth = useMemo(() => {\n const prevMonth = (valueMoment ?? dateDefaultMoment).clone().subtract(1, 'month').startOf('month');\n const isAfterStartDate = props.dateMin ? prevMonth.isBefore(moment.utc(props.dateMin), 'month') : false;\n return isAfterStartDate;\n }, [valueMoment, props.dateMin, dateDefaultMoment]);\n\n const [isInputFocused, setIsInputFocused] = useState(false);\n\n const refInputValue = useRef(input);\n const refIsHasValueOnce = useRef(false);\n const refPrevValue = useRef('');\n const refSelectMonth = useRef<HTMLElement>(null);\n const refSelectYear = useRef<HTMLElement>(null);\n const refHiddenInput = useRef<HTMLInputElement>(null);\n\n const onFocusPopover = useCallback(() => {\n props.onFocus?.();\n }, [props.onFocus]);\n const onBlurPopover = useCallback(() => {\n props.onBlur?.();\n }, [props.onBlur]);\n const onBlurReference = useCallback(() => {\n setActiveSegment(null);\n }, []);\n\n const { isOpen, refReference, refFloating, floatingStyles, close, toggle } = usePopover({\n placement: 'bottom-start',\n offset: sizePadding,\n mode: 'independence',\n isClickOutside: true,\n refsExcludeClickOutside: [refSelectMonth, refSelectYear],\n isDisabled: props?.isDisabled || props?.isReadOnly,\n onFocus: onFocusPopover,\n onBlur: onBlurPopover,\n onBlurReference: onBlurReference,\n });\n\n const isShowPlaceholder = useMemo(() => {\n return !!(\n !isInputFocused &&\n !isHasValue &&\n props.labelPlaceholder &&\n (type !== 'select' ? !isOpen : true) &&\n !isHasInput &&\n !activeSegment\n );\n }, [isInputFocused, isHasValue, isOpen, props.labelPlaceholder, isHasInput, activeSegment, type]);\n\n const onChangeDate = useCallback(\n (timestamp: number, isAddLeadingZeros: boolean, input?: Record<DatePickerVariant, string>) => {\n const momentNewDate = moment(timestamp).utc();\n\n const dd = momentNewDate.clone().date().toString();\n const mm = (momentNewDate.clone().month() + 1).toString();\n\n const ddWithZero = dd.padStart(2, '0');\n const mmWithZero = mm.padStart(2, '0');\n\n const yyyy = momentNewDate.clone().year().toString();\n const ddInput = input?.[DatePickerVariant.DD];\n const mmInput = input?.[DatePickerVariant.MM];\n const yyyyInput = input?.[DatePickerVariant.YYYY];\n\n const isSameInput = ddWithZero === ddInput && mmWithZero === mmInput && yyyyInput === yyyy;\n const isSameMoment = valueMoment?.isSame(momentNewDate, 'day');\n if (!isSameMoment) {\n setValueMoment(momentNewDate);\n onChange(momentNewDate.valueOf());\n }\n\n if (!isSameMoment || input ? !isSameInput : false) {\n setInput({\n [DatePickerVariant.DD]: isAddLeadingZeros ? ddWithZero : dd,\n [DatePickerVariant.MM]: isAddLeadingZeros ? mmWithZero : mm,\n [DatePickerVariant.YYYY]: yyyy,\n });\n }\n },\n [valueMoment, onChange],\n );\n\n const onKeyDown = useCallback(\n (e: KeyboardEvent<HTMLInputElement>) => {\n const key = e.key;\n\n const allowedKeys = ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown', 'Backspace', 'Delete', 'Tab', 'Enter'];\n\n const isDigit = /^\\d$/.test(key);\n const isAllowed = isDigit || allowedKeys.includes(key) || e.ctrlKey || e.metaKey;\n\n if (!isAllowed) {\n e.preventDefault();\n return;\n }\n\n if (activeSegment && dataDate.default[activeSegment]) {\n if (isDigit) {\n const digit = key;\n\n getDigitKey(digit, activeSegment, input, dataDate);\n e.preventDefault();\n e.stopPropagation();\n }\n if (key === 'Tab') {\n if (!dataDate.default[activeSegment].isLast) {\n e.preventDefault();\n dataDate.default[activeSegment].onNextSegment();\n } else {\n refHiddenInput?.current?.blur();\n }\n }\n if (key === 'Enter') {\n e.preventDefault();\n e.stopPropagation();\n }\n if (key === 'Backspace' || key === 'Delete') {\n if (activeSegment === DatePickerVariant.DD) {\n if (input.DD !== '') {\n const current = input.DD;\n if (current.length === 1) {\n dataDate.default[activeSegment].setValue('');\n } else {\n const newValue = current.slice(0, -1);\n dataDate.default[activeSegment].setValue(newValue);\n }\n } else {\n dataDate.default[activeSegment].onPrevSegment();\n }\n } else if (activeSegment === DatePickerVariant.MM) {\n if (input.MM !== '') {\n const current = input.MM;\n if (current.length === 1) {\n dataDate.default[activeSegment].setValue('');\n } else {\n const newValue = current.slice(0, -1);\n dataDate.default[activeSegment].setValue(newValue);\n }\n } else {\n dataDate.default[activeSegment].onPrevSegment();\n }\n } else if (activeSegment === DatePickerVariant.YYYY) {\n if (input.YYYY !== '') {\n const current = input.YYYY;\n if (current.length === 1) {\n dataDate.default[activeSegment].setValue('');\n } else {\n const newValue = current.slice(0, -1);\n dataDate.default[activeSegment].setValue(newValue);\n }\n } else {\n dataDate.default[activeSegment].onPrevSegment();\n }\n }\n\n e.preventDefault();\n e.stopPropagation();\n }\n if (key === 'ArrowLeft' || key === 'ArrowDown') {\n e.preventDefault();\n dataDate.default[activeSegment].onPrevSegment();\n }\n if (key === 'ArrowRight' || key === 'ArrowUp') {\n e.preventDefault();\n dataDate.default[activeSegment].onNextSegment();\n }\n }\n },\n [activeSegment, input, dataDate.default, dataDate],\n );\n\n const onNextMonth = useCallback(() => {\n const newDate = (valueMoment ?? dateDefaultMoment).clone().add(1, 'month');\n onChangeDate(newDate.valueOf(), true);\n }, [valueMoment, onChangeDate, dateDefaultMoment]);\n\n const onPrevMonth = useCallback(() => {\n const newDate = (valueMoment ?? dateDefaultMoment).clone().subtract(1, 'month');\n onChangeDate(newDate.valueOf(), true);\n }, [valueMoment, onChangeDate, dateDefaultMoment]);\n\n const onFocusInput = useCallback(() => {\n if (type === 'select') return;\n setIsInputFocused(true);\n if (!activeSegment) setActiveSegment(DatePickerVariant.DD);\n }, [activeSegment, type]);\n\n const onBlurInput = useCallback(() => {\n setIsInputFocused(false);\n\n if (!isOpen) {\n props.onBlur?.();\n }\n }, [isOpen, props.onBlur]);\n\n const onChangeInput = useCallback(\n (e: ChangeEvent<HTMLInputElement>) => {\n const value = e.target.value;\n\n const result = getParseDateString(value);\n\n if (result) {\n setInput({\n DD: String(result.day).padStart(2, '0'),\n MM: String(result.month).padStart(2, '0'),\n YYYY: String(result.year),\n });\n if (refHiddenInput.current) refHiddenInput.current.value = '';\n return;\n }\n\n const prevValue = refPrevValue.current;\n\n const newChar = value.length > prevValue.length ? value.slice(-1) : null;\n\n refPrevValue.current = value;\n\n if (newChar && /^\\d$/.test(newChar)) {\n onKeyDown({\n key: newChar,\n preventDefault: () => {},\n stopPropagation: () => {},\n } as unknown as KeyboardEvent<HTMLInputElement>);\n }\n\n if (value.length < prevValue.length) {\n onKeyDown({\n key: 'Backspace',\n preventDefault: () => {},\n stopPropagation: () => {},\n } as unknown as KeyboardEvent<HTMLInputElement>);\n }\n if (refHiddenInput.current) refHiddenInput.current.value = '';\n },\n [onKeyDown],\n );\n\n useEffect(() => {\n if (isHasValue && !refIsHasValueOnce.current) refIsHasValueOnce.current = true;\n }, [isHasValue]);\n\n useEffect(() => {\n setDateDefaultMoment(moment(props.dateDefault).utc());\n }, [props.dateDefault]);\n\n useEffect(() => {\n setValueMoment(props.value || props.defaultValue ? moment(props.value ?? props.defaultValue).utc() : null);\n if (props.value) {\n // При инициализации также форматируем в строки с ведущими нулями\n const m = moment(props.value).utc();\n setInput({\n [DatePickerVariant.DD]: m.date().toString().padStart(2, '0'),\n [DatePickerVariant.MM]: (m.month() + 1).toString().padStart(2, '0'),\n [DatePickerVariant.YYYY]: m.year().toString(),\n });\n }\n }, [props.value, props.defaultValue]);\n\n useEffect(() => {\n if (!activeSegment)\n getValidateInput(\n input,\n (value) => {\n onChangeDate(value, true, input);\n setIsError(false);\n },\n () => {\n onChange(null);\n setIsError(true);\n },\n (isHasInput) => {\n if (!isHasInput) {\n if (refIsHasValueOnce.current) {\n onChange(null);\n refIsHasValueOnce.current = false;\n }\n setIsError(false);\n }\n },\n );\n }, [onChangeDate, onChange, input, activeSegment]);\n\n useEffect(() => {\n if (!isOpen && !isInputFocused && isHasInput && !activeSegment)\n getValidateInput(\n input,\n () => {},\n () => {\n onChange(null);\n onClearInput();\n setIsError(false);\n },\n () => {\n onChange(null);\n onClearInput();\n setIsError(false);\n },\n );\n }, [onClearInput, input, isOpen, isInputFocused, onChange, isHasInput, activeSegment]);\n\n useEffect(() => {\n if (!activeSegment) return;\n getValidateInput(\n refInputValue.current,\n (value) => {\n onChangeDate(value, true, refInputValue.current);\n setIsError(false);\n },\n () => {\n setIsError(true);\n },\n (isHasInput) => {\n if (!isHasInput) {\n setIsError(false);\n }\n },\n );\n }, [onChangeDate, activeSegment]);\n\n useEffect(() => {\n if (activeSegment) {\n close();\n refHiddenInput?.current?.focus();\n }\n }, [activeSegment, close]);\n return (\n <>\n <DateWrapper\n $size={props.size}\n $genre={props.genre}\n $sx={props.sx}\n $isDisabled={props?.isDisabled}\n $isMinWidth={props?.isMinWidth}\n $radius={sizeRadius}\n $parentListHeight={height}\n tabIndex={-1}\n >\n <DateInputWrapper\n ref={refReference as RefObject<HTMLDivElement | null>}\n $genre={props.genre}\n $size={props.size}\n $isShowPlaceholder={isShowPlaceholder}\n $isDisabled={props?.isDisabled}\n $isReadOnly={props?.isReadOnly}\n $isDisabledOutline={props?.isDisabledOutline}\n $isOutlineBoxShadow={props?.isOutlineBoxShadow}\n tabIndex={-1}\n $error={\n isError\n ? {\n isError: true,\n size: props?.error?.size ?? props.size,\n ...props.notValidDate,\n }\n : props.error\n }\n $isOpen={isOpen || !!activeSegment}\n onClick={() => {\n if (type === 'select') {\n toggle();\n return;\n }\n if (!activeSegment && !props?.isReadOnly) setActiveSegment(DatePickerVariant.DD);\n }}\n >\n {type !== 'select' ? (\n <input\n name={props.name}\n aria-label={props.ariaLabel ?? props.name}\n autoComplete={props.autoComplete}\n id={props.id}\n ref={refHiddenInput}\n type='tel'\n inputMode='numeric'\n tabIndex={0}\n disabled={props?.isDisabled || props?.isReadOnly}\n style={{\n position: 'absolute',\n left: '-100dvw',\n top: 0,\n width: '100%',\n height: '100%',\n opacity: 0,\n border: 'none',\n background: 'transparent',\n }}\n onKeyDown={onKeyDown}\n onChange={onChangeInput}\n onFocus={onFocusInput}\n onBlur={onBlurInput}\n />\n ) : null}\n {isShowPlaceholder ? (\n <Typography\n sx={{ default: { size: 16, line: 1, isNoUserSelect: true } }}\n sxStandard={(theme) => ({\n default: {\n color: theme.colors.input[props.genre].color.placeholder,\n },\n })}\n >\n {props.labelPlaceholder}\n </Typography>\n ) : (\n dataDate.sort.map((date, index) => (\n <Fragment key={date.type}>\n <DateInput\n $isHaveValue={!!date.value}\n $isActive={activeSegment === date.type}\n $genre={props.genre}\n $size={props.size}\n $font={{\n ...props.font,\n size: props.font?.size ?? 16,\n weight: props.font?.weight ?? (props.isBold ? 500 : 400),\n }}\n onClick={(e) => {\n if (type === 'select') return;\n e.preventDefault();\n e.stopPropagation();\n if (props?.isDisabled || props?.isReadOnly) return;\n date.setActive();\n }}\n >\n {date.value || date.placeholder || ''}\n </DateInput>\n {index !== dataDate.sort.length - 1 && (\n <span style={{ width: '4px', pointerEvents: 'none', textAlign: 'center' }}>.</span>\n )}\n </Fragment>\n ))\n )}\n {type !== 'manual' ? (\n <DateInputButton\n genre={props.genre}\n size='small'\n isWidthAsHeight\n isFullSize\n isRadius\n isWhileTapEffect\n isOnlyIcon\n isDisabledRipple\n icons={[{ name: 'Calendar', type: 'id' }]}\n isDisabled={props?.isDisabled || props?.isReadOnly}\n tabIndex={0}\n onFocus={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setActiveSegment(null);\n }}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n toggle();\n }}\n />\n ) : null}\n {props.isShowClearButton && (isHasValue || isHasInput) && !props?.isDisabled && !props?.isReadOnly ? (\n <DateInputButtonClear\n genre={props.genre}\n size='small'\n isWidthAsHeight\n isFullSize\n isRadius\n isWhileTapEffect\n isOnlyIcon\n isDisabledRipple\n tabIndex={0}\n icons={[{ name: 'Close', type: 'id' }]}\n isDisabled={props?.isDisabled || props?.isReadOnly}\n onFocus={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setActiveSegment(null);\n }}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n onChange(null);\n onClearInput();\n setIsError(false);\n }}\n />\n ) : null}\n </DateInputWrapper>\n </DateWrapper>\n <Popover\n sx={(theme) => ({\n default: {\n background: theme.colors.input[props.genre].background.rest,\n border: `solid 1px ${theme.colors.input[props.genre].border.rest}`,\n },\n })}\n size={props.size}\n genre={props.genre}\n isOpen={isOpen}\n isShowAlwaysOutline\n floatingStyles={floatingStyles}\n ref={refFloating}\n >\n <DateDropdownList $isInputEffect={props.isInputEffect} $genre={props.genre} $size={props.size}>\n <Stack\n sx={{\n default: {\n justifyContent: 'space-between',\n alignItems: 'center',\n },\n }}\n >\n <Button\n type='button'\n isRadius\n isWhileTapEffect\n icons={[\n {\n name: 'Arrow2',\n type: 'id',\n turn: 90,\n },\n ]}\n isWidthAsHeight\n genre={props.genre}\n size={'small'}\n onClick={() => onPrevMonth()}\n isDisabledRipple\n isHidden={isBlockPrevMonth}\n isDisabled={isBlockPrevMonth}\n />\n <Stack sx={{ default: { gap: '8px' } }}>\n <SelectMonth\n isToggleWhenClickSelectListOption\n monthsLocale={props.locale.months}\n genre={props.genre}\n size={'small'}\n value={(valueMoment ?? dateDefaultMoment).clone().startOf('month').utc().valueOf()}\n isOnClickOptionClose\n isStayValueAfterSelect\n isOnlyColorInSelectListOption\n isCenter\n isShortLabel\n refFloating={refSelectMonth}\n onChange={(timestamp: number | null) => {\n if (timestamp) onChangeDate(timestamp, true);\n }}\n dateMin={props.dateMin}\n dateMax={props.dateMax}\n sx={{ default: { width: '60px' } }}\n />\n <SelectYear\n isToggleWhenClickSelectListOption\n genre={props.genre}\n size={'small'}\n refFloating={refSelectYear}\n value={(valueMoment ?? dateDefaultMoment).clone().startOf('year').utc().valueOf()}\n onChange={(timestamp: number | null) => {\n if (timestamp) onChangeDate(timestamp, true);\n }}\n isOnClickOptionClose\n isStayValueAfterSelect\n isOnlyColorInSelectListOption\n isCenter\n dateMin={props.dateMin}\n dateMax={props.dateMax}\n sx={{ default: { width: '60px' } }}\n />\n </Stack>\n <Button\n type='button'\n isWhileTapEffect\n onClick={() => onNextMonth()}\n isWidthAsHeight\n isRadius\n icons={[\n {\n name: 'Arrow2',\n type: 'id',\n turn: -90,\n },\n ]}\n genre={props.genre}\n size={'small'}\n isDisabledRipple\n isDisabled={isBlockNextMonth}\n isHidden={isBlockNextMonth}\n />\n </Stack>\n <DateDropdownDays $rows={rows}>\n {daysInWeek.map((e, index) => (\n <DateDropdownDayOfWeek\n $font={{\n ...props.font,\n size: 12,\n weight: 700,\n }}\n tabIndex={-1}\n type='button'\n $isToday={false}\n $isWeekend={false}\n $genre={props.genre}\n $size={props.size}\n $row={daysInMonth[0]?.weekOfMonth - 1}\n $column={index + 1}\n key={`${e.label}-${index}`}\n >\n {e.label}\n </DateDropdownDayOfWeek>\n ))}\n {daysInMonth.map((day) => (\n <DateDropdownDay\n $font={{\n ...props.font,\n size: 12,\n weight: 700,\n }}\n type='button'\n $isDisabled={day.isDisabled}\n $isDisabledOutline={day.isDisabled ?? props.isDisabledOutline}\n $isOutlineBoxShadow={props.isOutlineBoxShadow}\n $isReadOnly={props.isReadOnly}\n $genre={props.genre}\n $size={props.size}\n $row={day?.weekOfMonth + 1}\n $column={day.dayOfWeek}\n key={day.value}\n onClick={() => {\n if (!day.isDisabled) {\n onChangeDate(day.value, true);\n if (props.isOnClickClose) {\n close();\n }\n }\n }}\n tabIndex={day.isDisabled ? -1 : 0}\n $isToday={day.isToday}\n $isWeekend={day.isWeekend}\n $isChoice={day.value === valueMoment?.valueOf()}\n $isCurrentMonth={day.isCurrentMonth}\n >\n <Ripple color={theme.colors.date[props.genre].color.rest} isDisabled={day.isDisabled} />\n {day.labelNumber}\n </DateDropdownDay>\n ))}\n </DateDropdownDays>\n </DateDropdownList>\n </Popover>\n {isError || props?.error ? (\n <ErrorMessage\n {...(isError\n ? {\n isError: true,\n size: props?.error?.size ?? props.size,\n ...props.notValidDate,\n }\n : props.error)}\n size={props?.error?.size ?? props.size}\n font={{\n size: 12,\n weight: 400,\n family: props.font?.family ?? theme.font.family,\n }}\n />\n ) : null}\n </>\n );\n};\n\nconst ISO_DATE_REGEX = /^\\d{4}-\\d{2}-\\d{2}$/;\nconst SLASH_DATE_REGEX = /^(\\d{1,2})\\/(\\d{1,2})\\/(\\d{4})$/;\n\nfunction getDigitKey(\n key: string,\n activeSegment: DatePickerVariant,\n input: Record<DatePickerVariant, string>,\n dataDate: { default: Record<DatePickerVariant, { setValue: (value: string) => void; onNextSegment: () => void }> },\n) {\n const digit = key; // '0'..'9'\n const seg = activeSegment;\n const current = input[seg] ?? ''; // Теперь это уже строка\n\n if (seg === DatePickerVariant.DD) {\n // Дни: максимум 31\n if (current.length >= 2) {\n // уже два символа — начинаем ввод заново\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (current === '') {\n // первый символ\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // есть один символ, добавляем второй\n const potential = current + digit;\n const potentialNum = Number(potential);\n\n if (potentialNum > 31) {\n // если получается больше 31, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (potentialNum === 0) {\n // если получается 00, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // нормальная комбинация\n dataDate.default[seg].setValue(potential);\n dataDate.default[seg].onNextSegment();\n // const newInput = { ...input, [seg]: potential };\n // onNextSegment?.(newInput);\n } else if (seg === DatePickerVariant.MM) {\n // Месяцы: максимум 12\n if (current.length >= 2) {\n // уже два символа — начинаем ввод заново\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (current === '') {\n // первый символ\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // есть один символ, добавляем второй\n const potential = current + digit;\n const potentialNum = Number(potential);\n\n if (potentialNum > 12) {\n // если получается больше 12, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (potentialNum === 0) {\n // если получается 00, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // нормальная комбинация\n dataDate.default[seg].setValue(potential);\n if (potential.length === 2 || (potential.length === 1 && Number(potential) > 1)) {\n dataDate.default[seg].onNextSegment();\n // const newInput = { ...input, [seg]: potential };\n // onNextSegment?.(newInput);\n }\n } else if (seg === DatePickerVariant.YYYY) {\n // Год: накапливаем до 4 цифр\n if (current.length >= 4) {\n // уже четыре символа — начинаем ввод заново\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // добавляем цифру\n const nextValue = current + digit;\n dataDate.default[seg].setValue(nextValue);\n }\n}\n\nfunction getParseDateString(value: string) {\n // 1. ISO формат (YYYY-MM-DD)\n if (ISO_DATE_REGEX.test(value)) {\n const [year, month, day] = value.split('-').map(Number);\n return getValidateDate(year, month, day);\n }\n\n // 2. Локализованный формат (M/D/YYYY или D/M/YYYY)\n const match = SLASH_DATE_REGEX.exec(value);\n if (match) {\n const [_, p1, p2, p3] = match;\n const num1 = Number(p1);\n const num2 = Number(p2);\n const year = Number(p3);\n\n // Определяем порядок\n // Если num1 > 12 → значит это день (D/M/YYYY)\n let month: number;\n let day: number;\n\n if (num1 > 12) {\n day = num1;\n month = num2;\n } else {\n // По умолчанию считаем M/D/YYYY\n month = num1;\n day = num2;\n }\n\n return getValidateDate(year, month, day);\n }\n\n return null;\n}\n\nfunction getValidateDate(year: number, month: number, day: number) {\n const date = new Date(year, month - 1, day);\n if (date.getFullYear() === year && date.getMonth() === month - 1 && date.getDate() === day) {\n return { year, month, day };\n }\n return null;\n}\n\nfunction getCountSevens(number: number) {\n const divisor = 7;\n const count = Math.floor(number / divisor);\n const remainder = number % divisor;\n\n return remainder > 0 ? count + 1 : count;\n}\n\nfunction getNextSegment(currentSegment: DatePickerVariant, mode: DatePickerMode): DatePickerVariant | null {\n const currentIndex = mode.indexOf(currentSegment);\n return currentIndex < mode.length - 1 ? mode[currentIndex + 1] : mode[0];\n}\n\nfunction getPrevSegment(currentSegment: DatePickerVariant, mode: DatePickerMode): DatePickerVariant | null {\n const currentIndex = mode.indexOf(currentSegment);\n return currentIndex > 0 ? mode[currentIndex - 1] : mode[mode.length - 1];\n}\n\nfunction getValidateInput(\n input: Record<DatePickerVariant, string>,\n onSuccess?: (value: number) => void,\n onFailure?: () => void,\n onNan?: (isHasInput: boolean) => void,\n) {\n const dayStr = input.DD;\n const monthStr = input.MM;\n const yearStr = input.YYYY;\n\n const day = dayStr === '' ? NaN : Number(dayStr);\n const month = monthStr === '' ? NaN : Number(monthStr);\n const year = yearStr === '' ? NaN : Number(yearStr);\n\n const isHasInput = dayStr !== '' || monthStr !== '' || yearStr !== '';\n\n if (!Number.isNaN(day) && !Number.isNaN(month) && !Number.isNaN(year)) {\n const m = moment.utc(`${day}.${month}.${year}`, 'D.M.YYYY', true).startOf('day');\n if (m.isValid()) {\n onSuccess?.(m.valueOf());\n } else {\n onFailure?.();\n }\n } else {\n onNan?.(isHasInput);\n }\n}\n","import { InputStandardProps, StyledInputProps, StyledInputWrapperProps } from '@local/components/input';\nimport { addFontProps, addOutlineProps, addOutlinePropsDollar } from '@local/styles/add';\nimport { addErrorProps, ErrorMessageProps } from '@local/styles/error';\nimport { addSXProps } from '@local/styles/sx';\nimport { IThemeGenreDate, IThemeSize } from '@local/theme';\nimport { AddDollarSign } from '@local/types';\n\nimport { HTMLInputAutoCompleteAttribute } from 'react';\n\nimport { SelectMonthProps } from '../select';\n\nexport type DatePickerMode = DatePickerVariant[];\n\nexport enum DatePickerVariant {\n DD = 'DD',\n MM = 'MM',\n YYYY = 'YYYY',\n}\n\nexport type DatePickerType = 'manual' | 'select' | 'manualAndSelect';\n\nexport type CommonDatePickerProps = addErrorProps &\n addSXProps &\n addFontProps &\n addOutlineProps & {\n genre: TDateGenre;\n\n id?: string;\n\n isDisabled?: boolean;\n isBold?: boolean;\n isMinWidth?: boolean;\n\n isShowClearButton?: boolean;\n \n isInputEffect?: InputStandardProps['isInputEffect'];\n\n isOnClickClose?: boolean;\n\n labelPlaceholder?: string;\n\n locale: {\n months: SelectMonthProps['monthsLocale'];\n weeks: WeekItem[];\n inputs: InputItem;\n };\n\n notValidDate?: Omit<ErrorMessageProps, 'size' | 'isError'>;\n\n mode?: DatePickerMode;\n\n type?: DatePickerType;\n\n name?: string;\n\n ariaLabel?: string;\n\n autoComplete?: HTMLInputAutoCompleteAttribute | string;\n \n onBlur?: () => void;\n\n onChange: (timestamp: number | null) => void;\n\n onFocus?: () => void;\n\n size: IThemeSize;\n\n dateMax?: number;\n\n dateMin?: number;\n\n dateDefault: number;\n };\n\ntype ControlledValue = {\n value: number | null | undefined;\n\n defaultValue?: never;\n};\n\ntype UncontrolledValue = {\n defaultValue: number | null | undefined;\n\n value?: never;\n};\nexport type DatePickerProps = CommonDatePickerProps & (ControlledValue | UncontrolledValue);\n\nexport type TDateGenre = keyof IThemeGenreDate;\n\nexport interface DateDayProps {\n dayOfWeek: number;\n\n isCurrentMonth: boolean;\n\n isDisabled: boolean;\n\n isToday: boolean;\n\n isWeekend: boolean;\n\n labelNumber: number;\n\n labelString: string;\n\n value: number;\n\n weekOfMonth: number;\n}\n\nexport type DateWrapperProps = AddDollarSign<\n Pick<InputStandardProps, 'genre' | 'isDisabled'> & {\n parentListHeight: number;\n radius: number;\n isMinWidth?: boolean;\n }\n> &\n StyledInputWrapperProps;\n\nexport type DateInputProps = AddDollarSign<\n Pick<DatePickerProps, 'error' | 'genre' | 'size' | 'isBold' | 'isReadOnly' | 'isDisabledOutline' | 'isOutlineBoxShadow' | 'isDisabled' | 'font'> & {\n isOpen?: boolean;\n isActive?: boolean;\n isHaveValue?: boolean;\n isShowPlaceholder?: boolean;\n }\n>;\n\nexport type DateStyledOptionProps = AddDollarSign<{\n isSelectedItem?: boolean;\n isCheckboxProps?: boolean;\n}> &\n StyledInputProps;\n\nexport type DateStyledListProps = AddDollarSign<Pick<InputStandardProps, 'genre' | 'size'>>;\n\nexport type DateDropdownListProps = AddDollarSign<\n Pick<DatePickerProps, 'isInputEffect'> & Pick<DatePickerProps, 'genre' | 'size'>\n>;\n\nexport type DateDropdownDayProps = AddDollarSign<\n Pick<DatePickerProps, 'genre' | 'size' | 'font'> &\n Pick<DateDayProps, 'isToday' | 'isWeekend'> & {\n row: number;\n column: number;\n isChoice?: boolean;\n isCurrentMonth?: boolean;\n isDisabled?: boolean;\n }\n> &\n addOutlinePropsDollar;\n\nexport type MonthItem = {\n localeLong: string;\n\n localeShort: string;\n\n value:\n | 'january'\n | 'february'\n | 'march'\n | 'april'\n | 'may'\n | 'june'\n | 'july'\n | 'august'\n | 'september'\n | 'october'\n | 'november'\n | 'december';\n};\nexport type WeekItem = {\n localeLong: string;\n\n localeShort: string;\n\n value: 'mo' | 'tu' | 'we' | 'th' | 'fr' | 'sa' | 'su';\n};\nexport type InputItem = {\n day: string;\n\n month: string;\n\n year: string;\n};\n"],"names":["moment","_a","input","isHasInput","jsxs","Fragment","jsx","theme","_b","DatePickerVariant"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"component.types-TeXqILe2.js","sources":["../src/components/date-picker/component.tsx","../src/components/date-picker/component.types.ts"],"sourcesContent":["import { Button } from '@local/components/button';\nimport { Ripple } from '@local/components/ripple';\nimport { SelectMonth, SelectYear } from '@local/components/select';\nimport { Stack } from '@local/components/stack';\nimport { ErrorMessage } from '@local/styles/error';\nimport { KEY_SIZE_DATA } from '@local/theme';\n\nimport moment, { Moment } from 'moment';\nimport {\n ChangeEvent,\n Fragment,\n KeyboardEvent,\n RefObject,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useTheme } from 'styled-components';\n\nimport { Popover, usePopover } from '../popover';\nimport { Typography } from '../typography';\nimport {\n DateDayProps,\n DateDropdownDay,\n DateDropdownDayOfWeek,\n DateDropdownDays,\n DateDropdownList,\n DateInput,\n DateInputButton,\n DateInputButtonClear,\n DateInputWrapper,\n DatePickerMode,\n DatePickerProps,\n DatePickerType,\n DatePickerVariant,\n DateWrapper,\n WeekItem,\n} from '.';\n\nconst weekOrder: WeekItem['value'][] = ['mo', 'tu', 'we', 'th', 'fr', 'sa', 'su'];\n\nexport const DatePicker = (props: DatePickerProps) => {\n const { onChange } = props;\n const theme = useTheme();\n\n const [valueMoment, setValueMoment] = useState<null | Moment>(null);\n const [dateDefaultMoment, setDateDefaultMoment] = useState<Moment>(moment(props.dateDefault).utc());\n\n const [input, setInput] = useState<Record<DatePickerVariant, string>>({\n [DatePickerVariant.DD]: '',\n [DatePickerVariant.MM]: '',\n [DatePickerVariant.YYYY]: '',\n });\n\n useEffect(() => {\n refInputValue.current = input;\n }, [input]);\n\n const isHasInput = useMemo(\n () =>\n input[DatePickerVariant.DD] !== '' || input[DatePickerVariant.MM] !== '' || input[DatePickerVariant.YYYY] !== '',\n [input],\n );\n\n const onClearInput = useCallback(() => {\n setInput({\n [DatePickerVariant.DD]: '',\n [DatePickerVariant.MM]: '',\n [DatePickerVariant.YYYY]: '',\n });\n }, []);\n\n const [activeSegment, setActiveSegment] = useState<DatePickerVariant | null>(null);\n const [isError, setIsError] = useState(false);\n\n const mode: DatePickerMode = useMemo(() => {\n if (!props.mode || props.mode.length === 0) {\n return [DatePickerVariant.DD, DatePickerVariant.MM, DatePickerVariant.YYYY];\n }\n\n const hasDuplicates = new Set(props.mode).size !== props.mode.length;\n\n if (hasDuplicates) {\n return [DatePickerVariant.DD, DatePickerVariant.MM, DatePickerVariant.YYYY];\n }\n\n return props.mode;\n }, [props.mode]);\n\n const type: DatePickerType = useMemo(() => {\n if (!props.type) {\n return 'manualAndSelect';\n }\n\n return props.type;\n }, [props.type]);\n\n const dataDate = useMemo(() => {\n const segments = [DatePickerVariant.DD, DatePickerVariant.MM, DatePickerVariant.YYYY];\n\n const result = Object.fromEntries(\n segments.map((segment) => [\n segment,\n {\n type: segment,\n value: input[segment],\n placeholder:\n props.locale.inputs[\n segment === DatePickerVariant.DD ? 'day' : segment === DatePickerVariant.MM ? 'month' : 'year'\n ],\n isFirst: mode[0] === segment,\n isLast: mode[mode.length - 1] === segment,\n segmentNext: getNextSegment(segment, mode),\n segmentPrev: getPrevSegment(segment, mode),\n onNextSegment: () => setActiveSegment(getNextSegment(segment, mode)),\n onPrevSegment: () => setActiveSegment(getPrevSegment(segment, mode)),\n setValue: (value: string) => setInput((prev) => ({ ...prev, [segment]: value })),\n setActive: () => setActiveSegment(segment),\n },\n ]),\n ) as Record<\n DatePickerVariant,\n {\n type: DatePickerVariant;\n value: string;\n placeholder: string;\n isFirst: boolean;\n isLast: boolean;\n segmentNext: DatePickerVariant | null;\n segmentPrev: DatePickerVariant | null;\n onNextSegment: () => void;\n onPrevSegment: () => void;\n setValue: (value: string) => void;\n setActive: () => void;\n }\n >;\n\n const resultSort = mode.map((segment) => result[segment]).filter(Boolean);\n\n return { sort: resultSort, default: result };\n }, [props, mode, input]);\n\n const daysInWeek = useMemo(() => {\n return weekOrder.map((key, index) => {\n const found = props.locale.weeks.find((w) => w.value === key);\n return {\n index,\n label: found?.localeShort ?? key.toUpperCase(),\n };\n });\n }, [props.locale.weeks]);\n\n const daysInMonth: DateDayProps[] = useMemo(() => {\n const dateToday = moment.utc();\n const dateValue = valueMoment ?? dateDefaultMoment;\n const dateStartOfMonth = dateValue.clone().startOf('month');\n const dateEndOfMonth = dateValue.clone().endOf('month');\n const dateMin = props.dateMin ? moment.utc(props.dateMin) : null;\n const dateMax = props.dateMax ? moment.utc(props.dateMax) : null;\n\n const dateVisibleDayFirst = dateStartOfMonth.clone().subtract(dateStartOfMonth.isoWeekday() - 1, 'days');\n const dateVisibleDayLast = dateEndOfMonth.clone().add(7 - dateEndOfMonth.isoWeekday(), 'days');\n\n const result: DateDayProps[] = [];\n const dateCurrent = dateVisibleDayFirst.clone();\n\n while (dateCurrent <= dateVisibleDayLast) {\n const isCurrentMonth = dateCurrent.isBetween(dateStartOfMonth, dateEndOfMonth, 'day', '[]');\n result.push({\n value: dateCurrent.valueOf(),\n labelString: dateCurrent.format('dd'),\n labelNumber: dateCurrent.date(),\n dayOfWeek: dateCurrent.isoWeekday(),\n isWeekend: [6, 7].includes(dateCurrent.isoWeekday()),\n weekOfMonth: Math.ceil((result.length + 1) / 7),\n isToday: dateCurrent.isSame(dateToday, 'day'),\n isCurrentMonth,\n isDisabled: !!(\n (dateMin && dateCurrent.isBefore(dateMin, 'day')) ||\n (dateMax && dateCurrent.isAfter(dateMax, 'day'))\n ),\n });\n\n dateCurrent.add(1, 'day');\n }\n\n return result;\n }, [valueMoment, dateDefaultMoment, props.dateMax, props.dateMin]);\n\n const rows = useMemo(() => getCountSevens(daysInMonth.length) + 1, [daysInMonth]);\n\n const sizeRadius = useMemo(() => KEY_SIZE_DATA[props.size].radius, [props.size]);\n const sizePadding = useMemo(() => KEY_SIZE_DATA[props.size].padding, [props.size]);\n\n const height = useMemo(() => 40 + rows * 28 + (rows - 1) * 6 + sizePadding * 2, [sizePadding, rows]);\n\n const isHasValue = useMemo(() => valueMoment !== null, [valueMoment]);\n\n const isBlockNextMonth = useMemo(() => {\n const nextMonth = (valueMoment ?? dateDefaultMoment).clone().add(1, 'month').startOf('month');\n const isBeforeEndDate = props.dateMax ? nextMonth.isAfter(moment.utc(props.dateMax), 'month') : false;\n return isBeforeEndDate;\n }, [valueMoment, props.dateMax, dateDefaultMoment]);\n\n const isBlockPrevMonth = useMemo(() => {\n const prevMonth = (valueMoment ?? dateDefaultMoment).clone().subtract(1, 'month').startOf('month');\n const isAfterStartDate = props.dateMin ? prevMonth.isBefore(moment.utc(props.dateMin), 'month') : false;\n return isAfterStartDate;\n }, [valueMoment, props.dateMin, dateDefaultMoment]);\n\n const [isInputFocused, setIsInputFocused] = useState(false);\n\n const refInputValue = useRef(input);\n const refIsHasValueOnce = useRef(false);\n const refPrevValue = useRef('');\n const refSelectMonth = useRef<HTMLElement>(null);\n const refSelectYear = useRef<HTMLElement>(null);\n const refHiddenInput = useRef<HTMLInputElement>(null);\n\n const onFocusPopover = useCallback(() => {\n props.onFocus?.();\n }, [props.onFocus]);\n const onBlurPopover = useCallback(() => {\n props.onBlur?.();\n }, [props.onBlur]);\n const onBlurReference = useCallback(() => {\n setActiveSegment(null);\n }, []);\n\n const { isOpen, refReference, refFloating, floatingStyles, close, toggle } = usePopover({\n placement: 'bottom-start',\n offset: sizePadding,\n mode: 'independence',\n isClickOutside: true,\n refsExcludeClickOutside: [refSelectMonth, refSelectYear],\n isDisabled: props?.isDisabled || props?.isReadOnly,\n onFocus: onFocusPopover,\n onBlur: onBlurPopover,\n onBlurReference: onBlurReference,\n });\n\n const isShowPlaceholder = useMemo(() => {\n return !!(\n !isInputFocused &&\n !isHasValue &&\n props.labelPlaceholder &&\n (type !== 'select' ? !isOpen : true) &&\n !isHasInput &&\n !activeSegment\n );\n }, [isInputFocused, isHasValue, isOpen, props.labelPlaceholder, isHasInput, activeSegment, type]);\n\n const onChangeDate = useCallback(\n (timestamp: number, isAddLeadingZeros: boolean, input?: Record<DatePickerVariant, string>) => {\n const momentNewDate = moment(timestamp).utc();\n\n const dd = momentNewDate.clone().date().toString();\n const mm = (momentNewDate.clone().month() + 1).toString();\n\n const ddWithZero = dd.padStart(2, '0');\n const mmWithZero = mm.padStart(2, '0');\n\n const yyyy = momentNewDate.clone().year().toString();\n const ddInput = input?.[DatePickerVariant.DD];\n const mmInput = input?.[DatePickerVariant.MM];\n const yyyyInput = input?.[DatePickerVariant.YYYY];\n\n const isSameInput = ddWithZero === ddInput && mmWithZero === mmInput && yyyyInput === yyyy;\n const isSameMoment = valueMoment?.isSame(momentNewDate, 'day');\n if (!isSameMoment) {\n setValueMoment(momentNewDate);\n onChange(momentNewDate.valueOf());\n }\n\n if (!isSameMoment || input ? !isSameInput : false) {\n setInput({\n [DatePickerVariant.DD]: isAddLeadingZeros ? ddWithZero : dd,\n [DatePickerVariant.MM]: isAddLeadingZeros ? mmWithZero : mm,\n [DatePickerVariant.YYYY]: yyyy,\n });\n }\n },\n [valueMoment, onChange],\n );\n\n const onKeyDown = useCallback(\n (e: KeyboardEvent<HTMLInputElement>) => {\n const key = e.key;\n\n const allowedKeys = ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown', 'Backspace', 'Delete', 'Tab', 'Enter'];\n\n const isDigit = /^\\d$/.test(key);\n const isAllowed = isDigit || allowedKeys.includes(key) || e.ctrlKey || e.metaKey;\n\n if (!isAllowed) {\n e.preventDefault();\n return;\n }\n\n if (activeSegment && dataDate.default[activeSegment]) {\n if (isDigit) {\n const digit = key;\n\n getDigitKey(digit, activeSegment, input, dataDate);\n e.preventDefault();\n e.stopPropagation();\n }\n if (key === 'Tab') {\n if (!dataDate.default[activeSegment].isLast) {\n e.preventDefault();\n dataDate.default[activeSegment].onNextSegment();\n } else {\n refHiddenInput?.current?.blur();\n }\n }\n if (key === 'Enter') {\n e.preventDefault();\n e.stopPropagation();\n }\n if (key === 'Backspace' || key === 'Delete') {\n if (activeSegment === DatePickerVariant.DD) {\n if (input.DD !== '') {\n const current = input.DD;\n if (current.length === 1) {\n dataDate.default[activeSegment].setValue('');\n } else {\n const newValue = current.slice(0, -1);\n dataDate.default[activeSegment].setValue(newValue);\n }\n } else {\n dataDate.default[activeSegment].onPrevSegment();\n }\n } else if (activeSegment === DatePickerVariant.MM) {\n if (input.MM !== '') {\n const current = input.MM;\n if (current.length === 1) {\n dataDate.default[activeSegment].setValue('');\n } else {\n const newValue = current.slice(0, -1);\n dataDate.default[activeSegment].setValue(newValue);\n }\n } else {\n dataDate.default[activeSegment].onPrevSegment();\n }\n } else if (activeSegment === DatePickerVariant.YYYY) {\n if (input.YYYY !== '') {\n const current = input.YYYY;\n if (current.length === 1) {\n dataDate.default[activeSegment].setValue('');\n } else {\n const newValue = current.slice(0, -1);\n dataDate.default[activeSegment].setValue(newValue);\n }\n } else {\n dataDate.default[activeSegment].onPrevSegment();\n }\n }\n\n e.preventDefault();\n e.stopPropagation();\n }\n if (key === 'ArrowLeft' || key === 'ArrowDown') {\n e.preventDefault();\n dataDate.default[activeSegment].onPrevSegment();\n }\n if (key === 'ArrowRight' || key === 'ArrowUp') {\n e.preventDefault();\n dataDate.default[activeSegment].onNextSegment();\n }\n }\n },\n [activeSegment, input, dataDate.default, dataDate],\n );\n\n const onNextMonth = useCallback(() => {\n const newDate = (valueMoment ?? dateDefaultMoment).clone().add(1, 'month');\n onChangeDate(newDate.valueOf(), true);\n }, [valueMoment, onChangeDate, dateDefaultMoment]);\n\n const onPrevMonth = useCallback(() => {\n const newDate = (valueMoment ?? dateDefaultMoment).clone().subtract(1, 'month');\n onChangeDate(newDate.valueOf(), true);\n }, [valueMoment, onChangeDate, dateDefaultMoment]);\n\n const onFocusInput = useCallback(() => {\n if (type === 'select') return;\n setIsInputFocused(true);\n if (!activeSegment) setActiveSegment(DatePickerVariant.DD);\n }, [activeSegment, type]);\n\n const onBlurInput = useCallback(() => {\n setIsInputFocused(false);\n\n if (!isOpen) {\n props.onBlur?.();\n }\n }, [isOpen, props.onBlur]);\n\n const onChangeInput = useCallback(\n (e: ChangeEvent<HTMLInputElement>) => {\n const value = e.target.value;\n\n const result = getParseDateString(value);\n\n if (result) {\n setInput({\n DD: String(result.day).padStart(2, '0'),\n MM: String(result.month).padStart(2, '0'),\n YYYY: String(result.year),\n });\n if (refHiddenInput.current) refHiddenInput.current.value = '';\n return;\n }\n\n const prevValue = refPrevValue.current;\n\n const newChar = value.length > prevValue.length ? value.slice(-1) : null;\n\n refPrevValue.current = value;\n\n if (newChar && /^\\d$/.test(newChar)) {\n onKeyDown({\n key: newChar,\n preventDefault: () => {},\n stopPropagation: () => {},\n } as unknown as KeyboardEvent<HTMLInputElement>);\n }\n\n if (value.length < prevValue.length) {\n onKeyDown({\n key: 'Backspace',\n preventDefault: () => {},\n stopPropagation: () => {},\n } as unknown as KeyboardEvent<HTMLInputElement>);\n }\n if (refHiddenInput.current) refHiddenInput.current.value = '';\n },\n [onKeyDown],\n );\n\n useEffect(() => {\n if (isHasValue && !refIsHasValueOnce.current) refIsHasValueOnce.current = true;\n }, [isHasValue]);\n\n useEffect(() => {\n setDateDefaultMoment(moment(props.dateDefault).utc());\n }, [props.dateDefault]);\n\n useEffect(() => {\n setValueMoment(props.value || props.defaultValue ? moment(props.value ?? props.defaultValue).utc() : null);\n if (props.value) {\n // При инициализации также форматируем в строки с ведущими нулями\n const m = moment(props.value).utc();\n setInput({\n [DatePickerVariant.DD]: m.date().toString().padStart(2, '0'),\n [DatePickerVariant.MM]: (m.month() + 1).toString().padStart(2, '0'),\n [DatePickerVariant.YYYY]: m.year().toString(),\n });\n }\n }, [props.value, props.defaultValue]);\n\n useEffect(() => {\n if (!activeSegment)\n getValidateInput(\n input,\n (value) => {\n onChangeDate(value, true, input);\n setIsError(false);\n },\n () => {\n onChange(null);\n setIsError(true);\n },\n (isHasInput) => {\n if (!isHasInput) {\n if (refIsHasValueOnce.current) {\n onChange(null);\n refIsHasValueOnce.current = false;\n }\n setIsError(false);\n }\n },\n );\n }, [onChangeDate, onChange, input, activeSegment]);\n\n useEffect(() => {\n if (!isOpen && !isInputFocused && isHasInput && !activeSegment)\n getValidateInput(\n input,\n () => {},\n () => {\n onChange(null);\n onClearInput();\n setIsError(false);\n },\n () => {\n onChange(null);\n onClearInput();\n setIsError(false);\n },\n );\n }, [onClearInput, input, isOpen, isInputFocused, onChange, isHasInput, activeSegment]);\n\n useEffect(() => {\n if (!activeSegment) return;\n getValidateInput(\n refInputValue.current,\n (value) => {\n onChangeDate(value, true, refInputValue.current);\n setIsError(false);\n },\n () => {\n setIsError(true);\n },\n (isHasInput) => {\n if (!isHasInput) {\n setIsError(false);\n }\n },\n );\n }, [onChangeDate, activeSegment]);\n\n useEffect(() => {\n if (activeSegment) {\n close();\n refHiddenInput?.current?.focus();\n }\n }, [activeSegment, close]);\n return (\n <>\n <DateWrapper\n $size={props.size}\n $genre={props.genre}\n $sx={props.sx}\n $isDisabled={props?.isDisabled}\n $isMinWidth={props?.isMinWidth}\n $radius={sizeRadius}\n $parentListHeight={height}\n tabIndex={-1}\n >\n <DateInputWrapper\n ref={refReference as RefObject<HTMLDivElement | null>}\n $genre={props.genre}\n $size={props.size}\n $isShowPlaceholder={isShowPlaceholder}\n $isDisabled={props?.isDisabled}\n $isReadOnly={props?.isReadOnly}\n $isDisabledOutline={props?.isDisabledOutline}\n $isOutlineBoxShadow={props?.isOutlineBoxShadow}\n tabIndex={-1}\n $error={\n isError\n ? {\n isError: true,\n size: props?.error?.size ?? props.size,\n ...props.notValidDate,\n }\n : props.error\n }\n $isOpen={isOpen || !!activeSegment}\n onClick={() => {\n if (type === 'select') {\n toggle();\n return;\n }\n if (!activeSegment && !props?.isReadOnly) setActiveSegment(DatePickerVariant.DD);\n }}\n >\n {type !== 'select' ? (\n <input\n name={props.name}\n aria-label={props.ariaLabel ?? props.name}\n autoComplete={props.autoComplete}\n id={props.id}\n ref={refHiddenInput}\n type='tel'\n inputMode='numeric'\n tabIndex={0}\n disabled={props?.isDisabled || props?.isReadOnly}\n style={{\n position: 'absolute',\n left: '-100dvw',\n top: 0,\n width: '100%',\n height: '100%',\n opacity: 0,\n border: 'none',\n background: 'transparent',\n }}\n onKeyDown={onKeyDown}\n onChange={onChangeInput}\n onFocus={onFocusInput}\n onBlur={onBlurInput}\n />\n ) : null}\n {isShowPlaceholder ? (\n <Typography\n sx={{ default: { size: 16, line: 1, isNoUserSelect: true } }}\n sxStandard={(theme) => ({\n default: {\n color: theme.colors.input[props.genre].color.placeholder,\n },\n })}\n >\n {props.labelPlaceholder}\n </Typography>\n ) : (\n dataDate.sort.map((date, index) => (\n <Fragment key={date.type}>\n <DateInput\n $isHaveValue={!!date.value}\n $isActive={activeSegment === date.type}\n $genre={props.genre}\n $size={props.size}\n $font={{\n ...props.font,\n size: props.font?.size ?? 16,\n weight: props.font?.weight ?? (props.isBold ? 500 : 400),\n }}\n onClick={(e) => {\n if (type === 'select') return;\n e.preventDefault();\n e.stopPropagation();\n if (props?.isDisabled || props?.isReadOnly) return;\n date.setActive();\n }}\n >\n {date.value || date.placeholder || ''}\n </DateInput>\n {index !== dataDate.sort.length - 1 && (\n <span style={{ width: '4px', pointerEvents: 'none', textAlign: 'center' }}>.</span>\n )}\n </Fragment>\n ))\n )}\n {type !== 'manual' ? (\n <DateInputButton\n genre={props.genre}\n size='small'\n isWidthAsHeight\n isFullSize\n isRadius\n isWhileTapEffect\n isOnlyIcon\n isDisabledRipple\n icons={[{ name: 'Calendar', type: 'id' }]}\n isDisabled={props?.isDisabled || props?.isReadOnly}\n tabIndex={0}\n onFocus={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setActiveSegment(null);\n }}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n toggle();\n }}\n />\n ) : null}\n {props.isShowClearButton && (isHasValue || isHasInput) && !props?.isDisabled && !props?.isReadOnly ? (\n <DateInputButtonClear\n genre={props.genre}\n size='small'\n isWidthAsHeight\n isFullSize\n isRadius\n isWhileTapEffect\n isOnlyIcon\n isDisabledRipple\n tabIndex={0}\n icons={[{ name: 'Close', type: 'id' }]}\n isDisabled={props?.isDisabled || props?.isReadOnly}\n onFocus={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setActiveSegment(null);\n }}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n onChange(null);\n onClearInput();\n setIsError(false);\n }}\n />\n ) : null}\n </DateInputWrapper>\n </DateWrapper>\n <Popover\n sx={(theme) => ({\n default: {\n background: theme.colors.input[props.genre].background.rest,\n border: `solid 1px ${theme.colors.input[props.genre].border.rest}`,\n },\n })}\n size={props.size}\n genre={props.genre}\n isOpen={isOpen}\n isShowAlwaysOutline\n floatingStyles={floatingStyles}\n ref={refFloating}\n >\n <DateDropdownList $isInputEffect={props.isInputEffect} $genre={props.genre} $size={props.size}>\n <Stack\n sx={{\n default: {\n justifyContent: 'space-between',\n alignItems: 'center',\n },\n }}\n >\n <Button\n type='button'\n isRadius\n isWhileTapEffect\n icons={[\n {\n name: 'Arrow2',\n type: 'id',\n turn: 90,\n },\n ]}\n isWidthAsHeight\n genre={props.genre}\n size={'small'}\n onClick={() => onPrevMonth()}\n isDisabledRipple\n isHidden={isBlockPrevMonth}\n isDisabled={isBlockPrevMonth}\n />\n <Stack sx={{ default: { gap: '8px' } }}>\n <SelectMonth\n isToggleWhenClickSelectListOption\n monthsLocale={props.locale.months}\n genre={props.genre}\n size={'small'}\n value={(valueMoment ?? dateDefaultMoment).clone().startOf('month').utc().valueOf()}\n isOnClickOptionClose\n isStayValueAfterSelect\n isOnlyColorInSelectListOption\n isCenter\n isShortLabel\n refFloating={refSelectMonth}\n onChange={(timestamp: number | null) => {\n if (timestamp) onChangeDate(timestamp, true);\n }}\n dateMin={props.dateMin}\n dateMax={props.dateMax}\n sx={{ default: { width: '60px' } }}\n />\n <SelectYear\n isToggleWhenClickSelectListOption\n genre={props.genre}\n size={'small'}\n refFloating={refSelectYear}\n value={(valueMoment ?? dateDefaultMoment).clone().startOf('year').utc().valueOf()}\n onChange={(timestamp: number | null) => {\n if (timestamp) onChangeDate(timestamp, true);\n }}\n isOnClickOptionClose\n isStayValueAfterSelect\n isOnlyColorInSelectListOption\n isCenter\n dateMin={props.dateMin}\n dateMax={props.dateMax}\n sx={{ default: { width: '60px' } }}\n />\n </Stack>\n <Button\n type='button'\n isWhileTapEffect\n onClick={() => onNextMonth()}\n isWidthAsHeight\n isRadius\n icons={[\n {\n name: 'Arrow2',\n type: 'id',\n turn: -90,\n },\n ]}\n genre={props.genre}\n size={'small'}\n isDisabledRipple\n isDisabled={isBlockNextMonth}\n isHidden={isBlockNextMonth}\n />\n </Stack>\n <DateDropdownDays $rows={rows}>\n {daysInWeek.map((e, index) => (\n <DateDropdownDayOfWeek\n $font={{\n ...props.font,\n size: 12,\n weight: 700,\n }}\n tabIndex={-1}\n type='button'\n $isToday={false}\n $isWeekend={false}\n $genre={props.genre}\n $size={props.size}\n $row={daysInMonth[0]?.weekOfMonth - 1}\n $column={index + 1}\n key={`${e.label}-${index}`}\n >\n {e.label}\n </DateDropdownDayOfWeek>\n ))}\n {daysInMonth.map((day) => (\n <DateDropdownDay\n $font={{\n ...props.font,\n size: 12,\n weight: 700,\n }}\n type='button'\n $isDisabled={day.isDisabled}\n $isDisabledOutline={day.isDisabled ?? props.isDisabledOutline}\n $isOutlineBoxShadow={props.isOutlineBoxShadow}\n $isReadOnly={props.isReadOnly}\n $genre={props.genre}\n $size={props.size}\n $row={day?.weekOfMonth + 1}\n $column={day.dayOfWeek}\n key={day.value}\n onClick={() => {\n if (!day.isDisabled) {\n onChangeDate(day.value, true);\n if (props.isOnClickClose) {\n close();\n }\n }\n }}\n tabIndex={day.isDisabled ? -1 : 0}\n $isToday={day.isToday}\n $isWeekend={day.isWeekend}\n $isChoice={day.value === valueMoment?.valueOf()}\n $isCurrentMonth={day.isCurrentMonth}\n >\n <Ripple color={theme.colors.date[props.genre].color.rest} isDisabled={day.isDisabled} />\n {day.labelNumber}\n </DateDropdownDay>\n ))}\n </DateDropdownDays>\n </DateDropdownList>\n </Popover>\n {isError || props?.error ? (\n <ErrorMessage\n {...(isError\n ? {\n isError: true,\n size: props?.error?.size ?? props.size,\n ...props.notValidDate,\n }\n : props.error)}\n size={props?.error?.size ?? props.size}\n font={{\n size: 12,\n weight: 400,\n family: props.font?.family ?? theme.font.family,\n }}\n />\n ) : null}\n </>\n );\n};\n\nconst ISO_DATE_REGEX = /^\\d{4}-\\d{2}-\\d{2}$/;\nconst SLASH_DATE_REGEX = /^(\\d{1,2})\\/(\\d{1,2})\\/(\\d{4})$/;\n\nfunction getDigitKey(\n key: string,\n activeSegment: DatePickerVariant,\n input: Record<DatePickerVariant, string>,\n dataDate: { default: Record<DatePickerVariant, { setValue: (value: string) => void; onNextSegment: () => void }> },\n) {\n const digit = key; // '0'..'9'\n const seg = activeSegment;\n const current = input[seg] ?? ''; // Теперь это уже строка\n\n if (seg === DatePickerVariant.DD) {\n // Дни: максимум 31\n if (current.length >= 2) {\n // уже два символа — начинаем ввод заново\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (current === '') {\n // первый символ\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // есть один символ, добавляем второй\n const potential = current + digit;\n const potentialNum = Number(potential);\n\n if (potentialNum > 31) {\n // если получается больше 31, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (potentialNum === 0) {\n // если получается 00, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // нормальная комбинация\n dataDate.default[seg].setValue(potential);\n dataDate.default[seg].onNextSegment();\n // const newInput = { ...input, [seg]: potential };\n // onNextSegment?.(newInput);\n } else if (seg === DatePickerVariant.MM) {\n // Месяцы: максимум 12\n if (current.length >= 2) {\n // уже два символа — начинаем ввод заново\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (current === '') {\n // первый символ\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // есть один символ, добавляем второй\n const potential = current + digit;\n const potentialNum = Number(potential);\n\n if (potentialNum > 12) {\n // если получается больше 12, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n if (potentialNum === 0) {\n // если получается 00, заменяем на новую цифру\n // if (digit === '0') return; // нельзя начинать с 0\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // нормальная комбинация\n dataDate.default[seg].setValue(potential);\n if (potential.length === 2 || (potential.length === 1 && Number(potential) > 1)) {\n dataDate.default[seg].onNextSegment();\n // const newInput = { ...input, [seg]: potential };\n // onNextSegment?.(newInput);\n }\n } else if (seg === DatePickerVariant.YYYY) {\n // Год: накапливаем до 4 цифр\n if (current.length >= 4) {\n // уже четыре символа — начинаем ввод заново\n dataDate.default[seg].setValue(digit);\n return;\n }\n\n // добавляем цифру\n const nextValue = current + digit;\n dataDate.default[seg].setValue(nextValue);\n }\n}\n\nfunction getParseDateString(value: string) {\n // 1. ISO формат (YYYY-MM-DD)\n if (ISO_DATE_REGEX.test(value)) {\n const [year, month, day] = value.split('-').map(Number);\n return getValidateDate(year, month, day);\n }\n\n // 2. Локализованный формат (M/D/YYYY или D/M/YYYY)\n const match = SLASH_DATE_REGEX.exec(value);\n if (match) {\n const [_, p1, p2, p3] = match;\n const num1 = Number(p1);\n const num2 = Number(p2);\n const year = Number(p3);\n\n // Определяем порядок\n // Если num1 > 12 → значит это день (D/M/YYYY)\n let month: number;\n let day: number;\n\n if (num1 > 12) {\n day = num1;\n month = num2;\n } else {\n // По умолчанию считаем M/D/YYYY\n month = num1;\n day = num2;\n }\n\n return getValidateDate(year, month, day);\n }\n\n return null;\n}\n\nfunction getValidateDate(year: number, month: number, day: number) {\n const date = new Date(year, month - 1, day);\n if (date.getFullYear() === year && date.getMonth() === month - 1 && date.getDate() === day) {\n return { year, month, day };\n }\n return null;\n}\n\nfunction getCountSevens(number: number) {\n const divisor = 7;\n const count = Math.floor(number / divisor);\n const remainder = number % divisor;\n\n return remainder > 0 ? count + 1 : count;\n}\n\nfunction getNextSegment(currentSegment: DatePickerVariant, mode: DatePickerMode): DatePickerVariant | null {\n const currentIndex = mode.indexOf(currentSegment);\n return currentIndex < mode.length - 1 ? mode[currentIndex + 1] : mode[0];\n}\n\nfunction getPrevSegment(currentSegment: DatePickerVariant, mode: DatePickerMode): DatePickerVariant | null {\n const currentIndex = mode.indexOf(currentSegment);\n return currentIndex > 0 ? mode[currentIndex - 1] : mode[mode.length - 1];\n}\n\nfunction getValidateInput(\n input: Record<DatePickerVariant, string>,\n onSuccess?: (value: number) => void,\n onFailure?: () => void,\n onNan?: (isHasInput: boolean) => void,\n) {\n const dayStr = input.DD;\n const monthStr = input.MM;\n const yearStr = input.YYYY;\n\n const day = dayStr === '' ? NaN : Number(dayStr);\n const month = monthStr === '' ? NaN : Number(monthStr);\n const year = yearStr === '' ? NaN : Number(yearStr);\n\n const isHasInput = dayStr !== '' || monthStr !== '' || yearStr !== '';\n\n if (!Number.isNaN(day) && !Number.isNaN(month) && !Number.isNaN(year)) {\n const m = moment.utc(`${day}.${month}.${year}`, 'D.M.YYYY', true).startOf('day');\n if (m.isValid()) {\n onSuccess?.(m.valueOf());\n } else {\n onFailure?.();\n }\n } else {\n onNan?.(isHasInput);\n }\n}\n","import { InputStandardProps, StyledInputProps, StyledInputWrapperProps } from '@local/components/input';\nimport { addFontProps, addOutlineProps, addOutlinePropsDollar } from '@local/styles/add';\nimport { addErrorProps, ErrorMessageProps } from '@local/styles/error';\nimport { addSXProps } from '@local/styles/sx';\nimport { IThemeGenreDate, IThemeSize } from '@local/theme';\nimport { AddDollarSign } from '@local/types';\n\nimport { HTMLInputAutoCompleteAttribute } from 'react';\n\nimport { SelectMonthProps } from '../select';\n\nexport type DatePickerMode = DatePickerVariant[];\n\nexport enum DatePickerVariant {\n DD = 'DD',\n MM = 'MM',\n YYYY = 'YYYY',\n}\n\nexport type DatePickerType = 'manual' | 'select' | 'manualAndSelect';\n\nexport type CommonDatePickerProps = addErrorProps &\n addSXProps &\n addFontProps &\n addOutlineProps & {\n genre: TDateGenre;\n\n id?: string;\n\n isDisabled?: boolean;\n isBold?: boolean;\n isMinWidth?: boolean;\n\n isShowClearButton?: boolean;\n \n isInputEffect?: InputStandardProps['isInputEffect'];\n\n isOnClickClose?: boolean;\n\n labelPlaceholder?: string;\n\n locale: {\n months: SelectMonthProps['monthsLocale'];\n weeks: WeekItem[];\n inputs: InputItem;\n };\n\n notValidDate?: Omit<ErrorMessageProps, 'size' | 'isError'>;\n\n mode?: DatePickerMode;\n\n type?: DatePickerType;\n\n name?: string;\n\n ariaLabel?: string;\n\n autoComplete?: HTMLInputAutoCompleteAttribute | string;\n \n onBlur?: () => void;\n\n onChange: (timestamp: number | null) => void;\n\n onFocus?: () => void;\n\n size: IThemeSize;\n\n dateMax?: number;\n\n dateMin?: number;\n\n dateDefault: number;\n };\n\ntype ControlledValue = {\n value: number | null | undefined;\n\n defaultValue?: never;\n};\n\ntype UncontrolledValue = {\n defaultValue: number | null | undefined;\n\n value?: never;\n};\nexport type DatePickerProps = CommonDatePickerProps & (ControlledValue | UncontrolledValue);\n\nexport type TDateGenre = keyof IThemeGenreDate;\n\nexport interface DateDayProps {\n dayOfWeek: number;\n\n isCurrentMonth: boolean;\n\n isDisabled: boolean;\n\n isToday: boolean;\n\n isWeekend: boolean;\n\n labelNumber: number;\n\n labelString: string;\n\n value: number;\n\n weekOfMonth: number;\n}\n\nexport type DateWrapperProps = AddDollarSign<\n Pick<InputStandardProps, 'genre' | 'isDisabled'> & {\n parentListHeight: number;\n radius: number;\n isMinWidth?: boolean;\n }\n> &\n StyledInputWrapperProps;\n\nexport type DateInputProps = AddDollarSign<\n Pick<DatePickerProps, 'error' | 'genre' | 'size' | 'isBold' | 'isReadOnly' | 'isDisabledOutline' | 'isOutlineBoxShadow' | 'isDisabled' | 'font'> & {\n isOpen?: boolean;\n isActive?: boolean;\n isHaveValue?: boolean;\n isShowPlaceholder?: boolean;\n }\n>;\n\nexport type DateStyledOptionProps = AddDollarSign<{\n isSelectedItem?: boolean;\n isCheckboxProps?: boolean;\n}> &\n StyledInputProps;\n\nexport type DateStyledListProps = AddDollarSign<Pick<InputStandardProps, 'genre' | 'size'>>;\n\nexport type DateDropdownListProps = AddDollarSign<\n Pick<DatePickerProps, 'isInputEffect'> & Pick<DatePickerProps, 'genre' | 'size'>\n>;\n\nexport type DateDropdownDayProps = AddDollarSign<\n Pick<DatePickerProps, 'genre' | 'size' | 'font'> &\n Pick<DateDayProps, 'isToday' | 'isWeekend'> & {\n row: number;\n column: number;\n isChoice?: boolean;\n isCurrentMonth?: boolean;\n isDisabled?: boolean;\n }\n> &\n addOutlinePropsDollar;\n\nexport type MonthItem = {\n localeLong: string;\n\n localeShort: string;\n\n value:\n | 'january'\n | 'february'\n | 'march'\n | 'april'\n | 'may'\n | 'june'\n | 'july'\n | 'august'\n | 'september'\n | 'october'\n | 'november'\n | 'december';\n};\nexport type WeekItem = {\n localeLong: string;\n\n localeShort: string;\n\n value: 'mo' | 'tu' | 'we' | 'th' | 'fr' | 'sa' | 'su';\n};\nexport type InputItem = {\n day: string;\n\n month: string;\n\n year: string;\n};\n"],"names":["moment","_a","input","isHasInput","jsxs","Fragment","jsx","theme","_b","DatePickerVariant"],"mappings":"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"}
|
package/build/consts.cjs.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./functions.cjs.js"),o={eng:{value:"eng",label:"English",placeholder:"English",search:"English, eng"},rus:{value:"rus",label:"Русский",placeholder:"Русский",search:"Русский, rus"}},l={jenesei_id:{value:"jenesei_id",label:"Jenesei ID",placeholder:"Jenesei ID",search:"Jenesei ID"}},a=e.transformObjectToArray(o),r=e.transformObjectValuesToKeys(o),t=e.transformObjectToArray(l),u=e.transformObjectValuesToKeys(l),c=["image/*",".jpeg",".jpg",".png",".webp","avif"].join(",");exports.LIBRARY_VERSION="1.3.
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./functions.cjs.js"),o={eng:{value:"eng",label:"English",placeholder:"English",search:"English, eng"},rus:{value:"rus",label:"Русский",placeholder:"Русский",search:"Русский, rus"}},l={jenesei_id:{value:"jenesei_id",label:"Jenesei ID",placeholder:"Jenesei ID",search:"Jenesei ID"}},a=e.transformObjectToArray(o),r=e.transformObjectValuesToKeys(o),t=e.transformObjectToArray(l),u=e.transformObjectValuesToKeys(l),c=["image/*",".jpeg",".jpg",".png",".webp","avif"].join(",");exports.LIBRARY_VERSION="1.3.37",exports.LIST_IMAGE_SUPPORTED_FORMAT=["image/jpeg","image/jpg","image/png","image/webp","image/avif"],exports.LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT=c,exports.LIST_KEY_LANGUAGE=r,exports.LIST_KEY_SERVICE=u,exports.LIST_LANGUAGE=a,exports.LIST_SERVICE=t,exports.LOCALE_INPUT={day:"ДД",month:"ММ",year:"ГГГГ"},exports.LOCALE_MONTHS=[{localeLong:"Январь",localeShort:"Янв",value:"january"},{localeLong:"February",localeShort:"Feb",value:"february"},{localeLong:"March",localeShort:"Mar",value:"march"},{localeLong:"April",localeShort:"Apr",value:"april"},{localeLong:"May",localeShort:"May",value:"may"},{localeLong:"June",localeShort:"Jun",value:"june"},{localeLong:"July",localeShort:"Jul",value:"july"},{localeLong:"August",localeShort:"Aug",value:"august"},{localeLong:"September",localeShort:"Sep",value:"september"},{localeLong:"October",localeShort:"Oct",value:"october"},{localeLong:"November",localeShort:"Nov",value:"november"},{localeLong:"December",localeShort:"Dec",value:"december"}],exports.LOCALE_WEEKS=[{localeLong:"Monday",localeShort:"Пн",value:"mo"},{localeLong:"Tuesday",localeShort:"Tue",value:"tu"},{localeLong:"Wednesday",localeShort:"Wed",value:"we"},{localeLong:"Thursday",localeShort:"Thu",value:"th"},{localeLong:"Friday",localeShort:"Fri",value:"fr"},{localeLong:"Saturday",localeShort:"Sat",value:"sa"},{localeLong:"Sunday",localeShort:"Sun",value:"su"}],exports.LOREM_IPSUM_TEXT="Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.",exports.OBJECT_LANGUAGE=o,exports.OBJECT_SERVICE=l;
|
|
2
2
|
//# sourceMappingURL=consts.cjs.js.map
|
package/build/consts.es.js
CHANGED
|
@@ -132,7 +132,7 @@ const LOCALE_WEEKS = [
|
|
|
132
132
|
const LIST_IMAGE_SUPPORTED_FORMAT = ["image/jpeg", "image/jpg", "image/png", "image/webp", "image/avif"];
|
|
133
133
|
const LIST_IMAGE_SUPPORTED_FORMAT_FOR_INPUT = ["image/*", ".jpeg", ".jpg", ".png", ".webp", "avif"].join(",");
|
|
134
134
|
const LOREM_IPSUM_TEXT = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.";
|
|
135
|
-
const LIBRARY_VERSION = "1.3.
|
|
135
|
+
const LIBRARY_VERSION = "1.3.37";
|
|
136
136
|
export {
|
|
137
137
|
LIBRARY_VERSION,
|
|
138
138
|
LIST_IMAGE_SUPPORTED_FORMAT,
|
package/build/context-app.cjs.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./context.constants-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./context.constants-D9hGtc0A.cjs"),r=require("./context.hooks-2SMzc0Vc.cjs");exports.AppContext=e.AppContext,exports.ProviderApp=e.ProviderApp,exports.ProviderAppOutlet=e.ProviderAppOutlet,exports.ProviderAppOutletChildren=e.ProviderAppOutletChildren,exports.ProviderAppOutletFooter=e.ProviderAppOutletFooter,exports.ProviderAppOutletHeader=e.ProviderAppOutletHeader,exports.ProviderAppOutletLeftAside=e.ProviderAppOutletLeftAside,exports.ProviderAppOutletNav=e.ProviderAppOutletNav,exports.ProviderAppOutletNotification=e.ProviderAppOutletNotification,exports.ProviderAppOutletRightAside=e.ProviderAppOutletRightAside,exports.ProviderAppWrapper=e.ProviderAppWrapper,exports.useBgColor=e.useBgColor,exports.useBgImage=e.useBgImage,exports.useDescription=e.useDescription,exports.useStatusBarColor=e.useStatusBarColor,exports.useApp=r.useApp;
|
|
2
2
|
//# sourceMappingURL=context-app.cjs.js.map
|
package/build/context-app.es.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { aP, aQ, aW, aX, a_, aZ, b0, a$, aY, b1, aV, aR, aT, aU, aS } from "./context.constants-
|
|
2
|
-
import { u } from "./context.hooks-
|
|
1
|
+
import { aP, aQ, aW, aX, a_, aZ, b0, a$, aY, b1, aV, aR, aT, aU, aS } from "./context.constants-4eKvVwha.js";
|
|
2
|
+
import { u } from "./context.hooks-DEfRvBpX.js";
|
|
3
3
|
export {
|
|
4
4
|
aP as AppContext,
|
|
5
5
|
aQ as ProviderApp,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const D=require("./context.constants-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const D=require("./context.constants-CAlZQBvG.cjs"),E=require("./context.hooks-CdUNX5DP.cjs");exports.DEFAULT_PROVIDER_DIALOG_DURATION_ELEMENT=D.DEFAULT_PROVIDER_DIALOG_DURATION_ELEMENT,exports.DEFAULT_PROVIDER_DIALOG_DURATION_LAYOUT=D.DEFAULT_PROVIDER_DIALOG_DURATION_LAYOUT,exports.DEFAULT_PROVIDER_DIALOG_ELEMENT_BACKGROUND=D.DEFAULT_PROVIDER_DIALOG_ELEMENT_BACKGROUND,exports.DEFAULT_PROVIDER_DIALOG_ELEMENT_BORDER_RADIUS=D.DEFAULT_PROVIDER_DIALOG_ELEMENT_BORDER_RADIUS,exports.DEFAULT_PROVIDER_DIALOG_ELEMENT_MAX_HEIGHT=D.DEFAULT_PROVIDER_DIALOG_ELEMENT_MAX_HEIGHT,exports.DEFAULT_PROVIDER_DIALOG_ELEMENT_MAX_WIDTH=D.DEFAULT_PROVIDER_DIALOG_ELEMENT_MAX_WIDTH,exports.DEFAULT_PROVIDER_DIALOG_ELEMENT_PADDING=D.DEFAULT_PROVIDER_DIALOG_ELEMENT_PADDING,exports.DialogContent=D.DialogContent,exports.DialogContext=D.DialogContext,exports.DialogElementWrapper=D.DialogElementWrapper,exports.DialogLayout=D.DialogLayout,exports.ProviderDialog=D.ProviderDialog,exports.useDialog=E.useDialog,exports.useDialogs=E.useDialogs;
|
|
2
2
|
//# sourceMappingURL=context-dialog.cjs.js.map
|
|
@@ -24,8 +24,6 @@ declare type addOutlineProps = {
|
|
|
24
24
|
isOutlineBoxShadow?: boolean;
|
|
25
25
|
};
|
|
26
26
|
|
|
27
|
-
declare type addOutlinePropsDollar = AddDollarSign<addOutlineProps>;
|
|
28
|
-
|
|
29
27
|
export declare const DEFAULT_PROVIDER_DIALOG_DURATION_ELEMENT = 0.3;
|
|
30
28
|
|
|
31
29
|
export declare const DEFAULT_PROVIDER_DIALOG_DURATION_LAYOUT = 0.4;
|
|
@@ -42,43 +40,44 @@ export declare const DEFAULT_PROVIDER_DIALOG_ELEMENT_PADDING: string;
|
|
|
42
40
|
|
|
43
41
|
export declare const DialogContent: IStyledComponentBase<"web", FastOmit<Omit<HTMLMotionProps<"div">, "ref"> & RefAttributes<HTMLDivElement>, never>> & string & Omit<ForwardRefComponent<HTMLDivElement, HTMLMotionProps<"div">>, keyof Component<any, {}, any>>;
|
|
44
42
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
43
|
+
declare type DialogContentObjectPropsContent<T extends object> = (remove?: () => void, isAnimating?: boolean, propsCustom?: T) => ReactNode;
|
|
44
|
+
|
|
45
|
+
declare type DialogContentObjectPropsDialog = {
|
|
46
|
+
maxWidth?: string;
|
|
47
|
+
maxHeight?: string;
|
|
48
|
+
padding?: string;
|
|
49
|
+
borderRadius?: string;
|
|
50
|
+
background?: IThemePaletteKeys;
|
|
51
|
+
isRemoveOnOutsideClick?: boolean;
|
|
53
52
|
};
|
|
54
53
|
|
|
55
|
-
export declare type DialogContentProps<T extends object> = {
|
|
56
|
-
content?: (props?: useDialogProps<T>, remove?: () => void, isAnimating?: boolean) => ReactNode;
|
|
54
|
+
export declare type DialogContentProps<T extends object = any> = {
|
|
57
55
|
props?: useDialogProps<T>;
|
|
58
56
|
id?: string;
|
|
59
57
|
index?: number;
|
|
58
|
+
onRemove?: () => void;
|
|
60
59
|
};
|
|
61
60
|
|
|
62
|
-
export declare const DialogContext: Context<DialogContextProps
|
|
61
|
+
export declare const DialogContext: Context<DialogContextProps | null>;
|
|
63
62
|
|
|
64
|
-
export declare type DialogContextItemProps
|
|
65
|
-
add: (
|
|
63
|
+
export declare type DialogContextItemProps = {
|
|
64
|
+
add: () => void;
|
|
66
65
|
remove: () => void;
|
|
67
66
|
id: string | null;
|
|
68
67
|
};
|
|
69
68
|
|
|
70
|
-
export declare type DialogContextProps<T extends object> = {
|
|
71
|
-
add: (dialog: DialogContentProps<
|
|
72
|
-
remove: (id: DialogContentProps<
|
|
73
|
-
update: (dialog: DialogContentProps<
|
|
74
|
-
dialogHistory: DialogContentProps<
|
|
69
|
+
export declare type DialogContextProps<T extends object = any> = {
|
|
70
|
+
add: (dialog: DialogContentProps<T>) => void;
|
|
71
|
+
remove: (id: DialogContentProps<T>['id']) => void;
|
|
72
|
+
update: (dialog: DialogContentProps<T>) => void;
|
|
73
|
+
dialogHistory: DialogContentProps<T>[];
|
|
75
74
|
};
|
|
76
75
|
|
|
77
|
-
export declare type DialogElementProps
|
|
76
|
+
export declare type DialogElementProps<T extends object> = DialogContentProps<T>;
|
|
78
77
|
|
|
79
|
-
export declare const DialogElementWrapper: IStyledComponentBase<"web", Substitute<Omit<HTMLMotionProps<"dialog">, "ref"> & RefAttributes<HTMLDialogElement>,
|
|
78
|
+
export declare const DialogElementWrapper: IStyledComponentBase<"web", Substitute<Omit<HTMLMotionProps<"dialog">, "ref"> & RefAttributes<HTMLDialogElement>, AddDollarSign_2<addOutlineProps & Pick<useDialogProps<object>, "propsDialog">>>> & string & Omit<ForwardRefComponent<HTMLDialogElement, HTMLMotionProps<"dialog">>, keyof Component<any, {}, any>>;
|
|
80
79
|
|
|
81
|
-
export declare type DialogElementWrapperProps = AddDollarSign<useDialogProps<
|
|
80
|
+
export declare type DialogElementWrapperProps<T extends object> = AddDollarSign<addOutlineProps & Pick<useDialogProps<T>, 'propsDialog'>>;
|
|
82
81
|
|
|
83
82
|
export declare const DialogLayout: IStyledComponentBase<"web", Substitute<Omit<HTMLMotionProps<"div">, "ref"> & RefAttributes<HTMLDivElement>, AddDollarSign_2<Pick<ProviderDialogProps, "zIndex">>>> & string & Omit<ForwardRefComponent<HTMLDivElement, HTMLMotionProps<"div">>, keyof Component<any, {}, any>>;
|
|
84
83
|
|
|
@@ -92,10 +91,16 @@ export declare type ProviderDialogProps = PropsWithChildren & {
|
|
|
92
91
|
zIndex: number;
|
|
93
92
|
};
|
|
94
93
|
|
|
95
|
-
export declare const useDialog: <T extends object>(props?: useDialogProps<T>) => DialogContextItemProps
|
|
94
|
+
export declare const useDialog: <T extends object = object>(props?: useDialogProps<T>) => DialogContextItemProps;
|
|
96
95
|
|
|
97
|
-
export declare type useDialogProps<T extends object
|
|
96
|
+
export declare type useDialogProps<T extends object = any> = {
|
|
97
|
+
content?: DialogContentObjectPropsContent<T>;
|
|
98
|
+
propsDialog?: DialogContentObjectPropsDialog;
|
|
99
|
+
propsOutline?: addOutlineProps;
|
|
100
|
+
propsCustom?: T;
|
|
101
|
+
onRemove?: () => void;
|
|
102
|
+
};
|
|
98
103
|
|
|
99
|
-
export declare const useDialogs: () => DialogContextProps
|
|
104
|
+
export declare const useDialogs: () => DialogContextProps;
|
|
100
105
|
|
|
101
106
|
export { }
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { d, e, j, h, f, g, i, c, D, b, a, P } from "./context.constants-
|
|
2
|
-
import { a as a2, u } from "./context.hooks-
|
|
1
|
+
import { d, e, j, h, f, g, i, c, D, b, a, P } from "./context.constants-DRDMvlln.js";
|
|
2
|
+
import { a as a2, u } from "./context.hooks-CjH6Plw7.js";
|
|
3
3
|
export {
|
|
4
4
|
d as DEFAULT_PROVIDER_DIALOG_DURATION_ELEMENT,
|
|
5
5
|
e as DEFAULT_PROVIDER_DIALOG_DURATION_LAYOUT,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./context.constants-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./context.constants-D9hGtc0A.cjs"),n=require("./context.hooks-DpBSd_p-.cjs");exports.DEFAULT_PROVIDER_SONNER_BUTTON=e.DEFAULT_PROVIDER_SONNER_BUTTON,exports.DEFAULT_PROVIDER_SONNER_DURATION=e.DEFAULT_PROVIDER_SONNER_DURATION,exports.DEFAULT_PROVIDER_SONNER_GENRE=e.DEFAULT_PROVIDER_SONNER_GENRE,exports.DEFAULT_PROVIDER_SONNER_MARGIN_BOTTOM=e.DEFAULT_PROVIDER_SONNER_MARGIN_BOTTOM,exports.DEFAULT_PROVIDER_SONNER_SCALE=e.DEFAULT_PROVIDER_SONNER_SCALE,exports.DEFAULT_PROVIDER_SONNER_Y=e.DEFAULT_PROVIDER_SONNER_Y,exports.DEFAULT_PROVIDER_SONNER_Z_INDEX=e.DEFAULT_PROVIDER_SONNER_Z_INDEX,exports.ProviderSonner=e.ProviderSonner,exports.SonnerButtonWrapper=e.SonnerButtonWrapper,exports.SonnerContent=e.SonnerContent,exports.SonnerContentDescription=e.SonnerContentDescription,exports.SonnerContentTitle=e.SonnerContentTitle,exports.SonnerContext=e.SonnerContext,exports.SonnerElementWrapper=e.SonnerElementWrapper,exports.SonnerIcon=e.SonnerIcon,exports.SonnerLayout=e.SonnerLayout,exports.useSonner=n.useSonner;
|
|
2
2
|
//# sourceMappingURL=context-sonner.cjs.js.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { bh, be, bf, bg, bc, bd, bb, b3, ba, b6, b9, b8, b2, b5, b7, b4 } from "./context.constants-
|
|
2
|
-
import { u } from "./context.hooks-
|
|
1
|
+
import { bh, be, bf, bg, bc, bd, bb, b3, ba, b6, b9, b8, b2, b5, b7, b4 } from "./context.constants-4eKvVwha.js";
|
|
2
|
+
import { u } from "./context.hooks-CZOS7JGV.js";
|
|
3
3
|
export {
|
|
4
4
|
bh as DEFAULT_PROVIDER_SONNER_BUTTON,
|
|
5
5
|
be as DEFAULT_PROVIDER_SONNER_DURATION,
|
|
@@ -11,14 +11,14 @@ import { AnimatePresence, motion } from "framer-motion";
|
|
|
11
11
|
import "./area.styles-DhCCEhuq.js";
|
|
12
12
|
import { W as WordsPullUp } from "./motion-K7hUU4gL.js";
|
|
13
13
|
import { u as useScreenWidth } from "./context.hooks-oclt34zD.js";
|
|
14
|
-
import { u as useDeepCompareMemoize } from "./use-
|
|
14
|
+
import { u as useDeepCompareMemoize } from "./use-C7vngeRk.js";
|
|
15
15
|
import { createLink } from "@tanstack/react-router";
|
|
16
16
|
import * as ReactDOM from "react-dom";
|
|
17
17
|
import ReactDOM__default from "react-dom";
|
|
18
18
|
import { LIBRARY_VERSION, LIST_LANGUAGE } from "./consts.es.js";
|
|
19
19
|
import { useVirtualizer } from "@tanstack/react-virtual";
|
|
20
20
|
import { R as Ripple } from "./component-D-HMYzXU.js";
|
|
21
|
-
import { v as v4 } from "./context.constants-
|
|
21
|
+
import { v as v4 } from "./context.constants-DRDMvlln.js";
|
|
22
22
|
import "./component.styles-SZ5VuhNG.js";
|
|
23
23
|
import "./context-C0_RNFp_.js";
|
|
24
24
|
import "./context-LBih45kv.js";
|
|
@@ -12590,4 +12590,4 @@ export {
|
|
|
12590
12590
|
addDateInputWrapperSize as y,
|
|
12591
12591
|
DateInputWrapper as z
|
|
12592
12592
|
};
|
|
12593
|
-
//# sourceMappingURL=context.constants-
|
|
12593
|
+
//# sourceMappingURL=context.constants-4eKvVwha.js.map
|