@dnb/eufemia 10.32.0 → 10.34.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 (938) hide show
  1. package/CHANGELOG.md +51 -0
  2. package/cjs/components/autocomplete/style/dnb-autocomplete.css +0 -1
  3. package/cjs/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  4. package/cjs/components/autocomplete/style/dnb-autocomplete.scss +0 -2
  5. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +41 -0
  6. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.min.css +1 -0
  7. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +65 -0
  8. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +3 -0
  9. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
  10. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +6 -0
  11. package/cjs/components/breadcrumb/Breadcrumb.d.ts +4 -4
  12. package/cjs/components/breadcrumb/Breadcrumb.js +5 -3
  13. package/cjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  14. package/cjs/components/card/Card.js +1 -0
  15. package/cjs/components/card/Card.js.map +1 -1
  16. package/cjs/components/card/style/dnb-card.css +3 -0
  17. package/cjs/components/card/style/dnb-card.min.css +1 -1
  18. package/cjs/components/card/style/dnb-card.scss +4 -0
  19. package/cjs/components/checkbox/Checkbox.js +1 -1
  20. package/cjs/components/checkbox/Checkbox.js.map +1 -1
  21. package/cjs/components/checkbox/style/dnb-checkbox.css +9 -3
  22. package/cjs/components/checkbox/style/dnb-checkbox.min.css +1 -1
  23. package/cjs/components/checkbox/style/dnb-checkbox.scss +11 -3
  24. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.css +5 -3
  25. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.min.css +2 -2
  26. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.scss +5 -3
  27. package/cjs/components/flex/Container.js +4 -4
  28. package/cjs/components/flex/Container.js.map +1 -1
  29. package/cjs/components/form-row/FormRow.js +1 -1
  30. package/cjs/components/form-row/FormRow.js.map +1 -1
  31. package/cjs/components/form-set/FormSet.js +1 -1
  32. package/cjs/components/form-set/FormSet.js.map +1 -1
  33. package/cjs/components/form-status/FormStatus.d.ts +0 -1
  34. package/cjs/components/form-status/FormStatus.js +85 -67
  35. package/cjs/components/form-status/FormStatus.js.map +1 -1
  36. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +2 -2
  37. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -1
  38. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +2 -2
  39. package/cjs/components/global-status/GlobalStatus.js +2 -4
  40. package/cjs/components/global-status/GlobalStatus.js.map +1 -1
  41. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +1 -1
  42. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -1
  43. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +1 -1
  44. package/cjs/components/grid/Container.d.ts +2 -2
  45. package/cjs/components/grid/Container.js.map +1 -1
  46. package/cjs/components/grid/ContainerDocs.d.ts +2 -0
  47. package/cjs/components/grid/ContainerDocs.js +30 -0
  48. package/cjs/components/grid/ContainerDocs.js.map +1 -0
  49. package/cjs/components/grid/style/dnb-grid.css +6 -0
  50. package/cjs/components/grid/style/dnb-grid.min.css +1 -1
  51. package/cjs/components/grid/style/grid-container.scss +6 -0
  52. package/cjs/components/number-format/NumberFormat.js +1 -1
  53. package/cjs/components/number-format/NumberFormat.js.map +1 -1
  54. package/cjs/components/radio/style/dnb-radio.css +19 -7
  55. package/cjs/components/radio/style/dnb-radio.min.css +1 -1
  56. package/cjs/components/radio/style/dnb-radio.scss +21 -7
  57. package/cjs/components/radio/style/themes/dnb-radio-theme-sbanken.css +6 -0
  58. package/cjs/components/radio/style/themes/dnb-radio-theme-sbanken.min.css +1 -1
  59. package/cjs/components/radio/style/themes/dnb-radio-theme-sbanken.scss +6 -0
  60. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.css +1 -1
  61. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -1
  62. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.scss +1 -1
  63. package/cjs/components/slider/SliderDocs.d.ts +3 -0
  64. package/cjs/components/slider/SliderDocs.js +158 -0
  65. package/cjs/components/slider/SliderDocs.js.map +1 -0
  66. package/cjs/components/step-indicator/StepIndicator.js +1 -10
  67. package/cjs/components/step-indicator/StepIndicator.js.map +1 -1
  68. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +1 -1
  69. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -1
  70. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +1 -1
  71. package/cjs/components/table/TableContainer.d.ts +1 -0
  72. package/cjs/components/table/TableContainer.js +1 -0
  73. package/cjs/components/table/TableContainer.js.map +1 -1
  74. package/cjs/components/table/style/dnb-table.css +3 -0
  75. package/cjs/components/table/style/dnb-table.min.css +1 -1
  76. package/cjs/components/table/style/table-container.scss +5 -0
  77. package/cjs/extensions/forms/DataContext/Context.d.ts +8 -5
  78. package/cjs/extensions/forms/DataContext/Context.js +0 -1
  79. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  80. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  81. package/cjs/extensions/forms/DataContext/Provider/Provider.js +30 -3
  82. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  83. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +7 -2
  84. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  85. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  86. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  87. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  88. package/cjs/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  89. package/cjs/extensions/forms/Field/Composition/Composition.js.map +1 -1
  90. package/cjs/extensions/forms/Field/Composition/CompositionDocs.d.ts +2 -0
  91. package/cjs/extensions/forms/Field/Composition/CompositionDocs.js +23 -0
  92. package/cjs/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -0
  93. package/cjs/extensions/forms/Field/Number/Number.d.ts +1 -0
  94. package/cjs/extensions/forms/Field/Number/Number.js +18 -15
  95. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  96. package/cjs/extensions/forms/Field/Number/NumberDocs.js +6 -1
  97. package/cjs/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  98. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  99. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  100. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  101. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  102. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  103. package/cjs/extensions/forms/Field/Selection/Selection.js +5 -6
  104. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  105. package/cjs/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  106. package/cjs/extensions/forms/Field/Slider/Slider.js +115 -0
  107. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -0
  108. package/cjs/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  109. package/cjs/extensions/forms/Field/Slider/SliderDocs.js +34 -0
  110. package/cjs/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  111. package/cjs/extensions/forms/Field/Slider/index.d.ts +2 -0
  112. package/cjs/extensions/forms/Field/Slider/index.js +27 -0
  113. package/cjs/extensions/forms/Field/Slider/index.js.map +1 -0
  114. package/cjs/extensions/forms/Field/String/String.js +2 -2
  115. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  116. package/cjs/extensions/forms/Field/Toggle/Toggle.js +7 -7
  117. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  118. package/cjs/extensions/forms/Field/index.d.ts +1 -0
  119. package/cjs/extensions/forms/Field/index.js +7 -0
  120. package/cjs/extensions/forms/Field/index.js.map +1 -1
  121. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +4 -1
  122. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +15 -3
  123. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  124. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  125. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  126. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -1
  127. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  128. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -2
  129. package/cjs/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  130. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js +47 -24
  131. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  132. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  133. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  134. package/cjs/extensions/forms/Form/MainHeading/MainHeading.js +1 -0
  135. package/cjs/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  136. package/cjs/extensions/forms/Form/Section/Section.d.ts +36 -0
  137. package/cjs/extensions/forms/Form/Section/Section.js +79 -0
  138. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -0
  139. package/cjs/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  140. package/cjs/extensions/forms/Form/Section/SectionContext.js +12 -0
  141. package/cjs/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  142. package/cjs/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  143. package/cjs/extensions/forms/Form/Section/SectionDocs.js +53 -0
  144. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  145. package/cjs/extensions/forms/Form/Section/index.d.ts +2 -0
  146. package/cjs/extensions/forms/Form/Section/index.js +27 -0
  147. package/cjs/extensions/forms/Form/Section/index.js.map +1 -0
  148. package/cjs/extensions/forms/Form/SubHeading/SubHeading.js +1 -0
  149. package/cjs/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  150. package/cjs/extensions/forms/Form/Visibility/Visibility.js +15 -9
  151. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  152. package/cjs/extensions/forms/Form/data-context/useData.js +6 -2
  153. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  154. package/cjs/extensions/forms/Form/index.d.ts +1 -1
  155. package/cjs/extensions/forms/Form/index.js +7 -5
  156. package/cjs/extensions/forms/Form/index.js.map +1 -1
  157. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +2 -2
  158. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  159. package/cjs/extensions/forms/Iterate/Array/Array.js +37 -1
  160. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  161. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +15 -0
  162. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  163. package/cjs/extensions/forms/Iterate/Array/types.d.ts +9 -3
  164. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  165. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -2
  166. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  167. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  168. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  169. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  170. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  171. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -2
  172. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  173. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.css +1 -1
  174. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  175. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.scss +1 -0
  176. package/cjs/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  177. package/cjs/extensions/forms/Tools/GenerateSchema.js +143 -0
  178. package/cjs/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  179. package/cjs/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  180. package/cjs/extensions/forms/Tools/ListAllProps.js +73 -0
  181. package/cjs/extensions/forms/Tools/ListAllProps.js.map +1 -0
  182. package/{es/extensions/forms/Form → cjs/extensions/forms}/Tools/index.d.ts +1 -0
  183. package/cjs/extensions/forms/{Form/Tools → Tools}/index.js +7 -0
  184. package/cjs/extensions/forms/Tools/index.js.map +1 -0
  185. package/cjs/extensions/forms/Value/Boolean/Boolean.d.ts +5 -1
  186. package/cjs/extensions/forms/Value/Boolean/Boolean.js +5 -3
  187. package/cjs/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  188. package/cjs/extensions/forms/Value/Boolean/BooleanDocs.d.ts +2 -0
  189. package/cjs/extensions/forms/Value/Boolean/BooleanDocs.js +20 -0
  190. package/cjs/extensions/forms/Value/Boolean/BooleanDocs.js.map +1 -0
  191. package/cjs/extensions/forms/Value/Number/Number.d.ts +5 -1
  192. package/cjs/extensions/forms/Value/Number/Number.js +18 -5
  193. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  194. package/cjs/extensions/forms/Value/Number/NumberDocs.d.ts +2 -0
  195. package/cjs/extensions/forms/Value/Number/NumberDocs.js +20 -0
  196. package/cjs/extensions/forms/Value/Number/NumberDocs.js.map +1 -0
  197. package/cjs/extensions/forms/Value/ValueDocs.js +6 -1
  198. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  199. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +15 -1
  200. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  201. package/cjs/extensions/forms/Wizard/Buttons/Buttons.js +2 -1
  202. package/cjs/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  203. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +90 -42
  204. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  205. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  206. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  207. package/cjs/extensions/forms/Wizard/EditButton/EditButton.js +7 -2
  208. package/cjs/extensions/forms/Wizard/EditButton/EditButton.js.map +1 -1
  209. package/cjs/extensions/forms/Wizard/Step/Step.d.ts +4 -0
  210. package/cjs/extensions/forms/Wizard/Step/Step.js +7 -4
  211. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  212. package/cjs/extensions/forms/Wizard/Step/StepDocs.js +5 -0
  213. package/cjs/extensions/forms/Wizard/Step/StepDocs.js.map +1 -1
  214. package/cjs/extensions/forms/Wizard/hooks/useStep.js +17 -1
  215. package/cjs/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  216. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +1 -1
  217. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  218. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
  219. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +13 -0
  220. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +164 -0
  221. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -0
  222. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.d.ts +2 -0
  223. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +25 -0
  224. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -0
  225. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +77 -0
  226. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +84 -0
  227. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -0
  228. package/cjs/extensions/forms/blocks/ChildrenWithAge/index.d.ts +2 -0
  229. package/cjs/extensions/forms/blocks/ChildrenWithAge/index.js +27 -0
  230. package/cjs/extensions/forms/blocks/ChildrenWithAge/index.js.map +1 -0
  231. package/cjs/extensions/forms/blocks/index.d.ts +1 -0
  232. package/cjs/extensions/forms/blocks/index.js +14 -0
  233. package/cjs/extensions/forms/blocks/index.js.map +1 -0
  234. package/cjs/extensions/forms/constants/locales/en-GB.js +2 -2
  235. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  236. package/cjs/extensions/forms/hooks/DataValueDocs.js +10 -10
  237. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  238. package/cjs/extensions/forms/hooks/index.d.ts +2 -5
  239. package/cjs/extensions/forms/hooks/index.js +12 -4
  240. package/cjs/extensions/forms/hooks/index.js.map +1 -1
  241. package/cjs/extensions/forms/hooks/useDataValue.d.ts +9 -0
  242. package/cjs/extensions/forms/hooks/useDataValue.js +39 -0
  243. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -0
  244. package/cjs/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  245. package/cjs/extensions/forms/hooks/useExternalValue.js +47 -0
  246. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -0
  247. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  248. package/cjs/extensions/forms/hooks/useFieldProps.js +67 -83
  249. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  250. package/cjs/extensions/forms/hooks/usePath.d.ts +14 -0
  251. package/cjs/extensions/forms/hooks/usePath.js +72 -0
  252. package/cjs/extensions/forms/hooks/usePath.js.map +1 -0
  253. package/cjs/extensions/forms/hooks/useValueProps.js +19 -5
  254. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  255. package/cjs/extensions/forms/index.d.ts +2 -0
  256. package/cjs/extensions/forms/index.js +4 -1
  257. package/cjs/extensions/forms/index.js.map +1 -1
  258. package/cjs/extensions/forms/style/dnb-forms.css +5 -3
  259. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  260. package/cjs/extensions/forms/types.d.ts +16 -7
  261. package/cjs/extensions/forms/types.js.map +1 -1
  262. package/cjs/fragments/drawer-list/DrawerListHelpers.js +3 -2
  263. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  264. package/cjs/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +12 -1
  265. package/cjs/shared/Context.d.ts +4 -4
  266. package/cjs/shared/Context.js +8 -8
  267. package/cjs/shared/Context.js.map +1 -1
  268. package/cjs/shared/Eufemia.d.ts +1 -1
  269. package/cjs/shared/Eufemia.js +2 -2
  270. package/cjs/shared/Eufemia.js.map +1 -1
  271. package/cjs/shared/component-helper.d.ts +3 -1
  272. package/cjs/shared/component-helper.js +39 -10
  273. package/cjs/shared/component-helper.js.map +1 -1
  274. package/cjs/style/core/scopes.scss +1 -1
  275. package/cjs/style/dnb-ui-basis.css +1 -1
  276. package/cjs/style/dnb-ui-basis.min.css +1 -1
  277. package/cjs/style/dnb-ui-body.css +1 -1
  278. package/cjs/style/dnb-ui-body.min.css +1 -1
  279. package/cjs/style/dnb-ui-components.css +45 -14
  280. package/cjs/style/dnb-ui-components.min.css +3 -3
  281. package/cjs/style/dnb-ui-core.css +1 -1
  282. package/cjs/style/dnb-ui-core.min.css +1 -1
  283. package/cjs/style/dnb-ui-extensions.css +5 -3
  284. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  285. package/cjs/style/dnb-ui-forms.css +5 -3
  286. package/cjs/style/dnb-ui-forms.min.css +1 -1
  287. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +53 -17
  288. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  289. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +5 -3
  290. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  291. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +5 -3
  292. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  293. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +118 -76
  294. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -8
  295. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  296. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +5 -3
  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 +5 -3
  299. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  300. package/cjs/style/themes/theme-ui/ui-theme-components.css +53 -17
  301. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  302. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +5 -3
  303. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  304. package/cjs/style/themes/theme-ui/ui-theme-forms.css +5 -3
  305. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  306. package/components/autocomplete/style/dnb-autocomplete.css +0 -1
  307. package/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  308. package/components/autocomplete/style/dnb-autocomplete.scss +0 -2
  309. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +41 -0
  310. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.min.css +1 -0
  311. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +65 -0
  312. package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +3 -0
  313. package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
  314. package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +6 -0
  315. package/components/breadcrumb/Breadcrumb.d.ts +4 -4
  316. package/components/breadcrumb/Breadcrumb.js +6 -4
  317. package/components/breadcrumb/Breadcrumb.js.map +1 -1
  318. package/components/card/Card.js +1 -0
  319. package/components/card/Card.js.map +1 -1
  320. package/components/card/style/dnb-card.css +3 -0
  321. package/components/card/style/dnb-card.min.css +1 -1
  322. package/components/card/style/dnb-card.scss +4 -0
  323. package/components/checkbox/Checkbox.js +1 -1
  324. package/components/checkbox/Checkbox.js.map +1 -1
  325. package/components/checkbox/style/dnb-checkbox.css +9 -3
  326. package/components/checkbox/style/dnb-checkbox.min.css +1 -1
  327. package/components/checkbox/style/dnb-checkbox.scss +11 -3
  328. package/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.css +5 -3
  329. package/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.min.css +2 -2
  330. package/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.scss +5 -3
  331. package/components/flex/Container.js +4 -4
  332. package/components/flex/Container.js.map +1 -1
  333. package/components/form-row/FormRow.js +2 -2
  334. package/components/form-row/FormRow.js.map +1 -1
  335. package/components/form-set/FormSet.js +2 -2
  336. package/components/form-set/FormSet.js.map +1 -1
  337. package/components/form-status/FormStatus.d.ts +0 -1
  338. package/components/form-status/FormStatus.js +84 -66
  339. package/components/form-status/FormStatus.js.map +1 -1
  340. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +2 -2
  341. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -1
  342. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +2 -2
  343. package/components/global-status/GlobalStatus.js +2 -4
  344. package/components/global-status/GlobalStatus.js.map +1 -1
  345. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +1 -1
  346. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -1
  347. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +1 -1
  348. package/components/grid/Container.d.ts +2 -2
  349. package/components/grid/Container.js.map +1 -1
  350. package/components/grid/ContainerDocs.d.ts +2 -0
  351. package/components/grid/ContainerDocs.js +23 -0
  352. package/components/grid/ContainerDocs.js.map +1 -0
  353. package/components/grid/style/dnb-grid.css +6 -0
  354. package/components/grid/style/dnb-grid.min.css +1 -1
  355. package/components/grid/style/grid-container.scss +6 -0
  356. package/components/number-format/NumberFormat.js +2 -2
  357. package/components/number-format/NumberFormat.js.map +1 -1
  358. package/components/radio/style/dnb-radio.css +19 -7
  359. package/components/radio/style/dnb-radio.min.css +1 -1
  360. package/components/radio/style/dnb-radio.scss +21 -7
  361. package/components/radio/style/themes/dnb-radio-theme-sbanken.css +6 -0
  362. package/components/radio/style/themes/dnb-radio-theme-sbanken.min.css +1 -1
  363. package/components/radio/style/themes/dnb-radio-theme-sbanken.scss +6 -0
  364. package/components/section/style/themes/dnb-section-theme-sbanken.css +1 -1
  365. package/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -1
  366. package/components/section/style/themes/dnb-section-theme-sbanken.scss +1 -1
  367. package/components/slider/SliderDocs.d.ts +3 -0
  368. package/components/slider/SliderDocs.js +150 -0
  369. package/components/slider/SliderDocs.js.map +1 -0
  370. package/components/step-indicator/StepIndicator.js +1 -9
  371. package/components/step-indicator/StepIndicator.js.map +1 -1
  372. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +1 -1
  373. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -1
  374. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +1 -1
  375. package/components/table/TableContainer.d.ts +1 -0
  376. package/components/table/TableContainer.js +1 -0
  377. package/components/table/TableContainer.js.map +1 -1
  378. package/components/table/style/dnb-table.css +3 -0
  379. package/components/table/style/dnb-table.min.css +1 -1
  380. package/components/table/style/table-container.scss +5 -0
  381. package/es/components/autocomplete/style/dnb-autocomplete.css +0 -1
  382. package/es/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  383. package/es/components/autocomplete/style/dnb-autocomplete.scss +0 -2
  384. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +41 -0
  385. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.min.css +1 -0
  386. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +65 -0
  387. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +3 -0
  388. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
  389. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +6 -0
  390. package/es/components/breadcrumb/Breadcrumb.d.ts +4 -4
  391. package/es/components/breadcrumb/Breadcrumb.js +6 -4
  392. package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
  393. package/es/components/card/Card.js +1 -0
  394. package/es/components/card/Card.js.map +1 -1
  395. package/es/components/card/style/dnb-card.css +3 -0
  396. package/es/components/card/style/dnb-card.min.css +1 -1
  397. package/es/components/card/style/dnb-card.scss +4 -0
  398. package/es/components/checkbox/Checkbox.js +1 -1
  399. package/es/components/checkbox/Checkbox.js.map +1 -1
  400. package/es/components/checkbox/style/dnb-checkbox.css +9 -3
  401. package/es/components/checkbox/style/dnb-checkbox.min.css +1 -1
  402. package/es/components/checkbox/style/dnb-checkbox.scss +11 -3
  403. package/es/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.css +5 -3
  404. package/es/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.min.css +2 -2
  405. package/es/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.scss +5 -3
  406. package/es/components/flex/Container.js +4 -4
  407. package/es/components/flex/Container.js.map +1 -1
  408. package/es/components/form-row/FormRow.js +2 -2
  409. package/es/components/form-row/FormRow.js.map +1 -1
  410. package/es/components/form-set/FormSet.js +2 -2
  411. package/es/components/form-set/FormSet.js.map +1 -1
  412. package/es/components/form-status/FormStatus.d.ts +0 -1
  413. package/es/components/form-status/FormStatus.js +84 -66
  414. package/es/components/form-status/FormStatus.js.map +1 -1
  415. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +2 -2
  416. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -1
  417. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +2 -2
  418. package/es/components/global-status/GlobalStatus.js +2 -4
  419. package/es/components/global-status/GlobalStatus.js.map +1 -1
  420. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +1 -1
  421. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -1
  422. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +1 -1
  423. package/es/components/grid/Container.d.ts +2 -2
  424. package/es/components/grid/Container.js.map +1 -1
  425. package/es/components/grid/ContainerDocs.d.ts +2 -0
  426. package/es/components/grid/ContainerDocs.js +23 -0
  427. package/es/components/grid/ContainerDocs.js.map +1 -0
  428. package/es/components/grid/style/dnb-grid.css +6 -0
  429. package/es/components/grid/style/dnb-grid.min.css +1 -1
  430. package/es/components/grid/style/grid-container.scss +6 -0
  431. package/es/components/number-format/NumberFormat.js +2 -2
  432. package/es/components/number-format/NumberFormat.js.map +1 -1
  433. package/es/components/radio/style/dnb-radio.css +19 -7
  434. package/es/components/radio/style/dnb-radio.min.css +1 -1
  435. package/es/components/radio/style/dnb-radio.scss +21 -7
  436. package/es/components/radio/style/themes/dnb-radio-theme-sbanken.css +6 -0
  437. package/es/components/radio/style/themes/dnb-radio-theme-sbanken.min.css +1 -1
  438. package/es/components/radio/style/themes/dnb-radio-theme-sbanken.scss +6 -0
  439. package/es/components/section/style/themes/dnb-section-theme-sbanken.css +1 -1
  440. package/es/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -1
  441. package/es/components/section/style/themes/dnb-section-theme-sbanken.scss +1 -1
  442. package/es/components/slider/SliderDocs.d.ts +3 -0
  443. package/es/components/slider/SliderDocs.js +150 -0
  444. package/es/components/slider/SliderDocs.js.map +1 -0
  445. package/es/components/step-indicator/StepIndicator.js +1 -9
  446. package/es/components/step-indicator/StepIndicator.js.map +1 -1
  447. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +1 -1
  448. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -1
  449. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +1 -1
  450. package/es/components/table/TableContainer.d.ts +1 -0
  451. package/es/components/table/TableContainer.js +1 -0
  452. package/es/components/table/TableContainer.js.map +1 -1
  453. package/es/components/table/style/dnb-table.css +3 -0
  454. package/es/components/table/style/dnb-table.min.css +1 -1
  455. package/es/components/table/style/table-container.scss +5 -0
  456. package/es/extensions/forms/DataContext/Context.d.ts +8 -5
  457. package/es/extensions/forms/DataContext/Context.js +0 -1
  458. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  459. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  460. package/es/extensions/forms/DataContext/Provider/Provider.js +33 -6
  461. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  462. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +7 -2
  463. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  464. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  465. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  466. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  467. package/es/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  468. package/es/extensions/forms/Field/Composition/Composition.js.map +1 -1
  469. package/es/extensions/forms/Field/Composition/CompositionDocs.d.ts +2 -0
  470. package/es/extensions/forms/Field/Composition/CompositionDocs.js +14 -0
  471. package/es/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -0
  472. package/es/extensions/forms/Field/Number/Number.d.ts +1 -0
  473. package/es/extensions/forms/Field/Number/Number.js +18 -15
  474. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  475. package/es/extensions/forms/Field/Number/NumberDocs.js +6 -1
  476. package/es/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  477. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  478. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  479. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  480. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  481. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  482. package/es/extensions/forms/Field/Selection/Selection.js +5 -6
  483. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  484. package/es/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  485. package/es/extensions/forms/Field/Slider/Slider.js +103 -0
  486. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -0
  487. package/es/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  488. package/es/extensions/forms/Field/Slider/SliderDocs.js +26 -0
  489. package/es/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  490. package/es/extensions/forms/Field/Slider/index.d.ts +2 -0
  491. package/es/extensions/forms/Field/Slider/index.js +3 -0
  492. package/es/extensions/forms/Field/Slider/index.js.map +1 -0
  493. package/es/extensions/forms/Field/String/String.js +2 -2
  494. package/es/extensions/forms/Field/String/String.js.map +1 -1
  495. package/es/extensions/forms/Field/Toggle/Toggle.js +7 -7
  496. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  497. package/es/extensions/forms/Field/index.d.ts +1 -0
  498. package/es/extensions/forms/Field/index.js +1 -0
  499. package/es/extensions/forms/Field/index.js.map +1 -1
  500. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +4 -1
  501. package/es/extensions/forms/FieldBlock/FieldBlock.js +15 -3
  502. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  503. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  504. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  505. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -1
  506. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  507. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -2
  508. package/es/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  509. package/es/extensions/forms/Form/FieldProps/FieldProps.js +46 -25
  510. package/es/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  511. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  512. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  513. package/es/extensions/forms/Form/MainHeading/MainHeading.js +1 -0
  514. package/es/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  515. package/es/extensions/forms/Form/Section/Section.d.ts +36 -0
  516. package/es/extensions/forms/Form/Section/Section.js +63 -0
  517. package/es/extensions/forms/Form/Section/Section.js.map +1 -0
  518. package/es/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  519. package/es/extensions/forms/Form/Section/SectionContext.js +4 -0
  520. package/es/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  521. package/es/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  522. package/es/extensions/forms/Form/Section/SectionDocs.js +45 -0
  523. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  524. package/es/extensions/forms/Form/Section/index.d.ts +2 -0
  525. package/es/extensions/forms/Form/Section/index.js +3 -0
  526. package/es/extensions/forms/Form/Section/index.js.map +1 -0
  527. package/es/extensions/forms/Form/SubHeading/SubHeading.js +1 -0
  528. package/es/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  529. package/es/extensions/forms/Form/Visibility/Visibility.js +16 -10
  530. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  531. package/es/extensions/forms/Form/data-context/useData.js +6 -2
  532. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  533. package/es/extensions/forms/Form/index.d.ts +1 -1
  534. package/es/extensions/forms/Form/index.js +1 -1
  535. package/es/extensions/forms/Form/index.js.map +1 -1
  536. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +2 -2
  537. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  538. package/es/extensions/forms/Iterate/Array/Array.js +37 -1
  539. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  540. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +15 -0
  541. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  542. package/es/extensions/forms/Iterate/Array/types.d.ts +9 -3
  543. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  544. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -2
  545. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  546. package/es/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  547. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  548. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  549. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  550. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -2
  551. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  552. package/es/extensions/forms/Iterate/style/dnb-form-iterate.css +1 -1
  553. package/es/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  554. package/es/extensions/forms/Iterate/style/dnb-form-iterate.scss +1 -0
  555. package/es/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  556. package/es/extensions/forms/Tools/GenerateSchema.js +130 -0
  557. package/es/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  558. package/es/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  559. package/es/extensions/forms/Tools/ListAllProps.js +65 -0
  560. package/es/extensions/forms/Tools/ListAllProps.js.map +1 -0
  561. package/{extensions/forms/Form → es/extensions/forms}/Tools/index.d.ts +1 -0
  562. package/es/extensions/forms/Tools/index.js +3 -0
  563. package/es/extensions/forms/Tools/index.js.map +1 -0
  564. package/es/extensions/forms/Value/Boolean/Boolean.d.ts +5 -1
  565. package/es/extensions/forms/Value/Boolean/Boolean.js +5 -3
  566. package/es/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  567. package/es/extensions/forms/Value/Boolean/BooleanDocs.d.ts +2 -0
  568. package/es/extensions/forms/Value/Boolean/BooleanDocs.js +13 -0
  569. package/es/extensions/forms/Value/Boolean/BooleanDocs.js.map +1 -0
  570. package/es/extensions/forms/Value/Number/Number.d.ts +5 -1
  571. package/es/extensions/forms/Value/Number/Number.js +18 -5
  572. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  573. package/es/extensions/forms/Value/Number/NumberDocs.d.ts +2 -0
  574. package/es/extensions/forms/Value/Number/NumberDocs.js +13 -0
  575. package/es/extensions/forms/Value/Number/NumberDocs.js.map +1 -0
  576. package/es/extensions/forms/Value/ValueDocs.js +6 -1
  577. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  578. package/es/extensions/forms/ValueBlock/ValueBlock.js +16 -2
  579. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  580. package/es/extensions/forms/Wizard/Buttons/Buttons.js +2 -1
  581. package/es/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  582. package/es/extensions/forms/Wizard/Container/WizardContainer.js +83 -36
  583. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  584. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  585. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  586. package/es/extensions/forms/Wizard/EditButton/EditButton.js +7 -2
  587. package/es/extensions/forms/Wizard/EditButton/EditButton.js.map +1 -1
  588. package/es/extensions/forms/Wizard/Step/Step.d.ts +4 -0
  589. package/es/extensions/forms/Wizard/Step/Step.js +7 -4
  590. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  591. package/es/extensions/forms/Wizard/Step/StepDocs.js +5 -0
  592. package/es/extensions/forms/Wizard/Step/StepDocs.js.map +1 -1
  593. package/es/extensions/forms/Wizard/hooks/useStep.js +17 -1
  594. package/es/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  595. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +1 -1
  596. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  597. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
  598. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +13 -0
  599. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +151 -0
  600. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -0
  601. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.d.ts +2 -0
  602. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +18 -0
  603. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -0
  604. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +77 -0
  605. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +77 -0
  606. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -0
  607. package/es/extensions/forms/blocks/ChildrenWithAge/index.d.ts +2 -0
  608. package/es/extensions/forms/blocks/ChildrenWithAge/index.js +3 -0
  609. package/es/extensions/forms/blocks/ChildrenWithAge/index.js.map +1 -0
  610. package/es/extensions/forms/blocks/index.d.ts +1 -0
  611. package/es/extensions/forms/blocks/index.js +1 -0
  612. package/es/extensions/forms/blocks/index.js.map +1 -0
  613. package/es/extensions/forms/constants/locales/en-GB.js +2 -2
  614. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  615. package/es/extensions/forms/hooks/DataValueDocs.js +10 -10
  616. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  617. package/es/extensions/forms/hooks/index.d.ts +2 -5
  618. package/es/extensions/forms/hooks/index.js +2 -1
  619. package/es/extensions/forms/hooks/index.js.map +1 -1
  620. package/es/extensions/forms/hooks/useDataValue.d.ts +9 -0
  621. package/es/extensions/forms/hooks/useDataValue.js +32 -0
  622. package/es/extensions/forms/hooks/useDataValue.js.map +1 -0
  623. package/es/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  624. package/es/extensions/forms/hooks/useExternalValue.js +41 -0
  625. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -0
  626. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  627. package/es/extensions/forms/hooks/useFieldProps.js +67 -82
  628. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  629. package/es/extensions/forms/hooks/usePath.d.ts +14 -0
  630. package/es/extensions/forms/hooks/usePath.js +64 -0
  631. package/es/extensions/forms/hooks/usePath.js.map +1 -0
  632. package/es/extensions/forms/hooks/useValueProps.js +19 -6
  633. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  634. package/es/extensions/forms/index.d.ts +2 -0
  635. package/es/extensions/forms/index.js +1 -0
  636. package/es/extensions/forms/index.js.map +1 -1
  637. package/es/extensions/forms/style/dnb-forms.css +5 -3
  638. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  639. package/es/extensions/forms/types.d.ts +16 -7
  640. package/es/extensions/forms/types.js.map +1 -1
  641. package/es/fragments/drawer-list/DrawerListHelpers.js +3 -2
  642. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  643. package/es/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +12 -1
  644. package/es/shared/Context.d.ts +4 -4
  645. package/es/shared/Context.js +9 -9
  646. package/es/shared/Context.js.map +1 -1
  647. package/es/shared/Eufemia.d.ts +1 -1
  648. package/es/shared/Eufemia.js +2 -2
  649. package/es/shared/Eufemia.js.map +1 -1
  650. package/es/shared/component-helper.d.ts +3 -1
  651. package/es/shared/component-helper.js +25 -2
  652. package/es/shared/component-helper.js.map +1 -1
  653. package/es/style/core/scopes.scss +1 -1
  654. package/es/style/dnb-ui-basis.css +1 -1
  655. package/es/style/dnb-ui-basis.min.css +1 -1
  656. package/es/style/dnb-ui-body.css +1 -1
  657. package/es/style/dnb-ui-body.min.css +1 -1
  658. package/es/style/dnb-ui-components.css +45 -14
  659. package/es/style/dnb-ui-components.min.css +3 -3
  660. package/es/style/dnb-ui-core.css +1 -1
  661. package/es/style/dnb-ui-core.min.css +1 -1
  662. package/es/style/dnb-ui-extensions.css +5 -3
  663. package/es/style/dnb-ui-extensions.min.css +1 -1
  664. package/es/style/dnb-ui-forms.css +5 -3
  665. package/es/style/dnb-ui-forms.min.css +1 -1
  666. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +53 -17
  667. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  668. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +5 -3
  669. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  670. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +5 -3
  671. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  672. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +118 -76
  673. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -8
  674. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  675. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +5 -3
  676. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  677. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +5 -3
  678. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  679. package/es/style/themes/theme-ui/ui-theme-components.css +53 -17
  680. package/es/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  681. package/es/style/themes/theme-ui/ui-theme-extensions.css +5 -3
  682. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  683. package/es/style/themes/theme-ui/ui-theme-forms.css +5 -3
  684. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  685. package/esm/dnb-ui-basis.min.mjs +1 -1
  686. package/esm/dnb-ui-components.min.mjs +1 -1
  687. package/esm/dnb-ui-elements.min.mjs +1 -1
  688. package/esm/dnb-ui-extensions.min.mjs +5 -5
  689. package/esm/dnb-ui-lib.min.mjs +1 -1
  690. package/extensions/forms/DataContext/Context.d.ts +8 -5
  691. package/extensions/forms/DataContext/Context.js +0 -1
  692. package/extensions/forms/DataContext/Context.js.map +1 -1
  693. package/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  694. package/extensions/forms/DataContext/Provider/Provider.js +33 -6
  695. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  696. package/extensions/forms/DataContext/Provider/ProviderDocs.js +7 -2
  697. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  698. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  699. package/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  700. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  701. package/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  702. package/extensions/forms/Field/Composition/Composition.js.map +1 -1
  703. package/extensions/forms/Field/Composition/CompositionDocs.d.ts +2 -0
  704. package/extensions/forms/Field/Composition/CompositionDocs.js +14 -0
  705. package/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -0
  706. package/extensions/forms/Field/Number/Number.d.ts +1 -0
  707. package/extensions/forms/Field/Number/Number.js +18 -15
  708. package/extensions/forms/Field/Number/Number.js.map +1 -1
  709. package/extensions/forms/Field/Number/NumberDocs.js +6 -1
  710. package/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  711. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  712. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  713. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  714. package/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  715. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  716. package/extensions/forms/Field/Selection/Selection.js +5 -6
  717. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  718. package/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  719. package/extensions/forms/Field/Slider/Slider.js +104 -0
  720. package/extensions/forms/Field/Slider/Slider.js.map +1 -0
  721. package/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  722. package/extensions/forms/Field/Slider/SliderDocs.js +26 -0
  723. package/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  724. package/extensions/forms/Field/Slider/index.d.ts +2 -0
  725. package/extensions/forms/Field/Slider/index.js +3 -0
  726. package/extensions/forms/Field/Slider/index.js.map +1 -0
  727. package/extensions/forms/Field/String/String.js +2 -2
  728. package/extensions/forms/Field/String/String.js.map +1 -1
  729. package/extensions/forms/Field/Toggle/Toggle.js +7 -7
  730. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  731. package/extensions/forms/Field/index.d.ts +1 -0
  732. package/extensions/forms/Field/index.js +1 -0
  733. package/extensions/forms/Field/index.js.map +1 -1
  734. package/extensions/forms/FieldBlock/FieldBlock.d.ts +4 -1
  735. package/extensions/forms/FieldBlock/FieldBlock.js +15 -3
  736. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  737. package/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  738. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  739. package/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -1
  740. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  741. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -2
  742. package/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  743. package/extensions/forms/Form/FieldProps/FieldProps.js +46 -25
  744. package/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  745. package/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  746. package/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  747. package/extensions/forms/Form/MainHeading/MainHeading.js +1 -0
  748. package/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  749. package/extensions/forms/Form/Section/Section.d.ts +36 -0
  750. package/extensions/forms/Form/Section/Section.js +68 -0
  751. package/extensions/forms/Form/Section/Section.js.map +1 -0
  752. package/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  753. package/extensions/forms/Form/Section/SectionContext.js +4 -0
  754. package/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  755. package/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  756. package/extensions/forms/Form/Section/SectionDocs.js +45 -0
  757. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  758. package/extensions/forms/Form/Section/index.d.ts +2 -0
  759. package/extensions/forms/Form/Section/index.js +3 -0
  760. package/extensions/forms/Form/Section/index.js.map +1 -0
  761. package/extensions/forms/Form/SubHeading/SubHeading.js +1 -0
  762. package/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  763. package/extensions/forms/Form/Visibility/Visibility.js +16 -10
  764. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  765. package/extensions/forms/Form/data-context/useData.js +6 -2
  766. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  767. package/extensions/forms/Form/index.d.ts +1 -1
  768. package/extensions/forms/Form/index.js +1 -2
  769. package/extensions/forms/Form/index.js.map +1 -1
  770. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +2 -2
  771. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  772. package/extensions/forms/Iterate/Array/Array.js +37 -1
  773. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  774. package/extensions/forms/Iterate/Array/ArrayDocs.js +15 -0
  775. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  776. package/extensions/forms/Iterate/Array/types.d.ts +9 -3
  777. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  778. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -2
  779. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  780. package/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  781. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  782. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  783. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  784. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -2
  785. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  786. package/extensions/forms/Iterate/style/dnb-form-iterate.css +1 -1
  787. package/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  788. package/extensions/forms/Iterate/style/dnb-form-iterate.scss +1 -0
  789. package/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  790. package/extensions/forms/Tools/GenerateSchema.js +133 -0
  791. package/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  792. package/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  793. package/extensions/forms/Tools/ListAllProps.js +67 -0
  794. package/extensions/forms/Tools/ListAllProps.js.map +1 -0
  795. package/{cjs/extensions/forms/Form → extensions/forms}/Tools/index.d.ts +1 -0
  796. package/extensions/forms/Tools/index.js +3 -0
  797. package/extensions/forms/Tools/index.js.map +1 -0
  798. package/extensions/forms/Value/Boolean/Boolean.d.ts +5 -1
  799. package/extensions/forms/Value/Boolean/Boolean.js +5 -3
  800. package/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  801. package/extensions/forms/Value/Boolean/BooleanDocs.d.ts +2 -0
  802. package/extensions/forms/Value/Boolean/BooleanDocs.js +13 -0
  803. package/extensions/forms/Value/Boolean/BooleanDocs.js.map +1 -0
  804. package/extensions/forms/Value/Number/Number.d.ts +5 -1
  805. package/extensions/forms/Value/Number/Number.js +18 -5
  806. package/extensions/forms/Value/Number/Number.js.map +1 -1
  807. package/extensions/forms/Value/Number/NumberDocs.d.ts +2 -0
  808. package/extensions/forms/Value/Number/NumberDocs.js +13 -0
  809. package/extensions/forms/Value/Number/NumberDocs.js.map +1 -0
  810. package/extensions/forms/Value/ValueDocs.js +6 -1
  811. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  812. package/extensions/forms/ValueBlock/ValueBlock.js +16 -2
  813. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  814. package/extensions/forms/Wizard/Buttons/Buttons.js +2 -1
  815. package/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  816. package/extensions/forms/Wizard/Container/WizardContainer.js +91 -43
  817. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  818. package/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  819. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  820. package/extensions/forms/Wizard/EditButton/EditButton.js +7 -2
  821. package/extensions/forms/Wizard/EditButton/EditButton.js.map +1 -1
  822. package/extensions/forms/Wizard/Step/Step.d.ts +4 -0
  823. package/extensions/forms/Wizard/Step/Step.js +7 -4
  824. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  825. package/extensions/forms/Wizard/Step/StepDocs.js +5 -0
  826. package/extensions/forms/Wizard/Step/StepDocs.js.map +1 -1
  827. package/extensions/forms/Wizard/hooks/useStep.js +17 -1
  828. package/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  829. package/extensions/forms/Wizard/style/dnb-wizard-layout.css +1 -1
  830. package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  831. package/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
  832. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +13 -0
  833. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +156 -0
  834. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -0
  835. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.d.ts +2 -0
  836. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +18 -0
  837. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -0
  838. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +77 -0
  839. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +77 -0
  840. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -0
  841. package/extensions/forms/blocks/ChildrenWithAge/index.d.ts +2 -0
  842. package/extensions/forms/blocks/ChildrenWithAge/index.js +3 -0
  843. package/extensions/forms/blocks/ChildrenWithAge/index.js.map +1 -0
  844. package/extensions/forms/blocks/index.d.ts +1 -0
  845. package/extensions/forms/blocks/index.js +1 -0
  846. package/extensions/forms/blocks/index.js.map +1 -0
  847. package/extensions/forms/constants/locales/en-GB.js +2 -2
  848. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  849. package/extensions/forms/hooks/DataValueDocs.js +10 -10
  850. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  851. package/extensions/forms/hooks/index.d.ts +2 -5
  852. package/extensions/forms/hooks/index.js +2 -1
  853. package/extensions/forms/hooks/index.js.map +1 -1
  854. package/extensions/forms/hooks/useDataValue.d.ts +9 -0
  855. package/extensions/forms/hooks/useDataValue.js +33 -0
  856. package/extensions/forms/hooks/useDataValue.js.map +1 -0
  857. package/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  858. package/extensions/forms/hooks/useExternalValue.js +41 -0
  859. package/extensions/forms/hooks/useExternalValue.js.map +1 -0
  860. package/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  861. package/extensions/forms/hooks/useFieldProps.js +67 -82
  862. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  863. package/extensions/forms/hooks/usePath.d.ts +14 -0
  864. package/extensions/forms/hooks/usePath.js +66 -0
  865. package/extensions/forms/hooks/usePath.js.map +1 -0
  866. package/extensions/forms/hooks/useValueProps.js +19 -6
  867. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  868. package/extensions/forms/index.d.ts +2 -0
  869. package/extensions/forms/index.js +2 -0
  870. package/extensions/forms/index.js.map +1 -1
  871. package/extensions/forms/style/dnb-forms.css +5 -3
  872. package/extensions/forms/style/dnb-forms.min.css +1 -1
  873. package/extensions/forms/types.d.ts +16 -7
  874. package/extensions/forms/types.js.map +1 -1
  875. package/fragments/drawer-list/DrawerListHelpers.js +3 -2
  876. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  877. package/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +12 -1
  878. package/package.json +2 -2
  879. package/shared/Context.d.ts +4 -4
  880. package/shared/Context.js +9 -9
  881. package/shared/Context.js.map +1 -1
  882. package/shared/Eufemia.d.ts +1 -1
  883. package/shared/Eufemia.js +2 -2
  884. package/shared/Eufemia.js.map +1 -1
  885. package/shared/component-helper.d.ts +3 -1
  886. package/shared/component-helper.js +35 -8
  887. package/shared/component-helper.js.map +1 -1
  888. package/style/core/scopes.scss +1 -1
  889. package/style/dnb-ui-basis.css +1 -1
  890. package/style/dnb-ui-basis.min.css +1 -1
  891. package/style/dnb-ui-body.css +1 -1
  892. package/style/dnb-ui-body.min.css +1 -1
  893. package/style/dnb-ui-components.css +45 -14
  894. package/style/dnb-ui-components.min.css +3 -3
  895. package/style/dnb-ui-core.css +1 -1
  896. package/style/dnb-ui-core.min.css +1 -1
  897. package/style/dnb-ui-extensions.css +5 -3
  898. package/style/dnb-ui-extensions.min.css +1 -1
  899. package/style/dnb-ui-forms.css +5 -3
  900. package/style/dnb-ui-forms.min.css +1 -1
  901. package/style/themes/theme-eiendom/eiendom-theme-components.css +53 -17
  902. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  903. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +5 -3
  904. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  905. package/style/themes/theme-eiendom/eiendom-theme-forms.css +5 -3
  906. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  907. package/style/themes/theme-sbanken/sbanken-theme-components.css +118 -76
  908. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -8
  909. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  910. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +5 -3
  911. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  912. package/style/themes/theme-sbanken/sbanken-theme-forms.css +5 -3
  913. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  914. package/style/themes/theme-ui/ui-theme-components.css +53 -17
  915. package/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  916. package/style/themes/theme-ui/ui-theme-extensions.css +5 -3
  917. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  918. package/style/themes/theme-ui/ui-theme-forms.css +5 -3
  919. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  920. package/umd/dnb-ui-basis.min.js +1 -1
  921. package/umd/dnb-ui-components.min.js +1 -1
  922. package/umd/dnb-ui-elements.min.js +1 -1
  923. package/umd/dnb-ui-extensions.min.js +5 -5
  924. package/umd/dnb-ui-lib.min.js +1 -1
  925. package/cjs/extensions/forms/Form/Tools/GenerateSchema.d.ts +0 -8
  926. package/cjs/extensions/forms/Form/Tools/GenerateSchema.js +0 -100
  927. package/cjs/extensions/forms/Form/Tools/GenerateSchema.js.map +0 -1
  928. package/cjs/extensions/forms/Form/Tools/index.js.map +0 -1
  929. package/es/extensions/forms/Form/Tools/GenerateSchema.d.ts +0 -8
  930. package/es/extensions/forms/Form/Tools/GenerateSchema.js +0 -89
  931. package/es/extensions/forms/Form/Tools/GenerateSchema.js.map +0 -1
  932. package/es/extensions/forms/Form/Tools/index.js +0 -1
  933. package/es/extensions/forms/Form/Tools/index.js.map +0 -1
  934. package/extensions/forms/Form/Tools/GenerateSchema.d.ts +0 -8
  935. package/extensions/forms/Form/Tools/GenerateSchema.js +0 -90
  936. package/extensions/forms/Form/Tools/GenerateSchema.js.map +0 -1
  937. package/extensions/forms/Form/Tools/index.js +0 -1
  938. package/extensions/forms/Form/Tools/index.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","pickSpacingProps","pickFlexContainerProps","IterateElementContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","path","value","arrayValue","withoutFlex","emptyValue","placeholder","handleChange","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","current","elementData","_ref","map","index","_valueCountRef$curren","id","hasNewItems","length","push","isNew","containerMode","switchContainerMode","mode","_isNewRef$current","newArrayValue","_objectSpread","set","handlePush","element","handleRemove","keepItems","arguments","undefined","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","WrapperElement","Stack","createElement","elementProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n Fragment,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const {\n path,\n value: arrayValue,\n withoutFlex,\n emptyValue,\n placeholder,\n handleChange,\n onChange,\n children,\n } = useFieldProps<Value, Props>(props)\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<Record<Identifier, ContainerMode>>({})\n const valueWhileClosingRef = useRef<Array<unknown>>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const elementData = useMemo(() => {\n return ((valueWhileClosingRef.current || arrayValue) ?? []).map(\n (value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]) {\n modesRef.current[id] = isNew ? 'edit' : 'view'\n }\n\n return {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id],\n switchContainerMode: (mode: ContainerMode) => {\n modesRef.current[id] = mode\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path: Path, value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element: unknown) => {\n hadPushRef.current = true\n handleChange([...(arrayValue ?? []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n },\n } as IterateElementContextState\n }\n )\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = elementData?.[elementData.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, elementData, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames('dnb-forms-iterate', props?.className),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <WrapperElement {...(omitFlex ? null : flexProps)}>\n {arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : elementData.map((elementProps) => {\n const { id, value, index } = elementProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...elementProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateElementContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateElementContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
1
+ {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","pickSpacingProps","pickFlexContainerProps","IterateElementContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","structuredClone","useDataValue","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","getValue","preparedProps","path","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","withoutFlex","emptyValue","placeholder","handleChange","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","current","elementData","_ref","map","_valueCountRef$curren","id","hasNewItems","isNew","containerMode","switchContainerMode","mode","_isNewRef$current","newArrayValue","set","handlePush","element","handleRemove","keepItems","arguments","undefined","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","WrapperElement","Stack","createElement","elementProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n Fragment,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\nimport useDataValue from '../../hooks/useDataValue'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const { getValue } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValue(path)\n let countValue = parseFloat(getValue(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n ...props,\n value: newValue,\n }\n }\n }\n\n return props\n }, [getValue, props])\n\n const {\n path,\n value: arrayValue,\n withoutFlex,\n emptyValue,\n placeholder,\n handleChange,\n onChange,\n children,\n } = useFieldProps<Value, Props>(preparedProps)\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<Record<Identifier, ContainerMode>>({})\n const valueWhileClosingRef = useRef<Array<unknown>>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const elementData = useMemo(() => {\n return ((valueWhileClosingRef.current || arrayValue) ?? []).map(\n (value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]) {\n modesRef.current[id] = isNew ? 'edit' : 'view'\n }\n\n return {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id],\n switchContainerMode: (mode: ContainerMode) => {\n modesRef.current[id] = mode\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path: Path, value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element: unknown) => {\n hadPushRef.current = true\n handleChange([...(arrayValue ?? []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n },\n } as IterateElementContextState\n }\n )\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = elementData?.[elementData.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, elementData, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames('dnb-forms-iterate', props?.className),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <WrapperElement {...(omitFlex ? null : flexProps)}>\n {arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : elementData.map((elementProps) => {\n const { id, value, index } = elementProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...elementProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateElementContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateElementContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
@@ -9,6 +9,21 @@ export const ArrayProperties = {
9
9
  type: 'string',
10
10
  status: 'optional'
11
11
  },
12
+ countPath: {
13
+ doc: 'A path (JSON Pointer) to the array length.',
14
+ type: 'string',
15
+ status: 'optional'
16
+ },
17
+ countPathTransform: {
18
+ doc: 'Will transform the current value before it is displayed.',
19
+ type: 'function',
20
+ status: 'optional'
21
+ },
22
+ countPathLimit: {
23
+ doc: 'Will limit the iterate amount by given "countPathLimit" value.',
24
+ type: 'number',
25
+ status: 'optional'
26
+ },
12
27
  withoutFlex: {
13
28
  doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',
14
29
  type: 'boolean',
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayDocs.js","names":["ArrayProperties","value","doc","type","status","path","withoutFlex","placeholder","emptyValue","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,WAAW,EAAE;IACXJ,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDG,WAAW,EAAE;IACXL,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDI,UAAU,EAAE;IACVN,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDK,QAAQ,EAAE;IACRP,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMM,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRT,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"ArrayDocs.js","names":["ArrayProperties","value","doc","type","status","path","countPath","countPathTransform","countPathLimit","withoutFlex","placeholder","emptyValue","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,cAAc,EAAE;IACdN,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,QAAQ,EAAE;IACRV,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMS,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRZ,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -1,13 +1,19 @@
1
1
  /// <reference types="react" />
2
- import { UseFieldProps } from '../../types';
2
+ import { Path, UseFieldProps } from '../../types';
3
3
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
4
4
  export type ContainerMode = 'view' | 'edit';
5
5
  export type Value = Array<unknown | Record<string, unknown>>;
6
6
  export type ElementChild = React.ReactNode | ((value: any, index: number) => React.ReactNode);
7
- export type Props = Omit<FlexContainerProps, 'children' | 'width'> & {
7
+ export type Props = Omit<FlexContainerProps, 'children' | 'width' | 'defaultValue'> & {
8
8
  children: ElementChild | Array<ElementChild>;
9
9
  value?: UseFieldProps<Value, undefined | Value>['value'];
10
- path?: UseFieldProps<Value, undefined | Value>['path'];
10
+ path?: Path;
11
+ countPath?: Path;
12
+ countPathLimit?: number;
13
+ countPathTransform?: (params: {
14
+ value: any;
15
+ index: number;
16
+ }) => any;
11
17
  withoutFlex?: boolean;
12
18
  emptyValue?: UseFieldProps<Value, undefined | Value>['emptyValue'];
13
19
  placeholder?: React.ReactNode;
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { UseFieldProps } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit'\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<FlexContainerProps, 'children' | 'width'> & {\n children: ElementChild | Array<ElementChild>\n value?: UseFieldProps<Value, undefined | Value>['value']\n path?: UseFieldProps<Value, undefined | Value>['path']\n withoutFlex?: boolean\n emptyValue?: UseFieldProps<Value, undefined | Value>['emptyValue']\n placeholder?: React.ReactNode\n onChange?: UseFieldProps<Value, undefined | Value>['onChange']\n}\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit'\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 'children' | 'width' | 'defaultValue'\n> & {\n children: ElementChild | Array<ElementChild>\n value?: UseFieldProps<Value, undefined | Value>['value']\n path?: Path\n countPath?: Path\n countPathLimit?: number\n countPathTransform?: (params: { value: any; index: number }) => any\n withoutFlex?: boolean\n emptyValue?: UseFieldProps<Value, undefined | Value>['emptyValue']\n placeholder?: React.ReactNode\n onChange?: UseFieldProps<Value, undefined | Value>['onChange']\n}\n"],"mappings":""}
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
3
- import { ElementBlockProps } from '../AnimatedContainer/ElementBlock';
3
+ import { ElementSectionProps } from '../AnimatedContainer/ElementBlock';
4
4
  export type Props = {
5
5
  /**
6
6
  * The title of the EditContainer.
@@ -21,7 +21,7 @@ export type Props = {
21
21
  */
22
22
  toolbar?: React.ReactNode;
23
23
  };
24
- export type AllProps = Props & FlexContainerProps & ElementBlockProps;
24
+ export type AllProps = Props & FlexContainerProps & ElementSectionProps;
25
25
  declare function EditContainer(props: AllProps): import("react/jsx-runtime").JSX.Element;
26
26
  declare namespace EditContainer {
27
27
  var _supportsSpacingProps: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"EditContainer.js","names":["React","useContext","useEffect","useMemo","useRef","classnames","convertJsxToString","Lead","IterateElementContext","EditToolbarTools","ElementBlock","Toolbar","EditContainer","props","createElement","EditContainerWithoutToolbar","_extends","toolbar","_Toolbar","iterateElementContext","containerMode","isNew","_ref","children","className","title","titleWhenNew","restProps","_objectWithoutProperties","_excluded","wasNewRef","current","blockTitle","ariaLabel","mode","size","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useEffect, useMemo, useRef } 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 IterateElementContext from '../IterateElementContext'\nimport EditToolbarTools from './EditToolbarTools'\nimport ElementBlock, {\n ElementBlockProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\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 * Used internally.\n */\n open?: boolean\n\n /**\n * The toolbar to be shown in the EditContainer.\n * Used internally.\n */\n toolbar?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementBlockProps\n\nexport default function EditContainer(props: AllProps) {\n return (\n <EditContainerWithoutToolbar\n toolbar={\n <Toolbar>\n <EditToolbarTools />\n </Toolbar>\n }\n {...props}\n />\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const iterateElementContext = useContext(IterateElementContext)\n const { containerMode, isNew } = iterateElementContext ?? {}\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n ...restProps\n } = props || {}\n\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n const blockTitle =\n wasNewRef.current && titleWhenNew ? titleWhenNew : title\n const ariaLabel = useMemo(\n () => convertJsxToString(blockTitle),\n [blockTitle]\n )\n\n return (\n <ElementBlock\n mode=\"edit\"\n className={classnames('dnb-forms-iterate-edit-block', className)}\n ariaLabel={ariaLabel}\n {...restProps}\n >\n {blockTitle && <Lead size=\"basis\">{blockTitle}</Lead>}\n {children}\n {toolbar}\n </ElementBlock>\n )\n}\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,MAAM,QAAQ,OAAO;AACrE,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,sBAAsB;AAE3C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,OAAOC,gBAAgB,MAAM,oBAAoB;AACjD,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AA4BhC,eAAe,SAASC,aAAaA,CAACC,KAAe,EAAE;EACrD,OACEb,KAAA,CAAAc,aAAA,CAACC,2BAA2B,EAAAC,QAAA;IAC1BC,OAAO,EAAAC,QAAA,KAAAA,QAAA,GACLlB,KAAA,CAAAc,aAAA,CAACH,OAAO,QACNX,KAAA,CAAAc,aAAA,CAACL,gBAAgB,MAAE,CACZ,CAAC;EACX,GACGI,KAAK,CACV,CAAC;AAEN;AAEA,OAAO,SAASE,2BAA2BA,CACzCF,KAAiE,EACjE;EACA,MAAMM,qBAAqB,GAAGlB,UAAU,CAACO,qBAAqB,CAAC;EAC/D,MAAM;IAAEY,aAAa;IAAEC;EAAM,CAAC,GAAGF,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE5D,MAAAG,IAAA,GAOIT,KAAK,IAAI,CAAC,CAAC;IAPT;MACJU,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,YAAY;MACZT;IAEF,CAAC,GAAAK,IAAA;IADIK,SAAS,GAAAC,wBAAA,CAAAN,IAAA,EAAAO,SAAA;EAGd,MAAMC,SAAS,GAAG1B,MAAM,CAAUiB,KAAK,CAAC;EAExCnB,SAAS,CAAC,MAAM;IACd,IAAIkB,aAAa,KAAK,MAAM,EAAE;MAC5BU,SAAS,CAACC,OAAO,GAAG,KAAK;IAC3B;EACF,CAAC,EAAE,CAACV,KAAK,EAAED,aAAa,CAAC,CAAC;EAE1B,MAAMY,UAAU,GACdF,SAAS,CAACC,OAAO,IAAIL,YAAY,GAAGA,YAAY,GAAGD,KAAK;EAC1D,MAAMQ,SAAS,GAAG9B,OAAO,CACvB,MAAMG,kBAAkB,CAAC0B,UAAU,CAAC,EACpC,CAACA,UAAU,CACb,CAAC;EAED,OACEhC,KAAA,CAAAc,aAAA,CAACJ,YAAY,EAAAM,QAAA;IACXkB,IAAI,EAAC,MAAM;IACXV,SAAS,EAAEnB,UAAU,CAAC,8BAA8B,EAAEmB,SAAS,CAAE;IACjES,SAAS,EAAEA;EAAU,GACjBN,SAAS,GAEZK,UAAU,IAAIhC,KAAA,CAAAc,aAAA,CAACP,IAAI;IAAC4B,IAAI,EAAC;EAAO,GAAEH,UAAiB,CAAC,EACpDT,QAAQ,EACRN,OACW,CAAC;AAEnB;AAEAL,aAAa,CAACwB,qBAAqB,GAAG,IAAI;AAC1CrB,2BAA2B,CAACqB,qBAAqB,GAAG,IAAI"}
1
+ {"version":3,"file":"EditContainer.js","names":["React","useContext","useEffect","useMemo","useRef","classnames","convertJsxToString","Lead","IterateElementContext","EditToolbarTools","ElementBlock","Toolbar","EditContainer","props","createElement","EditContainerWithoutToolbar","_extends","toolbar","_Toolbar","iterateElementContext","containerMode","isNew","_ref","children","className","title","titleWhenNew","restProps","_objectWithoutProperties","_excluded","wasNewRef","current","blockTitle","ariaLabel","mode","size","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useEffect, useMemo, useRef } 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 IterateElementContext from '../IterateElementContext'\nimport EditToolbarTools from './EditToolbarTools'\nimport ElementBlock, {\n ElementSectionProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\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 * Used internally.\n */\n open?: boolean\n\n /**\n * The toolbar to be shown in the EditContainer.\n * Used internally.\n */\n toolbar?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementSectionProps\n\nexport default function EditContainer(props: AllProps) {\n return (\n <EditContainerWithoutToolbar\n toolbar={\n <Toolbar>\n <EditToolbarTools />\n </Toolbar>\n }\n {...props}\n />\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const iterateElementContext = useContext(IterateElementContext)\n const { containerMode, isNew } = iterateElementContext ?? {}\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n ...restProps\n } = props || {}\n\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n const blockTitle =\n wasNewRef.current && titleWhenNew ? titleWhenNew : title\n const ariaLabel = useMemo(\n () => convertJsxToString(blockTitle),\n [blockTitle]\n )\n\n return (\n <ElementBlock\n mode=\"edit\"\n className={classnames('dnb-forms-iterate-edit-block', className)}\n ariaLabel={ariaLabel}\n {...restProps}\n >\n {blockTitle && <Lead size=\"basis\">{blockTitle}</Lead>}\n {children}\n {toolbar}\n </ElementBlock>\n )\n}\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,MAAM,QAAQ,OAAO;AACrE,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,sBAAsB;AAE3C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,OAAOC,gBAAgB,MAAM,oBAAoB;AACjD,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AA4BhC,eAAe,SAASC,aAAaA,CAACC,KAAe,EAAE;EACrD,OACEb,KAAA,CAAAc,aAAA,CAACC,2BAA2B,EAAAC,QAAA;IAC1BC,OAAO,EAAAC,QAAA,KAAAA,QAAA,GACLlB,KAAA,CAAAc,aAAA,CAACH,OAAO,QACNX,KAAA,CAAAc,aAAA,CAACL,gBAAgB,MAAE,CACZ,CAAC;EACX,GACGI,KAAK,CACV,CAAC;AAEN;AAEA,OAAO,SAASE,2BAA2BA,CACzCF,KAAiE,EACjE;EACA,MAAMM,qBAAqB,GAAGlB,UAAU,CAACO,qBAAqB,CAAC;EAC/D,MAAM;IAAEY,aAAa;IAAEC;EAAM,CAAC,GAAGF,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE5D,MAAAG,IAAA,GAOIT,KAAK,IAAI,CAAC,CAAC;IAPT;MACJU,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,YAAY;MACZT;IAEF,CAAC,GAAAK,IAAA;IADIK,SAAS,GAAAC,wBAAA,CAAAN,IAAA,EAAAO,SAAA;EAGd,MAAMC,SAAS,GAAG1B,MAAM,CAAUiB,KAAK,CAAC;EAExCnB,SAAS,CAAC,MAAM;IACd,IAAIkB,aAAa,KAAK,MAAM,EAAE;MAC5BU,SAAS,CAACC,OAAO,GAAG,KAAK;IAC3B;EACF,CAAC,EAAE,CAACV,KAAK,EAAED,aAAa,CAAC,CAAC;EAE1B,MAAMY,UAAU,GACdF,SAAS,CAACC,OAAO,IAAIL,YAAY,GAAGA,YAAY,GAAGD,KAAK;EAC1D,MAAMQ,SAAS,GAAG9B,OAAO,CACvB,MAAMG,kBAAkB,CAAC0B,UAAU,CAAC,EACpC,CAACA,UAAU,CACb,CAAC;EAED,OACEhC,KAAA,CAAAc,aAAA,CAACJ,YAAY,EAAAM,QAAA;IACXkB,IAAI,EAAC,MAAM;IACXV,SAAS,EAAEnB,UAAU,CAAC,8BAA8B,EAAEmB,SAAS,CAAE;IACjES,SAAS,EAAEA;EAAU,GACjBN,SAAS,GAEZK,UAAU,IAAIhC,KAAA,CAAAc,aAAA,CAACP,IAAI;IAAC4B,IAAI,EAAC;EAAO,GAAEH,UAAiB,CAAC,EACpDT,QAAQ,EACRN,OACW,CAAC;AAEnB;AAEAL,aAAa,CAACwB,qBAAqB,GAAG,IAAI;AAC1CrB,2BAA2B,CAACqB,qBAAqB,GAAG,IAAI"}
@@ -27,7 +27,7 @@ function PushButton(props) {
27
27
  children
28
28
  } = useFieldProps(restProps);
29
29
  if (value !== undefined && !Array.isArray(value)) {
30
- throw new Error('PushButton received a non-array value.');
30
+ throw new Error('PushButton received a non-array value');
31
31
  }
32
32
  const handleClick = useCallback(() => {
33
33
  const newValue = typeof pushValue === 'function' ? pushValue(value) : pushValue;
@@ -1 +1 @@
1
- {"version":3,"file":"PushButton.js","names":["React","useCallback","useContext","classnames","Button","IterateElementContext","useFieldProps","omitDataValueReadWriteProps","add","PushButton","props","iterateElementContext","handlePush","pushValue","className","restProps","_objectWithoutProperties","_excluded","buttonProps","value","handleChange","children","undefined","Array","isArray","Error","handleClick","newValue","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateElementContext from '../IterateElementContext'\nimport { useFieldProps } from '../../hooks'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { add } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]> & {\n pushValue: unknown | ((value: unknown) => void)\n }\n\nfunction PushButton(props: Props) {\n const iterateElementContext = useContext(IterateElementContext)\n const { handlePush } = iterateElementContext ?? {}\n\n const { pushValue, className, ...restProps } = props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { value, handleChange, children } = useFieldProps(restProps)\n\n if (value !== undefined && !Array.isArray(value)) {\n throw new Error('PushButton received a non-array value.')\n }\n\n const handleClick = useCallback(() => {\n const newValue =\n typeof pushValue === 'function' ? pushValue(value) : pushValue\n\n if (handlePush) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n return // stop here\n }\n\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n handleChange([...(value ?? []), newValue])\n }, [value, pushValue, handlePush, handleChange])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {children}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,wBAAwB;AAE/C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,aAAa,QAAQ,aAAa;AAC3C,SAEEC,2BAA2B,QACtB,aAAa;AACpB,SAASC,GAAG,QAAQ,mBAAmB;AAOvC,SAASC,UAAUA,CAACC,KAAY,EAAE;EAChC,MAAMC,qBAAqB,GAAGT,UAAU,CAACG,qBAAqB,CAAC;EAC/D,MAAM;IAAEO;EAAW,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAElD,MAAM;MAAEE,SAAS;MAAEC;IAAwB,CAAC,GAAGJ,KAAK;IAAnBK,SAAS,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA;EACpD,MAAMC,WAAW,GAAGX,2BAA2B,CAACQ,SAAS,CAAC;EAC1D,MAAM;IAAEI,KAAK;IAAEC,YAAY;IAAEC;EAAS,CAAC,GAAGf,aAAa,CAACS,SAAS,CAAC;EAElE,IAAII,KAAK,KAAKG,SAAS,IAAI,CAACC,KAAK,CAACC,OAAO,CAACL,KAAK,CAAC,EAAE;IAChD,MAAM,IAAIM,KAAK,CAAC,wCAAwC,CAAC;EAC3D;EAEA,MAAMC,WAAW,GAAGzB,WAAW,CAAC,MAAM;IACpC,MAAM0B,QAAQ,GACZ,OAAOd,SAAS,KAAK,UAAU,GAAGA,SAAS,CAACM,KAAK,CAAC,GAAGN,SAAS;IAEhE,IAAID,UAAU,EAAE;MAEdA,UAAU,CAACe,QAAQ,CAAC;MACpB;IACF;IAGAP,YAAY,CAAC,CAAC,IAAID,KAAK,aAALA,KAAK,cAALA,KAAK,GAAI,EAAE,CAAC,EAAEQ,QAAQ,CAAC,CAAC;EAC5C,CAAC,EAAE,CAACR,KAAK,EAAEN,SAAS,EAAED,UAAU,EAAEQ,YAAY,CAAC,CAAC;EAEhD,OACEpB,KAAA,CAAA4B,aAAA,CAACxB,MAAM,EAAAyB,QAAA;IACLf,SAAS,EAAEX,UAAU,CAAC,+BAA+B,EAAEW,SAAS,CAAE;IAClEgB,OAAO,EAAC,WAAW;IACnBC,IAAI,EAAEvB,GAAI;IACVwB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEP;EAAY,GAClBR,WAAW,GAEdG,QACK,CAAC;AAEb;AAEAZ,UAAU,CAACyB,qBAAqB,GAAG,IAAI;AACvC,eAAezB,UAAU"}
1
+ {"version":3,"file":"PushButton.js","names":["React","useCallback","useContext","classnames","Button","IterateElementContext","useFieldProps","omitDataValueReadWriteProps","add","PushButton","props","iterateElementContext","handlePush","pushValue","className","restProps","_objectWithoutProperties","_excluded","buttonProps","value","handleChange","children","undefined","Array","isArray","Error","handleClick","newValue","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateElementContext from '../IterateElementContext'\nimport { useFieldProps } from '../../hooks'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { add } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]> & {\n pushValue: unknown | ((value: unknown) => void)\n }\n\nfunction PushButton(props: Props) {\n const iterateElementContext = useContext(IterateElementContext)\n const { handlePush } = iterateElementContext ?? {}\n\n const { pushValue, className, ...restProps } = props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { value, handleChange, children } = useFieldProps(restProps)\n\n if (value !== undefined && !Array.isArray(value)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const handleClick = useCallback(() => {\n const newValue =\n typeof pushValue === 'function' ? pushValue(value) : pushValue\n\n if (handlePush) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n return // stop here\n }\n\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n handleChange([...(value ?? []), newValue])\n }, [value, pushValue, handlePush, handleChange])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {children}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,wBAAwB;AAE/C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,aAAa,QAAQ,aAAa;AAC3C,SAEEC,2BAA2B,QACtB,aAAa;AACpB,SAASC,GAAG,QAAQ,mBAAmB;AAOvC,SAASC,UAAUA,CAACC,KAAY,EAAE;EAChC,MAAMC,qBAAqB,GAAGT,UAAU,CAACG,qBAAqB,CAAC;EAC/D,MAAM;IAAEO;EAAW,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAElD,MAAM;MAAEE,SAAS;MAAEC;IAAwB,CAAC,GAAGJ,KAAK;IAAnBK,SAAS,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA;EACpD,MAAMC,WAAW,GAAGX,2BAA2B,CAACQ,SAAS,CAAC;EAC1D,MAAM;IAAEI,KAAK;IAAEC,YAAY;IAAEC;EAAS,CAAC,GAAGf,aAAa,CAACS,SAAS,CAAC;EAElE,IAAII,KAAK,KAAKG,SAAS,IAAI,CAACC,KAAK,CAACC,OAAO,CAACL,KAAK,CAAC,EAAE;IAChD,MAAM,IAAIM,KAAK,CAAC,uCAAuC,CAAC;EAC1D;EAEA,MAAMC,WAAW,GAAGzB,WAAW,CAAC,MAAM;IACpC,MAAM0B,QAAQ,GACZ,OAAOd,SAAS,KAAK,UAAU,GAAGA,SAAS,CAACM,KAAK,CAAC,GAAGN,SAAS;IAEhE,IAAID,UAAU,EAAE;MAEdA,UAAU,CAACe,QAAQ,CAAC;MACpB;IACF;IAGAP,YAAY,CAAC,CAAC,IAAID,KAAK,aAALA,KAAK,cAALA,KAAK,GAAI,EAAE,CAAC,EAAEQ,QAAQ,CAAC,CAAC;EAC5C,CAAC,EAAE,CAACR,KAAK,EAAEN,SAAS,EAAED,UAAU,EAAEQ,YAAY,CAAC,CAAC;EAEhD,OACEpB,KAAA,CAAA4B,aAAA,CAACxB,MAAM,EAAAyB,QAAA;IACLf,SAAS,EAAEX,UAAU,CAAC,+BAA+B,EAAEW,SAAS,CAAE;IAClEgB,OAAO,EAAC,WAAW;IACnBC,IAAI,EAAEvB,GAAI;IACVwB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEP;EAAY,GAClBR,WAAW,GAEdG,QACK,CAAC;AAEb;AAEAZ,UAAU,CAACyB,qBAAqB,GAAG,IAAI;AACvC,eAAezB,UAAU"}
@@ -17,7 +17,7 @@ function RemoveButton(props) {
17
17
  handleRemove
18
18
  } = iterateElementContext !== null && iterateElementContext !== void 0 ? iterateElementContext : {};
19
19
  if (!iterateElementContext) {
20
- throw new Error('RemoveButton must be inside an Iterate.Array component.');
20
+ throw new Error('RemoveButton must be inside an Iterate.Array');
21
21
  }
22
22
  const {
23
23
  className
@@ -1 +1 @@
1
- {"version":3,"file":"RemoveButton.js","names":["React","useCallback","useContext","classnames","Button","IterateElementContext","useFieldProps","useTranslation","ElementBlockContext","omitDataValueReadWriteProps","trash","RemoveButton","props","iterateElementContext","handleRemove","Error","className","restProps","_objectWithoutProperties","_excluded","children","text","buttonProps","translation","Iterate","textContent","remove","elementBlockContext","handleRemoveBlock","handleClick","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/RemoveButton/RemoveButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateElementContext from '../IterateElementContext'\nimport { useFieldProps, useTranslation } from '../../hooks'\nimport ElementBlockContext from '../AnimatedContainer/ElementBlockContext'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { trash } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]>\n\nfunction RemoveButton(props: Props) {\n const iterateElementContext = useContext(IterateElementContext)\n const { handleRemove } = iterateElementContext ?? {}\n\n if (!iterateElementContext) {\n throw new Error(\n 'RemoveButton must be inside an Iterate.Array component.'\n )\n }\n\n const { className, ...restProps } = props\n const { children, text } = useFieldProps(restProps)\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const translation = useTranslation().Iterate\n const textContent = text || children || translation.remove\n\n const elementBlockContext = useContext(ElementBlockContext)\n const { handleRemoveBlock } = elementBlockContext ?? {}\n\n const handleClick = useCallback(() => {\n if (handleRemoveBlock) {\n handleRemoveBlock()\n } else {\n handleRemove()\n }\n }, [handleRemove, handleRemoveBlock])\n\n return (\n <Button\n className={classnames(\n 'dnb-forms-iterate-remove-element-button',\n className\n )}\n variant={textContent ? 'tertiary' : 'secondary'}\n icon={trash}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {textContent}\n </Button>\n )\n}\n\nRemoveButton._supportsSpacingProps = true\nexport default RemoveButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,wBAAwB;AAE/C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,aAAa,EAAEC,cAAc,QAAQ,aAAa;AAC3D,OAAOC,mBAAmB,MAAM,0CAA0C;AAC1E,SAEEC,2BAA2B,QACtB,aAAa;AACpB,SAASC,KAAK,QAAQ,mBAAmB;AAKzC,SAASC,YAAYA,CAACC,KAAY,EAAE;EAClC,MAAMC,qBAAqB,GAAGX,UAAU,CAACG,qBAAqB,CAAC;EAC/D,MAAM;IAAES;EAAa,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAEpD,IAAI,CAACA,qBAAqB,EAAE;IAC1B,MAAM,IAAIE,KAAK,CACb,yDACF,CAAC;EACH;EAEA,MAAM;MAAEC;IAAwB,CAAC,GAAGJ,KAAK;IAAnBK,SAAS,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA;EACzC,MAAM;IAAEC,QAAQ;IAAEC;EAAK,CAAC,GAAGf,aAAa,CAACW,SAAS,CAAC;EACnD,MAAMK,WAAW,GAAGb,2BAA2B,CAACQ,SAAS,CAAC;EAC1D,MAAMM,WAAW,GAAGhB,cAAc,CAAC,CAAC,CAACiB,OAAO;EAC5C,MAAMC,WAAW,GAAGJ,IAAI,IAAID,QAAQ,IAAIG,WAAW,CAACG,MAAM;EAE1D,MAAMC,mBAAmB,GAAGzB,UAAU,CAACM,mBAAmB,CAAC;EAC3D,MAAM;IAAEoB;EAAkB,CAAC,GAAGD,mBAAmB,aAAnBA,mBAAmB,cAAnBA,mBAAmB,GAAI,CAAC,CAAC;EAEvD,MAAME,WAAW,GAAG5B,WAAW,CAAC,MAAM;IACpC,IAAI2B,iBAAiB,EAAE;MACrBA,iBAAiB,CAAC,CAAC;IACrB,CAAC,MAAM;MACLd,YAAY,CAAC,CAAC;IAChB;EACF,CAAC,EAAE,CAACA,YAAY,EAAEc,iBAAiB,CAAC,CAAC;EAErC,OACE5B,KAAA,CAAA8B,aAAA,CAAC1B,MAAM,EAAA2B,QAAA;IACLf,SAAS,EAAEb,UAAU,CACnB,yCAAyC,EACzCa,SACF,CAAE;IACFgB,OAAO,EAAEP,WAAW,GAAG,UAAU,GAAG,WAAY;IAChDQ,IAAI,EAAEvB,KAAM;IACZwB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEN;EAAY,GAClBP,WAAW,GAEdG,WACK,CAAC;AAEb;AAEAd,YAAY,CAACyB,qBAAqB,GAAG,IAAI;AACzC,eAAezB,YAAY"}
1
+ {"version":3,"file":"RemoveButton.js","names":["React","useCallback","useContext","classnames","Button","IterateElementContext","useFieldProps","useTranslation","ElementBlockContext","omitDataValueReadWriteProps","trash","RemoveButton","props","iterateElementContext","handleRemove","Error","className","restProps","_objectWithoutProperties","_excluded","children","text","buttonProps","translation","Iterate","textContent","remove","elementBlockContext","handleRemoveBlock","handleClick","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/RemoveButton/RemoveButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateElementContext from '../IterateElementContext'\nimport { useFieldProps, useTranslation } from '../../hooks'\nimport ElementBlockContext from '../AnimatedContainer/ElementBlockContext'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { trash } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]>\n\nfunction RemoveButton(props: Props) {\n const iterateElementContext = useContext(IterateElementContext)\n const { handleRemove } = iterateElementContext ?? {}\n\n if (!iterateElementContext) {\n throw new Error('RemoveButton must be inside an Iterate.Array')\n }\n\n const { className, ...restProps } = props\n const { children, text } = useFieldProps(restProps)\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const translation = useTranslation().Iterate\n const textContent = text || children || translation.remove\n\n const elementBlockContext = useContext(ElementBlockContext)\n const { handleRemoveBlock } = elementBlockContext ?? {}\n\n const handleClick = useCallback(() => {\n if (handleRemoveBlock) {\n handleRemoveBlock()\n } else {\n handleRemove()\n }\n }, [handleRemove, handleRemoveBlock])\n\n return (\n <Button\n className={classnames(\n 'dnb-forms-iterate-remove-element-button',\n className\n )}\n variant={textContent ? 'tertiary' : 'secondary'}\n icon={trash}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {textContent}\n </Button>\n )\n}\n\nRemoveButton._supportsSpacingProps = true\nexport default RemoveButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,wBAAwB;AAE/C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,aAAa,EAAEC,cAAc,QAAQ,aAAa;AAC3D,OAAOC,mBAAmB,MAAM,0CAA0C;AAC1E,SAEEC,2BAA2B,QACtB,aAAa;AACpB,SAASC,KAAK,QAAQ,mBAAmB;AAKzC,SAASC,YAAYA,CAACC,KAAY,EAAE;EAClC,MAAMC,qBAAqB,GAAGX,UAAU,CAACG,qBAAqB,CAAC;EAC/D,MAAM;IAAES;EAAa,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAEpD,IAAI,CAACA,qBAAqB,EAAE;IAC1B,MAAM,IAAIE,KAAK,CAAC,8CAA8C,CAAC;EACjE;EAEA,MAAM;MAAEC;IAAwB,CAAC,GAAGJ,KAAK;IAAnBK,SAAS,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA;EACzC,MAAM;IAAEC,QAAQ;IAAEC;EAAK,CAAC,GAAGf,aAAa,CAACW,SAAS,CAAC;EACnD,MAAMK,WAAW,GAAGb,2BAA2B,CAACQ,SAAS,CAAC;EAC1D,MAAMM,WAAW,GAAGhB,cAAc,CAAC,CAAC,CAACiB,OAAO;EAC5C,MAAMC,WAAW,GAAGJ,IAAI,IAAID,QAAQ,IAAIG,WAAW,CAACG,MAAM;EAE1D,MAAMC,mBAAmB,GAAGzB,UAAU,CAACM,mBAAmB,CAAC;EAC3D,MAAM;IAAEoB;EAAkB,CAAC,GAAGD,mBAAmB,aAAnBA,mBAAmB,cAAnBA,mBAAmB,GAAI,CAAC,CAAC;EAEvD,MAAME,WAAW,GAAG5B,WAAW,CAAC,MAAM;IACpC,IAAI2B,iBAAiB,EAAE;MACrBA,iBAAiB,CAAC,CAAC;IACrB,CAAC,MAAM;MACLd,YAAY,CAAC,CAAC;IAChB;EACF,CAAC,EAAE,CAACA,YAAY,EAAEc,iBAAiB,CAAC,CAAC;EAErC,OACE5B,KAAA,CAAA8B,aAAA,CAAC1B,MAAM,EAAA2B,QAAA;IACLf,SAAS,EAAEb,UAAU,CACnB,yCAAyC,EACzCa,SACF,CAAE;IACFgB,OAAO,EAAEP,WAAW,GAAG,UAAU,GAAG,WAAY;IAChDQ,IAAI,EAAEvB,KAAM;IACZwB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEN;EAAY,GAClBP,WAAW,GAEdG,WACK,CAAC;AAEb;AAEAd,YAAY,CAACyB,qBAAqB,GAAG,IAAI;AACzC,eAAezB,YAAY"}
@@ -1,13 +1,13 @@
1
1
  import React from 'react';
2
2
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
3
- import { ElementBlockProps } from '../AnimatedContainer/ElementBlock';
3
+ import { ElementSectionProps } from '../AnimatedContainer/ElementBlock';
4
4
  export type Props = {
5
5
  /**
6
6
  * The title of the ViewContainer.
7
7
  */
8
8
  title?: React.ReactNode;
9
9
  };
10
- export type AllProps = Props & FlexContainerProps & ElementBlockProps;
10
+ export type AllProps = Props & FlexContainerProps & ElementSectionProps;
11
11
  declare function ViewContainer(props: AllProps): import("react/jsx-runtime").JSX.Element;
12
12
  declare namespace ViewContainer {
13
13
  var _supportsSpacingProps: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"ViewContainer.js","names":["React","useMemo","classnames","convertJsxToString","Flex","Lead","ElementBlock","Toolbar","ViewToolbarTools","ViewContainer","props","_ref","children","className","title","restProps","_objectWithoutProperties","_excluded","ariaLabel","createElement","_extends","mode","Stack","size","_Toolbar","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { Lead } from '../../../../elements'\nimport ElementBlock, {\n ElementBlockProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\nimport ViewToolbarTools from './ViewToolbarTools'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementBlockProps\n\nfunction ViewContainer(props: AllProps) {\n const { children, className, title, ...restProps } = props || {}\n const ariaLabel = useMemo(() => convertJsxToString(title), [title])\n\n return (\n <ElementBlock\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-iterate-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {title && <Lead size=\"basis\">{title}</Lead>}\n {children}\n <Toolbar>\n <ViewToolbarTools />\n </Toolbar>\n </Flex.Stack>\n </ElementBlock>\n )\n}\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,gBAAgB,MAAM,oBAAoB;AAWjD,SAASC,aAAaA,CAACC,KAAe,EAAE;EACtC,MAAAC,IAAA,GAAqDD,KAAK,IAAI,CAAC,CAAC;IAA1D;MAAEE,QAAQ;MAAEC,SAAS;MAAEC;IAAoB,CAAC,GAAAH,IAAA;IAAXI,SAAS,GAAAC,wBAAA,CAAAL,IAAA,EAAAM,SAAA;EAChD,MAAMC,SAAS,GAAGjB,OAAO,CAAC,MAAME,kBAAkB,CAACW,KAAK,CAAC,EAAE,CAACA,KAAK,CAAC,CAAC;EAEnE,OACEd,KAAA,CAAAmB,aAAA,CAACb,YAAY,EAAAc,QAAA;IACXC,IAAI,EAAC,MAAM;IACXH,SAAS,EAAEA,SAAU;IACrBL,SAAS,EAAEX,UAAU,CAAC,8BAA8B,EAAEW,SAAS;EAAE,GAC7DE,SAAS,GAEbf,KAAA,CAAAmB,aAAA,CAACf,IAAI,CAACkB,KAAK,QACRR,KAAK,IAAId,KAAA,CAAAmB,aAAA,CAACd,IAAI;IAACkB,IAAI,EAAC;EAAO,GAAET,KAAY,CAAC,EAC1CF,QAAQ,EAAAY,QAAA,KAAAA,QAAA,GACTxB,KAAA,CAAAmB,aAAA,CAACZ,OAAO,QACNP,KAAA,CAAAmB,aAAA,CAACX,gBAAgB,MAAE,CACZ,CAAC,CACA,CACA,CAAC;AAEnB;AAEAC,aAAa,CAACgB,qBAAqB,GAAG,IAAI;AAC1C,eAAehB,aAAa"}
1
+ {"version":3,"file":"ViewContainer.js","names":["React","useMemo","classnames","convertJsxToString","Flex","Lead","ElementBlock","Toolbar","ViewToolbarTools","ViewContainer","props","_ref","children","className","title","restProps","_objectWithoutProperties","_excluded","ariaLabel","createElement","_extends","mode","Stack","size","_Toolbar","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { Lead } from '../../../../elements'\nimport ElementBlock, {\n ElementSectionProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\nimport ViewToolbarTools from './ViewToolbarTools'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementSectionProps\n\nfunction ViewContainer(props: AllProps) {\n const { children, className, title, ...restProps } = props || {}\n const ariaLabel = useMemo(() => convertJsxToString(title), [title])\n\n return (\n <ElementBlock\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-iterate-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {title && <Lead size=\"basis\">{title}</Lead>}\n {children}\n <Toolbar>\n <ViewToolbarTools />\n </Toolbar>\n </Flex.Stack>\n </ElementBlock>\n )\n}\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,gBAAgB,MAAM,oBAAoB;AAWjD,SAASC,aAAaA,CAACC,KAAe,EAAE;EACtC,MAAAC,IAAA,GAAqDD,KAAK,IAAI,CAAC,CAAC;IAA1D;MAAEE,QAAQ;MAAEC,SAAS;MAAEC;IAAoB,CAAC,GAAAH,IAAA;IAAXI,SAAS,GAAAC,wBAAA,CAAAL,IAAA,EAAAM,SAAA;EAChD,MAAMC,SAAS,GAAGjB,OAAO,CAAC,MAAME,kBAAkB,CAACW,KAAK,CAAC,EAAE,CAACA,KAAK,CAAC,CAAC;EAEnE,OACEd,KAAA,CAAAmB,aAAA,CAACb,YAAY,EAAAc,QAAA;IACXC,IAAI,EAAC,MAAM;IACXH,SAAS,EAAEA,SAAU;IACrBL,SAAS,EAAEX,UAAU,CAAC,8BAA8B,EAAEW,SAAS;EAAE,GAC7DE,SAAS,GAEbf,KAAA,CAAAmB,aAAA,CAACf,IAAI,CAACkB,KAAK,QACRR,KAAK,IAAId,KAAA,CAAAmB,aAAA,CAACd,IAAI;IAACkB,IAAI,EAAC;EAAO,GAAET,KAAY,CAAC,EAC1CF,QAAQ,EAAAY,QAAA,KAAAA,QAAA,GACTxB,KAAA,CAAAmB,aAAA,CAACZ,OAAO,QACNP,KAAA,CAAAmB,aAAA,CAACX,gBAAgB,MAAE,CACZ,CAAC,CACA,CACA,CAAC;AAEnB;AAEAC,aAAa,CAACgB,qBAAqB,GAAG,IAAI;AAC1C,eAAehB,aAAa"}
@@ -15,7 +15,7 @@
15
15
  transition: transform 400ms var(--easing-default) 50ms, box-shadow 0.8s var(--easing-default);
16
16
  transform: translateY(-2.5rem);
17
17
  }
18
- .dnb-forms-iterate-block__inner:not([class*=dnb-flex-container--spacing]) {
18
+ .dnb-forms-iterate-block--variant-basic .dnb-forms-iterate-block__inner, .dnb-forms-iterate-block__inner:not([class*=dnb-flex-container--spacing]) {
19
19
  --padding: 0;
20
20
  }
21
21
  .dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing] {
@@ -1 +1 @@
1
- .dnb-forms-iterate-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-iterate-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-iterate-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-iterate-block__inner{flex:1;margin-bottom:var(--space);padding:var(--padding,1rem);transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-iterate-block__inner:not([class*=dnb-flex-container--spacing]){--padding:0}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing]{border-radius:.375rem}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-small{--space:var(--spacing-small)}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-medium{--space:var(--spacing-medium)}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-large{--space:var(--spacing-large)}.dnb-forms-iterate-block--variant-outline .dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing]{box-shadow:inset 0 0 0 2px var(--block-outline-color)}.dnb-forms-iterate-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-iterate-block.dnb-height-animation--is-visible .dnb-forms-iterate-block__inner{transform:translateY(-.5rem)}.dnb-forms-iterate-block.dnb-height-animation--parallax .dnb-forms-iterate-block__inner{transform:translateY(0)}.dnb-forms-iterate__element{outline:none}.dnb-forms-iterate>.dnb-forms-iterate__element:has(.dnb-forms-iterate-block){margin-top:0}
1
+ .dnb-forms-iterate-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-iterate-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-iterate-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-iterate-block__inner{flex:1;margin-bottom:var(--space);padding:var(--padding,1rem);transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-iterate-block--variant-basic .dnb-forms-iterate-block__inner,.dnb-forms-iterate-block__inner:not([class*=dnb-flex-container--spacing]){--padding:0}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing]{border-radius:.375rem}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-small{--space:var(--spacing-small)}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-medium{--space:var(--spacing-medium)}.dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-large{--space:var(--spacing-large)}.dnb-forms-iterate-block--variant-outline .dnb-forms-iterate-block__inner[class*=dnb-flex-container--spacing]{box-shadow:inset 0 0 0 2px var(--block-outline-color)}.dnb-forms-iterate-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-iterate-block.dnb-height-animation--is-visible .dnb-forms-iterate-block__inner{transform:translateY(-.5rem)}.dnb-forms-iterate-block.dnb-height-animation--parallax .dnb-forms-iterate-block__inner{transform:translateY(0)}.dnb-forms-iterate__element{outline:none}.dnb-forms-iterate>.dnb-forms-iterate__element:has(.dnb-forms-iterate-block){margin-top:0}
@@ -17,6 +17,7 @@
17
17
  margin-bottom: var(--space);
18
18
  padding: var(--padding, 1rem);
19
19
 
20
+ .dnb-forms-iterate-block--variant-basic &,
20
21
  &:not([class*='dnb-flex-container--spacing']) {
21
22
  --padding: 0;
22
23
  }
@@ -0,0 +1,19 @@
1
+ /// <reference types="react" />
2
+ import { JsonObject } from 'json-pointer';
3
+ import { FilterData } from '../DataContext/Context';
4
+ import { JSONSchema } from '../types';
5
+ export type GenerateSchemaReturn = {
6
+ schema: JSONSchema;
7
+ data: JsonObject;
8
+ propsOfFields: JsonObject;
9
+ propsOfValues: JsonObject;
10
+ };
11
+ export type GenerateSchemaProps = {
12
+ log?: boolean;
13
+ generateRef?: React.MutableRefObject<() => GenerateSchemaReturn>;
14
+ filterData?: FilterData;
15
+ children: React.ReactNode;
16
+ };
17
+ export type GenerateRef = GenerateSchemaProps['generateRef']['current'];
18
+ export declare const schemaParams: string[];
19
+ export default function GenerateSchema(props: GenerateSchemaProps): import("react").ReactNode;
@@ -0,0 +1,133 @@
1
+ "use client";
2
+
3
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
5
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
+ import { useCallback, useContext, useRef } from 'react';
7
+ import pointer from 'json-pointer';
8
+ import DataContext from '../DataContext/Context';
9
+ export const schemaParams = ['minLength', 'maxLength', 'pattern', 'description', 'min', 'max', 'multipleOf', 'exclusiveMinimum', 'exclusiveMaximum'];
10
+ export default function GenerateSchema(props) {
11
+ const {
12
+ generateRef,
13
+ filterData,
14
+ log,
15
+ children
16
+ } = props || {};
17
+ const {
18
+ fieldPropsRef,
19
+ valuePropsRef,
20
+ data,
21
+ hasContext
22
+ } = useContext(DataContext);
23
+ const dataRef = useRef({});
24
+ dataRef.current = data;
25
+ const generate = useCallback(() => {
26
+ const schema = Object.entries((fieldPropsRef === null || fieldPropsRef === void 0 ? void 0 : fieldPropsRef.current) || {}).reduce((acc, _ref) => {
27
+ let [path, props] = _ref;
28
+ if (path.startsWith('/')) {
29
+ const objectKey = path.substring(1);
30
+ const pathList = objectKey.split('/');
31
+ const slashCount = pathList.length;
32
+ const type = props.valueType || 'string';
33
+ const propertyValue = {
34
+ type
35
+ };
36
+ for (const prop of schemaParams) {
37
+ if (props[prop]) {
38
+ propertyValue[prop] = props[prop];
39
+ }
40
+ }
41
+ if (slashCount > 1) {
42
+ const nestedPath = [''];
43
+ for (const path of pathList) {
44
+ nestedPath.push(path);
45
+ const pathToSet = nestedPath.join('/properties/');
46
+ const isLast = nestedPath.length - 1 === pathList.length;
47
+ const existingValue = pointer.has(acc, pathToSet) ? pointer.get(acc, pathToSet) : null;
48
+ const pathValue = isLast ? propertyValue : existingValue;
49
+ if (isLast) {
50
+ if ((filterData === null || filterData === void 0 ? void 0 : filterData[pathToSet]) !== false) {
51
+ pointer.set(acc, pathToSet, pathValue);
52
+ }
53
+ } else {
54
+ const pathValue = _objectSpread({
55
+ type: 'object'
56
+ }, existingValue);
57
+ const required = [];
58
+ if (props.required) {
59
+ required.push(pathList.at(-1));
60
+ }
61
+ if (existingValue !== null && existingValue !== void 0 && existingValue.required) {
62
+ required.push(...existingValue.required);
63
+ }
64
+ if (required.length > 0) {
65
+ pathValue.required = required;
66
+ }
67
+ if ((filterData === null || filterData === void 0 ? void 0 : filterData[pathToSet]) !== false) {
68
+ pointer.set(acc, pathToSet, pathValue);
69
+ }
70
+ }
71
+ }
72
+ } else {
73
+ if ((filterData === null || filterData === void 0 ? void 0 : filterData[path]) !== false) {
74
+ pointer.set(acc.properties, path, propertyValue);
75
+ }
76
+ if (props.required) {
77
+ acc.required.push(objectKey);
78
+ }
79
+ }
80
+ }
81
+ return acc;
82
+ }, {
83
+ type: 'object',
84
+ properties: {},
85
+ required: []
86
+ });
87
+ const propsOfFields = Object.entries((fieldPropsRef === null || fieldPropsRef === void 0 ? void 0 : fieldPropsRef.current) || {}).reduce((acc, _ref2) => {
88
+ let [path, props] = _ref2;
89
+ if (path.startsWith('/')) {
90
+ const propertyValue = {};
91
+ for (const prop in props) {
92
+ if (props[prop] !== undefined && typeof props[prop] !== 'function') {
93
+ propertyValue[prop] = props[prop];
94
+ }
95
+ }
96
+ pointer.set(acc, path, propertyValue);
97
+ }
98
+ return acc;
99
+ }, {});
100
+ const propsOfValues = Object.entries((valuePropsRef === null || valuePropsRef === void 0 ? void 0 : valuePropsRef.current) || {}).reduce((acc, _ref3) => {
101
+ let [path, props] = _ref3;
102
+ if (path.startsWith('/')) {
103
+ const propertyValue = {};
104
+ for (const prop in props) {
105
+ if (props[prop] !== undefined && typeof props[prop] !== 'function') {
106
+ propertyValue[prop] = props[prop];
107
+ }
108
+ }
109
+ pointer.set(acc, path, propertyValue);
110
+ }
111
+ return acc;
112
+ }, {});
113
+ if (schema.required.length === 0) {
114
+ delete schema.required;
115
+ }
116
+ return {
117
+ schema,
118
+ data: dataRef.current,
119
+ propsOfFields,
120
+ propsOfValues
121
+ };
122
+ }, [fieldPropsRef, filterData, valuePropsRef]);
123
+ if (hasContext) {
124
+ if (log) {
125
+ console.log(generate().schema);
126
+ }
127
+ if (generateRef) {
128
+ generateRef.current = generate;
129
+ }
130
+ }
131
+ return children;
132
+ }
133
+ //# sourceMappingURL=GenerateSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GenerateSchema.js","names":["useCallback","useContext","useRef","pointer","DataContext","schemaParams","GenerateSchema","props","generateRef","filterData","log","children","fieldPropsRef","valuePropsRef","data","hasContext","dataRef","current","generate","schema","Object","entries","reduce","acc","_ref","path","startsWith","objectKey","substring","pathList","split","slashCount","length","type","valueType","propertyValue","prop","nestedPath","push","pathToSet","join","isLast","existingValue","has","get","pathValue","set","_objectSpread","required","at","properties","propsOfFields","_ref2","undefined","propsOfValues","_ref3","console"],"sources":["../../../../../src/extensions/forms/Tools/GenerateSchema.tsx"],"sourcesContent":["import { useCallback, useContext, useRef } from 'react'\nimport pointer, { JsonObject } from 'json-pointer'\nimport DataContext, { FilterData } from '../DataContext/Context'\nimport { JSONSchema } from '../types'\n\nexport type GenerateSchemaReturn = {\n schema: JSONSchema\n data: JsonObject\n propsOfFields: JsonObject\n propsOfValues: JsonObject\n}\nexport type GenerateSchemaProps = {\n log?: boolean\n generateRef?: React.MutableRefObject<() => GenerateSchemaReturn>\n filterData?: FilterData\n children: React.ReactNode\n}\nexport type GenerateRef = GenerateSchemaProps['generateRef']['current']\n\nexport const schemaParams = [\n 'minLength',\n 'maxLength',\n 'pattern',\n 'description',\n 'min',\n 'max',\n 'multipleOf',\n 'exclusiveMinimum',\n 'exclusiveMaximum',\n]\n\nexport default function GenerateSchema(props: GenerateSchemaProps) {\n const { generateRef, filterData, log, children } = props || {}\n const { fieldPropsRef, valuePropsRef, data, hasContext } =\n useContext(DataContext)\n\n const dataRef = useRef<JsonObject>({})\n dataRef.current = data\n\n const generate = useCallback(() => {\n const schema = Object.entries(fieldPropsRef?.current || {}).reduce(\n (acc, [path, props]) => {\n if (path.startsWith('/')) {\n const objectKey = path.substring(1)\n\n const pathList = objectKey.split('/')\n const slashCount = pathList.length\n\n const type = props.valueType || 'string'\n const propertyValue = {\n type,\n }\n\n for (const prop of schemaParams) {\n if (props[prop]) {\n propertyValue[prop] = props[prop]\n }\n }\n\n if (slashCount > 1) {\n const nestedPath = ['']\n for (const path of pathList) {\n nestedPath.push(path)\n const pathToSet = nestedPath.join('/properties/')\n const isLast = nestedPath.length - 1 === pathList.length\n\n const existingValue = pointer.has(acc, pathToSet)\n ? pointer.get(acc, pathToSet)\n : null\n\n const pathValue = isLast ? propertyValue : existingValue\n\n if (isLast) {\n if (filterData?.[pathToSet] !== false) {\n pointer.set(acc, pathToSet, pathValue)\n }\n } else {\n const pathValue = {\n type: 'object',\n ...existingValue,\n }\n\n // - Add required\n const required = []\n if (props.required) {\n required.push(pathList.at(-1))\n }\n if (existingValue?.required) {\n required.push(...existingValue.required)\n }\n if (required.length > 0) {\n pathValue.required = required\n }\n\n if (filterData?.[pathToSet] !== false) {\n pointer.set(acc, pathToSet, pathValue)\n }\n }\n }\n } else {\n if (filterData?.[path] !== false) {\n pointer.set(acc.properties, path, propertyValue)\n }\n if (props.required) {\n acc.required.push(objectKey)\n }\n }\n }\n\n return acc\n },\n { type: 'object', properties: {}, required: [] }\n )\n\n const propsOfFields = Object.entries(\n fieldPropsRef?.current || {}\n ).reduce((acc, [path, props]) => {\n if (path.startsWith('/')) {\n const propertyValue = {}\n\n for (const prop in props) {\n if (\n props[prop] !== undefined &&\n typeof props[prop] !== 'function'\n ) {\n propertyValue[prop] = props[prop]\n }\n }\n\n pointer.set(acc, path, propertyValue)\n }\n\n return acc\n }, {})\n\n const propsOfValues = Object.entries(\n valuePropsRef?.current || {}\n ).reduce((acc, [path, props]) => {\n if (path.startsWith('/')) {\n const propertyValue = {}\n\n for (const prop in props) {\n if (\n props[prop] !== undefined &&\n typeof props[prop] !== 'function'\n ) {\n propertyValue[prop] = props[prop]\n }\n }\n\n pointer.set(acc, path, propertyValue)\n }\n\n return acc\n }, {})\n\n if (schema.required.length === 0) {\n delete schema.required\n }\n\n return {\n schema,\n data: dataRef.current,\n propsOfFields,\n propsOfValues,\n } as GenerateSchemaReturn\n }, [fieldPropsRef, filterData, valuePropsRef])\n\n if (hasContext) {\n if (log) {\n console.log(generate().schema)\n }\n\n if (generateRef) {\n generateRef.current = generate\n }\n }\n\n return children\n}\n"],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /// <reference types="react" />
2
+ import { JsonObject } from 'json-pointer';
3
+ import { FilterData } from '../DataContext/Context';
4
+ export type ListAllPropsReturn = {
5
+ propsOfFields: JsonObject;
6
+ propsOfValues: JsonObject;
7
+ };
8
+ export type ListAllPropsProps = {
9
+ log?: boolean;
10
+ generateRef?: React.MutableRefObject<() => ListAllPropsReturn>;
11
+ filterData?: FilterData;
12
+ children: React.ReactNode;
13
+ };
14
+ export type GenerateRef = ListAllPropsProps['generateRef']['current'];
15
+ export default function ListAllProps(props: ListAllPropsProps): import("react").ReactNode;
@@ -0,0 +1,67 @@
1
+ "use client";
2
+
3
+ import { isValidElement, useCallback, useContext, useRef } from 'react';
4
+ import pointer from 'json-pointer';
5
+ import DataContext from '../DataContext/Context';
6
+ export default function ListAllProps(props) {
7
+ const {
8
+ log,
9
+ generateRef,
10
+ filterData,
11
+ children
12
+ } = props || {};
13
+ const {
14
+ fieldPropsRef,
15
+ valuePropsRef,
16
+ data,
17
+ hasContext
18
+ } = useContext(DataContext);
19
+ const dataRef = useRef({});
20
+ dataRef.current = data;
21
+ const generate = useCallback(() => {
22
+ const propsOfFields = Object.entries((fieldPropsRef === null || fieldPropsRef === void 0 ? void 0 : fieldPropsRef.current) || {}).reduce((acc, _ref) => {
23
+ let [path, props] = _ref;
24
+ if (path.startsWith('/')) {
25
+ const propertyValue = {};
26
+ for (const prop in props) {
27
+ if (props[prop] !== undefined && typeof props[prop] !== 'function' && !isValidElement(props[prop])) {
28
+ propertyValue[prop] = props[prop];
29
+ }
30
+ }
31
+ if ((filterData === null || filterData === void 0 ? void 0 : filterData[path]) !== false) {
32
+ pointer.set(acc, path, propertyValue);
33
+ }
34
+ }
35
+ return acc;
36
+ }, {});
37
+ const propsOfValues = Object.entries((valuePropsRef === null || valuePropsRef === void 0 ? void 0 : valuePropsRef.current) || {}).reduce((acc, _ref2) => {
38
+ let [path, props] = _ref2;
39
+ if (path.startsWith('/')) {
40
+ const propertyValue = {};
41
+ for (const prop in props) {
42
+ if (props[prop] !== undefined && typeof props[prop] !== 'function' && !isValidElement(props[prop])) {
43
+ propertyValue[prop] = props[prop];
44
+ }
45
+ }
46
+ if ((filterData === null || filterData === void 0 ? void 0 : filterData[path]) !== false) {
47
+ pointer.set(acc, path, propertyValue);
48
+ }
49
+ }
50
+ return acc;
51
+ }, {});
52
+ return {
53
+ propsOfFields,
54
+ propsOfValues
55
+ };
56
+ }, [fieldPropsRef, filterData, valuePropsRef]);
57
+ if (hasContext) {
58
+ if (log) {
59
+ console.log(generate());
60
+ }
61
+ if (generateRef) {
62
+ generateRef.current = generate;
63
+ }
64
+ }
65
+ return children;
66
+ }
67
+ //# sourceMappingURL=ListAllProps.js.map