@rc-component/picker 1.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.
- package/LICENSE.md +9 -0
- package/README.md +154 -0
- package/assets/index.css +407 -0
- package/assets/index.less +570 -0
- package/es/PickerInput/Popup/Footer.d.ts +19 -0
- package/es/PickerInput/Popup/Footer.js +78 -0
- package/es/PickerInput/Popup/PopupPanel.d.ts +10 -0
- package/es/PickerInput/Popup/PopupPanel.js +84 -0
- package/es/PickerInput/Popup/PresetPanel.d.ts +9 -0
- package/es/PickerInput/Popup/PresetPanel.js +31 -0
- package/es/PickerInput/Popup/index.d.ts +20 -0
- package/es/PickerInput/Popup/index.js +198 -0
- package/es/PickerInput/RangePicker.d.ts +54 -0
- package/es/PickerInput/RangePicker.js +641 -0
- package/es/PickerInput/Selector/Icon.d.ts +10 -0
- package/es/PickerInput/Selector/Icon.js +32 -0
- package/es/PickerInput/Selector/Input.d.ts +28 -0
- package/es/PickerInput/Selector/Input.js +377 -0
- package/es/PickerInput/Selector/MaskFormat.d.ts +22 -0
- package/es/PickerInput/Selector/MaskFormat.js +107 -0
- package/es/PickerInput/Selector/RangeSelector.d.ts +26 -0
- package/es/PickerInput/Selector/RangeSelector.js +218 -0
- package/es/PickerInput/Selector/SingleSelector/MultipleDates.d.ts +12 -0
- package/es/PickerInput/Selector/SingleSelector/MultipleDates.js +66 -0
- package/es/PickerInput/Selector/SingleSelector/index.d.ts +18 -0
- package/es/PickerInput/Selector/SingleSelector/index.js +187 -0
- package/es/PickerInput/Selector/hooks/useClearIcon.d.ts +8 -0
- package/es/PickerInput/Selector/hooks/useClearIcon.js +19 -0
- package/es/PickerInput/Selector/hooks/useInputProps.d.ts +16 -0
- package/es/PickerInput/Selector/hooks/useInputProps.js +178 -0
- package/es/PickerInput/Selector/hooks/useRootProps.d.ts +2 -0
- package/es/PickerInput/Selector/hooks/useRootProps.js +8 -0
- package/es/PickerInput/Selector/util.d.ts +1 -0
- package/es/PickerInput/Selector/util.js +12 -0
- package/es/PickerInput/SinglePicker.d.ts +51 -0
- package/es/PickerInput/SinglePicker.js +545 -0
- package/es/PickerInput/context.d.ts +13 -0
- package/es/PickerInput/context.js +3 -0
- package/es/PickerInput/hooks/useCellRender.d.ts +2 -0
- package/es/PickerInput/hooks/useCellRender.js +41 -0
- package/es/PickerInput/hooks/useDelayState.d.ts +5 -0
- package/es/PickerInput/hooks/useDelayState.js +48 -0
- package/es/PickerInput/hooks/useDisabledBoundary.d.ts +7 -0
- package/es/PickerInput/hooks/useDisabledBoundary.js +20 -0
- package/es/PickerInput/hooks/useFieldFormat.d.ts +2 -0
- package/es/PickerInput/hooks/useFieldFormat.js +18 -0
- package/es/PickerInput/hooks/useFieldsInvalidate.d.ts +5 -0
- package/es/PickerInput/hooks/useFieldsInvalidate.js +55 -0
- package/es/PickerInput/hooks/useFilledProps.d.ts +37 -0
- package/es/PickerInput/hooks/useFilledProps.js +155 -0
- package/es/PickerInput/hooks/useInputReadOnly.d.ts +2 -0
- package/es/PickerInput/hooks/useInputReadOnly.js +6 -0
- package/es/PickerInput/hooks/useInvalidate.d.ts +9 -0
- package/es/PickerInput/hooks/useInvalidate.js +61 -0
- package/es/PickerInput/hooks/useLockEffect.d.ts +5 -0
- package/es/PickerInput/hooks/useLockEffect.js +25 -0
- package/es/PickerInput/hooks/useOpen.d.ts +6 -0
- package/es/PickerInput/hooks/useOpen.js +33 -0
- package/es/PickerInput/hooks/usePickerRef.d.ts +7 -0
- package/es/PickerInput/hooks/usePickerRef.js +19 -0
- package/es/PickerInput/hooks/usePresets.d.ts +2 -0
- package/es/PickerInput/hooks/usePresets.js +28 -0
- package/es/PickerInput/hooks/useRangeActive.d.ts +19 -0
- package/es/PickerInput/hooks/useRangeActive.js +74 -0
- package/es/PickerInput/hooks/useRangeDisabledDate.d.ts +8 -0
- package/es/PickerInput/hooks/useRangeDisabledDate.js +53 -0
- package/es/PickerInput/hooks/useRangePickerValue.d.ts +5 -0
- package/es/PickerInput/hooks/useRangePickerValue.js +192 -0
- package/es/PickerInput/hooks/useRangeValue.d.ts +28 -0
- package/es/PickerInput/hooks/useRangeValue.js +297 -0
- package/es/PickerInput/hooks/useShowNow.d.ts +2 -0
- package/es/PickerInput/hooks/useShowNow.js +14 -0
- package/es/PickerPanel/DatePanel/index.d.ts +10 -0
- package/es/PickerPanel/DatePanel/index.js +190 -0
- package/es/PickerPanel/DateTimePanel/index.d.ts +3 -0
- package/es/PickerPanel/DateTimePanel/index.js +55 -0
- package/es/PickerPanel/DecadePanel/index.d.ts +3 -0
- package/es/PickerPanel/DecadePanel/index.js +113 -0
- package/es/PickerPanel/MonthPanel/index.d.ts +3 -0
- package/es/PickerPanel/MonthPanel/index.js +106 -0
- package/es/PickerPanel/PanelBody.d.ts +17 -0
- package/es/PickerPanel/PanelBody.js +153 -0
- package/es/PickerPanel/PanelHeader.d.ts +11 -0
- package/es/PickerPanel/PanelHeader.js +133 -0
- package/es/PickerPanel/QuarterPanel/index.d.ts +3 -0
- package/es/PickerPanel/QuarterPanel/index.js +92 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/TimeColumn.d.ts +17 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/TimeColumn.js +149 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/index.d.ts +4 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/index.js +283 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/useScrollTo.d.ts +2 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/useScrollTo.js +72 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/util.d.ts +3 -0
- package/es/PickerPanel/TimePanel/TimePanelBody/util.js +43 -0
- package/es/PickerPanel/TimePanel/index.d.ts +4 -0
- package/es/PickerPanel/TimePanel/index.js +38 -0
- package/es/PickerPanel/WeekPanel/index.d.ts +3 -0
- package/es/PickerPanel/WeekPanel/index.js +55 -0
- package/es/PickerPanel/YearPanel/index.d.ts +3 -0
- package/es/PickerPanel/YearPanel/index.js +116 -0
- package/es/PickerPanel/context.d.ts +24 -0
- package/es/PickerPanel/context.js +67 -0
- package/es/PickerPanel/index.d.ts +60 -0
- package/es/PickerPanel/index.js +315 -0
- package/es/PickerTrigger/index.d.ts +19 -0
- package/es/PickerTrigger/index.js +86 -0
- package/es/PickerTrigger/util.d.ts +2 -0
- package/es/PickerTrigger/util.js +4 -0
- package/es/generate/dateFns.d.ts +3 -0
- package/es/generate/dateFns.js +163 -0
- package/es/generate/dayjs.d.ts +4 -0
- package/es/generate/dayjs.js +233 -0
- package/es/generate/index.d.ts +37 -0
- package/es/generate/index.js +1 -0
- package/es/generate/luxon.d.ts +4 -0
- package/es/generate/luxon.js +197 -0
- package/es/generate/moment.d.ts +4 -0
- package/es/generate/moment.js +152 -0
- package/es/hooks/useLocale.d.ts +6 -0
- package/es/hooks/useLocale.js +82 -0
- package/es/hooks/useSyncState.d.ts +6 -0
- package/es/hooks/useSyncState.js +27 -0
- package/es/hooks/useTimeConfig.d.ts +18 -0
- package/es/hooks/useTimeConfig.js +166 -0
- package/es/hooks/useTimeInfo.d.ts +12 -0
- package/es/hooks/useTimeInfo.js +164 -0
- package/es/hooks/useToggleDates.d.ts +8 -0
- package/es/hooks/useToggleDates.js +26 -0
- package/es/index.d.ts +35 -0
- package/es/index.js +34 -0
- package/es/interface.d.ts +365 -0
- package/es/interface.js +1 -0
- package/es/locale/am_ET.d.ts +3 -0
- package/es/locale/am_ET.js +31 -0
- package/es/locale/ar_EG.d.ts +3 -0
- package/es/locale/ar_EG.js +34 -0
- package/es/locale/az_AZ.d.ts +3 -0
- package/es/locale/az_AZ.js +35 -0
- package/es/locale/bg_BG.d.ts +3 -0
- package/es/locale/bg_BG.js +34 -0
- package/es/locale/bn_BD.d.ts +3 -0
- package/es/locale/bn_BD.js +35 -0
- package/es/locale/by_BY.d.ts +3 -0
- package/es/locale/by_BY.js +35 -0
- package/es/locale/ca_ES.d.ts +3 -0
- package/es/locale/ca_ES.js +34 -0
- package/es/locale/common.d.ts +2 -0
- package/es/locale/common.js +6 -0
- package/es/locale/cs_CZ.d.ts +3 -0
- package/es/locale/cs_CZ.js +34 -0
- package/es/locale/da_DK.d.ts +3 -0
- package/es/locale/da_DK.js +34 -0
- package/es/locale/de_DE.d.ts +3 -0
- package/es/locale/de_DE.js +34 -0
- package/es/locale/el_GR.d.ts +3 -0
- package/es/locale/el_GR.js +34 -0
- package/es/locale/en_GB.d.ts +3 -0
- package/es/locale/en_GB.js +34 -0
- package/es/locale/en_US.d.ts +3 -0
- package/es/locale/en_US.js +35 -0
- package/es/locale/es_ES.d.ts +3 -0
- package/es/locale/es_ES.js +34 -0
- package/es/locale/es_MX.d.ts +3 -0
- package/es/locale/es_MX.js +35 -0
- package/es/locale/et_EE.d.ts +3 -0
- package/es/locale/et_EE.js +34 -0
- package/es/locale/eu_ES.d.ts +3 -0
- package/es/locale/eu_ES.js +36 -0
- package/es/locale/fa_IR.d.ts +3 -0
- package/es/locale/fa_IR.js +34 -0
- package/es/locale/fi_FI.d.ts +3 -0
- package/es/locale/fi_FI.js +34 -0
- package/es/locale/fr_BE.d.ts +3 -0
- package/es/locale/fr_BE.js +34 -0
- package/es/locale/fr_CA.d.ts +3 -0
- package/es/locale/fr_CA.js +35 -0
- package/es/locale/fr_FR.d.ts +3 -0
- package/es/locale/fr_FR.js +35 -0
- package/es/locale/ga_IE.d.ts +3 -0
- package/es/locale/ga_IE.js +35 -0
- package/es/locale/gl_ES.d.ts +3 -0
- package/es/locale/gl_ES.js +34 -0
- package/es/locale/he_IL.d.ts +3 -0
- package/es/locale/he_IL.js +35 -0
- package/es/locale/hi_IN.d.ts +3 -0
- package/es/locale/hi_IN.js +35 -0
- package/es/locale/hr_HR.d.ts +3 -0
- package/es/locale/hr_HR.js +35 -0
- package/es/locale/hu_HU.d.ts +3 -0
- package/es/locale/hu_HU.js +58 -0
- package/es/locale/id_ID.d.ts +3 -0
- package/es/locale/id_ID.js +35 -0
- package/es/locale/is_IS.d.ts +3 -0
- package/es/locale/is_IS.js +34 -0
- package/es/locale/it_IT.d.ts +3 -0
- package/es/locale/it_IT.js +34 -0
- package/es/locale/ja_JP.d.ts +3 -0
- package/es/locale/ja_JP.js +37 -0
- package/es/locale/ka_GE.d.ts +3 -0
- package/es/locale/ka_GE.js +35 -0
- package/es/locale/kk_KZ.d.ts +3 -0
- package/es/locale/kk_KZ.js +34 -0
- package/es/locale/km_KH.d.ts +3 -0
- package/es/locale/km_KH.js +36 -0
- package/es/locale/kmr_IQ.d.ts +3 -0
- package/es/locale/kmr_IQ.js +34 -0
- package/es/locale/kn_IN.d.ts +3 -0
- package/es/locale/kn_IN.js +35 -0
- package/es/locale/ko_KR.d.ts +3 -0
- package/es/locale/ko_KR.js +36 -0
- package/es/locale/lt_LT.d.ts +3 -0
- package/es/locale/lt_LT.js +36 -0
- package/es/locale/lv_LV.d.ts +3 -0
- package/es/locale/lv_LV.js +34 -0
- package/es/locale/mk_MK.d.ts +3 -0
- package/es/locale/mk_MK.js +34 -0
- package/es/locale/ml_IN.d.ts +3 -0
- package/es/locale/ml_IN.js +35 -0
- package/es/locale/mn_MN.d.ts +3 -0
- package/es/locale/mn_MN.js +36 -0
- package/es/locale/ms_MY.d.ts +3 -0
- package/es/locale/ms_MY.js +36 -0
- package/es/locale/my_MM.d.ts +3 -0
- package/es/locale/my_MM.js +35 -0
- package/es/locale/nb_NO.d.ts +3 -0
- package/es/locale/nb_NO.js +36 -0
- package/es/locale/ne_NP.d.ts +3 -0
- package/es/locale/ne_NP.js +35 -0
- package/es/locale/nl_BE.d.ts +3 -0
- package/es/locale/nl_BE.js +34 -0
- package/es/locale/nl_NL.d.ts +3 -0
- package/es/locale/nl_NL.js +34 -0
- package/es/locale/pl_PL.d.ts +3 -0
- package/es/locale/pl_PL.js +34 -0
- package/es/locale/pt_BR.d.ts +3 -0
- package/es/locale/pt_BR.js +37 -0
- package/es/locale/pt_PT.d.ts +3 -0
- package/es/locale/pt_PT.js +36 -0
- package/es/locale/ro_RO.d.ts +3 -0
- package/es/locale/ro_RO.js +35 -0
- package/es/locale/ru_RU.d.ts +3 -0
- package/es/locale/ru_RU.js +34 -0
- package/es/locale/si_LK.d.ts +3 -0
- package/es/locale/si_LK.js +36 -0
- package/es/locale/sk_SK.d.ts +3 -0
- package/es/locale/sk_SK.js +34 -0
- package/es/locale/sl_SI.d.ts +3 -0
- package/es/locale/sl_SI.js +34 -0
- package/es/locale/sr_Cyrl_RS.d.ts +3 -0
- package/es/locale/sr_Cyrl_RS.js +34 -0
- package/es/locale/sr_RS.d.ts +3 -0
- package/es/locale/sr_RS.js +34 -0
- package/es/locale/sv_SE.d.ts +3 -0
- package/es/locale/sv_SE.js +34 -0
- package/es/locale/ta_IN.d.ts +3 -0
- package/es/locale/ta_IN.js +35 -0
- package/es/locale/th_TH.d.ts +3 -0
- package/es/locale/th_TH.js +34 -0
- package/es/locale/tk_TK.d.ts +3 -0
- package/es/locale/tk_TK.js +34 -0
- package/es/locale/tr_TR.d.ts +3 -0
- package/es/locale/tr_TR.js +36 -0
- package/es/locale/ug_CN.d.ts +3 -0
- package/es/locale/ug_CN.js +37 -0
- package/es/locale/uk_UA.d.ts +3 -0
- package/es/locale/uk_UA.js +34 -0
- package/es/locale/ur_PK.d.ts +3 -0
- package/es/locale/ur_PK.js +35 -0
- package/es/locale/uz_UZ.d.ts +3 -0
- package/es/locale/uz_UZ.js +35 -0
- package/es/locale/vi_VN.d.ts +3 -0
- package/es/locale/vi_VN.js +35 -0
- package/es/locale/zh_CN.d.ts +3 -0
- package/es/locale/zh_CN.js +36 -0
- package/es/locale/zh_TW.d.ts +3 -0
- package/es/locale/zh_TW.js +38 -0
- package/es/utils/dateUtil.d.ts +29 -0
- package/es/utils/dateUtil.js +140 -0
- package/es/utils/getClearIcon.d.ts +5 -0
- package/es/utils/getClearIcon.js +8 -0
- package/es/utils/miscUtil.d.ts +14 -0
- package/es/utils/miscUtil.js +70 -0
- package/es/utils/uiUtil.d.ts +1 -0
- package/es/utils/uiUtil.js +7 -0
- package/es/utils/warnUtil.d.ts +5 -0
- package/es/utils/warnUtil.js +10 -0
- package/lib/PickerInput/Popup/Footer.d.ts +19 -0
- package/lib/PickerInput/Popup/Footer.js +88 -0
- package/lib/PickerInput/Popup/PopupPanel.d.ts +10 -0
- package/lib/PickerInput/Popup/PopupPanel.js +93 -0
- package/lib/PickerInput/Popup/PresetPanel.d.ts +9 -0
- package/lib/PickerInput/Popup/PresetPanel.js +40 -0
- package/lib/PickerInput/Popup/index.d.ts +20 -0
- package/lib/PickerInput/Popup/index.js +207 -0
- package/lib/PickerInput/RangePicker.d.ts +54 -0
- package/lib/PickerInput/RangePicker.js +650 -0
- package/lib/PickerInput/Selector/Icon.d.ts +10 -0
- package/lib/PickerInput/Selector/Icon.js +43 -0
- package/lib/PickerInput/Selector/Input.d.ts +28 -0
- package/lib/PickerInput/Selector/Input.js +385 -0
- package/lib/PickerInput/Selector/MaskFormat.d.ts +22 -0
- package/lib/PickerInput/Selector/MaskFormat.js +112 -0
- package/lib/PickerInput/Selector/RangeSelector.d.ts +26 -0
- package/lib/PickerInput/Selector/RangeSelector.js +227 -0
- package/lib/PickerInput/Selector/SingleSelector/MultipleDates.d.ts +12 -0
- package/lib/PickerInput/Selector/SingleSelector/MultipleDates.js +76 -0
- package/lib/PickerInput/Selector/SingleSelector/index.d.ts +18 -0
- package/lib/PickerInput/Selector/SingleSelector/index.js +196 -0
- package/lib/PickerInput/Selector/hooks/useClearIcon.d.ts +8 -0
- package/lib/PickerInput/Selector/hooks/useClearIcon.js +27 -0
- package/lib/PickerInput/Selector/hooks/useInputProps.d.ts +16 -0
- package/lib/PickerInput/Selector/hooks/useInputProps.js +187 -0
- package/lib/PickerInput/Selector/hooks/useRootProps.d.ts +2 -0
- package/lib/PickerInput/Selector/hooks/useRootProps.js +17 -0
- package/lib/PickerInput/Selector/util.d.ts +1 -0
- package/lib/PickerInput/Selector/util.js +18 -0
- package/lib/PickerInput/SinglePicker.d.ts +51 -0
- package/lib/PickerInput/SinglePicker.js +553 -0
- package/lib/PickerInput/context.d.ts +13 -0
- package/lib/PickerInput/context.js +12 -0
- package/lib/PickerInput/hooks/useCellRender.d.ts +2 -0
- package/lib/PickerInput/hooks/useCellRender.js +49 -0
- package/lib/PickerInput/hooks/useDelayState.d.ts +5 -0
- package/lib/PickerInput/hooks/useDelayState.js +54 -0
- package/lib/PickerInput/hooks/useDisabledBoundary.d.ts +7 -0
- package/lib/PickerInput/hooks/useDisabledBoundary.js +26 -0
- package/lib/PickerInput/hooks/useFieldFormat.d.ts +2 -0
- package/lib/PickerInput/hooks/useFieldFormat.js +26 -0
- package/lib/PickerInput/hooks/useFieldsInvalidate.d.ts +5 -0
- package/lib/PickerInput/hooks/useFieldsInvalidate.js +64 -0
- package/lib/PickerInput/hooks/useFilledProps.d.ts +37 -0
- package/lib/PickerInput/hooks/useFilledProps.js +164 -0
- package/lib/PickerInput/hooks/useInputReadOnly.d.ts +2 -0
- package/lib/PickerInput/hooks/useInputReadOnly.js +12 -0
- package/lib/PickerInput/hooks/useInvalidate.d.ts +9 -0
- package/lib/PickerInput/hooks/useInvalidate.js +67 -0
- package/lib/PickerInput/hooks/useLockEffect.d.ts +5 -0
- package/lib/PickerInput/hooks/useLockEffect.js +34 -0
- package/lib/PickerInput/hooks/useOpen.d.ts +6 -0
- package/lib/PickerInput/hooks/useOpen.js +39 -0
- package/lib/PickerInput/hooks/usePickerRef.d.ts +7 -0
- package/lib/PickerInput/hooks/usePickerRef.js +28 -0
- package/lib/PickerInput/hooks/usePresets.d.ts +2 -0
- package/lib/PickerInput/hooks/usePresets.js +38 -0
- package/lib/PickerInput/hooks/useRangeActive.d.ts +19 -0
- package/lib/PickerInput/hooks/useRangeActive.js +84 -0
- package/lib/PickerInput/hooks/useRangeDisabledDate.d.ts +8 -0
- package/lib/PickerInput/hooks/useRangeDisabledDate.js +58 -0
- package/lib/PickerInput/hooks/useRangePickerValue.d.ts +5 -0
- package/lib/PickerInput/hooks/useRangePickerValue.js +203 -0
- package/lib/PickerInput/hooks/useRangeValue.d.ts +28 -0
- package/lib/PickerInput/hooks/useRangeValue.js +308 -0
- package/lib/PickerInput/hooks/useShowNow.d.ts +2 -0
- package/lib/PickerInput/hooks/useShowNow.js +20 -0
- package/lib/PickerPanel/DatePanel/index.d.ts +10 -0
- package/lib/PickerPanel/DatePanel/index.js +199 -0
- package/lib/PickerPanel/DateTimePanel/index.d.ts +3 -0
- package/lib/PickerPanel/DateTimePanel/index.js +65 -0
- package/lib/PickerPanel/DecadePanel/index.d.ts +3 -0
- package/lib/PickerPanel/DecadePanel/index.js +122 -0
- package/lib/PickerPanel/MonthPanel/index.d.ts +3 -0
- package/lib/PickerPanel/MonthPanel/index.js +115 -0
- package/lib/PickerPanel/PanelBody.d.ts +17 -0
- package/lib/PickerPanel/PanelBody.js +162 -0
- package/lib/PickerPanel/PanelHeader.d.ts +11 -0
- package/lib/PickerPanel/PanelHeader.js +143 -0
- package/lib/PickerPanel/QuarterPanel/index.d.ts +3 -0
- package/lib/PickerPanel/QuarterPanel/index.js +101 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/TimeColumn.d.ts +17 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/TimeColumn.js +158 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/index.d.ts +4 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/index.js +293 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/useScrollTo.d.ts +2 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/useScrollTo.js +82 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/util.d.ts +3 -0
- package/lib/PickerPanel/TimePanel/TimePanelBody/util.js +49 -0
- package/lib/PickerPanel/TimePanel/index.d.ts +4 -0
- package/lib/PickerPanel/TimePanel/index.js +48 -0
- package/lib/PickerPanel/WeekPanel/index.d.ts +3 -0
- package/lib/PickerPanel/WeekPanel/index.js +64 -0
- package/lib/PickerPanel/YearPanel/index.d.ts +3 -0
- package/lib/PickerPanel/YearPanel/index.js +125 -0
- package/lib/PickerPanel/context.d.ts +24 -0
- package/lib/PickerPanel/context.js +78 -0
- package/lib/PickerPanel/index.d.ts +60 -0
- package/lib/PickerPanel/index.js +324 -0
- package/lib/PickerTrigger/index.d.ts +19 -0
- package/lib/PickerTrigger/index.js +95 -0
- package/lib/PickerTrigger/util.d.ts +2 -0
- package/lib/PickerTrigger/util.js +10 -0
- package/lib/generate/dateFns.d.ts +3 -0
- package/lib/generate/dateFns.js +172 -0
- package/lib/generate/dayjs.d.ts +4 -0
- package/lib/generate/dayjs.js +240 -0
- package/lib/generate/index.d.ts +37 -0
- package/lib/generate/index.js +5 -0
- package/lib/generate/luxon.d.ts +4 -0
- package/lib/generate/luxon.js +203 -0
- package/lib/generate/moment.d.ts +4 -0
- package/lib/generate/moment.js +159 -0
- package/lib/hooks/useLocale.d.ts +6 -0
- package/lib/hooks/useLocale.js +90 -0
- package/lib/hooks/useSyncState.d.ts +6 -0
- package/lib/hooks/useSyncState.js +35 -0
- package/lib/hooks/useTimeConfig.d.ts +18 -0
- package/lib/hooks/useTimeConfig.js +173 -0
- package/lib/hooks/useTimeInfo.d.ts +12 -0
- package/lib/hooks/useTimeInfo.js +172 -0
- package/lib/hooks/useToggleDates.d.ts +8 -0
- package/lib/hooks/useToggleDates.js +32 -0
- package/lib/index.d.ts +35 -0
- package/lib/index.js +57 -0
- package/lib/interface.d.ts +365 -0
- package/lib/interface.js +5 -0
- package/lib/locale/am_ET.d.ts +3 -0
- package/lib/locale/am_ET.js +37 -0
- package/lib/locale/ar_EG.d.ts +3 -0
- package/lib/locale/ar_EG.js +40 -0
- package/lib/locale/az_AZ.d.ts +3 -0
- package/lib/locale/az_AZ.js +41 -0
- package/lib/locale/bg_BG.d.ts +3 -0
- package/lib/locale/bg_BG.js +40 -0
- package/lib/locale/bn_BD.d.ts +3 -0
- package/lib/locale/bn_BD.js +41 -0
- package/lib/locale/by_BY.d.ts +3 -0
- package/lib/locale/by_BY.js +41 -0
- package/lib/locale/ca_ES.d.ts +3 -0
- package/lib/locale/ca_ES.js +40 -0
- package/lib/locale/common.d.ts +2 -0
- package/lib/locale/common.js +12 -0
- package/lib/locale/cs_CZ.d.ts +3 -0
- package/lib/locale/cs_CZ.js +40 -0
- package/lib/locale/da_DK.d.ts +3 -0
- package/lib/locale/da_DK.js +40 -0
- package/lib/locale/de_DE.d.ts +3 -0
- package/lib/locale/de_DE.js +40 -0
- package/lib/locale/el_GR.d.ts +3 -0
- package/lib/locale/el_GR.js +40 -0
- package/lib/locale/en_GB.d.ts +3 -0
- package/lib/locale/en_GB.js +40 -0
- package/lib/locale/en_US.d.ts +3 -0
- package/lib/locale/en_US.js +41 -0
- package/lib/locale/es_ES.d.ts +3 -0
- package/lib/locale/es_ES.js +40 -0
- package/lib/locale/es_MX.d.ts +3 -0
- package/lib/locale/es_MX.js +41 -0
- package/lib/locale/et_EE.d.ts +3 -0
- package/lib/locale/et_EE.js +40 -0
- package/lib/locale/eu_ES.d.ts +3 -0
- package/lib/locale/eu_ES.js +42 -0
- package/lib/locale/fa_IR.d.ts +3 -0
- package/lib/locale/fa_IR.js +40 -0
- package/lib/locale/fi_FI.d.ts +3 -0
- package/lib/locale/fi_FI.js +40 -0
- package/lib/locale/fr_BE.d.ts +3 -0
- package/lib/locale/fr_BE.js +40 -0
- package/lib/locale/fr_CA.d.ts +3 -0
- package/lib/locale/fr_CA.js +41 -0
- package/lib/locale/fr_FR.d.ts +3 -0
- package/lib/locale/fr_FR.js +41 -0
- package/lib/locale/ga_IE.d.ts +3 -0
- package/lib/locale/ga_IE.js +41 -0
- package/lib/locale/gl_ES.d.ts +3 -0
- package/lib/locale/gl_ES.js +40 -0
- package/lib/locale/he_IL.d.ts +3 -0
- package/lib/locale/he_IL.js +41 -0
- package/lib/locale/hi_IN.d.ts +3 -0
- package/lib/locale/hi_IN.js +41 -0
- package/lib/locale/hr_HR.d.ts +3 -0
- package/lib/locale/hr_HR.js +41 -0
- package/lib/locale/hu_HU.d.ts +3 -0
- package/lib/locale/hu_HU.js +64 -0
- package/lib/locale/id_ID.d.ts +3 -0
- package/lib/locale/id_ID.js +41 -0
- package/lib/locale/is_IS.d.ts +3 -0
- package/lib/locale/is_IS.js +40 -0
- package/lib/locale/it_IT.d.ts +3 -0
- package/lib/locale/it_IT.js +40 -0
- package/lib/locale/ja_JP.d.ts +3 -0
- package/lib/locale/ja_JP.js +43 -0
- package/lib/locale/ka_GE.d.ts +3 -0
- package/lib/locale/ka_GE.js +41 -0
- package/lib/locale/kk_KZ.d.ts +3 -0
- package/lib/locale/kk_KZ.js +40 -0
- package/lib/locale/km_KH.d.ts +3 -0
- package/lib/locale/km_KH.js +42 -0
- package/lib/locale/kmr_IQ.d.ts +3 -0
- package/lib/locale/kmr_IQ.js +40 -0
- package/lib/locale/kn_IN.d.ts +3 -0
- package/lib/locale/kn_IN.js +41 -0
- package/lib/locale/ko_KR.d.ts +3 -0
- package/lib/locale/ko_KR.js +42 -0
- package/lib/locale/lt_LT.d.ts +3 -0
- package/lib/locale/lt_LT.js +42 -0
- package/lib/locale/lv_LV.d.ts +3 -0
- package/lib/locale/lv_LV.js +40 -0
- package/lib/locale/mk_MK.d.ts +3 -0
- package/lib/locale/mk_MK.js +40 -0
- package/lib/locale/ml_IN.d.ts +3 -0
- package/lib/locale/ml_IN.js +41 -0
- package/lib/locale/mn_MN.d.ts +3 -0
- package/lib/locale/mn_MN.js +42 -0
- package/lib/locale/ms_MY.d.ts +3 -0
- package/lib/locale/ms_MY.js +42 -0
- package/lib/locale/my_MM.d.ts +3 -0
- package/lib/locale/my_MM.js +41 -0
- package/lib/locale/nb_NO.d.ts +3 -0
- package/lib/locale/nb_NO.js +42 -0
- package/lib/locale/ne_NP.d.ts +3 -0
- package/lib/locale/ne_NP.js +41 -0
- package/lib/locale/nl_BE.d.ts +3 -0
- package/lib/locale/nl_BE.js +40 -0
- package/lib/locale/nl_NL.d.ts +3 -0
- package/lib/locale/nl_NL.js +40 -0
- package/lib/locale/pl_PL.d.ts +3 -0
- package/lib/locale/pl_PL.js +40 -0
- package/lib/locale/pt_BR.d.ts +3 -0
- package/lib/locale/pt_BR.js +43 -0
- package/lib/locale/pt_PT.d.ts +3 -0
- package/lib/locale/pt_PT.js +42 -0
- package/lib/locale/ro_RO.d.ts +3 -0
- package/lib/locale/ro_RO.js +41 -0
- package/lib/locale/ru_RU.d.ts +3 -0
- package/lib/locale/ru_RU.js +40 -0
- package/lib/locale/si_LK.d.ts +3 -0
- package/lib/locale/si_LK.js +42 -0
- package/lib/locale/sk_SK.d.ts +3 -0
- package/lib/locale/sk_SK.js +40 -0
- package/lib/locale/sl_SI.d.ts +3 -0
- package/lib/locale/sl_SI.js +40 -0
- package/lib/locale/sr_Cyrl_RS.d.ts +3 -0
- package/lib/locale/sr_Cyrl_RS.js +40 -0
- package/lib/locale/sr_RS.d.ts +3 -0
- package/lib/locale/sr_RS.js +40 -0
- package/lib/locale/sv_SE.d.ts +3 -0
- package/lib/locale/sv_SE.js +40 -0
- package/lib/locale/ta_IN.d.ts +3 -0
- package/lib/locale/ta_IN.js +41 -0
- package/lib/locale/th_TH.d.ts +3 -0
- package/lib/locale/th_TH.js +40 -0
- package/lib/locale/tk_TK.d.ts +3 -0
- package/lib/locale/tk_TK.js +40 -0
- package/lib/locale/tr_TR.d.ts +3 -0
- package/lib/locale/tr_TR.js +42 -0
- package/lib/locale/ug_CN.d.ts +3 -0
- package/lib/locale/ug_CN.js +43 -0
- package/lib/locale/uk_UA.d.ts +3 -0
- package/lib/locale/uk_UA.js +40 -0
- package/lib/locale/ur_PK.d.ts +3 -0
- package/lib/locale/ur_PK.js +41 -0
- package/lib/locale/uz_UZ.d.ts +3 -0
- package/lib/locale/uz_UZ.js +41 -0
- package/lib/locale/vi_VN.d.ts +3 -0
- package/lib/locale/vi_VN.js +41 -0
- package/lib/locale/zh_CN.d.ts +3 -0
- package/lib/locale/zh_CN.js +42 -0
- package/lib/locale/zh_TW.d.ts +3 -0
- package/lib/locale/zh_TW.js +44 -0
- package/lib/utils/dateUtil.d.ts +29 -0
- package/lib/utils/dateUtil.js +161 -0
- package/lib/utils/getClearIcon.d.ts +5 -0
- package/lib/utils/getClearIcon.js +15 -0
- package/lib/utils/miscUtil.d.ts +14 -0
- package/lib/utils/miscUtil.js +81 -0
- package/lib/utils/uiUtil.d.ts +1 -0
- package/lib/utils/uiUtil.js +13 -0
- package/lib/utils/warnUtil.d.ts +5 -0
- package/lib/utils/warnUtil.js +17 -0
- package/package.json +107 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
5
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
|
6
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
7
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
8
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
9
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
10
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
11
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
12
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
13
|
+
import { isSame } from "../../utils/dateUtil";
|
|
14
|
+
import { getFromDate } from "../../utils/miscUtil";
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* RangePicker need additional logic to handle the `disabled` case. e.g.
|
|
18
|
+
* [disabled, enabled] should end date not before start date
|
|
19
|
+
*/
|
|
20
|
+
export default function useRangeDisabledDate(values, disabled, activeIndexList, generateConfig, locale, disabledDate) {
|
|
21
|
+
var activeIndex = activeIndexList[activeIndexList.length - 1];
|
|
22
|
+
var rangeDisabledDate = function rangeDisabledDate(date, info) {
|
|
23
|
+
var _values = _slicedToArray(values, 2),
|
|
24
|
+
start = _values[0],
|
|
25
|
+
end = _values[1];
|
|
26
|
+
var mergedInfo = _objectSpread(_objectSpread({}, info), {}, {
|
|
27
|
+
from: getFromDate(values, activeIndexList)
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
// ============================ Disabled ============================
|
|
31
|
+
// Should not select days before the start date
|
|
32
|
+
if (activeIndex === 1 && disabled[0] && start &&
|
|
33
|
+
// Same date isOK
|
|
34
|
+
!isSame(generateConfig, locale, start, date, mergedInfo.type) &&
|
|
35
|
+
// Before start date
|
|
36
|
+
generateConfig.isAfter(start, date)) {
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// Should not select days after the end date
|
|
41
|
+
if (activeIndex === 0 && disabled[1] && end &&
|
|
42
|
+
// Same date isOK
|
|
43
|
+
!isSame(generateConfig, locale, end, date, mergedInfo.type) &&
|
|
44
|
+
// After end date
|
|
45
|
+
generateConfig.isAfter(date, end)) {
|
|
46
|
+
return true;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// ============================= Origin =============================
|
|
50
|
+
return disabledDate === null || disabledDate === void 0 ? void 0 : disabledDate(date, mergedInfo);
|
|
51
|
+
};
|
|
52
|
+
return rangeDisabledDate;
|
|
53
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { GenerateConfig } from '../../generate';
|
|
2
|
+
import type { InternalMode, Locale, PanelMode } from '../../interface';
|
|
3
|
+
import type { RangePickerProps } from '../RangePicker';
|
|
4
|
+
export declare function offsetPanelDate<DateType = any>(generateConfig: GenerateConfig<DateType>, picker: InternalMode, date: DateType, offset: number): DateType;
|
|
5
|
+
export default function useRangePickerValue<DateType extends object, ValueType extends DateType[]>(generateConfig: GenerateConfig<DateType>, locale: Locale, calendarValue: ValueType, modes: PanelMode[], open: boolean, activeIndex: number, pickerMode: InternalMode, multiplePanel: boolean, defaultPickerValue?: ValueType, pickerValue?: ValueType, timeDefaultValue?: ValueType, onPickerValueChange?: RangePickerProps<DateType>['onPickerValueChange'], minDate?: DateType, maxDate?: DateType): [currentIndexPickerValue: DateType, setCurrentIndexPickerValue: (value: DateType) => void];
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
2
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
4
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
5
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
6
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
7
|
+
import { useMergedState } from '@rc-component/util';
|
|
8
|
+
import useLayoutEffect from "@rc-component/util/es/hooks/useLayoutEffect";
|
|
9
|
+
import * as React from 'react';
|
|
10
|
+
import { fillTime, isSame } from "../../utils/dateUtil";
|
|
11
|
+
export function offsetPanelDate(generateConfig, picker, date, offset) {
|
|
12
|
+
switch (picker) {
|
|
13
|
+
case 'date':
|
|
14
|
+
case 'week':
|
|
15
|
+
return generateConfig.addMonth(date, offset);
|
|
16
|
+
case 'month':
|
|
17
|
+
case 'quarter':
|
|
18
|
+
return generateConfig.addYear(date, offset);
|
|
19
|
+
case 'year':
|
|
20
|
+
return generateConfig.addYear(date, offset * 10);
|
|
21
|
+
case 'decade':
|
|
22
|
+
return generateConfig.addYear(date, offset * 100);
|
|
23
|
+
default:
|
|
24
|
+
return date;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
var EMPTY_LIST = [];
|
|
28
|
+
export default function useRangePickerValue(generateConfig, locale, calendarValue, modes, open, activeIndex, pickerMode, multiplePanel) {
|
|
29
|
+
var defaultPickerValue = arguments.length > 8 && arguments[8] !== undefined ? arguments[8] : EMPTY_LIST;
|
|
30
|
+
var pickerValue = arguments.length > 9 && arguments[9] !== undefined ? arguments[9] : EMPTY_LIST;
|
|
31
|
+
var timeDefaultValue = arguments.length > 10 && arguments[10] !== undefined ? arguments[10] : EMPTY_LIST;
|
|
32
|
+
var onPickerValueChange = arguments.length > 11 ? arguments[11] : undefined;
|
|
33
|
+
var minDate = arguments.length > 12 ? arguments[12] : undefined;
|
|
34
|
+
var maxDate = arguments.length > 13 ? arguments[13] : undefined;
|
|
35
|
+
var isTimePicker = pickerMode === 'time';
|
|
36
|
+
|
|
37
|
+
// ======================== Active ========================
|
|
38
|
+
// `activeIndex` must be valid to avoid getting empty `pickerValue`
|
|
39
|
+
var mergedActiveIndex = activeIndex || 0;
|
|
40
|
+
|
|
41
|
+
// ===================== Picker Value =====================
|
|
42
|
+
var getDefaultPickerValue = function getDefaultPickerValue(index) {
|
|
43
|
+
var now = generateConfig.getNow();
|
|
44
|
+
if (isTimePicker) {
|
|
45
|
+
now = fillTime(generateConfig, now);
|
|
46
|
+
}
|
|
47
|
+
return defaultPickerValue[index] || calendarValue[index] || now;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
// Align `pickerValue` with `showTime.defaultValue`
|
|
51
|
+
var _pickerValue = _slicedToArray(pickerValue, 2),
|
|
52
|
+
startPickerValue = _pickerValue[0],
|
|
53
|
+
endPickerValue = _pickerValue[1];
|
|
54
|
+
|
|
55
|
+
// PickerValue state
|
|
56
|
+
var _useMergedState = useMergedState(function () {
|
|
57
|
+
return getDefaultPickerValue(0);
|
|
58
|
+
}, {
|
|
59
|
+
value: startPickerValue
|
|
60
|
+
}),
|
|
61
|
+
_useMergedState2 = _slicedToArray(_useMergedState, 2),
|
|
62
|
+
mergedStartPickerValue = _useMergedState2[0],
|
|
63
|
+
setStartPickerValue = _useMergedState2[1];
|
|
64
|
+
var _useMergedState3 = useMergedState(function () {
|
|
65
|
+
return getDefaultPickerValue(1);
|
|
66
|
+
}, {
|
|
67
|
+
value: endPickerValue
|
|
68
|
+
}),
|
|
69
|
+
_useMergedState4 = _slicedToArray(_useMergedState3, 2),
|
|
70
|
+
mergedEndPickerValue = _useMergedState4[0],
|
|
71
|
+
setEndPickerValue = _useMergedState4[1];
|
|
72
|
+
|
|
73
|
+
// Current PickerValue
|
|
74
|
+
var currentPickerValue = React.useMemo(function () {
|
|
75
|
+
var current = [mergedStartPickerValue, mergedEndPickerValue][mergedActiveIndex];
|
|
76
|
+
|
|
77
|
+
// Merge the `showTime.defaultValue` into `pickerValue`
|
|
78
|
+
return isTimePicker ? current : fillTime(generateConfig, current, timeDefaultValue[mergedActiveIndex]);
|
|
79
|
+
}, [isTimePicker, mergedStartPickerValue, mergedEndPickerValue, mergedActiveIndex, generateConfig, timeDefaultValue]);
|
|
80
|
+
var setCurrentPickerValue = function setCurrentPickerValue(nextPickerValue) {
|
|
81
|
+
var source = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'panel';
|
|
82
|
+
var updater = [setStartPickerValue, setEndPickerValue][mergedActiveIndex];
|
|
83
|
+
updater(nextPickerValue);
|
|
84
|
+
var clone = [mergedStartPickerValue, mergedEndPickerValue];
|
|
85
|
+
clone[mergedActiveIndex] = nextPickerValue;
|
|
86
|
+
if (onPickerValueChange && (!isSame(generateConfig, locale, mergedStartPickerValue, clone[0], pickerMode) || !isSame(generateConfig, locale, mergedEndPickerValue, clone[1], pickerMode))) {
|
|
87
|
+
onPickerValueChange(clone, {
|
|
88
|
+
source: source,
|
|
89
|
+
range: mergedActiveIndex === 1 ? 'end' : 'start',
|
|
90
|
+
mode: modes
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
// ======================== Effect ========================
|
|
96
|
+
/**
|
|
97
|
+
* EndDate pickerValue is little different. It should be:
|
|
98
|
+
* - If date picker (without time), endDate is not same year & month as startDate
|
|
99
|
+
* - pickerValue minus one month
|
|
100
|
+
* - Else pass directly
|
|
101
|
+
*/
|
|
102
|
+
var getEndDatePickerValue = function getEndDatePickerValue(startDate, endDate) {
|
|
103
|
+
if (multiplePanel) {
|
|
104
|
+
// Basic offset
|
|
105
|
+
var SAME_CHECKER = {
|
|
106
|
+
date: 'month',
|
|
107
|
+
week: 'month',
|
|
108
|
+
month: 'year',
|
|
109
|
+
quarter: 'year'
|
|
110
|
+
};
|
|
111
|
+
var mode = SAME_CHECKER[pickerMode];
|
|
112
|
+
if (mode && !isSame(generateConfig, locale, startDate, endDate, mode)) {
|
|
113
|
+
return offsetPanelDate(generateConfig, pickerMode, endDate, -1);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// Year offset
|
|
117
|
+
if (pickerMode === 'year' && startDate) {
|
|
118
|
+
var srcYear = Math.floor(generateConfig.getYear(startDate) / 10);
|
|
119
|
+
var tgtYear = Math.floor(generateConfig.getYear(endDate) / 10);
|
|
120
|
+
if (srcYear !== tgtYear) {
|
|
121
|
+
return offsetPanelDate(generateConfig, pickerMode, endDate, -1);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
return endDate;
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
// >>> When switch field, reset the picker value as prev field picker value
|
|
129
|
+
var prevActiveIndexRef = React.useRef(null);
|
|
130
|
+
useLayoutEffect(function () {
|
|
131
|
+
if (open) {
|
|
132
|
+
if (!defaultPickerValue[mergedActiveIndex]) {
|
|
133
|
+
var nextPickerValue = isTimePicker ? null : generateConfig.getNow();
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* 1. If has prevActiveIndex, use it to avoid panel jump
|
|
137
|
+
* 2. If current field has value
|
|
138
|
+
* - If `activeIndex` is 1 and `calendarValue[0]` is not same panel as `calendarValue[1]`,
|
|
139
|
+
* offset `calendarValue[1]` and set it
|
|
140
|
+
* - Else use `calendarValue[activeIndex]`
|
|
141
|
+
* 3. If current field has no value but another field has value, use another field value
|
|
142
|
+
* 4. Else use now (not any `calendarValue` can ref)
|
|
143
|
+
*/
|
|
144
|
+
|
|
145
|
+
if (prevActiveIndexRef.current !== null && prevActiveIndexRef.current !== mergedActiveIndex) {
|
|
146
|
+
// If from another field, not jump picker value
|
|
147
|
+
nextPickerValue = [mergedStartPickerValue, mergedEndPickerValue][mergedActiveIndex ^ 1];
|
|
148
|
+
} else if (calendarValue[mergedActiveIndex]) {
|
|
149
|
+
// Current field has value
|
|
150
|
+
nextPickerValue = mergedActiveIndex === 0 ? calendarValue[0] : getEndDatePickerValue(calendarValue[0], calendarValue[1]);
|
|
151
|
+
} else if (calendarValue[mergedActiveIndex ^ 1]) {
|
|
152
|
+
// Current field has no value but another field has value
|
|
153
|
+
nextPickerValue = calendarValue[mergedActiveIndex ^ 1];
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// Only sync when has value, this will sync in the `min-max` logic
|
|
157
|
+
if (nextPickerValue) {
|
|
158
|
+
// nextPickerValue < minDate
|
|
159
|
+
if (minDate && generateConfig.isAfter(minDate, nextPickerValue)) {
|
|
160
|
+
nextPickerValue = minDate;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
// maxDate < nextPickerValue
|
|
164
|
+
var offsetPickerValue = multiplePanel ? offsetPanelDate(generateConfig, pickerMode, nextPickerValue, 1) : nextPickerValue;
|
|
165
|
+
if (maxDate && generateConfig.isAfter(offsetPickerValue, maxDate)) {
|
|
166
|
+
nextPickerValue = multiplePanel ? offsetPanelDate(generateConfig, pickerMode, maxDate, -1) : maxDate;
|
|
167
|
+
}
|
|
168
|
+
setCurrentPickerValue(nextPickerValue, 'reset');
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}, [open, mergedActiveIndex, calendarValue[mergedActiveIndex]]);
|
|
173
|
+
|
|
174
|
+
// >>> Reset prevActiveIndex when panel closed
|
|
175
|
+
React.useEffect(function () {
|
|
176
|
+
if (open) {
|
|
177
|
+
prevActiveIndexRef.current = mergedActiveIndex;
|
|
178
|
+
} else {
|
|
179
|
+
prevActiveIndexRef.current = null;
|
|
180
|
+
}
|
|
181
|
+
}, [open, mergedActiveIndex]);
|
|
182
|
+
|
|
183
|
+
// >>> defaultPickerValue: Resync to `defaultPickerValue` for each panel focused
|
|
184
|
+
useLayoutEffect(function () {
|
|
185
|
+
if (open && defaultPickerValue) {
|
|
186
|
+
if (defaultPickerValue[mergedActiveIndex]) {
|
|
187
|
+
setCurrentPickerValue(defaultPickerValue[mergedActiveIndex], 'reset');
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
}, [open, mergedActiveIndex]);
|
|
191
|
+
return [currentPickerValue, setCurrentPickerValue];
|
|
192
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { GenerateConfig } from '../../generate';
|
|
2
|
+
import type { BaseInfo, FormatType, Locale, ReplaceListType } from '../../interface';
|
|
3
|
+
import type { RangePickerProps } from '../RangePicker';
|
|
4
|
+
import type { ReplacedPickerProps } from '../SinglePicker';
|
|
5
|
+
type TriggerCalendarChange<ValueType extends object[]> = (calendarValues: ValueType) => void;
|
|
6
|
+
/**
|
|
7
|
+
* Control the internal `value` align with prop `value` and provide a temp `calendarValue` for ui.
|
|
8
|
+
* `calendarValue` will be reset when blur & focus & open.
|
|
9
|
+
*/
|
|
10
|
+
export declare function useInnerValue<ValueType extends DateType[], DateType extends object = any>(generateConfig: GenerateConfig<DateType>, locale: Locale, formatList: FormatType[],
|
|
11
|
+
/** Used for RangePicker. `true` means [DateType, DateType] or will be DateType[] */
|
|
12
|
+
rangeValue: boolean,
|
|
13
|
+
/**
|
|
14
|
+
* Trigger order when trigger calendar value change.
|
|
15
|
+
* This should only used in SinglePicker with `multiple` mode.
|
|
16
|
+
* So when `rangeValue` is `true`, order will be ignored.
|
|
17
|
+
*/
|
|
18
|
+
order: boolean, defaultValue?: ValueType, value?: ValueType, onCalendarChange?: (dates: ValueType, dateStrings: ReplaceListType<Required<ValueType>, string>, info: BaseInfo) => void, onOk?: (dates: ValueType) => void): readonly [ValueType, (updater: ValueType | ((origin: ValueType) => ValueType), ignoreDestroy?: boolean) => void, (useControlledValueFirst?: boolean) => ValueType, TriggerCalendarChange<ValueType>, () => void];
|
|
19
|
+
export default function useRangeValue<ValueType extends DateType[], DateType extends object = any>(info: Pick<RangePickerProps<DateType>, 'generateConfig' | 'locale' | 'allowEmpty' | 'order' | 'picker'> & ReplacedPickerProps<DateType>, mergedValue: ValueType, setInnerValue: (nextValue: ValueType) => void, getCalendarValue: () => ValueType, triggerCalendarChange: TriggerCalendarChange<ValueType>, disabled: ReplaceListType<Required<ValueType>, boolean>, formatList: FormatType[], focused: boolean, open: boolean, isInvalidateDate: (date: DateType, info?: {
|
|
20
|
+
from?: DateType;
|
|
21
|
+
activeIndex: number;
|
|
22
|
+
}) => boolean): [
|
|
23
|
+
/** Trigger `onChange` by check `disabledDate` */
|
|
24
|
+
flushSubmit: (index: number, needTriggerChange: boolean) => void,
|
|
25
|
+
/** Trigger `onChange` directly without check `disabledDate` */
|
|
26
|
+
triggerSubmitChange: (value: ValueType) => boolean
|
|
27
|
+
];
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
2
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
4
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
5
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
6
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
7
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
8
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
9
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
10
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
11
|
+
import { useEvent, useMergedState } from '@rc-component/util';
|
|
12
|
+
import * as React from 'react';
|
|
13
|
+
import useSyncState from "../../hooks/useSyncState";
|
|
14
|
+
import { formatValue, isSame, isSameTimestamp } from "../../utils/dateUtil";
|
|
15
|
+
import { fillIndex } from "../../utils/miscUtil";
|
|
16
|
+
import useLockEffect from "./useLockEffect";
|
|
17
|
+
var EMPTY_VALUE = [];
|
|
18
|
+
|
|
19
|
+
// Submit Logic:
|
|
20
|
+
// * ✅ Value:
|
|
21
|
+
// * merged value using controlled value, if not, use stateValue
|
|
22
|
+
// * When merged value change, [1] resync calendar value and submit value
|
|
23
|
+
// * ✅ Calender Value:
|
|
24
|
+
// * 💻 When user typing is validate, change the calendar value
|
|
25
|
+
// * 🌅 When user click on the panel, change the calendar value
|
|
26
|
+
// * Submit Value:
|
|
27
|
+
// * 💻 When user blur the input, flush calendar value to submit value
|
|
28
|
+
// * 🌅 When user click on the panel is no needConfirm, flush calendar value to submit value
|
|
29
|
+
// * 🌅 When user click on the panel is needConfirm and click OK, flush calendar value to submit value
|
|
30
|
+
// * Blur logic & close logic:
|
|
31
|
+
// * ✅ For value, always try flush submit
|
|
32
|
+
// * ✅ If `needConfirm`, reset as [1]
|
|
33
|
+
// * Else (`!needConfirm`)
|
|
34
|
+
// * If has another index field, active another index
|
|
35
|
+
// * ✅ Flush submit:
|
|
36
|
+
// * If all the start & end field is confirmed or all blur or panel closed
|
|
37
|
+
// * Update `needSubmit` mark to true
|
|
38
|
+
// * trigger onChange by `needSubmit` and update stateValue
|
|
39
|
+
|
|
40
|
+
function useUtil(generateConfig, locale, formatList) {
|
|
41
|
+
var getDateTexts = function getDateTexts(dates) {
|
|
42
|
+
return dates.map(function (date) {
|
|
43
|
+
return formatValue(date, {
|
|
44
|
+
generateConfig: generateConfig,
|
|
45
|
+
locale: locale,
|
|
46
|
+
format: formatList[0]
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
var isSameDates = function isSameDates(source, target) {
|
|
51
|
+
var maxLen = Math.max(source.length, target.length);
|
|
52
|
+
var diffIndex = -1;
|
|
53
|
+
for (var i = 0; i < maxLen; i += 1) {
|
|
54
|
+
var prev = source[i] || null;
|
|
55
|
+
var next = target[i] || null;
|
|
56
|
+
if (prev !== next && !isSameTimestamp(generateConfig, prev, next)) {
|
|
57
|
+
diffIndex = i;
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return [diffIndex < 0, diffIndex !== 0];
|
|
62
|
+
};
|
|
63
|
+
return [getDateTexts, isSameDates];
|
|
64
|
+
}
|
|
65
|
+
function orderDates(dates, generateConfig) {
|
|
66
|
+
return _toConsumableArray(dates).sort(function (a, b) {
|
|
67
|
+
return generateConfig.isAfter(a, b) ? 1 : -1;
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Used for internal value management.
|
|
73
|
+
* It should always use `mergedValue` in render logic
|
|
74
|
+
*/
|
|
75
|
+
function useCalendarValue(mergedValue) {
|
|
76
|
+
var _useSyncState = useSyncState(mergedValue),
|
|
77
|
+
_useSyncState2 = _slicedToArray(_useSyncState, 2),
|
|
78
|
+
calendarValue = _useSyncState2[0],
|
|
79
|
+
setCalendarValue = _useSyncState2[1];
|
|
80
|
+
|
|
81
|
+
/** Sync calendarValue & submitValue back with value */
|
|
82
|
+
var syncWithValue = useEvent(function () {
|
|
83
|
+
setCalendarValue(mergedValue);
|
|
84
|
+
});
|
|
85
|
+
React.useEffect(function () {
|
|
86
|
+
syncWithValue();
|
|
87
|
+
}, [mergedValue]);
|
|
88
|
+
return [calendarValue, setCalendarValue];
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Control the internal `value` align with prop `value` and provide a temp `calendarValue` for ui.
|
|
93
|
+
* `calendarValue` will be reset when blur & focus & open.
|
|
94
|
+
*/
|
|
95
|
+
export function useInnerValue(generateConfig, locale, formatList, /** Used for RangePicker. `true` means [DateType, DateType] or will be DateType[] */
|
|
96
|
+
rangeValue,
|
|
97
|
+
/**
|
|
98
|
+
* Trigger order when trigger calendar value change.
|
|
99
|
+
* This should only used in SinglePicker with `multiple` mode.
|
|
100
|
+
* So when `rangeValue` is `true`, order will be ignored.
|
|
101
|
+
*/
|
|
102
|
+
order, defaultValue, value, onCalendarChange, onOk) {
|
|
103
|
+
// This is the root value which will sync with controlled or uncontrolled value
|
|
104
|
+
var _useMergedState = useMergedState(defaultValue, {
|
|
105
|
+
value: value
|
|
106
|
+
}),
|
|
107
|
+
_useMergedState2 = _slicedToArray(_useMergedState, 2),
|
|
108
|
+
innerValue = _useMergedState2[0],
|
|
109
|
+
setInnerValue = _useMergedState2[1];
|
|
110
|
+
var mergedValue = innerValue || EMPTY_VALUE;
|
|
111
|
+
|
|
112
|
+
// ========================= Inner Values =========================
|
|
113
|
+
var _useCalendarValue = useCalendarValue(mergedValue),
|
|
114
|
+
_useCalendarValue2 = _slicedToArray(_useCalendarValue, 2),
|
|
115
|
+
calendarValue = _useCalendarValue2[0],
|
|
116
|
+
setCalendarValue = _useCalendarValue2[1];
|
|
117
|
+
|
|
118
|
+
// ============================ Change ============================
|
|
119
|
+
var _useUtil = useUtil(generateConfig, locale, formatList),
|
|
120
|
+
_useUtil2 = _slicedToArray(_useUtil, 2),
|
|
121
|
+
getDateTexts = _useUtil2[0],
|
|
122
|
+
isSameDates = _useUtil2[1];
|
|
123
|
+
var triggerCalendarChange = useEvent(function (nextCalendarValues) {
|
|
124
|
+
var clone = _toConsumableArray(nextCalendarValues);
|
|
125
|
+
if (rangeValue) {
|
|
126
|
+
for (var i = 0; i < 2; i += 1) {
|
|
127
|
+
clone[i] = clone[i] || null;
|
|
128
|
+
}
|
|
129
|
+
} else if (order) {
|
|
130
|
+
clone = orderDates(clone.filter(function (date) {
|
|
131
|
+
return date;
|
|
132
|
+
}), generateConfig);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// Update merged value
|
|
136
|
+
var _isSameDates = isSameDates(calendarValue(), clone),
|
|
137
|
+
_isSameDates2 = _slicedToArray(_isSameDates, 2),
|
|
138
|
+
isSameMergedDates = _isSameDates2[0],
|
|
139
|
+
isSameStart = _isSameDates2[1];
|
|
140
|
+
if (!isSameMergedDates) {
|
|
141
|
+
setCalendarValue(clone);
|
|
142
|
+
|
|
143
|
+
// Trigger calendar change event
|
|
144
|
+
if (onCalendarChange) {
|
|
145
|
+
var cellTexts = getDateTexts(clone);
|
|
146
|
+
onCalendarChange(clone, cellTexts, {
|
|
147
|
+
range: isSameStart ? 'end' : 'start'
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
var triggerOk = function triggerOk() {
|
|
153
|
+
if (onOk) {
|
|
154
|
+
onOk(calendarValue());
|
|
155
|
+
}
|
|
156
|
+
};
|
|
157
|
+
return [mergedValue, setInnerValue, calendarValue, triggerCalendarChange, triggerOk];
|
|
158
|
+
}
|
|
159
|
+
export default function useRangeValue(info, mergedValue, setInnerValue, getCalendarValue, triggerCalendarChange, disabled, formatList, focused, open, isInvalidateDate) {
|
|
160
|
+
var generateConfig = info.generateConfig,
|
|
161
|
+
locale = info.locale,
|
|
162
|
+
picker = info.picker,
|
|
163
|
+
onChange = info.onChange,
|
|
164
|
+
allowEmpty = info.allowEmpty,
|
|
165
|
+
order = info.order;
|
|
166
|
+
var orderOnChange = disabled.some(function (d) {
|
|
167
|
+
return d;
|
|
168
|
+
}) ? false : order;
|
|
169
|
+
|
|
170
|
+
// ============================= Util =============================
|
|
171
|
+
var _useUtil3 = useUtil(generateConfig, locale, formatList),
|
|
172
|
+
_useUtil4 = _slicedToArray(_useUtil3, 2),
|
|
173
|
+
getDateTexts = _useUtil4[0],
|
|
174
|
+
isSameDates = _useUtil4[1];
|
|
175
|
+
|
|
176
|
+
// ============================ Values ============================
|
|
177
|
+
// Used for trigger `onChange` event.
|
|
178
|
+
// Record current value which is wait for submit.
|
|
179
|
+
var _useSyncState3 = useSyncState(mergedValue),
|
|
180
|
+
_useSyncState4 = _slicedToArray(_useSyncState3, 2),
|
|
181
|
+
submitValue = _useSyncState4[0],
|
|
182
|
+
setSubmitValue = _useSyncState4[1];
|
|
183
|
+
|
|
184
|
+
/** Sync calendarValue & submitValue back with value */
|
|
185
|
+
var syncWithValue = useEvent(function () {
|
|
186
|
+
setSubmitValue(mergedValue);
|
|
187
|
+
});
|
|
188
|
+
React.useEffect(function () {
|
|
189
|
+
syncWithValue();
|
|
190
|
+
}, [mergedValue]);
|
|
191
|
+
|
|
192
|
+
// ============================ Submit ============================
|
|
193
|
+
var triggerSubmit = useEvent(function (nextValue) {
|
|
194
|
+
var isNullValue = nextValue === null;
|
|
195
|
+
var clone = _toConsumableArray(nextValue || submitValue());
|
|
196
|
+
|
|
197
|
+
// Fill null value
|
|
198
|
+
if (isNullValue) {
|
|
199
|
+
var maxLen = Math.max(disabled.length, clone.length);
|
|
200
|
+
for (var i = 0; i < maxLen; i += 1) {
|
|
201
|
+
if (!disabled[i]) {
|
|
202
|
+
clone[i] = null;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
// Only when exist value to sort
|
|
208
|
+
if (orderOnChange && clone[0] && clone[1]) {
|
|
209
|
+
clone = orderDates(clone, generateConfig);
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
// Sync `calendarValue`
|
|
213
|
+
triggerCalendarChange(clone);
|
|
214
|
+
|
|
215
|
+
// ========= Validate check =========
|
|
216
|
+
var _clone = clone,
|
|
217
|
+
_clone2 = _slicedToArray(_clone, 2),
|
|
218
|
+
start = _clone2[0],
|
|
219
|
+
end = _clone2[1];
|
|
220
|
+
|
|
221
|
+
// >>> Empty
|
|
222
|
+
var startEmpty = !start;
|
|
223
|
+
var endEmpty = !end;
|
|
224
|
+
var validateEmptyDateRange = allowEmpty ?
|
|
225
|
+
// Validate empty start
|
|
226
|
+
(!startEmpty || allowEmpty[0]) && (
|
|
227
|
+
// Validate empty end
|
|
228
|
+
!endEmpty || allowEmpty[1]) : true;
|
|
229
|
+
|
|
230
|
+
// >>> Order
|
|
231
|
+
var validateOrder = !order || startEmpty || endEmpty || isSame(generateConfig, locale, start, end, picker) || generateConfig.isAfter(end, start);
|
|
232
|
+
|
|
233
|
+
// >>> Invalid
|
|
234
|
+
var validateDates =
|
|
235
|
+
// Validate start
|
|
236
|
+
(disabled[0] || !start || !isInvalidateDate(start, {
|
|
237
|
+
activeIndex: 0
|
|
238
|
+
})) && (
|
|
239
|
+
// Validate end
|
|
240
|
+
disabled[1] || !end || !isInvalidateDate(end, {
|
|
241
|
+
from: start,
|
|
242
|
+
activeIndex: 1
|
|
243
|
+
}));
|
|
244
|
+
// >>> Result
|
|
245
|
+
var allPassed =
|
|
246
|
+
// Null value is from clear button
|
|
247
|
+
isNullValue ||
|
|
248
|
+
// Normal check
|
|
249
|
+
validateEmptyDateRange && validateOrder && validateDates;
|
|
250
|
+
if (allPassed) {
|
|
251
|
+
// Sync value with submit value
|
|
252
|
+
setInnerValue(clone);
|
|
253
|
+
var _isSameDates3 = isSameDates(clone, mergedValue),
|
|
254
|
+
_isSameDates4 = _slicedToArray(_isSameDates3, 1),
|
|
255
|
+
isSameMergedDates = _isSameDates4[0];
|
|
256
|
+
|
|
257
|
+
// Trigger `onChange` if needed
|
|
258
|
+
if (onChange && !isSameMergedDates) {
|
|
259
|
+
onChange(
|
|
260
|
+
// Return null directly if all date are empty
|
|
261
|
+
isNullValue && clone.every(function (val) {
|
|
262
|
+
return !val;
|
|
263
|
+
}) ? null : clone, getDateTexts(clone));
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
return allPassed;
|
|
267
|
+
});
|
|
268
|
+
|
|
269
|
+
// ========================= Flush Submit =========================
|
|
270
|
+
var flushSubmit = useEvent(function (index, needTriggerChange) {
|
|
271
|
+
var nextSubmitValue = fillIndex(submitValue(), index, getCalendarValue()[index]);
|
|
272
|
+
setSubmitValue(nextSubmitValue);
|
|
273
|
+
if (needTriggerChange) {
|
|
274
|
+
triggerSubmit();
|
|
275
|
+
}
|
|
276
|
+
});
|
|
277
|
+
|
|
278
|
+
// ============================ Effect ============================
|
|
279
|
+
// All finished action trigger after 2 frames
|
|
280
|
+
var interactiveFinished = !focused && !open;
|
|
281
|
+
useLockEffect(!interactiveFinished, function () {
|
|
282
|
+
if (interactiveFinished) {
|
|
283
|
+
// Always try to trigger submit first
|
|
284
|
+
triggerSubmit();
|
|
285
|
+
|
|
286
|
+
// Trigger calendar change since this is a effect reset
|
|
287
|
+
// https://github.com/ant-design/ant-design/issues/22351
|
|
288
|
+
triggerCalendarChange(mergedValue);
|
|
289
|
+
|
|
290
|
+
// Sync with value anyway
|
|
291
|
+
syncWithValue();
|
|
292
|
+
}
|
|
293
|
+
}, 2);
|
|
294
|
+
|
|
295
|
+
// ============================ Return ============================
|
|
296
|
+
return [flushSubmit, triggerSubmit];
|
|
297
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export default function useShowNow(picker, mode, showNow, showToday, rangePicker) {
|
|
2
|
+
if (mode !== 'date' && mode !== 'time') {
|
|
3
|
+
return false;
|
|
4
|
+
}
|
|
5
|
+
if (showNow !== undefined) {
|
|
6
|
+
return showNow;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
// Compatible with old version `showToday`
|
|
10
|
+
if (showToday !== undefined) {
|
|
11
|
+
return showToday;
|
|
12
|
+
}
|
|
13
|
+
return !rangePicker && (picker === 'date' || picker === 'time');
|
|
14
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { PanelMode, SharedPanelProps } from '../../interface';
|
|
3
|
+
export interface DatePanelProps<DateType extends object> extends SharedPanelProps<DateType> {
|
|
4
|
+
panelName?: PanelMode;
|
|
5
|
+
rowClassName?: (date: DateType) => string;
|
|
6
|
+
/** Used for `WeekPanel` */
|
|
7
|
+
mode?: PanelMode;
|
|
8
|
+
cellSelection?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export default function DatePanel<DateType extends object = any>(props: DatePanelProps<DateType>): React.JSX.Element;
|