@dnb/eufemia 10.74.0 → 10.75.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 +28 -0
- package/cjs/components/country-flag/CountryFlag.js +6 -3
- package/cjs/components/country-flag/CountryFlag.js.map +1 -1
- package/cjs/components/date-picker/DatePicker.d.ts +16 -7
- package/cjs/components/date-picker/DatePicker.js +8 -20
- package/cjs/components/date-picker/DatePicker.js.map +1 -1
- package/cjs/components/date-picker/DatePickerCalendar.d.ts +1 -3
- package/cjs/components/date-picker/DatePickerCalendar.js +34 -19
- package/cjs/components/date-picker/DatePickerCalendar.js.map +1 -1
- package/cjs/components/date-picker/DatePickerCalendarNavigator.d.ts +1 -4
- package/cjs/components/date-picker/DatePickerCalendarNavigator.js +1 -10
- package/cjs/components/date-picker/DatePickerCalendarNavigator.js.map +1 -1
- package/cjs/components/date-picker/DatePickerContext.d.ts +1 -0
- package/cjs/components/date-picker/DatePickerContext.js.map +1 -1
- package/cjs/components/date-picker/DatePickerDocs.js +0 -5
- package/cjs/components/date-picker/DatePickerDocs.js.map +1 -1
- package/cjs/components/date-picker/DatePickerFooter.js +2 -2
- package/cjs/components/date-picker/DatePickerFooter.js.map +1 -1
- package/cjs/components/date-picker/DatePickerInput.d.ts +3 -2
- package/cjs/components/date-picker/DatePickerInput.js +9 -8
- package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
- package/cjs/components/date-picker/DatePickerProvider.d.ts +1 -1
- package/cjs/components/date-picker/DatePickerProvider.js +16 -15
- package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
- package/cjs/components/date-picker/DatePickerRange.d.ts +3 -7
- package/cjs/components/date-picker/DatePickerRange.js +10 -8
- package/cjs/components/date-picker/DatePickerRange.js.map +1 -1
- package/cjs/components/date-picker/hooks/useDates.js.map +1 -1
- package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +4 -0
- package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
- package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -0
- package/cjs/components/number-format/NumberUtils.d.ts +1 -1
- package/cjs/extensions/forms/Field/Boolean/Boolean.d.ts +2 -9
- package/cjs/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
- package/cjs/extensions/forms/Field/Date/Date.d.ts +1 -1
- package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
- package/cjs/extensions/forms/Field/Date/DateDocs.js +2 -1
- package/cjs/extensions/forms/Field/Date/DateDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/Indeterminate/Indeterminate.d.ts +1 -1
- package/cjs/extensions/forms/Field/Indeterminate/Indeterminate.js.map +1 -1
- package/cjs/extensions/forms/Field/Indeterminate/IndeterminateDocs.js +1 -1
- package/cjs/extensions/forms/Field/Indeterminate/IndeterminateDocs.js.map +1 -1
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +8 -4
- package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +2 -2
- package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +3 -2
- package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +20 -13
- package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
- package/cjs/extensions/forms/Field/SelectCountry/useCountries.d.ts +2016 -0
- package/cjs/extensions/forms/Field/SelectCountry/useCountries.js +72 -0
- package/cjs/extensions/forms/Field/SelectCountry/useCountries.js.map +1 -0
- package/cjs/extensions/forms/Iterate/Array/Array.js +19 -6
- package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
- package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +10 -0
- package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/cjs/extensions/forms/Iterate/Array/types.d.ts +4 -1
- package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +9 -2
- package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +9 -2
- package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -2
- package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
- package/cjs/extensions/forms/Value/SelectCountry/useCountry.js +6 -1
- package/cjs/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -1
- package/cjs/extensions/forms/Wizard/Container/DisplaySteps.js.map +1 -1
- package/cjs/extensions/forms/Wizard/Container/useCollectStepsData.js.map +1 -1
- package/cjs/extensions/forms/constants/locales/countries/sv-SE.d.ts +257 -0
- package/cjs/extensions/forms/constants/locales/countries/sv-SE.js +263 -0
- package/cjs/extensions/forms/constants/locales/countries/sv-SE.js.map +1 -0
- package/cjs/extensions/forms/constants/locales/en-GB.d.ts +4 -0
- package/cjs/extensions/forms/constants/locales/en-GB.js +4 -0
- package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
- package/cjs/extensions/forms/constants/locales/en-US.d.ts +4 -0
- package/cjs/extensions/forms/constants/locales/index.d.ts +8 -0
- package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +4 -0
- package/cjs/extensions/forms/constants/locales/nb-NO.js +4 -0
- package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
- package/cjs/extensions/forms/constants/locales/sv-SE.d.ts +4 -0
- package/cjs/extensions/forms/constants/locales/sv-SE.js +4 -0
- package/cjs/extensions/forms/constants/locales/sv-SE.js.map +1 -1
- package/cjs/extensions/forms/hooks/useFieldProps.d.ts +2 -1
- package/cjs/extensions/forms/hooks/useFieldProps.js +19 -6
- package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/cjs/extensions/forms/hooks/usePath.d.ts +4 -1
- package/cjs/extensions/forms/hooks/usePath.js +10 -3
- package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
- package/cjs/extensions/forms/hooks/useTranslation.d.ts +2 -2
- package/cjs/extensions/forms/hooks/useTranslation.js.map +1 -1
- package/cjs/extensions/forms/utils/ajv.js +11 -3
- package/cjs/extensions/forms/utils/ajv.js.map +1 -1
- package/cjs/extensions/payment-card/PaymentCard.d.ts +9 -3
- package/cjs/extensions/payment-card/PaymentCard.js +12 -143
- package/cjs/extensions/payment-card/PaymentCard.js.map +1 -1
- package/cjs/extensions/payment-card/PaymentCardDocs.js +13 -13
- package/cjs/extensions/payment-card/PaymentCardDocs.js.map +1 -1
- package/cjs/extensions/payment-card/components/CardFigure.d.ts +12 -0
- package/cjs/extensions/payment-card/components/CardFigure.js +105 -0
- package/cjs/extensions/payment-card/components/CardFigure.js.map +1 -0
- package/cjs/extensions/payment-card/components/CardNumber.d.ts +27 -0
- package/cjs/extensions/payment-card/components/CardNumber.js +37 -0
- package/cjs/extensions/payment-card/components/CardNumber.js.map +1 -0
- package/cjs/extensions/payment-card/components/CardType.d.ts +7 -0
- package/cjs/extensions/payment-card/components/CardType.js +25 -0
- package/cjs/extensions/payment-card/components/CardType.js.map +1 -0
- package/cjs/extensions/payment-card/components/StatusOverlay.d.ts +20 -0
- package/cjs/extensions/payment-card/components/StatusOverlay.js +68 -0
- package/cjs/extensions/payment-card/components/StatusOverlay.js.map +1 -0
- package/cjs/extensions/payment-card/icons/brandLogos/DNB.js +24 -0
- package/cjs/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -0
- package/cjs/extensions/payment-card/icons/brandLogos/Sbanken.js +31 -0
- package/cjs/extensions/payment-card/icons/brandLogos/Sbanken.js.map +1 -0
- package/cjs/extensions/payment-card/icons/index.d.ts +3 -5
- package/cjs/extensions/payment-card/icons/index.js +40 -58
- package/cjs/extensions/payment-card/icons/index.js.map +1 -1
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Bedrift.js +40 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Bedrift.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Business.js +43 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Business.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Corporate.d.ts +3 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Corporate.js +52 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Corporate.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Intro.js +22 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Intro.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/PB.js +61 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/PB.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Pluss.js +29 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/Pluss.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/SagaGold.js +22 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/SagaGold.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/SagaPlatinum.js +43 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/SagaPlatinum.js.map +1 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/WorldElite.d.ts +3 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/WorldElite.js +22 -0
- package/cjs/extensions/payment-card/icons/loyaltyLogos/WorldElite.js.map +1 -0
- package/cjs/extensions/payment-card/icons/providers/BankAxept.js +24 -0
- package/cjs/extensions/payment-card/icons/providers/BankAxept.js.map +1 -0
- package/cjs/extensions/payment-card/icons/providers/ClickToPay.d.ts +3 -0
- package/cjs/extensions/payment-card/icons/providers/ClickToPay.js +24 -0
- package/cjs/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -0
- package/cjs/extensions/payment-card/icons/providers/MastercardDark.js +814 -0
- package/cjs/extensions/payment-card/icons/providers/MastercardDark.js.map +1 -0
- package/cjs/extensions/payment-card/icons/providers/MastercardDefault.js +37 -0
- package/cjs/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -0
- package/cjs/extensions/payment-card/icons/providers/VisaDefault.js +28 -0
- package/cjs/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -0
- package/cjs/extensions/payment-card/icons/providers/VisaPlatinum.js +28 -0
- package/cjs/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -0
- package/cjs/extensions/payment-card/icons/status/index.d.ts +3 -0
- package/cjs/extensions/payment-card/icons/status/index.js +61 -0
- package/cjs/extensions/payment-card/icons/status/index.js.map +1 -0
- package/cjs/extensions/payment-card/index.d.ts +2 -0
- package/cjs/extensions/payment-card/index.js +10 -1
- package/cjs/extensions/payment-card/index.js.map +1 -1
- package/cjs/extensions/payment-card/style/dnb-payment-card.css +173 -163
- package/cjs/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
- package/cjs/extensions/payment-card/style/dnb-payment-card.scss +257 -242
- package/cjs/extensions/payment-card/utils/CardDesigns.d.ts +22 -10
- package/cjs/extensions/payment-card/utils/CardDesigns.js +44 -36
- package/cjs/extensions/payment-card/utils/CardDesigns.js.map +1 -1
- package/cjs/extensions/payment-card/utils/Types.js +2 -0
- package/cjs/extensions/payment-card/utils/Types.js.map +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/index.d.ts +6 -2
- package/cjs/extensions/payment-card/utils/backgrounds/index.js +31 -3
- package/cjs/extensions/payment-card/utils/backgrounds/index.js.map +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/master-gold.d.ts +2 -0
- package/cjs/extensions/payment-card/utils/backgrounds/master-gold.js +9 -0
- package/cjs/extensions/payment-card/utils/backgrounds/master-gold.js.map +1 -0
- package/cjs/extensions/payment-card/utils/backgrounds/my-first.d.ts +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/my-first.js +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/my-first.js.map +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/visa-default.d.ts +2 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-default.js +9 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-default.js.map +1 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-pluss.d.ts +2 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-pluss.js +9 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-pluss.js.map +1 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-saga-gold.d.ts +2 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-saga-gold.js +9 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-saga-gold.js.map +1 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-saga-platinum.d.ts +2 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-saga-platinum.js +9 -0
- package/cjs/extensions/payment-card/utils/backgrounds/visa-saga-platinum.js.map +1 -0
- package/cjs/extensions/payment-card/utils/backgrounds/youth.d.ts +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/youth.js +1 -1
- package/cjs/extensions/payment-card/utils/backgrounds/youth.js.map +1 -1
- package/cjs/extensions/payment-card/utils/cardProducts.d.ts +1 -1
- package/cjs/extensions/payment-card/utils/cardProducts.js +241 -209
- package/cjs/extensions/payment-card/utils/cardProducts.js.map +1 -1
- package/cjs/shared/Context.d.ts +1 -1
- package/cjs/shared/Context.js +5 -14
- package/cjs/shared/Context.js.map +1 -1
- package/cjs/shared/Eufemia.d.ts +1 -1
- package/cjs/shared/Eufemia.js +2 -2
- package/cjs/shared/Eufemia.js.map +1 -1
- package/cjs/shared/Provider.js +15 -24
- package/cjs/shared/Provider.js.map +1 -1
- package/cjs/shared/locales/en-GB.d.ts +4 -2
- package/cjs/shared/locales/en-GB.js +6 -4
- package/cjs/shared/locales/en-GB.js.map +1 -1
- package/cjs/shared/locales/en-US.d.ts +4 -2
- package/cjs/shared/locales/index.d.ts +8 -4
- package/cjs/shared/locales/nb-NO.d.ts +4 -2
- package/cjs/shared/locales/nb-NO.js +6 -4
- package/cjs/shared/locales/nb-NO.js.map +1 -1
- package/cjs/shared/locales/sv-SE.d.ts +4 -2
- package/cjs/shared/locales/sv-SE.js +6 -4
- package/cjs/shared/locales/sv-SE.js.map +1 -1
- package/cjs/shared/useTranslation.d.ts +3 -2
- package/cjs/shared/useTranslation.js.map +1 -1
- package/cjs/style/core/scopes.scss +1 -1
- package/cjs/style/dnb-ui-basis.css +1 -1
- package/cjs/style/dnb-ui-basis.min.css +1 -1
- package/cjs/style/dnb-ui-body.css +1 -1
- package/cjs/style/dnb-ui-body.min.css +1 -1
- package/cjs/style/dnb-ui-core.css +1 -1
- package/cjs/style/dnb-ui-core.min.css +1 -1
- package/cjs/style/dnb-ui-extensions.css +173 -163
- package/cjs/style/dnb-ui-extensions.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +4 -0
- package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
- package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +173 -163
- package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +4 -0
- package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
- package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +173 -163
- package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-components.css +4 -0
- package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
- package/cjs/style/themes/theme-ui/ui-theme-extensions.css +173 -163
- package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
- package/components/country-flag/CountryFlag.js +5 -2
- package/components/country-flag/CountryFlag.js.map +1 -1
- package/components/date-picker/DatePicker.d.ts +16 -7
- package/components/date-picker/DatePicker.js +8 -20
- package/components/date-picker/DatePicker.js.map +1 -1
- package/components/date-picker/DatePickerCalendar.d.ts +1 -3
- package/components/date-picker/DatePickerCalendar.js +34 -19
- package/components/date-picker/DatePickerCalendar.js.map +1 -1
- package/components/date-picker/DatePickerCalendarNavigator.d.ts +1 -4
- package/components/date-picker/DatePickerCalendarNavigator.js +1 -10
- package/components/date-picker/DatePickerCalendarNavigator.js.map +1 -1
- package/components/date-picker/DatePickerContext.d.ts +1 -0
- package/components/date-picker/DatePickerContext.js.map +1 -1
- package/components/date-picker/DatePickerDocs.js +0 -5
- package/components/date-picker/DatePickerDocs.js.map +1 -1
- package/components/date-picker/DatePickerFooter.js +2 -2
- package/components/date-picker/DatePickerFooter.js.map +1 -1
- package/components/date-picker/DatePickerInput.d.ts +3 -2
- package/components/date-picker/DatePickerInput.js +9 -8
- package/components/date-picker/DatePickerInput.js.map +1 -1
- package/components/date-picker/DatePickerProvider.d.ts +1 -1
- package/components/date-picker/DatePickerProvider.js +17 -16
- package/components/date-picker/DatePickerProvider.js.map +1 -1
- package/components/date-picker/DatePickerRange.d.ts +3 -7
- package/components/date-picker/DatePickerRange.js +9 -8
- package/components/date-picker/DatePickerRange.js.map +1 -1
- package/components/date-picker/hooks/useDates.js.map +1 -1
- package/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +4 -0
- package/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
- package/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -0
- package/components/number-format/NumberUtils.d.ts +1 -1
- package/es/components/country-flag/CountryFlag.js +5 -2
- package/es/components/country-flag/CountryFlag.js.map +1 -1
- package/es/components/date-picker/DatePicker.d.ts +16 -7
- package/es/components/date-picker/DatePicker.js +8 -20
- package/es/components/date-picker/DatePicker.js.map +1 -1
- package/es/components/date-picker/DatePickerCalendar.d.ts +1 -3
- package/es/components/date-picker/DatePickerCalendar.js +33 -19
- package/es/components/date-picker/DatePickerCalendar.js.map +1 -1
- package/es/components/date-picker/DatePickerCalendarNavigator.d.ts +1 -4
- package/es/components/date-picker/DatePickerCalendarNavigator.js +1 -10
- package/es/components/date-picker/DatePickerCalendarNavigator.js.map +1 -1
- package/es/components/date-picker/DatePickerContext.d.ts +1 -0
- package/es/components/date-picker/DatePickerContext.js.map +1 -1
- package/es/components/date-picker/DatePickerDocs.js +0 -5
- package/es/components/date-picker/DatePickerDocs.js.map +1 -1
- package/es/components/date-picker/DatePickerFooter.js +2 -2
- package/es/components/date-picker/DatePickerFooter.js.map +1 -1
- package/es/components/date-picker/DatePickerInput.d.ts +3 -2
- package/es/components/date-picker/DatePickerInput.js +9 -8
- package/es/components/date-picker/DatePickerInput.js.map +1 -1
- package/es/components/date-picker/DatePickerProvider.d.ts +1 -1
- package/es/components/date-picker/DatePickerProvider.js +16 -15
- package/es/components/date-picker/DatePickerProvider.js.map +1 -1
- package/es/components/date-picker/DatePickerRange.d.ts +3 -7
- package/es/components/date-picker/DatePickerRange.js +9 -8
- package/es/components/date-picker/DatePickerRange.js.map +1 -1
- package/es/components/date-picker/hooks/useDates.js.map +1 -1
- package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +4 -0
- package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
- package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -0
- package/es/components/number-format/NumberUtils.d.ts +1 -1
- package/es/extensions/forms/Field/Boolean/Boolean.d.ts +2 -9
- package/es/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
- package/es/extensions/forms/Field/Date/Date.d.ts +1 -1
- package/es/extensions/forms/Field/Date/Date.js.map +1 -1
- package/es/extensions/forms/Field/Date/DateDocs.js +2 -1
- package/es/extensions/forms/Field/Date/DateDocs.js.map +1 -1
- package/es/extensions/forms/Field/Indeterminate/Indeterminate.d.ts +1 -1
- package/es/extensions/forms/Field/Indeterminate/Indeterminate.js.map +1 -1
- package/es/extensions/forms/Field/Indeterminate/IndeterminateDocs.js +1 -1
- package/es/extensions/forms/Field/Indeterminate/IndeterminateDocs.js.map +1 -1
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +7 -3
- package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +2 -2
- package/es/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +3 -2
- package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +13 -6
- package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
- package/es/extensions/forms/Field/SelectCountry/useCountries.d.ts +2016 -0
- package/es/extensions/forms/Field/SelectCountry/useCountries.js +63 -0
- package/es/extensions/forms/Field/SelectCountry/useCountries.js.map +1 -0
- package/es/extensions/forms/Iterate/Array/Array.js +19 -6
- package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
- package/es/extensions/forms/Iterate/Array/ArrayDocs.js +10 -0
- package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/es/extensions/forms/Iterate/Array/types.d.ts +4 -1
- package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/es/extensions/forms/Iterate/PushButton/PushButton.js +9 -2
- package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +10 -3
- package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -2
- package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
- package/es/extensions/forms/Value/SelectCountry/useCountry.js +6 -1
- package/es/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -1
- package/es/extensions/forms/Wizard/Container/DisplaySteps.js.map +1 -1
- package/es/extensions/forms/Wizard/Container/useCollectStepsData.js.map +1 -1
- package/es/extensions/forms/constants/locales/countries/sv-SE.d.ts +257 -0
- package/es/extensions/forms/constants/locales/countries/sv-SE.js +257 -0
- package/es/extensions/forms/constants/locales/countries/sv-SE.js.map +1 -0
- package/es/extensions/forms/constants/locales/en-GB.d.ts +4 -0
- package/es/extensions/forms/constants/locales/en-GB.js +4 -0
- package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
- package/es/extensions/forms/constants/locales/en-US.d.ts +4 -0
- package/es/extensions/forms/constants/locales/index.d.ts +8 -0
- package/es/extensions/forms/constants/locales/nb-NO.d.ts +4 -0
- package/es/extensions/forms/constants/locales/nb-NO.js +4 -0
- package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
- package/es/extensions/forms/constants/locales/sv-SE.d.ts +4 -0
- package/es/extensions/forms/constants/locales/sv-SE.js +4 -0
- package/es/extensions/forms/constants/locales/sv-SE.js.map +1 -1
- package/es/extensions/forms/hooks/useFieldProps.d.ts +2 -1
- package/es/extensions/forms/hooks/useFieldProps.js +19 -6
- package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/es/extensions/forms/hooks/usePath.d.ts +4 -1
- package/es/extensions/forms/hooks/usePath.js +10 -4
- package/es/extensions/forms/hooks/usePath.js.map +1 -1
- package/es/extensions/forms/hooks/useTranslation.d.ts +2 -2
- package/es/extensions/forms/hooks/useTranslation.js.map +1 -1
- package/es/extensions/forms/utils/ajv.js +11 -3
- package/es/extensions/forms/utils/ajv.js.map +1 -1
- package/es/extensions/payment-card/PaymentCard.d.ts +9 -3
- package/es/extensions/payment-card/PaymentCard.js +9 -133
- package/es/extensions/payment-card/PaymentCard.js.map +1 -1
- package/es/extensions/payment-card/PaymentCardDocs.js +13 -13
- package/es/extensions/payment-card/PaymentCardDocs.js.map +1 -1
- package/es/extensions/payment-card/components/CardFigure.d.ts +12 -0
- package/es/extensions/payment-card/components/CardFigure.js +94 -0
- package/es/extensions/payment-card/components/CardFigure.js.map +1 -0
- package/es/extensions/payment-card/components/CardNumber.d.ts +27 -0
- package/es/extensions/payment-card/components/CardNumber.js +26 -0
- package/es/extensions/payment-card/components/CardNumber.js.map +1 -0
- package/es/extensions/payment-card/components/CardType.d.ts +7 -0
- package/es/extensions/payment-card/components/CardType.js +17 -0
- package/es/extensions/payment-card/components/CardType.js.map +1 -0
- package/es/extensions/payment-card/components/StatusOverlay.d.ts +20 -0
- package/es/extensions/payment-card/components/StatusOverlay.js +59 -0
- package/es/extensions/payment-card/components/StatusOverlay.js.map +1 -0
- package/es/extensions/payment-card/icons/brandLogos/DNB.js +17 -0
- package/es/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -0
- package/es/extensions/payment-card/icons/brandLogos/Sbanken.js +24 -0
- package/es/extensions/payment-card/icons/brandLogos/Sbanken.js.map +1 -0
- package/es/extensions/payment-card/icons/index.d.ts +3 -5
- package/es/extensions/payment-card/icons/index.js +30 -53
- package/es/extensions/payment-card/icons/index.js.map +1 -1
- package/es/extensions/payment-card/icons/loyaltyLogos/Bedrift.js +33 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Bedrift.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Business.js +36 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Business.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Corporate.d.ts +3 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Corporate.js +45 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Corporate.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Intro.js +15 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Intro.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/PB.js +54 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/PB.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Pluss.js +22 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/Pluss.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/SagaGold.js +15 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/SagaGold.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/SagaPlatinum.js +36 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/SagaPlatinum.js.map +1 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/WorldElite.d.ts +3 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/WorldElite.js +15 -0
- package/es/extensions/payment-card/icons/loyaltyLogos/WorldElite.js.map +1 -0
- package/es/extensions/payment-card/icons/providers/BankAxept.js +17 -0
- package/es/extensions/payment-card/icons/providers/BankAxept.js.map +1 -0
- package/es/extensions/payment-card/icons/providers/ClickToPay.d.ts +3 -0
- package/es/extensions/payment-card/icons/providers/ClickToPay.js +17 -0
- package/es/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -0
- package/es/extensions/payment-card/icons/providers/MastercardDark.js +807 -0
- package/es/extensions/payment-card/icons/providers/MastercardDark.js.map +1 -0
- package/es/extensions/payment-card/icons/providers/MastercardDefault.js +30 -0
- package/es/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -0
- package/es/extensions/payment-card/icons/providers/VisaDefault.js +21 -0
- package/es/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -0
- package/es/extensions/payment-card/icons/providers/VisaPlatinum.js +21 -0
- package/es/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -0
- package/es/extensions/payment-card/icons/status/index.d.ts +3 -0
- package/es/extensions/payment-card/icons/status/index.js +52 -0
- package/es/extensions/payment-card/icons/status/index.js.map +1 -0
- package/es/extensions/payment-card/index.d.ts +2 -0
- package/es/extensions/payment-card/index.js +2 -0
- package/es/extensions/payment-card/index.js.map +1 -1
- package/es/extensions/payment-card/style/dnb-payment-card.css +173 -163
- package/es/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
- package/es/extensions/payment-card/style/dnb-payment-card.scss +257 -242
- package/es/extensions/payment-card/utils/CardDesigns.d.ts +22 -10
- package/es/extensions/payment-card/utils/CardDesigns.js +45 -37
- package/es/extensions/payment-card/utils/CardDesigns.js.map +1 -1
- package/es/extensions/payment-card/utils/Types.js +2 -0
- package/es/extensions/payment-card/utils/Types.js.map +1 -1
- package/es/extensions/payment-card/utils/backgrounds/index.d.ts +6 -2
- package/es/extensions/payment-card/utils/backgrounds/index.js +6 -2
- package/es/extensions/payment-card/utils/backgrounds/index.js.map +1 -1
- package/es/extensions/payment-card/utils/backgrounds/master-gold.d.ts +2 -0
- package/es/extensions/payment-card/utils/backgrounds/master-gold.js +3 -0
- package/es/extensions/payment-card/utils/backgrounds/master-gold.js.map +1 -0
- package/es/extensions/payment-card/utils/backgrounds/my-first.d.ts +1 -1
- package/es/extensions/payment-card/utils/backgrounds/my-first.js +1 -1
- package/es/extensions/payment-card/utils/backgrounds/my-first.js.map +1 -1
- package/es/extensions/payment-card/utils/backgrounds/visa-default.d.ts +2 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-default.js +3 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-default.js.map +1 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-pluss.d.ts +2 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-pluss.js +3 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-pluss.js.map +1 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-saga-gold.d.ts +2 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-saga-gold.js +3 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-saga-gold.js.map +1 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-saga-platinum.d.ts +2 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-saga-platinum.js +3 -0
- package/es/extensions/payment-card/utils/backgrounds/visa-saga-platinum.js.map +1 -0
- package/es/extensions/payment-card/utils/backgrounds/youth.d.ts +1 -1
- package/es/extensions/payment-card/utils/backgrounds/youth.js +1 -1
- package/es/extensions/payment-card/utils/backgrounds/youth.js.map +1 -1
- package/es/extensions/payment-card/utils/cardProducts.d.ts +1 -1
- package/es/extensions/payment-card/utils/cardProducts.js +241 -209
- package/es/extensions/payment-card/utils/cardProducts.js.map +1 -1
- package/es/shared/Context.d.ts +1 -1
- package/es/shared/Context.js +5 -14
- package/es/shared/Context.js.map +1 -1
- package/es/shared/Eufemia.d.ts +1 -1
- package/es/shared/Eufemia.js +2 -2
- package/es/shared/Eufemia.js.map +1 -1
- package/es/shared/Provider.js +15 -24
- package/es/shared/Provider.js.map +1 -1
- package/es/shared/locales/en-GB.d.ts +4 -2
- package/es/shared/locales/en-GB.js +6 -4
- package/es/shared/locales/en-GB.js.map +1 -1
- package/es/shared/locales/en-US.d.ts +4 -2
- package/es/shared/locales/index.d.ts +8 -4
- package/es/shared/locales/nb-NO.d.ts +4 -2
- package/es/shared/locales/nb-NO.js +6 -4
- package/es/shared/locales/nb-NO.js.map +1 -1
- package/es/shared/locales/sv-SE.d.ts +4 -2
- package/es/shared/locales/sv-SE.js +6 -4
- package/es/shared/locales/sv-SE.js.map +1 -1
- package/es/shared/useTranslation.d.ts +3 -2
- package/es/shared/useTranslation.js.map +1 -1
- package/es/style/core/scopes.scss +1 -1
- package/es/style/dnb-ui-basis.css +1 -1
- package/es/style/dnb-ui-basis.min.css +1 -1
- package/es/style/dnb-ui-body.css +1 -1
- package/es/style/dnb-ui-body.min.css +1 -1
- package/es/style/dnb-ui-core.css +1 -1
- package/es/style/dnb-ui-core.min.css +1 -1
- package/es/style/dnb-ui-extensions.css +173 -163
- package/es/style/dnb-ui-extensions.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-components.css +4 -0
- package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
- package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +173 -163
- package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-components.css +4 -0
- package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
- package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +173 -163
- package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-components.css +4 -0
- package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
- package/es/style/themes/theme-ui/ui-theme-extensions.css +173 -163
- package/es/style/themes/theme-ui/ui-theme-extensions.min.css +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-lib.min.mjs +1 -1
- package/extensions/forms/Field/Boolean/Boolean.d.ts +2 -9
- package/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
- package/extensions/forms/Field/Date/Date.d.ts +1 -1
- package/extensions/forms/Field/Date/Date.js.map +1 -1
- package/extensions/forms/Field/Date/DateDocs.js +2 -1
- package/extensions/forms/Field/Date/DateDocs.js.map +1 -1
- package/extensions/forms/Field/Indeterminate/Indeterminate.d.ts +1 -1
- package/extensions/forms/Field/Indeterminate/Indeterminate.js.map +1 -1
- package/extensions/forms/Field/Indeterminate/IndeterminateDocs.js +1 -1
- package/extensions/forms/Field/Indeterminate/IndeterminateDocs.js.map +1 -1
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +7 -3
- package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
- package/extensions/forms/Field/Provider/useFieldProvider.d.ts +2 -2
- package/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +3 -2
- package/extensions/forms/Field/SelectCountry/SelectCountry.js +17 -10
- package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
- package/extensions/forms/Field/SelectCountry/useCountries.d.ts +2016 -0
- package/extensions/forms/Field/SelectCountry/useCountries.js +64 -0
- package/extensions/forms/Field/SelectCountry/useCountries.js.map +1 -0
- package/extensions/forms/Iterate/Array/Array.js +19 -6
- package/extensions/forms/Iterate/Array/Array.js.map +1 -1
- package/extensions/forms/Iterate/Array/ArrayDocs.js +10 -0
- package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
- package/extensions/forms/Iterate/Array/types.d.ts +4 -1
- package/extensions/forms/Iterate/Array/types.js.map +1 -1
- package/extensions/forms/Iterate/PushButton/PushButton.js +9 -2
- package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
- package/extensions/forms/Iterate/PushContainer/PushContainer.js +10 -3
- package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
- package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -2
- package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
- package/extensions/forms/Value/SelectCountry/useCountry.js +6 -1
- package/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -1
- package/extensions/forms/Wizard/Container/DisplaySteps.js.map +1 -1
- package/extensions/forms/Wizard/Container/useCollectStepsData.js.map +1 -1
- package/extensions/forms/constants/locales/countries/sv-SE.d.ts +257 -0
- package/extensions/forms/constants/locales/countries/sv-SE.js +257 -0
- package/extensions/forms/constants/locales/countries/sv-SE.js.map +1 -0
- package/extensions/forms/constants/locales/en-GB.d.ts +4 -0
- package/extensions/forms/constants/locales/en-GB.js +4 -0
- package/extensions/forms/constants/locales/en-GB.js.map +1 -1
- package/extensions/forms/constants/locales/en-US.d.ts +4 -0
- package/extensions/forms/constants/locales/index.d.ts +8 -0
- package/extensions/forms/constants/locales/nb-NO.d.ts +4 -0
- package/extensions/forms/constants/locales/nb-NO.js +4 -0
- package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
- package/extensions/forms/constants/locales/sv-SE.d.ts +4 -0
- package/extensions/forms/constants/locales/sv-SE.js +4 -0
- package/extensions/forms/constants/locales/sv-SE.js.map +1 -1
- package/extensions/forms/hooks/useFieldProps.d.ts +2 -1
- package/extensions/forms/hooks/useFieldProps.js +19 -6
- package/extensions/forms/hooks/useFieldProps.js.map +1 -1
- package/extensions/forms/hooks/usePath.d.ts +4 -1
- package/extensions/forms/hooks/usePath.js +10 -3
- package/extensions/forms/hooks/usePath.js.map +1 -1
- package/extensions/forms/hooks/useTranslation.d.ts +2 -2
- package/extensions/forms/hooks/useTranslation.js.map +1 -1
- package/extensions/forms/utils/ajv.js +11 -3
- package/extensions/forms/utils/ajv.js.map +1 -1
- package/extensions/payment-card/PaymentCard.d.ts +9 -3
- package/extensions/payment-card/PaymentCard.js +9 -139
- package/extensions/payment-card/PaymentCard.js.map +1 -1
- package/extensions/payment-card/PaymentCardDocs.js +13 -13
- package/extensions/payment-card/PaymentCardDocs.js.map +1 -1
- package/extensions/payment-card/components/CardFigure.d.ts +12 -0
- package/extensions/payment-card/components/CardFigure.js +95 -0
- package/extensions/payment-card/components/CardFigure.js.map +1 -0
- package/extensions/payment-card/components/CardNumber.d.ts +27 -0
- package/extensions/payment-card/components/CardNumber.js +29 -0
- package/extensions/payment-card/components/CardNumber.js.map +1 -0
- package/extensions/payment-card/components/CardType.d.ts +7 -0
- package/extensions/payment-card/components/CardType.js +18 -0
- package/extensions/payment-card/components/CardType.js.map +1 -0
- package/extensions/payment-card/components/StatusOverlay.d.ts +20 -0
- package/extensions/payment-card/components/StatusOverlay.js +60 -0
- package/extensions/payment-card/components/StatusOverlay.js.map +1 -0
- package/extensions/payment-card/icons/brandLogos/DNB.js +17 -0
- package/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -0
- package/extensions/payment-card/icons/brandLogos/Sbanken.js +24 -0
- package/extensions/payment-card/icons/brandLogos/Sbanken.js.map +1 -0
- package/extensions/payment-card/icons/index.d.ts +3 -5
- package/extensions/payment-card/icons/index.js +32 -56
- package/extensions/payment-card/icons/index.js.map +1 -1
- package/extensions/payment-card/icons/loyaltyLogos/Bedrift.js +33 -0
- package/extensions/payment-card/icons/loyaltyLogos/Bedrift.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/Business.js +36 -0
- package/extensions/payment-card/icons/loyaltyLogos/Business.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/Corporate.d.ts +3 -0
- package/extensions/payment-card/icons/loyaltyLogos/Corporate.js +45 -0
- package/extensions/payment-card/icons/loyaltyLogos/Corporate.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/Intro.js +15 -0
- package/extensions/payment-card/icons/loyaltyLogos/Intro.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/PB.js +54 -0
- package/extensions/payment-card/icons/loyaltyLogos/PB.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/Pluss.js +22 -0
- package/extensions/payment-card/icons/loyaltyLogos/Pluss.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/SagaGold.js +15 -0
- package/extensions/payment-card/icons/loyaltyLogos/SagaGold.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/SagaPlatinum.js +36 -0
- package/extensions/payment-card/icons/loyaltyLogos/SagaPlatinum.js.map +1 -0
- package/extensions/payment-card/icons/loyaltyLogos/WorldElite.d.ts +3 -0
- package/extensions/payment-card/icons/loyaltyLogos/WorldElite.js +15 -0
- package/extensions/payment-card/icons/loyaltyLogos/WorldElite.js.map +1 -0
- package/extensions/payment-card/icons/providers/BankAxept.js +17 -0
- package/extensions/payment-card/icons/providers/BankAxept.js.map +1 -0
- package/extensions/payment-card/icons/providers/ClickToPay.d.ts +3 -0
- package/extensions/payment-card/icons/providers/ClickToPay.js +17 -0
- package/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -0
- package/extensions/payment-card/icons/providers/MastercardDark.js +807 -0
- package/extensions/payment-card/icons/providers/MastercardDark.js.map +1 -0
- package/extensions/payment-card/icons/providers/MastercardDefault.js +30 -0
- package/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -0
- package/extensions/payment-card/icons/providers/VisaDefault.js +21 -0
- package/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -0
- package/extensions/payment-card/icons/providers/VisaPlatinum.js +21 -0
- package/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -0
- package/extensions/payment-card/icons/status/index.d.ts +3 -0
- package/extensions/payment-card/icons/status/index.js +53 -0
- package/extensions/payment-card/icons/status/index.js.map +1 -0
- package/extensions/payment-card/index.d.ts +2 -0
- package/extensions/payment-card/index.js +2 -0
- package/extensions/payment-card/index.js.map +1 -1
- package/extensions/payment-card/style/dnb-payment-card.css +173 -163
- package/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
- package/extensions/payment-card/style/dnb-payment-card.scss +257 -242
- package/extensions/payment-card/utils/CardDesigns.d.ts +22 -10
- package/extensions/payment-card/utils/CardDesigns.js +45 -37
- package/extensions/payment-card/utils/CardDesigns.js.map +1 -1
- package/extensions/payment-card/utils/Types.js +2 -0
- package/extensions/payment-card/utils/Types.js.map +1 -1
- package/extensions/payment-card/utils/backgrounds/index.d.ts +6 -2
- package/extensions/payment-card/utils/backgrounds/index.js +6 -2
- package/extensions/payment-card/utils/backgrounds/index.js.map +1 -1
- package/extensions/payment-card/utils/backgrounds/master-gold.d.ts +2 -0
- package/extensions/payment-card/utils/backgrounds/master-gold.js +3 -0
- package/extensions/payment-card/utils/backgrounds/master-gold.js.map +1 -0
- package/extensions/payment-card/utils/backgrounds/my-first.d.ts +1 -1
- package/extensions/payment-card/utils/backgrounds/my-first.js +1 -1
- package/extensions/payment-card/utils/backgrounds/my-first.js.map +1 -1
- package/extensions/payment-card/utils/backgrounds/visa-default.d.ts +2 -0
- package/extensions/payment-card/utils/backgrounds/visa-default.js +3 -0
- package/extensions/payment-card/utils/backgrounds/visa-default.js.map +1 -0
- package/extensions/payment-card/utils/backgrounds/visa-pluss.d.ts +2 -0
- package/extensions/payment-card/utils/backgrounds/visa-pluss.js +3 -0
- package/extensions/payment-card/utils/backgrounds/visa-pluss.js.map +1 -0
- package/extensions/payment-card/utils/backgrounds/visa-saga-gold.d.ts +2 -0
- package/extensions/payment-card/utils/backgrounds/visa-saga-gold.js +3 -0
- package/extensions/payment-card/utils/backgrounds/visa-saga-gold.js.map +1 -0
- package/extensions/payment-card/utils/backgrounds/visa-saga-platinum.d.ts +2 -0
- package/extensions/payment-card/utils/backgrounds/visa-saga-platinum.js +3 -0
- package/extensions/payment-card/utils/backgrounds/visa-saga-platinum.js.map +1 -0
- package/extensions/payment-card/utils/backgrounds/youth.d.ts +1 -1
- package/extensions/payment-card/utils/backgrounds/youth.js +1 -1
- package/extensions/payment-card/utils/backgrounds/youth.js.map +1 -1
- package/extensions/payment-card/utils/cardProducts.d.ts +1 -1
- package/extensions/payment-card/utils/cardProducts.js +241 -209
- package/extensions/payment-card/utils/cardProducts.js.map +1 -1
- package/package.json +1 -1
- package/shared/Context.d.ts +1 -1
- package/shared/Context.js +5 -14
- package/shared/Context.js.map +1 -1
- package/shared/Eufemia.d.ts +1 -1
- package/shared/Eufemia.js +2 -2
- package/shared/Eufemia.js.map +1 -1
- package/shared/Provider.js +15 -24
- package/shared/Provider.js.map +1 -1
- package/shared/locales/en-GB.d.ts +4 -2
- package/shared/locales/en-GB.js +6 -4
- package/shared/locales/en-GB.js.map +1 -1
- package/shared/locales/en-US.d.ts +4 -2
- package/shared/locales/index.d.ts +8 -4
- package/shared/locales/nb-NO.d.ts +4 -2
- package/shared/locales/nb-NO.js +6 -4
- package/shared/locales/nb-NO.js.map +1 -1
- package/shared/locales/sv-SE.d.ts +4 -2
- package/shared/locales/sv-SE.js +6 -4
- package/shared/locales/sv-SE.js.map +1 -1
- package/shared/useTranslation.d.ts +3 -2
- package/shared/useTranslation.js.map +1 -1
- package/style/core/scopes.scss +1 -1
- package/style/dnb-ui-basis.css +1 -1
- package/style/dnb-ui-basis.min.css +1 -1
- package/style/dnb-ui-body.css +1 -1
- package/style/dnb-ui-body.min.css +1 -1
- package/style/dnb-ui-core.css +1 -1
- package/style/dnb-ui-core.min.css +1 -1
- package/style/dnb-ui-extensions.css +173 -163
- package/style/dnb-ui-extensions.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-components.css +4 -0
- package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
- package/style/themes/theme-eiendom/eiendom-theme-extensions.css +173 -163
- package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-components.css +4 -0
- package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
- package/style/themes/theme-sbanken/sbanken-theme-extensions.css +173 -163
- package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-components.css +4 -0
- package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
- package/style/themes/theme-ui/ui-theme-extensions.css +173 -163
- package/style/themes/theme-ui/ui-theme-extensions.min.css +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 +3 -3
- package/umd/dnb-ui-lib.min.js +1 -1
- package/cjs/extensions/payment-card/icons/BankAxept.js +0 -22
- package/cjs/extensions/payment-card/icons/BankAxept.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Bedrift.js +0 -22
- package/cjs/extensions/payment-card/icons/Bedrift.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Business.js +0 -22
- package/cjs/extensions/payment-card/icons/Business.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Clock.d.ts +0 -3
- package/cjs/extensions/payment-card/icons/Clock.js +0 -25
- package/cjs/extensions/payment-card/icons/Clock.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Credit.d.ts +0 -3
- package/cjs/extensions/payment-card/icons/Credit.js +0 -22
- package/cjs/extensions/payment-card/icons/Credit.js.map +0 -1
- package/cjs/extensions/payment-card/icons/DNB.js +0 -24
- package/cjs/extensions/payment-card/icons/DNB.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Intro.js +0 -22
- package/cjs/extensions/payment-card/icons/Intro.js.map +0 -1
- package/cjs/extensions/payment-card/icons/MastercardDark.js +0 -28
- package/cjs/extensions/payment-card/icons/MastercardDark.js.map +0 -1
- package/cjs/extensions/payment-card/icons/MastercardDefault.js +0 -28
- package/cjs/extensions/payment-card/icons/MastercardDefault.js.map +0 -1
- package/cjs/extensions/payment-card/icons/PB.js +0 -22
- package/cjs/extensions/payment-card/icons/PB.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Pluss.js +0 -22
- package/cjs/extensions/payment-card/icons/Pluss.js.map +0 -1
- package/cjs/extensions/payment-card/icons/SagaGold.js +0 -22
- package/cjs/extensions/payment-card/icons/SagaGold.js.map +0 -1
- package/cjs/extensions/payment-card/icons/SagaPlatinum.js +0 -22
- package/cjs/extensions/payment-card/icons/SagaPlatinum.js.map +0 -1
- package/cjs/extensions/payment-card/icons/Sbanken.js +0 -22
- package/cjs/extensions/payment-card/icons/Sbanken.js.map +0 -1
- package/cjs/extensions/payment-card/icons/VisaDefault.js +0 -22
- package/cjs/extensions/payment-card/icons/VisaDefault.js.map +0 -1
- package/cjs/extensions/payment-card/icons/VisaPlatinum.js +0 -22
- package/cjs/extensions/payment-card/icons/VisaPlatinum.js.map +0 -1
- package/cjs/extensions/payment-card/utils/backgrounds/ung.d.ts +0 -2
- package/cjs/extensions/payment-card/utils/backgrounds/ung.js +0 -9
- package/cjs/extensions/payment-card/utils/backgrounds/ung.js.map +0 -1
- package/es/extensions/payment-card/icons/BankAxept.js +0 -15
- package/es/extensions/payment-card/icons/BankAxept.js.map +0 -1
- package/es/extensions/payment-card/icons/Bedrift.js +0 -15
- package/es/extensions/payment-card/icons/Bedrift.js.map +0 -1
- package/es/extensions/payment-card/icons/Business.js +0 -15
- package/es/extensions/payment-card/icons/Business.js.map +0 -1
- package/es/extensions/payment-card/icons/Clock.d.ts +0 -3
- package/es/extensions/payment-card/icons/Clock.js +0 -18
- package/es/extensions/payment-card/icons/Clock.js.map +0 -1
- package/es/extensions/payment-card/icons/Credit.d.ts +0 -3
- package/es/extensions/payment-card/icons/Credit.js +0 -15
- package/es/extensions/payment-card/icons/Credit.js.map +0 -1
- package/es/extensions/payment-card/icons/DNB.js +0 -17
- package/es/extensions/payment-card/icons/DNB.js.map +0 -1
- package/es/extensions/payment-card/icons/Intro.js +0 -15
- package/es/extensions/payment-card/icons/Intro.js.map +0 -1
- package/es/extensions/payment-card/icons/MastercardDark.js +0 -21
- package/es/extensions/payment-card/icons/MastercardDark.js.map +0 -1
- package/es/extensions/payment-card/icons/MastercardDefault.js +0 -21
- package/es/extensions/payment-card/icons/MastercardDefault.js.map +0 -1
- package/es/extensions/payment-card/icons/PB.js +0 -15
- package/es/extensions/payment-card/icons/PB.js.map +0 -1
- package/es/extensions/payment-card/icons/Pluss.js +0 -15
- package/es/extensions/payment-card/icons/Pluss.js.map +0 -1
- package/es/extensions/payment-card/icons/SagaGold.js +0 -15
- package/es/extensions/payment-card/icons/SagaGold.js.map +0 -1
- package/es/extensions/payment-card/icons/SagaPlatinum.js +0 -15
- package/es/extensions/payment-card/icons/SagaPlatinum.js.map +0 -1
- package/es/extensions/payment-card/icons/Sbanken.js +0 -15
- package/es/extensions/payment-card/icons/Sbanken.js.map +0 -1
- package/es/extensions/payment-card/icons/VisaDefault.js +0 -15
- package/es/extensions/payment-card/icons/VisaDefault.js.map +0 -1
- package/es/extensions/payment-card/icons/VisaPlatinum.js +0 -15
- package/es/extensions/payment-card/icons/VisaPlatinum.js.map +0 -1
- package/es/extensions/payment-card/utils/backgrounds/ung.d.ts +0 -2
- package/es/extensions/payment-card/utils/backgrounds/ung.js +0 -3
- package/es/extensions/payment-card/utils/backgrounds/ung.js.map +0 -1
- package/extensions/payment-card/icons/BankAxept.js +0 -15
- package/extensions/payment-card/icons/BankAxept.js.map +0 -1
- package/extensions/payment-card/icons/Bedrift.js +0 -15
- package/extensions/payment-card/icons/Bedrift.js.map +0 -1
- package/extensions/payment-card/icons/Business.js +0 -15
- package/extensions/payment-card/icons/Business.js.map +0 -1
- package/extensions/payment-card/icons/Clock.d.ts +0 -3
- package/extensions/payment-card/icons/Clock.js +0 -18
- package/extensions/payment-card/icons/Clock.js.map +0 -1
- package/extensions/payment-card/icons/Credit.d.ts +0 -3
- package/extensions/payment-card/icons/Credit.js +0 -15
- package/extensions/payment-card/icons/Credit.js.map +0 -1
- package/extensions/payment-card/icons/DNB.js +0 -17
- package/extensions/payment-card/icons/DNB.js.map +0 -1
- package/extensions/payment-card/icons/Intro.js +0 -15
- package/extensions/payment-card/icons/Intro.js.map +0 -1
- package/extensions/payment-card/icons/MastercardDark.js +0 -21
- package/extensions/payment-card/icons/MastercardDark.js.map +0 -1
- package/extensions/payment-card/icons/MastercardDefault.js +0 -21
- package/extensions/payment-card/icons/MastercardDefault.js.map +0 -1
- package/extensions/payment-card/icons/PB.js +0 -15
- package/extensions/payment-card/icons/PB.js.map +0 -1
- package/extensions/payment-card/icons/Pluss.js +0 -15
- package/extensions/payment-card/icons/Pluss.js.map +0 -1
- package/extensions/payment-card/icons/SagaGold.js +0 -15
- package/extensions/payment-card/icons/SagaGold.js.map +0 -1
- package/extensions/payment-card/icons/SagaPlatinum.js +0 -15
- package/extensions/payment-card/icons/SagaPlatinum.js.map +0 -1
- package/extensions/payment-card/icons/Sbanken.js +0 -15
- package/extensions/payment-card/icons/Sbanken.js.map +0 -1
- package/extensions/payment-card/icons/VisaDefault.js +0 -15
- package/extensions/payment-card/icons/VisaDefault.js.map +0 -1
- package/extensions/payment-card/icons/VisaPlatinum.js +0 -15
- package/extensions/payment-card/icons/VisaPlatinum.js.map +0 -1
- package/extensions/payment-card/utils/backgrounds/ung.d.ts +0 -2
- package/extensions/payment-card/utils/backgrounds/ung.js +0 -3
- package/extensions/payment-card/utils/backgrounds/ung.js.map +0 -1
- /package/cjs/extensions/payment-card/icons/{DNB.d.ts → brandLogos/DNB.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{Sbanken.d.ts → brandLogos/Sbanken.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{Bedrift.d.ts → loyaltyLogos/Bedrift.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{Business.d.ts → loyaltyLogos/Business.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{Intro.d.ts → loyaltyLogos/Intro.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{PB.d.ts → loyaltyLogos/PB.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{Pluss.d.ts → loyaltyLogos/Pluss.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{SagaGold.d.ts → loyaltyLogos/SagaGold.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{SagaPlatinum.d.ts → loyaltyLogos/SagaPlatinum.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{BankAxept.d.ts → providers/BankAxept.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{MastercardDark.d.ts → providers/MastercardDark.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{MastercardDefault.d.ts → providers/MastercardDefault.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{VisaDefault.d.ts → providers/VisaDefault.d.ts} +0 -0
- /package/cjs/extensions/payment-card/icons/{VisaPlatinum.d.ts → providers/VisaPlatinum.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{DNB.d.ts → brandLogos/DNB.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{Sbanken.d.ts → brandLogos/Sbanken.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{Bedrift.d.ts → loyaltyLogos/Bedrift.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{Business.d.ts → loyaltyLogos/Business.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{Intro.d.ts → loyaltyLogos/Intro.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{PB.d.ts → loyaltyLogos/PB.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{Pluss.d.ts → loyaltyLogos/Pluss.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{SagaGold.d.ts → loyaltyLogos/SagaGold.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{SagaPlatinum.d.ts → loyaltyLogos/SagaPlatinum.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{BankAxept.d.ts → providers/BankAxept.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{MastercardDark.d.ts → providers/MastercardDark.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{MastercardDefault.d.ts → providers/MastercardDefault.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{VisaDefault.d.ts → providers/VisaDefault.d.ts} +0 -0
- /package/es/extensions/payment-card/icons/{VisaPlatinum.d.ts → providers/VisaPlatinum.d.ts} +0 -0
- /package/extensions/payment-card/icons/{DNB.d.ts → brandLogos/DNB.d.ts} +0 -0
- /package/extensions/payment-card/icons/{Sbanken.d.ts → brandLogos/Sbanken.d.ts} +0 -0
- /package/extensions/payment-card/icons/{Bedrift.d.ts → loyaltyLogos/Bedrift.d.ts} +0 -0
- /package/extensions/payment-card/icons/{Business.d.ts → loyaltyLogos/Business.d.ts} +0 -0
- /package/extensions/payment-card/icons/{Intro.d.ts → loyaltyLogos/Intro.d.ts} +0 -0
- /package/extensions/payment-card/icons/{PB.d.ts → loyaltyLogos/PB.d.ts} +0 -0
- /package/extensions/payment-card/icons/{Pluss.d.ts → loyaltyLogos/Pluss.d.ts} +0 -0
- /package/extensions/payment-card/icons/{SagaGold.d.ts → loyaltyLogos/SagaGold.d.ts} +0 -0
- /package/extensions/payment-card/icons/{SagaPlatinum.d.ts → loyaltyLogos/SagaPlatinum.d.ts} +0 -0
- /package/extensions/payment-card/icons/{BankAxept.d.ts → providers/BankAxept.d.ts} +0 -0
- /package/extensions/payment-card/icons/{MastercardDark.d.ts → providers/MastercardDark.d.ts} +0 -0
- /package/extensions/payment-card/icons/{MastercardDefault.d.ts → providers/MastercardDefault.d.ts} +0 -0
- /package/extensions/payment-card/icons/{VisaDefault.d.ts → providers/VisaDefault.d.ts} +0 -0
- /package/extensions/payment-card/icons/{VisaPlatinum.d.ts → providers/VisaPlatinum.d.ts} +0 -0
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
4
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
5
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
6
|
+
import { useCallback, useContext, useMemo } from 'react';
|
|
7
|
+
import listOfCountries from '../../constants/countries';
|
|
8
|
+
import { warn } from '../../../../shared/helpers';
|
|
9
|
+
import { LOCALE } from '../../../../shared/defaults';
|
|
10
|
+
import SharedContext from '../../../../shared/Context';
|
|
11
|
+
export default function useCountries() {
|
|
12
|
+
let {
|
|
13
|
+
translateAllLocales = false
|
|
14
|
+
} = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
15
|
+
const {
|
|
16
|
+
locale,
|
|
17
|
+
translations
|
|
18
|
+
} = useContext(SharedContext);
|
|
19
|
+
const translateCountries = useCallback(locales => {
|
|
20
|
+
const hasTranslations = locales.some(locale => {
|
|
21
|
+
var _translations$locale;
|
|
22
|
+
return Boolean(translations === null || translations === void 0 ? void 0 : (_translations$locale = translations[locale]) === null || _translations$locale === void 0 ? void 0 : _translations$locale.countries);
|
|
23
|
+
});
|
|
24
|
+
if (hasTranslations) {
|
|
25
|
+
const missing = [];
|
|
26
|
+
const defaultLocale = LOCALE.split('-')[0];
|
|
27
|
+
const result = listOfCountries.map(country => {
|
|
28
|
+
const translated = {};
|
|
29
|
+
locales.forEach(locale => {
|
|
30
|
+
const {
|
|
31
|
+
countries
|
|
32
|
+
} = (translations === null || translations === void 0 ? void 0 : translations[locale]) || {};
|
|
33
|
+
if (countries) {
|
|
34
|
+
const key = locale.split('-')[0];
|
|
35
|
+
translated[key] = countries[country.iso];
|
|
36
|
+
if (!translated[key]) {
|
|
37
|
+
translated[key] = country.i18n[defaultLocale];
|
|
38
|
+
missing.push(country.iso);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
return _objectSpread(_objectSpread({}, country), {}, {
|
|
43
|
+
i18n: _objectSpread(_objectSpread({}, country.i18n), translated)
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
if (missing.length > 0) {
|
|
47
|
+
warn('Missing country translation:', missing);
|
|
48
|
+
}
|
|
49
|
+
return result;
|
|
50
|
+
}
|
|
51
|
+
return listOfCountries;
|
|
52
|
+
}, [translations]);
|
|
53
|
+
const countries = useMemo(() => {
|
|
54
|
+
if (translateAllLocales) {
|
|
55
|
+
const allLocales = Object.keys(translations);
|
|
56
|
+
return translateCountries(allLocales);
|
|
57
|
+
}
|
|
58
|
+
return translateCountries([locale]);
|
|
59
|
+
}, [locale, translateAllLocales, translateCountries, translations]);
|
|
60
|
+
return {
|
|
61
|
+
countries
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=useCountries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCountries.js","names":["useCallback","useContext","useMemo","listOfCountries","warn","LOCALE","SharedContext","useCountries","translateAllLocales","arguments","length","undefined","locale","translations","translateCountries","locales","hasTranslations","some","_translations$locale","Boolean","countries","missing","defaultLocale","split","result","map","country","translated","forEach","key","iso","i18n","push","_objectSpread","allLocales","Object","keys"],"sources":["../../../../../../src/extensions/forms/Field/SelectCountry/useCountries.ts"],"sourcesContent":["import { useCallback, useContext, useMemo } from 'react'\nimport listOfCountries from '../../constants/countries'\nimport { warn } from '../../../../shared/helpers'\nimport { LOCALE } from '../../../../shared/defaults'\nimport SharedContext, { InternalLocale } from '../../../../shared/Context'\n\nexport default function useCountries({\n translateAllLocales = false,\n}: {\n /**\n * If set to `true`, all locales will be translated.\n * This is useful when you want to show the translated country name (e.g. sv) in the current locale (e.g. nb).\n */\n translateAllLocales?: boolean\n} = {}) {\n const { locale, translations } = useContext(SharedContext)\n\n const translateCountries = useCallback(\n (locales: Array<InternalLocale>) => {\n const hasTranslations = locales.some((locale) => {\n return Boolean(translations?.[locale]?.countries)\n })\n\n if (hasTranslations) {\n const missing = []\n const defaultLocale = LOCALE.split('-')[0]\n\n const result = listOfCountries.map((country) => {\n const translated = {}\n\n locales.forEach((locale) => {\n const { countries } = translations?.[locale] || {}\n if (countries) {\n const key = locale.split('-')[0]\n translated[key] = countries[country.iso]\n\n if (!translated[key]) {\n // Fall back to the default translation for this locale\n translated[key] = country.i18n[defaultLocale]\n missing.push(country.iso)\n }\n }\n })\n\n return {\n // Ensure we don't mutate the original list\n ...country,\n i18n: { ...country.i18n, ...translated },\n }\n }) as unknown as typeof listOfCountries\n\n if (missing.length > 0) {\n warn('Missing country translation:', missing)\n }\n\n return result\n }\n\n return listOfCountries\n },\n [translations]\n )\n\n const countries = useMemo(() => {\n if (translateAllLocales) {\n const allLocales = Object.keys(translations)\n return translateCountries(allLocales)\n }\n\n return translateCountries([locale])\n }, [locale, translateAllLocales, translateCountries, translations])\n\n return { countries }\n}\n"],"mappings":";;;;;AAAA,SAASA,WAAW,EAAEC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AACxD,OAAOC,eAAe,MAAM,2BAA2B;AACvD,SAASC,IAAI,QAAQ,4BAA4B;AACjD,SAASC,MAAM,QAAQ,6BAA6B;AACpD,OAAOC,aAAa,MAA0B,4BAA4B;AAE1E,eAAe,SAASC,YAAYA,CAAA,EAQ5B;EAAA,IAR6B;IACnCC,mBAAmB,GAAG;EAOxB,CAAC,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EACJ,MAAM;IAAEG,MAAM;IAAEC;EAAa,CAAC,GAAGZ,UAAU,CAACK,aAAa,CAAC;EAE1D,MAAMQ,kBAAkB,GAAGd,WAAW,CACnCe,OAA8B,IAAK;IAClC,MAAMC,eAAe,GAAGD,OAAO,CAACE,IAAI,CAAEL,MAAM,IAAK;MAAA,IAAAM,oBAAA;MAC/C,OAAOC,OAAO,CAACN,YAAY,aAAZA,YAAY,wBAAAK,oBAAA,GAAZL,YAAY,CAAGD,MAAM,CAAC,cAAAM,oBAAA,uBAAtBA,oBAAA,CAAwBE,SAAS,CAAC;IACnD,CAAC,CAAC;IAEF,IAAIJ,eAAe,EAAE;MACnB,MAAMK,OAAO,GAAG,EAAE;MAClB,MAAMC,aAAa,GAAGjB,MAAM,CAACkB,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;MAE1C,MAAMC,MAAM,GAAGrB,eAAe,CAACsB,GAAG,CAAEC,OAAO,IAAK;QAC9C,MAAMC,UAAU,GAAG,CAAC,CAAC;QAErBZ,OAAO,CAACa,OAAO,CAAEhB,MAAM,IAAK;UAC1B,MAAM;YAAEQ;UAAU,CAAC,GAAG,CAAAP,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAGD,MAAM,CAAC,KAAI,CAAC,CAAC;UAClD,IAAIQ,SAAS,EAAE;YACb,MAAMS,GAAG,GAAGjB,MAAM,CAACW,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAChCI,UAAU,CAACE,GAAG,CAAC,GAAGT,SAAS,CAACM,OAAO,CAACI,GAAG,CAAC;YAExC,IAAI,CAACH,UAAU,CAACE,GAAG,CAAC,EAAE;cAEpBF,UAAU,CAACE,GAAG,CAAC,GAAGH,OAAO,CAACK,IAAI,CAACT,aAAa,CAAC;cAC7CD,OAAO,CAACW,IAAI,CAACN,OAAO,CAACI,GAAG,CAAC;YAC3B;UACF;QACF,CAAC,CAAC;QAEF,OAAAG,aAAA,CAAAA,aAAA,KAEKP,OAAO;UACVK,IAAI,EAAAE,aAAA,CAAAA,aAAA,KAAOP,OAAO,CAACK,IAAI,GAAKJ,UAAU;QAAE;MAE5C,CAAC,CAAsC;MAEvC,IAAIN,OAAO,CAACX,MAAM,GAAG,CAAC,EAAE;QACtBN,IAAI,CAAC,8BAA8B,EAAEiB,OAAO,CAAC;MAC/C;MAEA,OAAOG,MAAM;IACf;IAEA,OAAOrB,eAAe;EACxB,CAAC,EACD,CAACU,YAAY,CACf,CAAC;EAED,MAAMO,SAAS,GAAGlB,OAAO,CAAC,MAAM;IAC9B,IAAIM,mBAAmB,EAAE;MACvB,MAAM0B,UAAU,GAAGC,MAAM,CAACC,IAAI,CAACvB,YAAY,CAAC;MAC5C,OAAOC,kBAAkB,CAACoB,UAAU,CAAC;IACvC;IAEA,OAAOpB,kBAAkB,CAAC,CAACF,MAAM,CAAC,CAAC;EACrC,CAAC,EAAE,CAACA,MAAM,EAAEJ,mBAAmB,EAAEM,kBAAkB,EAAED,YAAY,CAAC,CAAC;EAEnE,OAAO;IAAEO;EAAU,CAAC;AACtB","ignoreList":[]}
|
|
@@ -34,7 +34,8 @@ function ArrayComponent(props) {
|
|
|
34
34
|
reverse,
|
|
35
35
|
countPath,
|
|
36
36
|
countPathTransform,
|
|
37
|
-
countPathLimit = Infinity
|
|
37
|
+
countPathLimit = Infinity,
|
|
38
|
+
omitSectionPath
|
|
38
39
|
} = props || {};
|
|
39
40
|
const dataContext = useContext(DataContext);
|
|
40
41
|
const summaryListContext = useContext(SummaryListContext);
|
|
@@ -73,10 +74,21 @@ function ArrayComponent(props) {
|
|
|
73
74
|
}
|
|
74
75
|
}, []);
|
|
75
76
|
const preparedProps = useMemo(() => {
|
|
76
|
-
const shared = {
|
|
77
|
+
const shared = _objectSpread({
|
|
78
|
+
schema: undefined,
|
|
77
79
|
required: false,
|
|
78
80
|
validateRequired
|
|
79
|
-
};
|
|
81
|
+
}, props);
|
|
82
|
+
if (typeof props.minItems === 'number' || typeof props.maxItems === 'number') {
|
|
83
|
+
shared.schema = {
|
|
84
|
+
type: 'array',
|
|
85
|
+
minItems: props.minItems,
|
|
86
|
+
maxItems: props.maxItems
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
if (shared.schema && !shared.emptyValue) {
|
|
90
|
+
shared.emptyValue = [];
|
|
91
|
+
}
|
|
80
92
|
if (countPath) {
|
|
81
93
|
const arrayValue = getValueByPath(pathProp);
|
|
82
94
|
const newValue = [];
|
|
@@ -87,11 +99,11 @@ function ArrayComponent(props) {
|
|
|
87
99
|
index: i
|
|
88
100
|
}) : value);
|
|
89
101
|
}
|
|
90
|
-
return _objectSpread(_objectSpread(
|
|
102
|
+
return _objectSpread(_objectSpread({}, shared), {}, {
|
|
91
103
|
value: newValue
|
|
92
104
|
});
|
|
93
105
|
}
|
|
94
|
-
return _objectSpread(
|
|
106
|
+
return _objectSpread({}, shared);
|
|
95
107
|
}, [countPath, countPathTransform, countValue, getValueByPath, pathProp, props, validateRequired]);
|
|
96
108
|
const {
|
|
97
109
|
path,
|
|
@@ -112,7 +124,8 @@ function ArrayComponent(props) {
|
|
|
112
124
|
} = useFieldProps(preparedProps, {
|
|
113
125
|
updateContextDataInSync: true,
|
|
114
126
|
omitMultiplePathWarning: true,
|
|
115
|
-
forceUpdateWhenContextDataIsSet: Boolean(countPath)
|
|
127
|
+
forceUpdateWhenContextDataIsSet: Boolean(countPath),
|
|
128
|
+
omitSectionPath
|
|
116
129
|
});
|
|
117
130
|
const countValueRef = useRef();
|
|
118
131
|
useUpdateEffect(() => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","useCallback","classnames","pointer","useFieldProps","makeUniqueId","Flex","FormStatus","HeightAnimation","Span","pickSpacingProps","useMountEffect","useUpdateEffect","pickFlexContainerProps","IterateItemContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","DataContext","useDataValue","useArrayLimit","useItemPath","useSwitchContainerMode","getMessagesFromError","clearedArray","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","path","pathProp","itemPath","itemPathProp","reverse","countPath","countPathTransform","countPathLimit","Infinity","dataContext","summaryListContext","valueBlockContext","absolutePath","setLimitProps","error","limitWarning","getValueByPath","countValue","parseFloat","data","validateRequired","value","_ref","emptyValue","required","length","preparedProps","shared","arrayValue","newValue","i","l","push","index","_objectSpread","limit","withoutFlex","placeholder","containerMode","animate","handleChange","setChanged","onChange","validateValue","children","updateContextDataInSync","omitMultiplePathWarning","forceUpdateWhenContextDataIsSet","Boolean","countValueRef","current","window","requestAnimationFrame","handlePathChange","valueCountRef","idsRef","isNewRef","modesRef","valueWhileClosingRef","containerRef","hadPushRef","innerRefs","omitFlex","getNextContainerMode","arrayItems","_ref2","list","limitedList","slice","map","_valueCountRef$curren","_modesRef$current$id","id","hasNewItems","isNew","_getNextContainerMode","itemContext","previousContainerMode","previous","initialContainerMode","modeOptions","options","nestedIteratePath","switchContainerMode","mode","_isNewRef$current","arguments","undefined","preventUpdate","newArrayValue","set","handlePush","element","handleRemove","keepItems","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","total","last","flexProps","className","innerRef","arrayElements","createElement","size","itemProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","Stack","Fragment","show","state","shellSpace","top","bottom","no_animation","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n useCallback,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from '../../utils/json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex, FormStatus, HeightAnimation } from '../../../../components'\nimport { Span } from '../../../../elements'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport useUpdateEffect from '../../../../shared/helpers/useUpdateEffect'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateItemContext, {\n IterateItemContextState,\n ModeOptions,\n} from '../IterateItemContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport {\n useArrayLimit,\n useItemPath,\n useSwitchContainerMode,\n} from '../hooks'\nimport { getMessagesFromError } from '../../FieldBlock'\nimport { clearedArray } from '../../hooks/useFieldProps'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n path: pathProp,\n itemPath: itemPathProp,\n reverse,\n countPath,\n countPathTransform,\n countPathLimit = Infinity,\n } = props || {}\n\n const dataContext = useContext(DataContext)\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n const { absolutePath } = useItemPath(itemPathProp)\n const { setLimitProps, error: limitWarning } = useArrayLimit(\n pathProp || absolutePath\n )\n\n const { getValueByPath } = useDataValue()\n const countValue = useMemo(() => {\n if (!countPath) {\n return -1\n }\n\n let countValue = parseFloat(\n getValueByPath(countPath, dataContext.data)\n )\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n\n return countValue\n }, [countPath, countPathLimit, getValueByPath, dataContext.data])\n\n const validateRequired = useCallback(\n (value: Value, { emptyValue, required, error }) => {\n if (\n required &&\n (!value || value?.length === 0 || value === emptyValue)\n ) {\n return error\n }\n },\n []\n )\n\n const preparedProps = useMemo(() => {\n const shared = {\n required: false,\n validateRequired,\n }\n\n if (countPath) {\n const arrayValue = getValueByPath(pathProp)\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(\n countPathTransform\n ? countPathTransform({ value, index: i })\n : value\n )\n }\n\n return {\n ...shared,\n ...props,\n value: newValue,\n }\n }\n\n return {\n ...shared,\n ...props,\n }\n }, [\n countPath,\n countPathTransform,\n countValue,\n getValueByPath,\n pathProp,\n props,\n validateRequired,\n ])\n\n const {\n path,\n itemPath,\n value: arrayValue,\n limit,\n error,\n withoutFlex,\n emptyValue,\n placeholder,\n containerMode,\n animate,\n handleChange,\n setChanged,\n onChange,\n validateValue,\n children,\n } = useFieldProps(preparedProps, {\n // To ensure the defaultValue set on the Iterate.Array is set in the data context,\n // and will not overwrite defaultValues set by fields inside the Iterate.Array.\n updateContextDataInSync: true,\n omitMultiplePathWarning: true,\n forceUpdateWhenContextDataIsSet: Boolean(countPath),\n })\n\n // - Call onChange on the data context, if the count value changes\n const countValueRef = useRef<number>()\n useUpdateEffect(() => {\n if (countPath) {\n if (\n typeof countValueRef.current === 'number' &&\n countValue !== countValueRef.current\n ) {\n window.requestAnimationFrame(() => {\n dataContext.handlePathChange(path, getValueByPath(path))\n }) // so we get the correct value inside the array.\n }\n countValueRef.current = countValue\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [countValue])\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<\n Record<\n Identifier,\n {\n current: ContainerMode\n previous?: ContainerMode\n options?: ModeOptions\n }\n >\n >({})\n const valueWhileClosingRef = useRef<Value>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n const { getNextContainerMode } = useSwitchContainerMode()\n\n const arrayItems = useMemo(() => {\n const list = (valueWhileClosingRef.current || arrayValue) ?? []\n const limitedList =\n typeof limit === 'number' ? list.slice(0, limit) : list\n\n const arrayItems = limitedList.map((value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue?.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]?.current) {\n modesRef.current[id] = {\n current:\n containerMode ??\n (isNew ? getNextContainerMode() ?? 'edit' : 'auto'),\n }\n }\n\n const itemContext: IterateItemContextState = {\n id,\n path,\n itemPath,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id].current,\n previousContainerMode: modesRef.current[id].previous,\n initialContainerMode: containerMode || 'auto',\n modeOptions: modesRef.current[id].options,\n nestedIteratePath: absolutePath,\n switchContainerMode: (mode, options = {}) => {\n modesRef.current[id].previous = modesRef.current[id].current\n modesRef.current[id].current = mode\n modesRef.current[id].options = options\n delete isNewRef.current?.[id]\n if (options?.preventUpdate !== true) {\n forceUpdate()\n }\n },\n handleChange: (path, value) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element) => {\n hadPushRef.current = true\n handleChange([...(arrayValue || []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(\n newArrayValue.length === 0 ? clearedArray : newArrayValue\n )\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value) => {\n if (value) {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n }\n },\n }\n\n return itemContext\n })\n\n if (reverse) {\n return arrayItems.reverse()\n }\n\n return arrayItems\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n salt,\n arrayValue,\n limit,\n path,\n itemPath,\n absolutePath,\n reverse,\n handleChange,\n ])\n\n const total = arrayItems.length\n useEffect(() => {\n if (limit) {\n setLimitProps({ limit, total })\n }\n }, [total, limit, setLimitProps])\n\n useUpdateEffect(() => {\n validateValue()\n }, [total, validateValue])\n\n useMountEffect(() => {\n // To ensure the validator is called when a new item is added\n setChanged(true)\n })\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = arrayItems?.[arrayItems.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, arrayItems, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section', // To support containers\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const arrayElements =\n arrayValue === emptyValue || props?.value?.length === 0 ? (\n typeof placeholder === 'string' ? (\n <Span size=\"small\">{placeholder}</Span>\n ) : (\n placeholder\n )\n ) : (\n arrayItems.map((itemProps) => {\n const { id, value, index } = itemProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index, arrayItems)\n : elementChild\n }\n\n const contextValue = {\n ...itemProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateItemContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateItemContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })\n )\n\n const content = omitFlex ? (\n arrayElements\n ) : (\n <Flex.Stack {...flexProps}>{arrayElements}</Flex.Stack>\n )\n\n return (\n <>\n {animate ? <HeightAnimation>{content}</HeightAnimation> : content}\n\n <FormStatus\n show={Boolean(error || limitWarning)}\n state={!error && limitWarning ? 'warning' : undefined}\n shellSpace={{ top: 0, bottom: 'medium' }}\n no_animation={false}\n >\n {getMessagesFromError({ content: error || limitWarning })[0]}\n </FormStatus>\n </>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","useCallback","classnames","pointer","useFieldProps","makeUniqueId","Flex","FormStatus","HeightAnimation","Span","pickSpacingProps","useMountEffect","useUpdateEffect","pickFlexContainerProps","IterateItemContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","DataContext","useDataValue","useArrayLimit","useItemPath","useSwitchContainerMode","getMessagesFromError","clearedArray","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","path","pathProp","itemPath","itemPathProp","reverse","countPath","countPathTransform","countPathLimit","Infinity","omitSectionPath","dataContext","summaryListContext","valueBlockContext","absolutePath","setLimitProps","error","limitWarning","getValueByPath","countValue","parseFloat","data","validateRequired","value","_ref","emptyValue","required","length","preparedProps","shared","_objectSpread","schema","undefined","minItems","maxItems","type","arrayValue","newValue","i","l","push","index","limit","withoutFlex","placeholder","containerMode","animate","handleChange","setChanged","onChange","validateValue","children","updateContextDataInSync","omitMultiplePathWarning","forceUpdateWhenContextDataIsSet","Boolean","countValueRef","current","window","requestAnimationFrame","handlePathChange","valueCountRef","idsRef","isNewRef","modesRef","valueWhileClosingRef","containerRef","hadPushRef","innerRefs","omitFlex","getNextContainerMode","arrayItems","_ref2","list","limitedList","slice","map","_valueCountRef$curren","_modesRef$current$id","id","hasNewItems","isNew","_getNextContainerMode","itemContext","previousContainerMode","previous","initialContainerMode","modeOptions","options","nestedIteratePath","switchContainerMode","mode","_isNewRef$current","arguments","preventUpdate","newArrayValue","set","handlePush","element","handleRemove","keepItems","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","total","last","flexProps","className","innerRef","arrayElements","createElement","size","itemProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","Stack","Fragment","show","state","shellSpace","top","bottom","no_animation","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n useCallback,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from '../../utils/json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex, FormStatus, HeightAnimation } from '../../../../components'\nimport { Span } from '../../../../elements'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport useUpdateEffect from '../../../../shared/helpers/useUpdateEffect'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateItemContext, {\n IterateItemContextState,\n ModeOptions,\n} from '../IterateItemContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport {\n useArrayLimit,\n useItemPath,\n useSwitchContainerMode,\n} from '../hooks'\nimport { getMessagesFromError } from '../../FieldBlock'\nimport { clearedArray } from '../../hooks/useFieldProps'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n path: pathProp,\n itemPath: itemPathProp,\n reverse,\n countPath,\n countPathTransform,\n countPathLimit = Infinity,\n omitSectionPath,\n } = props || {}\n\n const dataContext = useContext(DataContext)\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n const { absolutePath } = useItemPath(itemPathProp)\n const { setLimitProps, error: limitWarning } = useArrayLimit(\n pathProp || absolutePath\n )\n\n const { getValueByPath } = useDataValue()\n const countValue = useMemo(() => {\n if (!countPath) {\n return -1\n }\n\n let countValue = parseFloat(\n getValueByPath(countPath, dataContext.data)\n )\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n\n return countValue\n }, [countPath, countPathLimit, getValueByPath, dataContext.data])\n\n const validateRequired = useCallback(\n (value: Value, { emptyValue, required, error }) => {\n if (\n required &&\n (!value || value?.length === 0 || value === emptyValue)\n ) {\n return error\n }\n },\n []\n )\n\n const preparedProps = useMemo(() => {\n const shared = {\n schema: undefined,\n required: false,\n validateRequired,\n ...props,\n }\n\n if (\n typeof props.minItems === 'number' ||\n typeof props.maxItems === 'number'\n ) {\n shared.schema = {\n type: 'array',\n minItems: props.minItems,\n maxItems: props.maxItems,\n }\n }\n\n if (shared.schema && !shared.emptyValue) {\n shared.emptyValue = []\n }\n\n if (countPath) {\n const arrayValue = getValueByPath(pathProp)\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(\n countPathTransform\n ? countPathTransform({ value, index: i })\n : value\n )\n }\n\n return {\n ...shared,\n value: newValue,\n }\n }\n\n return {\n ...shared,\n }\n }, [\n countPath,\n countPathTransform,\n countValue,\n getValueByPath,\n pathProp,\n props,\n validateRequired,\n ])\n\n const {\n path,\n itemPath,\n value: arrayValue,\n limit,\n error,\n withoutFlex,\n emptyValue,\n placeholder,\n containerMode,\n animate,\n handleChange,\n setChanged,\n onChange,\n validateValue,\n children,\n } = useFieldProps(preparedProps, {\n // To ensure the defaultValue set on the Iterate.Array is set in the data context,\n // and will not overwrite defaultValues set by fields inside the Iterate.Array.\n updateContextDataInSync: true,\n omitMultiplePathWarning: true,\n forceUpdateWhenContextDataIsSet: Boolean(countPath),\n omitSectionPath,\n })\n\n // - Call onChange on the data context, if the count value changes\n const countValueRef = useRef<number>()\n useUpdateEffect(() => {\n if (countPath) {\n if (\n typeof countValueRef.current === 'number' &&\n countValue !== countValueRef.current\n ) {\n window.requestAnimationFrame(() => {\n dataContext.handlePathChange(path, getValueByPath(path))\n }) // so we get the correct value inside the array.\n }\n countValueRef.current = countValue\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [countValue])\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<\n Record<\n Identifier,\n {\n current: ContainerMode\n previous?: ContainerMode\n options?: ModeOptions\n }\n >\n >({})\n const valueWhileClosingRef = useRef<Value>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n const { getNextContainerMode } = useSwitchContainerMode()\n\n const arrayItems = useMemo(() => {\n const list = (valueWhileClosingRef.current || arrayValue) ?? []\n const limitedList =\n typeof limit === 'number' ? list.slice(0, limit) : list\n\n const arrayItems = limitedList.map((value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue?.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]?.current) {\n modesRef.current[id] = {\n current:\n containerMode ??\n (isNew ? getNextContainerMode() ?? 'edit' : 'auto'),\n }\n }\n\n const itemContext: IterateItemContextState = {\n id,\n path,\n itemPath,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id].current,\n previousContainerMode: modesRef.current[id].previous,\n initialContainerMode: containerMode || 'auto',\n modeOptions: modesRef.current[id].options,\n nestedIteratePath: absolutePath,\n switchContainerMode: (mode, options = {}) => {\n modesRef.current[id].previous = modesRef.current[id].current\n modesRef.current[id].current = mode\n modesRef.current[id].options = options\n delete isNewRef.current?.[id]\n if (options?.preventUpdate !== true) {\n forceUpdate()\n }\n },\n handleChange: (path, value) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element) => {\n hadPushRef.current = true\n handleChange([...(arrayValue || []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(\n newArrayValue.length === 0 ? clearedArray : newArrayValue\n )\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value) => {\n if (value) {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n }\n },\n }\n\n return itemContext\n })\n\n if (reverse) {\n return arrayItems.reverse()\n }\n\n return arrayItems\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n salt,\n arrayValue,\n limit,\n path,\n itemPath,\n absolutePath,\n reverse,\n handleChange,\n ])\n\n const total = arrayItems.length\n useEffect(() => {\n if (limit) {\n setLimitProps({ limit, total })\n }\n }, [total, limit, setLimitProps])\n\n useUpdateEffect(() => {\n validateValue()\n }, [total, validateValue])\n\n useMountEffect(() => {\n // To ensure the validator is called when a new item is added\n setChanged(true)\n })\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = arrayItems?.[arrayItems.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, arrayItems, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section', // To support containers\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const arrayElements =\n arrayValue === emptyValue || props?.value?.length === 0 ? (\n typeof placeholder === 'string' ? (\n <Span size=\"small\">{placeholder}</Span>\n ) : (\n placeholder\n )\n ) : (\n arrayItems.map((itemProps) => {\n const { id, value, index } = itemProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index, arrayItems)\n : elementChild\n }\n\n const contextValue = {\n ...itemProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateItemContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateItemContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })\n )\n\n const content = omitFlex ? (\n arrayElements\n ) : (\n <Flex.Stack {...flexProps}>{arrayElements}</Flex.Stack>\n )\n\n return (\n <>\n {animate ? <HeightAnimation>{content}</HeightAnimation> : content}\n\n <FormStatus\n show={Boolean(error || limitWarning)}\n state={!error && limitWarning ? 'warning' : undefined}\n shellSpace={{ top: 0, bottom: 'medium' }}\n no_animation={false}\n >\n {getMessagesFromError({ content: error || limitWarning })[0]}\n </FormStatus>\n </>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -20,6 +20,16 @@ export const ArrayProperties = {
|
|
|
20
20
|
type: 'boolean',
|
|
21
21
|
status: 'optional'
|
|
22
22
|
},
|
|
23
|
+
minItems: {
|
|
24
|
+
doc: 'The minimum amount of items required to iterate over.',
|
|
25
|
+
type: 'number',
|
|
26
|
+
status: 'optional'
|
|
27
|
+
},
|
|
28
|
+
maxItems: {
|
|
29
|
+
doc: 'The maximum amount of items to iterate over before showing the error.',
|
|
30
|
+
type: 'number',
|
|
31
|
+
status: 'optional'
|
|
32
|
+
},
|
|
23
33
|
limit: {
|
|
24
34
|
doc: 'Limit the number of rendered items to iterate over. Defaults to `undefined`.',
|
|
25
35
|
type: 'number',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArrayDocs.js","names":["DataValueWritePropsProperties","ArrayProperties","value","doc","type","status","path","itemPath","required","limit","reverse","countPath","countPathTransform","countPathLimit","withoutFlex","animate","placeholder","emptyValue","containerMode","onChangeValidator","validateInitially","validateContinuously","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { DataValueWritePropsProperties } from '../../hooks/DataValueWritePropsDocs'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n itemPath: {\n doc: 'A path (JSON Pointer) to nested array items.',\n type: 'string',\n status: 'optional',\n },\n required: {\n doc: \"If the array is required. It does not automatically inherit the `required` property in the same way that `Field.*` components do. You may provide a custom error message to give the user a more useful message than the default one: `errorMessages={{ 'Field.errorRequired': 'Custom message' }}`\",\n type: 'boolean',\n status: 'optional',\n },\n limit: {\n doc: 'Limit the number of rendered items to iterate over. Defaults to `undefined`.',\n type: 'number',\n status: 'optional',\n },\n reverse: {\n doc: 'When `true` it will reverse the order of the items.',\n type: 'boolean',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n animate: {\n doc: 'When `true` it will animate the height of the items.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n onChangeValidator: DataValueWritePropsProperties.onChangeValidator,\n validateInitially: DataValueWritePropsProperties.validateInitially,\n validateContinuously: DataValueWritePropsProperties.validateContinuously,\n children: {\n doc: 'React.Node or a function so you can get the current value as the first function parameter, and the index as the second parameter as well as the array of internal items as the third parameter.',\n type: ['React.ReactNode', 'function'],\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/properties)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,6BAA6B,QAAQ,qCAAqC;AAEnF,OAAO,MAAMC,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,QAAQ,EAAE;IACRJ,GAAG,EAAE,8CAA8C;IACnDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,QAAQ,EAAE;IACRL,GAAG,EAAE,qSAAqS;IAC1SC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,KAAK,EAAE;
|
|
1
|
+
{"version":3,"file":"ArrayDocs.js","names":["DataValueWritePropsProperties","ArrayProperties","value","doc","type","status","path","itemPath","required","minItems","maxItems","limit","reverse","countPath","countPathTransform","countPathLimit","withoutFlex","animate","placeholder","emptyValue","containerMode","onChangeValidator","validateInitially","validateContinuously","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { DataValueWritePropsProperties } from '../../hooks/DataValueWritePropsDocs'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n itemPath: {\n doc: 'A path (JSON Pointer) to nested array items.',\n type: 'string',\n status: 'optional',\n },\n required: {\n doc: \"If the array is required. It does not automatically inherit the `required` property in the same way that `Field.*` components do. You may provide a custom error message to give the user a more useful message than the default one: `errorMessages={{ 'Field.errorRequired': 'Custom message' }}`\",\n type: 'boolean',\n status: 'optional',\n },\n minItems: {\n doc: 'The minimum amount of items required to iterate over.',\n type: 'number',\n status: 'optional',\n },\n maxItems: {\n doc: 'The maximum amount of items to iterate over before showing the error.',\n type: 'number',\n status: 'optional',\n },\n limit: {\n doc: 'Limit the number of rendered items to iterate over. Defaults to `undefined`.',\n type: 'number',\n status: 'optional',\n },\n reverse: {\n doc: 'When `true` it will reverse the order of the items.',\n type: 'boolean',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n animate: {\n doc: 'When `true` it will animate the height of the items.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n onChangeValidator: DataValueWritePropsProperties.onChangeValidator,\n validateInitially: DataValueWritePropsProperties.validateInitially,\n validateContinuously: DataValueWritePropsProperties.validateContinuously,\n children: {\n doc: 'React.Node or a function so you can get the current value as the first function parameter, and the index as the second parameter as well as the array of internal items as the third parameter.',\n type: ['React.ReactNode', 'function'],\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/properties)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,6BAA6B,QAAQ,qCAAqC;AAEnF,OAAO,MAAMC,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,QAAQ,EAAE;IACRJ,GAAG,EAAE,8CAA8C;IACnDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,QAAQ,EAAE;IACRL,GAAG,EAAE,qSAAqS;IAC1SC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,QAAQ,EAAE;IACRN,GAAG,EAAE,uDAAuD;IAC5DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,QAAQ,EAAE;IACRP,GAAG,EAAE,uEAAuE;IAC5EC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,KAAK,EAAE;IACLR,GAAG,EAAE,8EAA8E;IACnFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,OAAO,EAAE;IACPT,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAE;IACTV,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,kBAAkB,EAAE;IAClBX,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDU,cAAc,EAAE;IACdZ,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDW,WAAW,EAAE;IACXb,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDY,OAAO,EAAE;IACPd,GAAG,EAAE,sDAAsD;IAC3DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDa,WAAW,EAAE;IACXf,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDc,UAAU,EAAE;IACVhB,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDe,aAAa,EAAE;IACbjB,GAAG,EAAE,0SAA0S;IAC/SC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDgB,iBAAiB,EAAErB,6BAA6B,CAACqB,iBAAiB;EAClEC,iBAAiB,EAAEtB,6BAA6B,CAACsB,iBAAiB;EAClEC,oBAAoB,EAAEvB,6BAA6B,CAACuB,oBAAoB;EACxEC,QAAQ,EAAE;IACRrB,GAAG,EAAE,iMAAiM;IACtMC,IAAI,EAAE,CAAC,iBAAiB,EAAE,UAAU,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACD,mDAAmD,EAAE;IACnDF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMoB,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRvB,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC","ignoreList":[]}
|
|
@@ -5,7 +5,7 @@ import { IterateItemContextState } from '../IterateItemContext';
|
|
|
5
5
|
export type ContainerMode = 'view' | 'edit' | 'auto';
|
|
6
6
|
export type Value = Array<unknown | Record<string, unknown>>;
|
|
7
7
|
export type ElementChild = React.ReactNode | ((value: any, index: number, arrayItems: Array<IterateItemContextState>) => React.ReactNode);
|
|
8
|
-
export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation' | 'validateContinuously'> & {
|
|
8
|
+
export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation' | 'validateContinuously' | 'schema'> & {
|
|
9
9
|
children: ElementChild | Array<ElementChild>;
|
|
10
10
|
path?: Path;
|
|
11
11
|
itemPath?: Path;
|
|
@@ -13,6 +13,8 @@ export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTM
|
|
|
13
13
|
reverse?: boolean;
|
|
14
14
|
countPath?: Path;
|
|
15
15
|
countPathLimit?: number;
|
|
16
|
+
minItems?: number;
|
|
17
|
+
maxItems?: number;
|
|
16
18
|
onChangeValidator?: Validator<Value>;
|
|
17
19
|
withoutFlex?: boolean;
|
|
18
20
|
animate?: boolean;
|
|
@@ -25,4 +27,5 @@ export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTM
|
|
|
25
27
|
index: number;
|
|
26
28
|
}) => any;
|
|
27
29
|
validateValue?: () => void;
|
|
30
|
+
omitSectionPath?: boolean;
|
|
28
31
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import {\n DefaultErrorMessages,\n Path,\n UseFieldProps,\n Validator,\n} from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { IterateItemContextState } from '../IterateItemContext'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((\n value: any,\n index: number,\n arrayItems: Array<IterateItemContextState>\n ) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n | 'validateContinuously'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n itemPath?: Path\n limit?: number\n reverse?: boolean\n countPath?: Path\n countPathLimit?: number\n onChangeValidator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n required?: boolean\n errorMessages?: DefaultErrorMessages\n countPathTransform?: (params: { value: any; index: number }) => any\n\n // internal\n validateValue?: () => void\n }\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import {\n DefaultErrorMessages,\n Path,\n UseFieldProps,\n Validator,\n} from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { IterateItemContextState } from '../IterateItemContext'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((\n value: any,\n index: number,\n arrayItems: Array<IterateItemContextState>\n ) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n | 'validateContinuously'\n | 'schema'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n itemPath?: Path\n limit?: number\n reverse?: boolean\n countPath?: Path\n countPathLimit?: number\n minItems?: number\n maxItems?: number\n onChangeValidator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n required?: boolean\n errorMessages?: DefaultErrorMessages\n countPathTransform?: (params: { value: any; index: number }) => any\n\n // internal\n validateValue?: () => void\n omitSectionPath?: boolean\n }\n"],"mappings":"","ignoreList":[]}
|
|
@@ -14,6 +14,7 @@ import { omitDataValueReadWriteProps } from '../../types';
|
|
|
14
14
|
import { add } from '../../../../icons';
|
|
15
15
|
import DataContext from '../../DataContext/Context';
|
|
16
16
|
import useDataValue from '../../hooks/useDataValue';
|
|
17
|
+
import { usePath } from '../../hooks';
|
|
17
18
|
import { convertJsxToString } from '../../../../shared/component-helper';
|
|
18
19
|
function PushButton(props) {
|
|
19
20
|
const {
|
|
@@ -36,6 +37,12 @@ function PushButton(props) {
|
|
|
36
37
|
const {
|
|
37
38
|
absolutePath
|
|
38
39
|
} = useItemPath(itemPath);
|
|
40
|
+
const {
|
|
41
|
+
path: relativePath
|
|
42
|
+
} = usePath({
|
|
43
|
+
path,
|
|
44
|
+
itemPath
|
|
45
|
+
});
|
|
39
46
|
const arrayValue = useDataValue().getValueByPath(path || absolutePath);
|
|
40
47
|
const {
|
|
41
48
|
hasReachedLimit,
|
|
@@ -56,14 +63,14 @@ function PushButton(props) {
|
|
|
56
63
|
if (handlePush && !absolutePath) {
|
|
57
64
|
handlePush(newValue);
|
|
58
65
|
} else {
|
|
59
|
-
await (handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(
|
|
66
|
+
await (handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(absolutePath || relativePath, [...(arrayValue !== null && arrayValue !== void 0 ? arrayValue : []), newValue]));
|
|
60
67
|
}
|
|
61
68
|
if (!absolutePath) {
|
|
62
69
|
setTimeout(() => {
|
|
63
70
|
setLastItemContainerMode('view');
|
|
64
71
|
}, 100);
|
|
65
72
|
}
|
|
66
|
-
}, [arrayValue, absolutePath, handlePathChange, handlePush, hasReachedLimit,
|
|
73
|
+
}, [arrayValue, absolutePath, handlePathChange, handlePush, hasReachedLimit, relativePath, pushValue, setLastItemContainerMode, setShowStatus]);
|
|
67
74
|
const content = useMemo(() => {
|
|
68
75
|
if (children || text) {
|
|
69
76
|
const str = convertJsxToString(children || text);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PushButton.js","names":["React","useCallback","useContext","useMemo","classnames","Button","IterateItemContext","useArrayLimit","useItemPath","useSwitchContainerMode","omitDataValueReadWriteProps","add","DataContext","useDataValue","convertJsxToString","PushButton","props","handlePathChange","iterateItemContext","handlePush","pushValue","className","path","itemPath","text","children","restProps","_objectWithoutProperties","_excluded","buttonProps","absolutePath","arrayValue","getValueByPath","hasReachedLimit","setShowStatus","undefined","Array","isArray","Error","setLastItemContainerMode","handleClick","newValue","setTimeout","content","str","includes","nextItemNo","length","replace","String","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateItemContext from '../IterateItemContext'\nimport {\n useArrayLimit,\n useItemPath,\n useSwitchContainerMode,\n} from '../hooks'\nimport { omitDataValueReadWriteProps, Path } from '../../types'\nimport { add } from '../../../../icons'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport type Props = ButtonProps & {\n path?: Path\n itemPath?: Path\n pushValue: unknown | ((value: unknown) => void)\n\n /**\n * Used internally\n */\n value?: unknown\n}\n\nfunction PushButton(props: Props) {\n const { handlePathChange } = useContext(DataContext) || {}\n const iterateItemContext = useContext(IterateItemContext)\n const { handlePush } = iterateItemContext ?? {}\n\n const {\n pushValue,\n className,\n path,\n itemPath,\n text,\n children,\n ...restProps\n } = props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n\n const { absolutePath } = useItemPath(itemPath)\n\n const arrayValue = useDataValue().getValueByPath(path || absolutePath)\n\n const { hasReachedLimit, setShowStatus } = useArrayLimit(path)\n\n if (arrayValue !== undefined && !Array.isArray(arrayValue)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const { setLastItemContainerMode } = useSwitchContainerMode(path)\n\n const handleClick = useCallback(async () => {\n if (hasReachedLimit) {\n setShowStatus(true)\n return // stop here\n }\n\n const newValue =\n typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue\n\n if (handlePush && !absolutePath) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n } else {\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n await handlePathChange?.(
|
|
1
|
+
{"version":3,"file":"PushButton.js","names":["React","useCallback","useContext","useMemo","classnames","Button","IterateItemContext","useArrayLimit","useItemPath","useSwitchContainerMode","omitDataValueReadWriteProps","add","DataContext","useDataValue","usePath","convertJsxToString","PushButton","props","handlePathChange","iterateItemContext","handlePush","pushValue","className","path","itemPath","text","children","restProps","_objectWithoutProperties","_excluded","buttonProps","absolutePath","relativePath","arrayValue","getValueByPath","hasReachedLimit","setShowStatus","undefined","Array","isArray","Error","setLastItemContainerMode","handleClick","newValue","setTimeout","content","str","includes","nextItemNo","length","replace","String","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateItemContext from '../IterateItemContext'\nimport {\n useArrayLimit,\n useItemPath,\n useSwitchContainerMode,\n} from '../hooks'\nimport { omitDataValueReadWriteProps, Path } from '../../types'\nimport { add } from '../../../../icons'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { usePath } from '../../hooks'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport type Props = ButtonProps & {\n path?: Path\n itemPath?: Path\n pushValue: unknown | ((value: unknown) => void)\n\n /**\n * Used internally\n */\n value?: unknown\n}\n\nfunction PushButton(props: Props) {\n const { handlePathChange } = useContext(DataContext) || {}\n const iterateItemContext = useContext(IterateItemContext)\n const { handlePush } = iterateItemContext ?? {}\n\n const {\n pushValue,\n className,\n path,\n itemPath,\n text,\n children,\n ...restProps\n } = props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n\n const { absolutePath } = useItemPath(itemPath)\n const { path: relativePath } = usePath({ path, itemPath })\n\n const arrayValue = useDataValue().getValueByPath(path || absolutePath)\n\n const { hasReachedLimit, setShowStatus } = useArrayLimit(path)\n\n if (arrayValue !== undefined && !Array.isArray(arrayValue)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const { setLastItemContainerMode } = useSwitchContainerMode(path)\n\n const handleClick = useCallback(async () => {\n if (hasReachedLimit) {\n setShowStatus(true)\n return // stop here\n }\n\n // console.log('handlePush')\n const newValue =\n typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue\n\n if (handlePush && !absolutePath) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n } else {\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n await handlePathChange?.(absolutePath || relativePath, [\n ...(arrayValue ?? []),\n newValue,\n ])\n }\n\n if (!absolutePath) {\n setTimeout(() => {\n setLastItemContainerMode('view')\n }, 100) // UX improvement because of the \"openDelay\"\n }\n }, [\n arrayValue,\n absolutePath,\n handlePathChange,\n handlePush,\n hasReachedLimit,\n relativePath,\n pushValue,\n setLastItemContainerMode,\n setShowStatus,\n ])\n\n const content = useMemo(() => {\n if (children || text) {\n const str = convertJsxToString(children || text)\n\n if (str.includes('{nextItemNo}')) {\n const nextItemNo = (arrayValue?.length || 0) + 1\n return str.replace('{nextItemNo}', String(nextItemNo))\n }\n }\n\n return children || text\n }, [arrayValue?.length, children, text])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {content}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -23,7 +23,7 @@ import OpenButton from './OpenButton';
|
|
|
23
23
|
import { Flex, FormStatus, HeightAnimation } from '../../../../components';
|
|
24
24
|
import { useArrayLimit, useItemPath, useSwitchContainerMode } from '../hooks';
|
|
25
25
|
import Toolbar from '../Toolbar';
|
|
26
|
-
import { useTranslation } from '../../hooks';
|
|
26
|
+
import { usePath, useTranslation } from '../../hooks';
|
|
27
27
|
import { clearedData } from '../../DataContext/Provider';
|
|
28
28
|
import structuredClone from '@ungap/structured-clone';
|
|
29
29
|
function PushContainer(props) {
|
|
@@ -55,6 +55,12 @@ function PushContainer(props) {
|
|
|
55
55
|
const {
|
|
56
56
|
absolutePath
|
|
57
57
|
} = useItemPath(itemPath);
|
|
58
|
+
const {
|
|
59
|
+
path: relativePath
|
|
60
|
+
} = usePath({
|
|
61
|
+
path,
|
|
62
|
+
itemPath
|
|
63
|
+
});
|
|
58
64
|
const commitHandleRef = useRef();
|
|
59
65
|
const switchContainerModeRef = useRef();
|
|
60
66
|
const containerModeRef = useRef();
|
|
@@ -125,7 +131,7 @@ function PushContainer(props) {
|
|
|
125
131
|
let {
|
|
126
132
|
pushContainerItems
|
|
127
133
|
} = _ref2;
|
|
128
|
-
return moveValueToPath(
|
|
134
|
+
return moveValueToPath(absolutePath || relativePath, typeof insertAt === 'number' ? [...entries.slice(0, insertAt), ...pushContainerItems, ...entries.slice(insertAt)] : [...entries, ...pushContainerItems], absolutePath ? structuredClone(getValueByPath('/')) : {});
|
|
129
135
|
},
|
|
130
136
|
onCommit: (data, options) => {
|
|
131
137
|
const {
|
|
@@ -148,7 +154,8 @@ function PushContainer(props) {
|
|
|
148
154
|
}, React.createElement(IterateArray, {
|
|
149
155
|
path: "/pushContainerItems",
|
|
150
156
|
containerMode: showOpenButton ? 'view' : 'edit',
|
|
151
|
-
withoutFlex: true
|
|
157
|
+
withoutFlex: true,
|
|
158
|
+
omitSectionPath: true
|
|
152
159
|
}, React.createElement(NewContainer, _extends({
|
|
153
160
|
title: title,
|
|
154
161
|
openButton: openButton,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PushContainer.js","names":["React","useCallback","useContext","useEffect","useMemo","useReducer","useRef","classnames","Isolation","useHandleStatus","PushContainerContext","IterateItemContext","DataContext","VisibilityContext","useDataValue","EditContainer","DoneButton","CancelButton","ResetButton","IterateArray","OpenButton","Flex","FormStatus","HeightAnimation","useArrayLimit","useItemPath","useSwitchContainerMode","Toolbar","useTranslation","clearedData","structuredClone","PushContainer","props","forceUpdate","outerContext","data","outerData","required","requiredInherited","dataProp","defaultData","defaultDataProp","isolatedData","bubbleValidation","preventUncommittedChanges","requireCommit","showResetButton","path","itemPath","insertAt","title","children","openButton","showOpenButtonWhen","onCommit","rest","_objectWithoutProperties","_excluded","absolutePath","commitHandleRef","switchContainerModeRef","containerModeRef","value","entries","moveValueToPath","getValueByPath","setNextContainerMode","hasReachedLimit","setShowStatus","cancelHandler","showOpenButton","newItemContextProps","switchContainerMode","current","_Object$freeze","_objectSpread","pushContainerItems","Object","freeze","isFrozen","assign","emptyData","_data$pushContainerIt","_ref","firstItem","createElement","transformOnCommit","_ref2","slice","options","clearData","preventCommit","_switchContainerModeR","call","Provider","containerMode","withoutFlex","NewContainer","_extends","rerenderPushContainer","_ref3","_DoneButton","_CancelButton","_FormStatus","_excluded2","hasContentChanged","showStatus","showCommitStatus","error","pushContainerError","isVisible","Boolean","preventUncommittedChangesText","createButton","IteratePushContainer","restoreOriginalValue","toolbar","Consumer","context","Horizontal","gap","text","onClick","hidden","no_animation","show","keepInDOM","open","className","Error","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport Isolation from '../../Form/Isolation'\nimport useHandleStatus from '../../Form/Isolation/useHandleStatus'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport VisibilityContext from '../../Form/Visibility/VisibilityContext'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, {\n DoneButton,\n CancelButton,\n ResetButton,\n AllProps as EditContainerProps,\n} from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, FormStatus, HeightAnimation } from '../../../../components'\nimport { OnCommit, Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport {\n useArrayLimit,\n useItemPath,\n useSwitchContainerMode,\n} from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { useTranslation } from '../../hooks'\nimport { clearedData } from '../../DataContext/Provider'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So it's a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\ntype OnlyPathRequired = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /** The sub path to the array to add the new item to. */\n itemPath?: Path\n}\n\ntype OnlyItemPathRequired = {\n /**\n * The path to the array to add the new item to.\n */\n path?: Path\n\n /** The sub path to the array to add the new item to. */\n itemPath: Path\n}\n\nexport type Props = (OnlyPathRequired | OnlyItemPathRequired) & {\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * If the fields inside the container are required.\n */\n required?: boolean\n\n /**\n * The index to insert the new item at.\n */\n insertAt?: number\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields. The data will be put into this path: \"/pushContainerItems/0\".\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * Prefilled data to add to the fields. The data will be put into this path: \"/pushContainerItems/0\".\n */\n defaultData?: unknown | Record<string, unknown>\n\n /**\n * Provide additional data that will be put into the root of the isolated data context (parallel to \"/pushContainerItems/0\").\n */\n isolatedData?: Record<string, unknown>\n\n /**\n * Prevent the form from being submitted when there are fields with errors inside the PushContainer.\n */\n bubbleValidation?: boolean\n\n /**\n * If the container should be committed before the form is submitted.\n */\n /**\n * @deprecated – Replaced with preventUncommittedChanges, requireCommit will be removed in v11.\n */\n requireCommit?: boolean\n\n /**\n * Prevents uncommitted changes before the form is submitted. Will display an error message if user tries to submit without committing their changes.\n */\n preventUncommittedChanges?: boolean\n\n /**\n * Show a button to clear the PushContainer data.\n */\n showResetButton?: boolean\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * Will be called when the user clicks on the \"Done\" button.\n */\n onCommit?: OnCommit\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props &\n SpacingProps &\n Omit<EditContainerProps, 'data'>\n\nfunction PushContainer(props: AllProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n const outerContext = useContext(DataContext)\n const { data: outerData, required: requiredInherited } = outerContext\n\n const {\n data: dataProp,\n defaultData: defaultDataProp,\n isolatedData,\n bubbleValidation,\n preventUncommittedChanges = props?.requireCommit,\n requireCommit, // eslint-disable-line @typescript-eslint/no-unused-vars\n showResetButton,\n path,\n itemPath,\n insertAt,\n title,\n required = requiredInherited,\n children,\n openButton,\n showOpenButtonWhen,\n onCommit,\n ...rest\n } = props\n\n const { absolutePath } = useItemPath(itemPath)\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const containerModeRef = useRef<ContainerMode>()\n const {\n value: entries = [],\n moveValueToPath,\n getValueByPath,\n } = useDataValue<Array<unknown>>(path || itemPath)\n\n const { setNextContainerMode } = useSwitchContainerMode(\n path || absolutePath\n )\n const { hasReachedLimit, setShowStatus } = useArrayLimit(\n path || absolutePath\n )\n const cancelHandler = useCallback(() => {\n if (hasReachedLimit) {\n setShowStatus(false)\n }\n }, [hasReachedLimit, setShowStatus])\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n itemPath,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const data = useMemo(() => {\n if (defaultDataProp) {\n return // don't return a fallback, because we want to use the defaultData\n }\n return {\n ...isolatedData,\n pushContainerItems: [Object.freeze(dataProp) ?? clearedData],\n }\n }, [dataProp, defaultDataProp, isolatedData])\n\n if (outerData) {\n // Use assign to avoid mutating the original data object.\n // Because changes from outside should only silently be applied to the\n // data object, without triggering a rerender.\n // This way \"pushContainerItems\" will not clear/unset changed data.\n if (!Object.isFrozen(data)) {\n Object.assign(data || {}, outerData)\n }\n }\n\n const defaultData = useMemo(() => {\n return {\n ...(!dataProp ? isolatedData : null),\n pushContainerItems: [Object.freeze(defaultDataProp ?? clearedData)],\n }\n }, [dataProp, defaultDataProp, isolatedData])\n\n const emptyData = useCallback(\n (data: { pushContainerItems: unknown[] }) => {\n const firstItem = data.pushContainerItems?.[0]\n if (firstItem === null || typeof firstItem !== 'object') {\n return {\n ...isolatedData,\n pushContainerItems: [null],\n }\n }\n\n return {\n ...isolatedData,\n pushContainerItems: [dataProp ?? defaultDataProp ?? clearedData],\n }\n },\n [dataProp, defaultDataProp, isolatedData]\n )\n\n return (\n <Isolation\n data={data}\n defaultData={defaultData}\n required={required}\n emptyData={emptyData}\n bubbleValidation={\n containerModeRef.current === 'view' ? false : bubbleValidation\n }\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ pushContainerItems }) => {\n return moveValueToPath(\n path || absolutePath,\n typeof insertAt === 'number'\n ? [\n ...entries.slice(0, insertAt),\n ...pushContainerItems,\n ...entries.slice(insertAt),\n ]\n : [...entries, ...pushContainerItems],\n absolutePath ? structuredClone(getValueByPath('/')) : {}\n )\n }}\n onCommit={(data, options) => {\n const { clearData, preventCommit } = options\n if (hasReachedLimit) {\n preventCommit()\n setShowStatus(true)\n } else {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }\n onCommit?.(data, options)\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/pushContainerItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n withoutFlex\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n cancelHandler={cancelHandler}\n containerModeRef={containerModeRef}\n rerenderPushContainer={forceUpdate}\n preventUncommittedChanges={preventUncommittedChanges}\n showResetButton={showResetButton}\n outerContext={outerContext}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n showResetButton,\n switchContainerModeRef,\n cancelHandler,\n containerModeRef,\n rerenderPushContainer,\n preventUncommittedChanges,\n outerContext,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n containerModeRef.current = containerMode\n\n const { hasContentChanged, showStatus: showCommitStatus } =\n useHandleStatus({\n outerContext,\n preventUncommittedChanges,\n error: pushContainerError,\n })\n\n useEffect(() => {\n rerenderPushContainer()\n }, [containerMode, rerenderPushContainer])\n\n switchContainerModeRef.current = switchContainerMode\n const isVisible = Boolean(!showOpenButton || containerMode === 'edit')\n const { preventUncommittedChangesText } = useTranslation().Isolation\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && (\n <CancelButton onClick={cancelHandler} />\n )}\n {(preventUncommittedChanges || showResetButton) && (\n <ResetButton\n // Use hidden in order to render the useHasContentChanged hook\n hidden={!(showResetButton || showCommitStatus)}\n />\n )}\n </Flex.Horizontal>\n\n {preventUncommittedChanges && showCommitStatus && (\n <FormStatus no_animation={false} show={hasContentChanged}>\n {preventUncommittedChangesText}\n </FormStatus>\n )}\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <VisibilityContext.Provider value={{ isVisible, keepInDOM: false }}>\n <EditContainer\n open={isVisible}\n title={title}\n toolbar={toolbar}\n {...rest}\n // Add the class by default, because we don't get a \"hasSubmitError\" trigger\n className={classnames(\n 'dnb-forms-section-block--error',\n rest.className\n )}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </VisibilityContext.Provider>\n )\n}\n\nconst pushContainerError = new Error('Iterate.PushContainer')\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"PushContainer.js","names":["React","useCallback","useContext","useEffect","useMemo","useReducer","useRef","classnames","Isolation","useHandleStatus","PushContainerContext","IterateItemContext","DataContext","VisibilityContext","useDataValue","EditContainer","DoneButton","CancelButton","ResetButton","IterateArray","OpenButton","Flex","FormStatus","HeightAnimation","useArrayLimit","useItemPath","useSwitchContainerMode","Toolbar","usePath","useTranslation","clearedData","structuredClone","PushContainer","props","forceUpdate","outerContext","data","outerData","required","requiredInherited","dataProp","defaultData","defaultDataProp","isolatedData","bubbleValidation","preventUncommittedChanges","requireCommit","showResetButton","path","itemPath","insertAt","title","children","openButton","showOpenButtonWhen","onCommit","rest","_objectWithoutProperties","_excluded","absolutePath","relativePath","commitHandleRef","switchContainerModeRef","containerModeRef","value","entries","moveValueToPath","getValueByPath","setNextContainerMode","hasReachedLimit","setShowStatus","cancelHandler","showOpenButton","newItemContextProps","switchContainerMode","current","_Object$freeze","_objectSpread","pushContainerItems","Object","freeze","isFrozen","assign","emptyData","_data$pushContainerIt","_ref","firstItem","createElement","transformOnCommit","_ref2","slice","options","clearData","preventCommit","_switchContainerModeR","call","Provider","containerMode","withoutFlex","omitSectionPath","NewContainer","_extends","rerenderPushContainer","_ref3","_DoneButton","_CancelButton","_FormStatus","_excluded2","hasContentChanged","showStatus","showCommitStatus","error","pushContainerError","isVisible","Boolean","preventUncommittedChangesText","createButton","IteratePushContainer","restoreOriginalValue","toolbar","Consumer","context","Horizontal","gap","text","onClick","hidden","no_animation","show","keepInDOM","open","className","Error","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport Isolation from '../../Form/Isolation'\nimport useHandleStatus from '../../Form/Isolation/useHandleStatus'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport VisibilityContext from '../../Form/Visibility/VisibilityContext'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, {\n DoneButton,\n CancelButton,\n ResetButton,\n AllProps as EditContainerProps,\n} from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, FormStatus, HeightAnimation } from '../../../../components'\nimport { OnCommit, Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport {\n useArrayLimit,\n useItemPath,\n useSwitchContainerMode,\n} from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { usePath, useTranslation } from '../../hooks'\nimport { clearedData } from '../../DataContext/Provider'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So it's a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\ntype OnlyPathRequired = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /** The sub path to the array to add the new item to. */\n itemPath?: Path\n}\n\ntype OnlyItemPathRequired = {\n /**\n * The path to the array to add the new item to.\n */\n path?: Path\n\n /** The sub path to the array to add the new item to. */\n itemPath: Path\n}\n\nexport type Props = (OnlyPathRequired | OnlyItemPathRequired) & {\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * If the fields inside the container are required.\n */\n required?: boolean\n\n /**\n * The index to insert the new item at.\n */\n insertAt?: number\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields. The data will be put into this path: \"/pushContainerItems/0\".\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * Prefilled data to add to the fields. The data will be put into this path: \"/pushContainerItems/0\".\n */\n defaultData?: unknown | Record<string, unknown>\n\n /**\n * Provide additional data that will be put into the root of the isolated data context (parallel to \"/pushContainerItems/0\").\n */\n isolatedData?: Record<string, unknown>\n\n /**\n * Prevent the form from being submitted when there are fields with errors inside the PushContainer.\n */\n bubbleValidation?: boolean\n\n /**\n * If the container should be committed before the form is submitted.\n */\n /**\n * @deprecated – Replaced with preventUncommittedChanges, requireCommit will be removed in v11.\n */\n requireCommit?: boolean\n\n /**\n * Prevents uncommitted changes before the form is submitted. Will display an error message if user tries to submit without committing their changes.\n */\n preventUncommittedChanges?: boolean\n\n /**\n * Show a button to clear the PushContainer data.\n */\n showResetButton?: boolean\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * Will be called when the user clicks on the \"Done\" button.\n */\n onCommit?: OnCommit\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props &\n SpacingProps &\n Omit<EditContainerProps, 'data'>\n\nfunction PushContainer(props: AllProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n const outerContext = useContext(DataContext)\n const { data: outerData, required: requiredInherited } = outerContext\n\n const {\n data: dataProp,\n defaultData: defaultDataProp,\n isolatedData,\n bubbleValidation,\n preventUncommittedChanges = props?.requireCommit,\n requireCommit, // eslint-disable-line @typescript-eslint/no-unused-vars\n showResetButton,\n path,\n itemPath,\n insertAt,\n title,\n required = requiredInherited,\n children,\n openButton,\n showOpenButtonWhen,\n onCommit,\n ...rest\n } = props\n\n const { absolutePath } = useItemPath(itemPath)\n const { path: relativePath } = usePath({ path, itemPath })\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const containerModeRef = useRef<ContainerMode>()\n const {\n value: entries = [],\n moveValueToPath,\n getValueByPath,\n } = useDataValue<Array<unknown>>(path || itemPath)\n\n const { setNextContainerMode } = useSwitchContainerMode(\n path || absolutePath\n )\n const { hasReachedLimit, setShowStatus } = useArrayLimit(\n path || absolutePath\n )\n const cancelHandler = useCallback(() => {\n if (hasReachedLimit) {\n setShowStatus(false)\n }\n }, [hasReachedLimit, setShowStatus])\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n itemPath,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const data = useMemo(() => {\n if (defaultDataProp) {\n return // don't return a fallback, because we want to use the defaultData\n }\n return {\n ...isolatedData,\n pushContainerItems: [Object.freeze(dataProp) ?? clearedData],\n }\n }, [dataProp, defaultDataProp, isolatedData])\n\n if (outerData) {\n // Use assign to avoid mutating the original data object.\n // Because changes from outside should only silently be applied to the\n // data object, without triggering a rerender.\n // This way \"pushContainerItems\" will not clear/unset changed data.\n if (!Object.isFrozen(data)) {\n Object.assign(data || {}, outerData)\n }\n }\n\n const defaultData = useMemo(() => {\n return {\n ...(!dataProp ? isolatedData : null),\n pushContainerItems: [Object.freeze(defaultDataProp ?? clearedData)],\n }\n }, [dataProp, defaultDataProp, isolatedData])\n\n const emptyData = useCallback(\n (data: { pushContainerItems: unknown[] }) => {\n const firstItem = data.pushContainerItems?.[0]\n if (firstItem === null || typeof firstItem !== 'object') {\n return {\n ...isolatedData,\n pushContainerItems: [null],\n }\n }\n\n return {\n ...isolatedData,\n pushContainerItems: [dataProp ?? defaultDataProp ?? clearedData],\n }\n },\n [dataProp, defaultDataProp, isolatedData]\n )\n\n return (\n <Isolation\n data={data}\n defaultData={defaultData}\n required={required}\n emptyData={emptyData}\n bubbleValidation={\n containerModeRef.current === 'view' ? false : bubbleValidation\n }\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ pushContainerItems }) => {\n return moveValueToPath(\n absolutePath || relativePath,\n typeof insertAt === 'number'\n ? [\n ...entries.slice(0, insertAt),\n ...pushContainerItems,\n ...entries.slice(insertAt),\n ]\n : [...entries, ...pushContainerItems],\n absolutePath ? structuredClone(getValueByPath('/')) : {}\n )\n }}\n onCommit={(data, options) => {\n const { clearData, preventCommit } = options\n if (hasReachedLimit) {\n preventCommit()\n setShowStatus(true)\n } else {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }\n onCommit?.(data, options)\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/pushContainerItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n withoutFlex\n omitSectionPath\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n cancelHandler={cancelHandler}\n containerModeRef={containerModeRef}\n rerenderPushContainer={forceUpdate}\n preventUncommittedChanges={preventUncommittedChanges}\n showResetButton={showResetButton}\n outerContext={outerContext}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n showResetButton,\n switchContainerModeRef,\n cancelHandler,\n containerModeRef,\n rerenderPushContainer,\n preventUncommittedChanges,\n outerContext,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n containerModeRef.current = containerMode\n\n const { hasContentChanged, showStatus: showCommitStatus } =\n useHandleStatus({\n outerContext,\n preventUncommittedChanges,\n error: pushContainerError,\n })\n\n useEffect(() => {\n rerenderPushContainer()\n }, [containerMode, rerenderPushContainer])\n\n switchContainerModeRef.current = switchContainerMode\n const isVisible = Boolean(!showOpenButton || containerMode === 'edit')\n const { preventUncommittedChangesText } = useTranslation().Isolation\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && (\n <CancelButton onClick={cancelHandler} />\n )}\n {(preventUncommittedChanges || showResetButton) && (\n <ResetButton\n // Use hidden in order to render the useHasContentChanged hook\n hidden={!(showResetButton || showCommitStatus)}\n />\n )}\n </Flex.Horizontal>\n\n {preventUncommittedChanges && showCommitStatus && (\n <FormStatus no_animation={false} show={hasContentChanged}>\n {preventUncommittedChangesText}\n </FormStatus>\n )}\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <VisibilityContext.Provider value={{ isVisible, keepInDOM: false }}>\n <EditContainer\n open={isVisible}\n title={title}\n toolbar={toolbar}\n {...rest}\n // Add the class by default, because we don't get a \"hasSubmitError\" trigger\n className={classnames(\n 'dnb-forms-section-block--error',\n rest.className\n )}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </VisibilityContext.Provider>\n )\n}\n\nconst pushContainerError = new Error('Iterate.PushContainer')\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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","ignoreList":[]}
|