@dnb/eufemia 10.55.0 → 10.56.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.
Files changed (939) hide show
  1. package/CHANGELOG.md +31 -0
  2. package/cjs/components/accordion/Accordion.d.ts +2 -2
  3. package/cjs/components/accordion/Accordion.js.map +1 -1
  4. package/cjs/components/accordion/AccordionDocs.js +1 -1
  5. package/cjs/components/accordion/AccordionDocs.js.map +1 -1
  6. package/cjs/components/anchor/style/anchor-mixins.scss +3 -3
  7. package/cjs/components/anchor/style/dnb-anchor.css +6 -6
  8. package/cjs/components/anchor/style/dnb-anchor.min.css +1 -1
  9. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.css +12 -12
  10. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.min.css +1 -1
  11. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +3 -3
  12. package/cjs/components/button/style/themes/button-mixins.scss +2 -0
  13. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.css +4 -0
  14. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.css +4 -0
  15. package/cjs/components/button/style/themes/dnb-button-theme-ui.css +4 -0
  16. package/cjs/components/card/style/dnb-card.css +15 -0
  17. package/cjs/components/card/style/dnb-card.min.css +1 -1
  18. package/cjs/components/card/style/dnb-card.scss +17 -0
  19. package/cjs/components/card/style/themes/dnb-card-theme-ui.css +2 -1
  20. package/cjs/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  21. package/cjs/components/card/style/themes/dnb-card-theme-ui.scss +3 -1
  22. package/cjs/components/date-picker/DatePicker.d.ts +248 -65
  23. package/cjs/components/date-picker/DatePicker.js +125 -135
  24. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  25. package/cjs/components/date-picker/DatePickerAddon.js.map +1 -1
  26. package/cjs/components/date-picker/DatePickerCalc.d.ts +2 -2
  27. package/cjs/components/date-picker/DatePickerCalc.js +6 -6
  28. package/cjs/components/date-picker/DatePickerCalc.js.map +1 -1
  29. package/cjs/components/date-picker/DatePickerCalendar.d.ts +1 -1
  30. package/cjs/components/date-picker/DatePickerCalendar.js +9 -9
  31. package/cjs/components/date-picker/DatePickerCalendar.js.map +1 -1
  32. package/cjs/components/date-picker/DatePickerContext.d.ts +2 -2
  33. package/cjs/components/date-picker/DatePickerContext.js.map +1 -1
  34. package/cjs/components/date-picker/DatePickerDocs.d.ts +3 -0
  35. package/cjs/components/date-picker/DatePickerDocs.js +284 -0
  36. package/cjs/components/date-picker/DatePickerDocs.js.map +1 -0
  37. package/cjs/components/date-picker/DatePickerFooter.js +18 -18
  38. package/cjs/components/date-picker/DatePickerFooter.js.map +1 -1
  39. package/cjs/components/date-picker/DatePickerInput.d.ts +3 -3
  40. package/cjs/components/date-picker/DatePickerInput.js +18 -18
  41. package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
  42. package/cjs/components/date-picker/DatePickerProvider.d.ts +2 -2
  43. package/cjs/components/date-picker/DatePickerProvider.js +25 -25
  44. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  45. package/cjs/components/date-picker/hooks/useDates.js +8 -8
  46. package/cjs/components/date-picker/hooks/useDates.js.map +1 -1
  47. package/cjs/components/dropdown/style/themes/dnb-dropdown-theme-sbanken.css +2 -0
  48. package/cjs/components/form-label/FormLabel.js +26 -3
  49. package/cjs/components/form-label/FormLabel.js.map +1 -1
  50. package/cjs/components/help-button/HelpButtonInline.d.ts +37 -0
  51. package/cjs/components/help-button/HelpButtonInline.js +184 -0
  52. package/cjs/components/help-button/HelpButtonInline.js.map +1 -0
  53. package/cjs/components/help-button/style/dnb-help-button-inline.css +98 -0
  54. package/cjs/components/help-button/style/dnb-help-button-inline.min.css +1 -0
  55. package/cjs/components/help-button/style/dnb-help-button-inline.scss +128 -0
  56. package/cjs/components/help-button/style/dnb-help-button.css +104 -1
  57. package/cjs/components/help-button/style/dnb-help-button.min.css +1 -1
  58. package/cjs/components/help-button/style/dnb-help-button.scss +3 -2
  59. package/cjs/components/help-button/style/themes/dnb-help-button-theme-sbanken.css +7 -0
  60. package/cjs/components/help-button/style/themes/dnb-help-button-theme-sbanken.min.css +1 -0
  61. package/cjs/components/help-button/style/themes/dnb-help-button-theme-sbanken.scss +10 -0
  62. package/cjs/components/help-button/style/themes/dnb-help-button-theme-ui.css +5 -2
  63. package/cjs/components/help-button/style/themes/dnb-help-button-theme-ui.min.css +1 -0
  64. package/cjs/components/help-button/style/themes/dnb-help-button-theme-ui.scss +7 -1
  65. package/cjs/components/list-format/ListFormat.d.ts +6 -4
  66. package/cjs/components/list-format/ListFormat.js +16 -9
  67. package/cjs/components/list-format/ListFormat.js.map +1 -1
  68. package/cjs/components/list-format/ListFormatDocs.js +18 -4
  69. package/cjs/components/list-format/ListFormatDocs.js.map +1 -1
  70. package/cjs/components/modal/ModalContent.js +4 -2
  71. package/cjs/components/modal/ModalContent.js.map +1 -1
  72. package/cjs/components/table/style/dnb-table.css +8 -0
  73. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.css +2 -0
  74. package/cjs/components/tabs/style/dnb-tabs.css +2 -0
  75. package/cjs/components/tabs/style/themes/dnb-tabs-theme-eiendom.css +2 -0
  76. package/cjs/components/tabs/style/themes/dnb-tabs-theme-ui.css +2 -0
  77. package/cjs/components/tag/style/dnb-tag.css +2 -0
  78. package/cjs/components/textarea/Textarea.js +1 -1
  79. package/cjs/components/textarea/Textarea.js.map +1 -1
  80. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.css +1 -1
  81. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  82. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.scss +2 -1
  83. package/cjs/components/timeline/style/themes/dnb-timeline-theme-ui.css +2 -0
  84. package/cjs/components/upload/style/dnb-upload.css +3 -2
  85. package/cjs/components/upload/style/dnb-upload.min.css +1 -1
  86. package/cjs/components/upload/style/dnb-upload.scss +3 -2
  87. package/cjs/elements/ElementDocs.d.ts +1 -0
  88. package/cjs/elements/ElementDocs.js +20 -12
  89. package/cjs/elements/ElementDocs.js.map +1 -1
  90. package/cjs/elements/lib.d.ts +4 -7
  91. package/cjs/elements/lists/Dl.d.ts +1 -1
  92. package/cjs/elements/lists/Dl.js.map +1 -1
  93. package/cjs/elements/lists/DlDocs.js +1 -1
  94. package/cjs/elements/lists/DlDocs.js.map +1 -1
  95. package/cjs/elements/lists/Li.d.ts +1 -1
  96. package/cjs/elements/lists/Li.js +4 -4
  97. package/cjs/elements/lists/Li.js.map +1 -1
  98. package/cjs/elements/lists/Ol.d.ts +2 -2
  99. package/cjs/elements/lists/Ol.js +3 -3
  100. package/cjs/elements/lists/Ol.js.map +1 -1
  101. package/cjs/elements/lists/OlDocs.js +1 -1
  102. package/cjs/elements/lists/OlDocs.js.map +1 -1
  103. package/cjs/elements/lists/Ul.d.ts +2 -2
  104. package/cjs/elements/lists/Ul.js +3 -3
  105. package/cjs/elements/lists/Ul.js.map +1 -1
  106. package/cjs/elements/lists/UlDocs.js +1 -1
  107. package/cjs/elements/lists/UlDocs.js.map +1 -1
  108. package/cjs/elements/typography/P.d.ts +9 -5
  109. package/cjs/elements/typography/P.js +24 -13
  110. package/cjs/elements/typography/P.js.map +1 -1
  111. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -2
  112. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +11 -20
  113. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  114. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +4 -4
  115. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  116. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.scss +4 -4
  117. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +0 -5
  118. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  119. package/cjs/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  120. package/cjs/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  121. package/cjs/extensions/forms/Field/Composition/Composition.d.ts +1 -1
  122. package/cjs/extensions/forms/Field/Composition/Composition.js.map +1 -1
  123. package/cjs/extensions/forms/Field/Composition/CompositionDocs.js +16 -9
  124. package/cjs/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -1
  125. package/cjs/extensions/forms/Field/Currency/CurrencyDocs.js +0 -5
  126. package/cjs/extensions/forms/Field/Currency/CurrencyDocs.js.map +1 -1
  127. package/cjs/extensions/forms/Field/Date/Date.d.ts +17 -4
  128. package/cjs/extensions/forms/Field/Date/Date.js +62 -34
  129. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  130. package/cjs/extensions/forms/Field/Date/DateDocs.d.ts +8 -0
  131. package/cjs/extensions/forms/Field/Date/DateDocs.js +52 -13
  132. package/cjs/extensions/forms/Field/Date/DateDocs.js.map +1 -1
  133. package/cjs/extensions/forms/Field/Expiry/Expiry.d.ts +2 -2
  134. package/cjs/extensions/forms/Field/Expiry/Expiry.js +2 -7
  135. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  136. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +0 -5
  137. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  138. package/cjs/extensions/forms/Field/Number/Number.d.ts +2 -2
  139. package/cjs/extensions/forms/Field/Number/Number.js +2 -9
  140. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  141. package/cjs/extensions/forms/Field/Number/NumberDocs.js +0 -5
  142. package/cjs/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  143. package/cjs/extensions/forms/Field/Number/style/dnb-number.css +5 -0
  144. package/cjs/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  145. package/cjs/extensions/forms/Field/Number/style/dnb-number.scss +7 -0
  146. package/cjs/extensions/forms/Field/Option/Option.d.ts +2 -2
  147. package/cjs/extensions/forms/Field/Option/Option.js.map +1 -1
  148. package/cjs/extensions/forms/Field/Option/OptionDocs.d.ts +2 -0
  149. package/cjs/extensions/forms/Field/Option/OptionDocs.js +32 -0
  150. package/cjs/extensions/forms/Field/Option/OptionDocs.js.map +1 -0
  151. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +0 -5
  152. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  153. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  154. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +5 -2
  155. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  156. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +0 -5
  157. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  158. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +4 -2
  159. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +4 -3
  160. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  161. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +2 -5
  162. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
  163. package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +2 -1
  164. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +2 -2
  165. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +0 -4
  166. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  167. package/cjs/extensions/forms/Field/Selection/Selection.d.ts +2 -4
  168. package/cjs/extensions/forms/Field/Selection/Selection.js +14 -19
  169. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  170. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js +1 -6
  171. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  172. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.css +3 -0
  173. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  174. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.scss +5 -0
  175. package/cjs/extensions/forms/Field/Slider/Slider.d.ts +2 -2
  176. package/cjs/extensions/forms/Field/Slider/Slider.js +0 -5
  177. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -1
  178. package/cjs/extensions/forms/Field/String/String.d.ts +2 -2
  179. package/cjs/extensions/forms/Field/String/String.js +0 -4
  180. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  181. package/cjs/extensions/forms/Field/String/StringDocs.js +0 -5
  182. package/cjs/extensions/forms/Field/String/StringDocs.js.map +1 -1
  183. package/cjs/extensions/forms/Field/String/style/dnb-string.css +11 -0
  184. package/cjs/extensions/forms/Field/String/style/dnb-string.min.css +1 -0
  185. package/cjs/extensions/forms/Field/String/style/dnb-string.scss +17 -0
  186. package/cjs/extensions/forms/Field/Toggle/Toggle.d.ts +2 -2
  187. package/cjs/extensions/forms/Field/Toggle/Toggle.js +1 -14
  188. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  189. package/cjs/extensions/forms/Field/Toggle/ToggleDocs.js +0 -5
  190. package/cjs/extensions/forms/Field/Toggle/ToggleDocs.js.map +1 -1
  191. package/cjs/extensions/forms/Field/Upload/Upload.d.ts +5 -3
  192. package/cjs/extensions/forms/Field/Upload/Upload.js +57 -28
  193. package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
  194. package/cjs/extensions/forms/Field/Upload/style/dnb-upload.css +4 -0
  195. package/cjs/extensions/forms/Field/Upload/style/dnb-upload.min.css +1 -0
  196. package/cjs/extensions/forms/Field/Upload/style/dnb-upload.scss +8 -0
  197. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -0
  198. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +35 -28
  199. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  200. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  201. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  202. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +66 -36
  203. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  204. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +100 -54
  205. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.css +1 -1
  206. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.min.css +1 -1
  207. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.scss +1 -1
  208. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +1 -1
  209. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -1
  210. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +1 -1
  211. package/cjs/extensions/forms/Form/MainHeading/MainHeading.d.ts +2 -0
  212. package/cjs/extensions/forms/Form/MainHeading/MainHeading.js +19 -4
  213. package/cjs/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  214. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +3 -7
  215. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  216. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +4 -10
  217. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  218. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  219. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +3 -0
  220. package/cjs/extensions/forms/Form/SubHeading/SubHeading.d.ts +2 -0
  221. package/cjs/extensions/forms/Form/SubHeading/SubHeading.js +19 -4
  222. package/cjs/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  223. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +4 -0
  224. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.min.css +1 -1
  225. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +6 -0
  226. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  227. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +20 -7
  228. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  229. package/cjs/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.scss +0 -6
  230. package/cjs/extensions/forms/Value/SummaryList/SummaryList.d.ts +3 -1
  231. package/cjs/extensions/forms/Value/SummaryList/SummaryList.js +11 -1
  232. package/cjs/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  233. package/cjs/extensions/forms/Value/SummaryList/SummaryListContext.d.ts +1 -0
  234. package/cjs/extensions/forms/Value/SummaryList/SummaryListContext.js.map +1 -1
  235. package/cjs/extensions/forms/Value/SummaryList/useVerifyChildren.d.ts +14 -0
  236. package/cjs/extensions/forms/Value/SummaryList/useVerifyChildren.js +47 -0
  237. package/cjs/extensions/forms/Value/SummaryList/useVerifyChildren.js.map +1 -0
  238. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.css +1 -1
  239. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.min.css +1 -1
  240. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +1 -1
  241. package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js +3 -3
  242. package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
  243. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  244. package/cjs/extensions/forms/hooks/useFieldProps.js +12 -1
  245. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  246. package/cjs/extensions/forms/hooks/useValueProps.js +5 -0
  247. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  248. package/cjs/extensions/forms/style/dnb-forms.css +105 -47
  249. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  250. package/cjs/extensions/forms/types.d.ts +1 -7
  251. package/cjs/extensions/forms/types.js.map +1 -1
  252. package/cjs/shared/Context.d.ts +2 -2
  253. package/cjs/shared/Context.js.map +1 -1
  254. package/cjs/shared/Eufemia.d.ts +1 -1
  255. package/cjs/shared/Eufemia.js +2 -2
  256. package/cjs/shared/Eufemia.js.map +1 -1
  257. package/cjs/shared/component-helper.js.map +1 -1
  258. package/cjs/shared/locales/en-GB.d.ts +16 -16
  259. package/cjs/shared/locales/en-GB.js +16 -16
  260. package/cjs/shared/locales/en-GB.js.map +1 -1
  261. package/cjs/shared/locales/en-US.d.ts +17 -17
  262. package/cjs/shared/locales/en-US.js +3 -3
  263. package/cjs/shared/locales/en-US.js.map +1 -1
  264. package/cjs/shared/locales/index.d.ts +34 -32
  265. package/cjs/shared/locales/index.js.map +1 -1
  266. package/cjs/shared/locales/nb-NO.d.ts +16 -16
  267. package/cjs/shared/locales/nb-NO.js +16 -16
  268. package/cjs/shared/locales/nb-NO.js.map +1 -1
  269. package/cjs/style/core/scopes.scss +1 -1
  270. package/cjs/style/dnb-ui-basis.css +1 -1
  271. package/cjs/style/dnb-ui-basis.min.css +1 -1
  272. package/cjs/style/dnb-ui-body.css +1 -1
  273. package/cjs/style/dnb-ui-body.min.css +1 -1
  274. package/cjs/style/dnb-ui-components.css +344 -56
  275. package/cjs/style/dnb-ui-components.min.css +3 -3
  276. package/cjs/style/dnb-ui-components.scss +1 -0
  277. package/cjs/style/dnb-ui-core.css +1 -1
  278. package/cjs/style/dnb-ui-core.min.css +1 -1
  279. package/cjs/style/dnb-ui-extensions.css +105 -47
  280. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  281. package/cjs/style/dnb-ui-forms.css +105 -47
  282. package/cjs/style/dnb-ui-forms.min.css +1 -1
  283. package/cjs/style/dnb-ui-forms.scss +2 -0
  284. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +467 -108
  285. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  286. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +107 -49
  287. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  288. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +107 -49
  289. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  290. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +480 -120
  291. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +5 -5
  292. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  293. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +106 -48
  294. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  295. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +106 -48
  296. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  297. package/cjs/style/themes/theme-ui/ui-theme-components.css +467 -108
  298. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  299. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +107 -49
  300. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  301. package/cjs/style/themes/theme-ui/ui-theme-forms.css +107 -49
  302. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  303. package/cjs/style/themes/theme-ui/ui-theme-tags.css +3 -3
  304. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  305. package/components/accordion/Accordion.d.ts +2 -2
  306. package/components/accordion/Accordion.js.map +1 -1
  307. package/components/accordion/AccordionDocs.js +1 -1
  308. package/components/accordion/AccordionDocs.js.map +1 -1
  309. package/components/anchor/style/anchor-mixins.scss +3 -3
  310. package/components/anchor/style/dnb-anchor.css +6 -6
  311. package/components/anchor/style/dnb-anchor.min.css +1 -1
  312. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.css +12 -12
  313. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.min.css +1 -1
  314. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +3 -3
  315. package/components/button/style/themes/button-mixins.scss +2 -0
  316. package/components/button/style/themes/dnb-button-theme-eiendom.css +4 -0
  317. package/components/button/style/themes/dnb-button-theme-sbanken.css +4 -0
  318. package/components/button/style/themes/dnb-button-theme-ui.css +4 -0
  319. package/components/card/style/dnb-card.css +15 -0
  320. package/components/card/style/dnb-card.min.css +1 -1
  321. package/components/card/style/dnb-card.scss +17 -0
  322. package/components/card/style/themes/dnb-card-theme-ui.css +2 -1
  323. package/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  324. package/components/card/style/themes/dnb-card-theme-ui.scss +3 -1
  325. package/components/date-picker/DatePicker.d.ts +248 -65
  326. package/components/date-picker/DatePicker.js +126 -136
  327. package/components/date-picker/DatePicker.js.map +1 -1
  328. package/components/date-picker/DatePickerAddon.js.map +1 -1
  329. package/components/date-picker/DatePickerCalc.d.ts +2 -2
  330. package/components/date-picker/DatePickerCalc.js +6 -6
  331. package/components/date-picker/DatePickerCalc.js.map +1 -1
  332. package/components/date-picker/DatePickerCalendar.d.ts +1 -1
  333. package/components/date-picker/DatePickerCalendar.js +9 -9
  334. package/components/date-picker/DatePickerCalendar.js.map +1 -1
  335. package/components/date-picker/DatePickerContext.d.ts +2 -2
  336. package/components/date-picker/DatePickerContext.js.map +1 -1
  337. package/components/date-picker/DatePickerDocs.d.ts +3 -0
  338. package/components/date-picker/DatePickerDocs.js +276 -0
  339. package/components/date-picker/DatePickerDocs.js.map +1 -0
  340. package/components/date-picker/DatePickerFooter.js +18 -18
  341. package/components/date-picker/DatePickerFooter.js.map +1 -1
  342. package/components/date-picker/DatePickerInput.d.ts +3 -3
  343. package/components/date-picker/DatePickerInput.js +18 -18
  344. package/components/date-picker/DatePickerInput.js.map +1 -1
  345. package/components/date-picker/DatePickerProvider.d.ts +2 -2
  346. package/components/date-picker/DatePickerProvider.js +25 -25
  347. package/components/date-picker/DatePickerProvider.js.map +1 -1
  348. package/components/date-picker/hooks/useDates.js +8 -8
  349. package/components/date-picker/hooks/useDates.js.map +1 -1
  350. package/components/dropdown/style/themes/dnb-dropdown-theme-sbanken.css +2 -0
  351. package/components/form-label/FormLabel.js +26 -3
  352. package/components/form-label/FormLabel.js.map +1 -1
  353. package/components/help-button/HelpButtonInline.d.ts +37 -0
  354. package/components/help-button/HelpButtonInline.js +174 -0
  355. package/components/help-button/HelpButtonInline.js.map +1 -0
  356. package/components/help-button/style/dnb-help-button-inline.css +98 -0
  357. package/components/help-button/style/dnb-help-button-inline.min.css +1 -0
  358. package/components/help-button/style/dnb-help-button-inline.scss +128 -0
  359. package/components/help-button/style/dnb-help-button.css +104 -1
  360. package/components/help-button/style/dnb-help-button.min.css +1 -1
  361. package/components/help-button/style/dnb-help-button.scss +3 -2
  362. package/components/help-button/style/themes/dnb-help-button-theme-sbanken.css +7 -0
  363. package/components/help-button/style/themes/dnb-help-button-theme-sbanken.min.css +1 -0
  364. package/components/help-button/style/themes/dnb-help-button-theme-sbanken.scss +10 -0
  365. package/components/help-button/style/themes/dnb-help-button-theme-ui.css +5 -2
  366. package/components/help-button/style/themes/dnb-help-button-theme-ui.min.css +1 -0
  367. package/components/help-button/style/themes/dnb-help-button-theme-ui.scss +7 -1
  368. package/components/list-format/ListFormat.d.ts +6 -4
  369. package/components/list-format/ListFormat.js +15 -9
  370. package/components/list-format/ListFormat.js.map +1 -1
  371. package/components/list-format/ListFormatDocs.js +15 -4
  372. package/components/list-format/ListFormatDocs.js.map +1 -1
  373. package/components/modal/ModalContent.js +4 -2
  374. package/components/modal/ModalContent.js.map +1 -1
  375. package/components/table/style/dnb-table.css +8 -0
  376. package/components/table/style/themes/dnb-table-theme-sbanken.css +2 -0
  377. package/components/tabs/style/dnb-tabs.css +2 -0
  378. package/components/tabs/style/themes/dnb-tabs-theme-eiendom.css +2 -0
  379. package/components/tabs/style/themes/dnb-tabs-theme-ui.css +2 -0
  380. package/components/tag/style/dnb-tag.css +2 -0
  381. package/components/textarea/Textarea.js +1 -1
  382. package/components/textarea/Textarea.js.map +1 -1
  383. package/components/textarea/style/themes/dnb-textarea-theme-ui.css +1 -1
  384. package/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  385. package/components/textarea/style/themes/dnb-textarea-theme-ui.scss +2 -1
  386. package/components/timeline/style/themes/dnb-timeline-theme-ui.css +2 -0
  387. package/components/upload/style/dnb-upload.css +3 -2
  388. package/components/upload/style/dnb-upload.min.css +1 -1
  389. package/components/upload/style/dnb-upload.scss +3 -2
  390. package/elements/ElementDocs.d.ts +1 -0
  391. package/elements/ElementDocs.js +16 -11
  392. package/elements/ElementDocs.js.map +1 -1
  393. package/elements/lib.d.ts +4 -7
  394. package/elements/lists/Dl.d.ts +1 -1
  395. package/elements/lists/Dl.js.map +1 -1
  396. package/elements/lists/DlDocs.js +2 -2
  397. package/elements/lists/DlDocs.js.map +1 -1
  398. package/elements/lists/Li.d.ts +1 -1
  399. package/elements/lists/Li.js +4 -4
  400. package/elements/lists/Li.js.map +1 -1
  401. package/elements/lists/Ol.d.ts +2 -2
  402. package/elements/lists/Ol.js +3 -3
  403. package/elements/lists/Ol.js.map +1 -1
  404. package/elements/lists/OlDocs.js +2 -2
  405. package/elements/lists/OlDocs.js.map +1 -1
  406. package/elements/lists/Ul.d.ts +2 -2
  407. package/elements/lists/Ul.js +3 -3
  408. package/elements/lists/Ul.js.map +1 -1
  409. package/elements/lists/UlDocs.js +2 -2
  410. package/elements/lists/UlDocs.js.map +1 -1
  411. package/elements/typography/P.d.ts +9 -5
  412. package/elements/typography/P.js +21 -12
  413. package/elements/typography/P.js.map +1 -1
  414. package/es/components/accordion/Accordion.d.ts +2 -2
  415. package/es/components/accordion/Accordion.js.map +1 -1
  416. package/es/components/accordion/AccordionDocs.js +1 -1
  417. package/es/components/accordion/AccordionDocs.js.map +1 -1
  418. package/es/components/anchor/style/anchor-mixins.scss +3 -3
  419. package/es/components/anchor/style/dnb-anchor.css +6 -6
  420. package/es/components/anchor/style/dnb-anchor.min.css +1 -1
  421. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.css +12 -12
  422. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.min.css +1 -1
  423. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +3 -3
  424. package/es/components/button/style/themes/button-mixins.scss +2 -0
  425. package/es/components/button/style/themes/dnb-button-theme-eiendom.css +4 -0
  426. package/es/components/button/style/themes/dnb-button-theme-sbanken.css +4 -0
  427. package/es/components/button/style/themes/dnb-button-theme-ui.css +4 -0
  428. package/es/components/card/style/dnb-card.css +15 -0
  429. package/es/components/card/style/dnb-card.min.css +1 -1
  430. package/es/components/card/style/dnb-card.scss +17 -0
  431. package/es/components/card/style/themes/dnb-card-theme-ui.css +2 -1
  432. package/es/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  433. package/es/components/card/style/themes/dnb-card-theme-ui.scss +3 -1
  434. package/es/components/date-picker/DatePicker.d.ts +248 -65
  435. package/es/components/date-picker/DatePicker.js +126 -136
  436. package/es/components/date-picker/DatePicker.js.map +1 -1
  437. package/es/components/date-picker/DatePickerAddon.js.map +1 -1
  438. package/es/components/date-picker/DatePickerCalc.d.ts +2 -2
  439. package/es/components/date-picker/DatePickerCalc.js +6 -6
  440. package/es/components/date-picker/DatePickerCalc.js.map +1 -1
  441. package/es/components/date-picker/DatePickerCalendar.d.ts +1 -1
  442. package/es/components/date-picker/DatePickerCalendar.js +9 -9
  443. package/es/components/date-picker/DatePickerCalendar.js.map +1 -1
  444. package/es/components/date-picker/DatePickerContext.d.ts +2 -2
  445. package/es/components/date-picker/DatePickerContext.js.map +1 -1
  446. package/es/components/date-picker/DatePickerDocs.d.ts +3 -0
  447. package/es/components/date-picker/DatePickerDocs.js +276 -0
  448. package/es/components/date-picker/DatePickerDocs.js.map +1 -0
  449. package/es/components/date-picker/DatePickerFooter.js +18 -18
  450. package/es/components/date-picker/DatePickerFooter.js.map +1 -1
  451. package/es/components/date-picker/DatePickerInput.d.ts +3 -3
  452. package/es/components/date-picker/DatePickerInput.js +18 -18
  453. package/es/components/date-picker/DatePickerInput.js.map +1 -1
  454. package/es/components/date-picker/DatePickerProvider.d.ts +2 -2
  455. package/es/components/date-picker/DatePickerProvider.js +25 -25
  456. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  457. package/es/components/date-picker/hooks/useDates.js +8 -8
  458. package/es/components/date-picker/hooks/useDates.js.map +1 -1
  459. package/es/components/dropdown/style/themes/dnb-dropdown-theme-sbanken.css +2 -0
  460. package/es/components/form-label/FormLabel.js +26 -3
  461. package/es/components/form-label/FormLabel.js.map +1 -1
  462. package/es/components/help-button/HelpButtonInline.d.ts +37 -0
  463. package/es/components/help-button/HelpButtonInline.js +173 -0
  464. package/es/components/help-button/HelpButtonInline.js.map +1 -0
  465. package/es/components/help-button/style/dnb-help-button-inline.css +98 -0
  466. package/es/components/help-button/style/dnb-help-button-inline.min.css +1 -0
  467. package/es/components/help-button/style/dnb-help-button-inline.scss +128 -0
  468. package/es/components/help-button/style/dnb-help-button.css +104 -1
  469. package/es/components/help-button/style/dnb-help-button.min.css +1 -1
  470. package/es/components/help-button/style/dnb-help-button.scss +3 -2
  471. package/es/components/help-button/style/themes/dnb-help-button-theme-sbanken.css +7 -0
  472. package/es/components/help-button/style/themes/dnb-help-button-theme-sbanken.min.css +1 -0
  473. package/es/components/help-button/style/themes/dnb-help-button-theme-sbanken.scss +10 -0
  474. package/es/components/help-button/style/themes/dnb-help-button-theme-ui.css +5 -2
  475. package/es/components/help-button/style/themes/dnb-help-button-theme-ui.min.css +1 -0
  476. package/es/components/help-button/style/themes/dnb-help-button-theme-ui.scss +7 -1
  477. package/es/components/list-format/ListFormat.d.ts +6 -4
  478. package/es/components/list-format/ListFormat.js +15 -9
  479. package/es/components/list-format/ListFormat.js.map +1 -1
  480. package/es/components/list-format/ListFormatDocs.js +15 -4
  481. package/es/components/list-format/ListFormatDocs.js.map +1 -1
  482. package/es/components/modal/ModalContent.js +4 -2
  483. package/es/components/modal/ModalContent.js.map +1 -1
  484. package/es/components/table/style/dnb-table.css +8 -0
  485. package/es/components/table/style/themes/dnb-table-theme-sbanken.css +2 -0
  486. package/es/components/tabs/style/dnb-tabs.css +2 -0
  487. package/es/components/tabs/style/themes/dnb-tabs-theme-eiendom.css +2 -0
  488. package/es/components/tabs/style/themes/dnb-tabs-theme-ui.css +2 -0
  489. package/es/components/tag/style/dnb-tag.css +2 -0
  490. package/es/components/textarea/Textarea.js +1 -1
  491. package/es/components/textarea/Textarea.js.map +1 -1
  492. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.css +1 -1
  493. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  494. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.scss +2 -1
  495. package/es/components/timeline/style/themes/dnb-timeline-theme-ui.css +2 -0
  496. package/es/components/upload/style/dnb-upload.css +3 -2
  497. package/es/components/upload/style/dnb-upload.min.css +1 -1
  498. package/es/components/upload/style/dnb-upload.scss +3 -2
  499. package/es/elements/ElementDocs.d.ts +1 -0
  500. package/es/elements/ElementDocs.js +16 -11
  501. package/es/elements/ElementDocs.js.map +1 -1
  502. package/es/elements/lib.d.ts +4 -7
  503. package/es/elements/lists/Dl.d.ts +1 -1
  504. package/es/elements/lists/Dl.js.map +1 -1
  505. package/es/elements/lists/DlDocs.js +2 -2
  506. package/es/elements/lists/DlDocs.js.map +1 -1
  507. package/es/elements/lists/Li.d.ts +1 -1
  508. package/es/elements/lists/Li.js +4 -4
  509. package/es/elements/lists/Li.js.map +1 -1
  510. package/es/elements/lists/Ol.d.ts +2 -2
  511. package/es/elements/lists/Ol.js +3 -3
  512. package/es/elements/lists/Ol.js.map +1 -1
  513. package/es/elements/lists/OlDocs.js +2 -2
  514. package/es/elements/lists/OlDocs.js.map +1 -1
  515. package/es/elements/lists/Ul.d.ts +2 -2
  516. package/es/elements/lists/Ul.js +3 -3
  517. package/es/elements/lists/Ul.js.map +1 -1
  518. package/es/elements/lists/UlDocs.js +2 -2
  519. package/es/elements/lists/UlDocs.js.map +1 -1
  520. package/es/elements/typography/P.d.ts +9 -5
  521. package/es/elements/typography/P.js +21 -12
  522. package/es/elements/typography/P.js.map +1 -1
  523. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -2
  524. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +11 -20
  525. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  526. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +4 -4
  527. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  528. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.scss +4 -4
  529. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +0 -5
  530. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  531. package/es/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  532. package/es/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  533. package/es/extensions/forms/Field/Composition/Composition.d.ts +1 -1
  534. package/es/extensions/forms/Field/Composition/Composition.js.map +1 -1
  535. package/es/extensions/forms/Field/Composition/CompositionDocs.js +16 -7
  536. package/es/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -1
  537. package/es/extensions/forms/Field/Currency/CurrencyDocs.js +0 -5
  538. package/es/extensions/forms/Field/Currency/CurrencyDocs.js.map +1 -1
  539. package/es/extensions/forms/Field/Date/Date.d.ts +17 -4
  540. package/es/extensions/forms/Field/Date/Date.js +62 -35
  541. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  542. package/es/extensions/forms/Field/Date/DateDocs.d.ts +8 -0
  543. package/es/extensions/forms/Field/Date/DateDocs.js +47 -12
  544. package/es/extensions/forms/Field/Date/DateDocs.js.map +1 -1
  545. package/es/extensions/forms/Field/Expiry/Expiry.d.ts +2 -2
  546. package/es/extensions/forms/Field/Expiry/Expiry.js +2 -7
  547. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  548. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +0 -5
  549. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  550. package/es/extensions/forms/Field/Number/Number.d.ts +2 -2
  551. package/es/extensions/forms/Field/Number/Number.js +3 -10
  552. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  553. package/es/extensions/forms/Field/Number/NumberDocs.js +0 -5
  554. package/es/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  555. package/es/extensions/forms/Field/Number/style/dnb-number.css +5 -0
  556. package/es/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  557. package/es/extensions/forms/Field/Number/style/dnb-number.scss +7 -0
  558. package/es/extensions/forms/Field/Option/Option.d.ts +2 -2
  559. package/es/extensions/forms/Field/Option/Option.js.map +1 -1
  560. package/es/extensions/forms/Field/Option/OptionDocs.d.ts +2 -0
  561. package/es/extensions/forms/Field/Option/OptionDocs.js +25 -0
  562. package/es/extensions/forms/Field/Option/OptionDocs.js.map +1 -0
  563. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +0 -5
  564. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  565. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  566. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +5 -2
  567. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  568. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +0 -5
  569. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  570. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +4 -2
  571. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +4 -3
  572. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  573. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +2 -5
  574. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
  575. package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +2 -1
  576. package/es/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +2 -2
  577. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -5
  578. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  579. package/es/extensions/forms/Field/Selection/Selection.d.ts +2 -4
  580. package/es/extensions/forms/Field/Selection/Selection.js +16 -20
  581. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  582. package/es/extensions/forms/Field/Selection/SelectionDocs.js +1 -6
  583. package/es/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  584. package/es/extensions/forms/Field/Selection/style/dnb-selection.css +3 -0
  585. package/es/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  586. package/es/extensions/forms/Field/Selection/style/dnb-selection.scss +5 -0
  587. package/es/extensions/forms/Field/Slider/Slider.d.ts +2 -2
  588. package/es/extensions/forms/Field/Slider/Slider.js +0 -5
  589. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -1
  590. package/es/extensions/forms/Field/String/String.d.ts +2 -2
  591. package/es/extensions/forms/Field/String/String.js +1 -5
  592. package/es/extensions/forms/Field/String/String.js.map +1 -1
  593. package/es/extensions/forms/Field/String/StringDocs.js +0 -5
  594. package/es/extensions/forms/Field/String/StringDocs.js.map +1 -1
  595. package/es/extensions/forms/Field/String/style/dnb-string.css +11 -0
  596. package/es/extensions/forms/Field/String/style/dnb-string.min.css +1 -0
  597. package/es/extensions/forms/Field/String/style/dnb-string.scss +17 -0
  598. package/es/extensions/forms/Field/Toggle/Toggle.d.ts +2 -2
  599. package/es/extensions/forms/Field/Toggle/Toggle.js +2 -15
  600. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  601. package/es/extensions/forms/Field/Toggle/ToggleDocs.js +0 -5
  602. package/es/extensions/forms/Field/Toggle/ToggleDocs.js.map +1 -1
  603. package/es/extensions/forms/Field/Upload/Upload.d.ts +5 -3
  604. package/es/extensions/forms/Field/Upload/Upload.js +56 -27
  605. package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
  606. package/es/extensions/forms/Field/Upload/style/dnb-upload.css +4 -0
  607. package/es/extensions/forms/Field/Upload/style/dnb-upload.min.css +1 -0
  608. package/es/extensions/forms/Field/Upload/style/dnb-upload.scss +8 -0
  609. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -0
  610. package/es/extensions/forms/FieldBlock/FieldBlock.js +36 -28
  611. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  612. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  613. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  614. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +66 -36
  615. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  616. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +100 -54
  617. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.css +1 -1
  618. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.min.css +1 -1
  619. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.scss +1 -1
  620. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +1 -1
  621. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -1
  622. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +1 -1
  623. package/es/extensions/forms/Form/MainHeading/MainHeading.d.ts +2 -0
  624. package/es/extensions/forms/Form/MainHeading/MainHeading.js +17 -4
  625. package/es/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  626. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +3 -7
  627. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  628. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +4 -10
  629. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  630. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  631. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +3 -0
  632. package/es/extensions/forms/Form/SubHeading/SubHeading.d.ts +2 -0
  633. package/es/extensions/forms/Form/SubHeading/SubHeading.js +17 -4
  634. package/es/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  635. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +4 -0
  636. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.min.css +1 -1
  637. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +6 -0
  638. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  639. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +21 -8
  640. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  641. package/es/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.scss +0 -6
  642. package/es/extensions/forms/Value/SummaryList/SummaryList.d.ts +3 -1
  643. package/es/extensions/forms/Value/SummaryList/SummaryList.js +11 -1
  644. package/es/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  645. package/es/extensions/forms/Value/SummaryList/SummaryListContext.d.ts +1 -0
  646. package/es/extensions/forms/Value/SummaryList/SummaryListContext.js.map +1 -1
  647. package/es/extensions/forms/Value/SummaryList/useVerifyChildren.d.ts +14 -0
  648. package/es/extensions/forms/Value/SummaryList/useVerifyChildren.js +38 -0
  649. package/es/extensions/forms/Value/SummaryList/useVerifyChildren.js.map +1 -0
  650. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.css +1 -1
  651. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.min.css +1 -1
  652. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +1 -1
  653. package/es/extensions/forms/hooks/DataValueWritePropsDocs.js +3 -3
  654. package/es/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
  655. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  656. package/es/extensions/forms/hooks/useFieldProps.js +11 -1
  657. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  658. package/es/extensions/forms/hooks/useValueProps.js +5 -0
  659. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  660. package/es/extensions/forms/style/dnb-forms.css +105 -47
  661. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  662. package/es/extensions/forms/types.d.ts +1 -7
  663. package/es/extensions/forms/types.js.map +1 -1
  664. package/es/shared/Context.d.ts +2 -2
  665. package/es/shared/Context.js.map +1 -1
  666. package/es/shared/Eufemia.d.ts +1 -1
  667. package/es/shared/Eufemia.js +2 -2
  668. package/es/shared/Eufemia.js.map +1 -1
  669. package/es/shared/component-helper.js.map +1 -1
  670. package/es/shared/locales/en-GB.d.ts +16 -16
  671. package/es/shared/locales/en-GB.js +16 -16
  672. package/es/shared/locales/en-GB.js.map +1 -1
  673. package/es/shared/locales/en-US.d.ts +17 -17
  674. package/es/shared/locales/en-US.js +3 -3
  675. package/es/shared/locales/en-US.js.map +1 -1
  676. package/es/shared/locales/index.d.ts +34 -32
  677. package/es/shared/locales/index.js.map +1 -1
  678. package/es/shared/locales/nb-NO.d.ts +16 -16
  679. package/es/shared/locales/nb-NO.js +16 -16
  680. package/es/shared/locales/nb-NO.js.map +1 -1
  681. package/es/style/core/scopes.scss +1 -1
  682. package/es/style/dnb-ui-basis.css +1 -1
  683. package/es/style/dnb-ui-basis.min.css +1 -1
  684. package/es/style/dnb-ui-body.css +1 -1
  685. package/es/style/dnb-ui-body.min.css +1 -1
  686. package/es/style/dnb-ui-components.css +344 -56
  687. package/es/style/dnb-ui-components.min.css +3 -3
  688. package/es/style/dnb-ui-components.scss +1 -0
  689. package/es/style/dnb-ui-core.css +1 -1
  690. package/es/style/dnb-ui-core.min.css +1 -1
  691. package/es/style/dnb-ui-extensions.css +105 -47
  692. package/es/style/dnb-ui-extensions.min.css +1 -1
  693. package/es/style/dnb-ui-forms.css +105 -47
  694. package/es/style/dnb-ui-forms.min.css +1 -1
  695. package/es/style/dnb-ui-forms.scss +2 -0
  696. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +467 -108
  697. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  698. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +107 -49
  699. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  700. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +107 -49
  701. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  702. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +480 -120
  703. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +5 -5
  704. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  705. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +106 -48
  706. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  707. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +106 -48
  708. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  709. package/es/style/themes/theme-ui/ui-theme-components.css +467 -108
  710. package/es/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  711. package/es/style/themes/theme-ui/ui-theme-extensions.css +107 -49
  712. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  713. package/es/style/themes/theme-ui/ui-theme-forms.css +107 -49
  714. package/es/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  715. package/es/style/themes/theme-ui/ui-theme-tags.css +3 -3
  716. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  717. package/esm/dnb-ui-basis.min.mjs +1 -1
  718. package/esm/dnb-ui-components.min.mjs +1 -1
  719. package/esm/dnb-ui-elements.min.mjs +1 -1
  720. package/esm/dnb-ui-extensions.min.mjs +2 -2
  721. package/esm/dnb-ui-lib.min.mjs +1 -1
  722. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -2
  723. package/extensions/forms/Field/ArraySelection/ArraySelection.js +11 -20
  724. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  725. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +4 -4
  726. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  727. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.scss +4 -4
  728. package/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +0 -5
  729. package/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  730. package/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  731. package/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  732. package/extensions/forms/Field/Composition/Composition.d.ts +1 -1
  733. package/extensions/forms/Field/Composition/Composition.js.map +1 -1
  734. package/extensions/forms/Field/Composition/CompositionDocs.js +16 -7
  735. package/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -1
  736. package/extensions/forms/Field/Currency/CurrencyDocs.js +0 -5
  737. package/extensions/forms/Field/Currency/CurrencyDocs.js.map +1 -1
  738. package/extensions/forms/Field/Date/Date.d.ts +17 -4
  739. package/extensions/forms/Field/Date/Date.js +62 -35
  740. package/extensions/forms/Field/Date/Date.js.map +1 -1
  741. package/extensions/forms/Field/Date/DateDocs.d.ts +8 -0
  742. package/extensions/forms/Field/Date/DateDocs.js +47 -12
  743. package/extensions/forms/Field/Date/DateDocs.js.map +1 -1
  744. package/extensions/forms/Field/Expiry/Expiry.d.ts +2 -2
  745. package/extensions/forms/Field/Expiry/Expiry.js +2 -7
  746. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  747. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +0 -5
  748. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  749. package/extensions/forms/Field/Number/Number.d.ts +2 -2
  750. package/extensions/forms/Field/Number/Number.js +3 -10
  751. package/extensions/forms/Field/Number/Number.js.map +1 -1
  752. package/extensions/forms/Field/Number/NumberDocs.js +0 -5
  753. package/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  754. package/extensions/forms/Field/Number/style/dnb-number.css +5 -0
  755. package/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  756. package/extensions/forms/Field/Number/style/dnb-number.scss +7 -0
  757. package/extensions/forms/Field/Option/Option.d.ts +2 -2
  758. package/extensions/forms/Field/Option/Option.js.map +1 -1
  759. package/extensions/forms/Field/Option/OptionDocs.d.ts +2 -0
  760. package/extensions/forms/Field/Option/OptionDocs.js +25 -0
  761. package/extensions/forms/Field/Option/OptionDocs.js.map +1 -0
  762. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +0 -5
  763. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  764. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  765. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +5 -2
  766. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  767. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +0 -5
  768. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  769. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +4 -2
  770. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +4 -3
  771. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  772. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +2 -5
  773. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
  774. package/extensions/forms/Field/Provider/useFieldProvider.d.ts +2 -1
  775. package/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +2 -2
  776. package/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -5
  777. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  778. package/extensions/forms/Field/Selection/Selection.d.ts +2 -4
  779. package/extensions/forms/Field/Selection/Selection.js +16 -20
  780. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  781. package/extensions/forms/Field/Selection/SelectionDocs.js +1 -6
  782. package/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  783. package/extensions/forms/Field/Selection/style/dnb-selection.css +3 -0
  784. package/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  785. package/extensions/forms/Field/Selection/style/dnb-selection.scss +5 -0
  786. package/extensions/forms/Field/Slider/Slider.d.ts +2 -2
  787. package/extensions/forms/Field/Slider/Slider.js +0 -5
  788. package/extensions/forms/Field/Slider/Slider.js.map +1 -1
  789. package/extensions/forms/Field/String/String.d.ts +2 -2
  790. package/extensions/forms/Field/String/String.js +1 -5
  791. package/extensions/forms/Field/String/String.js.map +1 -1
  792. package/extensions/forms/Field/String/StringDocs.js +0 -5
  793. package/extensions/forms/Field/String/StringDocs.js.map +1 -1
  794. package/extensions/forms/Field/String/style/dnb-string.css +11 -0
  795. package/extensions/forms/Field/String/style/dnb-string.min.css +1 -0
  796. package/extensions/forms/Field/String/style/dnb-string.scss +17 -0
  797. package/extensions/forms/Field/Toggle/Toggle.d.ts +2 -2
  798. package/extensions/forms/Field/Toggle/Toggle.js +2 -15
  799. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  800. package/extensions/forms/Field/Toggle/ToggleDocs.js +0 -5
  801. package/extensions/forms/Field/Toggle/ToggleDocs.js.map +1 -1
  802. package/extensions/forms/Field/Upload/Upload.d.ts +5 -3
  803. package/extensions/forms/Field/Upload/Upload.js +57 -28
  804. package/extensions/forms/Field/Upload/Upload.js.map +1 -1
  805. package/extensions/forms/Field/Upload/style/dnb-upload.css +4 -0
  806. package/extensions/forms/Field/Upload/style/dnb-upload.min.css +1 -0
  807. package/extensions/forms/Field/Upload/style/dnb-upload.scss +8 -0
  808. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -0
  809. package/extensions/forms/FieldBlock/FieldBlock.js +36 -29
  810. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  811. package/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  812. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  813. package/extensions/forms/FieldBlock/style/dnb-field-block.css +66 -36
  814. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  815. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +100 -54
  816. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.css +1 -1
  817. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.min.css +1 -1
  818. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-sbanken.scss +1 -1
  819. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +1 -1
  820. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -1
  821. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +1 -1
  822. package/extensions/forms/Form/MainHeading/MainHeading.d.ts +2 -0
  823. package/extensions/forms/Form/MainHeading/MainHeading.js +17 -4
  824. package/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  825. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +3 -7
  826. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  827. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +4 -10
  828. package/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  829. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  830. package/extensions/forms/Form/Section/style/dnb-form-section.scss +3 -0
  831. package/extensions/forms/Form/SubHeading/SubHeading.d.ts +2 -0
  832. package/extensions/forms/Form/SubHeading/SubHeading.js +17 -4
  833. package/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  834. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +4 -0
  835. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.min.css +1 -1
  836. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +6 -0
  837. package/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  838. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +21 -8
  839. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  840. package/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.scss +0 -6
  841. package/extensions/forms/Value/SummaryList/SummaryList.d.ts +3 -1
  842. package/extensions/forms/Value/SummaryList/SummaryList.js +11 -1
  843. package/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  844. package/extensions/forms/Value/SummaryList/SummaryListContext.d.ts +1 -0
  845. package/extensions/forms/Value/SummaryList/SummaryListContext.js.map +1 -1
  846. package/extensions/forms/Value/SummaryList/useVerifyChildren.d.ts +14 -0
  847. package/extensions/forms/Value/SummaryList/useVerifyChildren.js +40 -0
  848. package/extensions/forms/Value/SummaryList/useVerifyChildren.js.map +1 -0
  849. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.css +1 -1
  850. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.min.css +1 -1
  851. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +1 -1
  852. package/extensions/forms/hooks/DataValueWritePropsDocs.js +3 -3
  853. package/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
  854. package/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  855. package/extensions/forms/hooks/useFieldProps.js +11 -1
  856. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  857. package/extensions/forms/hooks/useValueProps.js +5 -0
  858. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  859. package/extensions/forms/style/dnb-forms.css +105 -47
  860. package/extensions/forms/style/dnb-forms.min.css +1 -1
  861. package/extensions/forms/types.d.ts +1 -7
  862. package/extensions/forms/types.js.map +1 -1
  863. package/package.json +1 -1
  864. package/shared/Context.d.ts +2 -2
  865. package/shared/Context.js.map +1 -1
  866. package/shared/Eufemia.d.ts +1 -1
  867. package/shared/Eufemia.js +2 -2
  868. package/shared/Eufemia.js.map +1 -1
  869. package/shared/component-helper.js.map +1 -1
  870. package/shared/locales/en-GB.d.ts +16 -16
  871. package/shared/locales/en-GB.js +16 -16
  872. package/shared/locales/en-GB.js.map +1 -1
  873. package/shared/locales/en-US.d.ts +17 -17
  874. package/shared/locales/en-US.js +3 -3
  875. package/shared/locales/en-US.js.map +1 -1
  876. package/shared/locales/index.d.ts +34 -32
  877. package/shared/locales/index.js.map +1 -1
  878. package/shared/locales/nb-NO.d.ts +16 -16
  879. package/shared/locales/nb-NO.js +16 -16
  880. package/shared/locales/nb-NO.js.map +1 -1
  881. package/style/core/scopes.scss +1 -1
  882. package/style/dnb-ui-basis.css +1 -1
  883. package/style/dnb-ui-basis.min.css +1 -1
  884. package/style/dnb-ui-body.css +1 -1
  885. package/style/dnb-ui-body.min.css +1 -1
  886. package/style/dnb-ui-components.css +344 -56
  887. package/style/dnb-ui-components.min.css +3 -3
  888. package/style/dnb-ui-components.scss +1 -0
  889. package/style/dnb-ui-core.css +1 -1
  890. package/style/dnb-ui-core.min.css +1 -1
  891. package/style/dnb-ui-extensions.css +105 -47
  892. package/style/dnb-ui-extensions.min.css +1 -1
  893. package/style/dnb-ui-forms.css +105 -47
  894. package/style/dnb-ui-forms.min.css +1 -1
  895. package/style/dnb-ui-forms.scss +2 -0
  896. package/style/themes/theme-eiendom/eiendom-theme-components.css +467 -108
  897. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  898. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +107 -49
  899. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  900. package/style/themes/theme-eiendom/eiendom-theme-forms.css +107 -49
  901. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  902. package/style/themes/theme-sbanken/sbanken-theme-components.css +480 -120
  903. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +5 -5
  904. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  905. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +106 -48
  906. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  907. package/style/themes/theme-sbanken/sbanken-theme-forms.css +106 -48
  908. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  909. package/style/themes/theme-ui/ui-theme-components.css +467 -108
  910. package/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  911. package/style/themes/theme-ui/ui-theme-extensions.css +107 -49
  912. package/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  913. package/style/themes/theme-ui/ui-theme-forms.css +107 -49
  914. package/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  915. package/style/themes/theme-ui/ui-theme-tags.css +3 -3
  916. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  917. package/umd/dnb-ui-basis.min.js +1 -1
  918. package/umd/dnb-ui-components.min.js +1 -1
  919. package/umd/dnb-ui-elements.min.js +1 -1
  920. package/umd/dnb-ui-extensions.min.js +2 -2
  921. package/umd/dnb-ui-lib.min.js +1 -1
  922. package/cjs/components/date-picker/DatePickerOld.d.ts +0 -334
  923. package/cjs/components/date-picker/DatePickerOld.js +0 -538
  924. package/cjs/components/date-picker/DatePickerOld.js.map +0 -1
  925. package/cjs/extensions/style/index.d.ts +0 -5
  926. package/cjs/extensions/style/index.js +0 -6
  927. package/cjs/extensions/style/index.js.map +0 -1
  928. package/components/date-picker/DatePickerOld.d.ts +0 -334
  929. package/components/date-picker/DatePickerOld.js +0 -528
  930. package/components/date-picker/DatePickerOld.js.map +0 -1
  931. package/es/components/date-picker/DatePickerOld.d.ts +0 -334
  932. package/es/components/date-picker/DatePickerOld.js +0 -528
  933. package/es/components/date-picker/DatePickerOld.js.map +0 -1
  934. package/es/extensions/style/index.d.ts +0 -5
  935. package/es/extensions/style/index.js +0 -4
  936. package/es/extensions/style/index.js.map +0 -1
  937. package/extensions/style/index.d.ts +0 -5
  938. package/extensions/style/index.js +0 -4
  939. package/extensions/style/index.js.map +0 -1
@@ -1,4 +1,4 @@
1
- import { FieldHelpProps, FieldProps } from '../../types';
1
+ import { FieldProps } from '../../types';
2
2
  export type ToggleProps = {
3
3
  valueOn: unknown;
4
4
  valueOff: unknown;
@@ -6,7 +6,7 @@ export type ToggleProps = {
6
6
  textOn?: string;
7
7
  textOff?: string;
8
8
  };
9
- export type Props = FieldHelpProps & Omit<FieldProps<unknown>, 'layout' | 'layoutOptions'> & ToggleProps;
9
+ export type Props = Omit<FieldProps<unknown>, 'layout' | 'layoutOptions'> & ToggleProps;
10
10
  declare function Toggle(props: Props): import("react/jsx-runtime").JSX.Element;
11
11
  declare namespace Toggle {
12
12
  var _supportsSpacingProps: boolean;
@@ -4,7 +4,7 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
4
4
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
5
5
  import React, { useCallback, useMemo } from 'react';
6
6
  import classnames from 'classnames';
7
- import { Checkbox, HelpButton, ToggleButton } from '../../../../components';
7
+ import { Checkbox, ToggleButton } from '../../../../components';
8
8
  import ButtonRow from '../../Form/ButtonRow';
9
9
  import FieldBlock from '../../FieldBlock';
10
10
  import { useFieldProps } from '../../hooks';
@@ -24,11 +24,9 @@ function Toggle(props) {
24
24
  variant,
25
25
  disabled,
26
26
  label,
27
- labelDescription,
28
27
  textOn,
29
28
  textOff,
30
29
  value,
31
- help,
32
30
  hasError,
33
31
  htmlAttributes,
34
32
  handleChange,
@@ -52,9 +50,6 @@ function Toggle(props) {
52
50
  className: cn,
53
51
  disabled
54
52
  }, pickSpacingProps(props));
55
- const suffix = help ? React.createElement(HelpButton, {
56
- title: help.title
57
- }, help.content) : undefined;
58
53
  const isOn = value === valueOn;
59
54
  const isOff = value === valueOff;
60
55
  useMemo(() => {
@@ -75,7 +70,6 @@ function Toggle(props) {
75
70
  checked: isOn,
76
71
  disabled: disabled,
77
72
  status: hasError ? 'error' : undefined,
78
- suffix: suffix,
79
73
  onChange: handleCheckboxChange
80
74
  }, htmlAttributes)));
81
75
  case 'button':
@@ -85,18 +79,12 @@ function Toggle(props) {
85
79
  checked: isOn,
86
80
  disabled: disabled,
87
81
  status: hasError ? 'error' : undefined,
88
- suffix: suffix,
89
82
  value: value ? 'true' : 'false',
90
83
  on_change: handleCheckboxChange
91
84
  }, htmlAttributes)));
92
85
  case 'buttons':
93
86
  return React.createElement(FieldBlock, _extends({}, fieldBlockProps, {
94
- asFieldset: true,
95
- labelDescription: React.createElement(React.Fragment, null, labelDescription, help ? React.createElement(HelpButton, {
96
- size: "small",
97
- left: labelDescription ? 'x-small' : false,
98
- title: help.title
99
- }, help.content) : undefined)
87
+ asFieldset: true
100
88
  }), React.createElement(ButtonRow, {
101
89
  bottom: "x-small"
102
90
  }, React.createElement(ToggleButtonGroupContext.Provider, {
@@ -121,7 +109,6 @@ function Toggle(props) {
121
109
  checked: isOn,
122
110
  disabled: disabled,
123
111
  status: hasError ? 'error' : undefined,
124
- suffix: suffix,
125
112
  value: value ? 'true' : 'false',
126
113
  on_change: handleCheckboxChange
127
114
  }, htmlAttributes)));
@@ -1 +1 @@
1
- {"version":3,"file":"Toggle.js","names":["React","useCallback","useMemo","classnames","Checkbox","HelpButton","ToggleButton","ButtonRow","FieldBlock","useFieldProps","pickSpacingProps","ToggleButtonGroupContext","useTranslation","Toggle","props","translations","ToggleField","preparedProps","_objectSpread","errorMessages","id","className","valueOn","valueOff","variant","disabled","label","labelDescription","textOn","textOff","value","help","hasError","htmlAttributes","handleChange","setDisplayValue","handleCheckboxChange","_ref","checked","handleToggleChange","_ref2","cn","fieldBlockProps","forId","suffix","createElement","title","content","undefined","isOn","isOff","text","path","_extends","yes","no","status","onChange","on_change","asFieldset","Fragment","size","left","bottom","Provider","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Toggle/Toggle.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Checkbox, HelpButton, ToggleButton } from '../../../../components'\nimport ButtonRow from '../../Form/ButtonRow'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport { FieldHelpProps, FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type ToggleProps = {\n valueOn: unknown\n valueOff: unknown\n variant?: 'checkbox' | 'checkbox-button' | 'button' | 'buttons'\n textOn?: string\n textOff?: string\n}\n\nexport type Props = FieldHelpProps &\n Omit<FieldProps<unknown>, 'layout' | 'layoutOptions'> &\n ToggleProps\n\nfunction Toggle(props: Props) {\n const translations = useTranslation().ToggleField\n\n const preparedProps: Props = {\n ...props,\n errorMessages: props.errorMessages,\n }\n\n const {\n id,\n className,\n valueOn,\n valueOff,\n variant,\n disabled,\n label,\n labelDescription,\n textOn,\n textOff,\n value,\n help,\n hasError,\n htmlAttributes,\n handleChange,\n setDisplayValue,\n } = useFieldProps(preparedProps)\n\n const handleCheckboxChange = useCallback(\n ({ checked }) => {\n handleChange?.(checked ? valueOn : valueOff)\n },\n [handleChange, valueOn, valueOff]\n )\n const handleToggleChange = useCallback(\n ({ value }) => {\n handleChange?.(value === 'on' ? valueOn : valueOff)\n },\n [handleChange, valueOn, valueOff]\n )\n\n const cn = classnames('dnb-forms-field-toggle', className)\n\n const fieldBlockProps: FieldBlockProps = {\n forId: id,\n className: cn,\n disabled,\n ...pickSpacingProps(props),\n }\n\n const suffix = help ? (\n <HelpButton title={help.title}>{help.content}</HelpButton>\n ) : undefined\n\n const isOn = value === valueOn\n const isOff = value === valueOff\n\n useMemo(() => {\n const text = isOn ? textOn : textOff\n if (text) {\n setDisplayValue(props.path, text)\n }\n }, [isOn, props.path, setDisplayValue, textOff, textOn])\n\n switch (variant) {\n default:\n case 'checkbox':\n return (\n <FieldBlock {...fieldBlockProps} label={undefined}>\n <Checkbox\n id={id}\n className={cn}\n label={\n label ??\n (isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no)\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n suffix={suffix}\n onChange={handleCheckboxChange}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n suffix={suffix}\n value={value ? 'true' : 'false'}\n on_change={handleCheckboxChange}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'buttons':\n return (\n <FieldBlock\n {...fieldBlockProps}\n asFieldset\n labelDescription={\n <>\n {labelDescription}\n {help ? (\n <HelpButton\n size=\"small\"\n left={labelDescription ? 'x-small' : false}\n title={help.title}\n >\n {help.content}\n </HelpButton>\n ) : undefined}\n </>\n }\n >\n <ButtonRow bottom=\"x-small\">\n <ToggleButtonGroupContext.Provider\n value={{\n value: isOn ? 'on' : isOff ? 'off' : null, // use \"null\" to reset the value\n onChange: handleToggleChange,\n status: hasError ? 'error' : undefined,\n disabled,\n }}\n >\n <ToggleButton\n text={textOn ?? translations.yes}\n value=\"on\"\n {...htmlAttributes}\n />\n <ToggleButton\n text={textOff ?? translations.no}\n value=\"off\"\n {...htmlAttributes}\n />\n </ToggleButtonGroupContext.Provider>\n </ButtonRow>\n </FieldBlock>\n )\n case 'checkbox-button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n variant=\"checkbox\"\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n suffix={suffix}\n value={value ? 'true' : 'false'}\n on_change={handleCheckboxChange}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n }\n}\n\nToggle._supportsSpacingProps = true\nexport default Toggle\n"],"mappings":"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"}
1
+ {"version":3,"file":"Toggle.js","names":["React","useCallback","useMemo","classnames","Checkbox","ToggleButton","ButtonRow","FieldBlock","useFieldProps","pickSpacingProps","ToggleButtonGroupContext","useTranslation","Toggle","props","translations","ToggleField","preparedProps","_objectSpread","errorMessages","id","className","valueOn","valueOff","variant","disabled","label","textOn","textOff","value","hasError","htmlAttributes","handleChange","setDisplayValue","handleCheckboxChange","_ref","checked","handleToggleChange","_ref2","cn","fieldBlockProps","forId","isOn","isOff","text","path","createElement","_extends","undefined","yes","no","status","onChange","on_change","asFieldset","bottom","Provider","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Toggle/Toggle.tsx"],"sourcesContent":["import React, { useCallback, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Checkbox, ToggleButton } from '../../../../components'\nimport ButtonRow from '../../Form/ButtonRow'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type ToggleProps = {\n valueOn: unknown\n valueOff: unknown\n variant?: 'checkbox' | 'checkbox-button' | 'button' | 'buttons'\n textOn?: string\n textOff?: string\n}\n\nexport type Props = Omit<FieldProps<unknown>, 'layout' | 'layoutOptions'> &\n ToggleProps\n\nfunction Toggle(props: Props) {\n const translations = useTranslation().ToggleField\n\n const preparedProps: Props = {\n ...props,\n errorMessages: props.errorMessages,\n }\n\n const {\n id,\n className,\n valueOn,\n valueOff,\n variant,\n disabled,\n label,\n textOn,\n textOff,\n value,\n hasError,\n htmlAttributes,\n handleChange,\n setDisplayValue,\n } = useFieldProps(preparedProps)\n\n const handleCheckboxChange = useCallback(\n ({ checked }) => {\n handleChange?.(checked ? valueOn : valueOff)\n },\n [handleChange, valueOn, valueOff]\n )\n const handleToggleChange = useCallback(\n ({ value }) => {\n handleChange?.(value === 'on' ? valueOn : valueOff)\n },\n [handleChange, valueOn, valueOff]\n )\n\n const cn = classnames('dnb-forms-field-toggle', className)\n\n const fieldBlockProps: FieldBlockProps = {\n forId: id,\n className: cn,\n disabled,\n ...pickSpacingProps(props),\n }\n\n const isOn = value === valueOn\n const isOff = value === valueOff\n\n useMemo(() => {\n const text = isOn ? textOn : textOff\n if (text) {\n setDisplayValue(props.path, text)\n }\n }, [isOn, props.path, setDisplayValue, textOff, textOn])\n\n switch (variant) {\n default:\n case 'checkbox':\n return (\n <FieldBlock {...fieldBlockProps} label={undefined}>\n <Checkbox\n id={id}\n className={cn}\n label={\n label ??\n (isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no)\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n onChange={handleCheckboxChange}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n value={value ? 'true' : 'false'}\n on_change={handleCheckboxChange}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'buttons':\n return (\n <FieldBlock {...fieldBlockProps} asFieldset>\n <ButtonRow bottom=\"x-small\">\n <ToggleButtonGroupContext.Provider\n value={{\n value: isOn ? 'on' : isOff ? 'off' : null, // use \"null\" to reset the value\n onChange: handleToggleChange,\n status: hasError ? 'error' : undefined,\n disabled,\n }}\n >\n <ToggleButton\n text={textOn ?? translations.yes}\n value=\"on\"\n {...htmlAttributes}\n />\n <ToggleButton\n text={textOff ?? translations.no}\n value=\"off\"\n {...htmlAttributes}\n />\n </ToggleButtonGroupContext.Provider>\n </ButtonRow>\n </FieldBlock>\n )\n case 'checkbox-button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n variant=\"checkbox\"\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n value={value ? 'true' : 'false'}\n on_change={handleCheckboxChange}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n }\n}\n\nToggle._supportsSpacingProps = true\nexport default Toggle\n"],"mappings":"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"}
@@ -23,11 +23,6 @@ export const ToggleProperties = {
23
23
  doc: 'Choice of input feature. Can be: `checkbox`, `button`, `checkbox-button` or `buttons`.',
24
24
  type: 'string',
25
25
  status: 'optional'
26
- },
27
- help: {
28
- doc: 'Provide a help button. Object consisting of `title` and `content`.',
29
- type: 'object',
30
- status: 'optional'
31
26
  }
32
27
  };
33
28
  //# sourceMappingURL=ToggleDocs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ToggleDocs.js","names":["ToggleProperties","valueOn","doc","type","status","valueOff","textOn","textOff","variant","help"],"sources":["../../../../../../src/extensions/forms/Field/Toggle/ToggleDocs.tsx"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const ToggleProperties: PropertiesTableProps = {\n valueOn: {\n doc: 'Source data value when the toggle is in the \"on-state\" (varies based on UI variant).',\n type: ['string', 'number', 'boolean'],\n status: 'required',\n },\n valueOff: {\n doc: 'Source data value when the toggle is in the \"off-state\".',\n type: ['string', 'number', 'boolean'],\n status: 'required',\n },\n textOn: {\n doc: 'Text to show in the UI when in the \"on-state\".',\n type: 'string',\n status: 'optional',\n },\n textOff: {\n doc: 'Text to show in the UI when in the \"off-state\".',\n type: 'string',\n status: 'optional',\n },\n variant: {\n doc: 'Choice of input feature. Can be: `checkbox`, `button`, `checkbox-button` or `buttons`.',\n type: 'string',\n status: 'optional',\n },\n help: {\n doc: 'Provide a help button. Object consisting of `title` and `content`.',\n type: 'object',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,gBAAsC,GAAG;EACpDC,OAAO,EAAE;IACPC,GAAG,EAAE,sFAAsF;IAC3FC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACDC,QAAQ,EAAE;IACRH,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACDE,MAAM,EAAE;IACNJ,GAAG,EAAE,gDAAgD;IACrDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,OAAO,EAAE;IACPL,GAAG,EAAE,iDAAiD;IACtDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,OAAO,EAAE;IACPN,GAAG,EAAE,wFAAwF;IAC7FC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,IAAI,EAAE;IACJP,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"ToggleDocs.js","names":["ToggleProperties","valueOn","doc","type","status","valueOff","textOn","textOff","variant"],"sources":["../../../../../../src/extensions/forms/Field/Toggle/ToggleDocs.tsx"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const ToggleProperties: PropertiesTableProps = {\n valueOn: {\n doc: 'Source data value when the toggle is in the \"on-state\" (varies based on UI variant).',\n type: ['string', 'number', 'boolean'],\n status: 'required',\n },\n valueOff: {\n doc: 'Source data value when the toggle is in the \"off-state\".',\n type: ['string', 'number', 'boolean'],\n status: 'required',\n },\n textOn: {\n doc: 'Text to show in the UI when in the \"on-state\".',\n type: 'string',\n status: 'optional',\n },\n textOff: {\n doc: 'Text to show in the UI when in the \"off-state\".',\n type: 'string',\n status: 'optional',\n },\n variant: {\n doc: 'Choice of input feature. Can be: `checkbox`, `button`, `checkbox-button` or `buttons`.',\n type: 'string',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,gBAAsC,GAAG;EACpDC,OAAO,EAAE;IACPC,GAAG,EAAE,sFAAsF;IAC3FC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACDC,QAAQ,EAAE;IACRH,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACDE,MAAM,EAAE;IACNJ,GAAG,EAAE,gDAAgD;IACrDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,OAAO,EAAE;IACPL,GAAG,EAAE,iDAAiD;IACtDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,OAAO,EAAE;IACPN,GAAG,EAAE,wFAAwF;IAC7FC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -1,11 +1,13 @@
1
1
  import { FieldBlockWidth } from '../../FieldBlock';
2
- import { FieldHelpProps, FieldProps } from '../../types';
2
+ import { FieldProps } from '../../types';
3
3
  import { UploadFile, UploadFileNative, UploadProps } from '../../../../components/Upload';
4
4
  import { SpacingProps } from '../../../../shared/types';
5
5
  export type UploadValue = Array<UploadFile | UploadFileNative>;
6
- export type Props = FieldHelpProps & Omit<FieldProps<UploadValue, UploadValue | undefined>, 'name'> & SpacingProps & {
6
+ export type Props = Omit<FieldProps<UploadValue, UploadValue | undefined>, 'name'> & SpacingProps & {
7
7
  width?: Omit<FieldBlockWidth, 'medium' | 'small'>;
8
- } & Pick<Partial<UploadProps>, 'title' | 'text' | 'acceptedFileTypes' | 'filesAmountLimit' | 'fileMaxSize' | 'onFileDelete' | 'skeleton'>;
8
+ } & Pick<Partial<UploadProps>, 'title' | 'text' | 'acceptedFileTypes' | 'filesAmountLimit' | 'fileMaxSize' | 'onFileDelete' | 'skeleton'> & {
9
+ asyncFileHandler?: (newFiles: UploadValue) => Promise<UploadValue>;
10
+ };
9
11
  declare function UploadComponent(props: Props): import("react/jsx-runtime").JSX.Element;
10
12
  declare namespace UploadComponent {
11
13
  var _supportsSpacingProps: boolean;
@@ -3,34 +3,41 @@
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
5
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
6
- const _excluded = ["id", "className", "width", "value", "label", "labelDescription", "help", "htmlAttributes", "handleChange", "handleFocus", "handleBlur"];
6
+ const _excluded = ["id", "className", "width", "value", "label", "labelDescription", "help", "htmlAttributes", "handleChange", "handleFocus", "handleBlur", "asyncFileHandler"];
7
7
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
8
8
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
9
9
  import React, { useCallback, useEffect, useMemo } from 'react';
10
+ import classnames from 'classnames';
10
11
  import FieldBlock from '../../FieldBlock';
11
12
  import { useFieldProps, useTranslation as useFormsTranslation } from '../../hooks';
12
13
  import Upload from '../../../../components/Upload';
13
14
  import useUpload from '../../../../components/upload/useUpload';
14
15
  import { pickSpacingProps } from '../../../../components/flex/utils';
15
- import { HelpButton } from '../../../../components';
16
+ import HelpButtonInline, { HelpButtonInlineContent } from '../../../../components/help-button/HelpButtonInline';
16
17
  import { useTranslation as useSharedTranslation } from '../../../../shared';
17
18
  import { FormError } from '../../utils';
19
+ const validateRequired = (value, _ref) => {
20
+ let {
21
+ required,
22
+ isChanged,
23
+ error
24
+ } = _ref;
25
+ const hasError = value === null || value === void 0 ? void 0 : value.some(file => file.errorMessage);
26
+ if (hasError) {
27
+ return new FormError('Upload.errorInvalidFiles');
28
+ }
29
+ const hasFiles = (value === null || value === void 0 ? void 0 : value.length) > 0;
30
+ if (required && (!isChanged && !hasFiles || !hasFiles)) {
31
+ return error;
32
+ }
33
+ return undefined;
34
+ };
35
+ const updateFileLoadingState = (files, isLoading) => {
36
+ return files.map(file => _objectSpread(_objectSpread({}, file), {}, {
37
+ isLoading
38
+ }));
39
+ };
18
40
  function UploadComponent(props) {
19
- const validateRequired = useCallback((value, _ref) => {
20
- let {
21
- required,
22
- isChanged,
23
- error
24
- } = _ref;
25
- const hasError = value === null || value === void 0 ? void 0 : value.some(file => file.errorMessage);
26
- if (hasError) {
27
- return new FormError('Upload.errorInvalidFiles');
28
- }
29
- if (required && (!isChanged || !(value.length > 0))) {
30
- return error;
31
- }
32
- return undefined;
33
- }, []);
34
41
  const sharedTr = useSharedTranslation().Upload;
35
42
  const formsTr = useFormsTranslation().Upload;
36
43
  const errorMessages = useMemo(() => ({
@@ -54,7 +61,8 @@ function UploadComponent(props) {
54
61
  htmlAttributes,
55
62
  handleChange,
56
63
  handleFocus,
57
- handleBlur
64
+ handleBlur,
65
+ asyncFileHandler
58
66
  } = _useFieldProps,
59
67
  rest = _objectWithoutProperties(_useFieldProps, _excluded);
60
68
  const {
@@ -67,26 +75,43 @@ function UploadComponent(props) {
67
75
  onFileDelete
68
76
  } = rest;
69
77
  const {
78
+ files: fileContext,
70
79
  setFiles
71
80
  } = useUpload(id);
72
81
  useEffect(() => {
73
82
  setFiles(value);
74
- }, [handleBlur, setFiles, value]);
83
+ }, [setFiles, value]);
84
+ const handleChangeAsync = useCallback(async files => {
85
+ const existingFileIds = (fileContext === null || fileContext === void 0 ? void 0 : fileContext.map(file => file.id)) || [];
86
+ const newFiles = files.filter(file => !existingFileIds.includes(file.id));
87
+ if (newFiles.length > 0) {
88
+ setFiles([...fileContext, ...updateFileLoadingState(newFiles, true)]);
89
+ const uploadedFiles = updateFileLoadingState(await asyncFileHandler(newFiles), false);
90
+ handleChange([...fileContext, ...uploadedFiles]);
91
+ } else {
92
+ handleChange(files);
93
+ }
94
+ }, [fileContext, asyncFileHandler, setFiles, updateFileLoadingState]);
75
95
  const changeHandler = useCallback(_ref2 => {
76
96
  let {
77
97
  files
78
98
  } = _ref2;
79
99
  handleBlur();
80
100
  handleFocus();
81
- handleChange(files);
82
- }, [handleBlur, handleChange, handleFocus]);
101
+ if (asyncFileHandler) {
102
+ handleChangeAsync(files);
103
+ } else {
104
+ handleChange(files);
105
+ }
106
+ }, [handleBlur, handleChange, handleFocus, asyncFileHandler, fileContext]);
83
107
  const width = widthProp;
84
108
  const fieldBlockProps = _objectSpread({
85
109
  id,
86
- forId: id,
110
+ forId: `${id}-input`,
87
111
  labelSrOnly: true,
88
- className,
89
- width
112
+ className: classnames('dnb-forms-field-upload', className),
113
+ width,
114
+ help: undefined
90
115
  }, pickSpacingProps(props));
91
116
  return React.createElement(FieldBlock, fieldBlockProps, React.createElement(Upload, _extends({
92
117
  id: id,
@@ -97,11 +122,15 @@ function UploadComponent(props) {
97
122
  onChange: changeHandler,
98
123
  onFileDelete: onFileDelete,
99
124
  title: label !== null && label !== void 0 ? label : title,
100
- text: help ? React.createElement(React.Fragment, null, labelDescription !== null && labelDescription !== void 0 ? labelDescription : text, React.createElement(HelpButton, {
125
+ text: help ? React.createElement(React.Fragment, null, labelDescription !== null && labelDescription !== void 0 ? labelDescription : text, React.createElement(HelpButtonInline, {
126
+ contentId: `${id}-help`,
101
127
  left: text ? 'x-small' : false,
102
- title: help.title
103
- }, help.content)) : labelDescription !== null && labelDescription !== void 0 ? labelDescription : text
104
- }, htmlAttributes)));
128
+ help: help
129
+ })) : labelDescription !== null && labelDescription !== void 0 ? labelDescription : text
130
+ }, htmlAttributes), help && React.createElement(HelpButtonInlineContent, {
131
+ contentId: `${id}-help`,
132
+ help: help
133
+ })));
105
134
  }
106
135
  export default UploadComponent;
107
136
  UploadComponent._supportsSpacingProps = true;
@@ -1 +1 @@
1
- {"version":3,"file":"Upload.js","names":["React","useCallback","useEffect","useMemo","FieldBlock","useFieldProps","useTranslation","useFormsTranslation","Upload","useUpload","pickSpacingProps","HelpButton","useSharedTranslation","FormError","UploadComponent","props","validateRequired","value","_ref","required","isChanged","error","hasError","some","file","errorMessage","length","undefined","sharedTr","formsTr","errorMessages","errorRequired","preparedProps","_objectSpread","_useFieldProps","executeOnChangeRegardlessOfError","id","className","width","widthProp","label","labelDescription","help","htmlAttributes","handleChange","handleFocus","handleBlur","rest","_objectWithoutProperties","_excluded","title","text","acceptedFileTypes","filesAmountLimit","fileMaxSize","skeleton","onFileDelete","setFiles","changeHandler","_ref2","files","fieldBlockProps","forId","labelSrOnly","createElement","_extends","onChange","Fragment","left","content","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Upload/Upload.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo } from 'react'\nimport FieldBlock, {\n Props as FieldBlockProps,\n FieldBlockWidth,\n} from '../../FieldBlock'\nimport {\n useFieldProps,\n useTranslation as useFormsTranslation,\n} from '../../hooks'\nimport { FieldHelpProps, FieldProps } from '../../types'\nimport Upload, {\n UploadFile,\n UploadFileNative,\n UploadProps,\n} from '../../../../components/Upload'\nimport useUpload from '../../../../components/upload/useUpload'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { HelpButton } from '../../../../components'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport { SpacingProps } from '../../../../shared/types'\nimport { FormError } from '../../utils'\n\nexport type UploadValue = Array<UploadFile | UploadFileNative>\nexport type Props = FieldHelpProps &\n Omit<FieldProps<UploadValue, UploadValue | undefined>, 'name'> &\n SpacingProps & {\n width?: Omit<FieldBlockWidth, 'medium' | 'small'>\n } & Pick<\n Partial<UploadProps>,\n | 'title'\n | 'text'\n | 'acceptedFileTypes'\n | 'filesAmountLimit'\n | 'fileMaxSize'\n | 'onFileDelete'\n | 'skeleton'\n >\n\nfunction UploadComponent(props: Props) {\n const validateRequired = useCallback(\n (value: UploadValue, { required, isChanged, error }) => {\n const hasError = value?.some((file) => file.errorMessage)\n if (hasError) {\n return new FormError('Upload.errorInvalidFiles')\n }\n\n if (required && (!isChanged || !(value.length > 0))) {\n return error\n }\n\n return undefined\n },\n []\n )\n\n const sharedTr = useSharedTranslation().Upload\n const formsTr = useFormsTranslation().Upload\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': formsTr.errorRequired,\n }),\n [formsTr.errorRequired]\n )\n\n const preparedProps = {\n errorMessages,\n validateRequired,\n ...props,\n }\n\n const {\n id,\n className,\n width: widthProp = 'stretch',\n value,\n label,\n labelDescription,\n help,\n htmlAttributes,\n handleChange,\n handleFocus,\n handleBlur,\n ...rest\n } = useFieldProps(preparedProps, {\n executeOnChangeRegardlessOfError: true,\n })\n\n // Upload props\n const {\n title = sharedTr.title,\n text = sharedTr.text,\n acceptedFileTypes = ['pdf', 'png', 'jpg', 'jpeg'],\n filesAmountLimit = 100,\n fileMaxSize = 5,\n skeleton,\n onFileDelete,\n } = rest\n\n const { setFiles } = useUpload(id)\n\n useEffect(() => {\n setFiles(value)\n }, [handleBlur, setFiles, value])\n\n const changeHandler = useCallback(\n ({ files }: { files: UploadValue }) => {\n // Prevents the form-status from showing up\n handleBlur()\n handleFocus()\n handleChange(files)\n },\n [handleBlur, handleChange, handleFocus]\n )\n\n const width = widthProp as FieldBlockWidth\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: id,\n labelSrOnly: true,\n className,\n width,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <Upload\n id={id}\n acceptedFileTypes={acceptedFileTypes}\n filesAmountLimit={filesAmountLimit}\n fileMaxSize={fileMaxSize}\n skeleton={skeleton}\n onChange={changeHandler}\n onFileDelete={onFileDelete}\n title={label ?? title}\n text={\n help ? (\n <>\n {labelDescription ?? text}\n <HelpButton\n left={text ? 'x-small' : false}\n title={help.title}\n >\n {help.content}\n </HelpButton>\n </>\n ) : (\n labelDescription ?? text\n )\n }\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n}\n\nexport default UploadComponent\n\nUploadComponent._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"Upload.js","names":["React","useCallback","useEffect","useMemo","classnames","FieldBlock","useFieldProps","useTranslation","useFormsTranslation","Upload","useUpload","pickSpacingProps","HelpButtonInline","HelpButtonInlineContent","useSharedTranslation","FormError","validateRequired","value","_ref","required","isChanged","error","hasError","some","file","errorMessage","hasFiles","length","undefined","updateFileLoadingState","files","isLoading","map","_objectSpread","UploadComponent","props","sharedTr","formsTr","errorMessages","errorRequired","preparedProps","_useFieldProps","executeOnChangeRegardlessOfError","id","className","width","widthProp","label","labelDescription","help","htmlAttributes","handleChange","handleFocus","handleBlur","asyncFileHandler","rest","_objectWithoutProperties","_excluded","title","text","acceptedFileTypes","filesAmountLimit","fileMaxSize","skeleton","onFileDelete","fileContext","setFiles","handleChangeAsync","existingFileIds","newFiles","filter","includes","uploadedFiles","changeHandler","_ref2","fieldBlockProps","forId","labelSrOnly","createElement","_extends","onChange","Fragment","contentId","left","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Upload/Upload.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo } from 'react'\nimport classnames from 'classnames'\nimport FieldBlock, {\n Props as FieldBlockProps,\n FieldBlockWidth,\n} from '../../FieldBlock'\nimport {\n useFieldProps,\n useTranslation as useFormsTranslation,\n} from '../../hooks'\nimport { FieldProps } from '../../types'\nimport Upload, {\n UploadFile,\n UploadFileNative,\n UploadProps,\n} from '../../../../components/Upload'\nimport useUpload from '../../../../components/upload/useUpload'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n} from '../../../../components/help-button/HelpButtonInline'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport { SpacingProps } from '../../../../shared/types'\nimport { FormError } from '../../utils'\n\nexport type UploadValue = Array<UploadFile | UploadFileNative>\nexport type Props = Omit<\n FieldProps<UploadValue, UploadValue | undefined>,\n 'name'\n> &\n SpacingProps & {\n width?: Omit<FieldBlockWidth, 'medium' | 'small'>\n } & Pick<\n Partial<UploadProps>,\n | 'title'\n | 'text'\n | 'acceptedFileTypes'\n | 'filesAmountLimit'\n | 'fileMaxSize'\n | 'onFileDelete'\n | 'skeleton'\n > & {\n asyncFileHandler?: (newFiles: UploadValue) => Promise<UploadValue>\n }\n\nconst validateRequired = (\n value: UploadValue,\n { required, isChanged, error }\n) => {\n const hasError = value?.some((file) => file.errorMessage)\n if (hasError) {\n return new FormError('Upload.errorInvalidFiles')\n }\n\n const hasFiles = value?.length > 0\n if (required && ((!isChanged && !hasFiles) || !hasFiles)) {\n return error\n }\n\n return undefined\n}\n\nconst updateFileLoadingState = (\n files: UploadValue,\n isLoading: boolean\n) => {\n return files.map((file) => ({ ...file, isLoading }))\n}\n\nfunction UploadComponent(props: Props) {\n const sharedTr = useSharedTranslation().Upload\n const formsTr = useFormsTranslation().Upload\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': formsTr.errorRequired,\n }),\n [formsTr.errorRequired]\n )\n\n const preparedProps = {\n errorMessages,\n validateRequired,\n ...props,\n }\n\n const {\n id,\n className,\n width: widthProp = 'stretch',\n value,\n label,\n labelDescription,\n help,\n htmlAttributes,\n handleChange,\n handleFocus,\n handleBlur,\n asyncFileHandler,\n ...rest\n } = useFieldProps(preparedProps, {\n executeOnChangeRegardlessOfError: true,\n })\n\n // Upload props\n const {\n title = sharedTr.title,\n text = sharedTr.text,\n acceptedFileTypes = ['pdf', 'png', 'jpg', 'jpeg'],\n filesAmountLimit = 100,\n fileMaxSize = 5,\n skeleton,\n onFileDelete,\n } = rest\n\n const { files: fileContext, setFiles } = useUpload(id)\n\n useEffect(() => {\n setFiles(value)\n }, [setFiles, value])\n\n const handleChangeAsync = useCallback(\n async (files: UploadValue) => {\n // Filter out existing files\n const existingFileIds = fileContext?.map((file) => file.id) || []\n const newFiles = files.filter(\n (file) => !existingFileIds.includes(file.id)\n )\n\n if (newFiles.length > 0) {\n // Set loading\n setFiles([\n ...fileContext,\n ...updateFileLoadingState(newFiles, true),\n ])\n\n const uploadedFiles = updateFileLoadingState(\n await asyncFileHandler(newFiles),\n false\n )\n\n handleChange([...fileContext, ...uploadedFiles])\n } else {\n handleChange(files)\n }\n },\n [fileContext, asyncFileHandler, setFiles, updateFileLoadingState]\n )\n\n const changeHandler = useCallback(\n ({ files }: { files: UploadValue }) => {\n // Prevents the form-status from showing up\n handleBlur()\n handleFocus()\n\n if (asyncFileHandler) {\n handleChangeAsync(files)\n } else {\n handleChange(files)\n }\n },\n [handleBlur, handleChange, handleFocus, asyncFileHandler, fileContext]\n )\n\n const width = widthProp as FieldBlockWidth\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input`,\n labelSrOnly: true,\n className: classnames('dnb-forms-field-upload', className),\n width,\n help: undefined,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <Upload\n id={id}\n acceptedFileTypes={acceptedFileTypes}\n filesAmountLimit={filesAmountLimit}\n fileMaxSize={fileMaxSize}\n skeleton={skeleton}\n onChange={changeHandler}\n onFileDelete={onFileDelete}\n title={label ?? title}\n text={\n help ? (\n <>\n {labelDescription ?? text}\n <HelpButtonInline\n contentId={`${id}-help`}\n left={text ? 'x-small' : false}\n help={help}\n />\n </>\n ) : (\n labelDescription ?? text\n )\n }\n {...htmlAttributes}\n >\n {help && (\n <HelpButtonInlineContent contentId={`${id}-help`} help={help} />\n )}\n </Upload>\n </FieldBlock>\n )\n}\n\nexport default UploadComponent\n\nUploadComponent._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ .dnb-forms-field-upload .dnb-help-button__content .dnb-section {
2
+ margin-left: var(--upload-border-width);
3
+ margin-right: var(--upload-border-width);
4
+ }
@@ -0,0 +1 @@
1
+ .dnb-forms-field-upload .dnb-help-button__content .dnb-section{margin-left:var(--upload-border-width);margin-right:var(--upload-border-width)}
@@ -0,0 +1,8 @@
1
+ .dnb-forms-field-upload {
2
+ .dnb-help-button__content {
3
+ .dnb-section {
4
+ margin-left: var(--upload-border-width);
5
+ margin-right: var(--upload-border-width);
6
+ }
7
+ }
8
+ }
@@ -1,6 +1,7 @@
1
1
  import React from 'react';
2
2
  import { StateWithMessage, StateMessage, StateTypes, FieldBlockContextProps } from './FieldBlockContext';
3
3
  import { ComponentProps, FieldProps, SubmitState } from '../types';
4
+ import { HelpProps } from '../../../components/help-button/HelpButtonInline';
4
5
  export declare const states: Array<StateTypes>;
5
6
  /**
6
7
  * The width of a field block
@@ -40,6 +41,10 @@ export type SharedFieldBlockProps = {
40
41
  * Width of contents block, while label etc can be wider if space is available
41
42
  */
42
43
  contentWidth?: FieldBlockWidth;
44
+ /**
45
+ * Provide help content for the field.
46
+ */
47
+ help?: HelpProps;
43
48
  };
44
49
  export type Props = SharedFieldBlockProps & Pick<FieldProps, keyof ComponentProps | 'info' | 'warning' | 'error' | 'disabled'> & {
45
50
  /** The id to link a element with */
@@ -3,7 +3,7 @@
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
5
5
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
6
- const _excluded = ["className", "forId", "layout", "layoutOptions", "composition", "label", "labelDescription", "labelSuffix", "labelSrOnly", "asFieldset", "required", "info", "warning", "error", "disableStatusSummary", "fieldState", "disabled", "width", "contentWidth", "labelHeight", "align", "labelSize", "contentClassName", "children"];
6
+ const _excluded = ["className", "forId", "layout", "layoutOptions", "composition", "label", "labelDescription", "labelSuffix", "labelSrOnly", "help", "asFieldset", "required", "info", "warning", "error", "disableStatusSummary", "fieldState", "disabled", "width", "contentWidth", "labelHeight", "align", "labelSize", "contentClassName", "children"];
7
7
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
8
8
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
9
9
  import React, { useMemo, useContext, useCallback, useRef, useReducer, useEffect } from 'react';
@@ -13,8 +13,9 @@ import DataContext from '../DataContext/Context';
13
13
  import IterateElementContext from '../Iterate/IterateItemContext';
14
14
  import { Space, FormLabel, FormStatus } from '../../../components';
15
15
  import { Ul, Li } from '../../../elements';
16
- import { convertJsxToString, findElementInChildren, warn } from '../../../shared/component-helper';
16
+ import { convertJsxToString, findElementInChildren } from '../../../shared/component-helper';
17
17
  import useId from '../../../shared/helpers/useId';
18
+ import HelpButtonInline, { HelpButtonInlineContent } from '../../../components/help-button/HelpButtonInline';
18
19
  import SubmitIndicator from '../Form/SubmitIndicator/SubmitIndicator';
19
20
  import { createSharedState } from '../../../shared/helpers/useSharedState';
20
21
  import useTranslation from '../hooks/useTranslation';
@@ -25,7 +26,8 @@ function FieldBlock(props) {
25
26
  const dataContext = useContext(DataContext);
26
27
  const fieldBlockContext = useContext(FieldBlockContext);
27
28
  const nestedFieldBlockContext = !(fieldBlockContext !== null && fieldBlockContext !== void 0 && fieldBlockContext.disableStatusSummary) ? fieldBlockContext : null;
28
- const sharedData = createSharedState('field-block-props-' + ((_props$id = props.id) !== null && _props$id !== void 0 ? _props$id : props.forId));
29
+ const id = useId((_props$id = props.id) !== null && _props$id !== void 0 ? _props$id : props.forId);
30
+ const sharedData = createSharedState('field-block-props-' + id);
29
31
  const _Object$assign = Object.assign({}, sharedData.data, props),
30
32
  {
31
33
  className,
@@ -37,6 +39,7 @@ function FieldBlock(props) {
37
39
  labelDescription,
38
40
  labelSuffix,
39
41
  labelSrOnly,
42
+ help,
40
43
  asFieldset,
41
44
  required,
42
45
  info,
@@ -231,7 +234,7 @@ function FieldBlock(props) {
231
234
  }, []);
232
235
  if (messages.length > 0) {
233
236
  acc[type] = _objectSpread(_objectSpread({}, acc[type]), {}, {
234
- text: React.createElement(CombineMessages, {
237
+ children: React.createElement(CombineMessages, {
235
238
  type: type,
236
239
  messages: messages
237
240
  })
@@ -253,7 +256,7 @@ function FieldBlock(props) {
253
256
  mountedFieldsRef.current = {};
254
257
  stateRecordRef.current = {};
255
258
  }, []);
256
- const mainClasses = classnames('dnb-forms-field-block', className, width && `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`, labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`);
259
+ const mainClasses = classnames('dnb-forms-field-block', className, width && `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`, contentWidth && `dnb-forms-field-block--content-width-${hasCustomContentWidth ? 'custom' : contentWidth}`, labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`);
257
260
  const gridClasses = `dnb-forms-field-block__grid dnb-forms-field-block--layout-${layout}`;
258
261
  const enableFieldset = useEnableFieldset({
259
262
  label,
@@ -262,6 +265,7 @@ function FieldBlock(props) {
262
265
  nestedFieldBlockContext
263
266
  });
264
267
  const labelProps = {
268
+ className: 'dnb-forms-field-block__label',
265
269
  element: enableFieldset ? 'legend' : 'label',
266
270
  forId: enableFieldset ? undefined : forId,
267
271
  srOnly: labelSrOnly,
@@ -292,10 +296,8 @@ function FieldBlock(props) {
292
296
  if (dataContext !== null && dataContext !== void 0 && dataContext.prerenderFieldProps) {
293
297
  return null;
294
298
  }
295
- if (fieldState && typeof label === 'undefined') {
296
- warn('Provide a label when using an async validator or onChange event.');
297
- }
298
299
  const hasLabelDescription = isFragment(labelDescription) ? fragmentHasChildren(labelDescription) && !fragmentHasOnlyUndefinedChildren(labelDescription) : labelDescription;
300
+ const hasHelp = (help === null || help === void 0 ? void 0 : help.title) || (help === null || help === void 0 ? void 0 : help.content);
299
301
  return React.createElement(FieldBlockContext.Provider, {
300
302
  value: {
301
303
  setFieldState,
@@ -312,18 +314,27 @@ function FieldBlock(props) {
312
314
  className: mainClasses
313
315
  }, rest), React.createElement("div", {
314
316
  className: gridClasses
315
- }, React.createElement(LabelDescription, {
316
- labelDescription: labelDescription
317
- }, (label || labelDescription) && React.createElement(FormLabel, labelProps, React.createElement(SubmitIndicator, {
318
- state: fieldState
319
- }, label, hasLabelDescription && React.createElement("span", {
320
- className: "dnb-forms-field-block__label-description"
321
- }, labelDescription)))), React.createElement("div", {
317
+ }, (label || labelDescription || hasHelp) && React.createElement(FormLabel, labelProps, React.createElement("span", null, label && React.createElement("span", {
318
+ className: "dnb-forms-field-block__label__content"
319
+ }, label), hasLabelDescription && React.createElement("span", {
320
+ className: "dnb-forms-field-block__label__description"
321
+ }, labelDescription), hasHelp && React.createElement(HelpButtonInline, {
322
+ contentId: `${id}-help`,
323
+ help: help
324
+ }))), hasHelp && React.createElement(HelpButtonInlineContent, {
325
+ contentId: `${id}-help`,
326
+ className: "dnb-forms-field-block__help",
327
+ help: help,
328
+ breakout: layout === 'vertical' && !(nestedFieldBlockContext !== null && nestedFieldBlockContext !== void 0 && nestedFieldBlockContext.composition)
329
+ }), React.createElement("div", {
322
330
  className: 'dnb-forms-field-block__status' + (contentWidth && contentWidth !== 'small' && contentWidth !== 'medium' && !(parseFloat(contentWidth) <= 11) ? ` dnb-forms-field-block__contents--width-${hasCustomContentWidth ? 'custom' : contentWidth}` : "")
323
331
  }, React.createElement(FormStatus, statusContent === null || statusContent === void 0 ? void 0 : statusContent.error), React.createElement(FormStatus, statusContent === null || statusContent === void 0 ? void 0 : statusContent.warning), React.createElement(FormStatus, statusContent === null || statusContent === void 0 ? void 0 : statusContent.info)), React.createElement("div", {
324
332
  className: classnames('dnb-forms-field-block__contents', contentClassName, contentWidth && `dnb-forms-field-block__contents--width-${hasCustomContentWidth ? 'custom' : contentWidth}`, align && `dnb-forms-field-block__contents--align-${align}`, composition && `dnb-forms-field-block__contents__composition--${composition === true ? 'horizontal' : composition}`),
325
333
  ref: contentsRef
326
- }, children))));
334
+ }, children), React.createElement(SubmitIndicator, {
335
+ state: fieldState,
336
+ className: "dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap"
337
+ }))));
327
338
  }
328
339
  function useEnableFieldset(_ref3) {
329
340
  let {
@@ -370,18 +381,6 @@ function CombineMessages(_ref4) {
370
381
  }, message);
371
382
  })));
372
383
  }
373
- function LabelDescription(_ref6) {
374
- let {
375
- labelDescription,
376
- children
377
- } = _ref6;
378
- if (!labelDescription) {
379
- return children !== null && children !== void 0 ? children : null;
380
- }
381
- return React.createElement("div", {
382
- className: "dnb-forms-field-block__label"
383
- }, children);
384
- }
385
384
  export function getMessagesFromError(item) {
386
385
  const {
387
386
  content
@@ -391,7 +390,15 @@ export function getMessagesFromError(item) {
391
390
  return error.message;
392
391
  });
393
392
  }
394
- return [content instanceof Error && content.message || content instanceof FormError && content.message || (content === null || content === void 0 ? void 0 : content.toString()) || content];
393
+ if (Array.isArray(content)) {
394
+ return content.map(content => {
395
+ return content instanceof FormError || content instanceof Error ? content.message : content;
396
+ });
397
+ }
398
+ if (content instanceof FormError || content instanceof Error) {
399
+ return [content.message];
400
+ }
401
+ return [(React.isValidElement(content) ? content : content === null || content === void 0 ? void 0 : content.toString()) || content];
395
402
  }
396
403
  function isFragment(fragment) {
397
404
  return React.isValidElement(fragment) && fragment.type === React.Fragment;