@dnb/eufemia 10.62.3 → 10.63.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 (946) hide show
  1. package/CHANGELOG.md +61 -0
  2. package/cjs/components/accordion/Accordion.d.ts +1 -125
  3. package/cjs/components/accordion/Accordion.js +0 -1
  4. package/cjs/components/accordion/Accordion.js.map +1 -1
  5. package/cjs/components/autocomplete/Autocomplete.js +3 -2
  6. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  7. package/cjs/components/button/Button.d.ts +3 -6
  8. package/cjs/components/button/Button.js +8 -18
  9. package/cjs/components/button/Button.js.map +1 -1
  10. package/cjs/components/button/ButtonDocs.d.ts +2 -0
  11. package/cjs/components/button/ButtonDocs.js +135 -0
  12. package/cjs/components/button/ButtonDocs.js.map +1 -0
  13. package/cjs/components/card/Card.js +2 -1
  14. package/cjs/components/card/Card.js.map +1 -1
  15. package/cjs/components/date-picker/DatePicker.d.ts +4 -0
  16. package/cjs/components/date-picker/DatePicker.js +24 -10
  17. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  18. package/cjs/components/date-picker/DatePickerDocs.js +5 -0
  19. package/cjs/components/date-picker/DatePickerDocs.js.map +1 -1
  20. package/cjs/components/date-picker/DatePickerPortal.d.ts +9 -0
  21. package/cjs/components/date-picker/DatePickerPortal.js +61 -0
  22. package/cjs/components/date-picker/DatePickerPortal.js.map +1 -0
  23. package/cjs/components/date-picker/style/dnb-date-picker.css +64 -55
  24. package/cjs/components/date-picker/style/dnb-date-picker.min.css +1 -1
  25. package/cjs/components/date-picker/style/dnb-date-picker.scss +90 -75
  26. package/cjs/components/form-row/FormRow.js +2 -7
  27. package/cjs/components/form-row/FormRow.js.map +1 -1
  28. package/cjs/components/form-row/style/dnb-form-row.css +3 -3
  29. package/cjs/components/form-row/style/dnb-form-row.min.css +1 -1
  30. package/cjs/components/form-status/FormStatus.js +17 -19
  31. package/cjs/components/form-status/FormStatus.js.map +1 -1
  32. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  33. package/cjs/components/height-animation/HeightAnimationInstance.js +26 -1
  34. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  35. package/cjs/components/input-masked/InputMasked.d.ts +1 -1
  36. package/cjs/components/input-masked/InputMasked.js +2 -2
  37. package/cjs/components/input-masked/InputMasked.js.map +1 -1
  38. package/cjs/components/input-masked/InputMaskedDocs.js +1 -1
  39. package/cjs/components/input-masked/InputMaskedDocs.js.map +1 -1
  40. package/cjs/components/input-masked/InputMaskedHooks.js +1 -1
  41. package/cjs/components/input-masked/InputMaskedHooks.js.map +1 -1
  42. package/cjs/components/input-masked/InputMaskedUtils.js +1 -1
  43. package/cjs/components/input-masked/InputMaskedUtils.js.map +1 -1
  44. package/cjs/components/input-masked/style/dnb-input-masked.css +3 -3
  45. package/cjs/components/input-masked/style/dnb-input-masked.min.css +1 -1
  46. package/cjs/components/pagination/Pagination.d.ts +12 -0
  47. package/cjs/components/pagination/Pagination.js +7 -3
  48. package/cjs/components/pagination/Pagination.js.map +1 -1
  49. package/cjs/components/pagination/PaginationBar.d.ts +2 -1
  50. package/cjs/components/pagination/PaginationBar.js +10 -3
  51. package/cjs/components/pagination/PaginationBar.js.map +1 -1
  52. package/cjs/components/radio/style/dnb-radio.css +3 -3
  53. package/cjs/components/radio/style/dnb-radio.min.css +1 -1
  54. package/cjs/components/space/style/dnb-space.css +4 -4
  55. package/cjs/components/space/style/dnb-space.min.css +1 -1
  56. package/cjs/components/space/style/dnb-space.scss +2 -12
  57. package/cjs/components/space/style/space-mixins.scss +21 -0
  58. package/cjs/components/tabs/Tabs.d.ts +1 -1
  59. package/cjs/components/tabs/Tabs.js +4 -12
  60. package/cjs/components/tabs/Tabs.js.map +1 -1
  61. package/cjs/components/toggle-button/ToggleButton.d.ts +9 -5
  62. package/cjs/components/toggle-button/ToggleButton.js +2 -0
  63. package/cjs/components/toggle-button/ToggleButton.js.map +1 -1
  64. package/cjs/components/toggle-button/ToggleButtonDocs.d.ts +2 -0
  65. package/cjs/components/toggle-button/ToggleButtonDocs.js +87 -0
  66. package/cjs/components/toggle-button/ToggleButtonDocs.js.map +1 -0
  67. package/cjs/components/toggle-button/ToggleButtonGroup.d.ts +21 -6
  68. package/cjs/components/toggle-button/ToggleButtonGroupDocs.d.ts +2 -0
  69. package/cjs/components/toggle-button/ToggleButtonGroupDocs.js +90 -0
  70. package/cjs/components/toggle-button/ToggleButtonGroupDocs.js.map +1 -0
  71. package/cjs/components/toggle-button/style/dnb-toggle-button.css +3 -3
  72. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  73. package/cjs/elements/blockquote/style/blockquote-mixins.scss +5 -3
  74. package/cjs/elements/code/style/code-mixins.scss +2 -3
  75. package/cjs/elements/hr/style/hr-mixins.scss +2 -3
  76. package/cjs/elements/img/style/img-mixins.scss +3 -3
  77. package/cjs/elements/lists/style/lists-mixins.scss +3 -6
  78. package/cjs/elements/typography/style/typography-mixins.scss +2 -3
  79. package/cjs/extensions/forms/DataContext/Context.d.ts +15 -4
  80. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  81. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +1 -1
  82. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  83. package/cjs/extensions/forms/DataContext/Provider/Provider.js +28 -17
  84. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  85. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  86. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  87. package/cjs/extensions/forms/Field/Date/Date.js +5 -4
  88. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  89. package/cjs/extensions/forms/Field/Expiry/Expiry.js +4 -3
  90. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  91. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js +7 -7
  92. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  93. package/cjs/extensions/forms/Field/Number/Number.js +2 -2
  94. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  95. package/cjs/extensions/forms/Field/Option/Option.d.ts +2 -1
  96. package/cjs/extensions/forms/Field/Option/Option.js +2 -14
  97. package/cjs/extensions/forms/Field/Option/Option.js.map +1 -1
  98. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +10 -5
  99. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  100. package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +4 -3
  101. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +12 -4
  102. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  103. package/cjs/extensions/forms/Field/Selection/Selection.d.ts +8 -1
  104. package/cjs/extensions/forms/Field/Selection/Selection.js +19 -12
  105. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  106. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js +5 -0
  107. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  108. package/cjs/extensions/forms/Field/Slider/Slider.js +4 -3
  109. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -1
  110. package/cjs/extensions/forms/Field/String/String.js +2 -2
  111. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  112. package/cjs/extensions/forms/Field/Toggle/Toggle.js +14 -4
  113. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  114. package/cjs/extensions/forms/Field/Upload/Upload.js +21 -21
  115. package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
  116. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +14 -38
  117. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  118. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  119. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  120. package/cjs/extensions/forms/Form/Isolation/Isolation.js +17 -3
  121. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  122. package/cjs/extensions/forms/Form/MainHeading/MainHeadingDocs.d.ts +2 -0
  123. package/cjs/extensions/forms/Form/MainHeading/MainHeadingDocs.js +27 -0
  124. package/cjs/extensions/forms/Form/MainHeading/MainHeadingDocs.js.map +1 -0
  125. package/cjs/extensions/forms/Form/Section/EditContainer/CancelButton.js +7 -18
  126. package/cjs/extensions/forms/Form/Section/EditContainer/CancelButton.js.map +1 -1
  127. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +0 -10
  128. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  129. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +1 -12
  130. package/cjs/extensions/forms/Form/SubHeading/SubHeadingDocs.d.ts +2 -0
  131. package/cjs/extensions/forms/Form/SubHeading/SubHeadingDocs.js +27 -0
  132. package/cjs/extensions/forms/Form/SubHeading/SubHeadingDocs.js.map +1 -0
  133. package/cjs/extensions/forms/Form/Visibility/Visibility.d.ts +11 -1
  134. package/cjs/extensions/forms/Form/Visibility/Visibility.js +18 -10
  135. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  136. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.d.ts +2 -0
  137. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -1
  138. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  139. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  140. package/cjs/extensions/forms/Form/Visibility/useVisibility.js +18 -9
  141. package/cjs/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  142. package/cjs/extensions/forms/Form/data-context/useValidation.d.ts +2 -1
  143. package/cjs/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  144. package/cjs/extensions/forms/Iterate/Array/Array.js +49 -29
  145. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  146. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +14 -4
  147. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  148. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js +2 -1
  149. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  150. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +2 -0
  151. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -1
  152. package/cjs/extensions/forms/Iterate/Array/types.d.ts +8 -3
  153. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  154. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js +5 -15
  155. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  156. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +10 -1
  157. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -1
  158. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +1 -3
  159. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  160. package/cjs/extensions/forms/Iterate/ItemNo/useIItemNo.d.ts +5 -0
  161. package/cjs/extensions/forms/Iterate/ItemNo/useIItemNo.js +50 -0
  162. package/cjs/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +1 -0
  163. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +2 -0
  164. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  165. package/cjs/extensions/forms/Iterate/PushButton/PushButton.d.ts +1 -0
  166. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +16 -14
  167. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  168. package/cjs/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  169. package/cjs/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  170. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +17 -1
  171. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +32 -16
  172. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  173. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +1 -0
  174. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -1
  175. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  176. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  177. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +7 -6
  178. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  179. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +3 -2
  180. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  181. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js +1 -0
  182. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -1
  183. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -3
  184. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  185. package/cjs/extensions/forms/Iterate/Visibility/Visibility.d.ts +7 -0
  186. package/cjs/extensions/forms/Iterate/Visibility/Visibility.js +31 -0
  187. package/cjs/extensions/forms/Iterate/Visibility/Visibility.js.map +1 -0
  188. package/cjs/extensions/forms/Iterate/Visibility/index.d.ts +2 -0
  189. package/cjs/extensions/forms/Iterate/Visibility/index.js +27 -0
  190. package/cjs/extensions/forms/Iterate/Visibility/index.js.map +1 -0
  191. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  192. package/cjs/extensions/forms/Iterate/hooks/index.js +7 -0
  193. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -1
  194. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +1 -3
  195. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.js +1 -4
  196. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -1
  197. package/cjs/extensions/forms/Iterate/hooks/useItemPath.d.ts +4 -0
  198. package/cjs/extensions/forms/Iterate/hooks/useItemPath.js +22 -0
  199. package/cjs/extensions/forms/Iterate/hooks/useItemPath.js.map +1 -0
  200. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +1 -3
  201. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +1 -4
  202. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -1
  203. package/cjs/extensions/forms/Iterate/index.d.ts +1 -0
  204. package/cjs/extensions/forms/Iterate/index.js +7 -0
  205. package/cjs/extensions/forms/Iterate/index.js.map +1 -1
  206. package/cjs/extensions/forms/Iterate/style/dnb-iterate.css +16 -0
  207. package/cjs/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -1
  208. package/cjs/extensions/forms/Iterate/style/dnb-iterate.scss +25 -2
  209. package/cjs/extensions/forms/Tools/GenerateSchema.js +15 -9
  210. package/cjs/extensions/forms/Tools/GenerateSchema.js.map +1 -1
  211. package/cjs/extensions/forms/Tools/ListAllProps.js +11 -7
  212. package/cjs/extensions/forms/Tools/ListAllProps.js.map +1 -1
  213. package/cjs/extensions/forms/Tools/Log.js +2 -1
  214. package/cjs/extensions/forms/Tools/Log.js.map +1 -1
  215. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js +4 -4
  216. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  217. package/cjs/extensions/forms/Value/Selection/Selection.js +5 -5
  218. package/cjs/extensions/forms/Value/Selection/Selection.js.map +1 -1
  219. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +25 -7
  220. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  221. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.css +6 -1
  222. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  223. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.scss +22 -10
  224. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +6 -3
  225. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  226. package/cjs/extensions/forms/Wizard/Container/useHandleLayoutEffect.d.ts +2 -1
  227. package/cjs/extensions/forms/Wizard/Container/useHandleLayoutEffect.js +4 -3
  228. package/cjs/extensions/forms/Wizard/Container/useHandleLayoutEffect.js.map +1 -1
  229. package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js +9 -9
  230. package/cjs/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
  231. package/cjs/extensions/forms/hooks/useDataValue.d.ts +2 -2
  232. package/cjs/extensions/forms/hooks/useDataValue.js +5 -9
  233. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  234. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  235. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +8 -2
  236. package/cjs/extensions/forms/hooks/useFieldProps.js +164 -76
  237. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  238. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  239. package/cjs/extensions/forms/hooks/useValueProps.js +5 -5
  240. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  241. package/cjs/extensions/forms/style/dnb-forms.css +25 -14
  242. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  243. package/cjs/extensions/forms/types.d.ts +33 -6
  244. package/cjs/extensions/forms/types.js.map +1 -1
  245. package/cjs/extensions/forms/utils/json-pointer/json-pointer.js +8 -0
  246. package/cjs/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
  247. package/cjs/extensions/payment-card/PaymentCard.js +3 -12
  248. package/cjs/extensions/payment-card/PaymentCard.js.map +1 -1
  249. package/cjs/fragments/drawer-list/DrawerList.d.ts +4 -2
  250. package/cjs/fragments/drawer-list/DrawerList.js +33 -47
  251. package/cjs/fragments/drawer-list/DrawerList.js.map +1 -1
  252. package/cjs/fragments/drawer-list/DrawerListDocs.js +3 -3
  253. package/cjs/fragments/drawer-list/DrawerListDocs.js.map +1 -1
  254. package/cjs/fragments/drawer-list/style/dnb-drawer-list.scss +1 -1
  255. package/cjs/shared/AlignmentHelper.js +0 -4
  256. package/cjs/shared/AlignmentHelper.js.map +1 -1
  257. package/cjs/shared/Eufemia.d.ts +1 -1
  258. package/cjs/shared/Eufemia.js +2 -2
  259. package/cjs/shared/Eufemia.js.map +1 -1
  260. package/cjs/shared/component-helper.js +2 -1
  261. package/cjs/shared/component-helper.js.map +1 -1
  262. package/cjs/style/core/scopes.scss +1 -1
  263. package/cjs/style/core/utilities.scss +3 -12
  264. package/cjs/style/dnb-ui-basis.css +1 -1
  265. package/cjs/style/dnb-ui-basis.min.css +1 -1
  266. package/cjs/style/dnb-ui-body.css +1 -1
  267. package/cjs/style/dnb-ui-body.min.css +1 -1
  268. package/cjs/style/dnb-ui-components.css +106 -86
  269. package/cjs/style/dnb-ui-components.min.css +4 -4
  270. package/cjs/style/dnb-ui-core.css +1 -1
  271. package/cjs/style/dnb-ui-core.min.css +1 -1
  272. package/cjs/style/dnb-ui-elements.css +151 -31
  273. package/cjs/style/dnb-ui-elements.min.css +1 -1
  274. package/cjs/style/dnb-ui-extensions.css +25 -14
  275. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  276. package/cjs/style/dnb-ui-forms.css +25 -14
  277. package/cjs/style/dnb-ui-forms.min.css +1 -1
  278. package/cjs/style/dnb-ui-fragments.css +1 -1
  279. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  280. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +151 -31
  281. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  282. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +131 -100
  283. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  284. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +151 -31
  285. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  286. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +25 -14
  287. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  288. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +25 -14
  289. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  290. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +151 -31
  291. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  292. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +131 -100
  293. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +4 -4
  294. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +151 -31
  295. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  296. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +25 -14
  297. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  298. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +25 -14
  299. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  300. package/cjs/style/themes/theme-ui/ui-theme-basis.css +151 -31
  301. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  302. package/cjs/style/themes/theme-ui/ui-theme-components.css +131 -100
  303. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  304. package/cjs/style/themes/theme-ui/ui-theme-elements.css +151 -31
  305. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  306. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +25 -14
  307. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  308. package/cjs/style/themes/theme-ui/ui-theme-forms.css +25 -14
  309. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  310. package/cjs/style/themes/theme-ui/ui-theme-tags.css +100 -19
  311. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  312. package/components/accordion/Accordion.d.ts +1 -125
  313. package/components/accordion/Accordion.js +0 -1
  314. package/components/accordion/Accordion.js.map +1 -1
  315. package/components/autocomplete/Autocomplete.js +3 -2
  316. package/components/autocomplete/Autocomplete.js.map +1 -1
  317. package/components/button/Button.d.ts +3 -6
  318. package/components/button/Button.js +8 -18
  319. package/components/button/Button.js.map +1 -1
  320. package/components/button/ButtonDocs.d.ts +2 -0
  321. package/components/button/ButtonDocs.js +128 -0
  322. package/components/button/ButtonDocs.js.map +1 -0
  323. package/components/card/Card.js +2 -1
  324. package/components/card/Card.js.map +1 -1
  325. package/components/date-picker/DatePicker.d.ts +4 -0
  326. package/components/date-picker/DatePicker.js +25 -11
  327. package/components/date-picker/DatePicker.js.map +1 -1
  328. package/components/date-picker/DatePickerDocs.js +5 -0
  329. package/components/date-picker/DatePickerDocs.js.map +1 -1
  330. package/components/date-picker/DatePickerPortal.d.ts +9 -0
  331. package/components/date-picker/DatePickerPortal.js +53 -0
  332. package/components/date-picker/DatePickerPortal.js.map +1 -0
  333. package/components/date-picker/style/dnb-date-picker.css +64 -55
  334. package/components/date-picker/style/dnb-date-picker.min.css +1 -1
  335. package/components/date-picker/style/dnb-date-picker.scss +90 -75
  336. package/components/form-row/FormRow.js +2 -7
  337. package/components/form-row/FormRow.js.map +1 -1
  338. package/components/form-row/style/dnb-form-row.css +3 -3
  339. package/components/form-row/style/dnb-form-row.min.css +1 -1
  340. package/components/form-status/FormStatus.js +17 -19
  341. package/components/form-status/FormStatus.js.map +1 -1
  342. package/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  343. package/components/height-animation/HeightAnimationInstance.js +26 -1
  344. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  345. package/components/input-masked/InputMasked.d.ts +1 -1
  346. package/components/input-masked/InputMasked.js +2 -2
  347. package/components/input-masked/InputMasked.js.map +1 -1
  348. package/components/input-masked/InputMaskedDocs.js +1 -1
  349. package/components/input-masked/InputMaskedDocs.js.map +1 -1
  350. package/components/input-masked/InputMaskedHooks.js +1 -1
  351. package/components/input-masked/InputMaskedHooks.js.map +1 -1
  352. package/components/input-masked/InputMaskedUtils.js +1 -1
  353. package/components/input-masked/InputMaskedUtils.js.map +1 -1
  354. package/components/input-masked/style/dnb-input-masked.css +3 -3
  355. package/components/input-masked/style/dnb-input-masked.min.css +1 -1
  356. package/components/pagination/Pagination.d.ts +12 -0
  357. package/components/pagination/Pagination.js +7 -3
  358. package/components/pagination/Pagination.js.map +1 -1
  359. package/components/pagination/PaginationBar.d.ts +2 -1
  360. package/components/pagination/PaginationBar.js +10 -3
  361. package/components/pagination/PaginationBar.js.map +1 -1
  362. package/components/radio/style/dnb-radio.css +3 -3
  363. package/components/radio/style/dnb-radio.min.css +1 -1
  364. package/components/space/style/dnb-space.css +4 -4
  365. package/components/space/style/dnb-space.min.css +1 -1
  366. package/components/space/style/dnb-space.scss +2 -12
  367. package/components/space/style/space-mixins.scss +21 -0
  368. package/components/tabs/Tabs.d.ts +1 -1
  369. package/components/tabs/Tabs.js +4 -12
  370. package/components/tabs/Tabs.js.map +1 -1
  371. package/components/toggle-button/ToggleButton.d.ts +9 -5
  372. package/components/toggle-button/ToggleButton.js +2 -0
  373. package/components/toggle-button/ToggleButton.js.map +1 -1
  374. package/components/toggle-button/ToggleButtonDocs.d.ts +2 -0
  375. package/components/toggle-button/ToggleButtonDocs.js +80 -0
  376. package/components/toggle-button/ToggleButtonDocs.js.map +1 -0
  377. package/components/toggle-button/ToggleButtonGroup.d.ts +21 -6
  378. package/components/toggle-button/ToggleButtonGroupDocs.d.ts +2 -0
  379. package/components/toggle-button/ToggleButtonGroupDocs.js +83 -0
  380. package/components/toggle-button/ToggleButtonGroupDocs.js.map +1 -0
  381. package/components/toggle-button/style/dnb-toggle-button.css +3 -3
  382. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  383. package/elements/blockquote/style/blockquote-mixins.scss +5 -3
  384. package/elements/code/style/code-mixins.scss +2 -3
  385. package/elements/hr/style/hr-mixins.scss +2 -3
  386. package/elements/img/style/img-mixins.scss +3 -3
  387. package/elements/lists/style/lists-mixins.scss +3 -6
  388. package/elements/typography/style/typography-mixins.scss +2 -3
  389. package/es/components/accordion/Accordion.d.ts +1 -125
  390. package/es/components/accordion/Accordion.js +0 -1
  391. package/es/components/accordion/Accordion.js.map +1 -1
  392. package/es/components/autocomplete/Autocomplete.js +3 -2
  393. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  394. package/es/components/button/Button.d.ts +3 -6
  395. package/es/components/button/Button.js +8 -18
  396. package/es/components/button/Button.js.map +1 -1
  397. package/es/components/button/ButtonDocs.d.ts +2 -0
  398. package/es/components/button/ButtonDocs.js +128 -0
  399. package/es/components/button/ButtonDocs.js.map +1 -0
  400. package/es/components/card/Card.js +2 -1
  401. package/es/components/card/Card.js.map +1 -1
  402. package/es/components/date-picker/DatePicker.d.ts +4 -0
  403. package/es/components/date-picker/DatePicker.js +25 -11
  404. package/es/components/date-picker/DatePicker.js.map +1 -1
  405. package/es/components/date-picker/DatePickerDocs.js +5 -0
  406. package/es/components/date-picker/DatePickerDocs.js.map +1 -1
  407. package/es/components/date-picker/DatePickerPortal.d.ts +9 -0
  408. package/es/components/date-picker/DatePickerPortal.js +52 -0
  409. package/es/components/date-picker/DatePickerPortal.js.map +1 -0
  410. package/es/components/date-picker/style/dnb-date-picker.css +64 -55
  411. package/es/components/date-picker/style/dnb-date-picker.min.css +1 -1
  412. package/es/components/date-picker/style/dnb-date-picker.scss +90 -75
  413. package/es/components/form-row/FormRow.js +2 -7
  414. package/es/components/form-row/FormRow.js.map +1 -1
  415. package/es/components/form-row/style/dnb-form-row.css +3 -3
  416. package/es/components/form-row/style/dnb-form-row.min.css +1 -1
  417. package/es/components/form-status/FormStatus.js +17 -19
  418. package/es/components/form-status/FormStatus.js.map +1 -1
  419. package/es/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  420. package/es/components/height-animation/HeightAnimationInstance.js +26 -1
  421. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  422. package/es/components/input-masked/InputMasked.d.ts +1 -1
  423. package/es/components/input-masked/InputMasked.js +2 -2
  424. package/es/components/input-masked/InputMasked.js.map +1 -1
  425. package/es/components/input-masked/InputMaskedDocs.js +1 -1
  426. package/es/components/input-masked/InputMaskedDocs.js.map +1 -1
  427. package/es/components/input-masked/InputMaskedHooks.js +1 -1
  428. package/es/components/input-masked/InputMaskedHooks.js.map +1 -1
  429. package/es/components/input-masked/InputMaskedUtils.js +1 -1
  430. package/es/components/input-masked/InputMaskedUtils.js.map +1 -1
  431. package/es/components/input-masked/style/dnb-input-masked.css +3 -3
  432. package/es/components/input-masked/style/dnb-input-masked.min.css +1 -1
  433. package/es/components/pagination/Pagination.d.ts +12 -0
  434. package/es/components/pagination/Pagination.js +7 -3
  435. package/es/components/pagination/Pagination.js.map +1 -1
  436. package/es/components/pagination/PaginationBar.d.ts +2 -1
  437. package/es/components/pagination/PaginationBar.js +10 -3
  438. package/es/components/pagination/PaginationBar.js.map +1 -1
  439. package/es/components/radio/style/dnb-radio.css +3 -3
  440. package/es/components/radio/style/dnb-radio.min.css +1 -1
  441. package/es/components/space/style/dnb-space.css +4 -4
  442. package/es/components/space/style/dnb-space.min.css +1 -1
  443. package/es/components/space/style/dnb-space.scss +2 -12
  444. package/es/components/space/style/space-mixins.scss +21 -0
  445. package/es/components/tabs/Tabs.d.ts +1 -1
  446. package/es/components/tabs/Tabs.js +4 -12
  447. package/es/components/tabs/Tabs.js.map +1 -1
  448. package/es/components/toggle-button/ToggleButton.d.ts +9 -5
  449. package/es/components/toggle-button/ToggleButton.js +2 -0
  450. package/es/components/toggle-button/ToggleButton.js.map +1 -1
  451. package/es/components/toggle-button/ToggleButtonDocs.d.ts +2 -0
  452. package/es/components/toggle-button/ToggleButtonDocs.js +80 -0
  453. package/es/components/toggle-button/ToggleButtonDocs.js.map +1 -0
  454. package/es/components/toggle-button/ToggleButtonGroup.d.ts +21 -6
  455. package/es/components/toggle-button/ToggleButtonGroupDocs.d.ts +2 -0
  456. package/es/components/toggle-button/ToggleButtonGroupDocs.js +83 -0
  457. package/es/components/toggle-button/ToggleButtonGroupDocs.js.map +1 -0
  458. package/es/components/toggle-button/style/dnb-toggle-button.css +3 -3
  459. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  460. package/es/elements/blockquote/style/blockquote-mixins.scss +5 -3
  461. package/es/elements/code/style/code-mixins.scss +2 -3
  462. package/es/elements/hr/style/hr-mixins.scss +2 -3
  463. package/es/elements/img/style/img-mixins.scss +3 -3
  464. package/es/elements/lists/style/lists-mixins.scss +3 -6
  465. package/es/elements/typography/style/typography-mixins.scss +2 -3
  466. package/es/extensions/forms/DataContext/Context.d.ts +15 -4
  467. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  468. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +1 -1
  469. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  470. package/es/extensions/forms/DataContext/Provider/Provider.js +27 -16
  471. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  472. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  473. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  474. package/es/extensions/forms/Field/Date/Date.js +5 -4
  475. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  476. package/es/extensions/forms/Field/Expiry/Expiry.js +4 -3
  477. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  478. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js +7 -7
  479. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  480. package/es/extensions/forms/Field/Number/Number.js +2 -2
  481. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  482. package/es/extensions/forms/Field/Option/Option.d.ts +2 -1
  483. package/es/extensions/forms/Field/Option/Option.js +2 -12
  484. package/es/extensions/forms/Field/Option/Option.js.map +1 -1
  485. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +10 -5
  486. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  487. package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +4 -3
  488. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +12 -4
  489. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  490. package/es/extensions/forms/Field/Selection/Selection.d.ts +8 -1
  491. package/es/extensions/forms/Field/Selection/Selection.js +22 -14
  492. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  493. package/es/extensions/forms/Field/Selection/SelectionDocs.js +5 -0
  494. package/es/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  495. package/es/extensions/forms/Field/Slider/Slider.js +4 -3
  496. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -1
  497. package/es/extensions/forms/Field/String/String.js +2 -2
  498. package/es/extensions/forms/Field/String/String.js.map +1 -1
  499. package/es/extensions/forms/Field/Toggle/Toggle.js +14 -4
  500. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  501. package/es/extensions/forms/Field/Upload/Upload.js +21 -20
  502. package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
  503. package/es/extensions/forms/FieldBlock/FieldBlock.js +14 -38
  504. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  505. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  506. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  507. package/es/extensions/forms/Form/Isolation/Isolation.js +17 -3
  508. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  509. package/es/extensions/forms/Form/MainHeading/MainHeadingDocs.d.ts +2 -0
  510. package/es/extensions/forms/Form/MainHeading/MainHeadingDocs.js +20 -0
  511. package/es/extensions/forms/Form/MainHeading/MainHeadingDocs.js.map +1 -0
  512. package/es/extensions/forms/Form/Section/EditContainer/CancelButton.js +7 -18
  513. package/es/extensions/forms/Form/Section/EditContainer/CancelButton.js.map +1 -1
  514. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +0 -10
  515. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  516. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +1 -12
  517. package/es/extensions/forms/Form/SubHeading/SubHeadingDocs.d.ts +2 -0
  518. package/es/extensions/forms/Form/SubHeading/SubHeadingDocs.js +20 -0
  519. package/es/extensions/forms/Form/SubHeading/SubHeadingDocs.js.map +1 -0
  520. package/es/extensions/forms/Form/Visibility/Visibility.d.ts +11 -1
  521. package/es/extensions/forms/Form/Visibility/Visibility.js +20 -11
  522. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  523. package/es/extensions/forms/Form/Visibility/VisibilityContext.d.ts +2 -0
  524. package/es/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -1
  525. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  526. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  527. package/es/extensions/forms/Form/Visibility/useVisibility.js +18 -9
  528. package/es/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  529. package/es/extensions/forms/Form/data-context/useValidation.d.ts +2 -1
  530. package/es/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  531. package/es/extensions/forms/Iterate/Array/Array.js +47 -28
  532. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  533. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +14 -4
  534. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  535. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +2 -1
  536. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  537. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +2 -0
  538. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -1
  539. package/es/extensions/forms/Iterate/Array/types.d.ts +8 -3
  540. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  541. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +5 -15
  542. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  543. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +9 -1
  544. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -1
  545. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +1 -3
  546. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  547. package/es/extensions/forms/Iterate/ItemNo/useIItemNo.d.ts +5 -0
  548. package/es/extensions/forms/Iterate/ItemNo/useIItemNo.js +41 -0
  549. package/es/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +1 -0
  550. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +2 -0
  551. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  552. package/es/extensions/forms/Iterate/PushButton/PushButton.d.ts +1 -0
  553. package/es/extensions/forms/Iterate/PushButton/PushButton.js +17 -15
  554. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  555. package/es/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  556. package/es/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  557. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +17 -1
  558. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +34 -18
  559. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  560. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +1 -0
  561. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -1
  562. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  563. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  564. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +7 -6
  565. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  566. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +3 -2
  567. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  568. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js +1 -0
  569. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -1
  570. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -3
  571. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  572. package/es/extensions/forms/Iterate/Visibility/Visibility.d.ts +7 -0
  573. package/es/extensions/forms/Iterate/Visibility/Visibility.js +11 -0
  574. package/es/extensions/forms/Iterate/Visibility/Visibility.js.map +1 -0
  575. package/es/extensions/forms/Iterate/Visibility/index.d.ts +2 -0
  576. package/es/extensions/forms/Iterate/Visibility/index.js +3 -0
  577. package/es/extensions/forms/Iterate/Visibility/index.js.map +1 -0
  578. package/es/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  579. package/es/extensions/forms/Iterate/hooks/index.js +1 -0
  580. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -1
  581. package/es/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +1 -3
  582. package/es/extensions/forms/Iterate/hooks/useArrayLimit.js +1 -3
  583. package/es/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -1
  584. package/es/extensions/forms/Iterate/hooks/useItemPath.d.ts +4 -0
  585. package/es/extensions/forms/Iterate/hooks/useItemPath.js +16 -0
  586. package/es/extensions/forms/Iterate/hooks/useItemPath.js.map +1 -0
  587. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +1 -3
  588. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +1 -3
  589. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -1
  590. package/es/extensions/forms/Iterate/index.d.ts +1 -0
  591. package/es/extensions/forms/Iterate/index.js +1 -0
  592. package/es/extensions/forms/Iterate/index.js.map +1 -1
  593. package/es/extensions/forms/Iterate/style/dnb-iterate.css +16 -0
  594. package/es/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -1
  595. package/es/extensions/forms/Iterate/style/dnb-iterate.scss +25 -2
  596. package/es/extensions/forms/Tools/GenerateSchema.js +12 -6
  597. package/es/extensions/forms/Tools/GenerateSchema.js.map +1 -1
  598. package/es/extensions/forms/Tools/ListAllProps.js +9 -5
  599. package/es/extensions/forms/Tools/ListAllProps.js.map +1 -1
  600. package/es/extensions/forms/Tools/Log.js +2 -1
  601. package/es/extensions/forms/Tools/Log.js.map +1 -1
  602. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js +4 -4
  603. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  604. package/es/extensions/forms/Value/Selection/Selection.js +5 -5
  605. package/es/extensions/forms/Value/Selection/Selection.js.map +1 -1
  606. package/es/extensions/forms/ValueBlock/ValueBlock.js +26 -9
  607. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  608. package/es/extensions/forms/ValueBlock/style/dnb-value-block.css +6 -1
  609. package/es/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  610. package/es/extensions/forms/ValueBlock/style/dnb-value-block.scss +22 -10
  611. package/es/extensions/forms/Wizard/Container/WizardContainer.js +6 -3
  612. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  613. package/es/extensions/forms/Wizard/Container/useHandleLayoutEffect.d.ts +2 -1
  614. package/es/extensions/forms/Wizard/Container/useHandleLayoutEffect.js +4 -3
  615. package/es/extensions/forms/Wizard/Container/useHandleLayoutEffect.js.map +1 -1
  616. package/es/extensions/forms/hooks/DataValueWritePropsDocs.js +9 -9
  617. package/es/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
  618. package/es/extensions/forms/hooks/useDataValue.d.ts +2 -2
  619. package/es/extensions/forms/hooks/useDataValue.js +4 -8
  620. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  621. package/es/extensions/forms/hooks/useExternalValue.js +2 -2
  622. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  623. package/es/extensions/forms/hooks/useFieldProps.d.ts +8 -2
  624. package/es/extensions/forms/hooks/useFieldProps.js +163 -76
  625. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  626. package/es/extensions/forms/hooks/usePath.js +2 -2
  627. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  628. package/es/extensions/forms/hooks/useValueProps.js +5 -5
  629. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  630. package/es/extensions/forms/style/dnb-forms.css +25 -14
  631. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  632. package/es/extensions/forms/types.d.ts +33 -6
  633. package/es/extensions/forms/types.js.map +1 -1
  634. package/es/extensions/forms/utils/json-pointer/json-pointer.js +6 -0
  635. package/es/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
  636. package/es/extensions/payment-card/PaymentCard.js +3 -12
  637. package/es/extensions/payment-card/PaymentCard.js.map +1 -1
  638. package/es/fragments/drawer-list/DrawerList.d.ts +4 -2
  639. package/es/fragments/drawer-list/DrawerList.js +33 -47
  640. package/es/fragments/drawer-list/DrawerList.js.map +1 -1
  641. package/es/fragments/drawer-list/DrawerListDocs.js +3 -3
  642. package/es/fragments/drawer-list/DrawerListDocs.js.map +1 -1
  643. package/es/fragments/drawer-list/style/dnb-drawer-list.scss +1 -1
  644. package/es/shared/AlignmentHelper.js +0 -4
  645. package/es/shared/AlignmentHelper.js.map +1 -1
  646. package/es/shared/Eufemia.d.ts +1 -1
  647. package/es/shared/Eufemia.js +2 -2
  648. package/es/shared/Eufemia.js.map +1 -1
  649. package/es/shared/component-helper.js +2 -1
  650. package/es/shared/component-helper.js.map +1 -1
  651. package/es/style/core/scopes.scss +1 -1
  652. package/es/style/core/utilities.scss +3 -12
  653. package/es/style/dnb-ui-basis.css +1 -1
  654. package/es/style/dnb-ui-basis.min.css +1 -1
  655. package/es/style/dnb-ui-body.css +1 -1
  656. package/es/style/dnb-ui-body.min.css +1 -1
  657. package/es/style/dnb-ui-components.css +106 -86
  658. package/es/style/dnb-ui-components.min.css +4 -4
  659. package/es/style/dnb-ui-core.css +1 -1
  660. package/es/style/dnb-ui-core.min.css +1 -1
  661. package/es/style/dnb-ui-elements.css +151 -31
  662. package/es/style/dnb-ui-elements.min.css +1 -1
  663. package/es/style/dnb-ui-extensions.css +25 -14
  664. package/es/style/dnb-ui-extensions.min.css +1 -1
  665. package/es/style/dnb-ui-forms.css +25 -14
  666. package/es/style/dnb-ui-forms.min.css +1 -1
  667. package/es/style/dnb-ui-fragments.css +1 -1
  668. package/es/style/dnb-ui-fragments.min.css +1 -1
  669. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +151 -31
  670. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  671. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +131 -100
  672. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  673. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +151 -31
  674. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  675. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +25 -14
  676. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  677. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +25 -14
  678. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  679. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +151 -31
  680. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  681. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +131 -100
  682. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +4 -4
  683. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +151 -31
  684. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  685. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +25 -14
  686. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  687. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +25 -14
  688. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  689. package/es/style/themes/theme-ui/ui-theme-basis.css +151 -31
  690. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  691. package/es/style/themes/theme-ui/ui-theme-components.css +131 -100
  692. package/es/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  693. package/es/style/themes/theme-ui/ui-theme-elements.css +151 -31
  694. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  695. package/es/style/themes/theme-ui/ui-theme-extensions.css +25 -14
  696. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  697. package/es/style/themes/theme-ui/ui-theme-forms.css +25 -14
  698. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  699. package/es/style/themes/theme-ui/ui-theme-tags.css +100 -19
  700. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  701. package/esm/dnb-ui-basis.min.mjs +1 -1
  702. package/esm/dnb-ui-components.min.mjs +1 -1
  703. package/esm/dnb-ui-elements.min.mjs +1 -1
  704. package/esm/dnb-ui-extensions.min.mjs +5 -5
  705. package/esm/dnb-ui-lib.min.mjs +1 -1
  706. package/extensions/forms/DataContext/Context.d.ts +15 -4
  707. package/extensions/forms/DataContext/Context.js.map +1 -1
  708. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +1 -1
  709. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  710. package/extensions/forms/DataContext/Provider/Provider.js +28 -17
  711. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  712. package/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  713. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  714. package/extensions/forms/Field/Date/Date.js +5 -4
  715. package/extensions/forms/Field/Date/Date.js.map +1 -1
  716. package/extensions/forms/Field/Expiry/Expiry.js +4 -3
  717. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  718. package/extensions/forms/Field/Indeterminate/useDependencePaths.js +7 -7
  719. package/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  720. package/extensions/forms/Field/Number/Number.js +2 -2
  721. package/extensions/forms/Field/Number/Number.js.map +1 -1
  722. package/extensions/forms/Field/Option/Option.d.ts +2 -1
  723. package/extensions/forms/Field/Option/Option.js +2 -13
  724. package/extensions/forms/Field/Option/Option.js.map +1 -1
  725. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +10 -5
  726. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  727. package/extensions/forms/Field/Provider/useFieldProvider.d.ts +4 -3
  728. package/extensions/forms/Field/SelectCountry/SelectCountry.js +12 -4
  729. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  730. package/extensions/forms/Field/Selection/Selection.d.ts +8 -1
  731. package/extensions/forms/Field/Selection/Selection.js +19 -12
  732. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  733. package/extensions/forms/Field/Selection/SelectionDocs.js +5 -0
  734. package/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  735. package/extensions/forms/Field/Slider/Slider.js +4 -3
  736. package/extensions/forms/Field/Slider/Slider.js.map +1 -1
  737. package/extensions/forms/Field/String/String.js +2 -2
  738. package/extensions/forms/Field/String/String.js.map +1 -1
  739. package/extensions/forms/Field/Toggle/Toggle.js +14 -4
  740. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  741. package/extensions/forms/Field/Upload/Upload.js +21 -21
  742. package/extensions/forms/Field/Upload/Upload.js.map +1 -1
  743. package/extensions/forms/FieldBlock/FieldBlock.js +14 -38
  744. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  745. package/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  746. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  747. package/extensions/forms/Form/Isolation/Isolation.js +17 -3
  748. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  749. package/extensions/forms/Form/MainHeading/MainHeadingDocs.d.ts +2 -0
  750. package/extensions/forms/Form/MainHeading/MainHeadingDocs.js +20 -0
  751. package/extensions/forms/Form/MainHeading/MainHeadingDocs.js.map +1 -0
  752. package/extensions/forms/Form/Section/EditContainer/CancelButton.js +7 -18
  753. package/extensions/forms/Form/Section/EditContainer/CancelButton.js.map +1 -1
  754. package/extensions/forms/Form/Section/style/dnb-form-section.css +0 -10
  755. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  756. package/extensions/forms/Form/Section/style/dnb-form-section.scss +1 -12
  757. package/extensions/forms/Form/SubHeading/SubHeadingDocs.d.ts +2 -0
  758. package/extensions/forms/Form/SubHeading/SubHeadingDocs.js +20 -0
  759. package/extensions/forms/Form/SubHeading/SubHeadingDocs.js.map +1 -0
  760. package/extensions/forms/Form/Visibility/Visibility.d.ts +11 -1
  761. package/extensions/forms/Form/Visibility/Visibility.js +20 -11
  762. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  763. package/extensions/forms/Form/Visibility/VisibilityContext.d.ts +2 -0
  764. package/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -1
  765. package/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  766. package/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  767. package/extensions/forms/Form/Visibility/useVisibility.js +18 -9
  768. package/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  769. package/extensions/forms/Form/data-context/useValidation.d.ts +2 -1
  770. package/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  771. package/extensions/forms/Iterate/Array/Array.js +50 -30
  772. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  773. package/extensions/forms/Iterate/Array/ArrayDocs.js +14 -4
  774. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  775. package/extensions/forms/Iterate/Array/ArrayItemArea.js +2 -1
  776. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  777. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +2 -0
  778. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -1
  779. package/extensions/forms/Iterate/Array/types.d.ts +8 -3
  780. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  781. package/extensions/forms/Iterate/EditContainer/CancelButton.js +5 -15
  782. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  783. package/extensions/forms/Iterate/EditContainer/DoneButton.js +9 -1
  784. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -1
  785. package/extensions/forms/Iterate/EditContainer/EditContainer.js +1 -3
  786. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  787. package/extensions/forms/Iterate/ItemNo/useIItemNo.d.ts +5 -0
  788. package/extensions/forms/Iterate/ItemNo/useIItemNo.js +42 -0
  789. package/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +1 -0
  790. package/extensions/forms/Iterate/IterateItemContext.d.ts +2 -0
  791. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  792. package/extensions/forms/Iterate/PushButton/PushButton.d.ts +1 -0
  793. package/extensions/forms/Iterate/PushButton/PushButton.js +17 -15
  794. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  795. package/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  796. package/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  797. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +17 -1
  798. package/extensions/forms/Iterate/PushContainer/PushContainer.js +34 -18
  799. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  800. package/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +1 -0
  801. package/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -1
  802. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  803. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  804. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +7 -6
  805. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  806. package/extensions/forms/Iterate/Toolbar/Toolbar.js +3 -2
  807. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  808. package/extensions/forms/Iterate/ViewContainer/EditButton.js +1 -0
  809. package/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -1
  810. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -3
  811. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  812. package/extensions/forms/Iterate/Visibility/Visibility.d.ts +7 -0
  813. package/extensions/forms/Iterate/Visibility/Visibility.js +11 -0
  814. package/extensions/forms/Iterate/Visibility/Visibility.js.map +1 -0
  815. package/extensions/forms/Iterate/Visibility/index.d.ts +2 -0
  816. package/extensions/forms/Iterate/Visibility/index.js +3 -0
  817. package/extensions/forms/Iterate/Visibility/index.js.map +1 -0
  818. package/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  819. package/extensions/forms/Iterate/hooks/index.js +1 -0
  820. package/extensions/forms/Iterate/hooks/index.js.map +1 -1
  821. package/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +1 -3
  822. package/extensions/forms/Iterate/hooks/useArrayLimit.js +1 -4
  823. package/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -1
  824. package/extensions/forms/Iterate/hooks/useItemPath.d.ts +4 -0
  825. package/extensions/forms/Iterate/hooks/useItemPath.js +16 -0
  826. package/extensions/forms/Iterate/hooks/useItemPath.js.map +1 -0
  827. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +1 -3
  828. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +1 -4
  829. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -1
  830. package/extensions/forms/Iterate/index.d.ts +1 -0
  831. package/extensions/forms/Iterate/index.js +1 -0
  832. package/extensions/forms/Iterate/index.js.map +1 -1
  833. package/extensions/forms/Iterate/style/dnb-iterate.css +16 -0
  834. package/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -1
  835. package/extensions/forms/Iterate/style/dnb-iterate.scss +25 -2
  836. package/extensions/forms/Tools/GenerateSchema.js +15 -9
  837. package/extensions/forms/Tools/GenerateSchema.js.map +1 -1
  838. package/extensions/forms/Tools/ListAllProps.js +11 -7
  839. package/extensions/forms/Tools/ListAllProps.js.map +1 -1
  840. package/extensions/forms/Tools/Log.js +2 -1
  841. package/extensions/forms/Tools/Log.js.map +1 -1
  842. package/extensions/forms/Value/ArraySelection/ArraySelection.js +4 -4
  843. package/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  844. package/extensions/forms/Value/Selection/Selection.js +5 -5
  845. package/extensions/forms/Value/Selection/Selection.js.map +1 -1
  846. package/extensions/forms/ValueBlock/ValueBlock.js +27 -9
  847. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  848. package/extensions/forms/ValueBlock/style/dnb-value-block.css +6 -1
  849. package/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  850. package/extensions/forms/ValueBlock/style/dnb-value-block.scss +22 -10
  851. package/extensions/forms/Wizard/Container/WizardContainer.js +6 -3
  852. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  853. package/extensions/forms/Wizard/Container/useHandleLayoutEffect.d.ts +2 -1
  854. package/extensions/forms/Wizard/Container/useHandleLayoutEffect.js +4 -3
  855. package/extensions/forms/Wizard/Container/useHandleLayoutEffect.js.map +1 -1
  856. package/extensions/forms/hooks/DataValueWritePropsDocs.js +9 -9
  857. package/extensions/forms/hooks/DataValueWritePropsDocs.js.map +1 -1
  858. package/extensions/forms/hooks/useDataValue.d.ts +2 -2
  859. package/extensions/forms/hooks/useDataValue.js +5 -9
  860. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  861. package/extensions/forms/hooks/useExternalValue.js +2 -2
  862. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  863. package/extensions/forms/hooks/useFieldProps.d.ts +8 -2
  864. package/extensions/forms/hooks/useFieldProps.js +164 -76
  865. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  866. package/extensions/forms/hooks/usePath.js +2 -2
  867. package/extensions/forms/hooks/usePath.js.map +1 -1
  868. package/extensions/forms/hooks/useValueProps.js +5 -5
  869. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  870. package/extensions/forms/style/dnb-forms.css +25 -14
  871. package/extensions/forms/style/dnb-forms.min.css +1 -1
  872. package/extensions/forms/types.d.ts +33 -6
  873. package/extensions/forms/types.js.map +1 -1
  874. package/extensions/forms/utils/json-pointer/json-pointer.js +6 -0
  875. package/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
  876. package/extensions/payment-card/PaymentCard.js +3 -12
  877. package/extensions/payment-card/PaymentCard.js.map +1 -1
  878. package/fragments/drawer-list/DrawerList.d.ts +4 -2
  879. package/fragments/drawer-list/DrawerList.js +33 -47
  880. package/fragments/drawer-list/DrawerList.js.map +1 -1
  881. package/fragments/drawer-list/DrawerListDocs.js +3 -3
  882. package/fragments/drawer-list/DrawerListDocs.js.map +1 -1
  883. package/fragments/drawer-list/style/dnb-drawer-list.scss +1 -1
  884. package/package.json +1 -1
  885. package/shared/AlignmentHelper.js +0 -4
  886. package/shared/AlignmentHelper.js.map +1 -1
  887. package/shared/Eufemia.d.ts +1 -1
  888. package/shared/Eufemia.js +2 -2
  889. package/shared/Eufemia.js.map +1 -1
  890. package/shared/component-helper.js +2 -1
  891. package/shared/component-helper.js.map +1 -1
  892. package/style/core/scopes.scss +1 -1
  893. package/style/core/utilities.scss +3 -12
  894. package/style/dnb-ui-basis.css +1 -1
  895. package/style/dnb-ui-basis.min.css +1 -1
  896. package/style/dnb-ui-body.css +1 -1
  897. package/style/dnb-ui-body.min.css +1 -1
  898. package/style/dnb-ui-components.css +106 -86
  899. package/style/dnb-ui-components.min.css +4 -4
  900. package/style/dnb-ui-core.css +1 -1
  901. package/style/dnb-ui-core.min.css +1 -1
  902. package/style/dnb-ui-elements.css +151 -31
  903. package/style/dnb-ui-elements.min.css +1 -1
  904. package/style/dnb-ui-extensions.css +25 -14
  905. package/style/dnb-ui-extensions.min.css +1 -1
  906. package/style/dnb-ui-forms.css +25 -14
  907. package/style/dnb-ui-forms.min.css +1 -1
  908. package/style/dnb-ui-fragments.css +1 -1
  909. package/style/dnb-ui-fragments.min.css +1 -1
  910. package/style/themes/theme-eiendom/eiendom-theme-basis.css +151 -31
  911. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  912. package/style/themes/theme-eiendom/eiendom-theme-components.css +131 -100
  913. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  914. package/style/themes/theme-eiendom/eiendom-theme-elements.css +151 -31
  915. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  916. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +25 -14
  917. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  918. package/style/themes/theme-eiendom/eiendom-theme-forms.css +25 -14
  919. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  920. package/style/themes/theme-sbanken/sbanken-theme-basis.css +151 -31
  921. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  922. package/style/themes/theme-sbanken/sbanken-theme-components.css +131 -100
  923. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +4 -4
  924. package/style/themes/theme-sbanken/sbanken-theme-elements.css +151 -31
  925. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  926. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +25 -14
  927. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  928. package/style/themes/theme-sbanken/sbanken-theme-forms.css +25 -14
  929. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  930. package/style/themes/theme-ui/ui-theme-basis.css +151 -31
  931. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  932. package/style/themes/theme-ui/ui-theme-components.css +131 -100
  933. package/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  934. package/style/themes/theme-ui/ui-theme-elements.css +151 -31
  935. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  936. package/style/themes/theme-ui/ui-theme-extensions.css +25 -14
  937. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  938. package/style/themes/theme-ui/ui-theme-forms.css +25 -14
  939. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  940. package/style/themes/theme-ui/ui-theme-tags.css +100 -19
  941. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  942. package/umd/dnb-ui-basis.min.js +1 -1
  943. package/umd/dnb-ui-components.min.js +1 -1
  944. package/umd/dnb-ui-elements.min.js +1 -1
  945. package/umd/dnb-ui-extensions.min.js +3 -3
  946. package/umd/dnb-ui-lib.min.js +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"FieldBlock.js","names":["React","useMemo","useContext","useCallback","useRef","useReducer","useEffect","classnames","FieldBlockContext","DataContext","IterateElementContext","Space","FormLabel","FormStatus","Ul","Li","convertJsxToString","findElementInChildren","useId","HelpButtonInline","HelpButtonInlineContent","SubmitIndicator","createSharedState","useTranslation","FormError","states","FieldBlock","props","_props$id","dataContext","fieldBlockContext","nestedFieldBlockContext","disableStatusSummary","id","forId","sharedData","_Object$assign","Object","assign","data","className","layout","layoutOptions","composition","label","labelProp","labelDescription","labelSuffix","labelSrOnly","help","asFieldset","required","info","warning","error","errorProp","fieldState","disabled","width","contentWidth","labelHeight","align","labelSize","contentClassName","children","rest","_objectWithoutProperties","_excluded","hasCustomWidth","test","String","hasCustomContentWidth","iterateItemContext","index","iterateIndex","blockId","wasUpdated","forceUpdate","mountedFieldsRef","fieldStateRef","stateRecordRef","fieldStateIdsRef","contentsRef","hasInitiallyErrorProp","Boolean","optionalLabelSuffix","Field","labelSuffixText","content","undefined","replace","includes","isValidElement","createElement","Fragment","setInternalRecord","stateId","identifier","type","current","existingIndex","findIndex","item","_objectSpread","push","setBlockRecord","setFieldState","showFieldError","show","map","showInitially","statusContent","statesWithMessages","entries","flatMap","reduce","acc","cur","existing","find","messages","getMessagesFromError","message","state","width_element","no_animation","process","env","NODE_ENV","globalThis","IS_TEST","found","msg","filter","i","arr","length","CombineMessages","mainClasses","gridClasses","enableFieldset","useEnableFieldset","labelProps","element","srOnly","space","size","mainStyle","_lO$minWidth","_lO$maxWidth","style","lO","min","getFieldWidth","minWidth","max","maxWidth","prerenderFieldProps","hasLabelDescription","isFragment","fragmentHasChildren","fragmentHasOnlyUndefinedChildren","hasHelp","title","Provider","value","hasErrorProp","_extends","contentId","breakout","outset","parseFloat","ref","showLabel","result","count","child","_child$props","_child$type","translations","errorSummary","stateSummary","key","Array","isArray","errors","Error","toString","fragment","Children","isUndefined","toArray","every","_supportsSpacingProps"],"sources":["../../../../../src/extensions/forms/FieldBlock/FieldBlock.tsx"],"sourcesContent":["import React, {\n useMemo,\n useContext,\n useCallback,\n useRef,\n useReducer,\n useEffect,\n} from 'react'\nimport classnames from 'classnames'\nimport FieldBlockContext, {\n StateWithMessage,\n StatesWithMessages,\n FieldErrorIdsRef,\n MountedFieldsRef,\n StateRecord,\n StateMessage,\n StateTypes,\n StatusContent,\n FieldBlockContextProps,\n StateBasis,\n} from './FieldBlockContext'\nimport DataContext from '../DataContext/Context'\nimport IterateElementContext from '../Iterate/IterateItemContext'\nimport { Space, FormLabel, FormStatus } from '../../../components'\nimport { Ul, Li } from '../../../elements'\nimport {\n convertJsxToString,\n findElementInChildren,\n} from '../../../shared/component-helper'\nimport useId from '../../../shared/helpers/useId'\nimport {\n ComponentProps,\n FieldProps,\n SubmitState,\n Identifier,\n} from '../types'\nimport type { FormLabelAllProps } from '../../../components/FormLabel'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n HelpProps,\n} from '../../../components/help-button/HelpButtonInline'\nimport SubmitIndicator from '../Form/SubmitIndicator/SubmitIndicator'\nimport { createSharedState } from '../../../shared/helpers/useSharedState'\nimport useTranslation from '../hooks/useTranslation'\nimport { FormError } from '../utils'\n\nexport const states: Array<StateTypes> = ['error', 'info', 'warning']\n\n/**\n * The width of a field block\n */\nexport type CustomWidth = `${number}rem`\nexport type FieldBlockWidth =\n | false\n | 'small'\n | 'medium'\n | 'large'\n | 'stretch'\n | CustomWidth\nexport type FieldBlockHorizontalLabelWidth =\n | 'small'\n | 'medium'\n | 'large'\n | CustomWidth\nexport type FieldBlockHorizontalLabelHeight =\n | 'default'\n | 'small'\n | 'medium'\n | 'large'\n\nexport type SharedFieldBlockProps = {\n /**\n * The layout of the field block\n */\n layout?: 'vertical' | 'horizontal'\n /** Use this to set additional options for the layout */\n layoutOptions?: {\n width?: FieldBlockHorizontalLabelWidth\n minWidth?: FieldBlockHorizontalLabelWidth\n maxWidth?: FieldBlockHorizontalLabelWidth\n }\n /**\n * Main label text for the field\n */\n label?: React.ReactNode\n /**\n * Will append an additional text to the label, like \"(optional)\" or \"(recommended)\"\n */\n labelSuffix?: React.ReactNode\n /**\n * A more discreet text displayed beside the label\n */\n labelDescription?: React.ReactNode\n /**\n * Width of outer block element\n */\n width?: FieldBlockWidth\n /**\n * Width of contents block, while label etc can be wider if space is available\n */\n contentWidth?: FieldBlockWidth\n /**\n * Provide help content for the field.\n */\n help?: HelpProps\n}\n\nexport type Props = SharedFieldBlockProps &\n Pick<\n FieldProps,\n keyof ComponentProps | 'info' | 'warning' | 'error' | 'disabled'\n > & {\n /** The id to link a element with */\n forId?: string\n /** Use true if you have more than one form element */\n asFieldset?: boolean\n /** use `true` to make the label only readable by screen readers. */\n labelSrOnly?: boolean\n /** Defines the layout of nested fields */\n composition?: FieldBlockContextProps['composition']\n /** For composition only: Align the contents vertically */\n align?: 'center' | 'bottom'\n /** Class name for the contents block */\n contentClassName?: string\n /** To show the SubmitIndicator during async validation */\n fieldState?: SubmitState\n /** Typography size */\n labelSize?: 'medium' | 'large'\n /** Defines the height of an component (size prop), so the label can be aligned correctly */\n labelHeight?: FieldBlockHorizontalLabelHeight\n /** Disable the error summary for this field block */\n disableStatusSummary?: boolean\n /** For internal use only */\n required?: boolean\n children?: React.ReactNode\n } & React.HTMLAttributes<HTMLDivElement>\n\nfunction FieldBlock(props: Props) {\n const dataContext = useContext(DataContext)\n const fieldBlockContext = useContext(FieldBlockContext)\n const nestedFieldBlockContext = !fieldBlockContext?.disableStatusSummary\n ? fieldBlockContext\n : null\n\n const id = useId(props.id ?? props.forId)\n const sharedData = createSharedState<Props>('field-block-props-' + id)\n const {\n className,\n forId,\n layout = 'vertical',\n layoutOptions,\n composition,\n label: labelProp,\n labelDescription,\n labelSuffix,\n labelSrOnly,\n help,\n asFieldset,\n required,\n info,\n warning,\n error: errorProp,\n disableStatusSummary,\n fieldState,\n disabled,\n width,\n contentWidth,\n labelHeight,\n align,\n labelSize,\n contentClassName,\n children,\n ...rest\n } = Object.assign({}, sharedData.data, props)\n const hasCustomWidth = /\\d(rem)$/.test(String(width))\n const hasCustomContentWidth = /\\d(rem)$/.test(String(contentWidth))\n\n const iterateItemContext = useContext(IterateElementContext)\n const { index: iterateIndex } = iterateItemContext ?? {}\n\n const blockId = useId(props.id)\n const [wasUpdated, forceUpdate] = useReducer(() => ({}), {})\n const mountedFieldsRef = useRef<MountedFieldsRef>({})\n const fieldStateRef = useRef<SubmitState>(null)\n const stateRecordRef = useRef<StateRecord>({})\n const fieldStateIdsRef = useRef<FieldErrorIdsRef>(null)\n const contentsRef = useRef<HTMLDivElement>(null)\n const hasInitiallyErrorProp = useMemo(() => {\n return Boolean(errorProp)\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n const { optionalLabelSuffix } = useTranslation().Field\n const labelSuffixText = useMemo(() => {\n if (required === false || typeof labelSuffix !== 'undefined') {\n return labelSuffix ?? optionalLabelSuffix\n }\n return ''\n }, [required, labelSuffix, optionalLabelSuffix])\n\n const label = useMemo(() => {\n let content = labelProp\n\n if (iterateIndex !== undefined) {\n content = convertJsxToString(labelProp).replace(\n '{itemNo}',\n String(iterateIndex + 1)\n )\n }\n\n if (labelSuffixText) {\n if (convertJsxToString(content).includes(optionalLabelSuffix)) {\n return content\n }\n\n if (typeof content === 'string') {\n return content + ' ' + labelSuffixText\n }\n\n if (React.isValidElement(content)) {\n return (\n <>\n {content}\n {' '}\n {labelSuffixText}\n </>\n )\n }\n }\n\n return content\n }, [iterateIndex, labelProp, labelSuffixText, optionalLabelSuffix])\n\n const setInternalRecord = useCallback((props: StateBasis) => {\n const { stateId, identifier, type } = props\n\n if (!stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = []\n }\n\n fieldStateIdsRef.current = { error: null, warning: null, info: null }\n\n const existingIndex = stateRecordRef.current[identifier].findIndex(\n (item) => {\n return item.stateId === stateId && item.type === type\n }\n )\n\n if (existingIndex > -1) {\n stateRecordRef.current[identifier][existingIndex] = {\n ...stateRecordRef.current[identifier][existingIndex],\n ...props,\n }\n } else {\n stateRecordRef.current[identifier].push(props)\n }\n }, [])\n\n const setBlockRecord = useCallback(\n (props: StateBasis) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.setBlockRecord(props)\n return\n }\n\n setInternalRecord(props)\n\n forceUpdate()\n },\n [nestedFieldBlockContext, setInternalRecord]\n )\n\n const setFieldState = useCallback(\n (identifier: Identifier, fieldState: SubmitState) => {\n if (fieldState !== fieldStateRef.current) {\n fieldStateRef.current = fieldState\n\n forceUpdate()\n }\n },\n []\n )\n\n const showFieldError = useCallback(\n (identifier: Identifier, show: boolean) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.showFieldError(identifier, show)\n return\n }\n\n if (stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = stateRecordRef.current[\n identifier\n ].map((item) => {\n if (item.showInitially) {\n return item\n }\n\n return {\n ...item,\n show,\n }\n })\n\n forceUpdate()\n }\n },\n [nestedFieldBlockContext]\n )\n\n const statusContent = useMemo(() => {\n if (typeof errorProp !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: hasInitiallyErrorProp,\n type: 'error',\n content: errorProp,\n })\n }\n\n if (typeof warning !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'warning',\n content: warning,\n })\n }\n\n if (typeof info !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'info',\n content: info,\n })\n }\n\n const statesWithMessages: Array<StatesWithMessages> =\n // 1. Prepare the states for later use\n Object.entries(stateRecordRef.current)\n .flatMap(([identifier, states]) =>\n states.map((props) => {\n return {\n identifier,\n ...props,\n }\n })\n )\n\n // 2. Take states and group the same type together\n .reduce((acc, cur) => {\n const existing = acc.find((item) => {\n return item.type === cur.type\n })\n\n const messages = getMessagesFromError(cur).map((message) => {\n return {\n ...cur,\n message,\n }\n })\n\n if (existing) {\n existing.messages.push(...messages)\n } else {\n acc.push({\n ...cur,\n content: undefined,\n messages,\n })\n }\n\n return acc\n }, [] as Array<StatesWithMessages>)\n\n // 3. Return the grouped states/messages\n return states.reduce((acc, type) => {\n const id = `${props.id || forId || blockId}-form-status--${type}`\n acc[type] = {\n id,\n label,\n state: type === 'warning' ? 'warn' : type,\n width_element: contentsRef,\n\n // Enable animation only in the browser and not in tests\n no_animation:\n process.env.NODE_ENV === 'test'\n ? true\n : typeof globalThis !== 'undefined'\n ? globalThis.IS_TEST === true\n : false,\n }\n\n const found = statesWithMessages.find((item) => {\n return item.type === type\n })\n\n if (found?.messages) {\n // Hide/remove messages that should be hidden and are not marked as to be shown initially\n const messages = found.messages\n .map((msg) => {\n if (msg.type === 'error') {\n if (!msg.showInitially && !msg.show) {\n msg.message = null\n }\n }\n\n return msg\n })\n .filter(({ message }) => message)\n .reduce((acc, msg, i, arr) => {\n const existingIndex = arr.findIndex((item) => {\n return (\n convertJsxToString(item.message) ===\n convertJsxToString(msg.message)\n )\n })\n\n // Remove duplicates, use the first found message\n if (existingIndex === i) {\n acc.push(msg)\n }\n\n return acc\n }, [])\n\n // Combine the messages and put them in an ul/li list\n if (messages.length > 0) {\n acc[type] = {\n ...acc[type],\n children: <CombineMessages type={type} messages={messages} />,\n }\n\n fieldStateIdsRef.current[type] = id\n } else {\n fieldStateIdsRef.current[type] = undefined\n }\n }\n\n return acc\n }, {}) as StatusContent\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n info,\n warning,\n errorProp,\n nestedFieldBlockContext,\n setInternalRecord,\n blockId,\n wasUpdated, // wasUpdated is needed to get the current errors\n ])\n\n // Handle the error prop from outside\n useEffect(() => {\n if (!nestedFieldBlockContext) {\n showFieldError(blockId, Boolean(errorProp))\n }\n }, [errorProp, blockId, showFieldError, nestedFieldBlockContext])\n\n useEffect(\n () => () => {\n mountedFieldsRef.current = {}\n stateRecordRef.current = {}\n },\n []\n )\n\n const mainClasses = classnames(\n 'dnb-forms-field-block',\n width &&\n `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`,\n contentWidth &&\n `dnb-forms-field-block--content-width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`,\n composition && 'dnb-forms-field-block__composition',\n composition &&\n `dnb-forms-field-block__composition--${\n composition === true ? 'horizontal' : composition\n }`,\n className\n )\n const gridClasses = classnames(\n 'dnb-forms-field-block__grid',\n `dnb-forms-field-block--layout-${layout}`\n )\n\n // A child component with a label was found, use fieldset/legend instead of div/label\n const enableFieldset = useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n })\n\n const labelProps: FormLabelAllProps = {\n className: 'dnb-forms-field-block__label',\n element: enableFieldset ? 'legend' : 'label',\n forId: enableFieldset ? undefined : forId,\n srOnly: labelSrOnly,\n space: 0, // Use CSS for spacing, but we need to reset space for doing so\n size: labelSize,\n disabled,\n }\n\n const mainStyle = useMemo(() => {\n const style: React.CSSProperties = {}\n\n if (hasCustomWidth) {\n style['--dnb-forms-field-block-width'] = width\n }\n\n if (hasCustomContentWidth) {\n style['--dnb-forms-field-block-content-width'] = contentWidth\n }\n\n const lO = layoutOptions || {}\n const min = getFieldWidth(lO.minWidth ?? lO.width)\n const max = getFieldWidth(lO.maxWidth ?? lO.width)\n\n if (typeof min === 'string') {\n style['--dnb-forms-field-block-layout-width-min'] = min\n }\n if (typeof max === 'string') {\n style['--dnb-forms-field-block-layout-width-max'] = max\n }\n\n return style\n }, [\n contentWidth,\n hasCustomContentWidth,\n hasCustomWidth,\n layoutOptions,\n width,\n ])\n\n if (dataContext?.prerenderFieldProps) {\n return null\n }\n\n const hasLabelDescription = isFragment(labelDescription)\n ? fragmentHasChildren(labelDescription) &&\n !fragmentHasOnlyUndefinedChildren(labelDescription)\n : labelDescription\n const hasHelp = help?.title || help?.content\n\n return (\n <FieldBlockContext.Provider\n value={{\n setBlockRecord,\n setFieldState,\n showFieldError,\n hasErrorProp: Boolean(errorProp),\n fieldStateIdsRef,\n mountedFieldsRef,\n composition,\n disableStatusSummary,\n }}\n >\n <Space\n element={enableFieldset ? 'fieldset' : 'div'} // use fieldset and legend to enhance a11y\n style={mainStyle}\n className={mainClasses}\n {...rest}\n >\n <div className={gridClasses}>\n {(label || labelDescription || hasHelp) && (\n <FormLabel {...labelProps}>\n <span>\n {label && (\n <span className=\"dnb-forms-field-block__label__content\">\n {label}\n </span>\n )}\n\n {hasLabelDescription && (\n <span className=\"dnb-forms-field-block__label__description\">\n {labelDescription}\n </span>\n )}\n\n {hasHelp && (\n <HelpButtonInline contentId={`${id}-help`} help={help} />\n )}\n </span>\n </FormLabel>\n )}\n\n {hasHelp && (\n <HelpButtonInlineContent\n contentId={`${id}-help`}\n className=\"dnb-forms-field-block__help\"\n help={help}\n breakout={\n layout === 'vertical' &&\n !nestedFieldBlockContext?.composition\n }\n outset={layout !== 'horizontal'}\n />\n )}\n\n <div\n className={classnames(\n 'dnb-forms-field-block__status',\n\n // Handle the width of the status messages\n contentWidth &&\n contentWidth !== 'small' &&\n contentWidth !== 'medium' &&\n !(parseFloat(contentWidth) <= 11) &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`\n )}\n >\n <FormStatus {...statusContent?.error} />\n <FormStatus {...statusContent?.warning} />\n <FormStatus {...statusContent?.info} />\n </div>\n\n <div\n className={classnames(\n 'dnb-forms-field-block__contents',\n contentWidth &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n align && `dnb-forms-field-block__contents--align-${align}`,\n contentClassName\n )}\n ref={contentsRef}\n >\n {children}\n </div>\n\n <SubmitIndicator\n state={fieldState ?? fieldStateRef.current}\n showLabel\n className=\"dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap\"\n />\n </div>\n </Space>\n </FieldBlockContext.Provider>\n )\n}\n\nfunction useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n}) {\n return useMemo(() => {\n if (asFieldset === false) {\n return false\n }\n\n let result = asFieldset\n\n if (label && !result && !nestedFieldBlockContext) {\n let count = 0\n\n findElementInChildren(children, (child: React.ReactElement) => {\n if (\n child?.props?.label ||\n child?.type?.['_formElement'] === true\n ) {\n count++\n }\n if (count > 1) {\n return (result = true)\n }\n })\n }\n\n return Boolean(result)\n }, [asFieldset, children, label, nestedFieldBlockContext])\n}\n\nfunction CombineMessages({\n type,\n messages,\n}: {\n type: StateTypes\n messages: Array<StateWithMessage>\n}) {\n const translations = useTranslation().Field\n\n if (messages.length === 1) {\n return <>{messages[0].message}</>\n }\n\n return (\n <>\n {type === 'error'\n ? translations.errorSummary\n : translations.stateSummary}\n <Ul>\n {messages.map(({ message }, i) => {\n return <Li key={i}>{message}</Li>\n })}\n </Ul>\n </>\n )\n}\n\nexport function getMessagesFromError(\n item: Partial<StateWithMessage>\n): Array<StateMessage> {\n const { content } = item\n\n if (content instanceof FormError && Array.isArray(content.errors)) {\n return content.errors.map((error) => {\n return error.message\n })\n }\n\n if (Array.isArray(content)) {\n return content.map((content) => {\n return content instanceof FormError || content instanceof Error\n ? content.message\n : content\n })\n }\n\n if (content instanceof FormError || content instanceof Error) {\n return [content.message as StateMessage]\n }\n\n return [\n ((React.isValidElement(content) ? content : content?.toString()) ||\n content) as StateMessage,\n ]\n}\n\nfunction isFragment(fragment: React.ReactNode) {\n return React.isValidElement(fragment) && fragment.type === React.Fragment\n}\n\nfunction fragmentHasChildren(fragment: React.ReactNode) {\n return (\n React.isValidElement(fragment) &&\n React.Children.count(fragment.props.children) > 0\n )\n}\n\nfunction fragmentHasOnlyUndefinedChildren(fragment: React.ReactNode) {\n const isUndefined = (child) => child === undefined\n\n return (\n React.isValidElement(fragment) &&\n React.Children.toArray(fragment.props.children).every(isUndefined)\n )\n}\n\nFieldBlock._supportsSpacingProps = true\n\nexport default FieldBlock\n\nfunction getFieldWidth(width: FieldBlockHorizontalLabelWidth) {\n switch (width) {\n case 'small':\n return 'var(--forms-field-width--small)'\n case 'medium':\n return 'var(--forms-field-width--medium)'\n case 'large':\n return 'var(--forms-field-width--large)'\n }\n\n return width\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"FieldBlock.js","names":["React","useMemo","useContext","useCallback","useRef","useReducer","useEffect","classnames","FieldBlockContext","DataContext","Space","FormLabel","FormStatus","Ul","Li","convertJsxToString","findElementInChildren","useId","HelpButtonInline","HelpButtonInlineContent","SubmitIndicator","createSharedState","useTranslation","FormError","useIterateItemNo","states","FieldBlock","props","_props$id","dataContext","fieldBlockContext","nestedFieldBlockContext","disableStatusSummary","id","forId","sharedData","_Object$assign","Object","assign","data","className","layout","layoutOptions","composition","label","labelProp","labelDescription","labelSuffix","labelSrOnly","help","asFieldset","required","info","warning","error","errorProp","fieldState","disabled","width","contentWidth","labelHeight","align","labelSize","contentClassName","children","rest","_objectWithoutProperties","_excluded","hasCustomWidth","test","String","hasCustomContentWidth","blockId","salt","forceUpdate","mountedFieldsRef","fieldStateRef","stateRecordRef","fieldStateIdsRef","contentsRef","hasInitiallyErrorProp","Boolean","setInternalRecord","stateId","identifier","type","current","existingIndex","findIndex","item","_objectSpread","push","setBlockRecordNested","setBlockRecord","setFieldState","showFieldError","show","map","showInitially","statusContent","content","statesWithMessages","entries","flatMap","reduce","acc","cur","existing","find","messages","getMessagesFromError","message","undefined","state","width_element","no_animation","process","env","NODE_ENV","globalThis","IS_TEST","found","msg","filter","i","arr","length","createElement","CombineMessages","mainClasses","gridClasses","enableFieldset","useEnableFieldset","labelProps","element","srOnly","space","size","mainStyle","_lO$minWidth","_lO$maxWidth","style","lO","min","getFieldWidth","minWidth","max","maxWidth","prerenderFieldProps","hasLabelDescription","isFragment","fragmentHasChildren","fragmentHasOnlyUndefinedChildren","hasHelp","title","Provider","value","hasErrorProp","_extends","contentId","breakout","outset","parseFloat","ref","showLabel","result","count","child","_child$props","_child$type","translations","Field","Fragment","errorSummary","stateSummary","key","Array","isArray","errors","Error","isValidElement","toString","fragment","Children","isUndefined","toArray","every","_supportsSpacingProps"],"sources":["../../../../../src/extensions/forms/FieldBlock/FieldBlock.tsx"],"sourcesContent":["import React, {\n useMemo,\n useContext,\n useCallback,\n useRef,\n useReducer,\n useEffect,\n} from 'react'\nimport classnames from 'classnames'\nimport FieldBlockContext, {\n StateWithMessage,\n StatesWithMessages,\n FieldErrorIdsRef,\n MountedFieldsRef,\n StateRecord,\n StateMessage,\n StateTypes,\n StatusContent,\n FieldBlockContextProps,\n StateBasis,\n} from './FieldBlockContext'\nimport DataContext from '../DataContext/Context'\nimport { Space, FormLabel, FormStatus } from '../../../components'\nimport { Ul, Li } from '../../../elements'\nimport {\n convertJsxToString,\n findElementInChildren,\n} from '../../../shared/component-helper'\nimport useId from '../../../shared/helpers/useId'\nimport {\n ComponentProps,\n FieldProps,\n SubmitState,\n Identifier,\n} from '../types'\nimport type { FormLabelAllProps } from '../../../components/FormLabel'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n HelpProps,\n} from '../../../components/help-button/HelpButtonInline'\nimport SubmitIndicator from '../Form/SubmitIndicator/SubmitIndicator'\nimport { createSharedState } from '../../../shared/helpers/useSharedState'\nimport useTranslation from '../hooks/useTranslation'\nimport { FormError } from '../utils'\nimport { useIterateItemNo } from '../Iterate/ItemNo/useIItemNo'\n\nexport const states: Array<StateTypes> = ['error', 'info', 'warning']\n\n/**\n * The width of a field block\n */\nexport type CustomWidth = `${number}rem`\nexport type FieldBlockWidth =\n | false\n | 'small'\n | 'medium'\n | 'large'\n | 'stretch'\n | CustomWidth\nexport type FieldBlockHorizontalLabelWidth =\n | 'small'\n | 'medium'\n | 'large'\n | CustomWidth\nexport type FieldBlockHorizontalLabelHeight =\n | 'default'\n | 'small'\n | 'medium'\n | 'large'\n\nexport type SharedFieldBlockProps = {\n /**\n * The layout of the field block\n */\n layout?: 'vertical' | 'horizontal'\n /** Use this to set additional options for the layout */\n layoutOptions?: {\n width?: FieldBlockHorizontalLabelWidth\n minWidth?: FieldBlockHorizontalLabelWidth\n maxWidth?: FieldBlockHorizontalLabelWidth\n }\n /**\n * Main label text for the field\n */\n label?: React.ReactNode\n /**\n * Will append an additional text to the label, like \"(optional)\" or \"(recommended)\"\n */\n labelSuffix?: React.ReactNode\n /**\n * A more discreet text displayed beside the label\n */\n labelDescription?: React.ReactNode\n /**\n * Width of outer block element\n */\n width?: FieldBlockWidth\n /**\n * Width of contents block, while label etc can be wider if space is available\n */\n contentWidth?: FieldBlockWidth\n /**\n * Provide help content for the field.\n */\n help?: HelpProps\n}\n\nexport type Props = SharedFieldBlockProps &\n Pick<\n FieldProps,\n keyof ComponentProps | 'info' | 'warning' | 'error' | 'disabled'\n > & {\n /** The id to link a element with */\n forId?: string\n /** Use true if you have more than one form element */\n asFieldset?: boolean\n /** use `true` to make the label only readable by screen readers. */\n labelSrOnly?: boolean\n /** Defines the layout of nested fields */\n composition?: FieldBlockContextProps['composition']\n /** For composition only: Align the contents vertically */\n align?: 'center' | 'bottom'\n /** Class name for the contents block */\n contentClassName?: string\n /** To show the SubmitIndicator during async validation */\n fieldState?: SubmitState\n /** Typography size */\n labelSize?: 'medium' | 'large'\n /** Defines the height of an component (size prop), so the label can be aligned correctly */\n labelHeight?: FieldBlockHorizontalLabelHeight\n /** Disable the error summary for this field block */\n disableStatusSummary?: boolean\n /** For internal use only */\n required?: boolean\n children?: React.ReactNode\n } & React.HTMLAttributes<HTMLDivElement>\n\nfunction FieldBlock(props: Props) {\n const dataContext = useContext(DataContext)\n const fieldBlockContext = useContext(FieldBlockContext)\n const nestedFieldBlockContext = !fieldBlockContext?.disableStatusSummary\n ? fieldBlockContext\n : null\n\n const id = useId(props.id ?? props.forId)\n const sharedData = createSharedState<Props>('field-block-props-' + id)\n const {\n className,\n forId,\n layout = 'vertical',\n layoutOptions,\n composition,\n label: labelProp,\n labelDescription,\n labelSuffix,\n labelSrOnly,\n help,\n asFieldset,\n required,\n info,\n warning,\n error: errorProp,\n disableStatusSummary,\n fieldState,\n disabled,\n width,\n contentWidth,\n labelHeight,\n align,\n labelSize,\n contentClassName,\n children,\n ...rest\n } = Object.assign({}, sharedData.data, props)\n const hasCustomWidth = /\\d(rem)$/.test(String(width))\n const hasCustomContentWidth = /\\d(rem)$/.test(String(contentWidth))\n\n const blockId = useId(props.id)\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n const mountedFieldsRef = useRef<MountedFieldsRef>({})\n const fieldStateRef = useRef<SubmitState>(null)\n const stateRecordRef = useRef<StateRecord>({})\n const fieldStateIdsRef = useRef<FieldErrorIdsRef>(null)\n const contentsRef = useRef<HTMLDivElement>(null)\n const hasInitiallyErrorProp = useMemo(() => {\n return Boolean(errorProp)\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n const label = useIterateItemNo({\n label: labelProp,\n labelSuffix,\n required,\n })\n\n const setInternalRecord = useCallback((props: StateBasis) => {\n const { stateId, identifier, type } = props\n\n if (!stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = []\n }\n\n fieldStateIdsRef.current = { error: null, warning: null, info: null }\n\n const existingIndex = stateRecordRef.current[identifier].findIndex(\n (item) => {\n return item.stateId === stateId && item.type === type\n }\n )\n\n if (existingIndex > -1) {\n stateRecordRef.current[identifier][existingIndex] = {\n ...stateRecordRef.current[identifier][existingIndex],\n ...props,\n }\n } else {\n stateRecordRef.current[identifier].push(props)\n }\n }, [])\n\n const setBlockRecordNested = nestedFieldBlockContext?.setBlockRecord\n const setBlockRecord = useCallback(\n (props: StateBasis) => {\n if (setBlockRecordNested) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n setBlockRecordNested(props)\n return\n }\n\n setInternalRecord(props)\n\n forceUpdate()\n },\n [setBlockRecordNested, setInternalRecord]\n )\n\n const setFieldState = useCallback(\n (identifier: Identifier, fieldState: SubmitState) => {\n if (fieldState !== fieldStateRef.current) {\n fieldStateRef.current = fieldState\n\n forceUpdate()\n }\n },\n []\n )\n\n const showFieldError = useCallback(\n (identifier: Identifier, show: boolean) => {\n if (nestedFieldBlockContext) {\n // If this FieldBlock is inside another one, forward the call to the outer one\n nestedFieldBlockContext.showFieldError(identifier, show)\n return\n }\n\n if (stateRecordRef.current[identifier]) {\n stateRecordRef.current[identifier] = stateRecordRef.current[\n identifier\n ].map((item) => {\n if (item.showInitially) {\n return item\n }\n\n return {\n ...item,\n show,\n }\n })\n\n forceUpdate()\n }\n },\n [nestedFieldBlockContext]\n )\n\n const statusContent = useMemo(() => {\n if (typeof errorProp !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: hasInitiallyErrorProp,\n type: 'error',\n content: errorProp,\n })\n }\n\n if (typeof warning !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'warning',\n content: warning,\n })\n }\n\n if (typeof info !== 'undefined') {\n setInternalRecord({\n identifier: blockId,\n showInitially: true,\n type: 'info',\n content: info,\n })\n }\n\n const statesWithMessages: Array<StatesWithMessages> =\n // 1. Prepare the states for later use\n Object.entries(stateRecordRef.current)\n .flatMap(([identifier, states]) =>\n states.map((props) => {\n return {\n identifier,\n ...props,\n }\n })\n )\n\n // 2. Take states and group the same type together\n .reduce((acc, cur) => {\n const existing = acc.find((item) => {\n return item.type === cur.type\n })\n\n const messages = getMessagesFromError(cur).map((message) => {\n return {\n ...cur,\n message,\n }\n })\n\n if (existing) {\n existing.messages.push(...messages)\n } else {\n acc.push({\n ...cur,\n content: undefined,\n messages,\n })\n }\n\n return acc\n }, [] as Array<StatesWithMessages>)\n\n // 3. Return the grouped states/messages\n return states.reduce((acc, type) => {\n const id = `${props.id || forId || blockId}-form-status--${type}`\n acc[type] = {\n id,\n label,\n state: type === 'warning' ? 'warn' : type,\n width_element: contentsRef,\n\n // Enable animation only in the browser and not in tests\n no_animation:\n process.env.NODE_ENV === 'test'\n ? true\n : typeof globalThis !== 'undefined'\n ? globalThis.IS_TEST === true\n : false,\n }\n\n const found = statesWithMessages.find((item) => {\n return item.type === type\n })\n\n if (found?.messages) {\n // Hide/remove messages that should be hidden and are not marked as to be shown initially\n const messages = found.messages\n .map((msg) => {\n if (msg.type === 'error') {\n if (!msg.showInitially && !msg.show) {\n msg.message = null\n }\n }\n\n return msg\n })\n .filter(({ message }) => message)\n .reduce((acc, msg, i, arr) => {\n const existingIndex = arr.findIndex((item) => {\n return (\n convertJsxToString(item.message) ===\n convertJsxToString(msg.message)\n )\n })\n\n // Remove duplicates, use the first found message\n if (existingIndex === i) {\n acc.push(msg)\n }\n\n return acc\n }, [])\n\n // Combine the messages and put them in an ul/li list\n if (messages.length > 0) {\n acc[type] = {\n ...acc[type],\n children: <CombineMessages type={type} messages={messages} />,\n }\n\n fieldStateIdsRef.current[type] = id\n } else {\n fieldStateIdsRef.current[type] = undefined\n }\n }\n\n return acc\n }, salt) as StatusContent\n }, [\n errorProp,\n warning,\n info,\n salt,\n setInternalRecord,\n blockId,\n hasInitiallyErrorProp,\n props.id,\n forId,\n label,\n ])\n\n // Handle the error prop from outside\n useEffect(() => {\n if (!nestedFieldBlockContext) {\n showFieldError(blockId, Boolean(errorProp))\n }\n }, [errorProp, blockId, showFieldError, nestedFieldBlockContext])\n\n useEffect(\n () => () => {\n mountedFieldsRef.current = {}\n stateRecordRef.current = {}\n },\n []\n )\n\n const mainClasses = classnames(\n 'dnb-forms-field-block',\n width &&\n `dnb-forms-field-block--width-${hasCustomWidth ? 'custom' : width}`,\n contentWidth &&\n `dnb-forms-field-block--content-width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n labelHeight && `dnb-forms-field-block--label-height-${labelHeight}`,\n composition && 'dnb-forms-field-block__composition',\n composition &&\n `dnb-forms-field-block__composition--${\n composition === true ? 'horizontal' : composition\n }`,\n className\n )\n const gridClasses = classnames(\n 'dnb-forms-field-block__grid',\n `dnb-forms-field-block--layout-${layout}`\n )\n\n // A child component with a label was found, use fieldset/legend instead of div/label\n const enableFieldset = useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n })\n\n const labelProps: FormLabelAllProps = {\n id: `${id}-label`,\n className: 'dnb-forms-field-block__label',\n element: enableFieldset ? 'legend' : 'label',\n forId: enableFieldset ? undefined : forId,\n srOnly: labelSrOnly,\n space: 0, // Use CSS for spacing, but we need to reset space for doing so\n size: labelSize,\n disabled,\n }\n\n const mainStyle = useMemo(() => {\n const style: React.CSSProperties = {}\n\n if (hasCustomWidth) {\n style['--dnb-forms-field-block-width'] = width\n }\n\n if (hasCustomContentWidth) {\n style['--dnb-forms-field-block-content-width'] = contentWidth\n }\n\n const lO = layoutOptions || {}\n const min = getFieldWidth(lO.minWidth ?? lO.width)\n const max = getFieldWidth(lO.maxWidth ?? lO.width)\n\n if (typeof min === 'string') {\n style['--dnb-forms-field-block-layout-width-min'] = min\n }\n if (typeof max === 'string') {\n style['--dnb-forms-field-block-layout-width-max'] = max\n }\n\n return style\n }, [\n contentWidth,\n hasCustomContentWidth,\n hasCustomWidth,\n layoutOptions,\n width,\n ])\n\n if (dataContext?.prerenderFieldProps) {\n return null\n }\n\n const hasLabelDescription = isFragment(labelDescription)\n ? fragmentHasChildren(labelDescription) &&\n !fragmentHasOnlyUndefinedChildren(labelDescription)\n : labelDescription\n const hasHelp = help?.title || help?.content\n\n return (\n <FieldBlockContext.Provider\n value={{\n setBlockRecord,\n setFieldState,\n showFieldError,\n hasErrorProp: Boolean(errorProp),\n fieldStateIdsRef,\n mountedFieldsRef,\n composition,\n disableStatusSummary,\n }}\n >\n <Space\n element={enableFieldset ? 'fieldset' : 'div'} // use fieldset and legend to enhance a11y\n style={mainStyle}\n className={mainClasses}\n {...rest}\n >\n <div className={gridClasses}>\n {(label || labelDescription || hasHelp) && (\n <FormLabel {...labelProps}>\n <span>\n {label && (\n <span className=\"dnb-forms-field-block__label__content\">\n {label}\n </span>\n )}\n\n {hasLabelDescription && (\n <span className=\"dnb-forms-field-block__label__description\">\n {labelDescription}\n </span>\n )}\n\n {hasHelp && (\n <HelpButtonInline contentId={`${id}-help`} help={help} />\n )}\n </span>\n </FormLabel>\n )}\n\n {hasHelp && (\n <HelpButtonInlineContent\n contentId={`${id}-help`}\n className=\"dnb-forms-field-block__help\"\n help={help}\n breakout={\n layout === 'vertical' &&\n !nestedFieldBlockContext?.composition\n }\n outset={layout !== 'horizontal'}\n />\n )}\n\n <div\n className={classnames(\n 'dnb-forms-field-block__status',\n\n // Handle the width of the status messages\n contentWidth &&\n contentWidth !== 'small' &&\n contentWidth !== 'medium' &&\n !(parseFloat(contentWidth) <= 11) &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`\n )}\n >\n <FormStatus {...statusContent?.error} />\n <FormStatus {...statusContent?.warning} />\n <FormStatus {...statusContent?.info} />\n </div>\n\n <div\n className={classnames(\n 'dnb-forms-field-block__contents',\n contentWidth &&\n `dnb-forms-field-block__contents--width-${\n hasCustomContentWidth ? 'custom' : contentWidth\n }`,\n align && `dnb-forms-field-block__contents--align-${align}`,\n contentClassName\n )}\n ref={contentsRef}\n >\n {children}\n </div>\n\n <SubmitIndicator\n state={fieldState ?? fieldStateRef.current}\n showLabel\n className=\"dnb-forms-field-block__indicator dnb-forms-submit-indicator--inline-wrap\"\n />\n </div>\n </Space>\n </FieldBlockContext.Provider>\n )\n}\n\nfunction useEnableFieldset({\n label,\n asFieldset,\n children,\n nestedFieldBlockContext,\n}) {\n return useMemo(() => {\n if (asFieldset === false) {\n return false\n }\n\n let result = asFieldset\n\n if (label && !result && !nestedFieldBlockContext) {\n let count = 0\n\n findElementInChildren(children, (child: React.ReactElement) => {\n if (\n child?.props?.label ||\n child?.type?.['_formElement'] === true\n ) {\n count++\n }\n if (count > 1) {\n return (result = true)\n }\n })\n }\n\n return Boolean(result)\n }, [asFieldset, children, label, nestedFieldBlockContext])\n}\n\nfunction CombineMessages({\n type,\n messages,\n}: {\n type: StateTypes\n messages: Array<StateWithMessage>\n}) {\n const translations = useTranslation().Field\n\n if (messages.length === 1) {\n return <>{messages[0].message}</>\n }\n\n return (\n <>\n {type === 'error'\n ? translations.errorSummary\n : translations.stateSummary}\n <Ul>\n {messages.map(({ message }, i) => {\n return <Li key={i}>{message}</Li>\n })}\n </Ul>\n </>\n )\n}\n\nexport function getMessagesFromError(\n item: Partial<StateWithMessage>\n): Array<StateMessage> {\n const { content } = item\n\n if (content instanceof FormError && Array.isArray(content.errors)) {\n return content.errors.map((error) => {\n return error.message\n })\n }\n\n if (Array.isArray(content)) {\n return content.map((content) => {\n return content instanceof FormError || content instanceof Error\n ? content.message\n : content\n })\n }\n\n if (content instanceof FormError || content instanceof Error) {\n return [content.message as StateMessage]\n }\n\n return [\n ((React.isValidElement(content) ? content : content?.toString()) ||\n content) as StateMessage,\n ]\n}\n\nfunction isFragment(fragment: React.ReactNode) {\n return React.isValidElement(fragment) && fragment.type === React.Fragment\n}\n\nfunction fragmentHasChildren(fragment: React.ReactNode) {\n return (\n React.isValidElement(fragment) &&\n React.Children.count(fragment.props.children) > 0\n )\n}\n\nfunction fragmentHasOnlyUndefinedChildren(fragment: React.ReactNode) {\n const isUndefined = (child) => child === undefined\n\n return (\n React.isValidElement(fragment) &&\n React.Children.toArray(fragment.props.children).every(isUndefined)\n )\n}\n\nFieldBlock._supportsSpacingProps = true\n\nexport default FieldBlock\n\nfunction getFieldWidth(width: FieldBlockHorizontalLabelWidth) {\n switch (width) {\n case 'small':\n return 'var(--forms-field-width--small)'\n case 'medium':\n return 'var(--forms-field-width--medium)'\n case 'large':\n return 'var(--forms-field-width--large)'\n }\n\n return width\n}\n"],"mappings":"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"}
@@ -14,15 +14,15 @@ fieldset.dnb-forms-field-block {
14
14
  fieldset.dnb-forms-field-block:not([class*=space__top]) {
15
15
  margin-top: 0;
16
16
  }
17
- fieldset.dnb-forms-field-block:not([class*=space__right]) {
18
- margin-right: 0;
19
- }
20
17
  fieldset.dnb-forms-field-block:not([class*=space__bottom]) {
21
18
  margin-bottom: 0;
22
19
  }
23
20
  fieldset.dnb-forms-field-block:not([class*=space__left]) {
24
21
  margin-left: 0;
25
22
  }
23
+ fieldset.dnb-forms-field-block:not([class*=space__right]) {
24
+ margin-right: 0;
25
+ }
26
26
 
27
27
  .dnb-forms-field-block {
28
28
  --label-margin: 0.25rem;
@@ -1 +1 @@
1
- :root{--forms-field-width--small:5rem;--forms-field-width--medium:11rem;--forms-field-width--large:21rem}fieldset.dnb-forms-field-block{border:none;padding:0}fieldset.dnb-forms-field-block:not([class*=space__top]){margin-top:0}fieldset.dnb-forms-field-block:not([class*=space__right]){margin-right:0}fieldset.dnb-forms-field-block:not([class*=space__bottom]){margin-bottom:0}fieldset.dnb-forms-field-block:not([class*=space__left]){margin-left:0}.dnb-forms-field-block{--label-margin:0.25rem;--max-width:var(--forms-field-width--large)}.dnb-forms-field-block__grid{display:grid;grid-template-areas:"label" "help" "contents" "indicator" "status";grid-template-columns:minmax(min-content,var(--block-content-width,auto))}.dnb-forms-field-block--label-height-small{--label-margin:0}.dnb-forms-field-block--label-height-medium{--label-margin:0.5rem}.dnb-forms-field-block--label-height-large{--label-margin:0.7rem}.dnb-forms-field-block--width-stretch{flex-grow:1}.dnb-forms-field-block--width-stretch label.dnb-form-label{max-width:none}@media screen and (min-width:25.00625em){.dnb-forms-field-block--width-custom{width:calc(var(--dnb-forms-field-block-width))}.dnb-forms-field-block--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block:not([class*="--content-width"]){--max-width:60ch}.dnb-forms-field-block__label,.dnb-forms-field-block__label.dnb-form-label{align-items:center;display:flex;grid-area:label;margin-right:0;max-width:var(--max-width)}.dnb-forms-field-block__label.dnb-form-label__description,.dnb-forms-field-block__label__description{margin-left:.3em}.dnb-forms-field-block__label.dnb-form-label__content:has(+.dnb-help-button),.dnb-forms-field-block__label.dnb-form-label__description:has(+.dnb-help-button),.dnb-forms-field-block__label__content:has(+.dnb-help-button),.dnb-forms-field-block__label__description:has(+.dnb-help-button){margin-right:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical{flex-wrap:wrap}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical>.dnb-form-label{margin-bottom:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__label{margin-right:1rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:var(--label-margin);margin-top:var(--label-margin)}@media screen and (max-width:40em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:calc(var(--label-margin) + .5rem)}}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal{grid-template-areas:"label contents" ". help" ". indicator" ". status";grid-template-columns:minmax(var(--dnb-forms-field-block-layout-width-min,min-content),var(--dnb-forms-field-block-layout-width-max,max-content)) auto}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content{--help-button-indent-width:0}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content .dnb-section{--rounded-corner:0.25rem;align-self:flex-start}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__contents{align-self:end}}.dnb-forms-field-block__indicator{grid-area:indicator}.dnb-forms-field-block__help{display:flex;flex-flow:column;grid-area:help}.dnb-forms-field-block__help .dnb-section{margin-bottom:1rem}.dnb-forms-field-block__help .dnb-section>.dnb-p--lead{margin-bottom:.5rem}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__help .dnb-section{margin-bottom:0;margin-top:.5rem}}.dnb-forms-field-block__status{grid-area:status}.dnb-forms-field-block__status .dnb-form-status__shell{margin-top:.5rem;max-width:60ch}@media screen and (max-width:15em){.dnb-forms-field-block__status{width:90%}}.dnb-forms-field-block__contents{display:flex;grid-area:contents;width:100%}.dnb-forms-field-block__contents--width-stretch{width:100%}@media screen and (min-width:25.00625em){.dnb-forms-field-block__contents--width-custom{width:calc(var(--dnb-forms-field-block-content-width))}.dnb-forms-field-block__contents--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block__contents--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block__contents--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block__composition--vertical .dnb-forms-field-block__contents{display:flex;flex-flow:column;row-gap:var(--spacing-x-small)}.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{-moz-column-gap:var(--spacing-small);column-gap:var(--spacing-small);display:flex;flex-flow:row}@media screen and (min-width:25.00625em){.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{align-items:flex-end}.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents[class*=align-center]{align-items:center}}@media screen and (max-width:25em){.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{flex-flow:column;row-gap:var(--spacing-x-small)}.dnb-forms-field-block__composition>.dnb-forms-field-block__grid>.dnb-forms-submit-indicator{display:none}}@media screen and (min-width:25.00625em){.dnb-forms-field-block__composition>.dnb-forms-field-block__grid>.dnb-forms-field-block__contents .dnb-forms-submit-indicator{display:none}}
1
+ :root{--forms-field-width--small:5rem;--forms-field-width--medium:11rem;--forms-field-width--large:21rem}fieldset.dnb-forms-field-block{border:none;padding:0}fieldset.dnb-forms-field-block:not([class*=space__top]){margin-top:0}fieldset.dnb-forms-field-block:not([class*=space__bottom]){margin-bottom:0}fieldset.dnb-forms-field-block:not([class*=space__left]){margin-left:0}fieldset.dnb-forms-field-block:not([class*=space__right]){margin-right:0}.dnb-forms-field-block{--label-margin:0.25rem;--max-width:var(--forms-field-width--large)}.dnb-forms-field-block__grid{display:grid;grid-template-areas:"label" "help" "contents" "indicator" "status";grid-template-columns:minmax(min-content,var(--block-content-width,auto))}.dnb-forms-field-block--label-height-small{--label-margin:0}.dnb-forms-field-block--label-height-medium{--label-margin:0.5rem}.dnb-forms-field-block--label-height-large{--label-margin:0.7rem}.dnb-forms-field-block--width-stretch{flex-grow:1}.dnb-forms-field-block--width-stretch label.dnb-form-label{max-width:none}@media screen and (min-width:25.00625em){.dnb-forms-field-block--width-custom{width:calc(var(--dnb-forms-field-block-width))}.dnb-forms-field-block--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block:not([class*="--content-width"]){--max-width:60ch}.dnb-forms-field-block__label,.dnb-forms-field-block__label.dnb-form-label{align-items:center;display:flex;grid-area:label;margin-right:0;max-width:var(--max-width)}.dnb-forms-field-block__label.dnb-form-label__description,.dnb-forms-field-block__label__description{margin-left:.3em}.dnb-forms-field-block__label.dnb-form-label__content:has(+.dnb-help-button),.dnb-forms-field-block__label.dnb-form-label__description:has(+.dnb-help-button),.dnb-forms-field-block__label__content:has(+.dnb-help-button),.dnb-forms-field-block__label__description:has(+.dnb-help-button){margin-right:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical{flex-wrap:wrap}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-vertical>.dnb-form-label{margin-bottom:.5rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__label{margin-right:1rem}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:var(--label-margin);margin-top:var(--label-margin)}@media screen and (max-width:40em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal>.dnb-form-label{margin-bottom:calc(var(--label-margin) + .5rem)}}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal{grid-template-areas:"label contents" ". help" ". indicator" ". status";grid-template-columns:minmax(var(--dnb-forms-field-block-layout-width-min,min-content),var(--dnb-forms-field-block-layout-width-max,max-content)) auto}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content{--help-button-indent-width:0}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-help-button__content .dnb-section{--rounded-corner:0.25rem;align-self:flex-start}.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__contents{align-self:end}}.dnb-forms-field-block__indicator{grid-area:indicator}.dnb-forms-field-block__help{display:flex;flex-flow:column;grid-area:help}.dnb-forms-field-block__help .dnb-section{margin-bottom:1rem}.dnb-forms-field-block__help .dnb-section>.dnb-p--lead{margin-bottom:.5rem}@media screen and (min-width:40.00625em){.dnb-forms-field-block__grid.dnb-forms-field-block--layout-horizontal .dnb-forms-field-block__help .dnb-section{margin-bottom:0;margin-top:.5rem}}.dnb-forms-field-block__status{grid-area:status}.dnb-forms-field-block__status .dnb-form-status__shell{margin-top:.5rem;max-width:60ch}@media screen and (max-width:15em){.dnb-forms-field-block__status{width:90%}}.dnb-forms-field-block__contents{display:flex;grid-area:contents;width:100%}.dnb-forms-field-block__contents--width-stretch{width:100%}@media screen and (min-width:25.00625em){.dnb-forms-field-block__contents--width-custom{width:calc(var(--dnb-forms-field-block-content-width))}.dnb-forms-field-block__contents--width-small{width:var(--forms-field-width--small)}.dnb-forms-field-block__contents--width-medium{width:var(--forms-field-width--medium)}.dnb-forms-field-block__contents--width-large{width:var(--forms-field-width--large)}}.dnb-forms-field-block__composition--vertical .dnb-forms-field-block__contents{display:flex;flex-flow:column;row-gap:var(--spacing-x-small)}.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{-moz-column-gap:var(--spacing-small);column-gap:var(--spacing-small);display:flex;flex-flow:row}@media screen and (min-width:25.00625em){.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{align-items:flex-end}.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents[class*=align-center]{align-items:center}}@media screen and (max-width:25em){.dnb-forms-field-block__composition--horizontal .dnb-forms-field-block__contents{flex-flow:column;row-gap:var(--spacing-x-small)}.dnb-forms-field-block__composition>.dnb-forms-field-block__grid>.dnb-forms-submit-indicator{display:none}}@media screen and (min-width:25.00625em){.dnb-forms-field-block__composition>.dnb-forms-field-block__grid>.dnb-forms-field-block__contents .dnb-forms-submit-indicator{display:none}}
@@ -15,6 +15,7 @@ import IsolationCommitButton from './IsolationCommitButton';
15
15
  import { clearedData } from '../../DataContext/Provider';
16
16
  import structuredClone from '@ungap/structured-clone';
17
17
  function IsolationProvider(props) {
18
+ var _outerContext$addSetS, _outerContext$addSetS2;
18
19
  const {
19
20
  children,
20
21
  onPathChange,
@@ -104,6 +105,14 @@ function IsolationProvider(props) {
104
105
  forceUpdate();
105
106
  onClearProp === null || onClearProp === void 0 ? void 0 : onClearProp();
106
107
  }, [onClearProp]);
108
+ const setShowAllErrorsNested = useCallback(showAllErrors => {
109
+ var _dataContextRef$curre2, _dataContextRef$curre3;
110
+ (_dataContextRef$curre2 = dataContextRef.current) === null || _dataContextRef$curre2 === void 0 ? void 0 : (_dataContextRef$curre3 = _dataContextRef$curre2.setShowAllErrors) === null || _dataContextRef$curre3 === void 0 ? void 0 : _dataContextRef$curre3.call(_dataContextRef$curre2, showAllErrors);
111
+ }, []);
112
+ if (bubbleValidation && !(outerContext !== null && outerContext !== void 0 && (_outerContext$addSetS = outerContext.addSetShowAllErrorsRef) !== null && _outerContext$addSetS !== void 0 && (_outerContext$addSetS2 = _outerContext$addSetS.current) !== null && _outerContext$addSetS2 !== void 0 && _outerContext$addSetS2.includes(setShowAllErrorsNested))) {
113
+ var _outerContext$addSetS3;
114
+ (_outerContext$addSetS3 = outerContext.addSetShowAllErrorsRef) === null || _outerContext$addSetS3 === void 0 ? void 0 : _outerContext$addSetS3.current.push(setShowAllErrorsNested);
115
+ }
107
116
  const providerProps = _objectSpread(_objectSpread({}, props), {}, {
108
117
  [defaultData ? 'defaultData' : 'data']: internalDataRef.current,
109
118
  onPathChange: onPathChangeHandler,
@@ -128,18 +137,23 @@ function BubbleValidation({
128
137
  setMountedFieldState,
129
138
  setFieldError
130
139
  } = outerContext || {};
131
- const dataContext = useContext(DataContext);
140
+ const errors = useContext(DataContext).hasErrors();
132
141
  const id = useId();
133
142
  useEffect(() => {
134
143
  const path = `/${id}`;
135
- const errors = dataContext.hasErrors();
136
144
  if (errors) {
137
145
  setMountedFieldState === null || setMountedFieldState === void 0 ? void 0 : setMountedFieldState(path, {
138
146
  isMounted: true
139
147
  });
140
148
  }
141
149
  setFieldError === null || setFieldError === void 0 ? void 0 : setFieldError(path, errors ? new Error('Form.Isolation') : undefined);
142
- }, [dataContext, id, setFieldError, setMountedFieldState]);
150
+ return () => {
151
+ setFieldError === null || setFieldError === void 0 ? void 0 : setFieldError(path, undefined);
152
+ setMountedFieldState === null || setMountedFieldState === void 0 ? void 0 : setMountedFieldState(path, {
153
+ isMounted: false
154
+ });
155
+ };
156
+ }, [errors, id, setFieldError, setMountedFieldState]);
143
157
  return null;
144
158
  }
145
159
  IsolationProvider.CommitButton = IsolationCommitButton;
@@ -1 +1 @@
1
- {"version":3,"file":"Isolation.js","names":["React","useCallback","useContext","useEffect","useMemo","useReducer","useRef","pointer","extendDeep","isAsync","useId","useDataValue","Context","DataContext","Provider","SectionContext","IsolationCommitButton","clearedData","structuredClone","IsolationProvider","props","children","onPathChange","onCommit","onCommitProp","onClear","onClearProp","transformOnCommit","transformOnCommitProp","commitHandleRef","bubbleValidation","data","defaultData","forceUpdate","internalDataRef","localDataRef","dataContextRef","outerContext","path","pathSection","handlePathChange","handlePathChangeOuter","dataOuter","moveValueToPath","onPathChangeHandler","value","current","set","replace","removeSectionPath","has","get","getMountedData","mounterData","_dataContextRef$curre","mountedFieldsRef","field","isMounted","localData","Object","assign","additionalArgs","_props$path","mountedData","outerData","isolatedData","stop","preventCommit","commitData","result","Array","isArray","providerProps","_objectSpread","isolate","createElement","Consumer","dataContext","handleSubmit","BubbleValidation","setMountedFieldState","setFieldError","id","errors","hasErrors","Error","undefined","CommitButton","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/Isolation.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer, { JsonObject } from '../../utils/json-pointer'\nimport { extendDeep } from '../../../../shared/component-helper'\nimport { isAsync } from '../../../../shared/helpers/isAsync'\nimport useId from '../../../../shared/helpers/useId'\nimport useDataValue from '../../hooks/useDataValue'\nimport {\n Context as DataContext,\n ContextState,\n Provider,\n} from '../../DataContext'\nimport SectionContext from '../Section/SectionContext'\nimport IsolationCommitButton from './IsolationCommitButton'\nimport {\n clearedData,\n type Props as ProviderProps,\n} from '../../DataContext/Provider'\nimport type { OnCommit, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So it's a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type IsolationProviderProps<Data extends JsonObject> = {\n /**\n * Form.Isolation: Will be called when the isolated context is committed.\n */\n onCommit?: OnCommit<Data>\n /**\n * Form.Isolation: Will be called when the form is cleared via Form.clearData\n */\n onClear?: () => void\n /**\n * Form.Isolation: A function that will be called when the isolated context is committed.\n * It will receive the data from the isolated context and the data from the outer context.\n * You can use this to transform the data before it is committed.\n */\n transformOnCommit?: (isolatedData: Data, handlerData: Data) => JsonObject\n /**\n * Prevent the form from being submitted when there are fields with errors inside the Form.Isolation.\n */\n bubbleValidation?: boolean\n /**\n * Used internally by the Form.Isolation component\n */\n path?: Path\n /**\n * Used internally by the Form.Isolation component\n */\n isolate?: boolean\n}\n\nexport type IsolationProps<Data extends JsonObject> = Omit<\n ProviderProps<Data>,\n | 'onSubmit'\n | 'onSubmitRequest'\n | 'onSubmitComplete'\n | 'minimumAsyncBehaviorTime'\n | 'asyncSubmitTimeout'\n | 'scrollTopOnSubmit'\n | 'sessionStorageId'\n | 'globalStatusId'\n> & {\n /**\n * A ref (function) that you can call in order to commit the data programmatically to the outer context.\n */\n commitHandleRef?: React.MutableRefObject<() => void>\n}\n\nfunction IsolationProvider<Data extends JsonObject>(\n props: IsolationProps<Data>\n) {\n const {\n children,\n onPathChange,\n onCommit: onCommitProp,\n onClear: onClearProp,\n transformOnCommit: transformOnCommitProp,\n commitHandleRef,\n bubbleValidation,\n data,\n defaultData,\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n const internalDataRef = useRef<Data>()\n const localDataRef = useRef<Partial<Data>>({})\n const dataContextRef = useRef<ContextState>(null)\n const outerContext = useContext(DataContext)\n const { path: pathSection } = useContext(SectionContext) || {}\n const { handlePathChange: handlePathChangeOuter, data: dataOuter } =\n outerContext || {}\n const { moveValueToPath } = useDataValue()\n\n const onPathChangeHandler = useCallback(\n async (path: Path, value: unknown) => {\n if (localDataRef.current === clearedData) {\n localDataRef.current = {}\n }\n\n pointer.set(localDataRef.current, path, value)\n\n if (pathSection) {\n path = path.replace(pathSection, '')\n }\n\n return await onPathChange?.(path, value)\n },\n [onPathChange, pathSection]\n )\n\n const removeSectionPath = useCallback(\n (data: Data) => {\n return pathSection && pointer.has(data, pathSection)\n ? pointer.get(data, pathSection)\n : data\n },\n [pathSection]\n )\n\n const getMountedData = useCallback((data: Data) => {\n const mounterData = {} as Data\n for (const path in dataContextRef.current?.mountedFieldsRef.current) {\n const field = dataContextRef.current.mountedFieldsRef.current[path]\n if (field.isMounted && pointer.has(data, path)) {\n pointer.set(mounterData, path, pointer.get(data, path))\n }\n }\n return mounterData\n }, [])\n\n useEffect(() => {\n localDataRef.current = getMountedData(internalDataRef.current)\n }, [getMountedData])\n\n // Update the isolated data with the outside context data\n useMemo(() => {\n if (localDataRef.current === clearedData) {\n return // stop here\n }\n\n let localData = data ?? defaultData\n\n if (\n localData &&\n pathSection &&\n !pointer.has(localDataRef.current, pathSection)\n ) {\n localData = moveValueToPath<Data>(pathSection, localData)\n }\n\n internalDataRef.current = Object.assign(\n {},\n localData || dataOuter || {},\n localDataRef.current\n )\n }, [data, defaultData, pathSection, dataOuter, moveValueToPath])\n\n const onCommit: IsolationProps<Data>['onCommit'] = useCallback(\n async (data: Data, additionalArgs) => {\n const mountedData = getMountedData(data)\n const path = props.path ?? '/'\n const outerData =\n props.path && pointer.has(dataOuter, path)\n ? pointer.get(dataOuter, path)\n : dataOuter\n\n localDataRef.current = mountedData\n let isolatedData = structuredClone(mountedData)\n\n if (typeof transformOnCommitProp === 'function') {\n isolatedData = transformOnCommitProp(isolatedData, outerData)\n }\n\n let stop = false\n additionalArgs.preventCommit = () => (stop = true)\n\n const commitData = removeSectionPath(isolatedData)\n const result = isAsync(onCommitProp)\n ? await onCommitProp?.(commitData, additionalArgs)\n : onCommitProp?.(commitData, additionalArgs)\n\n if (stop) {\n return // stop here\n }\n\n // Commit the internal data to the nested context data\n await handlePathChangeOuter?.(\n path,\n Array.isArray(isolatedData)\n ? isolatedData\n : extendDeep({}, outerData, isolatedData)\n )\n\n return result\n },\n [\n getMountedData,\n props.path,\n dataOuter,\n transformOnCommitProp,\n handlePathChangeOuter,\n onCommitProp,\n removeSectionPath,\n ]\n )\n\n const onClear = useCallback(() => {\n localDataRef.current = clearedData\n internalDataRef.current = clearedData as Data\n forceUpdate()\n onClearProp?.()\n }, [onClearProp])\n\n const providerProps: IsolationProps<Data> = {\n ...props,\n [defaultData ? 'defaultData' : 'data']: internalDataRef.current,\n onPathChange: onPathChangeHandler,\n onCommit,\n onClear,\n isolate: true,\n }\n\n return (\n <Provider {...providerProps}>\n <DataContext.Consumer>\n {(dataContext) => {\n dataContextRef.current = dataContext\n\n if (commitHandleRef) {\n commitHandleRef.current = dataContext?.handleSubmit\n }\n\n return children\n }}\n </DataContext.Consumer>\n\n {bubbleValidation && (\n <BubbleValidation outerContext={outerContext} />\n )}\n </Provider>\n )\n}\n\nfunction BubbleValidation({ outerContext }) {\n const { setMountedFieldState, setFieldError } = outerContext || {}\n const dataContext = useContext(DataContext)\n\n const id = useId()\n useEffect(() => {\n const path = `/${id}`\n const errors = dataContext.hasErrors()\n if (errors) {\n setMountedFieldState?.(path, {\n isMounted: true,\n })\n }\n setFieldError?.(path, errors ? new Error('Form.Isolation') : undefined)\n }, [dataContext, id, setFieldError, setMountedFieldState])\n\n return null\n}\n\nIsolationProvider.CommitButton = IsolationCommitButton\nIsolationProvider._supportsSpacingProps = undefined\n\nexport default IsolationProvider\n"],"mappings":"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"}
1
+ {"version":3,"file":"Isolation.js","names":["React","useCallback","useContext","useEffect","useMemo","useReducer","useRef","pointer","extendDeep","isAsync","useId","useDataValue","Context","DataContext","Provider","SectionContext","IsolationCommitButton","clearedData","structuredClone","IsolationProvider","props","_outerContext$addSetS","_outerContext$addSetS2","children","onPathChange","onCommit","onCommitProp","onClear","onClearProp","transformOnCommit","transformOnCommitProp","commitHandleRef","bubbleValidation","data","defaultData","forceUpdate","internalDataRef","localDataRef","dataContextRef","outerContext","path","pathSection","handlePathChange","handlePathChangeOuter","dataOuter","moveValueToPath","onPathChangeHandler","value","current","set","replace","removeSectionPath","has","get","getMountedData","mounterData","_dataContextRef$curre","mountedFieldsRef","field","isMounted","localData","Object","assign","additionalArgs","_props$path","mountedData","outerData","isolatedData","stop","preventCommit","commitData","result","Array","isArray","setShowAllErrorsNested","showAllErrors","_dataContextRef$curre2","_dataContextRef$curre3","setShowAllErrors","call","addSetShowAllErrorsRef","includes","_outerContext$addSetS3","push","providerProps","_objectSpread","isolate","createElement","Consumer","dataContext","handleSubmit","BubbleValidation","setMountedFieldState","setFieldError","errors","hasErrors","id","Error","undefined","CommitButton","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/Isolation.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer, { JsonObject } from '../../utils/json-pointer'\nimport { extendDeep } from '../../../../shared/component-helper'\nimport { isAsync } from '../../../../shared/helpers/isAsync'\nimport useId from '../../../../shared/helpers/useId'\nimport useDataValue from '../../hooks/useDataValue'\nimport {\n Context as DataContext,\n ContextState,\n Provider,\n} from '../../DataContext'\nimport SectionContext from '../Section/SectionContext'\nimport IsolationCommitButton from './IsolationCommitButton'\nimport {\n clearedData,\n type Props as ProviderProps,\n} from '../../DataContext/Provider'\nimport type { OnCommit, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So it's a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type IsolationProviderProps<Data extends JsonObject> = {\n /**\n * Form.Isolation: Will be called when the isolated context is committed.\n */\n onCommit?: OnCommit<Data>\n /**\n * Form.Isolation: Will be called when the form is cleared via Form.clearData\n */\n onClear?: () => void\n /**\n * Form.Isolation: A function that will be called when the isolated context is committed.\n * It will receive the data from the isolated context and the data from the outer context.\n * You can use this to transform the data before it is committed.\n */\n transformOnCommit?: (isolatedData: Data, handlerData: Data) => JsonObject\n /**\n * Prevent the form from being submitted when there are fields with errors inside the Form.Isolation.\n */\n bubbleValidation?: boolean\n /**\n * Used internally by the Form.Isolation component\n */\n path?: Path\n /**\n * Used internally by the Form.Isolation component\n */\n isolate?: boolean\n}\n\nexport type IsolationProps<Data extends JsonObject> = Omit<\n ProviderProps<Data>,\n | 'onSubmit'\n | 'onSubmitRequest'\n | 'onSubmitComplete'\n | 'minimumAsyncBehaviorTime'\n | 'asyncSubmitTimeout'\n | 'scrollTopOnSubmit'\n | 'sessionStorageId'\n | 'globalStatusId'\n> & {\n /**\n * A ref (function) that you can call in order to commit the data programmatically to the outer context.\n */\n commitHandleRef?: React.MutableRefObject<() => void>\n}\n\nfunction IsolationProvider<Data extends JsonObject>(\n props: IsolationProps<Data>\n) {\n const {\n children,\n onPathChange,\n onCommit: onCommitProp,\n onClear: onClearProp,\n transformOnCommit: transformOnCommitProp,\n commitHandleRef,\n bubbleValidation,\n data,\n defaultData,\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n const internalDataRef = useRef<Data>()\n const localDataRef = useRef<Partial<Data>>({})\n const dataContextRef = useRef<ContextState>(null)\n const outerContext = useContext(DataContext)\n const { path: pathSection } = useContext(SectionContext) || {}\n const { handlePathChange: handlePathChangeOuter, data: dataOuter } =\n outerContext || {}\n const { moveValueToPath } = useDataValue()\n\n const onPathChangeHandler = useCallback(\n async (path: Path, value: unknown) => {\n if (localDataRef.current === clearedData) {\n localDataRef.current = {}\n }\n\n // Depending on the usage, we can get a path like so: \"/pushContainerItems/0/somePath\"\n // where \"somePath\" is a frozen object. In order to still be able to modify it,\n // pointer.set will unfreeze the object and then modify it. (Object.isFrozen(obj[tok]))\n\n pointer.set(localDataRef.current, path, value)\n\n if (pathSection) {\n path = path.replace(pathSection, '')\n }\n\n return await onPathChange?.(path, value)\n },\n [onPathChange, pathSection]\n )\n\n const removeSectionPath = useCallback(\n (data: Data) => {\n return pathSection && pointer.has(data, pathSection)\n ? pointer.get(data, pathSection)\n : data\n },\n [pathSection]\n )\n\n const getMountedData = useCallback((data: Data) => {\n const mounterData = {} as Data\n for (const path in dataContextRef.current?.mountedFieldsRef.current) {\n const field = dataContextRef.current.mountedFieldsRef.current[path]\n if (field.isMounted && pointer.has(data, path)) {\n pointer.set(mounterData, path, pointer.get(data, path))\n }\n }\n return mounterData\n }, [])\n\n useEffect(() => {\n localDataRef.current = getMountedData(internalDataRef.current)\n }, [getMountedData])\n\n // Update the isolated data with the outside context data\n useMemo(() => {\n if (localDataRef.current === clearedData) {\n return // stop here\n }\n\n let localData = data ?? defaultData\n\n if (\n localData &&\n pathSection &&\n !pointer.has(localDataRef.current, pathSection)\n ) {\n localData = moveValueToPath<Data>(pathSection, localData)\n }\n\n internalDataRef.current = Object.assign(\n {},\n localData || dataOuter || {},\n localDataRef.current\n )\n }, [data, defaultData, pathSection, dataOuter, moveValueToPath])\n\n const onCommit: IsolationProps<Data>['onCommit'] = useCallback(\n async (data: Data, additionalArgs) => {\n const mountedData = getMountedData(data)\n const path = props.path ?? '/'\n const outerData =\n props.path && pointer.has(dataOuter, path)\n ? pointer.get(dataOuter, path)\n : dataOuter\n\n localDataRef.current = mountedData\n let isolatedData = structuredClone(mountedData)\n\n if (typeof transformOnCommitProp === 'function') {\n isolatedData = transformOnCommitProp(isolatedData, outerData)\n }\n\n let stop = false\n additionalArgs.preventCommit = () => (stop = true)\n\n const commitData = removeSectionPath(isolatedData)\n const result = isAsync(onCommitProp)\n ? await onCommitProp?.(commitData, additionalArgs)\n : onCommitProp?.(commitData, additionalArgs)\n\n if (stop) {\n return // stop here\n }\n\n // Commit the internal data to the nested context data\n await handlePathChangeOuter?.(\n path,\n Array.isArray(isolatedData)\n ? isolatedData\n : extendDeep({}, outerData, isolatedData)\n )\n\n return result\n },\n [\n getMountedData,\n props.path,\n dataOuter,\n transformOnCommitProp,\n handlePathChangeOuter,\n onCommitProp,\n removeSectionPath,\n ]\n )\n\n const onClear = useCallback(() => {\n localDataRef.current = clearedData\n internalDataRef.current = clearedData as Data\n forceUpdate()\n onClearProp?.()\n }, [onClearProp])\n\n const setShowAllErrorsNested = useCallback((showAllErrors: boolean) => {\n dataContextRef.current?.setShowAllErrors?.(showAllErrors)\n }, [])\n\n if (\n bubbleValidation &&\n !outerContext?.addSetShowAllErrorsRef?.current?.includes(\n setShowAllErrorsNested\n )\n ) {\n outerContext.addSetShowAllErrorsRef?.current.push(\n setShowAllErrorsNested\n )\n }\n\n const providerProps: IsolationProps<Data> = {\n ...props,\n [defaultData ? 'defaultData' : 'data']: internalDataRef.current,\n onPathChange: onPathChangeHandler,\n onCommit,\n onClear,\n isolate: true,\n }\n\n return (\n <Provider {...providerProps}>\n <DataContext.Consumer>\n {(dataContext) => {\n dataContextRef.current = dataContext\n\n if (commitHandleRef) {\n commitHandleRef.current = dataContext?.handleSubmit\n }\n\n return children\n }}\n </DataContext.Consumer>\n\n {bubbleValidation && (\n <BubbleValidation outerContext={outerContext} />\n )}\n </Provider>\n )\n}\n\nfunction BubbleValidation({\n outerContext,\n}: {\n outerContext: ContextState\n}) {\n const { setMountedFieldState, setFieldError } = outerContext || {}\n const errors = useContext(DataContext).hasErrors()\n\n const id = useId()\n useEffect(() => {\n const path = `/${id}`\n\n if (errors) {\n setMountedFieldState?.(path, {\n isMounted: true,\n })\n }\n\n setFieldError?.(path, errors ? new Error('Form.Isolation') : undefined)\n\n return () => {\n setFieldError?.(path, undefined)\n setMountedFieldState?.(path, {\n isMounted: false,\n })\n }\n }, [errors, id, setFieldError, setMountedFieldState])\n\n return null\n}\n\nIsolationProvider.CommitButton = IsolationCommitButton\nIsolationProvider._supportsSpacingProps = undefined\n\nexport default IsolationProvider\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { PropertiesTableProps } from '../../../../shared/types';
2
+ export declare const MainHeadingProperties: PropertiesTableProps;
@@ -0,0 +1,20 @@
1
+ import { FieldProperties } from '../../Field/FieldDocs';
2
+ export const MainHeadingProperties = {
3
+ level: {
4
+ doc: 'Define a specific level value to ensure correct level hierarchy. Defaults to `2`.',
5
+ type: 'number',
6
+ status: 'optional'
7
+ },
8
+ help: FieldProperties.help,
9
+ children: {
10
+ doc: 'Heading text / contents.',
11
+ type: 'React.Node',
12
+ status: 'optional'
13
+ },
14
+ '[Space](/uilib/layout/space/properties)': {
15
+ doc: 'Spacing properties like `top` or `bottom` are supported.',
16
+ type: ['string', 'object'],
17
+ status: 'optional'
18
+ }
19
+ };
20
+ //# sourceMappingURL=MainHeadingDocs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MainHeadingDocs.js","names":["FieldProperties","MainHeadingProperties","level","doc","type","status","help","children"],"sources":["../../../../../../src/extensions/forms/Form/MainHeading/MainHeadingDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { FieldProperties } from '../../Field/FieldDocs'\n\nexport const MainHeadingProperties: PropertiesTableProps = {\n level: {\n doc: 'Define a specific level value to ensure correct level hierarchy. Defaults to `2`.',\n type: 'number',\n status: 'optional',\n },\n help: FieldProperties.help,\n children: {\n doc: 'Heading text / contents.',\n type: 'React.Node',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,eAAe,QAAQ,uBAAuB;AAEvD,OAAO,MAAMC,qBAA2C,GAAG;EACzDC,KAAK,EAAE;IACLC,GAAG,EAAE,mFAAmF;IACxFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAEN,eAAe,CAACM,IAAI;EAC1BC,QAAQ,EAAE;IACRJ,GAAG,EAAE,0BAA0B;IAC/BC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -17,30 +17,19 @@ export default function CancelButton() {
17
17
  restoreOriginalData
18
18
  } = useContainerDataStore();
19
19
  const {
20
- switchContainerMode,
21
- initialContainerMode
20
+ switchContainerMode
22
21
  } = useContext(SectionContainerContext) || {};
23
22
  const {
24
- hasVisibleError,
25
- hasSubmitError,
26
- hasError,
27
23
  setShowBoundaryErrors
28
24
  } = useContext(FieldBoundaryContext) || {};
29
25
  const translation = useTranslation().SectionEditContainer;
30
26
  const cancelHandler = useCallback(() => {
31
- if (hasSubmitError || initialContainerMode === 'auto' && hasError) {
32
- setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
33
- if (hasVisibleError) {
34
- setShowError(true);
35
- }
36
- } else {
37
- setShowError(false);
38
- setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
39
- restoreOriginalData();
40
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
41
- onCancel === null || onCancel === void 0 ? void 0 : onCancel();
42
- }
43
- }, [hasError, hasSubmitError, hasVisibleError, initialContainerMode, onCancel, restoreOriginalData, setShowBoundaryErrors, setShowError, switchContainerMode]);
27
+ setShowError(false);
28
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
29
+ restoreOriginalData();
30
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
31
+ onCancel === null || onCancel === void 0 ? void 0 : onCancel();
32
+ }, [onCancel, restoreOriginalData, setShowBoundaryErrors, setShowError, switchContainerMode]);
44
33
  return React.createElement(Button, {
45
34
  variant: "tertiary",
46
35
  icon: close,
@@ -1 +1 @@
1
- {"version":3,"file":"CancelButton.js","names":["React","useCallback","useContext","SectionContainerContext","ToolbarContext","useTranslation","Button","close","useContainerDataStore","FieldBoundaryContext","CancelButton","onCancel","setShowError","restoreOriginalData","switchContainerMode","initialContainerMode","hasVisibleError","hasSubmitError","hasError","setShowBoundaryErrors","translation","SectionEditContainer","cancelHandler","createElement","variant","icon","icon_position","on_click","cancelButton"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport { useTranslation } from '../../../hooks'\nimport { Button } from '../../../../../components'\nimport { close } from '../../../../../icons'\nimport useContainerDataStore from './useContainerDataStore'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport default function CancelButton() {\n const { onCancel, setShowError } = useContext(ToolbarContext) || {}\n const { restoreOriginalData } = useContainerDataStore()\n const { switchContainerMode, initialContainerMode } =\n useContext(SectionContainerContext) || {}\n const {\n hasVisibleError,\n hasSubmitError,\n hasError,\n setShowBoundaryErrors,\n } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().SectionEditContainer\n\n const cancelHandler = useCallback(() => {\n if (hasSubmitError || (initialContainerMode === 'auto' && hasError)) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n restoreOriginalData()\n switchContainerMode?.('view')\n onCancel?.()\n }\n }, [\n hasError,\n hasSubmitError,\n hasVisibleError,\n initialContainerMode,\n onCancel,\n restoreOriginalData,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancelButton}\n </Button>\n )\n}\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,uBAAuB,MAAM,uCAAuC;AAC3E,OAAOC,cAAc,MAAM,2BAA2B;AACtD,SAASC,cAAc,QAAQ,gBAAgB;AAC/C,SAASC,MAAM,QAAQ,2BAA2B;AAClD,SAASC,KAAK,QAAQ,sBAAsB;AAC5C,OAAOC,qBAAqB,MAAM,yBAAyB;AAC3D,OAAOC,oBAAoB,MAAM,yDAAyD;AAE1F,eAAe,SAASC,YAAYA,CAAA,EAAG;EACrC,MAAM;IAAEC,QAAQ;IAAEC;EAAa,CAAC,GAAGV,UAAU,CAACE,cAAc,CAAC,IAAI,CAAC,CAAC;EACnE,MAAM;IAAES;EAAoB,CAAC,GAAGL,qBAAqB,CAAC,CAAC;EACvD,MAAM;IAAEM,mBAAmB;IAAEC;EAAqB,CAAC,GACjDb,UAAU,CAACC,uBAAuB,CAAC,IAAI,CAAC,CAAC;EAC3C,MAAM;IACJa,eAAe;IACfC,cAAc;IACdC,QAAQ;IACRC;EACF,CAAC,GAAGjB,UAAU,CAACO,oBAAoB,CAAC,IAAI,CAAC,CAAC;EAE1C,MAAMW,WAAW,GAAGf,cAAc,CAAC,CAAC,CAACgB,oBAAoB;EAEzD,MAAMC,aAAa,GAAGrB,WAAW,CAAC,MAAM;IACtC,IAAIgB,cAAc,IAAKF,oBAAoB,KAAK,MAAM,IAAIG,QAAS,EAAE;MACnEC,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,IAAI,CAAC;MAC7B,IAAIH,eAAe,EAAE;QACnBJ,YAAY,CAAC,IAAI,CAAC;MACpB;IACF,CAAC,MAAM;MACLA,YAAY,CAAC,KAAK,CAAC;MACnBO,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,KAAK,CAAC;MAC9BN,mBAAmB,CAAC,CAAC;MACrBC,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;MAC7BH,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAG,CAAC;IACd;EACF,CAAC,EAAE,CACDO,QAAQ,EACRD,cAAc,EACdD,eAAe,EACfD,oBAAoB,EACpBJ,QAAQ,EACRE,mBAAmB,EACnBM,qBAAqB,EACrBP,YAAY,EACZE,mBAAmB,CACpB,CAAC;EAEF,OACEd,KAAA,CAAAuB,aAAA,CAACjB,MAAM;IACLkB,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAElB,KAAM;IACZmB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEL;EAAc,GAEvBF,WAAW,CAACQ,YACP,CAAC;AAEb"}
1
+ {"version":3,"file":"CancelButton.js","names":["React","useCallback","useContext","SectionContainerContext","ToolbarContext","useTranslation","Button","close","useContainerDataStore","FieldBoundaryContext","CancelButton","onCancel","setShowError","restoreOriginalData","switchContainerMode","setShowBoundaryErrors","translation","SectionEditContainer","cancelHandler","createElement","variant","icon","icon_position","on_click","cancelButton"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport { useTranslation } from '../../../hooks'\nimport { Button } from '../../../../../components'\nimport { close } from '../../../../../icons'\nimport useContainerDataStore from './useContainerDataStore'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport default function CancelButton() {\n const { onCancel, setShowError } = useContext(ToolbarContext) || {}\n const { restoreOriginalData } = useContainerDataStore()\n const { switchContainerMode } = useContext(SectionContainerContext) || {}\n const { setShowBoundaryErrors } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().SectionEditContainer\n\n const cancelHandler = useCallback(() => {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n restoreOriginalData()\n switchContainerMode?.('view')\n onCancel?.()\n }, [\n onCancel,\n restoreOriginalData,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancelButton}\n </Button>\n )\n}\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,uBAAuB,MAAM,uCAAuC;AAC3E,OAAOC,cAAc,MAAM,2BAA2B;AACtD,SAASC,cAAc,QAAQ,gBAAgB;AAC/C,SAASC,MAAM,QAAQ,2BAA2B;AAClD,SAASC,KAAK,QAAQ,sBAAsB;AAC5C,OAAOC,qBAAqB,MAAM,yBAAyB;AAC3D,OAAOC,oBAAoB,MAAM,yDAAyD;AAE1F,eAAe,SAASC,YAAYA,CAAA,EAAG;EACrC,MAAM;IAAEC,QAAQ;IAAEC;EAAa,CAAC,GAAGV,UAAU,CAACE,cAAc,CAAC,IAAI,CAAC,CAAC;EACnE,MAAM;IAAES;EAAoB,CAAC,GAAGL,qBAAqB,CAAC,CAAC;EACvD,MAAM;IAAEM;EAAoB,CAAC,GAAGZ,UAAU,CAACC,uBAAuB,CAAC,IAAI,CAAC,CAAC;EACzE,MAAM;IAAEY;EAAsB,CAAC,GAAGb,UAAU,CAACO,oBAAoB,CAAC,IAAI,CAAC,CAAC;EAExE,MAAMO,WAAW,GAAGX,cAAc,CAAC,CAAC,CAACY,oBAAoB;EAEzD,MAAMC,aAAa,GAAGjB,WAAW,CAAC,MAAM;IACtCW,YAAY,CAAC,KAAK,CAAC;IACnBG,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,KAAK,CAAC;IAC9BF,mBAAmB,CAAC,CAAC;IACrBC,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;IAC7BH,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAG,CAAC;EACd,CAAC,EAAE,CACDA,QAAQ,EACRE,mBAAmB,EACnBE,qBAAqB,EACrBH,YAAY,EACZE,mBAAmB,CACpB,CAAC;EAEF,OACEd,KAAA,CAAAmB,aAAA,CAACb,MAAM;IACLc,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAEd,KAAM;IACZe,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEL;EAAc,GAEvBF,WAAW,CAACQ,YACP,CAAC;AAEb"}
@@ -11,19 +11,9 @@
11
11
  .dnb-forms-section-block__inner {
12
12
  flex: 1;
13
13
  outline: none;
14
- margin-bottom: var(--space);
15
14
  transition: transform 400ms var(--easing-default) 50ms, box-shadow 0.8s var(--easing-default);
16
15
  transform: translateY(-2.5rem);
17
16
  }
18
- .dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-small) {
19
- --space: var(--spacing-small);
20
- }
21
- .dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-medium) {
22
- --space: var(--spacing-medium);
23
- }
24
- .dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-large) {
25
- --space: var(--spacing-large);
26
- }
27
17
  .dnb-forms-section-block__inner .dnb-dl .dnb-dd {
28
18
  margin-bottom: 0;
29
19
  }
@@ -1 +1 @@
1
- .dnb-forms-section-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-section-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-section-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-section-block__inner{flex:1;margin-bottom:var(--space);outline:none;transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-small){--space:var(--spacing-small)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-medium){--space:var(--spacing-medium)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-large){--space:var(--spacing-large)}.dnb-forms-section-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-section-block--variant-basic{--border-color:transparent}.dnb-card .dnb-forms-section-block--variant-basic .dnb-card,.dnb-forms-section-block--variant-basic .dnb-card{--card-outline-color:transparent}.dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner{--space:var(--spacing-small);background-color:var(--color-lavender)}.dnb-forms-section-block--no-animation .dnb-forms-section-block__inner{transform:translateY(0)}.dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner{transform:translateY(-.5rem)}.dnb-forms-section-block.dnb-height-animation--parallax .dnb-forms-section-block__inner{transform:translateY(0)}
1
+ .dnb-forms-section-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-section-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-section-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-section-block__inner{flex:1;outline:none;transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-section-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-section-block--variant-basic{--border-color:transparent}.dnb-card .dnb-forms-section-block--variant-basic .dnb-card,.dnb-forms-section-block--variant-basic .dnb-card{--card-outline-color:transparent}.dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner{--space:var(--spacing-small);background-color:var(--color-lavender)}.dnb-forms-section-block--no-animation .dnb-forms-section-block__inner{transform:translateY(0)}.dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner{transform:translateY(-.5rem)}.dnb-forms-section-block.dnb-height-animation--parallax .dnb-forms-section-block__inner{transform:translateY(0)}
@@ -13,18 +13,7 @@
13
13
 
14
14
  &__inner {
15
15
  flex: 1;
16
- outline: none; // for JavaSCript focus
17
-
18
- margin-bottom: var(--space);
19
- &:has(.dnb-flex-container--spacing-small) {
20
- --space: var(--spacing-small);
21
- }
22
- &:has(.dnb-flex-container--spacing-medium) {
23
- --space: var(--spacing-medium);
24
- }
25
- &:has(.dnb-flex-container--spacing-large) {
26
- --space: var(--spacing-large);
27
- }
16
+ outline: none; // Because of JavaScript focus management (tabIndex)
28
17
 
29
18
  transition:
30
19
  transform 400ms var(--easing-default) 50ms,
@@ -0,0 +1,2 @@
1
+ import { PropertiesTableProps } from '../../../../shared/types';
2
+ export declare const SubHeadingProperties: PropertiesTableProps;
@@ -0,0 +1,20 @@
1
+ import { FieldProperties } from '../../Field/FieldDocs';
2
+ export const SubHeadingProperties = {
3
+ level: {
4
+ doc: 'Define a specific level value to ensure correct level hierarchy. Defaults to `3`.',
5
+ type: 'number',
6
+ status: 'optional'
7
+ },
8
+ help: FieldProperties.help,
9
+ children: {
10
+ doc: 'Heading text / contents.',
11
+ type: 'React.Node',
12
+ status: 'optional'
13
+ },
14
+ '[Space](/uilib/layout/space/properties)': {
15
+ doc: 'Spacing properties like `top` or `bottom` are supported.',
16
+ type: ['string', 'object'],
17
+ status: 'optional'
18
+ }
19
+ };
20
+ //# sourceMappingURL=SubHeadingDocs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SubHeadingDocs.js","names":["FieldProperties","SubHeadingProperties","level","doc","type","status","help","children"],"sources":["../../../../../../src/extensions/forms/Form/SubHeading/SubHeadingDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { FieldProperties } from '../../Field/FieldDocs'\n\nexport const SubHeadingProperties: PropertiesTableProps = {\n level: {\n doc: 'Define a specific level value to ensure correct level hierarchy. Defaults to `3`.',\n type: 'number',\n status: 'optional',\n },\n help: FieldProperties.help,\n children: {\n doc: 'Heading text / contents.',\n type: 'React.Node',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,eAAe,QAAQ,uBAAuB;AAEvD,OAAO,MAAMC,oBAA0C,GAAG;EACxDC,KAAK,EAAE;IACLC,GAAG,EAAE,mFAAmF;IACxFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAEN,eAAe,CAACM,IAAI;EAC1BC,QAAQ,EAAE;IACRJ,GAAG,EAAE,0BAA0B;IAC/BC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -12,11 +12,19 @@ export type VisibleWhen = {
12
12
  } | {
13
13
  path: Path;
14
14
  isValid: boolean;
15
+ /**
16
+ * @deprecated – Replaced with validateContinuously, continuousValidation can be removed in v11.
17
+ */
15
18
  continuousValidation?: boolean;
19
+ validateContinuously?: boolean;
16
20
  } | {
17
21
  itemPath: Path;
18
22
  isValid: boolean;
23
+ /**
24
+ * @deprecated – Replaced with validateContinuously, continuousValidation can be removed in v11.
25
+ */
19
26
  continuousValidation?: boolean;
27
+ validateContinuously?: boolean;
20
28
  }
21
29
  /**
22
30
  * @deprecated Will be removed in v11!
@@ -70,12 +78,14 @@ export type Props = {
70
78
  fieldPropsWhenHidden?: UseFieldProps & DataAttributes & AriaAttributes;
71
79
  element?: HeightAnimationAllProps['element'];
72
80
  children: React.ReactNode;
81
+ /** For internal use only. Used by "Iterate.Visibility" */
82
+ withinIterate?: boolean;
73
83
  /** @deprecated Use `visibleWhen` instead */
74
84
  pathValue?: string;
75
85
  /** @deprecated Use `visibleWhen` instead */
76
86
  whenValue?: unknown;
77
87
  };
78
- declare function Visibility({ visible, pathDefined, pathUndefined, pathTruthy, pathFalsy, pathTrue, pathFalse, pathValue, whenValue, visibleWhen, visibleWhenNot, inferData, filterData, onVisible, onAnimationEnd, animate, keepInDOM, compensateForGap, fieldPropsWhenHidden, children, ...rest }: Props): import("react/jsx-runtime").JSX.Element;
88
+ declare function Visibility(props: Props): import("react/jsx-runtime").JSX.Element;
79
89
  declare namespace Visibility {
80
90
  var _supportsSpacingProps: string;
81
91
  }