@dnb/eufemia 10.63.3 → 10.64.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 +50 -0
- package/assets/icons/dnb/calendar_add.svg +1 -0
- package/assets/icons/dnb/calendar_add_medium.svg +1 -0
- package/assets/icons/dnb/cog_medium.svg +1 -1
- package/assets/icons/dnb/digipass_corporate.svg +1 -1
- package/assets/icons/dnb/digipass_corporate_medium.svg +1 -1
- package/assets/icons/dnb/digipass_private.svg +1 -1
- package/assets/icons/dnb/digipass_private_medium.svg +1 -1
- package/assets/icons/dnb/digitpass_private_corporate.svg +1 -0
- package/assets/icons/dnb/digitpass_private_corporate_medium.svg +1 -0
- package/assets/icons/dnb/eufemia-icons-xml-categorized.tgz +0 -0
- package/assets/icons/dnb/eufemia-icons-xml.tgz +0 -0
- package/assets/icons/dnb/goal.svg +1 -0
- package/assets/icons/dnb/goal_medium.svg +1 -0
- package/assets/icons/dnb/information.svg +1 -1
- package/assets/icons/dnb/investor.svg +1 -0
- package/assets/icons/dnb/investor_medium.svg +1 -0
- package/assets/icons/dnb/layout_grid.svg +1 -0
- package/assets/icons/dnb/layout_grid_medium.svg +1 -0
- package/assets/icons/dnb/question.svg +1 -1
- package/assets/icons/dnb/question_circled.svg +1 -1
- package/assets/icons/dnb/question_medium.svg +1 -1
- package/assets/icons/dnb/return_1_medium.svg +1 -1
- package/assets/icons/dnb/show_pin.svg +1 -0
- package/assets/icons/dnb/show_pin_medium.svg +1 -0
- package/assets/icons/dnb/table.svg +1 -0
- package/assets/icons/dnb/table_medium.svg +1 -0
- package/cjs/components/button/style/themes/dnb-button-theme-ui.scss +1 -1
- package/cjs/components/date-picker/DatePickerCalc.js +1 -1
- package/cjs/components/date-picker/DatePickerCalc.js.map +1 -1
- package/cjs/components/drawer/style/dnb-drawer.css +4 -4
- package/cjs/components/drawer/style/dnb-drawer.min.css +1 -1
- package/cjs/components/drawer/style/dnb-drawer.scss +4 -4
- package/cjs/components/dropdown/Dropdown.d.ts +1 -1
- package/cjs/components/form-status/FormStatus.js +3 -2
- package/cjs/components/form-status/FormStatus.js.map +1 -1
- package/cjs/components/heading/HeadingCounter.js +4 -4
- package/cjs/components/heading/HeadingCounter.js.map +1 -1
- package/cjs/components/input/Input.js +1 -1
- package/cjs/components/input/Input.js.map +1 -1
- package/cjs/components/radio/Radio.d.ts +1 -1
- package/cjs/components/radio/RadioGroup.d.ts +1 -1
- package/cjs/components/section/Section.d.ts +1 -1
- 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/textarea/Textarea.js +8 -1
- package/cjs/components/textarea/Textarea.js.map +1 -1
- package/cjs/elements/lists/style/lists-mixins.scss +1 -1
- package/cjs/extensions/forms/Connectors/Bring/index.d.ts +1 -0
- package/cjs/extensions/forms/Connectors/Bring/index.js +11 -0
- package/cjs/extensions/forms/Connectors/Bring/index.js.map +1 -0
- package/cjs/extensions/forms/Connectors/Bring/postalCode.d.ts +25 -0
- package/cjs/extensions/forms/Connectors/Bring/postalCode.js +164 -0
- package/cjs/extensions/forms/Connectors/Bring/postalCode.js.map +1 -0
- package/cjs/extensions/forms/Connectors/createContext.d.ts +58 -0
- package/cjs/extensions/forms/Connectors/createContext.js +130 -0
- package/cjs/extensions/forms/Connectors/createContext.js.map +1 -0
- package/cjs/extensions/forms/Connectors/index.d.ts +2 -0
- package/cjs/extensions/forms/Connectors/index.js +26 -0
- package/cjs/extensions/forms/Connectors/index.js.map +1 -0
- package/cjs/extensions/forms/DataContext/Context.d.ts +4 -1
- package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
- package/cjs/extensions/forms/DataContext/Provider/Provider.js +30 -16
- package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/cjs/extensions/forms/Field/Address/Address.d.ts +9 -0
- package/cjs/extensions/forms/Field/Address/Address.js +63 -0
- package/cjs/extensions/forms/Field/Address/Address.js.map +1 -0
- package/cjs/extensions/forms/Field/Address/AddressDocs.d.ts +2 -0
- package/cjs/extensions/forms/Field/Address/AddressDocs.js +15 -0
- package/cjs/extensions/forms/Field/Address/AddressDocs.js.map +1 -0
- package/cjs/extensions/forms/Field/Address/index.d.ts +2 -0
- package/cjs/extensions/forms/Field/Address/index.js +27 -0
- package/cjs/extensions/forms/Field/Address/index.js.map +1 -0
- package/cjs/extensions/forms/Field/Email/EmailDocs.d.ts +2 -0
- package/cjs/extensions/forms/Field/Email/EmailDocs.js +15 -0
- package/cjs/extensions/forms/Field/Email/EmailDocs.js.map +1 -0
- package/cjs/extensions/forms/Field/Expiry/Expiry.js +83 -32
- package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
- package/cjs/extensions/forms/Field/Name/Name.js +2 -2
- package/cjs/extensions/forms/Field/Name/Name.js.map +1 -1
- package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +1 -0
- package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +10 -0
- package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/Password/PasswordDocs.d.ts +2 -0
- package/cjs/extensions/forms/Field/Password/PasswordDocs.js +30 -0
- package/cjs/extensions/forms/Field/Password/PasswordDocs.js.map +1 -0
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +10 -0
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +23 -10
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +3 -3
- package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +4 -4
- package/cjs/extensions/forms/Field/index.d.ts +1 -0
- package/cjs/extensions/forms/Field/index.js +7 -0
- package/cjs/extensions/forms/Field/index.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlock.js +0 -1
- package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +4 -0
- package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
- package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -0
- package/cjs/extensions/forms/Iterate/Array/Array.js +7 -2
- package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
- package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +5 -0
- package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/cjs/extensions/forms/Iterate/Array/types.d.ts +1 -0
- package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +4 -0
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +3 -2
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
- package/cjs/extensions/forms/Value/Address/Address.d.ts +9 -0
- package/cjs/extensions/forms/Value/Address/Address.js +41 -0
- package/cjs/extensions/forms/Value/Address/Address.js.map +1 -0
- package/cjs/extensions/forms/Value/Address/index.d.ts +2 -0
- package/cjs/extensions/forms/Value/Address/index.js +27 -0
- package/cjs/extensions/forms/Value/Address/index.js.map +1 -0
- package/cjs/extensions/forms/Value/PostalCodeAndCity/PostalCodeAndCityDocs.js +1 -1
- package/cjs/extensions/forms/Value/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
- package/cjs/extensions/forms/Value/index.d.ts +1 -0
- package/cjs/extensions/forms/Value/index.js +7 -0
- package/cjs/extensions/forms/Value/index.js.map +1 -1
- package/cjs/extensions/forms/Wizard/Step/Step.js +2 -2
- package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
- package/cjs/extensions/forms/constants/locales/en-GB.d.ts +13 -0
- package/cjs/extensions/forms/constants/locales/en-GB.js +20 -7
- package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
- package/cjs/extensions/forms/constants/locales/en-US.d.ts +13 -0
- package/cjs/extensions/forms/constants/locales/index.d.ts +26 -0
- package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +13 -0
- package/cjs/extensions/forms/constants/locales/nb-NO.js +16 -3
- package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
- package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js +3 -3
- package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/cjs/extensions/forms/hooks/useFieldProps.d.ts +8 -4
- package/cjs/extensions/forms/hooks/useFieldProps.js +39 -19
- package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/cjs/extensions/forms/index.d.ts +1 -0
- package/cjs/extensions/forms/index.js +4 -1
- package/cjs/extensions/forms/index.js.map +1 -1
- package/cjs/extensions/forms/style/dnb-forms.css +4 -0
- package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
- package/cjs/extensions/forms/types.d.ts +34 -10
- package/cjs/extensions/forms/types.js.map +1 -1
- package/cjs/extensions/forms/utils/json-pointer/json-pointer.js +1 -1
- package/cjs/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
- package/cjs/icons/calendar_add.d.ts +3 -0
- package/cjs/icons/calendar_add.js +11 -0
- package/cjs/icons/calendar_add.js.map +1 -0
- package/cjs/icons/calendar_add_medium.d.ts +3 -0
- package/cjs/icons/calendar_add_medium.js +11 -0
- package/cjs/icons/calendar_add_medium.js.map +1 -0
- package/cjs/icons/digitpass_private_corporate.d.ts +3 -0
- package/cjs/icons/digitpass_private_corporate.js +11 -0
- package/cjs/icons/digitpass_private_corporate.js.map +1 -0
- package/cjs/icons/digitpass_private_corporate_medium.d.ts +3 -0
- package/cjs/icons/digitpass_private_corporate_medium.js +11 -0
- package/cjs/icons/digitpass_private_corporate_medium.js.map +1 -0
- package/cjs/icons/dnb/calendar_add.d.ts +3 -0
- package/cjs/icons/dnb/calendar_add.js +31 -0
- package/cjs/icons/dnb/calendar_add.js.map +1 -0
- package/cjs/icons/dnb/calendar_add_medium.d.ts +3 -0
- package/cjs/icons/dnb/calendar_add_medium.js +25 -0
- package/cjs/icons/dnb/calendar_add_medium.js.map +1 -0
- package/cjs/icons/dnb/cog_medium.js +1 -1
- package/cjs/icons/dnb/cog_medium.js.map +1 -1
- package/cjs/icons/dnb/digipass_corporate.js +3 -3
- package/cjs/icons/dnb/digipass_corporate.js.map +1 -1
- package/cjs/icons/dnb/digipass_corporate_medium.js +3 -3
- package/cjs/icons/dnb/digipass_corporate_medium.js.map +1 -1
- package/cjs/icons/dnb/digipass_private.js +3 -3
- package/cjs/icons/dnb/digipass_private.js.map +1 -1
- package/cjs/icons/dnb/digipass_private_medium.js +3 -3
- package/cjs/icons/dnb/digipass_private_medium.js.map +1 -1
- package/cjs/icons/dnb/digitpass_private_corporate.d.ts +3 -0
- package/cjs/icons/dnb/digitpass_private_corporate.js +25 -0
- package/cjs/icons/dnb/digitpass_private_corporate.js.map +1 -0
- package/cjs/icons/dnb/digitpass_private_corporate_medium.d.ts +3 -0
- package/cjs/icons/dnb/digitpass_private_corporate_medium.js +25 -0
- package/cjs/icons/dnb/digitpass_private_corporate_medium.js.map +1 -0
- package/cjs/icons/dnb/goal.d.ts +3 -0
- package/cjs/icons/dnb/goal.js +26 -0
- package/cjs/icons/dnb/goal.js.map +1 -0
- package/cjs/icons/dnb/goal_medium.d.ts +3 -0
- package/cjs/icons/dnb/goal_medium.js +26 -0
- package/cjs/icons/dnb/goal_medium.js.map +1 -0
- package/cjs/icons/dnb/icons-meta.json +132 -4
- package/cjs/icons/dnb/icons-svg.lock +1278 -1096
- package/cjs/icons/dnb/index.d.ts +15 -1
- package/cjs/icons/dnb/index.js +98 -0
- package/cjs/icons/dnb/index.js.map +1 -1
- package/cjs/icons/dnb/information.js +1 -1
- package/cjs/icons/dnb/information.js.map +1 -1
- package/cjs/icons/dnb/investor.d.ts +3 -0
- package/cjs/icons/dnb/investor.js +33 -0
- package/cjs/icons/dnb/investor.js.map +1 -0
- package/cjs/icons/dnb/investor_medium.d.ts +3 -0
- package/cjs/icons/dnb/investor_medium.js +33 -0
- package/cjs/icons/dnb/investor_medium.js.map +1 -0
- package/cjs/icons/dnb/layout_grid.d.ts +3 -0
- package/cjs/icons/dnb/layout_grid.js +34 -0
- package/cjs/icons/dnb/layout_grid.js.map +1 -0
- package/cjs/icons/dnb/layout_grid_medium.d.ts +3 -0
- package/cjs/icons/dnb/layout_grid_medium.js +34 -0
- package/cjs/icons/dnb/layout_grid_medium.js.map +1 -0
- package/cjs/icons/dnb/question.js +1 -1
- package/cjs/icons/dnb/question.js.map +1 -1
- package/cjs/icons/dnb/question_circled.js +1 -1
- package/cjs/icons/dnb/question_circled.js.map +1 -1
- package/cjs/icons/dnb/question_medium.js +1 -1
- package/cjs/icons/dnb/question_medium.js.map +1 -1
- package/cjs/icons/dnb/return_1_medium.js +1 -1
- package/cjs/icons/dnb/return_1_medium.js.map +1 -1
- package/cjs/icons/dnb/secondary_icons.d.ts +8 -1
- package/cjs/icons/dnb/secondary_icons.js +49 -0
- package/cjs/icons/dnb/secondary_icons.js.map +1 -1
- package/cjs/icons/dnb/secondary_icons_medium.d.ts +8 -1
- package/cjs/icons/dnb/secondary_icons_medium.js +49 -0
- package/cjs/icons/dnb/secondary_icons_medium.js.map +1 -1
- package/cjs/icons/dnb/show_pin.d.ts +3 -0
- package/cjs/icons/dnb/show_pin.js +23 -0
- package/cjs/icons/dnb/show_pin.js.map +1 -0
- package/cjs/icons/dnb/show_pin_medium.d.ts +3 -0
- package/cjs/icons/dnb/show_pin_medium.js +23 -0
- package/cjs/icons/dnb/show_pin_medium.js.map +1 -0
- package/cjs/icons/dnb/table.d.ts +3 -0
- package/cjs/icons/dnb/table.js +33 -0
- package/cjs/icons/dnb/table.js.map +1 -0
- package/cjs/icons/dnb/table_medium.d.ts +3 -0
- package/cjs/icons/dnb/table_medium.js +26 -0
- package/cjs/icons/dnb/table_medium.js.map +1 -0
- package/cjs/icons/goal.d.ts +3 -0
- package/cjs/icons/goal.js +11 -0
- package/cjs/icons/goal.js.map +1 -0
- package/cjs/icons/goal_medium.d.ts +3 -0
- package/cjs/icons/goal_medium.js +11 -0
- package/cjs/icons/goal_medium.js.map +1 -0
- package/cjs/icons/index.d.ts +15 -1
- package/cjs/icons/index.js +98 -0
- package/cjs/icons/index.js.map +1 -1
- package/cjs/icons/investor.d.ts +3 -0
- package/cjs/icons/investor.js +11 -0
- package/cjs/icons/investor.js.map +1 -0
- package/cjs/icons/investor_medium.d.ts +3 -0
- package/cjs/icons/investor_medium.js +11 -0
- package/cjs/icons/investor_medium.js.map +1 -0
- package/cjs/icons/layout_grid.d.ts +3 -0
- package/cjs/icons/layout_grid.js +11 -0
- package/cjs/icons/layout_grid.js.map +1 -0
- package/cjs/icons/layout_grid_medium.d.ts +3 -0
- package/cjs/icons/layout_grid_medium.js +11 -0
- package/cjs/icons/layout_grid_medium.js.map +1 -0
- package/cjs/icons/show_pin.d.ts +3 -0
- package/cjs/icons/show_pin.js +11 -0
- package/cjs/icons/show_pin.js.map +1 -0
- package/cjs/icons/show_pin_medium.d.ts +3 -0
- package/cjs/icons/show_pin_medium.js +11 -0
- package/cjs/icons/show_pin_medium.js.map +1 -0
- package/cjs/icons/table.d.ts +3 -0
- package/cjs/icons/table.js +11 -0
- package/cjs/icons/table.js.map +1 -0
- package/cjs/icons/table_medium.d.ts +3 -0
- package/cjs/icons/table_medium.js +11 -0
- package/cjs/icons/table_medium.js.map +1 -0
- 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/style/core/reset.scss +3 -9
- package/cjs/style/core/scopes.scss +1 -1
- package/cjs/style/dnb-ui-basis.css +4 -8
- package/cjs/style/dnb-ui-basis.min.css +1 -1
- package/cjs/style/dnb-ui-body.css +4 -8
- package/cjs/style/dnb-ui-body.min.css +1 -1
- package/cjs/style/dnb-ui-components.css +8 -4
- package/cjs/style/dnb-ui-components.min.css +2 -2
- package/cjs/style/dnb-ui-core.css +4 -8
- package/cjs/style/dnb-ui-core.min.css +1 -1
- package/cjs/style/dnb-ui-extensions.css +4 -0
- package/cjs/style/dnb-ui-extensions.min.css +1 -1
- package/cjs/style/dnb-ui-forms.css +4 -0
- package/cjs/style/dnb-ui-forms.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +12 -4
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
- package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +4 -0
- package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +4 -0
- package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +12 -4
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
- package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +4 -0
- package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +4 -0
- package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-components.css +12 -4
- package/cjs/style/themes/theme-ui/ui-theme-components.min.css +2 -2
- package/cjs/style/themes/theme-ui/ui-theme-extensions.css +4 -0
- package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-forms.css +4 -0
- package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
- package/components/button/style/themes/dnb-button-theme-ui.scss +1 -1
- package/components/date-picker/DatePickerCalc.js +1 -1
- package/components/date-picker/DatePickerCalc.js.map +1 -1
- package/components/drawer/style/dnb-drawer.css +4 -4
- package/components/drawer/style/dnb-drawer.min.css +1 -1
- package/components/drawer/style/dnb-drawer.scss +4 -4
- package/components/dropdown/Dropdown.d.ts +1 -1
- package/components/form-status/FormStatus.js +3 -2
- package/components/form-status/FormStatus.js.map +1 -1
- package/components/heading/HeadingCounter.js +4 -4
- package/components/heading/HeadingCounter.js.map +1 -1
- package/components/input/Input.js +1 -1
- package/components/input/Input.js.map +1 -1
- package/components/radio/Radio.d.ts +1 -1
- package/components/radio/RadioGroup.d.ts +1 -1
- package/components/section/Section.d.ts +1 -1
- 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/textarea/Textarea.js +8 -1
- package/components/textarea/Textarea.js.map +1 -1
- package/elements/lists/style/lists-mixins.scss +1 -1
- package/es/components/button/style/themes/dnb-button-theme-ui.scss +1 -1
- package/es/components/date-picker/DatePickerCalc.js +1 -1
- package/es/components/date-picker/DatePickerCalc.js.map +1 -1
- package/es/components/drawer/style/dnb-drawer.css +4 -4
- package/es/components/drawer/style/dnb-drawer.min.css +1 -1
- package/es/components/drawer/style/dnb-drawer.scss +4 -4
- package/es/components/dropdown/Dropdown.d.ts +1 -1
- package/es/components/form-status/FormStatus.js +3 -2
- package/es/components/form-status/FormStatus.js.map +1 -1
- package/es/components/heading/HeadingCounter.js +4 -4
- package/es/components/heading/HeadingCounter.js.map +1 -1
- package/es/components/input/Input.js +1 -1
- package/es/components/input/Input.js.map +1 -1
- package/es/components/radio/Radio.d.ts +1 -1
- package/es/components/radio/RadioGroup.d.ts +1 -1
- package/es/components/section/Section.d.ts +1 -1
- 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/textarea/Textarea.js +8 -1
- package/es/components/textarea/Textarea.js.map +1 -1
- package/es/elements/lists/style/lists-mixins.scss +1 -1
- package/es/extensions/forms/Connectors/Bring/index.d.ts +1 -0
- package/es/extensions/forms/Connectors/Bring/index.js +1 -0
- package/es/extensions/forms/Connectors/Bring/index.js.map +1 -0
- package/es/extensions/forms/Connectors/Bring/postalCode.d.ts +25 -0
- package/es/extensions/forms/Connectors/Bring/postalCode.js +150 -0
- package/es/extensions/forms/Connectors/Bring/postalCode.js.map +1 -0
- package/es/extensions/forms/Connectors/createContext.d.ts +58 -0
- package/es/extensions/forms/Connectors/createContext.js +116 -0
- package/es/extensions/forms/Connectors/createContext.js.map +1 -0
- package/es/extensions/forms/Connectors/index.d.ts +2 -0
- package/es/extensions/forms/Connectors/index.js +3 -0
- package/es/extensions/forms/Connectors/index.js.map +1 -0
- package/es/extensions/forms/DataContext/Context.d.ts +4 -1
- package/es/extensions/forms/DataContext/Context.js.map +1 -1
- package/es/extensions/forms/DataContext/Provider/Provider.js +25 -14
- package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/es/extensions/forms/Field/Address/Address.d.ts +9 -0
- package/es/extensions/forms/Field/Address/Address.js +51 -0
- package/es/extensions/forms/Field/Address/Address.js.map +1 -0
- package/es/extensions/forms/Field/Address/AddressDocs.d.ts +2 -0
- package/es/extensions/forms/Field/Address/AddressDocs.js +8 -0
- package/es/extensions/forms/Field/Address/AddressDocs.js.map +1 -0
- package/es/extensions/forms/Field/Address/index.d.ts +2 -0
- package/es/extensions/forms/Field/Address/index.js +3 -0
- package/es/extensions/forms/Field/Address/index.js.map +1 -0
- package/es/extensions/forms/Field/Email/EmailDocs.d.ts +2 -0
- package/es/extensions/forms/Field/Email/EmailDocs.js +8 -0
- package/es/extensions/forms/Field/Email/EmailDocs.js.map +1 -0
- package/es/extensions/forms/Field/Expiry/Expiry.js +82 -31
- package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
- package/es/extensions/forms/Field/Name/Name.js +2 -2
- package/es/extensions/forms/Field/Name/Name.js.map +1 -1
- package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +1 -0
- package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +9 -0
- package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
- package/es/extensions/forms/Field/Password/PasswordDocs.d.ts +2 -0
- package/es/extensions/forms/Field/Password/PasswordDocs.js +23 -0
- package/es/extensions/forms/Field/Password/PasswordDocs.js.map +1 -0
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +10 -0
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +23 -10
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +3 -3
- package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
- package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +4 -4
- package/es/extensions/forms/Field/index.d.ts +1 -0
- package/es/extensions/forms/Field/index.js +1 -0
- package/es/extensions/forms/Field/index.js.map +1 -1
- package/es/extensions/forms/FieldBlock/FieldBlock.js +0 -1
- package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +4 -0
- package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
- package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -0
- package/es/extensions/forms/Iterate/Array/Array.js +7 -2
- package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
- package/es/extensions/forms/Iterate/Array/ArrayDocs.js +5 -0
- package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/es/extensions/forms/Iterate/Array/types.d.ts +1 -0
- package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +4 -0
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +3 -2
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
- package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
- package/es/extensions/forms/Value/Address/Address.d.ts +9 -0
- package/es/extensions/forms/Value/Address/Address.js +31 -0
- package/es/extensions/forms/Value/Address/Address.js.map +1 -0
- package/es/extensions/forms/Value/Address/index.d.ts +2 -0
- package/es/extensions/forms/Value/Address/index.js +3 -0
- package/es/extensions/forms/Value/Address/index.js.map +1 -0
- package/es/extensions/forms/Value/PostalCodeAndCity/PostalCodeAndCityDocs.js +1 -1
- package/es/extensions/forms/Value/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
- package/es/extensions/forms/Value/index.d.ts +1 -0
- package/es/extensions/forms/Value/index.js +1 -0
- package/es/extensions/forms/Value/index.js.map +1 -1
- package/es/extensions/forms/Wizard/Step/Step.js +2 -2
- package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
- package/es/extensions/forms/constants/locales/en-GB.d.ts +13 -0
- package/es/extensions/forms/constants/locales/en-GB.js +20 -7
- package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
- package/es/extensions/forms/constants/locales/en-US.d.ts +13 -0
- package/es/extensions/forms/constants/locales/index.d.ts +26 -0
- package/es/extensions/forms/constants/locales/nb-NO.d.ts +13 -0
- package/es/extensions/forms/constants/locales/nb-NO.js +16 -3
- package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
- package/es/extensions/forms/hooks/DataValueWritePropsDocs.js +3 -3
- package/es/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/es/extensions/forms/hooks/useFieldProps.d.ts +8 -4
- package/es/extensions/forms/hooks/useFieldProps.js +39 -18
- package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/es/extensions/forms/index.d.ts +1 -0
- package/es/extensions/forms/index.js +1 -0
- package/es/extensions/forms/index.js.map +1 -1
- package/es/extensions/forms/style/dnb-forms.css +4 -0
- package/es/extensions/forms/style/dnb-forms.min.css +1 -1
- package/es/extensions/forms/types.d.ts +34 -10
- package/es/extensions/forms/types.js.map +1 -1
- package/es/extensions/forms/utils/json-pointer/json-pointer.js +1 -1
- package/es/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
- package/es/icons/calendar_add.d.ts +3 -0
- package/es/icons/calendar_add.js +3 -0
- package/es/icons/calendar_add.js.map +1 -0
- package/es/icons/calendar_add_medium.d.ts +3 -0
- package/es/icons/calendar_add_medium.js +3 -0
- package/es/icons/calendar_add_medium.js.map +1 -0
- package/es/icons/digitpass_private_corporate.d.ts +3 -0
- package/es/icons/digitpass_private_corporate.js +3 -0
- package/es/icons/digitpass_private_corporate.js.map +1 -0
- package/es/icons/digitpass_private_corporate_medium.d.ts +3 -0
- package/es/icons/digitpass_private_corporate_medium.js +3 -0
- package/es/icons/digitpass_private_corporate_medium.js.map +1 -0
- package/es/icons/dnb/calendar_add.d.ts +3 -0
- package/es/icons/dnb/calendar_add.js +23 -0
- package/es/icons/dnb/calendar_add.js.map +1 -0
- package/es/icons/dnb/calendar_add_medium.d.ts +3 -0
- package/es/icons/dnb/calendar_add_medium.js +17 -0
- package/es/icons/dnb/calendar_add_medium.js.map +1 -0
- package/es/icons/dnb/cog_medium.js +1 -1
- package/es/icons/dnb/cog_medium.js.map +1 -1
- package/es/icons/dnb/digipass_corporate.js +3 -3
- package/es/icons/dnb/digipass_corporate.js.map +1 -1
- package/es/icons/dnb/digipass_corporate_medium.js +3 -3
- package/es/icons/dnb/digipass_corporate_medium.js.map +1 -1
- package/es/icons/dnb/digipass_private.js +3 -3
- package/es/icons/dnb/digipass_private.js.map +1 -1
- package/es/icons/dnb/digipass_private_medium.js +3 -3
- package/es/icons/dnb/digipass_private_medium.js.map +1 -1
- package/es/icons/dnb/digitpass_private_corporate.d.ts +3 -0
- package/es/icons/dnb/digitpass_private_corporate.js +17 -0
- package/es/icons/dnb/digitpass_private_corporate.js.map +1 -0
- package/es/icons/dnb/digitpass_private_corporate_medium.d.ts +3 -0
- package/es/icons/dnb/digitpass_private_corporate_medium.js +17 -0
- package/es/icons/dnb/digitpass_private_corporate_medium.js.map +1 -0
- package/es/icons/dnb/goal.d.ts +3 -0
- package/es/icons/dnb/goal.js +18 -0
- package/es/icons/dnb/goal.js.map +1 -0
- package/es/icons/dnb/goal_medium.d.ts +3 -0
- package/es/icons/dnb/goal_medium.js +18 -0
- package/es/icons/dnb/goal_medium.js.map +1 -0
- package/es/icons/dnb/icons-meta.json +132 -4
- package/es/icons/dnb/icons-svg.lock +1278 -1096
- package/es/icons/dnb/index.d.ts +15 -1
- package/es/icons/dnb/index.js +15 -1
- package/es/icons/dnb/index.js.map +1 -1
- package/es/icons/dnb/information.js +1 -1
- package/es/icons/dnb/information.js.map +1 -1
- package/es/icons/dnb/investor.d.ts +3 -0
- package/es/icons/dnb/investor.js +25 -0
- package/es/icons/dnb/investor.js.map +1 -0
- package/es/icons/dnb/investor_medium.d.ts +3 -0
- package/es/icons/dnb/investor_medium.js +25 -0
- package/es/icons/dnb/investor_medium.js.map +1 -0
- package/es/icons/dnb/layout_grid.d.ts +3 -0
- package/es/icons/dnb/layout_grid.js +26 -0
- package/es/icons/dnb/layout_grid.js.map +1 -0
- package/es/icons/dnb/layout_grid_medium.d.ts +3 -0
- package/es/icons/dnb/layout_grid_medium.js +26 -0
- package/es/icons/dnb/layout_grid_medium.js.map +1 -0
- package/es/icons/dnb/question.js +1 -1
- package/es/icons/dnb/question.js.map +1 -1
- package/es/icons/dnb/question_circled.js +1 -1
- package/es/icons/dnb/question_circled.js.map +1 -1
- package/es/icons/dnb/question_medium.js +1 -1
- package/es/icons/dnb/question_medium.js.map +1 -1
- package/es/icons/dnb/return_1_medium.js +1 -1
- package/es/icons/dnb/return_1_medium.js.map +1 -1
- package/es/icons/dnb/secondary_icons.d.ts +8 -1
- package/es/icons/dnb/secondary_icons.js +8 -1
- package/es/icons/dnb/secondary_icons.js.map +1 -1
- package/es/icons/dnb/secondary_icons_medium.d.ts +8 -1
- package/es/icons/dnb/secondary_icons_medium.js +8 -1
- package/es/icons/dnb/secondary_icons_medium.js.map +1 -1
- package/es/icons/dnb/show_pin.d.ts +3 -0
- package/es/icons/dnb/show_pin.js +15 -0
- package/es/icons/dnb/show_pin.js.map +1 -0
- package/es/icons/dnb/show_pin_medium.d.ts +3 -0
- package/es/icons/dnb/show_pin_medium.js +15 -0
- package/es/icons/dnb/show_pin_medium.js.map +1 -0
- package/es/icons/dnb/table.d.ts +3 -0
- package/es/icons/dnb/table.js +25 -0
- package/es/icons/dnb/table.js.map +1 -0
- package/es/icons/dnb/table_medium.d.ts +3 -0
- package/es/icons/dnb/table_medium.js +18 -0
- package/es/icons/dnb/table_medium.js.map +1 -0
- package/es/icons/goal.d.ts +3 -0
- package/es/icons/goal.js +3 -0
- package/es/icons/goal.js.map +1 -0
- package/es/icons/goal_medium.d.ts +3 -0
- package/es/icons/goal_medium.js +3 -0
- package/es/icons/goal_medium.js.map +1 -0
- package/es/icons/index.d.ts +15 -1
- package/es/icons/index.js +15 -1
- package/es/icons/index.js.map +1 -1
- package/es/icons/investor.d.ts +3 -0
- package/es/icons/investor.js +3 -0
- package/es/icons/investor.js.map +1 -0
- package/es/icons/investor_medium.d.ts +3 -0
- package/es/icons/investor_medium.js +3 -0
- package/es/icons/investor_medium.js.map +1 -0
- package/es/icons/layout_grid.d.ts +3 -0
- package/es/icons/layout_grid.js +3 -0
- package/es/icons/layout_grid.js.map +1 -0
- package/es/icons/layout_grid_medium.d.ts +3 -0
- package/es/icons/layout_grid_medium.js +3 -0
- package/es/icons/layout_grid_medium.js.map +1 -0
- package/es/icons/show_pin.d.ts +3 -0
- package/es/icons/show_pin.js +3 -0
- package/es/icons/show_pin.js.map +1 -0
- package/es/icons/show_pin_medium.d.ts +3 -0
- package/es/icons/show_pin_medium.js +3 -0
- package/es/icons/show_pin_medium.js.map +1 -0
- package/es/icons/table.d.ts +3 -0
- package/es/icons/table.js +3 -0
- package/es/icons/table.js.map +1 -0
- package/es/icons/table_medium.d.ts +3 -0
- package/es/icons/table_medium.js +3 -0
- package/es/icons/table_medium.js.map +1 -0
- 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/style/core/reset.scss +3 -9
- package/es/style/core/scopes.scss +1 -1
- package/es/style/dnb-ui-basis.css +4 -8
- package/es/style/dnb-ui-basis.min.css +1 -1
- package/es/style/dnb-ui-body.css +4 -8
- package/es/style/dnb-ui-body.min.css +1 -1
- package/es/style/dnb-ui-components.css +8 -4
- package/es/style/dnb-ui-components.min.css +2 -2
- package/es/style/dnb-ui-core.css +4 -8
- package/es/style/dnb-ui-core.min.css +1 -1
- package/es/style/dnb-ui-extensions.css +4 -0
- package/es/style/dnb-ui-extensions.min.css +1 -1
- package/es/style/dnb-ui-forms.css +4 -0
- package/es/style/dnb-ui-forms.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-components.css +12 -4
- package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
- package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +4 -0
- package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +4 -0
- package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-components.css +12 -4
- package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
- package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +4 -0
- package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +4 -0
- package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-components.css +12 -4
- package/es/style/themes/theme-ui/ui-theme-components.min.css +2 -2
- package/es/style/themes/theme-ui/ui-theme-extensions.css +4 -0
- package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-forms.css +4 -0
- package/es/style/themes/theme-ui/ui-theme-forms.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 +3 -3
- package/esm/dnb-ui-icons.min.mjs +1 -1
- package/esm/dnb-ui-lib.min.mjs +1 -1
- package/extensions/forms/Connectors/Bring/index.d.ts +1 -0
- package/extensions/forms/Connectors/Bring/index.js +3 -0
- package/extensions/forms/Connectors/Bring/index.js.map +1 -0
- package/extensions/forms/Connectors/Bring/postalCode.d.ts +25 -0
- package/extensions/forms/Connectors/Bring/postalCode.js +151 -0
- package/extensions/forms/Connectors/Bring/postalCode.js.map +1 -0
- package/extensions/forms/Connectors/createContext.d.ts +58 -0
- package/extensions/forms/Connectors/createContext.js +119 -0
- package/extensions/forms/Connectors/createContext.js.map +1 -0
- package/extensions/forms/Connectors/index.d.ts +2 -0
- package/extensions/forms/Connectors/index.js +4 -0
- package/extensions/forms/Connectors/index.js.map +1 -0
- package/extensions/forms/DataContext/Context.d.ts +4 -1
- package/extensions/forms/DataContext/Context.js.map +1 -1
- package/extensions/forms/DataContext/Provider/Provider.js +30 -16
- package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
- package/extensions/forms/Field/Address/Address.d.ts +9 -0
- package/extensions/forms/Field/Address/Address.js +51 -0
- package/extensions/forms/Field/Address/Address.js.map +1 -0
- package/extensions/forms/Field/Address/AddressDocs.d.ts +2 -0
- package/extensions/forms/Field/Address/AddressDocs.js +8 -0
- package/extensions/forms/Field/Address/AddressDocs.js.map +1 -0
- package/extensions/forms/Field/Address/index.d.ts +2 -0
- package/extensions/forms/Field/Address/index.js +3 -0
- package/extensions/forms/Field/Address/index.js.map +1 -0
- package/extensions/forms/Field/Email/EmailDocs.d.ts +2 -0
- package/extensions/forms/Field/Email/EmailDocs.js +8 -0
- package/extensions/forms/Field/Email/EmailDocs.js.map +1 -0
- package/extensions/forms/Field/Expiry/Expiry.js +82 -31
- package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
- package/extensions/forms/Field/Name/Name.js +2 -2
- package/extensions/forms/Field/Name/Name.js.map +1 -1
- package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +1 -0
- package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +9 -0
- package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
- package/extensions/forms/Field/Password/PasswordDocs.d.ts +2 -0
- package/extensions/forms/Field/Password/PasswordDocs.js +23 -0
- package/extensions/forms/Field/Password/PasswordDocs.js.map +1 -0
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +10 -0
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +23 -10
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +3 -3
- package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
- package/extensions/forms/Field/Provider/useFieldProvider.d.ts +4 -4
- package/extensions/forms/Field/index.d.ts +1 -0
- package/extensions/forms/Field/index.js +1 -0
- package/extensions/forms/Field/index.js.map +1 -1
- package/extensions/forms/FieldBlock/FieldBlock.js +0 -1
- package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
- package/extensions/forms/FieldBlock/style/dnb-field-block.css +4 -0
- package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
- package/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -0
- package/extensions/forms/Iterate/Array/Array.js +7 -2
- package/extensions/forms/Iterate/Array/Array.js.map +1 -1
- package/extensions/forms/Iterate/Array/ArrayDocs.js +5 -0
- package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/extensions/forms/Iterate/Array/types.d.ts +1 -0
- package/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +4 -0
- package/extensions/forms/Iterate/PushContainer/PushContainer.js +3 -2
- package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
- package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
- package/extensions/forms/Value/Address/Address.d.ts +9 -0
- package/extensions/forms/Value/Address/Address.js +31 -0
- package/extensions/forms/Value/Address/Address.js.map +1 -0
- package/extensions/forms/Value/Address/index.d.ts +2 -0
- package/extensions/forms/Value/Address/index.js +3 -0
- package/extensions/forms/Value/Address/index.js.map +1 -0
- package/extensions/forms/Value/PostalCodeAndCity/PostalCodeAndCityDocs.js +1 -1
- package/extensions/forms/Value/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
- package/extensions/forms/Value/index.d.ts +1 -0
- package/extensions/forms/Value/index.js +1 -0
- package/extensions/forms/Value/index.js.map +1 -1
- package/extensions/forms/Wizard/Step/Step.js +2 -2
- package/extensions/forms/Wizard/Step/Step.js.map +1 -1
- package/extensions/forms/constants/locales/en-GB.d.ts +13 -0
- package/extensions/forms/constants/locales/en-GB.js +20 -7
- package/extensions/forms/constants/locales/en-GB.js.map +1 -1
- package/extensions/forms/constants/locales/en-US.d.ts +13 -0
- package/extensions/forms/constants/locales/index.d.ts +26 -0
- package/extensions/forms/constants/locales/nb-NO.d.ts +13 -0
- package/extensions/forms/constants/locales/nb-NO.js +16 -3
- package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
- package/extensions/forms/hooks/DataValueWritePropsDocs.js +3 -3
- package/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
- package/extensions/forms/hooks/useFieldProps.d.ts +8 -4
- package/extensions/forms/hooks/useFieldProps.js +39 -19
- package/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/extensions/forms/index.d.ts +1 -0
- package/extensions/forms/index.js +2 -0
- package/extensions/forms/index.js.map +1 -1
- package/extensions/forms/style/dnb-forms.css +4 -0
- package/extensions/forms/style/dnb-forms.min.css +1 -1
- package/extensions/forms/types.d.ts +34 -10
- package/extensions/forms/types.js.map +1 -1
- package/extensions/forms/utils/json-pointer/json-pointer.js +1 -1
- package/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
- package/icons/calendar_add.d.ts +3 -0
- package/icons/calendar_add.js +3 -0
- package/icons/calendar_add.js.map +1 -0
- package/icons/calendar_add_medium.d.ts +3 -0
- package/icons/calendar_add_medium.js +3 -0
- package/icons/calendar_add_medium.js.map +1 -0
- package/icons/digitpass_private_corporate.d.ts +3 -0
- package/icons/digitpass_private_corporate.js +3 -0
- package/icons/digitpass_private_corporate.js.map +1 -0
- package/icons/digitpass_private_corporate_medium.d.ts +3 -0
- package/icons/digitpass_private_corporate_medium.js +3 -0
- package/icons/digitpass_private_corporate_medium.js.map +1 -0
- package/icons/dnb/calendar_add.d.ts +3 -0
- package/icons/dnb/calendar_add.js +23 -0
- package/icons/dnb/calendar_add.js.map +1 -0
- package/icons/dnb/calendar_add_medium.d.ts +3 -0
- package/icons/dnb/calendar_add_medium.js +17 -0
- package/icons/dnb/calendar_add_medium.js.map +1 -0
- package/icons/dnb/cog_medium.js +1 -1
- package/icons/dnb/cog_medium.js.map +1 -1
- package/icons/dnb/digipass_corporate.js +3 -3
- package/icons/dnb/digipass_corporate.js.map +1 -1
- package/icons/dnb/digipass_corporate_medium.js +3 -3
- package/icons/dnb/digipass_corporate_medium.js.map +1 -1
- package/icons/dnb/digipass_private.js +3 -3
- package/icons/dnb/digipass_private.js.map +1 -1
- package/icons/dnb/digipass_private_medium.js +3 -3
- package/icons/dnb/digipass_private_medium.js.map +1 -1
- package/icons/dnb/digitpass_private_corporate.d.ts +3 -0
- package/icons/dnb/digitpass_private_corporate.js +17 -0
- package/icons/dnb/digitpass_private_corporate.js.map +1 -0
- package/icons/dnb/digitpass_private_corporate_medium.d.ts +3 -0
- package/icons/dnb/digitpass_private_corporate_medium.js +17 -0
- package/icons/dnb/digitpass_private_corporate_medium.js.map +1 -0
- package/icons/dnb/goal.d.ts +3 -0
- package/icons/dnb/goal.js +18 -0
- package/icons/dnb/goal.js.map +1 -0
- package/icons/dnb/goal_medium.d.ts +3 -0
- package/icons/dnb/goal_medium.js +18 -0
- package/icons/dnb/goal_medium.js.map +1 -0
- package/icons/dnb/icons-meta.json +132 -4
- package/icons/dnb/icons-svg.lock +1278 -1096
- package/icons/dnb/index.d.ts +15 -1
- package/icons/dnb/index.js +15 -1
- package/icons/dnb/index.js.map +1 -1
- package/icons/dnb/information.js +1 -1
- package/icons/dnb/information.js.map +1 -1
- package/icons/dnb/investor.d.ts +3 -0
- package/icons/dnb/investor.js +25 -0
- package/icons/dnb/investor.js.map +1 -0
- package/icons/dnb/investor_medium.d.ts +3 -0
- package/icons/dnb/investor_medium.js +25 -0
- package/icons/dnb/investor_medium.js.map +1 -0
- package/icons/dnb/layout_grid.d.ts +3 -0
- package/icons/dnb/layout_grid.js +26 -0
- package/icons/dnb/layout_grid.js.map +1 -0
- package/icons/dnb/layout_grid_medium.d.ts +3 -0
- package/icons/dnb/layout_grid_medium.js +26 -0
- package/icons/dnb/layout_grid_medium.js.map +1 -0
- package/icons/dnb/question.js +1 -1
- package/icons/dnb/question.js.map +1 -1
- package/icons/dnb/question_circled.js +1 -1
- package/icons/dnb/question_circled.js.map +1 -1
- package/icons/dnb/question_medium.js +1 -1
- package/icons/dnb/question_medium.js.map +1 -1
- package/icons/dnb/return_1_medium.js +1 -1
- package/icons/dnb/return_1_medium.js.map +1 -1
- package/icons/dnb/secondary_icons.d.ts +8 -1
- package/icons/dnb/secondary_icons.js +8 -1
- package/icons/dnb/secondary_icons.js.map +1 -1
- package/icons/dnb/secondary_icons_medium.d.ts +8 -1
- package/icons/dnb/secondary_icons_medium.js +8 -1
- package/icons/dnb/secondary_icons_medium.js.map +1 -1
- package/icons/dnb/show_pin.d.ts +3 -0
- package/icons/dnb/show_pin.js +15 -0
- package/icons/dnb/show_pin.js.map +1 -0
- package/icons/dnb/show_pin_medium.d.ts +3 -0
- package/icons/dnb/show_pin_medium.js +15 -0
- package/icons/dnb/show_pin_medium.js.map +1 -0
- package/icons/dnb/table.d.ts +3 -0
- package/icons/dnb/table.js +25 -0
- package/icons/dnb/table.js.map +1 -0
- package/icons/dnb/table_medium.d.ts +3 -0
- package/icons/dnb/table_medium.js +18 -0
- package/icons/dnb/table_medium.js.map +1 -0
- package/icons/goal.d.ts +3 -0
- package/icons/goal.js +3 -0
- package/icons/goal.js.map +1 -0
- package/icons/goal_medium.d.ts +3 -0
- package/icons/goal_medium.js +3 -0
- package/icons/goal_medium.js.map +1 -0
- package/icons/index.d.ts +15 -1
- package/icons/index.js +15 -1
- package/icons/index.js.map +1 -1
- package/icons/investor.d.ts +3 -0
- package/icons/investor.js +3 -0
- package/icons/investor.js.map +1 -0
- package/icons/investor_medium.d.ts +3 -0
- package/icons/investor_medium.js +3 -0
- package/icons/investor_medium.js.map +1 -0
- package/icons/layout_grid.d.ts +3 -0
- package/icons/layout_grid.js +3 -0
- package/icons/layout_grid.js.map +1 -0
- package/icons/layout_grid_medium.d.ts +3 -0
- package/icons/layout_grid_medium.js +3 -0
- package/icons/layout_grid_medium.js.map +1 -0
- package/icons/show_pin.d.ts +3 -0
- package/icons/show_pin.js +3 -0
- package/icons/show_pin.js.map +1 -0
- package/icons/show_pin_medium.d.ts +3 -0
- package/icons/show_pin_medium.js +3 -0
- package/icons/show_pin_medium.js.map +1 -0
- package/icons/table.d.ts +3 -0
- package/icons/table.js +3 -0
- package/icons/table.js.map +1 -0
- package/icons/table_medium.d.ts +3 -0
- package/icons/table_medium.js +3 -0
- package/icons/table_medium.js.map +1 -0
- 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/style/core/reset.scss +3 -9
- package/style/core/scopes.scss +1 -1
- package/style/dnb-ui-basis.css +4 -8
- package/style/dnb-ui-basis.min.css +1 -1
- package/style/dnb-ui-body.css +4 -8
- package/style/dnb-ui-body.min.css +1 -1
- package/style/dnb-ui-components.css +8 -4
- package/style/dnb-ui-components.min.css +2 -2
- package/style/dnb-ui-core.css +4 -8
- package/style/dnb-ui-core.min.css +1 -1
- package/style/dnb-ui-extensions.css +4 -0
- package/style/dnb-ui-extensions.min.css +1 -1
- package/style/dnb-ui-forms.css +4 -0
- package/style/dnb-ui-forms.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-components.css +12 -4
- package/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
- package/style/themes/theme-eiendom/eiendom-theme-extensions.css +4 -0
- package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-forms.css +4 -0
- package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-components.css +12 -4
- package/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
- package/style/themes/theme-sbanken/sbanken-theme-extensions.css +4 -0
- package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-forms.css +4 -0
- package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-components.css +12 -4
- package/style/themes/theme-ui/ui-theme-components.min.css +2 -2
- package/style/themes/theme-ui/ui-theme-extensions.css +4 -0
- package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-forms.css +4 -0
- package/style/themes/theme-ui/ui-theme-forms.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-icons.min.js +1 -1
- package/umd/dnb-ui-lib.min.js +1 -1
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.EmailProperties = void 0;
|
|
7
|
+
const EmailProperties = {
|
|
8
|
+
'[Input](/uilib/components/input/properties)': {
|
|
9
|
+
doc: 'All `Input` properties are supported.',
|
|
10
|
+
type: 'Various',
|
|
11
|
+
status: 'optional'
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
exports.EmailProperties = EmailProperties;
|
|
15
|
+
//# sourceMappingURL=EmailDocs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmailDocs.js","names":["EmailProperties","doc","type","status","exports"],"sources":["../../../../../../src/extensions/forms/Field/Email/EmailDocs.tsx"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const EmailProperties: PropertiesTableProps = {\n '[Input](/uilib/components/input/properties)': {\n doc: 'All `Input` properties are supported.',\n type: 'Various',\n status: 'optional',\n },\n}\n"],"mappings":";;;;;;AAEO,MAAMA,eAAqC,GAAG;EACnD,6CAA6C,EAAE;IAC7CC,GAAG,EAAE,uCAAuC;IAC5CC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAAAC,OAAA,CAAAJ,eAAA,GAAAA,eAAA"}
|
|
@@ -12,6 +12,7 @@ var _FieldBlock = _interopRequireDefault(require("../../FieldBlock"));
|
|
|
12
12
|
var _inputMasked = require("../../../../components/input-masked");
|
|
13
13
|
var _shared = require("../../../../shared");
|
|
14
14
|
var _useTranslation = _interopRequireDefault(require("../../hooks/useTranslation"));
|
|
15
|
+
var _utils2 = require("../../utils");
|
|
15
16
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
16
17
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
17
18
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
@@ -39,6 +40,14 @@ function Expiry(props) {
|
|
|
39
40
|
const errorMessages = (0, _react.useMemo)(() => _objectSpread({
|
|
40
41
|
'Field.errorRequired': errorRequired
|
|
41
42
|
}, props.errorMessages), [errorRequired, props.errorMessages]);
|
|
43
|
+
const handleInput = (0, _react.useCallback)(values => {
|
|
44
|
+
const month = expiryValueToString(values.month, placeholders.month);
|
|
45
|
+
const year = expiryValueToString(values.year, placeholders.year);
|
|
46
|
+
if (isFieldEmpty(month, placeholders.month) && isFieldEmpty(year, placeholders.year)) {
|
|
47
|
+
return '';
|
|
48
|
+
}
|
|
49
|
+
return `${month}${year}`;
|
|
50
|
+
}, [placeholders.month, placeholders.year]);
|
|
42
51
|
const validateRequired = (0, _react.useCallback)((value, _ref) => {
|
|
43
52
|
let {
|
|
44
53
|
required,
|
|
@@ -46,10 +55,36 @@ function Expiry(props) {
|
|
|
46
55
|
} = _ref;
|
|
47
56
|
return required && !value ? error : undefined;
|
|
48
57
|
}, []);
|
|
58
|
+
const monthAndYearValidator = (0, _react.useCallback)(value => validateMonthAndYear(value, placeholders), [placeholders]);
|
|
59
|
+
const validateInitially = (0, _react.useMemo)(() => {
|
|
60
|
+
if (props.validateInitially) {
|
|
61
|
+
return props.validateInitially;
|
|
62
|
+
}
|
|
63
|
+
if (props.value) {
|
|
64
|
+
return true;
|
|
65
|
+
}
|
|
66
|
+
return undefined;
|
|
67
|
+
}, [props.validateInitially, props.value]);
|
|
68
|
+
const valueProp = (0, _react.useMemo)(() => {
|
|
69
|
+
var _props$value;
|
|
70
|
+
const {
|
|
71
|
+
month,
|
|
72
|
+
year
|
|
73
|
+
} = stringToExpiryValue((_props$value = props.value) !== null && _props$value !== void 0 ? _props$value : props.defaultValue);
|
|
74
|
+
const monthString = expiryValueToString(month, placeholders.month);
|
|
75
|
+
const yearString = expiryValueToString(year, placeholders.year);
|
|
76
|
+
if (isFieldEmpty(monthString, placeholders.month) && isFieldEmpty(yearString, placeholders.year)) {
|
|
77
|
+
return '';
|
|
78
|
+
}
|
|
79
|
+
return `${monthString}${yearString}`;
|
|
80
|
+
}, [props.value, props.defaultValue, placeholders.month, placeholders.year]);
|
|
49
81
|
const preparedProps = _objectSpread(_objectSpread({}, props), {}, {
|
|
50
82
|
errorMessages,
|
|
51
|
-
|
|
52
|
-
|
|
83
|
+
value: valueProp,
|
|
84
|
+
fromInput: handleInput,
|
|
85
|
+
validateRequired,
|
|
86
|
+
validateInitially: validateInitially,
|
|
87
|
+
onBlurValidator: monthAndYearValidator
|
|
53
88
|
});
|
|
54
89
|
const {
|
|
55
90
|
id,
|
|
@@ -68,13 +103,7 @@ function Expiry(props) {
|
|
|
68
103
|
handleChange,
|
|
69
104
|
setDisplayValue
|
|
70
105
|
} = (0, _hooks.useFieldProps)(preparedProps);
|
|
71
|
-
const expiry = (0, _react.useMemo)(() =>
|
|
72
|
-
var _value$substring;
|
|
73
|
-
return {
|
|
74
|
-
month: ensureValidMonth(value === null || value === void 0 ? void 0 : value.substring(0, 2)),
|
|
75
|
-
year: (_value$substring = value === null || value === void 0 ? void 0 : value.substring(2, 4)) !== null && _value$substring !== void 0 ? _value$substring : ''
|
|
76
|
-
};
|
|
77
|
-
}, [value]);
|
|
106
|
+
const expiry = (0, _react.useMemo)(() => stringToExpiryValue(value), [value]);
|
|
78
107
|
(0, _react.useMemo)(() => {
|
|
79
108
|
if ((path || itemPath) && expiry.month && expiry.year) {
|
|
80
109
|
setDisplayValue(`${expiry.month}/${expiry.year}`);
|
|
@@ -102,7 +131,7 @@ function Expiry(props) {
|
|
|
102
131
|
inputs: [_objectSpread({
|
|
103
132
|
id: 'month',
|
|
104
133
|
label: monthLabel,
|
|
105
|
-
mask:
|
|
134
|
+
mask: [/[0-9]/, /[0-9]/],
|
|
106
135
|
placeholderCharacter: placeholders['month'],
|
|
107
136
|
autoComplete: 'cc-exp-month'
|
|
108
137
|
}, htmlAttributes), _objectSpread({
|
|
@@ -114,31 +143,53 @@ function Expiry(props) {
|
|
|
114
143
|
}, htmlAttributes)]
|
|
115
144
|
}));
|
|
116
145
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
exports.default = _default;
|
|
120
|
-
function toExpiryString(values) {
|
|
121
|
-
return Object.values(values).join('');
|
|
146
|
+
function isFieldEmpty(value, placeholder) {
|
|
147
|
+
return value === `${placeholder}${placeholder}`;
|
|
122
148
|
}
|
|
123
|
-
function
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
149
|
+
function stringToExpiryValue(value) {
|
|
150
|
+
var _value$substring, _value$substring2;
|
|
151
|
+
const month = (_value$substring = value === null || value === void 0 ? void 0 : value.substring(0, 2)) !== null && _value$substring !== void 0 ? _value$substring : '';
|
|
152
|
+
const year = (_value$substring2 = value === null || value === void 0 ? void 0 : value.substring(2, 4)) !== null && _value$substring2 !== void 0 ? _value$substring2 : '';
|
|
153
|
+
return {
|
|
154
|
+
month,
|
|
155
|
+
year
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
function expiryValueToString(value, placeholder) {
|
|
159
|
+
if (!value) {
|
|
160
|
+
return `${placeholder}${placeholder}`;
|
|
132
161
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
if (secondDigit && !isSecondDigitValid) {
|
|
136
|
-
return '';
|
|
162
|
+
if (value.length === 1) {
|
|
163
|
+
return `${value}${placeholder}`;
|
|
137
164
|
}
|
|
138
|
-
return
|
|
165
|
+
return value;
|
|
139
166
|
}
|
|
140
|
-
function
|
|
141
|
-
const
|
|
142
|
-
|
|
167
|
+
function validateMonthAndYear(date, placeholders) {
|
|
168
|
+
const {
|
|
169
|
+
month,
|
|
170
|
+
year
|
|
171
|
+
} = stringToExpiryValue(date);
|
|
172
|
+
const monthNumber = Number(month);
|
|
173
|
+
const messages = [];
|
|
174
|
+
if (month.includes(placeholders.month) || monthNumber < 1 || monthNumber > 12) {
|
|
175
|
+
messages.push(new _utils2.FormError('Expiry.errorMonth', {
|
|
176
|
+
messageValues: {
|
|
177
|
+
month: month
|
|
178
|
+
}
|
|
179
|
+
}));
|
|
180
|
+
}
|
|
181
|
+
if (year.includes(placeholders.year)) {
|
|
182
|
+
messages.push(new _utils2.FormError('Expiry.errorYear', {
|
|
183
|
+
messageValues: {
|
|
184
|
+
year: year
|
|
185
|
+
}
|
|
186
|
+
}));
|
|
187
|
+
}
|
|
188
|
+
if (messages.length) {
|
|
189
|
+
return messages;
|
|
190
|
+
}
|
|
143
191
|
}
|
|
192
|
+
Expiry._supportsEufemiaSpacingProps = true;
|
|
193
|
+
var _default = Expiry;
|
|
194
|
+
exports.default = _default;
|
|
144
195
|
//# sourceMappingURL=Expiry.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Expiry.js","names":["_react","_interopRequireWildcard","require","_utils","_hooks","_classnames","_interopRequireDefault","_FieldBlock","_inputMasked","_shared","_useTranslation","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","Expiry","props","Date","errorRequired","label","expiryLabel","useTranslation","DatePicker","placeholderCharacters","placeholders","month","monthLabel","year","yearLabel","useSharedTranslation","errorMessages","useMemo","validateRequired","useCallback","_ref","required","error","preparedProps","fromInput","toExpiryString","id","path","itemPath","className","hasError","info","warning","disabled","htmlAttributes","handleFocus","handleBlur","handleChange","setDisplayValue","useFieldProps","expiry","_value$substring","ensureValidMonth","substring","status","fieldBlockProps","forId","classnames","pickSpacingProps","createElement","MultiInputMask","stretch","values","statusState","onChange","onBlur","onFocus","delimiter","inputMode","inputs","mask","getMonthMask","placeholderCharacter","autoComplete","_supportsEufemiaSpacingProps","_default","exports","join","firstMask","secondMask","firstDigit","charAt","isFirstDigitValid","test","secondDigit","isSecondDigitValid"],"sources":["../../../../../../src/extensions/forms/Field/Expiry/Expiry.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from 'react'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { useFieldProps } from '../../hooks'\nimport classnames from 'classnames'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\nimport { MultiInputMask } from '../../../../components/input-masked'\nimport type { MultiInputMaskValue } from '../../../../components/input-masked'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport useTranslation from '../../hooks/useTranslation'\n\ntype ExpiryValue = MultiInputMaskValue<'month' | 'year'>\n\nexport type ExpiryProps = FieldProps<string, undefined | ''>\n\nfunction Expiry(props: ExpiryProps) {\n const {\n Date: { errorRequired },\n Expiry: { label: expiryLabel },\n } = useTranslation()\n\n const {\n DatePicker: {\n placeholderCharacters: placeholders,\n month: monthLabel,\n year: yearLabel,\n },\n } = useSharedTranslation()\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': errorRequired,\n ...props.errorMessages,\n }),\n [errorRequired, props.errorMessages]\n )\n\n const validateRequired = useCallback(\n (value: string, { required, error }) => {\n return required && !value ? error : undefined\n },\n []\n )\n\n const preparedProps: ExpiryProps = {\n ...props,\n errorMessages,\n fromInput: toExpiryString,\n validateRequired,\n }\n\n const {\n id,\n path,\n itemPath,\n className,\n label = expiryLabel,\n hasError,\n info,\n warning,\n disabled,\n value = '',\n htmlAttributes,\n handleFocus,\n handleBlur,\n handleChange,\n setDisplayValue,\n } = useFieldProps(preparedProps)\n\n const expiry: ExpiryValue = useMemo(() => {\n return {\n month: ensureValidMonth(value?.substring(0, 2)),\n year: value?.substring(2, 4) ?? '',\n }\n }, [value])\n\n useMemo(() => {\n if ((path || itemPath) && expiry.month && expiry.year) {\n setDisplayValue(`${expiry.month}/${expiry.year}`)\n }\n }, [expiry.month, expiry.year, itemPath, path, setDisplayValue])\n\n const status = hasError\n ? 'error'\n : warning\n ? 'warn'\n : info\n ? 'info'\n : null\n\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input-month`,\n className: classnames('dnb-forms-field-expiry', className),\n label,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <MultiInputMask\n stretch\n id={`${id}-input`}\n values={expiry}\n status={status}\n statusState={disabled ? 'disabled' : undefined}\n disabled={disabled}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n delimiter=\"/\"\n inputMode=\"numeric\"\n inputs={[\n {\n id: 'month',\n label: monthLabel,\n mask: getMonthMask(expiry?.month),\n placeholderCharacter: placeholders['month'],\n autoComplete: 'cc-exp-month',\n ...htmlAttributes,\n },\n {\n id: 'year',\n label: yearLabel,\n mask: [/[0-9]/, /[0-9]/],\n placeholderCharacter: placeholders['year'],\n autoComplete: 'cc-exp-year',\n ...htmlAttributes,\n },\n ]}\n />\n </FieldBlock>\n )\n}\n\nExpiry._supportsEufemiaSpacingProps = true\nexport default Expiry\n\nfunction toExpiryString(values: ExpiryValue) {\n return Object.values(values).join('')\n}\n\nfunction ensureValidMonth(month: string) {\n // Return empty value if no month is given\n if (!month) {\n return ''\n }\n\n const [firstMask, secondMask] = getMonthMask(month)\n\n const firstDigit = month?.charAt(0)\n const isFirstDigitValid = firstMask.test(firstDigit)\n\n if (firstDigit && !isFirstDigitValid) {\n // Return empty value if the first digit is invalid\n return ''\n }\n\n const secondDigit = month?.charAt(1)\n const isSecondDigitValid = secondMask.test(secondDigit)\n\n if (secondDigit && !isSecondDigitValid) {\n // Return empty value if the second digit is invalid\n return ''\n }\n\n // Return given month of month value is valid\n return month\n}\n\nfunction getMonthMask(month: string) {\n const firstDigit = month?.charAt(0)\n\n return [\n /[0-1]/,\n firstDigit === '0' || firstDigit === '' ? /[1-9]/ : /[0-2]/,\n ]\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Expiry.js","names":["_react","_interopRequireWildcard","require","_utils","_hooks","_classnames","_interopRequireDefault","_FieldBlock","_inputMasked","_shared","_useTranslation","_utils2","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","Expiry","props","Date","errorRequired","label","expiryLabel","useTranslation","DatePicker","placeholderCharacters","placeholders","month","monthLabel","year","yearLabel","useSharedTranslation","errorMessages","useMemo","handleInput","useCallback","values","expiryValueToString","isFieldEmpty","validateRequired","_ref","required","error","monthAndYearValidator","validateMonthAndYear","validateInitially","valueProp","_props$value","stringToExpiryValue","defaultValue","monthString","yearString","preparedProps","fromInput","onBlurValidator","id","path","itemPath","className","hasError","info","warning","disabled","htmlAttributes","handleFocus","handleBlur","handleChange","setDisplayValue","useFieldProps","expiry","status","fieldBlockProps","forId","classnames","pickSpacingProps","createElement","MultiInputMask","stretch","statusState","onChange","onBlur","onFocus","delimiter","inputMode","inputs","mask","placeholderCharacter","autoComplete","placeholder","_value$substring","_value$substring2","substring","date","monthNumber","messages","includes","FormError","messageValues","_supportsEufemiaSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Field/Expiry/Expiry.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from 'react'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { useFieldProps } from '../../hooks'\nimport classnames from 'classnames'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\nimport { MultiInputMask } from '../../../../components/input-masked'\nimport type { MultiInputMaskValue } from '../../../../components/input-masked'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport useTranslation from '../../hooks/useTranslation'\nimport { FormError } from '../../utils'\n\ntype ExpiryValue = MultiInputMaskValue<'month' | 'year'>\n\nexport type ExpiryProps = FieldProps<string, undefined | ''>\n\nfunction Expiry(props: ExpiryProps) {\n const {\n Date: { errorRequired },\n Expiry: { label: expiryLabel },\n } = useTranslation()\n\n const {\n DatePicker: {\n placeholderCharacters: placeholders,\n month: monthLabel,\n year: yearLabel,\n },\n } = useSharedTranslation()\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': errorRequired,\n ...props.errorMessages,\n }),\n [errorRequired, props.errorMessages]\n )\n\n const handleInput = useCallback(\n (values: ExpiryValue) => {\n const month = expiryValueToString(values.month, placeholders.month)\n const year = expiryValueToString(values.year, placeholders.year)\n\n if (\n isFieldEmpty(month, placeholders.month) &&\n isFieldEmpty(year, placeholders.year)\n ) {\n return ''\n }\n\n return `${month}${year}`\n },\n [placeholders.month, placeholders.year]\n )\n\n const validateRequired = useCallback(\n (value: string, { required, error }) => {\n return required && !value ? error : undefined\n },\n []\n )\n\n const monthAndYearValidator = useCallback(\n (value: string) => validateMonthAndYear(value, placeholders),\n [placeholders]\n )\n\n const validateInitially = useMemo(() => {\n if (props.validateInitially) {\n return props.validateInitially\n }\n\n if (props.value) {\n return true\n }\n\n return undefined\n }, [props.validateInitially, props.value])\n\n const valueProp = useMemo(() => {\n const { month, year } = stringToExpiryValue(\n props.value ?? props.defaultValue\n )\n const monthString = expiryValueToString(month, placeholders.month)\n const yearString = expiryValueToString(year, placeholders.year)\n\n if (\n isFieldEmpty(monthString, placeholders.month) &&\n isFieldEmpty(yearString, placeholders.year)\n ) {\n return ''\n }\n\n return `${monthString}${yearString}`\n }, [\n props.value,\n props.defaultValue,\n placeholders.month,\n placeholders.year,\n ])\n\n const preparedProps: ExpiryProps = {\n ...props,\n errorMessages,\n value: valueProp,\n fromInput: handleInput,\n validateRequired,\n validateInitially: validateInitially,\n onBlurValidator: monthAndYearValidator,\n }\n\n const {\n id,\n path,\n itemPath,\n className,\n label = expiryLabel,\n hasError,\n info,\n warning,\n disabled,\n value = '',\n htmlAttributes,\n handleFocus,\n handleBlur,\n handleChange,\n setDisplayValue,\n } = useFieldProps(preparedProps)\n\n const expiry: ExpiryValue = useMemo(\n () => stringToExpiryValue(value),\n [value]\n )\n\n useMemo(() => {\n if ((path || itemPath) && expiry.month && expiry.year) {\n setDisplayValue(`${expiry.month}/${expiry.year}`)\n }\n }, [expiry.month, expiry.year, itemPath, path, setDisplayValue])\n\n const status = hasError\n ? 'error'\n : warning\n ? 'warn'\n : info\n ? 'info'\n : null\n\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input-month`,\n className: classnames('dnb-forms-field-expiry', className),\n label,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <MultiInputMask\n stretch\n id={`${id}-input`}\n values={expiry}\n status={status}\n statusState={disabled ? 'disabled' : undefined}\n disabled={disabled}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n delimiter=\"/\"\n inputMode=\"numeric\"\n inputs={[\n {\n id: 'month',\n label: monthLabel,\n mask: [/[0-9]/, /[0-9]/],\n placeholderCharacter: placeholders['month'],\n autoComplete: 'cc-exp-month',\n ...htmlAttributes,\n },\n {\n id: 'year',\n label: yearLabel,\n mask: [/[0-9]/, /[0-9]/],\n placeholderCharacter: placeholders['year'],\n autoComplete: 'cc-exp-year',\n ...htmlAttributes,\n },\n ]}\n />\n </FieldBlock>\n )\n}\n\nfunction isFieldEmpty(value: string, placeholder: string) {\n return value === `${placeholder}${placeholder}`\n}\n\nfunction stringToExpiryValue(value: string) {\n const month = value?.substring(0, 2) ?? ''\n const year = value?.substring(2, 4) ?? ''\n\n return {\n month,\n year,\n }\n}\n\nfunction expiryValueToString(value: string, placeholder: string) {\n if (!value) {\n return `${placeholder}${placeholder}`\n }\n\n if (value.length === 1) {\n return `${value}${placeholder}`\n }\n\n return value\n}\n\nfunction validateMonthAndYear(\n date: string,\n placeholders: Record<'month' | 'year', string>\n) {\n const { month, year } = stringToExpiryValue(date)\n\n const monthNumber = Number(month)\n\n const messages: Array<FormError> = []\n\n if (\n month.includes(placeholders.month) ||\n monthNumber < 1 ||\n monthNumber > 12\n ) {\n messages.push(\n new FormError('Expiry.errorMonth', {\n messageValues: { month: month },\n })\n )\n }\n\n if (year.includes(placeholders.year)) {\n messages.push(\n new FormError('Expiry.errorYear', {\n messageValues: { year: year },\n })\n )\n }\n\n if (messages.length) {\n return messages\n }\n}\n\nExpiry._supportsEufemiaSpacingProps = true\nexport default Expiry\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,MAAA,GAAAD,OAAA;AACA,IAAAE,MAAA,GAAAF,OAAA;AACA,IAAAG,WAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,WAAA,GAAAD,sBAAA,CAAAJ,OAAA;AACA,IAAAM,YAAA,GAAAN,OAAA;AAEA,IAAAO,OAAA,GAAAP,OAAA;AACA,IAAAQ,eAAA,GAAAJ,sBAAA,CAAAJ,OAAA;AACA,IAAAS,OAAA,GAAAT,OAAA;AAAuC,SAAAI,uBAAAM,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAf,wBAAAW,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAQ,KAAA,GAAAL,wBAAA,CAAAC,WAAA,OAAAI,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAT,GAAA,YAAAQ,KAAA,CAAAE,GAAA,CAAAV,GAAA,SAAAW,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAhB,GAAA,QAAAgB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAnB,GAAA,EAAAgB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAf,GAAA,EAAAgB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAhB,GAAA,CAAAgB,GAAA,SAAAL,MAAA,CAAAT,OAAA,GAAAF,GAAA,MAAAQ,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAArB,GAAA,EAAAW,MAAA,YAAAA,MAAA;AAAA,SAAAW,QAAAC,MAAA,EAAAC,cAAA,QAAAC,IAAA,GAAAZ,MAAA,CAAAY,IAAA,CAAAF,MAAA,OAAAV,MAAA,CAAAa,qBAAA,QAAAC,OAAA,GAAAd,MAAA,CAAAa,qBAAA,CAAAH,MAAA,GAAAC,cAAA,KAAAG,OAAA,GAAAA,OAAA,CAAAC,MAAA,WAAAC,GAAA,WAAAhB,MAAA,CAAAE,wBAAA,CAAAQ,MAAA,EAAAM,GAAA,EAAAC,UAAA,OAAAL,IAAA,CAAAM,IAAA,CAAAC,KAAA,CAAAP,IAAA,EAAAE,OAAA,YAAAF,IAAA;AAAA,SAAAQ,cAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,WAAAF,SAAA,CAAAD,CAAA,IAAAC,SAAA,CAAAD,CAAA,QAAAA,CAAA,OAAAb,OAAA,CAAAT,MAAA,CAAAyB,MAAA,OAAAC,OAAA,WAAAvB,GAAA,IAAAwB,eAAA,CAAAN,MAAA,EAAAlB,GAAA,EAAAsB,MAAA,CAAAtB,GAAA,SAAAH,MAAA,CAAA4B,yBAAA,GAAA5B,MAAA,CAAA6B,gBAAA,CAAAR,MAAA,EAAArB,MAAA,CAAA4B,yBAAA,CAAAH,MAAA,KAAAhB,OAAA,CAAAT,MAAA,CAAAyB,MAAA,GAAAC,OAAA,WAAAvB,GAAA,IAAAH,MAAA,CAAAC,cAAA,CAAAoB,MAAA,EAAAlB,GAAA,EAAAH,MAAA,CAAAE,wBAAA,CAAAuB,MAAA,EAAAtB,GAAA,iBAAAkB,MAAA;AAAA,SAAAM,gBAAAxC,GAAA,EAAAgB,GAAA,EAAA2B,KAAA,IAAA3B,GAAA,GAAA4B,cAAA,CAAA5B,GAAA,OAAAA,GAAA,IAAAhB,GAAA,IAAAa,MAAA,CAAAC,cAAA,CAAAd,GAAA,EAAAgB,GAAA,IAAA2B,KAAA,EAAAA,KAAA,EAAAb,UAAA,QAAAe,YAAA,QAAAC,QAAA,oBAAA9C,GAAA,CAAAgB,GAAA,IAAA2B,KAAA,WAAA3C,GAAA;AAAA,SAAA4C,eAAAG,GAAA,QAAA/B,GAAA,GAAAgC,YAAA,CAAAD,GAAA,2BAAA/B,GAAA,gBAAAA,GAAA,GAAAiC,MAAA,CAAAjC,GAAA;AAAA,SAAAgC,aAAAE,KAAA,EAAAC,IAAA,eAAAD,KAAA,iBAAAA,KAAA,kBAAAA,KAAA,MAAAE,IAAA,GAAAF,KAAA,CAAAG,MAAA,CAAAC,WAAA,OAAAF,IAAA,KAAAG,SAAA,QAAAC,GAAA,GAAAJ,IAAA,CAAAjC,IAAA,CAAA+B,KAAA,EAAAC,IAAA,2BAAAK,GAAA,sBAAAA,GAAA,YAAAC,SAAA,4DAAAN,IAAA,gBAAAF,MAAA,GAAAS,MAAA,EAAAR,KAAA;AAMvC,SAASS,MAAMA,CAACC,KAAkB,EAAE;EAClC,MAAM;IACJC,IAAI,EAAE;MAAEC;IAAc,CAAC;IACvBH,MAAM,EAAE;MAAEI,KAAK,EAAEC;IAAY;EAC/B,CAAC,GAAG,IAAAC,uBAAc,EAAC,CAAC;EAEpB,MAAM;IACJC,UAAU,EAAE;MACVC,qBAAqB,EAAEC,YAAY;MACnCC,KAAK,EAAEC,UAAU;MACjBC,IAAI,EAAEC;IACR;EACF,CAAC,GAAG,IAAAC,sBAAoB,EAAC,CAAC;EAE1B,MAAMC,aAAa,GAAG,IAAAC,cAAO,EAC3B,MAAA1C,aAAA;IACE,qBAAqB,EAAE6B;EAAa,GACjCF,KAAK,CAACc,aAAa,CACtB,EACF,CAACZ,aAAa,EAAEF,KAAK,CAACc,aAAa,CACrC,CAAC;EAED,MAAME,WAAW,GAAG,IAAAC,kBAAW,EAC5BC,MAAmB,IAAK;IACvB,MAAMT,KAAK,GAAGU,mBAAmB,CAACD,MAAM,CAACT,KAAK,EAAED,YAAY,CAACC,KAAK,CAAC;IACnE,MAAME,IAAI,GAAGQ,mBAAmB,CAACD,MAAM,CAACP,IAAI,EAAEH,YAAY,CAACG,IAAI,CAAC;IAEhE,IACES,YAAY,CAACX,KAAK,EAAED,YAAY,CAACC,KAAK,CAAC,IACvCW,YAAY,CAACT,IAAI,EAAEH,YAAY,CAACG,IAAI,CAAC,EACrC;MACA,OAAO,EAAE;IACX;IAEA,OAAQ,GAAEF,KAAM,GAAEE,IAAK,EAAC;EAC1B,CAAC,EACD,CAACH,YAAY,CAACC,KAAK,EAAED,YAAY,CAACG,IAAI,CACxC,CAAC;EAED,MAAMU,gBAAgB,GAAG,IAAAJ,kBAAW,EAClC,CAAClC,KAAa,EAAAuC,IAAA,KAA0B;IAAA,IAAxB;MAAEC,QAAQ;MAAEC;IAAM,CAAC,GAAAF,IAAA;IACjC,OAAOC,QAAQ,IAAI,CAACxC,KAAK,GAAGyC,KAAK,GAAG7B,SAAS;EAC/C,CAAC,EACD,EACF,CAAC;EAED,MAAM8B,qBAAqB,GAAG,IAAAR,kBAAW,EACtClC,KAAa,IAAK2C,oBAAoB,CAAC3C,KAAK,EAAEyB,YAAY,CAAC,EAC5D,CAACA,YAAY,CACf,CAAC;EAED,MAAMmB,iBAAiB,GAAG,IAAAZ,cAAO,EAAC,MAAM;IACtC,IAAIf,KAAK,CAAC2B,iBAAiB,EAAE;MAC3B,OAAO3B,KAAK,CAAC2B,iBAAiB;IAChC;IAEA,IAAI3B,KAAK,CAACjB,KAAK,EAAE;MACf,OAAO,IAAI;IACb;IAEA,OAAOY,SAAS;EAClB,CAAC,EAAE,CAACK,KAAK,CAAC2B,iBAAiB,EAAE3B,KAAK,CAACjB,KAAK,CAAC,CAAC;EAE1C,MAAM6C,SAAS,GAAG,IAAAb,cAAO,EAAC,MAAM;IAAA,IAAAc,YAAA;IAC9B,MAAM;MAAEpB,KAAK;MAAEE;IAAK,CAAC,GAAGmB,mBAAmB,EAAAD,YAAA,GACzC7B,KAAK,CAACjB,KAAK,cAAA8C,YAAA,cAAAA,YAAA,GAAI7B,KAAK,CAAC+B,YACvB,CAAC;IACD,MAAMC,WAAW,GAAGb,mBAAmB,CAACV,KAAK,EAAED,YAAY,CAACC,KAAK,CAAC;IAClE,MAAMwB,UAAU,GAAGd,mBAAmB,CAACR,IAAI,EAAEH,YAAY,CAACG,IAAI,CAAC;IAE/D,IACES,YAAY,CAACY,WAAW,EAAExB,YAAY,CAACC,KAAK,CAAC,IAC7CW,YAAY,CAACa,UAAU,EAAEzB,YAAY,CAACG,IAAI,CAAC,EAC3C;MACA,OAAO,EAAE;IACX;IAEA,OAAQ,GAAEqB,WAAY,GAAEC,UAAW,EAAC;EACtC,CAAC,EAAE,CACDjC,KAAK,CAACjB,KAAK,EACXiB,KAAK,CAAC+B,YAAY,EAClBvB,YAAY,CAACC,KAAK,EAClBD,YAAY,CAACG,IAAI,CAClB,CAAC;EAEF,MAAMuB,aAA0B,GAAA7D,aAAA,CAAAA,aAAA,KAC3B2B,KAAK;IACRc,aAAa;IACb/B,KAAK,EAAE6C,SAAS;IAChBO,SAAS,EAAEnB,WAAW;IACtBK,gBAAgB;IAChBM,iBAAiB,EAAEA,iBAAiB;IACpCS,eAAe,EAAEX;EAAqB,EACvC;EAED,MAAM;IACJY,EAAE;IACFC,IAAI;IACJC,QAAQ;IACRC,SAAS;IACTrC,KAAK,GAAGC,WAAW;IACnBqC,QAAQ;IACRC,IAAI;IACJC,OAAO;IACPC,QAAQ;IACR7D,KAAK,GAAG,EAAE;IACV8D,cAAc;IACdC,WAAW;IACXC,UAAU;IACVC,YAAY;IACZC;EACF,CAAC,GAAG,IAAAC,oBAAa,EAAChB,aAAa,CAAC;EAEhC,MAAMiB,MAAmB,GAAG,IAAApC,cAAO,EACjC,MAAMe,mBAAmB,CAAC/C,KAAK,CAAC,EAChC,CAACA,KAAK,CACR,CAAC;EAED,IAAAgC,cAAO,EAAC,MAAM;IACZ,IAAI,CAACuB,IAAI,IAAIC,QAAQ,KAAKY,MAAM,CAAC1C,KAAK,IAAI0C,MAAM,CAACxC,IAAI,EAAE;MACrDsC,eAAe,CAAE,GAAEE,MAAM,CAAC1C,KAAM,IAAG0C,MAAM,CAACxC,IAAK,EAAC,CAAC;IACnD;EACF,CAAC,EAAE,CAACwC,MAAM,CAAC1C,KAAK,EAAE0C,MAAM,CAACxC,IAAI,EAAE4B,QAAQ,EAAED,IAAI,EAAEW,eAAe,CAAC,CAAC;EAEhE,MAAMG,MAAM,GAAGX,QAAQ,GACnB,OAAO,GACPE,OAAO,GACP,MAAM,GACND,IAAI,GACJ,MAAM,GACN,IAAI;EAER,MAAMW,eAAgC,GAAAhF,aAAA;IACpCgE,EAAE;IACFiB,KAAK,EAAG,GAAEjB,EAAG,cAAa;IAC1BG,SAAS,EAAE,IAAAe,mBAAU,EAAC,wBAAwB,EAAEf,SAAS,CAAC;IAC1DrC;EAAK,GACF,IAAAqD,uBAAgB,EAACxD,KAAK,CAAC,CAC3B;EAED,OACExE,MAAA,CAAAc,OAAA,CAAAmH,aAAA,CAAC1H,WAAA,CAAAO,OAAU,EAAK+G,eAAe,EAC7B7H,MAAA,CAAAc,OAAA,CAAAmH,aAAA,CAACzH,YAAA,CAAA0H,cAAc;IACbC,OAAO;IACPtB,EAAE,EAAG,GAAEA,EAAG,QAAQ;IAClBnB,MAAM,EAAEiC,MAAO;IACfC,MAAM,EAAEA,MAAO;IACfQ,WAAW,EAAEhB,QAAQ,GAAG,UAAU,GAAGjD,SAAU;IAC/CiD,QAAQ,EAAEA,QAAS;IACnBiB,QAAQ,EAAEb,YAAa;IACvBc,MAAM,EAAEf,UAAW;IACnBgB,OAAO,EAAEjB,WAAY;IACrBkB,SAAS,EAAC,GAAG;IACbC,SAAS,EAAC,SAAS;IACnBC,MAAM,EAAE,CAAA7F,aAAA;MAEJgE,EAAE,EAAE,OAAO;MACXlC,KAAK,EAAEO,UAAU;MACjByD,IAAI,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;MACxBC,oBAAoB,EAAE5D,YAAY,CAAC,OAAO,CAAC;MAC3C6D,YAAY,EAAE;IAAc,GACzBxB,cAAc,GAAAxE,aAAA;MAGjBgE,EAAE,EAAE,MAAM;MACVlC,KAAK,EAAES,SAAS;MAChBuD,IAAI,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;MACxBC,oBAAoB,EAAE5D,YAAY,CAAC,MAAM,CAAC;MAC1C6D,YAAY,EAAE;IAAa,GACxBxB,cAAc;EAEnB,CACH,CACS,CAAC;AAEjB;AAEA,SAASzB,YAAYA,CAACrC,KAAa,EAAEuF,WAAmB,EAAE;EACxD,OAAOvF,KAAK,KAAM,GAAEuF,WAAY,GAAEA,WAAY,EAAC;AACjD;AAEA,SAASxC,mBAAmBA,CAAC/C,KAAa,EAAE;EAAA,IAAAwF,gBAAA,EAAAC,iBAAA;EAC1C,MAAM/D,KAAK,IAAA8D,gBAAA,GAAGxF,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAE0F,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,cAAAF,gBAAA,cAAAA,gBAAA,GAAI,EAAE;EAC1C,MAAM5D,IAAI,IAAA6D,iBAAA,GAAGzF,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAE0F,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,cAAAD,iBAAA,cAAAA,iBAAA,GAAI,EAAE;EAEzC,OAAO;IACL/D,KAAK;IACLE;EACF,CAAC;AACH;AAEA,SAASQ,mBAAmBA,CAACpC,KAAa,EAAEuF,WAAmB,EAAE;EAC/D,IAAI,CAACvF,KAAK,EAAE;IACV,OAAQ,GAAEuF,WAAY,GAAEA,WAAY,EAAC;EACvC;EAEA,IAAIvF,KAAK,CAACN,MAAM,KAAK,CAAC,EAAE;IACtB,OAAQ,GAAEM,KAAM,GAAEuF,WAAY,EAAC;EACjC;EAEA,OAAOvF,KAAK;AACd;AAEA,SAAS2C,oBAAoBA,CAC3BgD,IAAY,EACZlE,YAA8C,EAC9C;EACA,MAAM;IAAEC,KAAK;IAAEE;EAAK,CAAC,GAAGmB,mBAAmB,CAAC4C,IAAI,CAAC;EAEjD,MAAMC,WAAW,GAAG7E,MAAM,CAACW,KAAK,CAAC;EAEjC,MAAMmE,QAA0B,GAAG,EAAE;EAErC,IACEnE,KAAK,CAACoE,QAAQ,CAACrE,YAAY,CAACC,KAAK,CAAC,IAClCkE,WAAW,GAAG,CAAC,IACfA,WAAW,GAAG,EAAE,EAChB;IACAC,QAAQ,CAACzG,IAAI,CACX,IAAI2G,iBAAS,CAAC,mBAAmB,EAAE;MACjCC,aAAa,EAAE;QAAEtE,KAAK,EAAEA;MAAM;IAChC,CAAC,CACH,CAAC;EACH;EAEA,IAAIE,IAAI,CAACkE,QAAQ,CAACrE,YAAY,CAACG,IAAI,CAAC,EAAE;IACpCiE,QAAQ,CAACzG,IAAI,CACX,IAAI2G,iBAAS,CAAC,kBAAkB,EAAE;MAChCC,aAAa,EAAE;QAAEpE,IAAI,EAAEA;MAAK;IAC9B,CAAC,CACH,CAAC;EACH;EAEA,IAAIiE,QAAQ,CAACnG,MAAM,EAAE;IACnB,OAAOmG,QAAQ;EACjB;AACF;AAEA7E,MAAM,CAACiF,4BAA4B,GAAG,IAAI;AAAA,IAAAC,QAAA,GAC3BlF,MAAM;AAAAmF,OAAA,CAAA5I,OAAA,GAAA2I,QAAA"}
|
|
@@ -57,7 +57,7 @@ Name.Last = function LastName(props) {
|
|
|
57
57
|
});
|
|
58
58
|
return _react.default.createElement(Name, nameProps);
|
|
59
59
|
};
|
|
60
|
-
Name.
|
|
60
|
+
Name.Last['_supportsSpacingProps'] = true;
|
|
61
61
|
Name.Company = function CompanyName(props) {
|
|
62
62
|
const translations = (0, _useTranslation.default)().CompanyName;
|
|
63
63
|
const errorMessages = (0, _react.useMemo)(() => {
|
|
@@ -74,7 +74,7 @@ Name.Company = function CompanyName(props) {
|
|
|
74
74
|
});
|
|
75
75
|
return _react.default.createElement(Name, StringFieldProps);
|
|
76
76
|
};
|
|
77
|
-
Name.
|
|
77
|
+
Name.Company['_supportsSpacingProps'] = true;
|
|
78
78
|
var _default = Name;
|
|
79
79
|
exports.default = _default;
|
|
80
80
|
//# sourceMappingURL=Name.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Name.js","names":["_react","_interopRequireWildcard","require","_String","_interopRequireDefault","_useTranslation","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","Name","props","StringFieldProps","trim","autoComplete","pattern","createElement","_supportsSpacingProps","First","FirstName","translations","useTranslation","errorMessages","useMemo","errorRequired","errorPattern","nameProps","label","Last","LastName","Company","CompanyName","_default","exports"],"sources":["../../../../../../src/extensions/forms/Field/Name/Name.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport StringField, { Props as StringFieldProps } from '../String'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type Props = StringFieldProps\n\nfunction Name(props: Props) {\n const StringFieldProps: Props = {\n trim: true,\n autoComplete: 'name',\n pattern: '^(?!.*[\\\\-\\\\s]{2})[\\\\p{L}]+([ \\\\-][\\\\p{L}]+)*$',\n ...props,\n }\n\n return <StringField {...StringFieldProps} />\n}\nName._supportsSpacingProps = true\n\nName.First = function FirstName(props: Props) {\n const translations = useTranslation().FirstName\n const errorMessages = useMemo(() => {\n return {\n 'Field.errorRequired': translations.errorRequired,\n 'Field.errorPattern': translations.errorPattern,\n ...props.errorMessages,\n }\n }, [\n props.errorMessages,\n translations.errorPattern,\n translations.errorRequired,\n ])\n\n const nameProps: Props = {\n label: translations.label,\n autoComplete: 'given-name',\n ...props,\n errorMessages,\n }\n\n return <Name {...nameProps} />\n}\nName.First['_supportsSpacingProps'] = true\n\nName.Last = function LastName(props: Props) {\n const translations = useTranslation().LastName\n const errorMessages = useMemo(() => {\n return {\n 'Field.errorRequired': translations.errorRequired,\n 'Field.errorPattern': translations.errorPattern,\n ...props.errorMessages,\n }\n }, [\n props.errorMessages,\n translations.errorPattern,\n translations.errorRequired,\n ])\n\n const nameProps: Props = {\n label: translations.label,\n autoComplete: 'family-name',\n ...props,\n errorMessages,\n }\n\n return <Name {...nameProps} />\n}\nName.
|
|
1
|
+
{"version":3,"file":"Name.js","names":["_react","_interopRequireWildcard","require","_String","_interopRequireDefault","_useTranslation","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","Name","props","StringFieldProps","trim","autoComplete","pattern","createElement","_supportsSpacingProps","First","FirstName","translations","useTranslation","errorMessages","useMemo","errorRequired","errorPattern","nameProps","label","Last","LastName","Company","CompanyName","_default","exports"],"sources":["../../../../../../src/extensions/forms/Field/Name/Name.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport StringField, { Props as StringFieldProps } from '../String'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type Props = StringFieldProps\n\nfunction Name(props: Props) {\n const StringFieldProps: Props = {\n trim: true,\n autoComplete: 'name',\n pattern: '^(?!.*[\\\\-\\\\s]{2})[\\\\p{L}]+([ \\\\-][\\\\p{L}]+)*$',\n ...props,\n }\n\n return <StringField {...StringFieldProps} />\n}\nName._supportsSpacingProps = true\n\nName.First = function FirstName(props: Props) {\n const translations = useTranslation().FirstName\n const errorMessages = useMemo(() => {\n return {\n 'Field.errorRequired': translations.errorRequired,\n 'Field.errorPattern': translations.errorPattern,\n ...props.errorMessages,\n }\n }, [\n props.errorMessages,\n translations.errorPattern,\n translations.errorRequired,\n ])\n\n const nameProps: Props = {\n label: translations.label,\n autoComplete: 'given-name',\n ...props,\n errorMessages,\n }\n\n return <Name {...nameProps} />\n}\nName.First['_supportsSpacingProps'] = true\n\nName.Last = function LastName(props: Props) {\n const translations = useTranslation().LastName\n const errorMessages = useMemo(() => {\n return {\n 'Field.errorRequired': translations.errorRequired,\n 'Field.errorPattern': translations.errorPattern,\n ...props.errorMessages,\n }\n }, [\n props.errorMessages,\n translations.errorPattern,\n translations.errorRequired,\n ])\n\n const nameProps: Props = {\n label: translations.label,\n autoComplete: 'family-name',\n ...props,\n errorMessages,\n }\n\n return <Name {...nameProps} />\n}\nName.Last['_supportsSpacingProps'] = true\n\nName.Company = function CompanyName(props: Props) {\n const translations = useTranslation().CompanyName\n const errorMessages = useMemo(() => {\n return {\n 'Field.errorRequired': translations.errorRequired,\n ...props.errorMessages,\n }\n }, [props.errorMessages, translations.errorRequired])\n\n const StringFieldProps: Props = {\n label: translations.label,\n pattern:\n '^(?!.*[-\\\\s]{2})(?!.*[\\\\.]{2})[\\\\p{L}\\\\p{N}][\\\\p{L}\\\\p{N}\\\\p{P}\\\\p{Zs}.]*[\\\\p{L}\\\\p{N}\\\\p{P}]$',\n autoComplete: 'organization',\n ...props,\n errorMessages,\n }\n\n return <Name {...StringFieldProps} />\n}\nName.Company['_supportsSpacingProps'] = true\n\nexport default Name\n"],"mappings":"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"}
|
|
@@ -13,4 +13,5 @@ declare namespace NationalIdentityNumber {
|
|
|
13
13
|
export declare function getAgeByBirthDate(birthDate: Date): number;
|
|
14
14
|
export declare function getBirthDateByFnrOrDnr(value: string): Date;
|
|
15
15
|
export declare function createMinimumAgeValidator(age: number): (value: string) => FormError;
|
|
16
|
+
export declare function createMinimumAgeVerifier(age: number): (value: string) => boolean;
|
|
16
17
|
export default NationalIdentityNumber;
|
|
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.createMinimumAgeValidator = createMinimumAgeValidator;
|
|
7
|
+
exports.createMinimumAgeVerifier = createMinimumAgeVerifier;
|
|
7
8
|
exports.default = void 0;
|
|
8
9
|
exports.getAgeByBirthDate = getAgeByBirthDate;
|
|
9
10
|
exports.getBirthDateByFnrOrDnr = getBirthDateByFnrOrDnr;
|
|
@@ -148,6 +149,15 @@ function createMinimumAgeValidator(age) {
|
|
|
148
149
|
});
|
|
149
150
|
};
|
|
150
151
|
}
|
|
152
|
+
function createMinimumAgeVerifier(age) {
|
|
153
|
+
const validator = createMinimumAgeValidator(age);
|
|
154
|
+
return value => {
|
|
155
|
+
if ((value === null || value === void 0 ? void 0 : value.length) >= 7) {
|
|
156
|
+
return !(validator(value) instanceof Error);
|
|
157
|
+
}
|
|
158
|
+
return false;
|
|
159
|
+
};
|
|
160
|
+
}
|
|
151
161
|
NationalIdentityNumber._supportsSpacingProps = true;
|
|
152
162
|
var _default = NationalIdentityNumber;
|
|
153
163
|
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NationalIdentityNumber.js","names":["_react","_interopRequireWildcard","require","_String","_interopRequireDefault","_fnrvalidator","_utils","_useTranslation","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","NationalIdentityNumber","props","translations","useTranslation","label","errorRequired","errorFnr","errorFnrLength","errorDnr","errorDnrLength","errorMessages","useMemo","identificationNumberIsOfLength","identificationNumber","fnrValidator","useCallback","parseInt","substring","Error","fnrIs11Digits","fnr","status","dnrValidator","dnrIs11Digits","dnr","dnrAndFnrValidator","dnrValidationPattern","RegExp","test","validate","omitMask","validator","onChangeValidator","onBlurValidator","width","labelProp","mask","Array","fill","onBlurValidatorToUse","StringFieldProps","inputMode","exportValidators","createElement","getAgeByBirthDate","birthDate","today","Date","age","getFullYear","month","getMonth","day","getDate","getBirthDateByFnrOrDnr","yearPart","centuryNumber","isBornIn20XX","year","differentiatorValue","isDnr","createMinimumAgeValidator","identificationNumberIs7DigitsOrMore","FormError","validationRule","date","messageValues","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from 'react'\nimport StringField, { Props as StringFieldProps } from '../String'\nimport { dnr, fnr } from '@navikt/fnrvalidator'\nimport { Validator } from '../../types'\nimport { FormError } from '../../utils'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type Props = Omit<StringFieldProps, 'onBlurValidator'> & {\n omitMask?: boolean\n validate?: boolean\n onBlurValidator?: Validator<string> | false\n}\n\nfunction NationalIdentityNumber(props: Props) {\n const translations = useTranslation().NationalIdentityNumber\n const {\n label,\n errorRequired,\n errorFnr,\n errorFnrLength,\n errorDnr,\n errorDnrLength,\n } = translations\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': errorRequired,\n 'Field.errorPattern': errorFnr,\n ...props.errorMessages,\n }),\n [errorRequired, errorFnr, props.errorMessages]\n )\n\n const identificationNumberIsOfLength = (\n identificationNumber: string,\n length: number\n ) => {\n return identificationNumber?.length === length\n }\n\n const fnrValidator = useCallback(\n (value: string) => {\n if (value !== undefined) {\n if (Number.parseInt(value.substring(0, 1)) > 3) {\n return Error(errorFnr)\n }\n\n const fnrIs11Digits = identificationNumberIsOfLength(value, 11)\n\n if (!fnrIs11Digits) {\n return Error(errorFnrLength)\n }\n if (fnrIs11Digits && fnr(value).status === 'invalid') {\n return Error(errorFnr)\n }\n }\n },\n [errorFnr, errorFnrLength]\n )\n\n const dnrValidator = useCallback(\n (value: string) => {\n if (value !== undefined) {\n if (Number.parseInt(value.substring(0, 1)) < 4) {\n return Error(errorDnr)\n }\n\n const dnrIs11Digits = identificationNumberIsOfLength(value, 11)\n\n if (!dnrIs11Digits) {\n return Error(errorDnrLength)\n }\n if (dnrIs11Digits && dnr(value).status === 'invalid') {\n return Error(errorDnr)\n }\n }\n },\n [errorDnr, errorDnrLength]\n )\n\n const dnrAndFnrValidator = useCallback(\n (value: string) => {\n const dnrValidationPattern = '^[4-9].*' // 1st num is increased by 4. i.e, if 01.01.1985, D number would be 410185.\n\n if (new RegExp(dnrValidationPattern).test(value)) {\n return dnrValidator(value)\n }\n return fnrValidator(value)\n },\n [dnrValidator, fnrValidator]\n )\n\n const {\n validate = true,\n omitMask,\n // Deprecated – can be removed in v11\n validator,\n onChangeValidator = validator,\n onBlurValidator = dnrAndFnrValidator,\n width,\n label: labelProp,\n } = props\n\n const mask = useMemo(\n () =>\n omitMask\n ? Array(11).fill(/\\d/)\n : [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ],\n [omitMask]\n )\n\n const onBlurValidatorToUse =\n onBlurValidator === false ? undefined : onBlurValidator\n\n const StringFieldProps: StringFieldProps = {\n ...props,\n label: labelProp ?? label,\n errorMessages,\n mask,\n width: width ?? 'medium',\n inputMode: 'numeric',\n onChangeValidator: validate ? onChangeValidator : undefined,\n onBlurValidator: validate ? onBlurValidatorToUse : undefined,\n exportValidators: {\n dnrValidator,\n fnrValidator,\n dnrAndFnrValidator,\n },\n }\n\n return <StringField {...StringFieldProps} />\n}\n\nexport function getAgeByBirthDate(birthDate: Date): number {\n const today = new Date()\n const age = today.getFullYear() - birthDate.getFullYear()\n const month = today.getMonth() - birthDate.getMonth()\n const day = today.getDate() - birthDate.getDate()\n\n if (month < 0 || (month === 0 && day < 0)) {\n return age - 1\n }\n\n return age\n}\n\nexport function getBirthDateByFnrOrDnr(value: string) {\n if (value === undefined) {\n return // stop here\n }\n\n const yearPart = value.substring(4, 6)\n const centuryNumber = Number.parseInt(value.substring(6, 7))\n\n const isBornIn20XX = centuryNumber >= 5\n const year = isBornIn20XX ? `20${yearPart}` : `19${yearPart}`\n const month = Number.parseInt(value.substring(2, 4))\n\n const differentiatorValue =\n value.length > 0 ? Number.parseInt(value.substring(0, 1)) : undefined\n const isDnr = differentiatorValue && differentiatorValue > 3\n\n const day = isDnr\n ? Number.parseInt(value.substring(0, 2)) - 40\n : Number.parseInt(value.substring(0, 2))\n\n return new Date(Number.parseInt(year), month - 1, day)\n}\n\nexport function createMinimumAgeValidator(age: number) {\n return (value: string) => {\n if (typeof value !== 'string') {\n return // stop here\n }\n\n const identificationNumberIs7DigitsOrMore = value?.length >= 7\n\n if (!identificationNumberIs7DigitsOrMore) {\n return new FormError(\n 'NationalIdentityNumber.errorMinimumAgeValidatorLength',\n {\n validationRule: 'errorMinimumAgeValidatorLength', // \"validationRule\" Will be removed in future PR\n }\n )\n }\n\n if (identificationNumberIs7DigitsOrMore) {\n const date = getBirthDateByFnrOrDnr(value)\n if (getAgeByBirthDate(date) >= age) {\n return // stop here\n }\n }\n\n return new FormError(\n 'NationalIdentityNumber.errorMinimumAgeValidator',\n {\n validationRule: 'errorMinimumAgeValidator', // \"validationRule\" Will be removed in future PR\n messageValues: { age: String(age) },\n }\n )\n }\n}\n\nNationalIdentityNumber._supportsSpacingProps = true\nexport default NationalIdentityNumber\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"NationalIdentityNumber.js","names":["_react","_interopRequireWildcard","require","_String","_interopRequireDefault","_fnrvalidator","_utils","_useTranslation","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","NationalIdentityNumber","props","translations","useTranslation","label","errorRequired","errorFnr","errorFnrLength","errorDnr","errorDnrLength","errorMessages","useMemo","identificationNumberIsOfLength","identificationNumber","fnrValidator","useCallback","parseInt","substring","Error","fnrIs11Digits","fnr","status","dnrValidator","dnrIs11Digits","dnr","dnrAndFnrValidator","dnrValidationPattern","RegExp","test","validate","omitMask","validator","onChangeValidator","onBlurValidator","width","labelProp","mask","Array","fill","onBlurValidatorToUse","StringFieldProps","inputMode","exportValidators","createElement","getAgeByBirthDate","birthDate","today","Date","age","getFullYear","month","getMonth","day","getDate","getBirthDateByFnrOrDnr","yearPart","centuryNumber","isBornIn20XX","year","differentiatorValue","isDnr","createMinimumAgeValidator","identificationNumberIs7DigitsOrMore","FormError","validationRule","date","messageValues","createMinimumAgeVerifier","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from 'react'\nimport StringField, { Props as StringFieldProps } from '../String'\nimport { dnr, fnr } from '@navikt/fnrvalidator'\nimport { Validator } from '../../types'\nimport { FormError } from '../../utils'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type Props = Omit<StringFieldProps, 'onBlurValidator'> & {\n omitMask?: boolean\n validate?: boolean\n onBlurValidator?: Validator<string> | false\n}\n\nfunction NationalIdentityNumber(props: Props) {\n const translations = useTranslation().NationalIdentityNumber\n const {\n label,\n errorRequired,\n errorFnr,\n errorFnrLength,\n errorDnr,\n errorDnrLength,\n } = translations\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': errorRequired,\n 'Field.errorPattern': errorFnr,\n ...props.errorMessages,\n }),\n [errorRequired, errorFnr, props.errorMessages]\n )\n\n const identificationNumberIsOfLength = (\n identificationNumber: string,\n length: number\n ) => {\n return identificationNumber?.length === length\n }\n\n const fnrValidator = useCallback(\n (value: string) => {\n if (value !== undefined) {\n if (Number.parseInt(value.substring(0, 1)) > 3) {\n return Error(errorFnr)\n }\n\n const fnrIs11Digits = identificationNumberIsOfLength(value, 11)\n\n if (!fnrIs11Digits) {\n return Error(errorFnrLength)\n }\n if (fnrIs11Digits && fnr(value).status === 'invalid') {\n return Error(errorFnr)\n }\n }\n },\n [errorFnr, errorFnrLength]\n )\n\n const dnrValidator = useCallback(\n (value: string) => {\n if (value !== undefined) {\n if (Number.parseInt(value.substring(0, 1)) < 4) {\n return Error(errorDnr)\n }\n\n const dnrIs11Digits = identificationNumberIsOfLength(value, 11)\n\n if (!dnrIs11Digits) {\n return Error(errorDnrLength)\n }\n if (dnrIs11Digits && dnr(value).status === 'invalid') {\n return Error(errorDnr)\n }\n }\n },\n [errorDnr, errorDnrLength]\n )\n\n const dnrAndFnrValidator = useCallback(\n (value: string) => {\n const dnrValidationPattern = '^[4-9].*' // 1st num is increased by 4. i.e, if 01.01.1985, D number would be 410185.\n\n if (new RegExp(dnrValidationPattern).test(value)) {\n return dnrValidator(value)\n }\n return fnrValidator(value)\n },\n [dnrValidator, fnrValidator]\n )\n\n const {\n validate = true,\n omitMask,\n // Deprecated – can be removed in v11\n validator,\n onChangeValidator = validator,\n onBlurValidator = dnrAndFnrValidator,\n width,\n label: labelProp,\n } = props\n\n const mask = useMemo(\n () =>\n omitMask\n ? Array(11).fill(/\\d/)\n : [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ],\n [omitMask]\n )\n\n const onBlurValidatorToUse =\n onBlurValidator === false ? undefined : onBlurValidator\n\n const StringFieldProps: StringFieldProps = {\n ...props,\n label: labelProp ?? label,\n errorMessages,\n mask,\n width: width ?? 'medium',\n inputMode: 'numeric',\n onChangeValidator: validate ? onChangeValidator : undefined,\n onBlurValidator: validate ? onBlurValidatorToUse : undefined,\n exportValidators: {\n dnrValidator,\n fnrValidator,\n dnrAndFnrValidator,\n },\n }\n\n return <StringField {...StringFieldProps} />\n}\n\nexport function getAgeByBirthDate(birthDate: Date): number {\n const today = new Date()\n const age = today.getFullYear() - birthDate.getFullYear()\n const month = today.getMonth() - birthDate.getMonth()\n const day = today.getDate() - birthDate.getDate()\n\n if (month < 0 || (month === 0 && day < 0)) {\n return age - 1\n }\n\n return age\n}\n\nexport function getBirthDateByFnrOrDnr(value: string) {\n if (value === undefined) {\n return // stop here\n }\n\n const yearPart = value.substring(4, 6)\n const centuryNumber = Number.parseInt(value.substring(6, 7))\n\n const isBornIn20XX = centuryNumber >= 5\n const year = isBornIn20XX ? `20${yearPart}` : `19${yearPart}`\n const month = Number.parseInt(value.substring(2, 4))\n\n const differentiatorValue =\n value.length > 0 ? Number.parseInt(value.substring(0, 1)) : undefined\n const isDnr = differentiatorValue && differentiatorValue > 3\n\n const day = isDnr\n ? Number.parseInt(value.substring(0, 2)) - 40\n : Number.parseInt(value.substring(0, 2))\n\n return new Date(Number.parseInt(year), month - 1, day)\n}\n\nexport function createMinimumAgeValidator(age: number) {\n return (value: string) => {\n if (typeof value !== 'string') {\n return // stop here\n }\n\n const identificationNumberIs7DigitsOrMore = value?.length >= 7\n\n if (!identificationNumberIs7DigitsOrMore) {\n return new FormError(\n 'NationalIdentityNumber.errorMinimumAgeValidatorLength',\n {\n validationRule: 'errorMinimumAgeValidatorLength', // \"validationRule\" Will be removed in future PR\n }\n )\n }\n\n if (identificationNumberIs7DigitsOrMore) {\n const date = getBirthDateByFnrOrDnr(value)\n if (getAgeByBirthDate(date) >= age) {\n return // stop here\n }\n }\n\n return new FormError(\n 'NationalIdentityNumber.errorMinimumAgeValidator',\n {\n validationRule: 'errorMinimumAgeValidator', // \"validationRule\" Will be removed in future PR\n messageValues: { age: String(age) },\n }\n )\n }\n}\n\nexport function createMinimumAgeVerifier(age: number) {\n const validator = createMinimumAgeValidator(age)\n return (value: string) => {\n if (value?.length >= 7) {\n return !(validator(value) instanceof Error)\n }\n\n return false\n }\n}\n\nNationalIdentityNumber._supportsSpacingProps = true\nexport default NationalIdentityNumber\n"],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.PasswordProperties = void 0;
|
|
7
|
+
const PasswordProperties = {
|
|
8
|
+
pattern: {
|
|
9
|
+
doc: 'Validation based on regex pattern for the number field e.g. `pattern="w{8}d{4}"`.',
|
|
10
|
+
type: 'string',
|
|
11
|
+
status: 'optional'
|
|
12
|
+
},
|
|
13
|
+
size: {
|
|
14
|
+
doc: '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. Also, if you define a number like size="2" then it will be forwarded as the input element attribute.',
|
|
15
|
+
type: 'object',
|
|
16
|
+
status: 'optional'
|
|
17
|
+
},
|
|
18
|
+
innerRef: {
|
|
19
|
+
doc: '`ElementRef` passed on to the password `input` element.',
|
|
20
|
+
type: 'object',
|
|
21
|
+
status: 'optional'
|
|
22
|
+
},
|
|
23
|
+
'[Space](/uilib/layout/space/properties)': {
|
|
24
|
+
doc: 'Spacing properties like `top` or `bottom` are supported.',
|
|
25
|
+
type: ['string', 'object'],
|
|
26
|
+
status: 'optional'
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
exports.PasswordProperties = PasswordProperties;
|
|
30
|
+
//# sourceMappingURL=PasswordDocs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PasswordDocs.js","names":["PasswordProperties","pattern","doc","type","status","size","innerRef","exports"],"sources":["../../../../../../src/extensions/forms/Field/Password/PasswordDocs.tsx"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const PasswordProperties: PropertiesTableProps = {\n pattern: {\n doc: 'Validation based on regex pattern for the number field e.g. `pattern=\"w{8}d{4}\"`.',\n type: 'string',\n status: 'optional',\n },\n size: {\n doc: '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. Also, if you define a number like size=\"2\" then it will be forwarded as the input element attribute.',\n type: 'object',\n status: 'optional',\n },\n innerRef: {\n doc: '`ElementRef` passed on to the password `input` element.',\n type: 'object',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n"],"mappings":";;;;;;AAEO,MAAMA,kBAAwC,GAAG;EACtDC,OAAO,EAAE;IACPC,GAAG,EAAE,mFAAmF;IACxFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,8PAA8P;IACnQC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,QAAQ,EAAE;IACRJ,GAAG,EAAE,yDAAyD;IAC9DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAAAG,OAAA,CAAAP,kBAAA,GAAAA,kBAAA"}
|
|
@@ -9,7 +9,17 @@ export type Props = Pick<FieldBlockProps, 'error' | 'warning' | 'info' | 'width'
|
|
|
9
9
|
* You can also use the value of another field to define the country, by using a path value i.e. `/myCountryPath`.
|
|
10
10
|
* Default: `NO`
|
|
11
11
|
*/
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated – use countryCode instead. Will be removed in v11.
|
|
14
|
+
*/
|
|
12
15
|
country?: Path | string;
|
|
16
|
+
/**
|
|
17
|
+
* Defines which country the postal code and city is for.
|
|
18
|
+
* Setting it to anything other than `no` will remove the default norwegian postal code pattern.
|
|
19
|
+
* You can also use the value of another field to define the countryCode, by using a path value i.e. `/myCountryCodePath`.
|
|
20
|
+
* Default: `NO`
|
|
21
|
+
*/
|
|
22
|
+
countryCode?: Path | string;
|
|
13
23
|
help?: HelpProps;
|
|
14
24
|
};
|
|
15
25
|
declare function PostalCodeAndCity(props: Props): import("react/jsx-runtime").JSX.Element;
|
|
@@ -11,7 +11,7 @@ var _Composition = _interopRequireDefault(require("../Composition"));
|
|
|
11
11
|
var _useTranslation = _interopRequireDefault(require("../../hooks/useTranslation"));
|
|
12
12
|
var _useDataValue = _interopRequireDefault(require("../../hooks/useDataValue"));
|
|
13
13
|
var _defaults = require("../../../../shared/defaults");
|
|
14
|
-
const _excluded = ["postalCode", "city", "help", "width", "country"];
|
|
14
|
+
const _excluded = ["postalCode", "city", "help", "width", "country", "countryCode"];
|
|
15
15
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
16
16
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
17
17
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
@@ -33,20 +33,32 @@ function PostalCodeAndCity(props) {
|
|
|
33
33
|
city = {},
|
|
34
34
|
help,
|
|
35
35
|
width = 'large',
|
|
36
|
-
country
|
|
36
|
+
country,
|
|
37
|
+
countryCode = _defaults.COUNTRY
|
|
37
38
|
} = props,
|
|
38
39
|
fieldBlockProps = _objectWithoutProperties(props, _excluded);
|
|
40
|
+
const countryCodeValue = getSourceValue(country || countryCode);
|
|
41
|
+
const handleCityDefaults = (0, _react.useCallback)(city => {
|
|
42
|
+
const props = {};
|
|
43
|
+
switch (countryCodeValue) {
|
|
44
|
+
case _defaults.COUNTRY:
|
|
45
|
+
{
|
|
46
|
+
props.pattern = '^[A-Za-zÆØÅæøå -]+$';
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return _objectSpread(_objectSpread({}, props), city);
|
|
51
|
+
}, [countryCodeValue]);
|
|
39
52
|
const {
|
|
40
53
|
pattern: cityPattern,
|
|
41
54
|
className: cityClassName,
|
|
42
55
|
label: cityLabel,
|
|
43
56
|
width: cityWidth,
|
|
44
57
|
errorMessages: cityErrorMessages
|
|
45
|
-
} = city;
|
|
46
|
-
const
|
|
47
|
-
const handleDefaults = (0, _react.useCallback)(postalCode => {
|
|
58
|
+
} = handleCityDefaults(city);
|
|
59
|
+
const handlePostalCodeDefaults = (0, _react.useCallback)(postalCode => {
|
|
48
60
|
const props = {};
|
|
49
|
-
switch (
|
|
61
|
+
switch (countryCodeValue) {
|
|
50
62
|
case _defaults.COUNTRY:
|
|
51
63
|
case 'DK':
|
|
52
64
|
case 'CH':
|
|
@@ -61,7 +73,7 @@ function PostalCodeAndCity(props) {
|
|
|
61
73
|
break;
|
|
62
74
|
}
|
|
63
75
|
return _objectSpread(_objectSpread({}, props), postalCode);
|
|
64
|
-
}, [
|
|
76
|
+
}, [countryCodeValue]);
|
|
65
77
|
const {
|
|
66
78
|
mask: postalCodeMask,
|
|
67
79
|
pattern: postalCodePattern,
|
|
@@ -70,7 +82,7 @@ function PostalCodeAndCity(props) {
|
|
|
70
82
|
label: postalCodeLabel,
|
|
71
83
|
width: postalCodeWidth,
|
|
72
84
|
errorMessages: postalCodeErrorMessages
|
|
73
|
-
} =
|
|
85
|
+
} = handlePostalCodeDefaults(postalCode);
|
|
74
86
|
return _react.default.createElement(_Composition.default, _extends({
|
|
75
87
|
className: (0, _classnames.default)('dnb-forms-field-postal-code-and-city', props.className)
|
|
76
88
|
}, fieldBlockProps, {
|
|
@@ -88,7 +100,8 @@ function PostalCodeAndCity(props) {
|
|
|
88
100
|
width: postalCodeWidth !== null && postalCodeWidth !== void 0 ? postalCodeWidth : false,
|
|
89
101
|
inputClassName: "dnb-forms-field-postal-code-and-city__postal-code-input",
|
|
90
102
|
inputMode: "numeric",
|
|
91
|
-
autoComplete: "postal-code"
|
|
103
|
+
autoComplete: "postal-code",
|
|
104
|
+
"data-country-code": country || countryCode
|
|
92
105
|
})), _react.default.createElement(_String.default, _extends({
|
|
93
106
|
help: help
|
|
94
107
|
}, city, {
|
|
@@ -98,7 +111,7 @@ function PostalCodeAndCity(props) {
|
|
|
98
111
|
'Field.errorRequired': translations.City.errorRequired,
|
|
99
112
|
'Field.errorPattern': translations.City.errorPattern
|
|
100
113
|
}, cityErrorMessages), [cityErrorMessages, translations.City.errorPattern, translations.City.errorRequired]),
|
|
101
|
-
pattern: cityPattern
|
|
114
|
+
pattern: cityPattern,
|
|
102
115
|
trim: true,
|
|
103
116
|
width: cityWidth !== null && cityWidth !== void 0 ? cityWidth : 'stretch',
|
|
104
117
|
autoComplete: "address-level2"
|