@dnb/eufemia 10.70.0 → 10.71.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/CHANGELOG.md +26 -0
- package/cjs/components/autocomplete/AutocompleteDocs.js +3 -3
- package/cjs/components/autocomplete/AutocompleteDocs.js.map +1 -1
- package/cjs/components/avatar/Avatar.js +3 -8
- package/cjs/components/avatar/Avatar.js.map +1 -1
- package/cjs/components/checkbox/CheckboxDocs.js +2 -2
- package/cjs/components/checkbox/CheckboxDocs.js.map +1 -1
- package/cjs/components/date-picker/DatePickerContext.d.ts +0 -1
- package/cjs/components/date-picker/DatePickerContext.js.map +1 -1
- package/cjs/components/date-picker/DatePickerDocs.js +1 -1
- package/cjs/components/date-picker/DatePickerDocs.js.map +1 -1
- package/cjs/components/date-picker/DatePickerInput.js +110 -136
- package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
- package/cjs/components/date-picker/DatePickerProvider.js +0 -2
- package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
- package/cjs/components/date-picker/hooks/useDates.d.ts +0 -2
- package/cjs/components/date-picker/hooks/useDates.js +5 -5
- package/cjs/components/date-picker/hooks/useDates.js.map +1 -1
- package/cjs/components/date-picker/style/dnb-date-picker.css +4 -0
- package/cjs/components/date-picker/style/dnb-date-picker.min.css +1 -1
- package/cjs/components/date-picker/style/dnb-date-picker.scss +3 -0
- package/cjs/components/dialog/DialogDocs.js +7 -2
- package/cjs/components/dialog/DialogDocs.js.map +1 -1
- package/cjs/components/dropdown/Dropdown.d.ts +20 -20
- package/cjs/components/dropdown/DropdownDocs.d.ts +1 -0
- package/cjs/components/dropdown/DropdownDocs.js +158 -1
- package/cjs/components/dropdown/DropdownDocs.js.map +1 -1
- package/cjs/components/flex/ContainerDocs.js +1 -1
- package/cjs/components/flex/ContainerDocs.js.map +1 -1
- package/cjs/components/flex/ItemDocs.d.ts +2 -0
- package/cjs/components/flex/ItemDocs.js +39 -0
- package/cjs/components/flex/ItemDocs.js.map +1 -0
- package/cjs/components/grid/ItemDocs.d.ts +2 -0
- package/cjs/components/grid/ItemDocs.js +19 -0
- package/cjs/components/grid/ItemDocs.js.map +1 -0
- package/cjs/components/input/InputDocs.js +3 -3
- package/cjs/components/input/InputDocs.js.map +1 -1
- package/cjs/components/input-masked/InputMasked.d.ts +0 -3
- package/cjs/components/input-masked/InputMaskedDocs.d.ts +1 -0
- package/cjs/components/input-masked/InputMaskedDocs.js +58 -1
- package/cjs/components/input-masked/InputMaskedDocs.js.map +1 -1
- package/cjs/components/input-masked/InputMaskedHooks.js +11 -7
- package/cjs/components/input-masked/InputMaskedHooks.js.map +1 -1
- package/cjs/components/input-masked/InputMaskedUtils.d.ts +1 -1
- package/cjs/components/input-masked/InputMaskedUtils.js +2 -1
- package/cjs/components/input-masked/InputMaskedUtils.js.map +1 -1
- package/cjs/components/input-masked/MultiInputMaskedDocs.d.ts +2 -0
- package/cjs/components/input-masked/MultiInputMaskedDocs.js +70 -1
- package/cjs/components/input-masked/MultiInputMaskedDocs.js.map +1 -1
- package/cjs/components/input-masked/style/dnb-input-masked.css +9 -0
- package/cjs/components/input-masked/style/dnb-input-masked.min.css +1 -1
- package/cjs/components/input-masked/style/dnb-input-masked.scss +12 -0
- package/cjs/components/input-masked/text-mask/InputModeNumber.d.ts +8 -0
- package/cjs/components/input-masked/text-mask/InputModeNumber.js +32 -9
- package/cjs/components/input-masked/text-mask/InputModeNumber.js.map +1 -1
- package/cjs/components/input-masked/text-mask/adjustCaretPosition.d.ts +2 -1
- package/cjs/components/input-masked/text-mask/adjustCaretPosition.js +3 -2
- package/cjs/components/input-masked/text-mask/adjustCaretPosition.js.map +1 -1
- package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js +9 -3
- package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
- package/cjs/components/modal/ModalDocs.d.ts +5 -0
- package/cjs/components/modal/ModalDocs.js +201 -0
- package/cjs/components/modal/ModalDocs.js.map +1 -0
- package/cjs/components/radio/RadioDocs.js +2 -2
- package/cjs/components/radio/RadioDocs.js.map +1 -1
- package/cjs/components/section/Section.js +2 -7
- package/cjs/components/section/Section.js.map +1 -1
- package/cjs/components/section/SectionDocs.js +1 -1
- package/cjs/components/section/SectionDocs.js.map +1 -1
- package/cjs/components/slider/SliderDocs.js +2 -2
- package/cjs/components/slider/SliderDocs.js.map +1 -1
- package/cjs/components/space/SpaceDocs.d.ts +3 -0
- package/cjs/components/space/SpaceDocs.js +61 -0
- package/cjs/components/space/SpaceDocs.js.map +1 -0
- package/cjs/components/switch/SwitchDocs.js +2 -2
- package/cjs/components/switch/SwitchDocs.js.map +1 -1
- package/cjs/components/textarea/TextareaDocs.js +3 -3
- package/cjs/components/textarea/TextareaDocs.js.map +1 -1
- package/cjs/components/toggle-button/ToggleButtonGroupDocs.js +1 -1
- package/cjs/components/toggle-button/ToggleButtonGroupDocs.js.map +1 -1
- package/cjs/components/tooltip/TooltipDocs.js +1 -1
- package/cjs/components/tooltip/TooltipDocs.js.map +1 -1
- package/cjs/components/upload/Upload.js +6 -3
- package/cjs/components/upload/Upload.js.map +1 -1
- package/cjs/components/upload/UploadDocs.d.ts +1 -0
- package/cjs/components/upload/UploadDocs.js +43 -1
- package/cjs/components/upload/UploadDocs.js.map +1 -1
- package/cjs/components/upload/UploadFileListCell.js +32 -12
- package/cjs/components/upload/UploadFileListCell.js.map +1 -1
- package/cjs/components/upload/types.d.ts +7 -0
- package/cjs/components/upload/types.js.map +1 -1
- package/cjs/extensions/forms/DataContext/At/AtDocs.d.ts +2 -0
- package/cjs/extensions/forms/DataContext/At/AtDocs.js +24 -0
- package/cjs/extensions/forms/DataContext/At/AtDocs.js.map +1 -0
- package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
- package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/Number/Number.js +3 -6
- package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
- package/cjs/extensions/forms/Field/Password/PasswordDocs.d.ts +1 -0
- package/cjs/extensions/forms/Field/Password/PasswordDocs.js +14 -2
- package/cjs/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +6 -4
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +33 -25
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +2 -2
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +8 -3
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
- package/cjs/extensions/forms/Field/String/StringDocs.js +1 -1
- package/cjs/extensions/forms/Field/String/StringDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/Upload/Upload.d.ts +1 -1
- package/cjs/extensions/forms/Field/Upload/Upload.js +3 -1
- package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlock.js +11 -4
- package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlockContext.d.ts +1 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
- package/cjs/extensions/forms/Form/ButtonRow/ButtonRowDocs.d.ts +2 -0
- package/cjs/extensions/forms/Form/ButtonRow/ButtonRowDocs.js +19 -0
- package/cjs/extensions/forms/Form/ButtonRow/ButtonRowDocs.js.map +1 -0
- package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js +1 -1
- package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
- package/cjs/extensions/forms/Wizard/Buttons/ButtonsDocs.d.ts +2 -0
- package/cjs/extensions/forms/Wizard/Buttons/ButtonsDocs.js +14 -0
- package/cjs/extensions/forms/Wizard/Buttons/ButtonsDocs.js.map +1 -0
- package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js +1 -1
- package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/cjs/extensions/forms/hooks/useFieldProps.js +55 -18
- package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/cjs/extensions/forms/types.d.ts +8 -5
- package/cjs/extensions/forms/types.js.map +1 -1
- package/cjs/extensions/forms/utils/FormError.d.ts +20 -16
- package/cjs/extensions/forms/utils/FormError.js.map +1 -1
- package/cjs/shared/Eufemia.d.ts +1 -1
- package/cjs/shared/Eufemia.js +2 -2
- package/cjs/shared/Eufemia.js.map +1 -1
- package/cjs/shared/helpers.d.ts +1 -0
- package/cjs/shared/helpers.js +7 -0
- package/cjs/shared/helpers.js.map +1 -1
- package/cjs/shared/locales/sv-SE.js +2 -2
- package/cjs/shared/locales/sv-SE.js.map +1 -1
- package/cjs/style/core/scopes.scss +1 -1
- package/cjs/style/dnb-ui-basis.css +1 -1
- package/cjs/style/dnb-ui-basis.min.css +1 -1
- package/cjs/style/dnb-ui-body.css +1 -1
- package/cjs/style/dnb-ui-body.min.css +1 -1
- package/cjs/style/dnb-ui-components.css +13 -0
- package/cjs/style/dnb-ui-components.min.css +1 -1
- package/cjs/style/dnb-ui-core.css +1 -1
- package/cjs/style/dnb-ui-core.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +13 -0
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +13 -0
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-components.css +13 -0
- package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
- package/components/autocomplete/AutocompleteDocs.js +3 -3
- package/components/autocomplete/AutocompleteDocs.js.map +1 -1
- package/components/avatar/Avatar.js +1 -6
- package/components/avatar/Avatar.js.map +1 -1
- package/components/checkbox/CheckboxDocs.js +2 -2
- package/components/checkbox/CheckboxDocs.js.map +1 -1
- package/components/date-picker/DatePickerContext.d.ts +0 -1
- package/components/date-picker/DatePickerContext.js.map +1 -1
- package/components/date-picker/DatePickerDocs.js +1 -1
- package/components/date-picker/DatePickerDocs.js.map +1 -1
- package/components/date-picker/DatePickerInput.js +111 -137
- package/components/date-picker/DatePickerInput.js.map +1 -1
- package/components/date-picker/DatePickerProvider.js +0 -2
- package/components/date-picker/DatePickerProvider.js.map +1 -1
- package/components/date-picker/hooks/useDates.d.ts +0 -2
- package/components/date-picker/hooks/useDates.js +3 -5
- package/components/date-picker/hooks/useDates.js.map +1 -1
- package/components/date-picker/style/dnb-date-picker.css +4 -0
- package/components/date-picker/style/dnb-date-picker.min.css +1 -1
- package/components/date-picker/style/dnb-date-picker.scss +3 -0
- package/components/dialog/DialogDocs.js +7 -2
- package/components/dialog/DialogDocs.js.map +1 -1
- package/components/dropdown/Dropdown.d.ts +20 -20
- package/components/dropdown/DropdownDocs.d.ts +1 -0
- package/components/dropdown/DropdownDocs.js +157 -0
- package/components/dropdown/DropdownDocs.js.map +1 -1
- package/components/flex/ContainerDocs.js +1 -1
- package/components/flex/ContainerDocs.js.map +1 -1
- package/components/flex/ItemDocs.d.ts +2 -0
- package/components/flex/ItemDocs.js +33 -0
- package/components/flex/ItemDocs.js.map +1 -0
- package/components/grid/ItemDocs.d.ts +2 -0
- package/components/grid/ItemDocs.js +13 -0
- package/components/grid/ItemDocs.js.map +1 -0
- package/components/input/InputDocs.js +3 -3
- package/components/input/InputDocs.js.map +1 -1
- package/components/input-masked/InputMasked.d.ts +0 -3
- package/components/input-masked/InputMaskedDocs.d.ts +1 -0
- package/components/input-masked/InputMaskedDocs.js +57 -0
- package/components/input-masked/InputMaskedDocs.js.map +1 -1
- package/components/input-masked/InputMaskedHooks.js +11 -7
- package/components/input-masked/InputMaskedHooks.js.map +1 -1
- package/components/input-masked/InputMaskedUtils.d.ts +1 -1
- package/components/input-masked/InputMaskedUtils.js +2 -1
- package/components/input-masked/InputMaskedUtils.js.map +1 -1
- package/components/input-masked/MultiInputMaskedDocs.d.ts +2 -0
- package/components/input-masked/MultiInputMaskedDocs.js +69 -0
- package/components/input-masked/MultiInputMaskedDocs.js.map +1 -1
- package/components/input-masked/style/dnb-input-masked.css +9 -0
- package/components/input-masked/style/dnb-input-masked.min.css +1 -1
- package/components/input-masked/style/dnb-input-masked.scss +12 -0
- package/components/input-masked/text-mask/InputModeNumber.d.ts +8 -0
- package/components/input-masked/text-mask/InputModeNumber.js +32 -9
- package/components/input-masked/text-mask/InputModeNumber.js.map +1 -1
- package/components/input-masked/text-mask/adjustCaretPosition.d.ts +2 -1
- package/components/input-masked/text-mask/adjustCaretPosition.js +3 -2
- package/components/input-masked/text-mask/adjustCaretPosition.js.map +1 -1
- package/components/input-masked/text-mask/createTextMaskInputElement.js +9 -3
- package/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
- package/components/modal/ModalDocs.d.ts +5 -0
- package/components/modal/ModalDocs.js +195 -0
- package/components/modal/ModalDocs.js.map +1 -0
- package/components/radio/RadioDocs.js +2 -2
- package/components/radio/RadioDocs.js.map +1 -1
- package/components/section/Section.js +1 -6
- package/components/section/Section.js.map +1 -1
- package/components/section/SectionDocs.js +1 -1
- package/components/section/SectionDocs.js.map +1 -1
- package/components/slider/SliderDocs.js +2 -2
- package/components/slider/SliderDocs.js.map +1 -1
- package/components/space/SpaceDocs.d.ts +3 -0
- package/components/space/SpaceDocs.js +55 -0
- package/components/space/SpaceDocs.js.map +1 -0
- package/components/switch/SwitchDocs.js +2 -2
- package/components/switch/SwitchDocs.js.map +1 -1
- package/components/textarea/TextareaDocs.js +3 -3
- package/components/textarea/TextareaDocs.js.map +1 -1
- package/components/toggle-button/ToggleButtonGroupDocs.js +1 -1
- package/components/toggle-button/ToggleButtonGroupDocs.js.map +1 -1
- package/components/tooltip/TooltipDocs.js +1 -1
- package/components/tooltip/TooltipDocs.js.map +1 -1
- package/components/upload/Upload.js +6 -3
- package/components/upload/Upload.js.map +1 -1
- package/components/upload/UploadDocs.d.ts +1 -0
- package/components/upload/UploadDocs.js +42 -0
- package/components/upload/UploadDocs.js.map +1 -1
- package/components/upload/UploadFileListCell.js +32 -12
- package/components/upload/UploadFileListCell.js.map +1 -1
- package/components/upload/types.d.ts +7 -0
- package/components/upload/types.js.map +1 -1
- package/es/components/autocomplete/AutocompleteDocs.js +3 -3
- package/es/components/autocomplete/AutocompleteDocs.js.map +1 -1
- package/es/components/avatar/Avatar.js +1 -6
- package/es/components/avatar/Avatar.js.map +1 -1
- package/es/components/checkbox/CheckboxDocs.js +2 -2
- package/es/components/checkbox/CheckboxDocs.js.map +1 -1
- package/es/components/date-picker/DatePickerContext.d.ts +0 -1
- package/es/components/date-picker/DatePickerContext.js.map +1 -1
- package/es/components/date-picker/DatePickerDocs.js +1 -1
- package/es/components/date-picker/DatePickerDocs.js.map +1 -1
- package/es/components/date-picker/DatePickerInput.js +103 -130
- package/es/components/date-picker/DatePickerInput.js.map +1 -1
- package/es/components/date-picker/DatePickerProvider.js +0 -2
- package/es/components/date-picker/DatePickerProvider.js.map +1 -1
- package/es/components/date-picker/hooks/useDates.d.ts +0 -2
- package/es/components/date-picker/hooks/useDates.js +3 -5
- package/es/components/date-picker/hooks/useDates.js.map +1 -1
- package/es/components/date-picker/style/dnb-date-picker.css +4 -0
- package/es/components/date-picker/style/dnb-date-picker.min.css +1 -1
- package/es/components/date-picker/style/dnb-date-picker.scss +3 -0
- package/es/components/dialog/DialogDocs.js +7 -2
- package/es/components/dialog/DialogDocs.js.map +1 -1
- package/es/components/dropdown/Dropdown.d.ts +20 -20
- package/es/components/dropdown/DropdownDocs.d.ts +1 -0
- package/es/components/dropdown/DropdownDocs.js +157 -0
- package/es/components/dropdown/DropdownDocs.js.map +1 -1
- package/es/components/flex/ContainerDocs.js +1 -1
- package/es/components/flex/ContainerDocs.js.map +1 -1
- package/es/components/flex/ItemDocs.d.ts +2 -0
- package/es/components/flex/ItemDocs.js +33 -0
- package/es/components/flex/ItemDocs.js.map +1 -0
- package/es/components/grid/ItemDocs.d.ts +2 -0
- package/es/components/grid/ItemDocs.js +13 -0
- package/es/components/grid/ItemDocs.js.map +1 -0
- package/es/components/input/InputDocs.js +3 -3
- package/es/components/input/InputDocs.js.map +1 -1
- package/es/components/input-masked/InputMasked.d.ts +0 -3
- package/es/components/input-masked/InputMaskedDocs.d.ts +1 -0
- package/es/components/input-masked/InputMaskedDocs.js +57 -0
- package/es/components/input-masked/InputMaskedDocs.js.map +1 -1
- package/es/components/input-masked/InputMaskedHooks.js +11 -7
- package/es/components/input-masked/InputMaskedHooks.js.map +1 -1
- package/es/components/input-masked/InputMaskedUtils.d.ts +1 -1
- package/es/components/input-masked/InputMaskedUtils.js +2 -1
- package/es/components/input-masked/InputMaskedUtils.js.map +1 -1
- package/es/components/input-masked/MultiInputMaskedDocs.d.ts +2 -0
- package/es/components/input-masked/MultiInputMaskedDocs.js +69 -0
- package/es/components/input-masked/MultiInputMaskedDocs.js.map +1 -1
- package/es/components/input-masked/style/dnb-input-masked.css +9 -0
- package/es/components/input-masked/style/dnb-input-masked.min.css +1 -1
- package/es/components/input-masked/style/dnb-input-masked.scss +12 -0
- package/es/components/input-masked/text-mask/InputModeNumber.d.ts +8 -0
- package/es/components/input-masked/text-mask/InputModeNumber.js +39 -9
- package/es/components/input-masked/text-mask/InputModeNumber.js.map +1 -1
- package/es/components/input-masked/text-mask/adjustCaretPosition.d.ts +2 -1
- package/es/components/input-masked/text-mask/adjustCaretPosition.js +3 -2
- package/es/components/input-masked/text-mask/adjustCaretPosition.js.map +1 -1
- package/es/components/input-masked/text-mask/createTextMaskInputElement.js +9 -3
- package/es/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
- package/es/components/modal/ModalDocs.d.ts +5 -0
- package/es/components/modal/ModalDocs.js +191 -0
- package/es/components/modal/ModalDocs.js.map +1 -0
- package/es/components/radio/RadioDocs.js +2 -2
- package/es/components/radio/RadioDocs.js.map +1 -1
- package/es/components/section/Section.js +1 -6
- package/es/components/section/Section.js.map +1 -1
- package/es/components/section/SectionDocs.js +1 -1
- package/es/components/section/SectionDocs.js.map +1 -1
- package/es/components/slider/SliderDocs.js +2 -2
- package/es/components/slider/SliderDocs.js.map +1 -1
- package/es/components/space/SpaceDocs.d.ts +3 -0
- package/es/components/space/SpaceDocs.js +55 -0
- package/es/components/space/SpaceDocs.js.map +1 -0
- package/es/components/switch/SwitchDocs.js +2 -2
- package/es/components/switch/SwitchDocs.js.map +1 -1
- package/es/components/textarea/TextareaDocs.js +3 -3
- package/es/components/textarea/TextareaDocs.js.map +1 -1
- package/es/components/toggle-button/ToggleButtonGroupDocs.js +1 -1
- package/es/components/toggle-button/ToggleButtonGroupDocs.js.map +1 -1
- package/es/components/tooltip/TooltipDocs.js +1 -1
- package/es/components/tooltip/TooltipDocs.js.map +1 -1
- package/es/components/upload/Upload.js +6 -3
- package/es/components/upload/Upload.js.map +1 -1
- package/es/components/upload/UploadDocs.d.ts +1 -0
- package/es/components/upload/UploadDocs.js +42 -0
- package/es/components/upload/UploadDocs.js.map +1 -1
- package/es/components/upload/UploadFileListCell.js +32 -12
- package/es/components/upload/UploadFileListCell.js.map +1 -1
- package/es/components/upload/types.d.ts +7 -0
- package/es/components/upload/types.js.map +1 -1
- package/es/extensions/forms/DataContext/At/AtDocs.d.ts +2 -0
- package/es/extensions/forms/DataContext/At/AtDocs.js +18 -0
- package/es/extensions/forms/DataContext/At/AtDocs.js.map +1 -0
- package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
- package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
- package/es/extensions/forms/Field/Number/Number.js +3 -6
- package/es/extensions/forms/Field/Number/Number.js.map +1 -1
- package/es/extensions/forms/Field/Password/PasswordDocs.d.ts +1 -0
- package/es/extensions/forms/Field/Password/PasswordDocs.js +13 -1
- package/es/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +6 -4
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +24 -16
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +2 -2
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +7 -2
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
- package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
- package/es/extensions/forms/Field/String/StringDocs.js +1 -1
- package/es/extensions/forms/Field/String/StringDocs.js.map +1 -1
- package/es/extensions/forms/Field/Upload/Upload.d.ts +1 -1
- package/es/extensions/forms/Field/Upload/Upload.js +3 -1
- package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
- package/es/extensions/forms/FieldBlock/FieldBlock.js +11 -4
- package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/es/extensions/forms/FieldBlock/FieldBlockContext.d.ts +1 -1
- package/es/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
- package/es/extensions/forms/Form/ButtonRow/ButtonRowDocs.d.ts +2 -0
- package/es/extensions/forms/Form/ButtonRow/ButtonRowDocs.js +13 -0
- package/es/extensions/forms/Form/ButtonRow/ButtonRowDocs.js.map +1 -0
- package/es/extensions/forms/Form/Isolation/IsolationDocs.js +1 -1
- package/es/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
- package/es/extensions/forms/Wizard/Buttons/ButtonsDocs.d.ts +2 -0
- package/es/extensions/forms/Wizard/Buttons/ButtonsDocs.js +8 -0
- package/es/extensions/forms/Wizard/Buttons/ButtonsDocs.js.map +1 -0
- package/es/extensions/forms/hooks/DataValueWritePropsDocs.js +1 -1
- package/es/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/es/extensions/forms/hooks/useFieldProps.js +56 -19
- package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/es/extensions/forms/types.d.ts +8 -5
- package/es/extensions/forms/types.js.map +1 -1
- package/es/extensions/forms/utils/FormError.d.ts +20 -16
- package/es/extensions/forms/utils/FormError.js +1 -0
- package/es/extensions/forms/utils/FormError.js.map +1 -1
- package/es/shared/Eufemia.d.ts +1 -1
- package/es/shared/Eufemia.js +2 -2
- package/es/shared/Eufemia.js.map +1 -1
- package/es/shared/helpers.d.ts +1 -0
- package/es/shared/helpers.js +6 -0
- package/es/shared/helpers.js.map +1 -1
- package/es/shared/locales/sv-SE.js +2 -2
- package/es/shared/locales/sv-SE.js.map +1 -1
- package/es/style/core/scopes.scss +1 -1
- package/es/style/dnb-ui-basis.css +1 -1
- package/es/style/dnb-ui-basis.min.css +1 -1
- package/es/style/dnb-ui-body.css +1 -1
- package/es/style/dnb-ui-body.min.css +1 -1
- package/es/style/dnb-ui-components.css +13 -0
- package/es/style/dnb-ui-components.min.css +1 -1
- package/es/style/dnb-ui-core.css +1 -1
- package/es/style/dnb-ui-core.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-components.css +13 -0
- package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-components.css +13 -0
- package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-components.css +13 -0
- package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
- package/esm/dnb-ui-basis.min.mjs +1 -1
- package/esm/dnb-ui-components.min.mjs +1 -1
- package/esm/dnb-ui-elements.min.mjs +1 -1
- package/esm/dnb-ui-extensions.min.mjs +1 -1
- package/esm/dnb-ui-lib.min.mjs +1 -1
- package/extensions/forms/DataContext/At/AtDocs.d.ts +2 -0
- package/extensions/forms/DataContext/At/AtDocs.js +18 -0
- package/extensions/forms/DataContext/At/AtDocs.js.map +1 -0
- package/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
- package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
- package/extensions/forms/Field/Number/Number.js +3 -6
- package/extensions/forms/Field/Number/Number.js.map +1 -1
- package/extensions/forms/Field/Password/PasswordDocs.d.ts +1 -0
- package/extensions/forms/Field/Password/PasswordDocs.js +13 -1
- package/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +6 -4
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +33 -25
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +2 -2
- package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +7 -2
- package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
- package/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
- package/extensions/forms/Field/String/StringDocs.js +1 -1
- package/extensions/forms/Field/String/StringDocs.js.map +1 -1
- package/extensions/forms/Field/Upload/Upload.d.ts +1 -1
- package/extensions/forms/Field/Upload/Upload.js +3 -1
- package/extensions/forms/Field/Upload/Upload.js.map +1 -1
- package/extensions/forms/FieldBlock/FieldBlock.js +11 -4
- package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/extensions/forms/FieldBlock/FieldBlockContext.d.ts +1 -1
- package/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
- package/extensions/forms/Form/ButtonRow/ButtonRowDocs.d.ts +2 -0
- package/extensions/forms/Form/ButtonRow/ButtonRowDocs.js +13 -0
- package/extensions/forms/Form/ButtonRow/ButtonRowDocs.js.map +1 -0
- package/extensions/forms/Form/Isolation/IsolationDocs.js +1 -1
- package/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
- package/extensions/forms/Wizard/Buttons/ButtonsDocs.d.ts +2 -0
- package/extensions/forms/Wizard/Buttons/ButtonsDocs.js +8 -0
- package/extensions/forms/Wizard/Buttons/ButtonsDocs.js.map +1 -0
- package/extensions/forms/hooks/DataValueWritePropsDocs.js +1 -1
- package/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/extensions/forms/hooks/useFieldProps.js +56 -19
- package/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/extensions/forms/types.d.ts +8 -5
- package/extensions/forms/types.js.map +1 -1
- package/extensions/forms/utils/FormError.d.ts +20 -16
- package/extensions/forms/utils/FormError.js.map +1 -1
- package/package.json +1 -1
- package/shared/Eufemia.d.ts +1 -1
- package/shared/Eufemia.js +2 -2
- package/shared/Eufemia.js.map +1 -1
- package/shared/helpers.d.ts +1 -0
- package/shared/helpers.js +6 -0
- package/shared/helpers.js.map +1 -1
- package/shared/locales/sv-SE.js +2 -2
- package/shared/locales/sv-SE.js.map +1 -1
- package/style/core/scopes.scss +1 -1
- package/style/dnb-ui-basis.css +1 -1
- package/style/dnb-ui-basis.min.css +1 -1
- package/style/dnb-ui-body.css +1 -1
- package/style/dnb-ui-body.min.css +1 -1
- package/style/dnb-ui-components.css +13 -0
- package/style/dnb-ui-components.min.css +1 -1
- package/style/dnb-ui-core.css +1 -1
- package/style/dnb-ui-core.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-components.css +13 -0
- package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-components.css +13 -0
- package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-components.css +13 -0
- package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
- package/umd/dnb-ui-basis.min.js +1 -1
- package/umd/dnb-ui-components.min.js +1 -1
- package/umd/dnb-ui-elements.min.js +1 -1
- package/umd/dnb-ui-extensions.min.js +1 -1
- package/umd/dnb-ui-lib.min.js +1 -1
|
@@ -12,16 +12,14 @@ import "core-js/modules/web.dom-collections.iterator.js";
|
|
|
12
12
|
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; }
|
|
13
13
|
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; }
|
|
14
14
|
import React, { useCallback, useContext, useMemo, useRef, useState } from 'react';
|
|
15
|
-
import addDays from 'date-fns/addDays';
|
|
16
|
-
import addMonths from 'date-fns/addMonths';
|
|
17
|
-
import addYears from 'date-fns/addYears';
|
|
18
15
|
import isValid from 'date-fns/isValid';
|
|
19
16
|
import parseISO from 'date-fns/parseISO';
|
|
20
17
|
import classnames from 'classnames';
|
|
21
18
|
import TextMask from '../input-masked/TextMask';
|
|
22
19
|
import Button from '../button/Button';
|
|
23
20
|
import Input, { SubmitButton } from '../input/Input';
|
|
24
|
-
import { warn, validateDOMAttributes } from '../../shared/component-helper';
|
|
21
|
+
import { warn, validateDOMAttributes, toCapitalized } from '../../shared/component-helper';
|
|
22
|
+
import { IS_ANDROID, IS_IOS } from '../../shared/helpers';
|
|
25
23
|
import { convertStringToDate } from './DatePickerCalc';
|
|
26
24
|
import DatePickerContext from './DatePickerContext';
|
|
27
25
|
import { useTranslation } from '../../shared';
|
|
@@ -73,7 +71,6 @@ function DatePickerInput(externalProps) {
|
|
|
73
71
|
const {
|
|
74
72
|
updateDates,
|
|
75
73
|
callOnChangeHandler,
|
|
76
|
-
hasHadValidDate,
|
|
77
74
|
getReturnObject,
|
|
78
75
|
__startDay,
|
|
79
76
|
__startMonth,
|
|
@@ -85,10 +82,12 @@ function DatePickerInput(externalProps) {
|
|
|
85
82
|
endDate,
|
|
86
83
|
props: {
|
|
87
84
|
onType,
|
|
88
|
-
label
|
|
85
|
+
label,
|
|
86
|
+
correctInvalidDate
|
|
89
87
|
}
|
|
90
88
|
} = useContext(DatePickerContext);
|
|
91
89
|
const translation = useTranslation().DatePicker;
|
|
90
|
+
const hasHadValidDate = isValid(startDate) || isValid(endDate);
|
|
92
91
|
const modeDate = useMemo(() => ({
|
|
93
92
|
startDate,
|
|
94
93
|
endDate
|
|
@@ -278,129 +277,7 @@ function DatePickerInput(externalProps) {
|
|
|
278
277
|
is_valid_start_date,
|
|
279
278
|
is_valid_end_date
|
|
280
279
|
}, returnObject), typedDates));
|
|
281
|
-
}, [
|
|
282
|
-
const prepareCounting = useCallback(async _ref3 => {
|
|
283
|
-
let {
|
|
284
|
-
keyCode,
|
|
285
|
-
target,
|
|
286
|
-
event
|
|
287
|
-
} = _ref3;
|
|
288
|
-
try {
|
|
289
|
-
const isDate = target.getAttribute('class').match(/__input--(day|month|year)($|\s)/)[1];
|
|
290
|
-
const isInRange = target.getAttribute('id').match(/-(start|end)-(day|month|year)/)[1];
|
|
291
|
-
let date = isInRange === 'start' ? startDate : endDate;
|
|
292
|
-
if (!date) {
|
|
293
|
-
return;
|
|
294
|
-
}
|
|
295
|
-
const count = keyCode === 'ArrowUp' ? 1 : -1;
|
|
296
|
-
if (keyCode === 'ArrowUp' || keyCode === 'ArrowDown') {
|
|
297
|
-
switch (isDate) {
|
|
298
|
-
case 'day':
|
|
299
|
-
date = addDays(date, count);
|
|
300
|
-
break;
|
|
301
|
-
case 'month':
|
|
302
|
-
date = addMonths(date, count);
|
|
303
|
-
break;
|
|
304
|
-
case 'year':
|
|
305
|
-
date = addYears(date, count);
|
|
306
|
-
break;
|
|
307
|
-
}
|
|
308
|
-
}
|
|
309
|
-
callOnChange({
|
|
310
|
-
[isInRange === 'start' ? 'startDate' : 'endDate']: date,
|
|
311
|
-
event
|
|
312
|
-
});
|
|
313
|
-
await wait(1);
|
|
314
|
-
selectAll(target);
|
|
315
|
-
} catch (e) {
|
|
316
|
-
warn(e);
|
|
317
|
-
}
|
|
318
|
-
}, [startDate, endDate, callOnChange]);
|
|
319
|
-
const selectStart = useCallback(target => {
|
|
320
|
-
target.focus();
|
|
321
|
-
target.setSelectionRange(0, 0);
|
|
322
|
-
}, []);
|
|
323
|
-
const onFocusHandler = useCallback(event => {
|
|
324
|
-
try {
|
|
325
|
-
selectAll(event.target);
|
|
326
|
-
} catch (e) {
|
|
327
|
-
warn(e);
|
|
328
|
-
}
|
|
329
|
-
setFocusState('focus');
|
|
330
|
-
onFocus === null || onFocus === void 0 ? void 0 : onFocus(_objectSpread(_objectSpread({}, event), getReturnObject({
|
|
331
|
-
event
|
|
332
|
-
})));
|
|
333
|
-
}, [getReturnObject, onFocus]);
|
|
334
|
-
const onBlurHandler = useCallback(event => {
|
|
335
|
-
focusMode.current = null;
|
|
336
|
-
setFocusState('blur');
|
|
337
|
-
onBlur === null || onBlur === void 0 ? void 0 : onBlur(_objectSpread(_objectSpread({}, event), getReturnObject(_objectSpread({
|
|
338
|
-
event
|
|
339
|
-
}, partialDatesRef.current))));
|
|
340
|
-
}, [onBlur, getReturnObject, partialDatesRef]);
|
|
341
|
-
const onKeyDownHandler = useCallback(async event => {
|
|
342
|
-
const keyCode = event.key;
|
|
343
|
-
const target = event.target;
|
|
344
|
-
if (target.selectionStart !== target.selectionEnd) {
|
|
345
|
-
selectStart(target);
|
|
346
|
-
}
|
|
347
|
-
switch (keyCode) {
|
|
348
|
-
case 'ArrowUp':
|
|
349
|
-
case 'ArrowDown':
|
|
350
|
-
event.persist();
|
|
351
|
-
event.preventDefault();
|
|
352
|
-
prepareCounting({
|
|
353
|
-
event,
|
|
354
|
-
keyCode,
|
|
355
|
-
target
|
|
356
|
-
});
|
|
357
|
-
return false;
|
|
358
|
-
case 'Tab':
|
|
359
|
-
return false;
|
|
360
|
-
}
|
|
361
|
-
const size = parseFloat(target.getAttribute('size'));
|
|
362
|
-
const firstSelectionStart = target.selectionStart;
|
|
363
|
-
await wait(1);
|
|
364
|
-
const secondSelectionStart = target.selectionStart;
|
|
365
|
-
const isValid = /[0-9]/g.test(keyCode);
|
|
366
|
-
const refListArray = refList.current;
|
|
367
|
-
const index = refListArray.findIndex(_ref4 => {
|
|
368
|
-
let {
|
|
369
|
-
current
|
|
370
|
-
} = _ref4;
|
|
371
|
-
return current === target;
|
|
372
|
-
});
|
|
373
|
-
if (index < refListArray.length - 1 && (secondSelectionStart === size && isValid && keyCode !== 'ArrowLeft' && keyCode !== 'Backspace' || firstSelectionStart === size && keyCode === 'ArrowRight')) {
|
|
374
|
-
try {
|
|
375
|
-
if (!refListArray[index + 1].current) {
|
|
376
|
-
return;
|
|
377
|
-
}
|
|
378
|
-
const nextSibling = refListArray[index + 1].current;
|
|
379
|
-
if (nextSibling) {
|
|
380
|
-
nextSibling.focus();
|
|
381
|
-
nextSibling.setSelectionRange(0, 0);
|
|
382
|
-
}
|
|
383
|
-
} catch (e) {
|
|
384
|
-
warn(e);
|
|
385
|
-
}
|
|
386
|
-
} else if (firstSelectionStart === 0 && index > 0) {
|
|
387
|
-
switch (keyCode) {
|
|
388
|
-
case 'ArrowLeft':
|
|
389
|
-
case 'Backspace':
|
|
390
|
-
try {
|
|
391
|
-
const prevSibling = refListArray[index - 1].current;
|
|
392
|
-
if (prevSibling) {
|
|
393
|
-
const endPos = prevSibling.value.length;
|
|
394
|
-
prevSibling.focus();
|
|
395
|
-
prevSibling.setSelectionRange(endPos, endPos);
|
|
396
|
-
}
|
|
397
|
-
} catch (e) {
|
|
398
|
-
warn(e);
|
|
399
|
-
}
|
|
400
|
-
break;
|
|
401
|
-
}
|
|
402
|
-
}
|
|
403
|
-
}, [prepareCounting, selectStart]);
|
|
280
|
+
}, [setPartialDates, isRange, getReturnObject, partialDatesRef, onType, inputDates]);
|
|
404
281
|
const setDate = useCallback((event, mode, type) => {
|
|
405
282
|
event.persist();
|
|
406
283
|
const value = event.target.value;
|
|
@@ -465,6 +342,92 @@ function DatePickerInput(externalProps) {
|
|
|
465
342
|
setDate(event, 'end', 'Year');
|
|
466
343
|
}
|
|
467
344
|
}), [setDate]);
|
|
345
|
+
const onFocusHandler = useCallback(event => {
|
|
346
|
+
setFocusState('focus');
|
|
347
|
+
onFocus === null || onFocus === void 0 ? void 0 : onFocus(_objectSpread(_objectSpread({}, event), getReturnObject({
|
|
348
|
+
event
|
|
349
|
+
})));
|
|
350
|
+
if (isNaN(parseFloat(event.target.value))) {
|
|
351
|
+
setCursorPosition(event.target);
|
|
352
|
+
}
|
|
353
|
+
}, [getReturnObject, onFocus]);
|
|
354
|
+
const onBlurHandler = useCallback(event => {
|
|
355
|
+
focusMode.current = null;
|
|
356
|
+
setFocusState('blur');
|
|
357
|
+
onBlur === null || onBlur === void 0 ? void 0 : onBlur(_objectSpread(_objectSpread({}, event), getReturnObject(_objectSpread({
|
|
358
|
+
event
|
|
359
|
+
}, partialDatesRef.current))));
|
|
360
|
+
}, [onBlur, getReturnObject, partialDatesRef]);
|
|
361
|
+
const onKeyDownHandler = useCallback(async event => {
|
|
362
|
+
const keyCode = event.key;
|
|
363
|
+
const target = event.target;
|
|
364
|
+
if (correctInvalidDate && target.selectionStart !== target.selectionEnd) {
|
|
365
|
+
setCursorPosition(target);
|
|
366
|
+
}
|
|
367
|
+
const size = parseFloat(target.getAttribute('size'));
|
|
368
|
+
const firstSelectionStart = target.selectionStart;
|
|
369
|
+
const firstSelectionEnd = target.selectionEnd;
|
|
370
|
+
await wait(IS_IOS ? 10 : 1);
|
|
371
|
+
const secondSelectionStart = target.selectionStart;
|
|
372
|
+
const isValid = /[0-9]/g.test(keyCode);
|
|
373
|
+
const refListArray = refList.current;
|
|
374
|
+
const index = refListArray.findIndex(_ref3 => {
|
|
375
|
+
let {
|
|
376
|
+
current
|
|
377
|
+
} = _ref3;
|
|
378
|
+
return current === target;
|
|
379
|
+
});
|
|
380
|
+
const isLastChar = secondSelectionStart === size;
|
|
381
|
+
const isFirstChar = firstSelectionStart === size;
|
|
382
|
+
const isMovingForward = keyCode !== 'ArrowLeft' && keyCode !== 'Backspace' && isValid && isLastChar;
|
|
383
|
+
const isExplicitForward = (keyCode === 'ArrowRight' || keyCode === 'Enter') && isFirstChar;
|
|
384
|
+
const hasNextField = index < refListArray.length - 1;
|
|
385
|
+
if (hasNextField && (isMovingForward || isExplicitForward)) {
|
|
386
|
+
var _refListArray;
|
|
387
|
+
if (!refListArray[index + 1].current) {
|
|
388
|
+
return;
|
|
389
|
+
}
|
|
390
|
+
const nextSibling = (_refListArray = refListArray[index + 1]) === null || _refListArray === void 0 ? void 0 : _refListArray.current;
|
|
391
|
+
if (nextSibling) {
|
|
392
|
+
setCursorPosition(nextSibling, 0, {
|
|
393
|
+
withoutDelay: true
|
|
394
|
+
});
|
|
395
|
+
}
|
|
396
|
+
if (parseFloat(keyCode) <= 9 && firstSelectionStart === target.size) {
|
|
397
|
+
const name = toCapitalized(nextSibling.getAttribute('class').match(/__input--(day|month|year)($|\s)/)[1]);
|
|
398
|
+
const mode = nextSibling.getAttribute('id').match(/-(start|end)-(day|month|year)/)[1];
|
|
399
|
+
dateSetters[`set_${mode}${name}`](_objectSpread(_objectSpread({
|
|
400
|
+
persist: () => null
|
|
401
|
+
}, event), {}, {
|
|
402
|
+
target: {
|
|
403
|
+
value: keyCode + nextSibling.value.slice(1)
|
|
404
|
+
}
|
|
405
|
+
}));
|
|
406
|
+
setCursorPosition(nextSibling, 1);
|
|
407
|
+
}
|
|
408
|
+
} else if (index > 0 && firstSelectionStart === firstSelectionEnd) {
|
|
409
|
+
const isMovingBackward = keyCode === 'ArrowLeft' && firstSelectionStart === 0;
|
|
410
|
+
const isPressingBackspace = keyCode === 'Backspace' && firstSelectionStart <= 1;
|
|
411
|
+
if (isMovingBackward || isPressingBackspace) {
|
|
412
|
+
var _refListArray2;
|
|
413
|
+
const prevSibling = (_refListArray2 = refListArray[index - 1]) === null || _refListArray2 === void 0 ? void 0 : _refListArray2.current;
|
|
414
|
+
if (prevSibling) {
|
|
415
|
+
const endPos = prevSibling.value.length;
|
|
416
|
+
setCursorPosition(prevSibling, endPos, {
|
|
417
|
+
withoutDelay: true
|
|
418
|
+
});
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
}, [correctInvalidDate, dateSetters]);
|
|
423
|
+
const onInputHandler = useCallback(event => {
|
|
424
|
+
const target = event.currentTarget;
|
|
425
|
+
if (IS_ANDROID && event.nativeEvent.inputType === 'deleteContentBackward' && target.selectionStart === 0 && target.selectionEnd === 0) {
|
|
426
|
+
onKeyDownHandler(_objectSpread(_objectSpread({}, event), {}, {
|
|
427
|
+
key: 'Backspace'
|
|
428
|
+
}));
|
|
429
|
+
}
|
|
430
|
+
}, [onKeyDownHandler]);
|
|
468
431
|
const getPlaceholderChar = useCallback(value => {
|
|
469
432
|
const index = maskOrder.indexOf(value);
|
|
470
433
|
return maskPlaceholder[index];
|
|
@@ -482,6 +445,7 @@ function DatePickerInput(externalProps) {
|
|
|
482
445
|
if (!separatorRegExp.test(value)) {
|
|
483
446
|
if (!inputElement) {
|
|
484
447
|
element = _objectSpread(_objectSpread({}, element), {}, {
|
|
448
|
+
onInput: onInputHandler,
|
|
485
449
|
onKeyDown: onKeyDownHandler,
|
|
486
450
|
onPaste: pasteHandler,
|
|
487
451
|
onFocus: e => {
|
|
@@ -563,7 +527,7 @@ function DatePickerInput(externalProps) {
|
|
|
563
527
|
"aria-hidden": true
|
|
564
528
|
}, placeholderChar);
|
|
565
529
|
});
|
|
566
|
-
}, [
|
|
530
|
+
}, [maskList, getPlaceholderChar, translation, isRange, separatorRegExp, inputElement, size, onInputHandler, onKeyDownHandler, pasteHandler, onBlurHandler, onFocusHandler, id, dateSetters, inputDates]);
|
|
567
531
|
const renderInputElement = useCallback(element => {
|
|
568
532
|
refList.current = [];
|
|
569
533
|
const startDateList = generateDateList(element, 'start');
|
|
@@ -576,7 +540,7 @@ function DatePickerInput(externalProps) {
|
|
|
576
540
|
"aria-hidden": true
|
|
577
541
|
}, ' – '))), isRange && endDateList);
|
|
578
542
|
}, [id, isRange, generateDateList]);
|
|
579
|
-
const
|
|
543
|
+
const ariaLabel = useMemo(() => selectedDateTitle ? `${selectedDateTitle}, ${translation.openPickerText}` : translation.openPickerText, [selectedDateTitle, translation]);
|
|
580
544
|
validateDOMAttributes(props, attributes);
|
|
581
545
|
validateDOMAttributes(null, submitAttributes);
|
|
582
546
|
const SubmitElement = useMemo(() => showInput ? SubmitButton : Button, [showInput]);
|
|
@@ -604,7 +568,7 @@ function DatePickerInput(externalProps) {
|
|
|
604
568
|
disabled: disabled,
|
|
605
569
|
skeleton: skeleton,
|
|
606
570
|
className: classnames(showInput && 'dnb-button--input-button', opened && 'dnb-button--active'),
|
|
607
|
-
"aria-label":
|
|
571
|
+
"aria-label": ariaLabel,
|
|
608
572
|
title: title,
|
|
609
573
|
size: size,
|
|
610
574
|
status: status,
|
|
@@ -619,18 +583,28 @@ function DatePickerInput(externalProps) {
|
|
|
619
583
|
}, attributes)));
|
|
620
584
|
}
|
|
621
585
|
export default DatePickerInput;
|
|
622
|
-
function
|
|
586
|
+
function setCursorPosition(target) {
|
|
587
|
+
let position = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
588
|
+
let options = arguments.length > 2 ? arguments[2] : undefined;
|
|
623
589
|
target.focus();
|
|
624
|
-
|
|
590
|
+
const select = () => {
|
|
591
|
+
target.setSelectionRange(position, position);
|
|
592
|
+
};
|
|
593
|
+
if (!(options !== null && options !== void 0 && options.withoutDelay) && process.env.NODE_ENV !== 'test') {
|
|
594
|
+
setTimeout(select, 0);
|
|
595
|
+
} else {
|
|
596
|
+
select();
|
|
597
|
+
}
|
|
625
598
|
}
|
|
626
|
-
function InputElement(
|
|
599
|
+
function InputElement(_ref4) {
|
|
627
600
|
let {
|
|
628
601
|
className,
|
|
629
602
|
value
|
|
630
|
-
} =
|
|
631
|
-
props = _objectWithoutProperties(
|
|
603
|
+
} = _ref4,
|
|
604
|
+
props = _objectWithoutProperties(_ref4, _excluded3);
|
|
632
605
|
return React.createElement(TextMask, _extends({
|
|
633
606
|
guide: true,
|
|
607
|
+
inputMode: "numeric",
|
|
634
608
|
showMask: true,
|
|
635
609
|
keepCharPositions: false,
|
|
636
610
|
autoComplete: "off",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DatePickerInput.js","names":["React","useCallback","useContext","useMemo","useRef","useState","addDays","addMonths","addYears","isValid","parseISO","classnames","TextMask","Button","Input","SubmitButton","warn","validateDOMAttributes","convertStringToDate","DatePickerContext","useTranslation","usePartialDates","defaultProps","maskOrder","maskPlaceholder","separatorRegExp","statusState","opened","DatePickerInput","externalProps","props","_objectSpread","isRange","id","title","submitAttributes","onFocus","onBlur","onChange","onSubmit","selectedDateTitle","showInput","inputElement","lang","disabled","skeleton","size","status","statusProps","attributes","_objectWithoutProperties","_excluded","focusState","setFocusState","partialDatesRef","setPartialDates","invalidDatesRef","invalidStartDate","invalidEndDate","isDateFullyFilledOutRef","updateDates","callOnChangeHandler","hasHadValidDate","getReturnObject","__startDay","__startMonth","__startYear","__endDay","__endMonth","__endYear","startDate","endDate","onType","label","translation","DatePicker","modeDate","inputDates","inputRefs","startDayRef","current","undefined","startMonthRef","startYearRef","endDayRef","endMonthRef","endYearRef","dateRefs","startDay","startMonth","startYear","endDay","endMonth","endYear","syncDateRefs","temporaryDates","refList","focusMode","maskList","separators","match","split","reduce","acc","cur","push","length","shift","pasteHandler","event","success","clipboardData","window","getData","preventDefault","possibleFormats","forEach","date","sep","replace","reverse","join","index","dateFormat","mode","error","callOnChangeAsInvalid","state","hoverDate","dates","callOnChange","_ref","callOnType","_ref2","getDates","partialStartDate","partialEndDate","parsedStartDate","parsedEndDate","isStartDateValid","isEndDateValid","_getReturnObject","is_valid","is_valid_start_date","is_valid_end_date","returnObject","_excluded2","typedDates","start_date","end_date","prepareCounting","_ref3","keyCode","target","isDate","getAttribute","isInRange","count","wait","selectAll","e","selectStart","focus","setSelectionRange","onFocusHandler","onBlurHandler","onKeyDownHandler","key","selectionStart","selectionEnd","persist","parseFloat","firstSelectionStart","secondSelectionStart","test","refListArray","findIndex","_ref4","nextSibling","prevSibling","endPos","value","setDate","type","fallback","year","getFullYear","month","getMonth","day","getDate","Date","String","isValidDate","dateString","dateSetters","set_startDay","set_startMonth","set_startYear","set_endDay","set_endMonth","set_endYear","getPlaceholderChar","indexOf","generateDateList","element","map","i","slice","placeholderChar","isRangeLabel","onKeyDown","onPaste","DateField","isValidElement","InputElement","inputSizeClassName","createElement","Fragment","_extends","className","mask","inputRef","hidden","htmlFor","renderInputElement","startDateList","endDateList","_span","formatDate","openPickerText","SubmitElement","innerRef","ref","input_state","input_element","status_state","submit_element","icon","variant","on_submit","on_click","select","_ref5","_excluded3","guide","showMask","keepCharPositions","autoComplete","autoCapitalize","spellCheck","autoCorrect","dateRefValue","inputDateValue","duration","Promise","r","setTimeout"],"sources":["../../../../src/components/date-picker/DatePickerInput.tsx"],"sourcesContent":["/**\n * Web DatePicker Component\n *\n */\n\nimport React, {\n MutableRefObject,\n useCallback,\n useContext,\n useMemo,\n useRef,\n useState,\n} from 'react'\n\n// date-fns\nimport addDays from 'date-fns/addDays'\nimport addMonths from 'date-fns/addMonths'\nimport addYears from 'date-fns/addYears'\nimport isValid from 'date-fns/isValid'\nimport parseISO from 'date-fns/parseISO'\n\nimport classnames from 'classnames'\nimport TextMask, { TextMaskProps } from '../input-masked/TextMask'\nimport Button from '../button/Button'\nimport Input, { SubmitButton } from '../input/Input'\nimport type { InputInputElement, InputSize } from '../Input'\nimport { warn, validateDOMAttributes } from '../../shared/component-helper'\nimport { convertStringToDate } from './DatePickerCalc'\nimport DatePickerContext from './DatePickerContext'\n\nimport type {\n FormStatusProps,\n FormStatusState,\n FormStatusText,\n} from '../FormStatus'\nimport type { SkeletonShow } from '../Skeleton'\nimport { ReturnObject } from './DatePickerProvider'\nimport { DatePickerEventAttributes } from './DatePicker'\nimport { useTranslation } from '../../shared'\nimport { DatePickerInputDates } from './hooks/useDates'\nimport usePartialDates from './hooks/usePartialDates'\n\nexport type DatePickerInputProps = Omit<\n React.HTMLProps<HTMLInputElement>,\n | 'children'\n | 'ref'\n | 'value'\n | 'size'\n | 'onFocus'\n | 'onBlur'\n | 'onSubmit'\n | 'label'\n> & {\n selectedDateTitle?: string\n maskOrder?: string\n maskPlaceholder?: string\n separatorRegExp?: RegExp\n submitAttributes?: Record<string, unknown>\n isRange?: boolean\n /**\n * The sizes you can choose is `small` (1.5rem), `default` (2rem), `medium` (2.5rem) and `large` (3rem) are supported component sizes. Defaults to `default` / `null`.\n */\n size?: InputSize\n /**\n * Text with a status message. The style defaults to an error message. You can use `true` to only get the status color, without a message.\n */\n status?: FormStatusText\n /**\n * Defines the state of the status. Currently, there are two statuses `[error, info]`. Defaults to `error`.\n */\n statusState?: FormStatusState\n /**\n * Use an object to define additional FormStatus properties.\n */\n statusProps?: FormStatusProps\n /**\n * Gives you the possibility to use a plain/vanilla `<input />` HTML element by defining it as a string `input_element=\"input\"`, a React element, or a render function `input_element={(internalProps) => (<Return />)}`. Can also be used in circumstances where the `react-text-mask` not should be used, e.g. in testing environments. Defaults to custom masked input.\n */\n inputElement?: InputInputElement\n /**\n * If set to `true`, an overlaying skeleton with animation will be shown.\n */\n skeleton?: SkeletonShow\n /**\n * To open the date-picker by default. Defaults to `false`.\n */\n opened?: boolean\n showInput?: boolean\n onSubmit?: (event: React.MouseEvent<HTMLButtonElement>) => void\n onChange?: (\n event: ReturnObject<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called once the input gets focus.\n */\n onFocus?: (\n event: ReturnObject<React.FocusEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called once the input lose focus.\n */\n onBlur?: (\n event: ReturnObject<React.FocusEvent<HTMLInputElement>>\n ) => void\n}\n\nexport type InvalidDates = {\n invalidDate?: string\n invalidStartDate?: string\n invalidEndDate?: string\n}\n\nconst defaultProps: DatePickerInputProps = {\n maskOrder: 'dd/mm/yyyy',\n maskPlaceholder: 'dd/mm/åååå',\n separatorRegExp: /[-/ ]/g,\n statusState: 'error',\n opened: false,\n}\n\nfunction DatePickerInput(externalProps: DatePickerInputProps) {\n const props = { ...defaultProps, ...externalProps }\n\n const {\n isRange,\n maskOrder,\n separatorRegExp,\n id,\n title,\n submitAttributes,\n maskPlaceholder, // eslint-disable-line\n onFocus,\n onBlur,\n onChange, // eslint-disable-line\n onSubmit, // eslint-disable-line\n selectedDateTitle, // eslint-disable-line\n showInput, // eslint-disable-line\n inputElement,\n lang,\n disabled,\n skeleton,\n opened,\n size,\n status,\n statusState,\n statusProps,\n\n ...attributes\n } = props\n const [focusState, setFocusState] = useState<string>('virgin')\n\n const { partialDatesRef, setPartialDates } = usePartialDates()\n\n const invalidDatesRef = useRef<InvalidDates>({\n invalidStartDate: null,\n invalidEndDate: null,\n })\n const isDateFullyFilledOutRef = useRef(false)\n\n const {\n updateDates,\n callOnChangeHandler,\n hasHadValidDate,\n getReturnObject,\n __startDay,\n __startMonth,\n __startYear,\n __endDay,\n __endMonth,\n __endYear,\n startDate,\n endDate,\n props: { onType, label },\n } = useContext(DatePickerContext)\n\n const translation = useTranslation().DatePicker\n\n const modeDate = useMemo(\n () => ({\n startDate,\n endDate,\n }),\n [startDate, endDate]\n )\n\n const inputDates = useMemo(\n () => ({\n __startDay,\n __startMonth,\n __startYear,\n __endDay,\n __endMonth,\n __endYear,\n }),\n [\n __startDay,\n __startMonth,\n __startYear,\n __endDay,\n __endMonth,\n __endYear,\n ]\n )\n\n const inputRefs = useRef<\n Record<string, MutableRefObject<HTMLInputElement>>\n >({\n startDayRef: { current: undefined },\n startMonthRef: { current: undefined },\n startYearRef: { current: undefined },\n endDayRef: { current: undefined },\n endMonthRef: { current: undefined },\n endYearRef: { current: undefined },\n })\n\n const dateRefs = useRef<Record<string, string>>({\n startDay: '',\n startMonth: '',\n startYear: '',\n endDay: '',\n endMonth: '',\n endYear: '',\n })\n\n // Keep dateRefs in sync with inputDates on re-render\n syncDateRefs(dateRefs, inputDates)\n\n const temporaryDates = useRef<Record<string, Date>>({\n startDate: undefined,\n endDate: undefined,\n })\n\n const refList = useRef<Array<MutableRefObject<HTMLInputElement>>>()\n\n const focusMode = useRef<string>()\n\n const maskList = useMemo(() => {\n const separators = maskOrder.match(separatorRegExp)\n\n return maskOrder\n .split(separatorRegExp)\n .reduce<Array<string>>((acc, cur) => {\n if (!cur) {\n return acc\n }\n\n acc.push(cur)\n\n if (separators.length > 0) {\n // makes sure that separators are added at the correct places and removed from array when added\n acc.push(separators.shift())\n }\n\n return acc\n }, [])\n }, [maskOrder, separatorRegExp])\n\n const pasteHandler = useCallback(\n async (event: React.ClipboardEvent<HTMLInputElement>) => {\n if (!focusMode.current) {\n return // Stop here\n }\n\n const success = (\n event.clipboardData ||\n (typeof window !== 'undefined' && window['clipboardData'])\n ).getData('text')\n\n if (!success) {\n return // Stop here\n }\n\n event.preventDefault()\n\n try {\n const separators = ['.', '/']\n const possibleFormats = ['yyyy-MM-dd']\n\n // TODO: Merge these loops\n possibleFormats.forEach((date) => {\n separators.forEach((sep) => {\n possibleFormats.push(date.replace(/-/g, sep))\n })\n })\n\n possibleFormats.forEach((date) => {\n possibleFormats.push(date.split('').reverse().join(''))\n })\n\n let date: Date\n let index = 0\n\n for (index; index < possibleFormats.length; ++index) {\n date = convertStringToDate(success, {\n dateFormat: possibleFormats[index],\n })\n\n if (date) {\n break\n }\n }\n\n const mode =\n focusMode.current === 'start' ? 'startDate' : 'endDate'\n\n if (date) {\n updateDates({\n [mode]: date,\n })\n }\n } catch (error: unknown) {\n warn(error)\n }\n },\n [updateDates]\n )\n\n const callOnChangeAsInvalid = useCallback(\n (state: {\n endDate?: Date\n starDate?: Date\n event: React.ChangeEvent<HTMLInputElement>\n }) => {\n updateDates(\n {\n hoverDate: null,\n },\n (dates) => {\n // Should fire if user has filled out an invalid date,\n // or if the date was valid. Like if the user has pressed backspace or removed the valid date.\n if (isDateFullyFilledOutRef.current || hasHadValidDate) {\n const { startDate, endDate, event } = {\n ...state,\n ...dates,\n }\n callOnChangeHandler({\n startDate,\n endDate,\n event,\n ...invalidDatesRef.current,\n })\n }\n }\n )\n },\n [updateDates, callOnChangeHandler, hasHadValidDate]\n )\n\n const callOnChange = useCallback(\n ({\n startDate,\n endDate,\n event,\n }: {\n startDate?: Date\n endDate?: Date\n event:\n | React.ChangeEvent<HTMLInputElement>\n | React.KeyboardEvent<HTMLInputElement>\n }) => {\n const state = {}\n if (typeof startDate !== 'undefined' && isValid(startDate)) {\n state['startDate'] = startDate\n }\n if (!isRange) {\n endDate = startDate\n }\n if (typeof endDate !== 'undefined' && isValid(endDate)) {\n state['endDate'] = endDate\n }\n\n updateDates(state, (dates) => {\n if (\n (typeof startDate !== 'undefined' && isValid(startDate)) ||\n (typeof endDate !== 'undefined' && isValid(endDate))\n ) {\n callOnChangeHandler({\n event,\n ...dates,\n ...invalidDatesRef.current,\n })\n }\n })\n },\n [updateDates, callOnChangeHandler, isRange]\n )\n\n const callOnType = useCallback(\n ({ event }: { event: React.ChangeEvent<HTMLInputElement> }) => {\n const getDates = () =>\n ['start', 'end'].reduce(\n (acc, mode) => {\n acc[`${mode}Date`] = [\n dateRefs.current[`${mode}Year`] ||\n inputDates[`__${mode}Year`] ||\n 'yyyy',\n dateRefs.current[`${mode}Month`] ||\n inputDates[`__${mode}Month`] ||\n 'mm',\n dateRefs.current[`${mode}Day`] ||\n inputDates[`__${mode}Day`] ||\n 'dd',\n ].join('-')\n return acc\n },\n { startDate: undefined, endDate: undefined }\n )\n\n // Get the typed dates, so we can ...\n const { startDate, endDate } = getDates()\n\n // Get the partial dates, so we can know if something was typed or not in an optional date field\n setPartialDates({\n partialStartDate: startDate,\n // Only set endDate if in range mode\n ...(isRange && { partialEndDate: endDate }),\n })\n\n const parsedStartDate = parseISO(startDate)\n const parsedEndDate = parseISO(endDate)\n\n const isStartDateValid = isValid(parsedStartDate)\n const isEndDateValid = isValid(parsedEndDate)\n\n const {\n is_valid,\n is_valid_start_date,\n is_valid_end_date,\n ...returnObject\n } = getReturnObject({\n startDate: isStartDateValid ? parsedStartDate : null,\n endDate: isEndDateValid ? parsedEndDate : null,\n event,\n ...partialDatesRef.current,\n ...invalidDatesRef.current,\n })\n\n // Re-assigns dates to the typed date, instead of `null` from getReturnObject, if dates are invalid\n const typedDates = {\n ...(!isRange && is_valid === false && { date: startDate }),\n ...(isRange &&\n is_valid_start_date === false && { start_date: startDate }),\n ...(isRange &&\n is_valid_end_date === false && { end_date: endDate }),\n }\n\n onType?.({\n is_valid,\n is_valid_start_date,\n is_valid_end_date,\n ...returnObject,\n ...typedDates,\n })\n },\n [isRange, dateRefs, getReturnObject, inputDates, onType]\n )\n\n const prepareCounting = useCallback(\n async ({\n keyCode,\n target,\n event,\n }: {\n keyCode: string\n target: HTMLInputElement\n event: React.KeyboardEvent<HTMLInputElement>\n }) => {\n try {\n const isDate = target\n .getAttribute('class')\n .match(/__input--(day|month|year)($|\\s)/)[1]\n\n const isInRange = target\n .getAttribute('id')\n .match(/-(start|end)-(day|month|year)/)[1]\n\n let date = isInRange === 'start' ? startDate : endDate\n\n // do nothing if date is not set yet\n if (!date) {\n return\n }\n\n const count = keyCode === 'ArrowUp' ? 1 : -1\n\n if (keyCode === 'ArrowUp' || keyCode === 'ArrowDown') {\n switch (isDate) {\n case 'day':\n date = addDays(date, count)\n break\n case 'month':\n date = addMonths(date, count)\n break\n case 'year':\n date = addYears(date, count)\n break\n }\n }\n\n callOnChange({\n [isInRange === 'start' ? 'startDate' : 'endDate']: date,\n event,\n })\n\n await wait(1) // to get the correct position afterwards\n\n selectAll(target)\n } catch (e) {\n warn(e)\n }\n },\n [startDate, endDate, callOnChange]\n )\n\n const selectStart = useCallback((target: HTMLInputElement) => {\n target.focus()\n target.setSelectionRange(0, 0)\n }, [])\n\n const onFocusHandler = useCallback(\n (event: React.FocusEvent<HTMLInputElement>) => {\n try {\n selectAll(event.target)\n } catch (e) {\n warn(e)\n }\n\n setFocusState('focus')\n\n onFocus?.({\n ...event,\n ...getReturnObject({ event }),\n })\n },\n [getReturnObject, onFocus]\n )\n\n const onBlurHandler = useCallback(\n (event: React.FocusEvent<HTMLInputElement>) => {\n focusMode.current = null\n setFocusState('blur')\n\n onBlur?.({\n ...event,\n ...getReturnObject({ event, ...partialDatesRef.current }),\n })\n },\n [onBlur, getReturnObject, partialDatesRef]\n )\n\n const onKeyDownHandler = useCallback(\n async (event: React.KeyboardEvent<HTMLInputElement>) => {\n const keyCode = event.key\n const target = event.target as HTMLInputElement\n\n if (target.selectionStart !== target.selectionEnd) {\n selectStart(target)\n }\n\n // only to process key up and down press\n switch (keyCode) {\n case 'ArrowUp':\n case 'ArrowDown':\n event.persist()\n event.preventDefault()\n prepareCounting({ event, keyCode, target })\n return false\n case 'Tab':\n return false\n }\n\n // the rest is for value entry\n\n const size = parseFloat(target.getAttribute('size'))\n const firstSelectionStart = target.selectionStart\n\n await wait(1) // to get the correct position afterwards\n\n const secondSelectionStart = target.selectionStart\n // Always false (since the old keycode function set number keys to undefined) but needed to not break tests\n const isValid = /[0-9]/g.test(keyCode)\n const refListArray = refList.current\n\n const index = refListArray.findIndex(\n ({ current }) => current === target\n )\n\n if (\n index < refListArray.length - 1 &&\n ((secondSelectionStart === size &&\n isValid &&\n keyCode !== 'ArrowLeft' &&\n keyCode !== 'Backspace') ||\n (firstSelectionStart === size && keyCode === 'ArrowRight'))\n ) {\n try {\n // stop in case there is no next input element\n if (!refListArray[index + 1].current) {\n return\n }\n const nextSibling = refListArray[index + 1].current\n if (nextSibling) {\n nextSibling.focus()\n nextSibling.setSelectionRange(0, 0)\n }\n } catch (e) {\n warn(e)\n }\n } else if (firstSelectionStart === 0 && index > 0) {\n switch (keyCode) {\n case 'ArrowLeft':\n case 'Backspace':\n try {\n const prevSibling = refListArray[index - 1].current\n if (prevSibling) {\n const endPos = prevSibling.value.length\n prevSibling.focus()\n prevSibling.setSelectionRange(endPos, endPos)\n }\n } catch (e) {\n warn(e)\n }\n break\n }\n }\n },\n [prepareCounting, selectStart]\n )\n\n const setDate = useCallback(\n (\n event: React.ChangeEvent<HTMLInputElement>,\n mode: 'start' | 'end',\n type: 'Day' | 'Month' | 'Year'\n ) => {\n event.persist() // since we have later a state update and afterwards the callback\n\n const value = (event.target as HTMLInputElement).value\n\n dateRefs.current[`${mode}${type}`] = value\n\n if (modeDate[`${mode}Date`]) {\n temporaryDates.current[`${mode}Date`] = modeDate[`${mode}Date`]\n }\n\n const fallback = temporaryDates.current[`${mode}Date`]\n\n // provide fallbacks to create a temp fallback\n const year =\n dateRefs.current[`${mode}Year`] ||\n (fallback && fallback.getFullYear())\n const month =\n dateRefs.current[`${mode}Month`] ||\n (fallback && fallback.getMonth() + 1)\n const day =\n dateRefs.current[`${mode}Day`] || (fallback && fallback.getDate())\n\n // calculate new date\n const date = new Date(\n parseFloat(String(year)),\n parseFloat(String(month)) - 1,\n parseFloat(String(day))\n )\n\n const isValidDate =\n !/[^0-9]/.test(String(day)) &&\n !/[^0-9]/.test(String(month)) &&\n !/[^0-9]/.test(String(year)) &&\n isValid(date) &&\n date.getDate() == parseFloat(String(day)) &&\n date.getMonth() + 1 == parseFloat(String(month)) &&\n date.getFullYear() == parseFloat(String(year))\n\n const dateString = `${year}-${month}-${day}`\n\n isDateFullyFilledOutRef.current =\n /^[0-9]{4}-[0-9]{2}-[0-9]{2}$/.test(dateString)\n\n // update the date\n if (isValidDate) {\n invalidDatesRef.current = {\n ...invalidDatesRef.current,\n ...(mode === 'start'\n ? { invalidStartDate: null }\n : { invalidEndDate: null }),\n }\n\n callOnChange({\n [`${mode}Date`]: date,\n event,\n })\n } else {\n updateDates({\n [`${mode}Date`]: null,\n [`__${mode}${type}`]: value,\n })\n\n invalidDatesRef.current = {\n ...invalidDatesRef.current,\n ...(mode === 'start'\n ? { invalidStartDate: dateString }\n : { invalidEndDate: dateString }),\n }\n\n callOnChangeAsInvalid({\n [`${mode}Date`]: null,\n event,\n })\n }\n\n callOnType({ event })\n },\n [\n updateDates,\n callOnChange,\n callOnChangeAsInvalid,\n callOnType,\n modeDate,\n dateRefs,\n temporaryDates,\n ]\n )\n\n const dateSetters = useMemo(\n () => ({\n set_startDay: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'start', 'Day')\n },\n\n set_startMonth: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'start', 'Month')\n },\n\n set_startYear: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'start', 'Year')\n },\n\n set_endDay: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'end', 'Day')\n },\n\n set_endMonth: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'end', 'Month')\n },\n\n set_endYear: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'end', 'Year')\n },\n }),\n [setDate]\n )\n\n const getPlaceholderChar = useCallback(\n (value: string) => {\n const index = maskOrder.indexOf(value)\n return maskPlaceholder[index]\n },\n [maskOrder, maskPlaceholder]\n )\n\n // TODO: Replace with MutliInputMask\n const generateDateList = useCallback(\n (\n element: Omit<React.HTMLProps<HTMLInputElement>, 'size'> &\n DatePickerEventAttributes,\n mode: 'start' | 'end'\n ) => {\n return maskList.map((value, i) => {\n const state = value.slice(0, 1)\n const placeholderChar = getPlaceholderChar(value)\n const { day, month, year } = translation\n const isRangeLabel = isRange ? `${translation[mode]} ` : ''\n\n if (!separatorRegExp.test(value)) {\n if (!inputElement) {\n element = {\n ...element,\n onKeyDown: onKeyDownHandler,\n onPaste: pasteHandler,\n onFocus: (e) => {\n focusMode.current = mode\n onFocusHandler(e)\n },\n onBlur: onBlurHandler,\n placeholderChar,\n }\n }\n\n // this makes it possible to use a vanilla <input /> like: input_element=\"input\"\n const DateField =\n inputElement && React.isValidElement(inputElement)\n ? inputElement.type\n : InputElement\n\n const inputSizeClassName =\n size && `dnb-date-picker__input--${size}`\n\n switch (state) {\n case 'd':\n refList.current.push(inputRefs.current[`${mode}DayRef`])\n\n return (\n <React.Fragment key={'dd' + i}>\n <DateField\n {...element}\n id={`${id}-${mode}-day`}\n key={'di' + i}\n className={classnames(\n element.className,\n 'dnb-date-picker__input',\n 'dnb-date-picker__input--day',\n inputSizeClassName\n )}\n size={2}\n mask={[/[0-9]/, /[0-9]/]}\n inputRef={inputRefs.current[`${mode}DayRef`]}\n onChange={dateSetters[`set_${mode}Day`]}\n value={inputDates[`__${mode}Day`] || ''}\n aria-labelledby={`${id}-${mode}-day-label`}\n />\n <label\n key={'dl' + i}\n hidden\n id={`${id}-${mode}-day-label`}\n htmlFor={`${id}-${mode}-day`}\n >\n {isRangeLabel + day}\n </label>\n </React.Fragment>\n )\n case 'm':\n refList.current.push(inputRefs.current[`${mode}MonthRef`])\n\n return (\n <React.Fragment key={'mm' + i}>\n <DateField\n {...element}\n id={`${id}-${mode}-month`}\n key={'mi' + i}\n className={classnames(\n element.className,\n 'dnb-date-picker__input',\n 'dnb-date-picker__input--month',\n inputSizeClassName\n )}\n size={2}\n mask={[/[0-9]/, /[0-9]/]}\n inputRef={inputRefs.current[`${mode}MonthRef`]}\n onChange={dateSetters[`set_${mode}Month`]}\n value={inputDates[`__${mode}Month`] || ''}\n aria-labelledby={`${id}-${mode}-month-label`}\n />\n <label\n key={'ml' + i}\n hidden\n id={`${id}-${mode}-month-label`}\n htmlFor={`${id}-${mode}-month`}\n >\n {isRangeLabel + month}\n </label>\n </React.Fragment>\n )\n case 'y':\n refList.current.push(inputRefs.current[`${mode}YearRef`])\n\n return (\n <React.Fragment key={'yy' + i}>\n <DateField\n {...element}\n id={`${id}-${mode}-year`}\n key={'yi' + i}\n className={classnames(\n element.className,\n 'dnb-date-picker__input',\n 'dnb-date-picker__input--year',\n inputSizeClassName\n )}\n size={4}\n mask={[/[0-9]/, /[0-9]/, /[0-9]/, /[0-9]/]}\n inputRef={inputRefs.current[`${mode}YearRef`]}\n onChange={dateSetters[`set_${mode}Year`]}\n value={inputDates[`__${mode}Year`] || ''}\n aria-labelledby={`${id}-${mode}-year-label`}\n />\n <label\n key={'yl' + i}\n hidden\n id={`${id}-${mode}-year-label`}\n htmlFor={`${id}-${mode}-year`}\n >\n {isRangeLabel + year}\n </label>\n </React.Fragment>\n )\n }\n }\n return (\n <span\n key={'s' + i}\n className=\"dnb-date-picker--separator\"\n aria-hidden\n >\n {placeholderChar}\n </span>\n )\n })\n },\n [\n id,\n inputElement,\n isRange,\n size,\n translation,\n separatorRegExp,\n dateSetters,\n inputRefs,\n maskList,\n onBlurHandler,\n onFocusHandler,\n getPlaceholderChar,\n pasteHandler,\n onKeyDownHandler,\n inputDates,\n ]\n )\n\n const renderInputElement = useCallback(\n (\n element: React.HTMLProps<HTMLInputElement> &\n DatePickerEventAttributes\n ) => {\n refList.current = []\n const startDateList = generateDateList(element, 'start')\n const endDateList = generateDateList(element, 'end')\n\n return (\n <span\n id={`${id}-input`}\n className=\"dnb-date-picker__input__wrapper\"\n >\n {startDateList}\n {isRange && (\n <span className=\"dnb-date-picker--separator\" aria-hidden>\n {' – '}\n </span>\n )}\n {isRange && endDateList}\n </span>\n )\n },\n [id, isRange, generateDateList]\n )\n\n const formatDate = useMemo(\n () =>\n selectedDateTitle\n ? `${selectedDateTitle}, ${translation.openPickerText}`\n : translation.openPickerText,\n [selectedDateTitle, translation]\n )\n\n validateDOMAttributes(props, attributes)\n validateDOMAttributes(null, submitAttributes)\n\n const SubmitElement: React.ElementType = useMemo(\n () => (showInput ? SubmitButton : Button),\n [showInput]\n )\n\n if (!showInput) {\n // Use Button inner ref\n submitAttributes.innerRef = submitAttributes.ref\n submitAttributes.ref = null\n }\n\n return (\n <fieldset className=\"dnb-date-picker__fieldset\" lang={lang}>\n {label && <legend className=\"dnb-sr-only\">{label}</legend>}\n <Input\n id={`${id}__input`}\n input_state={disabled ? 'disabled' : focusState}\n input_element={\n inputElement && typeof inputElement !== 'string'\n ? typeof inputElement === 'function'\n ? inputElement(props)\n : inputElement\n : renderInputElement\n }\n disabled={disabled || skeleton}\n skeleton={skeleton}\n size={size}\n status={!opened ? status : null}\n status_state={statusState}\n {...statusProps}\n submit_element={\n <SubmitElement\n id={id}\n disabled={disabled}\n skeleton={skeleton}\n className={classnames(\n showInput && 'dnb-button--input-button',\n opened ? 'dnb-button--active' : null\n )}\n aria-label={formatDate}\n title={title}\n size={size}\n status={status}\n status_state={statusState}\n type=\"button\"\n icon=\"calendar\"\n variant=\"secondary\"\n on_submit={onSubmit}\n on_click={onSubmit}\n {...submitAttributes}\n {...statusProps}\n />\n }\n lang={lang}\n {...attributes}\n />\n </fieldset>\n )\n}\n\nexport default DatePickerInput\n\nfunction selectAll(target: HTMLInputElement) {\n target.focus()\n target.select()\n}\n\nfunction InputElement({ className, value, ...props }: TextMaskProps) {\n return (\n <TextMask\n guide={true}\n showMask={true}\n keepCharPositions={false} // so we can overwrite next value, if it already exists\n autoComplete=\"off\"\n autoCapitalize=\"none\"\n spellCheck={false}\n autoCorrect=\"off\"\n className={classnames(\n className,\n /\\d+/.test(String(value)) && 'dnb-date-picker__input--highlight'\n )}\n value={value}\n {...props}\n />\n )\n}\n\nfunction syncDateRefs(\n dateRefs: React.MutableRefObject<Record<string, string>>,\n inputDates: DatePickerInputDates\n) {\n for (const date in dateRefs.current) {\n const dateRefValue = dateRefs.current[date]\n const inputDateValue = inputDates[`__${date}`]\n\n if (dateRefValue !== inputDateValue) {\n dateRefs.current[date] = inputDateValue\n }\n }\n}\n\nconst wait = (duration: number) =>\n new Promise((r) => setTimeout(r, duration))\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"DatePickerInput.js","names":["React","useCallback","useContext","useMemo","useRef","useState","isValid","parseISO","classnames","TextMask","Button","Input","SubmitButton","warn","validateDOMAttributes","toCapitalized","IS_ANDROID","IS_IOS","convertStringToDate","DatePickerContext","useTranslation","usePartialDates","defaultProps","maskOrder","maskPlaceholder","separatorRegExp","statusState","opened","DatePickerInput","externalProps","props","_objectSpread","isRange","id","title","submitAttributes","onFocus","onBlur","onChange","onSubmit","selectedDateTitle","showInput","inputElement","lang","disabled","skeleton","size","status","statusProps","attributes","_objectWithoutProperties","_excluded","focusState","setFocusState","partialDatesRef","setPartialDates","invalidDatesRef","invalidStartDate","invalidEndDate","isDateFullyFilledOutRef","updateDates","callOnChangeHandler","getReturnObject","__startDay","__startMonth","__startYear","__endDay","__endMonth","__endYear","startDate","endDate","onType","label","correctInvalidDate","translation","DatePicker","hasHadValidDate","modeDate","inputDates","inputRefs","startDayRef","current","undefined","startMonthRef","startYearRef","endDayRef","endMonthRef","endYearRef","dateRefs","startDay","startMonth","startYear","endDay","endMonth","endYear","syncDateRefs","temporaryDates","refList","focusMode","maskList","separators","match","split","reduce","acc","cur","push","length","shift","pasteHandler","event","success","clipboardData","window","getData","preventDefault","possibleFormats","forEach","date","sep","replace","reverse","join","index","dateFormat","mode","error","callOnChangeAsInvalid","state","hoverDate","dates","callOnChange","_ref","callOnType","_ref2","getDates","partialStartDate","partialEndDate","parsedStartDate","parsedEndDate","isStartDateValid","isEndDateValid","_getReturnObject","is_valid","is_valid_start_date","is_valid_end_date","returnObject","_excluded2","typedDates","start_date","end_date","setDate","type","persist","value","target","fallback","year","getFullYear","month","getMonth","day","getDate","Date","parseFloat","String","isValidDate","test","dateString","dateSetters","set_startDay","set_startMonth","set_startYear","set_endDay","set_endMonth","set_endYear","onFocusHandler","isNaN","setCursorPosition","onBlurHandler","onKeyDownHandler","keyCode","key","selectionStart","selectionEnd","getAttribute","firstSelectionStart","firstSelectionEnd","wait","secondSelectionStart","refListArray","findIndex","_ref3","isLastChar","isFirstChar","isMovingForward","isExplicitForward","hasNextField","_refListArray","nextSibling","withoutDelay","name","slice","isMovingBackward","isPressingBackspace","_refListArray2","prevSibling","endPos","onInputHandler","currentTarget","nativeEvent","inputType","getPlaceholderChar","indexOf","generateDateList","element","map","i","placeholderChar","isRangeLabel","onInput","onKeyDown","onPaste","e","DateField","isValidElement","InputElement","inputSizeClassName","createElement","Fragment","_extends","className","mask","inputRef","hidden","htmlFor","renderInputElement","startDateList","endDateList","_span","ariaLabel","openPickerText","SubmitElement","innerRef","ref","input_state","input_element","status_state","submit_element","icon","variant","on_submit","on_click","position","arguments","options","focus","select","setSelectionRange","process","env","NODE_ENV","setTimeout","_ref4","_excluded3","guide","inputMode","showMask","keepCharPositions","autoComplete","autoCapitalize","spellCheck","autoCorrect","dateRefValue","inputDateValue","duration","Promise","r"],"sources":["../../../../src/components/date-picker/DatePickerInput.tsx"],"sourcesContent":["/**\n * Web DatePicker Component\n *\n */\n\nimport React, {\n MutableRefObject,\n useCallback,\n useContext,\n useMemo,\n useRef,\n useState,\n} from 'react'\n\n// date-fns\nimport isValid from 'date-fns/isValid'\nimport parseISO from 'date-fns/parseISO'\n\nimport classnames from 'classnames'\nimport TextMask, { TextMaskProps } from '../input-masked/TextMask'\nimport Button from '../button/Button'\nimport Input, { SubmitButton } from '../input/Input'\nimport type { InputInputElement, InputSize } from '../Input'\nimport {\n warn,\n validateDOMAttributes,\n toCapitalized,\n} from '../../shared/component-helper'\nimport { IS_ANDROID, IS_IOS } from '../../shared/helpers'\nimport { convertStringToDate } from './DatePickerCalc'\nimport DatePickerContext from './DatePickerContext'\n\nimport type {\n FormStatusProps,\n FormStatusState,\n FormStatusText,\n} from '../FormStatus'\nimport type { SkeletonShow } from '../Skeleton'\nimport { ReturnObject } from './DatePickerProvider'\nimport { DatePickerEventAttributes } from './DatePicker'\nimport { useTranslation } from '../../shared'\nimport { DatePickerInputDates } from './hooks/useDates'\nimport usePartialDates from './hooks/usePartialDates'\n\nexport type DatePickerInputProps = Omit<\n React.HTMLProps<HTMLInputElement>,\n | 'children'\n | 'ref'\n | 'value'\n | 'size'\n | 'onFocus'\n | 'onBlur'\n | 'onSubmit'\n | 'label'\n> & {\n selectedDateTitle?: string\n maskOrder?: string\n maskPlaceholder?: string\n separatorRegExp?: RegExp\n submitAttributes?: Record<string, unknown>\n isRange?: boolean\n /**\n * The sizes you can choose is `small` (1.5rem), `default` (2rem), `medium` (2.5rem) and `large` (3rem) are supported component sizes. Defaults to `default` / `null`.\n */\n size?: InputSize\n /**\n * Text with a status message. The style defaults to an error message. You can use `true` to only get the status color, without a message.\n */\n status?: FormStatusText\n /**\n * Defines the state of the status. Currently, there are two statuses `[error, info]`. Defaults to `error`.\n */\n statusState?: FormStatusState\n /**\n * Use an object to define additional FormStatus properties.\n */\n statusProps?: FormStatusProps\n /**\n * Gives you the possibility to use a plain/vanilla `<input />` HTML element by defining it as a string `input_element=\"input\"`, a React element, or a render function `input_element={(internalProps) => (<Return />)}`. Can also be used in circumstances where the `react-text-mask` not should be used, e.g. in testing environments. Defaults to custom masked input.\n */\n inputElement?: InputInputElement\n /**\n * If set to `true`, an overlaying skeleton with animation will be shown.\n */\n skeleton?: SkeletonShow\n /**\n * To open the date-picker by default. Defaults to `false`.\n */\n opened?: boolean\n showInput?: boolean\n onSubmit?: (event: React.MouseEvent<HTMLButtonElement>) => void\n onChange?: (\n event: ReturnObject<React.ChangeEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called once the input gets focus.\n */\n onFocus?: (\n event: ReturnObject<React.FocusEvent<HTMLInputElement>>\n ) => void\n /**\n * Will be called once the input lose focus.\n */\n onBlur?: (\n event: ReturnObject<React.FocusEvent<HTMLInputElement>>\n ) => void\n}\n\nexport type InvalidDates = {\n invalidDate?: string\n invalidStartDate?: string\n invalidEndDate?: string\n}\n\nconst defaultProps: DatePickerInputProps = {\n maskOrder: 'dd/mm/yyyy',\n maskPlaceholder: 'dd/mm/åååå',\n separatorRegExp: /[-/ ]/g,\n statusState: 'error',\n opened: false,\n}\n\nfunction DatePickerInput(externalProps: DatePickerInputProps) {\n const props = { ...defaultProps, ...externalProps }\n\n const {\n isRange,\n maskOrder,\n separatorRegExp,\n id,\n title,\n submitAttributes,\n maskPlaceholder, // eslint-disable-line\n onFocus,\n onBlur,\n onChange, // eslint-disable-line\n onSubmit, // eslint-disable-line\n selectedDateTitle, // eslint-disable-line\n showInput, // eslint-disable-line\n inputElement,\n lang,\n disabled,\n skeleton,\n opened,\n size,\n status,\n statusState,\n statusProps,\n\n ...attributes\n } = props\n const [focusState, setFocusState] = useState<string>('virgin')\n\n const { partialDatesRef, setPartialDates } = usePartialDates()\n\n const invalidDatesRef = useRef<InvalidDates>({\n invalidStartDate: null,\n invalidEndDate: null,\n })\n const isDateFullyFilledOutRef = useRef(false)\n\n const {\n updateDates,\n callOnChangeHandler,\n getReturnObject,\n __startDay,\n __startMonth,\n __startYear,\n __endDay,\n __endMonth,\n __endYear,\n startDate,\n endDate,\n props: { onType, label, correctInvalidDate },\n } = useContext(DatePickerContext)\n\n const translation = useTranslation().DatePicker\n\n const hasHadValidDate = isValid(startDate) || isValid(endDate)\n\n const modeDate = useMemo(\n () => ({\n startDate,\n endDate,\n }),\n [startDate, endDate]\n )\n\n const inputDates = useMemo(\n () => ({\n __startDay,\n __startMonth,\n __startYear,\n __endDay,\n __endMonth,\n __endYear,\n }),\n [\n __startDay,\n __startMonth,\n __startYear,\n __endDay,\n __endMonth,\n __endYear,\n ]\n )\n\n const inputRefs = useRef<\n Record<string, MutableRefObject<HTMLInputElement>>\n >({\n startDayRef: { current: undefined },\n startMonthRef: { current: undefined },\n startYearRef: { current: undefined },\n endDayRef: { current: undefined },\n endMonthRef: { current: undefined },\n endYearRef: { current: undefined },\n })\n\n const dateRefs = useRef<Record<string, string>>({\n startDay: '',\n startMonth: '',\n startYear: '',\n endDay: '',\n endMonth: '',\n endYear: '',\n })\n\n // Keep dateRefs in sync with inputDates on re-render\n syncDateRefs(dateRefs, inputDates)\n\n const temporaryDates = useRef<Record<string, Date>>({\n startDate: undefined,\n endDate: undefined,\n })\n\n const refList = useRef<Array<MutableRefObject<HTMLInputElement>>>()\n\n const focusMode = useRef<string>()\n\n const maskList = useMemo(() => {\n const separators = maskOrder.match(separatorRegExp)\n\n return maskOrder\n .split(separatorRegExp)\n .reduce<Array<string>>((acc, cur) => {\n if (!cur) {\n return acc\n }\n\n acc.push(cur)\n\n if (separators.length > 0) {\n // makes sure that separators are added at the correct places and removed from array when added\n acc.push(separators.shift())\n }\n\n return acc\n }, [])\n }, [maskOrder, separatorRegExp])\n\n const pasteHandler = useCallback(\n async (event: React.ClipboardEvent<HTMLInputElement>) => {\n if (!focusMode.current) {\n return // Stop here\n }\n\n const success = (\n event.clipboardData ||\n (typeof window !== 'undefined' && window['clipboardData'])\n ).getData('text')\n\n if (!success) {\n return // Stop here\n }\n\n event.preventDefault()\n\n try {\n const separators = ['.', '/']\n const possibleFormats = ['yyyy-MM-dd']\n\n // TODO: Merge these loops\n possibleFormats.forEach((date) => {\n separators.forEach((sep) => {\n possibleFormats.push(date.replace(/-/g, sep))\n })\n })\n\n possibleFormats.forEach((date) => {\n possibleFormats.push(date.split('').reverse().join(''))\n })\n\n let date: Date\n let index = 0\n\n for (index; index < possibleFormats.length; ++index) {\n date = convertStringToDate(success, {\n dateFormat: possibleFormats[index],\n })\n\n if (date) {\n break\n }\n }\n\n const mode =\n focusMode.current === 'start' ? 'startDate' : 'endDate'\n\n if (date) {\n updateDates({\n [mode]: date,\n })\n }\n } catch (error: unknown) {\n warn(error)\n }\n },\n [updateDates]\n )\n\n const callOnChangeAsInvalid = useCallback(\n (state: {\n endDate?: Date\n starDate?: Date\n event: React.ChangeEvent<HTMLInputElement>\n }) => {\n updateDates(\n {\n hoverDate: null,\n },\n (dates) => {\n // Should fire if user has filled out an invalid date,\n // or if the date was valid. Like if the user has pressed backspace or removed the valid date.\n if (isDateFullyFilledOutRef.current || hasHadValidDate) {\n const { startDate, endDate, event } = {\n ...state,\n ...dates,\n }\n callOnChangeHandler({\n startDate,\n endDate,\n event,\n ...invalidDatesRef.current,\n })\n }\n }\n )\n },\n [updateDates, callOnChangeHandler, hasHadValidDate]\n )\n\n const callOnChange = useCallback(\n ({\n startDate,\n endDate,\n event,\n }: {\n startDate?: Date\n endDate?: Date\n event:\n | React.ChangeEvent<HTMLInputElement>\n | React.KeyboardEvent<HTMLInputElement>\n }) => {\n const state = {}\n if (typeof startDate !== 'undefined' && isValid(startDate)) {\n state['startDate'] = startDate\n }\n if (!isRange) {\n endDate = startDate\n }\n if (typeof endDate !== 'undefined' && isValid(endDate)) {\n state['endDate'] = endDate\n }\n\n updateDates(state, (dates) => {\n if (\n (typeof startDate !== 'undefined' && isValid(startDate)) ||\n (typeof endDate !== 'undefined' && isValid(endDate))\n ) {\n callOnChangeHandler({\n event,\n ...dates,\n ...invalidDatesRef.current,\n })\n }\n })\n },\n [updateDates, callOnChangeHandler, isRange]\n )\n\n const callOnType = useCallback(\n ({ event }: { event: React.ChangeEvent<HTMLInputElement> }) => {\n const getDates = () =>\n ['start', 'end'].reduce(\n (acc, mode) => {\n acc[`${mode}Date`] = [\n dateRefs.current[`${mode}Year`] ||\n inputDates[`__${mode}Year`] ||\n 'yyyy',\n dateRefs.current[`${mode}Month`] ||\n inputDates[`__${mode}Month`] ||\n 'mm',\n dateRefs.current[`${mode}Day`] ||\n inputDates[`__${mode}Day`] ||\n 'dd',\n ].join('-')\n return acc\n },\n { startDate: undefined, endDate: undefined }\n )\n\n // Get the typed dates, so we can ...\n const { startDate, endDate } = getDates()\n\n // Get the partial dates, so we can know if something was typed or not in an optional date field\n setPartialDates({\n partialStartDate: startDate,\n // Only set endDate if in range mode\n ...(isRange && { partialEndDate: endDate }),\n })\n\n const parsedStartDate = parseISO(startDate)\n const parsedEndDate = parseISO(endDate)\n\n const isStartDateValid = isValid(parsedStartDate)\n const isEndDateValid = isValid(parsedEndDate)\n\n const {\n is_valid,\n is_valid_start_date,\n is_valid_end_date,\n ...returnObject\n } = getReturnObject({\n startDate: isStartDateValid ? parsedStartDate : null,\n endDate: isEndDateValid ? parsedEndDate : null,\n event,\n ...partialDatesRef.current,\n ...invalidDatesRef.current,\n })\n\n // Re-assigns dates to the typed date, instead of `null` from getReturnObject, if dates are invalid\n const typedDates = {\n ...(!isRange && is_valid === false && { date: startDate }),\n ...(isRange &&\n is_valid_start_date === false && { start_date: startDate }),\n ...(isRange &&\n is_valid_end_date === false && { end_date: endDate }),\n }\n\n onType?.({\n is_valid,\n is_valid_start_date,\n is_valid_end_date,\n ...returnObject,\n ...typedDates,\n })\n },\n [\n setPartialDates,\n isRange,\n getReturnObject,\n partialDatesRef,\n onType,\n inputDates,\n ]\n )\n\n const setDate = useCallback(\n (\n event: React.ChangeEvent<HTMLInputElement>,\n mode: 'start' | 'end',\n type: 'Day' | 'Month' | 'Year'\n ) => {\n event.persist() // since we have later a state update and afterwards the callback\n\n const value = (event.target as HTMLInputElement).value\n\n dateRefs.current[`${mode}${type}`] = value\n\n if (modeDate[`${mode}Date`]) {\n temporaryDates.current[`${mode}Date`] = modeDate[`${mode}Date`]\n }\n\n const fallback = temporaryDates.current[`${mode}Date`]\n\n // provide fallbacks to create a temp fallback\n const year =\n dateRefs.current[`${mode}Year`] ||\n (fallback && fallback.getFullYear())\n const month =\n dateRefs.current[`${mode}Month`] ||\n (fallback && fallback.getMonth() + 1)\n const day =\n dateRefs.current[`${mode}Day`] || (fallback && fallback.getDate())\n\n // calculate new date\n const date = new Date(\n parseFloat(String(year)),\n parseFloat(String(month)) - 1,\n parseFloat(String(day))\n )\n\n const isValidDate =\n !/[^0-9]/.test(String(day)) &&\n !/[^0-9]/.test(String(month)) &&\n !/[^0-9]/.test(String(year)) &&\n isValid(date) &&\n date.getDate() == parseFloat(String(day)) &&\n date.getMonth() + 1 == parseFloat(String(month)) &&\n date.getFullYear() == parseFloat(String(year))\n\n const dateString = `${year}-${month}-${day}`\n\n isDateFullyFilledOutRef.current =\n /^[0-9]{4}-[0-9]{2}-[0-9]{2}$/.test(dateString)\n\n // update the date\n if (isValidDate) {\n invalidDatesRef.current = {\n ...invalidDatesRef.current,\n ...(mode === 'start'\n ? { invalidStartDate: null }\n : { invalidEndDate: null }),\n }\n\n callOnChange({\n [`${mode}Date`]: date,\n event,\n })\n } else {\n updateDates({\n [`${mode}Date`]: null,\n [`__${mode}${type}`]: value,\n })\n\n invalidDatesRef.current = {\n ...invalidDatesRef.current,\n ...(mode === 'start'\n ? { invalidStartDate: dateString }\n : { invalidEndDate: dateString }),\n }\n\n callOnChangeAsInvalid({\n [`${mode}Date`]: null,\n event,\n })\n }\n\n callOnType({ event })\n },\n [\n updateDates,\n callOnChange,\n callOnChangeAsInvalid,\n callOnType,\n modeDate,\n dateRefs,\n temporaryDates,\n ]\n )\n\n const dateSetters = useMemo(\n () => ({\n set_startDay: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'start', 'Day')\n },\n\n set_startMonth: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'start', 'Month')\n },\n\n set_startYear: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'start', 'Year')\n },\n\n set_endDay: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'end', 'Day')\n },\n\n set_endMonth: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'end', 'Month')\n },\n\n set_endYear: (event: React.ChangeEvent<HTMLInputElement>) => {\n setDate(event, 'end', 'Year')\n },\n }),\n [setDate]\n )\n\n const onFocusHandler = useCallback(\n (event: React.FocusEvent<HTMLInputElement>) => {\n setFocusState('focus')\n\n onFocus?.({\n ...event,\n ...getReturnObject({ event }),\n })\n\n if (isNaN(parseFloat(event.target.value))) {\n setCursorPosition(event.target)\n }\n },\n [getReturnObject, onFocus]\n )\n\n const onBlurHandler = useCallback(\n (event: React.FocusEvent<HTMLInputElement>) => {\n focusMode.current = null\n setFocusState('blur')\n\n onBlur?.({\n ...event,\n ...getReturnObject({ event, ...partialDatesRef.current }),\n })\n },\n [onBlur, getReturnObject, partialDatesRef]\n )\n\n const onKeyDownHandler = useCallback(\n async (event: React.KeyboardEvent<HTMLInputElement>) => {\n const keyCode = event.key\n const target = event.target as HTMLInputElement\n\n if (\n correctInvalidDate &&\n target.selectionStart !== target.selectionEnd\n ) {\n setCursorPosition(target)\n }\n\n // The rest is for value entry\n\n const size = parseFloat(target.getAttribute('size'))\n const firstSelectionStart = target.selectionStart\n const firstSelectionEnd = target.selectionEnd\n\n // To get the correct position afterwards.\n // Use 10ms in order to make it work on iOS Safari\n await wait(IS_IOS ? 10 : 1)\n\n const secondSelectionStart = target.selectionStart\n\n // Always false (since the old keycode function set number keys to undefined) but needed to not break tests\n const isValid = /[0-9]/g.test(keyCode)\n const refListArray = refList.current\n\n const index = refListArray.findIndex(\n ({ current }) => current === target\n )\n\n const isLastChar = secondSelectionStart === size\n const isFirstChar = firstSelectionStart === size\n\n const isMovingForward =\n keyCode !== 'ArrowLeft' &&\n keyCode !== 'Backspace' &&\n isValid &&\n isLastChar\n\n const isExplicitForward =\n (keyCode === 'ArrowRight' || keyCode === 'Enter') && isFirstChar\n\n const hasNextField = index < refListArray.length - 1\n\n if (hasNextField && (isMovingForward || isExplicitForward)) {\n // stop in case there is no next input element\n if (!refListArray[index + 1].current) {\n return // stop here\n }\n const nextSibling = refListArray[index + 1]?.current\n\n if (nextSibling) {\n setCursorPosition(nextSibling, 0, { withoutDelay: true })\n }\n\n // When the cursor is at the end of the input\n // and the user types a number, we want to set the value on the next input.\n if (\n parseFloat(keyCode) <= 9 &&\n firstSelectionStart === target.size\n ) {\n const name = toCapitalized(\n nextSibling\n .getAttribute('class')\n .match(/__input--(day|month|year)($|\\s)/)[1]\n )\n const mode = nextSibling\n .getAttribute('id')\n .match(/-(start|end)-(day|month|year)/)[1]\n\n dateSetters[`set_${mode}${name}`]({\n persist: () => null,\n ...event,\n target: {\n value: keyCode + nextSibling.value.slice(1),\n },\n })\n\n setCursorPosition(nextSibling, 1)\n }\n } else if (index > 0 && firstSelectionStart === firstSelectionEnd) {\n const isMovingBackward =\n keyCode === 'ArrowLeft' && firstSelectionStart === 0\n const isPressingBackspace =\n keyCode === 'Backspace' && firstSelectionStart <= 1\n\n if (isMovingBackward || isPressingBackspace) {\n const prevSibling = refListArray[index - 1]?.current\n if (prevSibling) {\n const endPos = prevSibling.value.length\n setCursorPosition(prevSibling, endPos, {\n withoutDelay: true,\n })\n }\n }\n }\n },\n [correctInvalidDate, dateSetters]\n )\n\n const onInputHandler = useCallback(\n (event) => {\n const target = event.currentTarget\n\n // Add support for \"backspace\" on Android virtual keyboard\n if (\n IS_ANDROID &&\n event.nativeEvent.inputType === 'deleteContentBackward' &&\n target.selectionStart === 0 &&\n target.selectionEnd === 0\n ) {\n onKeyDownHandler({\n ...event,\n key: 'Backspace',\n })\n }\n },\n [onKeyDownHandler]\n )\n\n const getPlaceholderChar = useCallback(\n (value: string) => {\n const index = maskOrder.indexOf(value)\n return maskPlaceholder[index]\n },\n [maskOrder, maskPlaceholder]\n )\n\n // TODO: Replace with MultiInputMask\n const generateDateList = useCallback(\n (\n element: Omit<React.HTMLProps<HTMLInputElement>, 'size'> &\n DatePickerEventAttributes,\n mode: 'start' | 'end'\n ) => {\n return maskList.map((value, i) => {\n const state = value.slice(0, 1)\n const placeholderChar = getPlaceholderChar(value)\n const { day, month, year } = translation\n const isRangeLabel = isRange ? `${translation[mode]} ` : ''\n\n if (!separatorRegExp.test(value)) {\n if (!inputElement) {\n element = {\n ...element,\n onInput: onInputHandler,\n onKeyDown: onKeyDownHandler,\n onPaste: pasteHandler,\n onFocus: (e) => {\n focusMode.current = mode\n onFocusHandler(e)\n },\n onBlur: onBlurHandler,\n placeholderChar,\n }\n }\n\n // this makes it possible to use a vanilla <input /> like: input_element=\"input\"\n const DateField =\n inputElement && React.isValidElement(inputElement)\n ? inputElement.type\n : InputElement\n\n const inputSizeClassName =\n size && `dnb-date-picker__input--${size}`\n\n switch (state) {\n case 'd':\n refList.current.push(inputRefs.current[`${mode}DayRef`])\n\n return (\n <React.Fragment key={'dd' + i}>\n <DateField\n {...element}\n id={`${id}-${mode}-day`}\n key={'di' + i}\n className={classnames(\n element.className,\n 'dnb-date-picker__input',\n 'dnb-date-picker__input--day',\n inputSizeClassName\n )}\n size={2}\n mask={[/[0-9]/, /[0-9]/]}\n inputRef={inputRefs.current[`${mode}DayRef`]}\n onChange={dateSetters[`set_${mode}Day`]}\n value={inputDates[`__${mode}Day`] || ''}\n aria-labelledby={`${id}-${mode}-day-label`}\n />\n <label\n key={'dl' + i}\n hidden\n id={`${id}-${mode}-day-label`}\n htmlFor={`${id}-${mode}-day`}\n >\n {isRangeLabel + day}\n </label>\n </React.Fragment>\n )\n case 'm':\n refList.current.push(inputRefs.current[`${mode}MonthRef`])\n\n return (\n <React.Fragment key={'mm' + i}>\n <DateField\n {...element}\n id={`${id}-${mode}-month`}\n key={'mi' + i}\n className={classnames(\n element.className,\n 'dnb-date-picker__input',\n 'dnb-date-picker__input--month',\n inputSizeClassName\n )}\n size={2}\n mask={[/[0-9]/, /[0-9]/]}\n inputRef={inputRefs.current[`${mode}MonthRef`]}\n onChange={dateSetters[`set_${mode}Month`]}\n value={inputDates[`__${mode}Month`] || ''}\n aria-labelledby={`${id}-${mode}-month-label`}\n />\n <label\n key={'ml' + i}\n hidden\n id={`${id}-${mode}-month-label`}\n htmlFor={`${id}-${mode}-month`}\n >\n {isRangeLabel + month}\n </label>\n </React.Fragment>\n )\n case 'y':\n refList.current.push(inputRefs.current[`${mode}YearRef`])\n\n return (\n <React.Fragment key={'yy' + i}>\n <DateField\n {...element}\n id={`${id}-${mode}-year`}\n key={'yi' + i}\n className={classnames(\n element.className,\n 'dnb-date-picker__input',\n 'dnb-date-picker__input--year',\n inputSizeClassName\n )}\n size={4}\n mask={[/[0-9]/, /[0-9]/, /[0-9]/, /[0-9]/]}\n inputRef={inputRefs.current[`${mode}YearRef`]}\n onChange={dateSetters[`set_${mode}Year`]}\n value={inputDates[`__${mode}Year`] || ''}\n aria-labelledby={`${id}-${mode}-year-label`}\n />\n <label\n key={'yl' + i}\n hidden\n id={`${id}-${mode}-year-label`}\n htmlFor={`${id}-${mode}-year`}\n >\n {isRangeLabel + year}\n </label>\n </React.Fragment>\n )\n }\n }\n return (\n <span\n key={'s' + i}\n className=\"dnb-date-picker--separator\"\n aria-hidden\n >\n {placeholderChar}\n </span>\n )\n })\n },\n [\n maskList,\n getPlaceholderChar,\n translation,\n isRange,\n separatorRegExp,\n inputElement,\n size,\n onInputHandler,\n onKeyDownHandler,\n pasteHandler,\n onBlurHandler,\n onFocusHandler,\n id,\n dateSetters,\n inputDates,\n ]\n )\n\n const renderInputElement = useCallback(\n (\n element: React.HTMLProps<HTMLInputElement> &\n DatePickerEventAttributes\n ) => {\n refList.current = []\n const startDateList = generateDateList(element, 'start')\n const endDateList = generateDateList(element, 'end')\n\n return (\n <span\n id={`${id}-input`}\n className=\"dnb-date-picker__input__wrapper\"\n >\n {startDateList}\n {isRange && (\n <span className=\"dnb-date-picker--separator\" aria-hidden>\n {' – '}\n </span>\n )}\n {isRange && endDateList}\n </span>\n )\n },\n [id, isRange, generateDateList]\n )\n\n const ariaLabel = useMemo(\n () =>\n selectedDateTitle\n ? `${selectedDateTitle}, ${translation.openPickerText}`\n : translation.openPickerText,\n [selectedDateTitle, translation]\n )\n\n validateDOMAttributes(props, attributes)\n validateDOMAttributes(null, submitAttributes)\n\n const SubmitElement: React.ElementType = useMemo(\n () => (showInput ? SubmitButton : Button),\n [showInput]\n )\n\n if (!showInput) {\n // Use Button inner ref\n submitAttributes.innerRef = submitAttributes.ref\n submitAttributes.ref = null\n }\n\n return (\n <fieldset className=\"dnb-date-picker__fieldset\" lang={lang}>\n {label && <legend className=\"dnb-sr-only\">{label}</legend>}\n <Input\n id={`${id}__input`}\n input_state={disabled ? 'disabled' : focusState}\n input_element={\n inputElement && typeof inputElement !== 'string'\n ? typeof inputElement === 'function'\n ? inputElement(props)\n : inputElement\n : renderInputElement\n }\n disabled={disabled || skeleton}\n skeleton={skeleton}\n size={size}\n status={!opened ? status : null}\n status_state={statusState}\n {...statusProps}\n submit_element={\n <SubmitElement\n id={id}\n disabled={disabled}\n skeleton={skeleton}\n className={classnames(\n showInput && 'dnb-button--input-button',\n opened ? 'dnb-button--active' : null\n )}\n aria-label={ariaLabel}\n title={title}\n size={size}\n status={status}\n status_state={statusState}\n type=\"button\"\n icon=\"calendar\"\n variant=\"secondary\"\n on_submit={onSubmit}\n on_click={onSubmit}\n {...submitAttributes}\n {...statusProps}\n />\n }\n lang={lang}\n {...attributes}\n />\n </fieldset>\n )\n}\n\nexport default DatePickerInput\n\nfunction setCursorPosition(\n target: HTMLInputElement,\n position = 0,\n options?: { withoutDelay?: boolean }\n) {\n target.focus()\n\n const select = () => {\n target.setSelectionRange(position, position)\n }\n\n // Delay for correct iOS Safari appearance\n if (!options?.withoutDelay && process.env.NODE_ENV !== 'test') {\n setTimeout(select, 0)\n } else {\n select()\n }\n}\n\nfunction InputElement({ className, value, ...props }: TextMaskProps) {\n return (\n <TextMask\n guide={true}\n inputMode=\"numeric\"\n showMask={true}\n keepCharPositions={false} // so we can overwrite next value, if it already exists\n autoComplete=\"off\"\n autoCapitalize=\"none\"\n spellCheck={false}\n autoCorrect=\"off\"\n className={classnames(\n className,\n /\\d+/.test(String(value)) && 'dnb-date-picker__input--highlight'\n )}\n value={value}\n {...props}\n />\n )\n}\n\nfunction syncDateRefs(\n dateRefs: React.MutableRefObject<Record<string, string>>,\n inputDates: DatePickerInputDates\n) {\n for (const date in dateRefs.current) {\n const dateRefValue = dateRefs.current[date]\n const inputDateValue = inputDates[`__${date}`]\n\n if (dateRefValue !== inputDateValue) {\n dateRefs.current[date] = inputDateValue\n }\n }\n}\n\nconst wait = (duration: number) =>\n new Promise((r) => setTimeout(r, duration))\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -43,7 +43,6 @@ function DatePickerProvider(externalProps) {
|
|
|
43
43
|
const {
|
|
44
44
|
dates,
|
|
45
45
|
updateDates,
|
|
46
|
-
hasHadValidDate,
|
|
47
46
|
previousDateProps
|
|
48
47
|
} = useDates({
|
|
49
48
|
date,
|
|
@@ -137,7 +136,6 @@ function DatePickerProvider(externalProps) {
|
|
|
137
136
|
props
|
|
138
137
|
}, dates), {}, {
|
|
139
138
|
previousDateProps,
|
|
140
|
-
hasHadValidDate,
|
|
141
139
|
views,
|
|
142
140
|
setViews,
|
|
143
141
|
setHasClickedCalendarDay
|