@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":"ArrayItemArea.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateItemContext","_ArrayItemAreaContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","useLayoutEffect","window","React","useEffect","ArrayItemArea","props","forceUpdate","useReducer","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","toolbarVariant","restProps","localContextRef","useRef","hasError","hasSubmitError","useContext","FieldBoundaryContext","current","IterateItemContext","nextFocusElementRef","isNew","determineMode","useCallback","value","initialContainerMode","containerMode","modeOptions","omitFocusManagement","editMode","switchContainerMode","preventUpdate","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","HeightAnimation","classnames","duration","keepInDOM","Card","stack","filled","innerSpace","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, { useCallback, useContext, useReducer, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Card, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\n// SSR warning fix: https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\nconst useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline`, `filled` or `basic`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic' | 'filled'\n toolbarVariant?: 'minimumOneItem' | 'custom'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n toolbarVariant,\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew } = localContextRef.current\n\n const determineMode = useCallback(() => {\n const { value, initialContainerMode } = localContextRef.current\n if (initialContainerMode === 'auto') {\n // - Set the container mode to \"edit\" if we have an error\n if (\n hasSubmitError ||\n hasError ||\n !value ||\n (typeof value === 'object' && Object.keys(value).length === 0)\n ) {\n return 'edit'\n }\n }\n }, [hasError, hasSubmitError])\n\n if (determineMode() === 'edit') {\n localContextRef.current.containerMode = 'edit'\n if (!localContextRef.current.modeOptions) {\n localContextRef.current.modeOptions = {}\n }\n localContextRef.current.modeOptions.omitFocusManagement = true\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n useLayoutEffect(() => {\n if (mode === 'edit') {\n const editMode = determineMode()\n if (editMode) {\n const { switchContainerMode } = localContextRef.current\n switchContainerMode?.(editMode, {\n omitFocusManagement: true,\n preventUpdate: true,\n })\n }\n }\n }, [determineMode, mode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useLayoutEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n setOpenState(false)\n handleRemove?.({ keepItems: true })\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider\n value={{ handleRemoveItem, variant, toolbarVariant }}\n >\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Card\n stack\n filled={variant === 'filled'}\n innerSpace={variant === 'basic' ? false : 'small'}\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n aria-label={ariaLabel}\n >\n {children}\n </Card>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
1
+ {"version":3,"file":"ArrayItemArea.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateItemContext","_ArrayItemAreaContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","useLayoutEffect","window","React","useEffect","ArrayItemArea","props","forceUpdate","useReducer","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","toolbarVariant","restProps","localContextRef","useRef","hasError","hasSubmitError","useContext","FieldBoundaryContext","current","IterateItemContext","nextFocusElementRef","isNew","determineMode","useCallback","value","initialContainerMode","containerMode","modeOptions","omitFocusManagement","editMode","switchContainerMode","preventUpdate","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","divider","HeightAnimation","classnames","duration","keepInDOM","Card","stack","filled","innerSpace","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, { useCallback, useContext, useReducer, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Card, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\n// SSR warning fix: https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\nconst useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline`, `filled` or `basic`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic' | 'filled'\n toolbarVariant?: 'minimumOneItem' | 'custom'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n toolbarVariant,\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew } = localContextRef.current\n\n const determineMode = useCallback(() => {\n const { value, initialContainerMode } = localContextRef.current\n if (initialContainerMode === 'auto') {\n // - Set the container mode to \"edit\" if we have an error\n if (\n hasSubmitError ||\n hasError ||\n !value ||\n (typeof value === 'object' && Object.keys(value).length === 0)\n ) {\n return 'edit'\n }\n }\n }, [hasError, hasSubmitError])\n\n if (determineMode() === 'edit') {\n localContextRef.current.containerMode = 'edit'\n if (!localContextRef.current.modeOptions) {\n localContextRef.current.modeOptions = {}\n }\n localContextRef.current.modeOptions.omitFocusManagement = true\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n useLayoutEffect(() => {\n if (mode === 'edit') {\n const editMode = determineMode()\n if (editMode) {\n const { switchContainerMode } = localContextRef.current\n switchContainerMode?.(editMode, {\n omitFocusManagement: true,\n preventUpdate: true,\n })\n }\n }\n }, [determineMode, mode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useLayoutEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n setOpenState(false)\n handleRemove?.({ keepItems: true })\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider\n value={{\n handleRemoveItem,\n variant,\n toolbarVariant,\n divider: restProps.divider,\n }}\n >\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Card\n stack\n filled={variant === 'filled'}\n innerSpace={variant === 'basic' ? false : 'small'}\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n aria-label={ariaLabel}\n >\n {children}\n </Card>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
@@ -1,9 +1,11 @@
1
1
  /// <reference types="react" />
2
2
  import { ArrayItemAreaProps } from './ArrayItemArea';
3
+ import { BasicProps } from '../../../../components/flex/Container';
3
4
  type ArrayItemAreaContext = {
4
5
  handleRemoveItem?: () => void;
5
6
  variant?: ArrayItemAreaProps['variant'];
6
7
  toolbarVariant?: ArrayItemAreaProps['toolbarVariant'];
8
+ divider?: BasicProps['divider'];
7
9
  };
8
10
  declare const ArrayItemAreaContext: import("react").Context<ArrayItemAreaContext>;
9
11
  export default ArrayItemAreaContext;
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayItemAreaContext.js","names":["_react","require","ArrayItemAreaContext","createContext","_default","exports","default"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemAreaContext.ts"],"sourcesContent":["import { createContext } from 'react'\nimport { ArrayItemAreaProps } from './ArrayItemArea'\n\ntype ArrayItemAreaContext = {\n handleRemoveItem?: () => void\n variant?: ArrayItemAreaProps['variant']\n toolbarVariant?: ArrayItemAreaProps['toolbarVariant']\n}\n\nconst ArrayItemAreaContext = createContext<ArrayItemAreaContext>(null)\n\nexport default ArrayItemAreaContext\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AASA,MAAMC,oBAAoB,GAAG,IAAAC,oBAAa,EAAuB,IAAI,CAAC;AAAA,IAAAC,QAAA,GAEvDF,oBAAoB;AAAAG,OAAA,CAAAC,OAAA,GAAAF,QAAA"}
1
+ {"version":3,"file":"ArrayItemAreaContext.js","names":["_react","require","ArrayItemAreaContext","createContext","_default","exports","default"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemAreaContext.ts"],"sourcesContent":["import { createContext } from 'react'\nimport { ArrayItemAreaProps } from './ArrayItemArea'\nimport { BasicProps } from '../../../../components/flex/Container'\n\ntype ArrayItemAreaContext = {\n handleRemoveItem?: () => void\n variant?: ArrayItemAreaProps['variant']\n toolbarVariant?: ArrayItemAreaProps['toolbarVariant']\n divider?: BasicProps['divider']\n}\n\nconst ArrayItemAreaContext = createContext<ArrayItemAreaContext>(null)\n\nexport default ArrayItemAreaContext\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AAWA,MAAMC,oBAAoB,GAAG,IAAAC,oBAAa,EAAuB,IAAI,CAAC;AAAA,IAAAC,QAAA,GAEvDF,oBAAoB;AAAAG,OAAA,CAAAC,OAAA,GAAAF,QAAA"}
@@ -1,12 +1,14 @@
1
1
  /// <reference types="react" />
2
- import { Path, UseFieldProps, Validator } from '../../types';
2
+ import { DefaultErrorMessages, Path, UseFieldProps, Validator } from '../../types';
3
3
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
4
+ import { IterateItemContextState } from '../IterateItemContext';
4
5
  export type ContainerMode = 'view' | 'edit' | 'auto';
5
6
  export type Value = Array<unknown | Record<string, unknown>>;
6
- export type ElementChild = React.ReactNode | ((value: any, index: number) => React.ReactNode);
7
- export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation'> & {
7
+ export type ElementChild = React.ReactNode | ((value: any, index: number, arrayItems: Array<IterateItemContextState>) => React.ReactNode);
8
+ export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation' | 'validateContinuously'> & {
8
9
  children: ElementChild | Array<ElementChild>;
9
10
  path?: Path;
11
+ itemPath?: Path;
10
12
  limit?: number;
11
13
  countPath?: Path;
12
14
  countPathLimit?: number;
@@ -15,8 +17,11 @@ export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTM
15
17
  animate?: boolean;
16
18
  placeholder?: React.ReactNode;
17
19
  containerMode?: ContainerMode;
20
+ required?: boolean;
21
+ errorMessages?: DefaultErrorMessages;
18
22
  countPathTransform?: (params: {
19
23
  value: any;
20
24
  index: number;
21
25
  }) => any;
26
+ validateValue?: () => void;
22
27
  };
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps, Validator } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n limit?: number\n countPath?: Path\n countPathLimit?: number\n onChangeValidator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import {\n DefaultErrorMessages,\n Path,\n UseFieldProps,\n Validator,\n} from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { IterateItemContextState } from '../IterateItemContext'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((\n value: any,\n index: number,\n arrayItems: Array<IterateItemContextState>\n ) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n | 'validateContinuously'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n itemPath?: Path\n limit?: number\n countPath?: Path\n countPathLimit?: number\n onChangeValidator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n required?: boolean\n errorMessages?: DefaultErrorMessages\n countPathTransform?: (params: { value: any; index: number }) => any\n\n // internal\n validateValue?: () => void\n }\n"],"mappings":""}
@@ -30,14 +30,11 @@ function CancelButton(props) {
30
30
  restoreOriginalValue,
31
31
  switchContainerMode,
32
32
  containerMode,
33
- initialContainerMode,
34
33
  arrayValue,
35
34
  isNew,
36
35
  index
37
36
  } = (0, _react.useContext)(_IterateItemContext.default) || {};
38
37
  const {
39
- hasError,
40
- hasVisibleError,
41
38
  setShowBoundaryErrors
42
39
  } = (0, _react.useContext)(_FieldBoundaryContext.default) || {};
43
40
  const {
@@ -61,18 +58,11 @@ function CancelButton(props) {
61
58
  event
62
59
  } = _ref;
63
60
  onClick === null || onClick === void 0 ? void 0 : onClick(event);
64
- if (hasError && initialContainerMode === 'auto') {
65
- setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
66
- if (hasVisibleError) {
67
- setShowError(true);
68
- }
69
- } else {
70
- restoreOriginalValue === null || restoreOriginalValue === void 0 ? void 0 : restoreOriginalValue(valueBackupRef.current);
71
- setShowError(false);
72
- setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
73
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
74
- }
75
- }, [hasError, hasVisibleError, initialContainerMode, onClick, restoreOriginalValue, setShowBoundaryErrors, setShowError, switchContainerMode]);
61
+ restoreOriginalValue === null || restoreOriginalValue === void 0 ? void 0 : restoreOriginalValue(valueBackupRef.current);
62
+ setShowError(false);
63
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
64
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
65
+ }, [onClick, restoreOriginalValue, setShowBoundaryErrors, setShowError, switchContainerMode]);
76
66
  const wasNew = useWasNew({
77
67
  isNew,
78
68
  containerMode
@@ -1 +1 @@
1
- {"version":3,"file":"CancelButton.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateItemContext","_ToolbarContext","_FieldBoundaryContext","_icons","_RemoveButton","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","CancelButton","props","onClick","rest","restoreOriginalValue","switchContainerMode","containerMode","initialContainerMode","arrayValue","isNew","index","useContext","IterateItemContext","hasError","hasVisibleError","setShowBoundaryErrors","FieldBoundaryContext","setShowError","ToolbarContext","cancelButton","removeButton","useTranslation","IterateEditContainer","valueBackupRef","useRef","useEffect","current","cancelHandler","useCallback","_ref","event","wasNew","useWasNew","createElement","Fragment","text","Button","variant","icon","close","icon_position","on_click","_ref2","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { close } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport RemoveButton, { Props as RemoveButtonProps } from '../RemoveButton'\nimport { ContainerMode } from '../Array'\n\ntype Props = ButtonProps\n\nexport default function CancelButton(props: Props) {\n const { onClick, ...rest } = props\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n initialContainerMode,\n arrayValue,\n isNew,\n index,\n } = useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { cancelButton, removeButton } =\n useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(\n ({ event }: { event: React.MouseEvent<HTMLButtonElement> }) => {\n onClick?.(event)\n if (hasError && initialContainerMode === 'auto') {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n restoreOriginalValue?.(valueBackupRef.current)\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n },\n [\n hasError,\n hasVisibleError,\n initialContainerMode,\n onClick,\n restoreOriginalValue,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ]\n )\n\n const wasNew = useWasNew({ isNew, containerMode })\n\n if (containerMode === 'edit' && arrayValue?.length === 0) {\n return <></>\n }\n\n if (wasNew) {\n return (\n <RemoveButton\n text={removeButton}\n onClick={onClick}\n {...(rest as RemoveButtonProps)}\n />\n )\n }\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n {...rest}\n >\n {cancelButton}\n </Button>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"CancelButton.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateItemContext","_ToolbarContext","_FieldBoundaryContext","_icons","_RemoveButton","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","CancelButton","props","onClick","rest","restoreOriginalValue","switchContainerMode","containerMode","arrayValue","isNew","index","useContext","IterateItemContext","setShowBoundaryErrors","FieldBoundaryContext","setShowError","ToolbarContext","cancelButton","removeButton","useTranslation","IterateEditContainer","valueBackupRef","useRef","useEffect","current","cancelHandler","useCallback","_ref","event","wasNew","useWasNew","createElement","Fragment","text","Button","variant","icon","close","icon_position","on_click","_ref2","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { close } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport RemoveButton, { Props as RemoveButtonProps } from '../RemoveButton'\nimport { ContainerMode } from '../Array'\n\ntype Props = ButtonProps\n\nexport default function CancelButton(props: Props) {\n const { onClick, ...rest } = props\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n arrayValue,\n isNew,\n index,\n } = useContext(IterateItemContext) || {}\n const { setShowBoundaryErrors } = useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { cancelButton, removeButton } =\n useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(\n ({ event }: { event: React.MouseEvent<HTMLButtonElement> }) => {\n onClick?.(event)\n restoreOriginalValue?.(valueBackupRef.current)\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n },\n [\n onClick,\n restoreOriginalValue,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ]\n )\n\n const wasNew = useWasNew({ isNew, containerMode })\n\n if (containerMode === 'edit' && arrayValue?.length === 0) {\n return <></>\n }\n\n if (wasNew) {\n return (\n <RemoveButton\n text={removeButton}\n onClick={onClick}\n {...(rest as RemoveButtonProps)}\n />\n )\n }\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n {...rest}\n >\n {cancelButton}\n </Button>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.default = DoneButton;
8
8
  var _react = _interopRequireWildcard(require("react"));
9
+ var _classnames = _interopRequireDefault(require("classnames"));
9
10
  var _components = require("../../../../components");
10
11
  var _useTranslation = _interopRequireDefault(require("../../hooks/useTranslation"));
11
12
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
@@ -13,11 +14,18 @@ var _ToolbarContext = _interopRequireDefault(require("../Toolbar/ToolbarContext"
13
14
  var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
14
15
  var _PushContainerContext = _interopRequireDefault(require("../PushContainer/PushContainerContext"));
15
16
  var _icons = require("../../../../icons");
17
+ const _excluded = ["className"];
16
18
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
19
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
18
20
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
19
21
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
22
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
23
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
20
24
  function DoneButton(props) {
25
+ const {
26
+ className
27
+ } = props,
28
+ restProps = _objectWithoutProperties(props, _excluded);
21
29
  const {
22
30
  switchContainerMode,
23
31
  containerMode,
@@ -66,9 +74,10 @@ function DoneButton(props) {
66
74
  }, [commitHandleRef, hasError, hasVisibleError, setShowBoundaryErrors, setShowError, switchContainerMode]);
67
75
  return _react.default.createElement(_components.Button, _extends({
68
76
  variant: "tertiary",
77
+ className: (0, _classnames.default)('dnb-push-container__done-button', className),
69
78
  icon: _icons.check,
70
79
  icon_position: "left",
71
80
  on_click: doneHandler
72
- }, props), doneButton);
81
+ }, restProps), doneButton);
73
82
  }
74
83
  //# sourceMappingURL=DoneButton.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DoneButton.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateItemContext","_ToolbarContext","_FieldBoundaryContext","_PushContainerContext","_icons","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","DoneButton","props","switchContainerMode","containerMode","arrayValue","index","useContext","IterateItemContext","hasError","hasVisibleError","setShowBoundaryErrors","FieldBoundaryContext","commitHandleRef","PushContainerContext","setShowError","ToolbarContext","doneButton","useTranslation","IterateEditContainer","valueBackupRef","useRef","useEffect","current","doneHandler","useCallback","_commitHandleRef$curr","createElement","Button","variant","icon","check","icon_position","on_click"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/DoneButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport PushContainerContext from '../PushContainer/PushContainerContext'\nimport { check } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\n\ntype Props = ButtonProps\n\nexport default function DoneButton(props: Props) {\n const { switchContainerMode, containerMode, arrayValue, index } =\n useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { commitHandleRef } = useContext(PushContainerContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { doneButton } = useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowBoundaryErrors?.(false)\n setShowError(false)\n if (commitHandleRef) {\n commitHandleRef.current?.()\n } else {\n switchContainerMode?.('view')\n }\n }\n }, [\n commitHandleRef,\n hasError,\n hasVisibleError,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n return (\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n {...props}\n >\n {doneButton}\n </Button>\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"DoneButton.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_useTranslation","_IterateItemContext","_ToolbarContext","_FieldBoundaryContext","_PushContainerContext","_icons","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","DoneButton","props","className","restProps","switchContainerMode","containerMode","arrayValue","index","useContext","IterateItemContext","hasError","hasVisibleError","setShowBoundaryErrors","FieldBoundaryContext","commitHandleRef","PushContainerContext","setShowError","ToolbarContext","doneButton","useTranslation","IterateEditContainer","valueBackupRef","useRef","useEffect","current","doneHandler","useCallback","_commitHandleRef$curr","createElement","Button","variant","classnames","icon","check","icon_position","on_click"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/DoneButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport PushContainerContext from '../PushContainer/PushContainerContext'\nimport { check } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\n\ntype Props = ButtonProps\n\nexport default function DoneButton(props: Props) {\n const { className, ...restProps } = props\n const { switchContainerMode, containerMode, arrayValue, index } =\n useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { commitHandleRef } = useContext(PushContainerContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { doneButton } = useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowBoundaryErrors?.(false)\n setShowError(false)\n if (commitHandleRef) {\n commitHandleRef.current?.()\n } else {\n switchContainerMode?.('view')\n }\n }\n }, [\n commitHandleRef,\n hasError,\n hasVisibleError,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n return (\n <Button\n variant=\"tertiary\"\n className={classnames('dnb-push-container__done-button', className)}\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n {...restProps}\n >\n {doneButton}\n </Button>\n )\n}\n"],"mappings":"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"}
@@ -73,9 +73,7 @@ function EditContainerWithoutToolbar(props) {
73
73
  const itemTitle = (0, _react.useMemo)(() => {
74
74
  return (0, _ItemNo.replaceItemNo)(wasNew && titleWhenNew ? titleWhenNew : title, index);
75
75
  }, [index, title, titleWhenNew, wasNew]);
76
- (0, _hooks.useSwitchContainerMode)({
77
- path
78
- });
76
+ (0, _hooks.useSwitchContainerMode)(path);
79
77
  return _react.default.createElement(_ArrayItemArea.default, _extends({
80
78
  mode: "edit",
81
79
  className: (0, _classnames.default)('dnb-forms-section-edit-block', className),
@@ -1 +1 @@
1
- {"version":3,"file":"EditContainer.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_componentHelper","_elements","_IterateItemContext","_ArrayItemArea","_Toolbar2","_hooks","_DoneButton","_CancelButton","_ItemNo","_Toolbar","_excluded","_excluded2","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","EditContainer","props","_toolbarElement","toolbar","toolbarVariant","children","rest","arrayValue","useContext","IterateItemContext","toolbarElement","createElement","Fragment","hasToolbar","React","Children","toArray","some","child","Toolbar","EditContainerWithoutToolbar","containerMode","isNew","index","path","_ref","className","title","titleWhenNew","restProps","wasNew","useWasNew","itemTitle","useMemo","replaceItemNo","useSwitchContainerMode","mode","classnames","ariaLabel","convertJsxToString","Lead","size","DoneButton","CancelButton","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Lead } from '../../../../elements'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport IterateItemContext from '../IterateItemContext'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport Toolbar from '../Toolbar'\nimport { useSwitchContainerMode } from '../hooks'\nimport DoneButton from './DoneButton'\nimport CancelButton, { useWasNew } from './CancelButton'\nimport { replaceItemNo } from '../ItemNo'\n\nexport type Props = {\n /**\n * The title of the EditContainer.\n */\n title?: React.ReactNode\n\n /**\n * The title for a new item show within the EditContainer.\n */\n titleWhenNew?: React.ReactNode\n\n /**\n * If the EditContainer is open or not.\n */\n open?: boolean\n\n /**\n * An alternative toolbar to be shown in the EditContainer.\n */\n toolbar?: React.ReactNode\n\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: ArrayItemAreaProps['toolbarVariant']\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nexport default function EditContainer(props: AllProps) {\n const { toolbar, toolbarVariant, children, ...rest } = props\n const { arrayValue } = useContext(IterateItemContext)\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = <></>\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <EditContainerWithoutToolbar\n toolbar={\n hasToolbar\n ? null\n : toolbarElement ??\n (toolbarVariant !== 'custom' && (\n <Toolbar>\n <DoneButton />\n <CancelButton />\n </Toolbar>\n ))\n }\n toolbarVariant={toolbarVariant}\n {...rest}\n >\n {children}\n </EditContainerWithoutToolbar>\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const { containerMode, isNew, index, path } =\n useContext(IterateItemContext)\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n toolbarVariant,\n ...restProps\n } = props || {}\n\n const wasNew = useWasNew({ isNew, containerMode })\n const itemTitle = useMemo(() => {\n return replaceItemNo(\n wasNew && titleWhenNew ? titleWhenNew : title,\n index\n )\n }, [index, title, titleWhenNew, wasNew])\n\n useSwitchContainerMode({ path })\n\n return (\n <ArrayItemArea\n mode=\"edit\"\n className={classnames('dnb-forms-section-edit-block', className)}\n ariaLabel={convertJsxToString(itemTitle)}\n toolbarVariant={toolbarVariant}\n {...restProps}\n >\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {toolbar}\n </ArrayItemArea>\n )\n}\n\nEditContainer.DoneButton = DoneButton\nEditContainer.CancelButton = CancelButton\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"EditContainer.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_componentHelper","_elements","_IterateItemContext","_ArrayItemArea","_Toolbar2","_hooks","_DoneButton","_CancelButton","_ItemNo","_Toolbar","_excluded","_excluded2","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","EditContainer","props","_toolbarElement","toolbar","toolbarVariant","children","rest","arrayValue","useContext","IterateItemContext","toolbarElement","createElement","Fragment","hasToolbar","React","Children","toArray","some","child","Toolbar","EditContainerWithoutToolbar","containerMode","isNew","index","path","_ref","className","title","titleWhenNew","restProps","wasNew","useWasNew","itemTitle","useMemo","replaceItemNo","useSwitchContainerMode","mode","classnames","ariaLabel","convertJsxToString","Lead","size","DoneButton","CancelButton","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Lead } from '../../../../elements'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport IterateItemContext from '../IterateItemContext'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport Toolbar from '../Toolbar'\nimport { useSwitchContainerMode } from '../hooks'\nimport DoneButton from './DoneButton'\nimport CancelButton, { useWasNew } from './CancelButton'\nimport { replaceItemNo } from '../ItemNo'\n\nexport type Props = {\n /**\n * The title of the EditContainer.\n */\n title?: React.ReactNode\n\n /**\n * The title for a new item show within the EditContainer.\n */\n titleWhenNew?: React.ReactNode\n\n /**\n * If the EditContainer is open or not.\n */\n open?: boolean\n\n /**\n * An alternative toolbar to be shown in the EditContainer.\n */\n toolbar?: React.ReactNode\n\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: ArrayItemAreaProps['toolbarVariant']\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nexport default function EditContainer(props: AllProps) {\n const { toolbar, toolbarVariant, children, ...rest } = props\n const { arrayValue } = useContext(IterateItemContext)\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = <></>\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <EditContainerWithoutToolbar\n toolbar={\n hasToolbar\n ? null\n : toolbarElement ??\n (toolbarVariant !== 'custom' && (\n <Toolbar>\n <DoneButton />\n <CancelButton />\n </Toolbar>\n ))\n }\n toolbarVariant={toolbarVariant}\n {...rest}\n >\n {children}\n </EditContainerWithoutToolbar>\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const { containerMode, isNew, index, path } =\n useContext(IterateItemContext)\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n toolbarVariant,\n ...restProps\n } = props || {}\n\n const wasNew = useWasNew({ isNew, containerMode })\n const itemTitle = useMemo(() => {\n return replaceItemNo(\n wasNew && titleWhenNew ? titleWhenNew : title,\n index\n )\n }, [index, title, titleWhenNew, wasNew])\n\n useSwitchContainerMode(path)\n\n return (\n <ArrayItemArea\n mode=\"edit\"\n className={classnames('dnb-forms-section-edit-block', className)}\n ariaLabel={convertJsxToString(itemTitle)}\n toolbarVariant={toolbarVariant}\n {...restProps}\n >\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {toolbar}\n </ArrayItemArea>\n )\n}\n\nEditContainer.DoneButton = DoneButton\nEditContainer.CancelButton = CancelButton\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":";;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAEA,IAAAK,mBAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,cAAA,GAAAJ,sBAAA,CAAAF,OAAA;AACA,IAAAO,SAAA,GAAAL,sBAAA,CAAAF,OAAA;AACA,IAAAQ,MAAA,GAAAR,OAAA;AACA,IAAAS,WAAA,GAAAP,sBAAA,CAAAF,OAAA;AACA,IAAAU,aAAA,GAAAX,uBAAA,CAAAC,OAAA;AACA,IAAAW,OAAA,GAAAX,OAAA;AAAyC,IAAAY,QAAA;AAAA,MAAAC,SAAA;EAAAC,UAAA;AAAA,SAAAZ,uBAAAa,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAApB,wBAAAgB,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAQ,KAAA,GAAAL,wBAAA,CAAAC,WAAA,OAAAI,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAT,GAAA,YAAAQ,KAAA,CAAAE,GAAA,CAAAV,GAAA,SAAAW,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAhB,GAAA,QAAAgB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAnB,GAAA,EAAAgB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAf,GAAA,EAAAgB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAhB,GAAA,CAAAgB,GAAA,SAAAL,MAAA,CAAAT,OAAA,GAAAF,GAAA,MAAAQ,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAArB,GAAA,EAAAW,MAAA,YAAAA,MAAA;AAAA,SAAAW,SAAA,IAAAA,QAAA,GAAAT,MAAA,CAAAU,MAAA,GAAAV,MAAA,CAAAU,MAAA,CAAAC,IAAA,eAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,GAAAF,SAAA,CAAAD,CAAA,YAAAV,GAAA,IAAAa,MAAA,QAAAhB,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAU,MAAA,EAAAb,GAAA,KAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,gBAAAS,MAAA,YAAAH,QAAA,CAAAQ,KAAA,OAAAH,SAAA;AAAA,SAAAI,yBAAAF,MAAA,EAAAG,QAAA,QAAAH,MAAA,yBAAAJ,MAAA,GAAAQ,6BAAA,CAAAJ,MAAA,EAAAG,QAAA,OAAAhB,GAAA,EAAAU,CAAA,MAAAb,MAAA,CAAAqB,qBAAA,QAAAC,gBAAA,GAAAtB,MAAA,CAAAqB,qBAAA,CAAAL,MAAA,QAAAH,CAAA,MAAAA,CAAA,GAAAS,gBAAA,CAAAP,MAAA,EAAAF,CAAA,MAAAV,GAAA,GAAAmB,gBAAA,CAAAT,CAAA,OAAAM,QAAA,CAAAI,OAAA,CAAApB,GAAA,uBAAAH,MAAA,CAAAI,SAAA,CAAAoB,oBAAA,CAAAlB,IAAA,CAAAU,MAAA,EAAAb,GAAA,aAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,cAAAS,MAAA;AAAA,SAAAQ,8BAAAJ,MAAA,EAAAG,QAAA,QAAAH,MAAA,yBAAAJ,MAAA,WAAAa,UAAA,GAAAzB,MAAA,CAAA0B,IAAA,CAAAV,MAAA,OAAAb,GAAA,EAAAU,CAAA,OAAAA,CAAA,MAAAA,CAAA,GAAAY,UAAA,CAAAV,MAAA,EAAAF,CAAA,MAAAV,GAAA,GAAAsB,UAAA,CAAAZ,CAAA,OAAAM,QAAA,CAAAI,OAAA,CAAApB,GAAA,kBAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,YAAAS,MAAA;AA+B1B,SAASe,aAAaA,CAACC,KAAe,EAAE;EAAA,IAAAC,eAAA;EACrD,MAAM;MAAEC,OAAO;MAAEC,cAAc;MAAEC;IAAkB,CAAC,GAAGJ,KAAK;IAAdK,IAAI,GAAAf,wBAAA,CAAKU,KAAK,EAAA3C,SAAA;EAC5D,MAAM;IAAEiD;EAAW,CAAC,GAAG,IAAAC,iBAAU,EAACC,2BAAkB,CAAC;EAErD,IAAIC,cAAc,GAAGP,OAAO;EAC5B,IAAIC,cAAc,KAAK,gBAAgB,IAAIG,UAAU,CAACnB,MAAM,IAAI,CAAC,EAAE;IACjEsB,cAAc,GAAGnE,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAAApE,MAAA,CAAAmB,OAAA,CAAAkD,QAAA,MAAI,CAAC;EACxB;EAEA,MAAMC,UAAU,GACd,CAACH,cAAc,IACfI,cAAK,CAACC,QAAQ,CAACC,OAAO,CAACX,QAAQ,CAAC,CAACY,IAAI,CAAEC,KAAK,IAAK;IAC/C,OAAO,CAAAA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,MAAM,CAAC,MAAKC,iBAAO;EACpC,CAAC,CAAC;EAEJ,OACE5E,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAACS,2BAA2B,EAAAtC,QAAA;IAC1BqB,OAAO,EACLU,UAAU,GACN,IAAI,IAAAX,eAAA,GACJQ,cAAc,cAAAR,eAAA,cAAAA,eAAA,GACbE,cAAc,KAAK,QAAQ,KAAA/C,QAAA,KAAAA,QAAA,GAC1Bd,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAAC3D,SAAA,CAAAU,OAAO,QACNnB,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAACzD,WAAA,CAAAQ,OAAU,MAAE,CAAC,EACdnB,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAACxD,aAAA,CAAAO,OAAY,MAAE,CACR,CAAC,EAEjB;IACD0C,cAAc,EAAEA;EAAe,GAC3BE,IAAI,GAEPD,QAC0B,CAAC;AAElC;AAEO,SAASe,2BAA2BA,CACzCnB,KAAiE,EACjE;EACA,MAAM;IAAEoB,aAAa;IAAEC,KAAK;IAAEC,KAAK;IAAEC;EAAK,CAAC,GACzC,IAAAhB,iBAAU,EAACC,2BAAkB,CAAC;EAEhC,MAAAgB,IAAA,GAQIxB,KAAK,IAAI,CAAC,CAAC;IART;MACJI,QAAQ;MACRqB,SAAS;MACTC,KAAK;MACLC,YAAY;MACZzB,OAAO;MACPC;IAEF,CAAC,GAAAqB,IAAA;IADII,SAAS,GAAAtC,wBAAA,CAAAkC,IAAA,EAAAlE,UAAA;EAGd,MAAMuE,MAAM,GAAG,IAAAC,uBAAS,EAAC;IAAET,KAAK;IAAED;EAAc,CAAC,CAAC;EAClD,MAAMW,SAAS,GAAG,IAAAC,cAAO,EAAC,MAAM;IAC9B,OAAO,IAAAC,qBAAa,EAClBJ,MAAM,IAAIF,YAAY,GAAGA,YAAY,GAAGD,KAAK,EAC7CJ,KACF,CAAC;EACH,CAAC,EAAE,CAACA,KAAK,EAAEI,KAAK,EAAEC,YAAY,EAAEE,MAAM,CAAC,CAAC;EAExC,IAAAK,6BAAsB,EAACX,IAAI,CAAC;EAE5B,OACEjF,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAAC5D,cAAA,CAAAW,OAAa,EAAAoB,QAAA;IACZsD,IAAI,EAAC,MAAM;IACXV,SAAS,EAAE,IAAAW,mBAAU,EAAC,8BAA8B,EAAEX,SAAS,CAAE;IACjEY,SAAS,EAAE,IAAAC,mCAAkB,EAACP,SAAS,CAAE;IACzC5B,cAAc,EAAEA;EAAe,GAC3ByB,SAAS,GAEZG,SAAS,IAAIzF,MAAA,CAAAmB,OAAA,CAAAiD,aAAA,CAAC9D,SAAA,CAAA2F,IAAI;IAACC,IAAI,EAAC;EAAO,GAAET,SAAgB,CAAC,EAClD3B,QAAQ,EACRF,OACY,CAAC;AAEpB;AAEAH,aAAa,CAAC0C,UAAU,GAAGA,mBAAU;AACrC1C,aAAa,CAAC2C,YAAY,GAAGA,qBAAY;AAEzC3C,aAAa,CAAC4C,qBAAqB,GAAG,IAAI;AAC1CxB,2BAA2B,CAACwB,qBAAqB,GAAG,IAAI"}
@@ -0,0 +1,5 @@
1
+ export declare function useIterateItemNo({ label: labelProp, labelSuffix, required, }: {
2
+ label: any;
3
+ labelSuffix: any;
4
+ required: any;
5
+ }): any;
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useIterateItemNo = useIterateItemNo;
7
+ var _react = _interopRequireWildcard(require("react"));
8
+ var _hooks = require("../hooks");
9
+ var _hooks2 = require("../../hooks");
10
+ var _componentHelper = require("../../../../shared/component-helper");
11
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
12
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
13
+ function useIterateItemNo(_ref) {
14
+ let {
15
+ label: labelProp,
16
+ labelSuffix,
17
+ required
18
+ } = _ref;
19
+ const {
20
+ index: iterateIndex
21
+ } = (0, _hooks.useItem)() || {};
22
+ const {
23
+ optionalLabelSuffix
24
+ } = (0, _hooks2.useTranslation)().Field;
25
+ const labelSuffixText = (0, _react.useMemo)(() => {
26
+ if (required === false || typeof labelSuffix !== 'undefined') {
27
+ return labelSuffix !== null && labelSuffix !== void 0 ? labelSuffix : optionalLabelSuffix;
28
+ }
29
+ return '';
30
+ }, [required, labelSuffix, optionalLabelSuffix]);
31
+ return (0, _react.useMemo)(() => {
32
+ let content = labelProp;
33
+ if (iterateIndex !== undefined) {
34
+ content = (0, _componentHelper.convertJsxToString)(labelProp).replace('{itemNo}', String(iterateIndex + 1));
35
+ }
36
+ if (labelSuffixText) {
37
+ if ((0, _componentHelper.convertJsxToString)(content).includes(optionalLabelSuffix)) {
38
+ return content;
39
+ }
40
+ if (typeof content === 'string') {
41
+ return content + ' ' + labelSuffixText;
42
+ }
43
+ if (_react.default.isValidElement(content)) {
44
+ return _react.default.createElement(_react.default.Fragment, null, content, ' ', labelSuffixText);
45
+ }
46
+ }
47
+ return content;
48
+ }, [iterateIndex, labelProp, labelSuffixText, optionalLabelSuffix]);
49
+ }
50
+ //# sourceMappingURL=useIItemNo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIItemNo.js","names":["_react","_interopRequireWildcard","require","_hooks","_hooks2","_componentHelper","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","useIterateItemNo","_ref","label","labelProp","labelSuffix","required","index","iterateIndex","useItem","optionalLabelSuffix","useTranslation","Field","labelSuffixText","useMemo","content","undefined","convertJsxToString","replace","String","includes","React","isValidElement","createElement","Fragment"],"sources":["../../../../../../src/extensions/forms/Iterate/ItemNo/useIItemNo.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport { useItem } from '../hooks'\nimport { useTranslation } from '../../hooks'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport function useIterateItemNo({\n label: labelProp,\n labelSuffix,\n required,\n}) {\n const { index: iterateIndex } = useItem() || {}\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 return 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"],"mappings":"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"}
@@ -11,6 +11,8 @@ export interface IterateItemContextState {
11
11
  value?: unknown;
12
12
  isNew?: boolean;
13
13
  path?: Path;
14
+ itemPath?: Path;
15
+ nestedIteratePath?: Path;
14
16
  arrayValue?: Array<unknown>;
15
17
  containerMode?: ContainerMode;
16
18
  previousContainerMode?: ContainerMode;
@@ -1 +1 @@
1
- {"version":3,"file":"IterateItemContext.js","names":["_react","_interopRequireDefault","require","obj","__esModule","default","IterateItemContext","React","createContext","undefined","_default","exports"],"sources":["../../../../../src/extensions/forms/Iterate/IterateItemContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../types'\nimport { ContainerMode } from './Array/types'\n\nexport type ModeOptions = {\n omitFocusManagement?: boolean\n preventUpdate?: boolean\n}\n\nexport interface IterateItemContextState {\n id?: string\n index?: number\n value?: unknown\n isNew?: boolean\n path?: Path\n arrayValue?: Array<unknown>\n containerMode?: ContainerMode\n previousContainerMode?: ContainerMode\n initialContainerMode?: ContainerMode\n containerRef?: React.RefObject<HTMLDivElement>\n elementRef?: React.RefObject<HTMLDivElement>\n modeOptions?: ModeOptions\n switchContainerMode?: (\n mode: ContainerMode,\n options?: ModeOptions\n ) => void\n handleChange?: (path: Path, value: unknown) => void\n handleRemove?: ({ keepItems }?: { keepItems?: boolean }) => void\n handlePush?: (value: unknown) => void\n restoreOriginalValue?: (value: unknown) => void\n fulfillRemove?: () => void\n}\n\nconst IterateItemContext = React.createContext<\n IterateItemContextState | undefined\n>(undefined)\n\nexport default IterateItemContext\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAyB,SAAAD,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAiCzB,MAAMG,kBAAkB,GAAGC,cAAK,CAACC,aAAa,CAE5CC,SAAS,CAAC;AAAA,IAAAC,QAAA,GAEGJ,kBAAkB;AAAAK,OAAA,CAAAN,OAAA,GAAAK,QAAA"}
1
+ {"version":3,"file":"IterateItemContext.js","names":["_react","_interopRequireDefault","require","obj","__esModule","default","IterateItemContext","React","createContext","undefined","_default","exports"],"sources":["../../../../../src/extensions/forms/Iterate/IterateItemContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../types'\nimport { ContainerMode } from './Array/types'\n\nexport type ModeOptions = {\n omitFocusManagement?: boolean\n preventUpdate?: boolean\n}\n\nexport interface IterateItemContextState {\n id?: string\n index?: number\n value?: unknown\n isNew?: boolean\n path?: Path\n itemPath?: Path\n nestedIteratePath?: Path\n arrayValue?: Array<unknown>\n containerMode?: ContainerMode\n previousContainerMode?: ContainerMode\n initialContainerMode?: ContainerMode\n containerRef?: React.RefObject<HTMLDivElement>\n elementRef?: React.RefObject<HTMLDivElement>\n modeOptions?: ModeOptions\n switchContainerMode?: (\n mode: ContainerMode,\n options?: ModeOptions\n ) => void\n handleChange?: (path: Path, value: unknown) => void\n handleRemove?: ({ keepItems }?: { keepItems?: boolean }) => void\n handlePush?: (value: unknown) => void\n restoreOriginalValue?: (value: unknown) => void\n fulfillRemove?: () => void\n}\n\nconst IterateItemContext = React.createContext<\n IterateItemContextState | undefined\n>(undefined)\n\nexport default IterateItemContext\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAyB,SAAAD,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAmCzB,MAAMG,kBAAkB,GAAGC,cAAK,CAACC,aAAa,CAE5CC,SAAS,CAAC;AAAA,IAAAC,QAAA,GAEGJ,kBAAkB;AAAAK,OAAA,CAAAN,OAAA,GAAAK,QAAA"}
@@ -2,6 +2,7 @@ import { ButtonProps } from '../../../../components/Button';
2
2
  import { Path } from '../../types';
3
3
  export type Props = ButtonProps & {
4
4
  path?: Path;
5
+ itemPath?: Path;
5
6
  pushValue: unknown | ((value: unknown) => void);
6
7
  /**
7
8
  * Used internally
@@ -15,7 +15,7 @@ var _icons = require("../../../../icons");
15
15
  var _Context = _interopRequireDefault(require("../../DataContext/Context"));
16
16
  var _useDataValue = _interopRequireDefault(require("../../hooks/useDataValue"));
17
17
  var _componentHelper = require("../../../../shared/component-helper");
18
- const _excluded = ["pushValue", "className", "path", "text", "children"];
18
+ const _excluded = ["pushValue", "className", "path", "itemPath", "text", "children"];
19
19
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
20
20
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
21
21
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -34,41 +34,43 @@ function PushButton(props) {
34
34
  pushValue,
35
35
  className,
36
36
  path,
37
+ itemPath,
37
38
  text,
38
39
  children
39
40
  } = props,
40
41
  restProps = _objectWithoutProperties(props, _excluded);
41
42
  const buttonProps = (0, _types.omitDataValueReadWriteProps)(restProps);
42
- const arrayValue = (0, _useDataValue.default)().getValueByPath(path);
43
+ const {
44
+ absolutePath
45
+ } = (0, _hooks.useItemPath)(itemPath);
46
+ const arrayValue = (0, _useDataValue.default)().getValueByPath(path || absolutePath);
43
47
  const {
44
48
  hasReachedLimit,
45
49
  setShowStatus
46
- } = (0, _hooks.useArrayLimit)({
47
- path
48
- });
50
+ } = (0, _hooks.useArrayLimit)(path);
49
51
  if (arrayValue !== undefined && !Array.isArray(arrayValue)) {
50
52
  throw new Error('PushButton received a non-array value');
51
53
  }
52
54
  const {
53
55
  setLastItemContainerMode
54
- } = (0, _hooks.useSwitchContainerMode)({
55
- path
56
- });
56
+ } = (0, _hooks.useSwitchContainerMode)(path);
57
57
  const handleClick = (0, _react.useCallback)(async () => {
58
58
  if (hasReachedLimit) {
59
59
  setShowStatus(true);
60
60
  return;
61
61
  }
62
62
  const newValue = typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue;
63
- if (handlePush) {
63
+ if (handlePush && !absolutePath) {
64
64
  handlePush(newValue);
65
65
  } else {
66
- await (handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(path, [...(arrayValue !== null && arrayValue !== void 0 ? arrayValue : []), newValue]));
66
+ await (handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(path || absolutePath, [...(arrayValue !== null && arrayValue !== void 0 ? arrayValue : []), newValue]));
67
+ }
68
+ if (!absolutePath) {
69
+ setTimeout(() => {
70
+ setLastItemContainerMode('view');
71
+ }, 100);
67
72
  }
68
- setTimeout(() => {
69
- setLastItemContainerMode('view');
70
- }, 100);
71
- }, [arrayValue, handlePathChange, handlePush, hasReachedLimit, path, pushValue, setLastItemContainerMode, setShowStatus]);
73
+ }, [arrayValue, absolutePath, handlePathChange, handlePush, hasReachedLimit, path, pushValue, setLastItemContainerMode, setShowStatus]);
72
74
  const content = (0, _react.useMemo)(() => {
73
75
  if (children || text) {
74
76
  const str = (0, _componentHelper.convertJsxToString)(children || text);