@dnb/eufemia 10.31.0 → 10.33.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 (846) hide show
  1. package/CHANGELOG.md +57 -0
  2. package/cjs/components/anchor/Anchor.d.ts +8 -1
  3. package/cjs/components/anchor/Anchor.js.map +1 -1
  4. package/cjs/components/card/Card.js +3 -2
  5. package/cjs/components/card/Card.js.map +1 -1
  6. package/cjs/components/card/style/dnb-card.css +1 -2
  7. package/cjs/components/card/style/dnb-card.min.css +1 -1
  8. package/cjs/components/card/style/themes/dnb-card-theme-sbanken.css +5 -0
  9. package/cjs/components/card/style/themes/dnb-card-theme-sbanken.min.css +1 -0
  10. package/cjs/components/card/style/themes/dnb-card-theme-sbanken.scss +7 -0
  11. package/cjs/components/checkbox/style/dnb-checkbox.css +2 -2
  12. package/cjs/components/checkbox/style/dnb-checkbox.min.css +1 -1
  13. package/cjs/components/checkbox/style/dnb-checkbox.scss +2 -3
  14. package/cjs/components/flex/Container.d.ts +4 -1
  15. package/cjs/components/flex/Container.js +8 -5
  16. package/cjs/components/flex/Container.js.map +1 -1
  17. package/cjs/components/flex/Stack.js +3 -3
  18. package/cjs/components/flex/Stack.js.map +1 -1
  19. package/cjs/components/flex/utils.js +7 -7
  20. package/cjs/components/flex/utils.js.map +1 -1
  21. package/cjs/components/grid/Container.d.ts +2 -2
  22. package/cjs/components/grid/Container.js.map +1 -1
  23. package/cjs/components/grid/ContainerDocs.d.ts +2 -0
  24. package/cjs/components/grid/ContainerDocs.js +30 -0
  25. package/cjs/components/grid/ContainerDocs.js.map +1 -0
  26. package/cjs/components/grid/style/dnb-grid.css +6 -0
  27. package/cjs/components/grid/style/dnb-grid.min.css +1 -1
  28. package/cjs/components/grid/style/grid-container.scss +6 -0
  29. package/cjs/components/skeleton/style/dnb-skeleton.css +4 -8
  30. package/cjs/components/skeleton/style/dnb-skeleton.min.css +1 -1
  31. package/cjs/components/slider/SliderDocs.d.ts +3 -0
  32. package/cjs/components/slider/SliderDocs.js +158 -0
  33. package/cjs/components/slider/SliderDocs.js.map +1 -0
  34. package/cjs/components/space/SpacingUtils.d.ts +1 -1
  35. package/cjs/components/space/SpacingUtils.js +1 -1
  36. package/cjs/components/space/SpacingUtils.js.map +1 -1
  37. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +70 -0
  38. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -0
  39. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +97 -0
  40. package/cjs/components/switch/style/themes/dnb-switch-theme-ui.css +1 -2
  41. package/cjs/components/switch/style/themes/dnb-switch-theme-ui.min.css +1 -1
  42. package/cjs/components/table/style/dnb-table.css +5 -10
  43. package/cjs/components/table/style/dnb-table.min.css +1 -1
  44. package/cjs/components/visually-hidden/style/dnb-visually-hidden.css +1 -2
  45. package/cjs/components/visually-hidden/style/dnb-visually-hidden.min.css +1 -1
  46. package/cjs/extensions/forms/DataContext/Context.d.ts +26 -14
  47. package/cjs/extensions/forms/DataContext/Context.js +2 -3
  48. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  49. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +3 -3
  50. package/cjs/extensions/forms/DataContext/Provider/Provider.js +81 -35
  51. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  52. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +3 -3
  53. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  54. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  55. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  56. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  57. package/cjs/extensions/forms/Field/Boolean/Boolean.js +2 -1
  58. package/cjs/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  59. package/cjs/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  60. package/cjs/extensions/forms/Field/Composition/Composition.js.map +1 -1
  61. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js +7 -7
  62. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  63. package/cjs/extensions/forms/Field/Number/Number.js +6 -4
  64. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  65. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +1 -1
  66. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  67. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  68. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  69. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  70. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  71. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  72. package/cjs/extensions/forms/Field/Selection/Selection.js +3 -3
  73. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  74. package/cjs/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  75. package/cjs/extensions/forms/Field/Slider/Slider.js +115 -0
  76. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -0
  77. package/cjs/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  78. package/cjs/extensions/forms/Field/Slider/SliderDocs.js +34 -0
  79. package/cjs/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  80. package/cjs/extensions/forms/Field/Slider/index.d.ts +2 -0
  81. package/cjs/extensions/forms/Field/Slider/index.js +27 -0
  82. package/cjs/extensions/forms/Field/Slider/index.js.map +1 -0
  83. package/cjs/extensions/forms/Field/String/String.js +2 -2
  84. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  85. package/cjs/extensions/forms/Field/Toggle/Toggle.js +7 -7
  86. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  87. package/cjs/extensions/forms/Field/index.d.ts +1 -0
  88. package/cjs/extensions/forms/Field/index.js +7 -0
  89. package/cjs/extensions/forms/Field/index.js.map +1 -1
  90. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +1 -1
  91. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +5 -0
  92. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  93. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +0 -3
  94. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  95. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +0 -2
  96. package/cjs/extensions/forms/Form/Element/Element.js +1 -1
  97. package/cjs/extensions/forms/Form/Element/Element.js.map +1 -1
  98. package/cjs/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  99. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js +52 -21
  100. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  101. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  102. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  103. package/cjs/extensions/forms/Form/Section/Section.d.ts +44 -0
  104. package/cjs/extensions/forms/Form/Section/Section.js +67 -0
  105. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -0
  106. package/cjs/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  107. package/cjs/extensions/forms/Form/Section/SectionContext.js +12 -0
  108. package/cjs/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  109. package/cjs/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  110. package/cjs/extensions/forms/Form/Section/SectionDocs.js +43 -0
  111. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  112. package/cjs/extensions/forms/Form/Section/index.d.ts +2 -0
  113. package/cjs/extensions/forms/Form/Section/index.js +27 -0
  114. package/cjs/extensions/forms/Form/Section/index.js.map +1 -0
  115. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js +3 -3
  116. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  117. package/cjs/extensions/forms/Form/Visibility/Visibility.d.ts +19 -5
  118. package/cjs/extensions/forms/Form/Visibility/Visibility.js +47 -10
  119. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  120. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js +11 -6
  121. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  122. package/cjs/extensions/forms/Form/data-context/useData.d.ts +1 -1
  123. package/cjs/extensions/forms/Form/data-context/useData.js +8 -4
  124. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  125. package/cjs/extensions/forms/Form/data-context/useError.d.ts +1 -0
  126. package/cjs/extensions/forms/Form/data-context/useError.js +5 -3
  127. package/cjs/extensions/forms/Form/data-context/useError.js.map +1 -1
  128. package/cjs/extensions/forms/Form/index.d.ts +1 -0
  129. package/cjs/extensions/forms/Form/index.js +7 -0
  130. package/cjs/extensions/forms/Form/index.js.map +1 -1
  131. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +8 -1
  132. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +4 -3
  133. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  134. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -1
  135. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  136. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  137. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  138. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +1 -1
  139. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  140. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  141. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  142. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  143. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  144. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +1 -1
  145. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  146. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -1
  147. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  148. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  149. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  150. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +1 -1
  151. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  152. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.css +3 -1
  153. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  154. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.scss +4 -1
  155. package/cjs/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  156. package/cjs/extensions/forms/Tools/GenerateSchema.js +143 -0
  157. package/cjs/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  158. package/cjs/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  159. package/cjs/extensions/forms/Tools/ListAllProps.js +73 -0
  160. package/cjs/extensions/forms/Tools/ListAllProps.js.map +1 -0
  161. package/cjs/extensions/forms/Tools/index.d.ts +2 -0
  162. package/cjs/extensions/forms/Tools/index.js +21 -0
  163. package/cjs/extensions/forms/Tools/index.js.map +1 -0
  164. package/cjs/extensions/forms/Value/Number/Number.js +4 -2
  165. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  166. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +4 -2
  167. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  168. package/cjs/extensions/forms/Wizard/Container/WizardContainer.d.ts +31 -2
  169. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +102 -32
  170. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  171. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +4 -0
  172. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  173. package/cjs/extensions/forms/Wizard/Step/Step.d.ts +6 -1
  174. package/cjs/extensions/forms/Wizard/Step/Step.js +9 -5
  175. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  176. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +0 -1
  177. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  178. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.scss +0 -1
  179. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.css +1 -0
  180. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.min.css +0 -0
  181. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.scss +1 -0
  182. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.css +3 -0
  183. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.min.css +1 -0
  184. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +7 -0
  185. package/cjs/extensions/forms/blocks/Category/FirstBlock/FirstBlock.d.ts +2 -0
  186. package/cjs/extensions/forms/blocks/Category/FirstBlock/FirstBlock.js +46 -0
  187. package/cjs/extensions/forms/blocks/Category/FirstBlock/FirstBlock.js.map +1 -0
  188. package/cjs/extensions/forms/blocks/Category/FirstBlock/index.d.ts +2 -0
  189. package/cjs/extensions/forms/blocks/Category/FirstBlock/index.js +27 -0
  190. package/cjs/extensions/forms/blocks/Category/FirstBlock/index.js.map +1 -0
  191. package/cjs/extensions/forms/blocks/Category/index.d.ts +1 -0
  192. package/cjs/extensions/forms/blocks/Category/index.js +14 -0
  193. package/cjs/extensions/forms/blocks/Category/index.js.map +1 -0
  194. package/cjs/extensions/forms/blocks/index.d.ts +1 -0
  195. package/cjs/extensions/forms/blocks/index.js +11 -0
  196. package/cjs/extensions/forms/blocks/index.js.map +1 -0
  197. package/cjs/extensions/forms/hooks/index.d.ts +2 -5
  198. package/cjs/extensions/forms/hooks/index.js +12 -4
  199. package/cjs/extensions/forms/hooks/index.js.map +1 -1
  200. package/cjs/extensions/forms/hooks/useDataValue.d.ts +9 -0
  201. package/cjs/extensions/forms/hooks/useDataValue.js +39 -0
  202. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -0
  203. package/cjs/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  204. package/cjs/extensions/forms/hooks/useExternalValue.js +47 -0
  205. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -0
  206. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  207. package/cjs/extensions/forms/hooks/useFieldProps.js +126 -108
  208. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  209. package/cjs/extensions/forms/hooks/usePath.d.ts +14 -0
  210. package/cjs/extensions/forms/hooks/usePath.js +72 -0
  211. package/cjs/extensions/forms/hooks/usePath.js.map +1 -0
  212. package/cjs/extensions/forms/hooks/useValueProps.js +17 -4
  213. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  214. package/cjs/extensions/forms/index.d.ts +2 -0
  215. package/cjs/extensions/forms/index.js +4 -1
  216. package/cjs/extensions/forms/index.js.map +1 -1
  217. package/cjs/extensions/forms/style/dnb-forms.css +3 -5
  218. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  219. package/cjs/extensions/forms/types.d.ts +10 -3
  220. package/cjs/extensions/forms/types.js.map +1 -1
  221. package/cjs/fragments/drawer-list/DrawerListHelpers.js +6 -2
  222. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  223. package/cjs/shared/Context.d.ts +3 -3
  224. package/cjs/shared/Context.js +8 -8
  225. package/cjs/shared/Context.js.map +1 -1
  226. package/cjs/shared/Eufemia.d.ts +1 -1
  227. package/cjs/shared/Eufemia.js +2 -2
  228. package/cjs/shared/Eufemia.js.map +1 -1
  229. package/cjs/shared/MediaQuery.js +19 -1
  230. package/cjs/shared/MediaQuery.js.map +1 -1
  231. package/cjs/shared/MediaQueryUtils.d.ts +12 -34
  232. package/cjs/shared/MediaQueryUtils.js +22 -12
  233. package/cjs/shared/MediaQueryUtils.js.map +1 -1
  234. package/cjs/shared/component-helper.d.ts +1 -1
  235. package/cjs/shared/component-helper.js +5 -1
  236. package/cjs/shared/component-helper.js.map +1 -1
  237. package/cjs/shared/useMedia.d.ts +7 -2
  238. package/cjs/shared/useMedia.js +16 -11
  239. package/cjs/shared/useMedia.js.map +1 -1
  240. package/cjs/shared/useMediaQuery.js +30 -9
  241. package/cjs/shared/useMediaQuery.js.map +1 -1
  242. package/cjs/style/core/scopes.scss +1 -1
  243. package/cjs/style/dnb-ui-basis.css +2 -3
  244. package/cjs/style/dnb-ui-basis.min.css +1 -1
  245. package/cjs/style/dnb-ui-body.css +1 -1
  246. package/cjs/style/dnb-ui-body.min.css +1 -1
  247. package/cjs/style/dnb-ui-components.css +22 -29
  248. package/cjs/style/dnb-ui-components.min.css +3 -3
  249. package/cjs/style/dnb-ui-core.css +2 -3
  250. package/cjs/style/dnb-ui-core.min.css +1 -1
  251. package/cjs/style/dnb-ui-extensions.css +3 -5
  252. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  253. package/cjs/style/dnb-ui-forms.css +3 -5
  254. package/cjs/style/dnb-ui-forms.min.css +1 -1
  255. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +30 -36
  256. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +5 -5
  257. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +7 -5
  258. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  259. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  260. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +7 -5
  261. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  262. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  263. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +103 -112
  264. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  265. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +2 -2
  266. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +4 -5
  267. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  268. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  269. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +4 -5
  270. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  271. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  272. package/cjs/style/themes/theme-ui/ui-theme-components.css +30 -36
  273. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +5 -5
  274. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +7 -5
  275. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  276. package/cjs/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  277. package/cjs/style/themes/theme-ui/ui-theme-forms.css +7 -5
  278. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  279. package/cjs/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  280. package/components/anchor/Anchor.d.ts +8 -1
  281. package/components/anchor/Anchor.js.map +1 -1
  282. package/components/card/Card.js +3 -2
  283. package/components/card/Card.js.map +1 -1
  284. package/components/card/style/dnb-card.css +1 -2
  285. package/components/card/style/dnb-card.min.css +1 -1
  286. package/components/card/style/themes/dnb-card-theme-sbanken.css +5 -0
  287. package/components/card/style/themes/dnb-card-theme-sbanken.min.css +1 -0
  288. package/components/card/style/themes/dnb-card-theme-sbanken.scss +7 -0
  289. package/components/checkbox/style/dnb-checkbox.css +2 -2
  290. package/components/checkbox/style/dnb-checkbox.min.css +1 -1
  291. package/components/checkbox/style/dnb-checkbox.scss +2 -3
  292. package/components/flex/Container.d.ts +4 -1
  293. package/components/flex/Container.js +8 -5
  294. package/components/flex/Container.js.map +1 -1
  295. package/components/flex/Stack.js +3 -3
  296. package/components/flex/Stack.js.map +1 -1
  297. package/components/flex/utils.js +8 -8
  298. package/components/flex/utils.js.map +1 -1
  299. package/components/grid/Container.d.ts +2 -2
  300. package/components/grid/Container.js.map +1 -1
  301. package/components/grid/ContainerDocs.d.ts +2 -0
  302. package/components/grid/ContainerDocs.js +23 -0
  303. package/components/grid/ContainerDocs.js.map +1 -0
  304. package/components/grid/style/dnb-grid.css +6 -0
  305. package/components/grid/style/dnb-grid.min.css +1 -1
  306. package/components/grid/style/grid-container.scss +6 -0
  307. package/components/skeleton/style/dnb-skeleton.css +4 -8
  308. package/components/skeleton/style/dnb-skeleton.min.css +1 -1
  309. package/components/slider/SliderDocs.d.ts +3 -0
  310. package/components/slider/SliderDocs.js +150 -0
  311. package/components/slider/SliderDocs.js.map +1 -0
  312. package/components/space/SpacingUtils.d.ts +1 -1
  313. package/components/space/SpacingUtils.js +1 -1
  314. package/components/space/SpacingUtils.js.map +1 -1
  315. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +70 -0
  316. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -0
  317. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +97 -0
  318. package/components/switch/style/themes/dnb-switch-theme-ui.css +1 -2
  319. package/components/switch/style/themes/dnb-switch-theme-ui.min.css +1 -1
  320. package/components/table/style/dnb-table.css +5 -10
  321. package/components/table/style/dnb-table.min.css +1 -1
  322. package/components/visually-hidden/style/dnb-visually-hidden.css +1 -2
  323. package/components/visually-hidden/style/dnb-visually-hidden.min.css +1 -1
  324. package/es/components/anchor/Anchor.d.ts +8 -1
  325. package/es/components/anchor/Anchor.js.map +1 -1
  326. package/es/components/card/Card.js +3 -2
  327. package/es/components/card/Card.js.map +1 -1
  328. package/es/components/card/style/dnb-card.css +1 -2
  329. package/es/components/card/style/dnb-card.min.css +1 -1
  330. package/es/components/card/style/themes/dnb-card-theme-sbanken.css +5 -0
  331. package/es/components/card/style/themes/dnb-card-theme-sbanken.min.css +1 -0
  332. package/es/components/card/style/themes/dnb-card-theme-sbanken.scss +7 -0
  333. package/es/components/checkbox/style/dnb-checkbox.css +2 -2
  334. package/es/components/checkbox/style/dnb-checkbox.min.css +1 -1
  335. package/es/components/checkbox/style/dnb-checkbox.scss +2 -3
  336. package/es/components/flex/Container.d.ts +4 -1
  337. package/es/components/flex/Container.js +8 -5
  338. package/es/components/flex/Container.js.map +1 -1
  339. package/es/components/flex/Stack.js +3 -3
  340. package/es/components/flex/Stack.js.map +1 -1
  341. package/es/components/flex/utils.js +8 -8
  342. package/es/components/flex/utils.js.map +1 -1
  343. package/es/components/grid/Container.d.ts +2 -2
  344. package/es/components/grid/Container.js.map +1 -1
  345. package/es/components/grid/ContainerDocs.d.ts +2 -0
  346. package/es/components/grid/ContainerDocs.js +23 -0
  347. package/es/components/grid/ContainerDocs.js.map +1 -0
  348. package/es/components/grid/style/dnb-grid.css +6 -0
  349. package/es/components/grid/style/dnb-grid.min.css +1 -1
  350. package/es/components/grid/style/grid-container.scss +6 -0
  351. package/es/components/skeleton/style/dnb-skeleton.css +4 -8
  352. package/es/components/skeleton/style/dnb-skeleton.min.css +1 -1
  353. package/es/components/slider/SliderDocs.d.ts +3 -0
  354. package/es/components/slider/SliderDocs.js +150 -0
  355. package/es/components/slider/SliderDocs.js.map +1 -0
  356. package/es/components/space/SpacingUtils.d.ts +1 -1
  357. package/es/components/space/SpacingUtils.js +1 -1
  358. package/es/components/space/SpacingUtils.js.map +1 -1
  359. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +70 -0
  360. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -0
  361. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +97 -0
  362. package/es/components/switch/style/themes/dnb-switch-theme-ui.css +1 -2
  363. package/es/components/switch/style/themes/dnb-switch-theme-ui.min.css +1 -1
  364. package/es/components/table/style/dnb-table.css +5 -10
  365. package/es/components/table/style/dnb-table.min.css +1 -1
  366. package/es/components/visually-hidden/style/dnb-visually-hidden.css +1 -2
  367. package/es/components/visually-hidden/style/dnb-visually-hidden.min.css +1 -1
  368. package/es/extensions/forms/DataContext/Context.d.ts +26 -14
  369. package/es/extensions/forms/DataContext/Context.js +2 -3
  370. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  371. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +3 -3
  372. package/es/extensions/forms/DataContext/Provider/Provider.js +79 -34
  373. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  374. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +3 -3
  375. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  376. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  377. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  378. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  379. package/es/extensions/forms/Field/Boolean/Boolean.js +2 -1
  380. package/es/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  381. package/es/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  382. package/es/extensions/forms/Field/Composition/Composition.js.map +1 -1
  383. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js +7 -7
  384. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  385. package/es/extensions/forms/Field/Number/Number.js +6 -4
  386. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  387. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +1 -1
  388. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  389. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  390. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  391. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  392. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  393. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  394. package/es/extensions/forms/Field/Selection/Selection.js +3 -3
  395. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  396. package/es/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  397. package/es/extensions/forms/Field/Slider/Slider.js +103 -0
  398. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -0
  399. package/es/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  400. package/es/extensions/forms/Field/Slider/SliderDocs.js +26 -0
  401. package/es/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  402. package/es/extensions/forms/Field/Slider/index.d.ts +2 -0
  403. package/es/extensions/forms/Field/Slider/index.js +3 -0
  404. package/es/extensions/forms/Field/Slider/index.js.map +1 -0
  405. package/es/extensions/forms/Field/String/String.js +2 -2
  406. package/es/extensions/forms/Field/String/String.js.map +1 -1
  407. package/es/extensions/forms/Field/Toggle/Toggle.js +7 -7
  408. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  409. package/es/extensions/forms/Field/index.d.ts +1 -0
  410. package/es/extensions/forms/Field/index.js +1 -0
  411. package/es/extensions/forms/Field/index.js.map +1 -1
  412. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +1 -1
  413. package/es/extensions/forms/FieldBlock/FieldBlock.js +5 -0
  414. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  415. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +0 -3
  416. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  417. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +0 -2
  418. package/es/extensions/forms/Form/Element/Element.js +1 -1
  419. package/es/extensions/forms/Form/Element/Element.js.map +1 -1
  420. package/es/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  421. package/es/extensions/forms/Form/FieldProps/FieldProps.js +49 -21
  422. package/es/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  423. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  424. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  425. package/es/extensions/forms/Form/Section/Section.d.ts +44 -0
  426. package/es/extensions/forms/Form/Section/Section.js +56 -0
  427. package/es/extensions/forms/Form/Section/Section.js.map +1 -0
  428. package/es/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  429. package/es/extensions/forms/Form/Section/SectionContext.js +4 -0
  430. package/es/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  431. package/es/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  432. package/es/extensions/forms/Form/Section/SectionDocs.js +35 -0
  433. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  434. package/es/extensions/forms/Form/Section/index.d.ts +2 -0
  435. package/es/extensions/forms/Form/Section/index.js +3 -0
  436. package/es/extensions/forms/Form/Section/index.js.map +1 -0
  437. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js +3 -3
  438. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  439. package/es/extensions/forms/Form/Visibility/Visibility.d.ts +19 -5
  440. package/es/extensions/forms/Form/Visibility/Visibility.js +48 -11
  441. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  442. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js +11 -6
  443. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  444. package/es/extensions/forms/Form/data-context/useData.d.ts +1 -1
  445. package/es/extensions/forms/Form/data-context/useData.js +7 -4
  446. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  447. package/es/extensions/forms/Form/data-context/useError.d.ts +1 -0
  448. package/es/extensions/forms/Form/data-context/useError.js +5 -3
  449. package/es/extensions/forms/Form/data-context/useError.js.map +1 -1
  450. package/es/extensions/forms/Form/index.d.ts +1 -0
  451. package/es/extensions/forms/Form/index.js +1 -0
  452. package/es/extensions/forms/Form/index.js.map +1 -1
  453. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +8 -1
  454. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +4 -3
  455. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  456. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -1
  457. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  458. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  459. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  460. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +1 -1
  461. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  462. package/es/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  463. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  464. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  465. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  466. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +1 -1
  467. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  468. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -1
  469. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  470. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  471. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  472. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +1 -1
  473. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  474. package/es/extensions/forms/Iterate/style/dnb-form-iterate.css +3 -1
  475. package/es/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  476. package/es/extensions/forms/Iterate/style/dnb-form-iterate.scss +4 -1
  477. package/es/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  478. package/es/extensions/forms/Tools/GenerateSchema.js +130 -0
  479. package/es/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  480. package/es/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  481. package/es/extensions/forms/Tools/ListAllProps.js +65 -0
  482. package/es/extensions/forms/Tools/ListAllProps.js.map +1 -0
  483. package/es/extensions/forms/Tools/index.d.ts +2 -0
  484. package/es/extensions/forms/Tools/index.js +3 -0
  485. package/es/extensions/forms/Tools/index.js.map +1 -0
  486. package/es/extensions/forms/Value/Number/Number.js +4 -2
  487. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  488. package/es/extensions/forms/ValueBlock/ValueBlock.js +4 -2
  489. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  490. package/es/extensions/forms/Wizard/Container/WizardContainer.d.ts +31 -2
  491. package/es/extensions/forms/Wizard/Container/WizardContainer.js +98 -32
  492. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  493. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +4 -0
  494. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  495. package/es/extensions/forms/Wizard/Step/Step.d.ts +6 -1
  496. package/es/extensions/forms/Wizard/Step/Step.js +9 -5
  497. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  498. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +0 -1
  499. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  500. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.scss +0 -1
  501. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.css +1 -0
  502. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.min.css +0 -0
  503. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.scss +1 -0
  504. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.css +3 -0
  505. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.min.css +1 -0
  506. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +7 -0
  507. package/es/extensions/forms/blocks/Category/FirstBlock/FirstBlock.d.ts +2 -0
  508. package/es/extensions/forms/blocks/Category/FirstBlock/FirstBlock.js +39 -0
  509. package/es/extensions/forms/blocks/Category/FirstBlock/FirstBlock.js.map +1 -0
  510. package/es/extensions/forms/blocks/Category/FirstBlock/index.d.ts +2 -0
  511. package/es/extensions/forms/blocks/Category/FirstBlock/index.js +3 -0
  512. package/es/extensions/forms/blocks/Category/FirstBlock/index.js.map +1 -0
  513. package/es/extensions/forms/blocks/Category/index.d.ts +1 -0
  514. package/es/extensions/forms/blocks/Category/index.js +1 -0
  515. package/es/extensions/forms/blocks/Category/index.js.map +1 -0
  516. package/es/extensions/forms/blocks/index.d.ts +1 -0
  517. package/es/extensions/forms/blocks/index.js +1 -0
  518. package/es/extensions/forms/blocks/index.js.map +1 -0
  519. package/es/extensions/forms/hooks/index.d.ts +2 -5
  520. package/es/extensions/forms/hooks/index.js +2 -1
  521. package/es/extensions/forms/hooks/index.js.map +1 -1
  522. package/es/extensions/forms/hooks/useDataValue.d.ts +9 -0
  523. package/es/extensions/forms/hooks/useDataValue.js +32 -0
  524. package/es/extensions/forms/hooks/useDataValue.js.map +1 -0
  525. package/es/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  526. package/es/extensions/forms/hooks/useExternalValue.js +41 -0
  527. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -0
  528. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  529. package/es/extensions/forms/hooks/useFieldProps.js +122 -102
  530. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  531. package/es/extensions/forms/hooks/usePath.d.ts +14 -0
  532. package/es/extensions/forms/hooks/usePath.js +64 -0
  533. package/es/extensions/forms/hooks/usePath.js.map +1 -0
  534. package/es/extensions/forms/hooks/useValueProps.js +16 -4
  535. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  536. package/es/extensions/forms/index.d.ts +2 -0
  537. package/es/extensions/forms/index.js +1 -0
  538. package/es/extensions/forms/index.js.map +1 -1
  539. package/es/extensions/forms/style/dnb-forms.css +3 -5
  540. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  541. package/es/extensions/forms/types.d.ts +10 -3
  542. package/es/extensions/forms/types.js.map +1 -1
  543. package/es/fragments/drawer-list/DrawerListHelpers.js +6 -2
  544. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  545. package/es/shared/Context.d.ts +3 -3
  546. package/es/shared/Context.js +8 -8
  547. package/es/shared/Context.js.map +1 -1
  548. package/es/shared/Eufemia.d.ts +1 -1
  549. package/es/shared/Eufemia.js +2 -2
  550. package/es/shared/Eufemia.js.map +1 -1
  551. package/es/shared/MediaQuery.js +19 -1
  552. package/es/shared/MediaQuery.js.map +1 -1
  553. package/es/shared/MediaQueryUtils.d.ts +12 -34
  554. package/es/shared/MediaQueryUtils.js +22 -17
  555. package/es/shared/MediaQueryUtils.js.map +1 -1
  556. package/es/shared/component-helper.d.ts +1 -1
  557. package/es/shared/component-helper.js +5 -2
  558. package/es/shared/component-helper.js.map +1 -1
  559. package/es/shared/useMedia.d.ts +7 -2
  560. package/es/shared/useMedia.js +14 -11
  561. package/es/shared/useMedia.js.map +1 -1
  562. package/es/shared/useMediaQuery.js +28 -9
  563. package/es/shared/useMediaQuery.js.map +1 -1
  564. package/es/style/core/scopes.scss +1 -1
  565. package/es/style/dnb-ui-basis.css +2 -3
  566. package/es/style/dnb-ui-basis.min.css +1 -1
  567. package/es/style/dnb-ui-body.css +1 -1
  568. package/es/style/dnb-ui-body.min.css +1 -1
  569. package/es/style/dnb-ui-components.css +22 -29
  570. package/es/style/dnb-ui-components.min.css +3 -3
  571. package/es/style/dnb-ui-core.css +2 -3
  572. package/es/style/dnb-ui-core.min.css +1 -1
  573. package/es/style/dnb-ui-extensions.css +3 -5
  574. package/es/style/dnb-ui-extensions.min.css +1 -1
  575. package/es/style/dnb-ui-forms.css +3 -5
  576. package/es/style/dnb-ui-forms.min.css +1 -1
  577. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +30 -36
  578. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +5 -5
  579. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +7 -5
  580. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  581. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  582. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +7 -5
  583. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  584. package/es/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  585. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +103 -112
  586. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  587. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +2 -2
  588. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +4 -5
  589. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  590. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  591. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +4 -5
  592. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  593. package/es/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  594. package/es/style/themes/theme-ui/ui-theme-components.css +30 -36
  595. package/es/style/themes/theme-ui/ui-theme-components.min.css +5 -5
  596. package/es/style/themes/theme-ui/ui-theme-extensions.css +7 -5
  597. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  598. package/es/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  599. package/es/style/themes/theme-ui/ui-theme-forms.css +7 -5
  600. package/es/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  601. package/es/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  602. package/esm/dnb-ui-basis.min.mjs +1 -1
  603. package/esm/dnb-ui-components.min.mjs +1 -1
  604. package/esm/dnb-ui-elements.min.mjs +1 -1
  605. package/esm/dnb-ui-extensions.min.mjs +3 -3
  606. package/esm/dnb-ui-lib.min.mjs +1 -1
  607. package/extensions/forms/DataContext/Context.d.ts +26 -14
  608. package/extensions/forms/DataContext/Context.js +2 -3
  609. package/extensions/forms/DataContext/Context.js.map +1 -1
  610. package/extensions/forms/DataContext/Provider/Provider.d.ts +3 -3
  611. package/extensions/forms/DataContext/Provider/Provider.js +82 -36
  612. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  613. package/extensions/forms/DataContext/Provider/ProviderDocs.js +3 -3
  614. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  615. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  616. package/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  617. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  618. package/extensions/forms/Field/Boolean/Boolean.js +2 -1
  619. package/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  620. package/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  621. package/extensions/forms/Field/Composition/Composition.js.map +1 -1
  622. package/extensions/forms/Field/Indeterminate/useDependencePaths.js +7 -7
  623. package/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  624. package/extensions/forms/Field/Number/Number.js +6 -4
  625. package/extensions/forms/Field/Number/Number.js.map +1 -1
  626. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +1 -1
  627. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  628. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  629. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  630. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  631. package/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  632. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  633. package/extensions/forms/Field/Selection/Selection.js +3 -3
  634. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  635. package/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  636. package/extensions/forms/Field/Slider/Slider.js +104 -0
  637. package/extensions/forms/Field/Slider/Slider.js.map +1 -0
  638. package/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  639. package/extensions/forms/Field/Slider/SliderDocs.js +26 -0
  640. package/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  641. package/extensions/forms/Field/Slider/index.d.ts +2 -0
  642. package/extensions/forms/Field/Slider/index.js +3 -0
  643. package/extensions/forms/Field/Slider/index.js.map +1 -0
  644. package/extensions/forms/Field/String/String.js +2 -2
  645. package/extensions/forms/Field/String/String.js.map +1 -1
  646. package/extensions/forms/Field/Toggle/Toggle.js +7 -7
  647. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  648. package/extensions/forms/Field/index.d.ts +1 -0
  649. package/extensions/forms/Field/index.js +1 -0
  650. package/extensions/forms/Field/index.js.map +1 -1
  651. package/extensions/forms/FieldBlock/FieldBlock.d.ts +1 -1
  652. package/extensions/forms/FieldBlock/FieldBlock.js +5 -0
  653. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  654. package/extensions/forms/FieldBlock/style/dnb-field-block.css +0 -3
  655. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  656. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +0 -2
  657. package/extensions/forms/Form/Element/Element.js +1 -1
  658. package/extensions/forms/Form/Element/Element.js.map +1 -1
  659. package/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  660. package/extensions/forms/Form/FieldProps/FieldProps.js +50 -21
  661. package/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  662. package/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  663. package/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  664. package/extensions/forms/Form/Section/Section.d.ts +44 -0
  665. package/extensions/forms/Form/Section/Section.js +56 -0
  666. package/extensions/forms/Form/Section/Section.js.map +1 -0
  667. package/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  668. package/extensions/forms/Form/Section/SectionContext.js +4 -0
  669. package/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  670. package/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  671. package/extensions/forms/Form/Section/SectionDocs.js +35 -0
  672. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  673. package/extensions/forms/Form/Section/index.d.ts +2 -0
  674. package/extensions/forms/Form/Section/index.js +3 -0
  675. package/extensions/forms/Form/Section/index.js.map +1 -0
  676. package/extensions/forms/Form/SubmitButton/SubmitButton.js +3 -3
  677. package/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  678. package/extensions/forms/Form/Visibility/Visibility.d.ts +19 -5
  679. package/extensions/forms/Form/Visibility/Visibility.js +48 -11
  680. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  681. package/extensions/forms/Form/Visibility/VisibilityDocs.js +11 -6
  682. package/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  683. package/extensions/forms/Form/data-context/useData.d.ts +1 -1
  684. package/extensions/forms/Form/data-context/useData.js +8 -4
  685. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  686. package/extensions/forms/Form/data-context/useError.d.ts +1 -0
  687. package/extensions/forms/Form/data-context/useError.js +5 -3
  688. package/extensions/forms/Form/data-context/useError.js.map +1 -1
  689. package/extensions/forms/Form/index.d.ts +1 -0
  690. package/extensions/forms/Form/index.js +1 -0
  691. package/extensions/forms/Form/index.js.map +1 -1
  692. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +8 -1
  693. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +4 -3
  694. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  695. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -1
  696. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  697. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  698. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  699. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +1 -1
  700. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  701. package/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  702. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  703. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  704. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  705. package/extensions/forms/Iterate/Toolbar/Toolbar.js +1 -1
  706. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  707. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -1
  708. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  709. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  710. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  711. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +1 -1
  712. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  713. package/extensions/forms/Iterate/style/dnb-form-iterate.css +3 -1
  714. package/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  715. package/extensions/forms/Iterate/style/dnb-form-iterate.scss +4 -1
  716. package/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  717. package/extensions/forms/Tools/GenerateSchema.js +133 -0
  718. package/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  719. package/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  720. package/extensions/forms/Tools/ListAllProps.js +67 -0
  721. package/extensions/forms/Tools/ListAllProps.js.map +1 -0
  722. package/extensions/forms/Tools/index.d.ts +2 -0
  723. package/extensions/forms/Tools/index.js +3 -0
  724. package/extensions/forms/Tools/index.js.map +1 -0
  725. package/extensions/forms/Value/Number/Number.js +4 -2
  726. package/extensions/forms/Value/Number/Number.js.map +1 -1
  727. package/extensions/forms/ValueBlock/ValueBlock.js +4 -2
  728. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  729. package/extensions/forms/Wizard/Container/WizardContainer.d.ts +31 -2
  730. package/extensions/forms/Wizard/Container/WizardContainer.js +102 -32
  731. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  732. package/extensions/forms/Wizard/Context/WizardContext.d.ts +4 -0
  733. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  734. package/extensions/forms/Wizard/Step/Step.d.ts +6 -1
  735. package/extensions/forms/Wizard/Step/Step.js +9 -5
  736. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  737. package/extensions/forms/Wizard/style/dnb-wizard-layout.css +0 -1
  738. package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  739. package/extensions/forms/Wizard/style/dnb-wizard-layout.scss +0 -1
  740. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.css +1 -0
  741. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.min.css +0 -0
  742. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-sbanken.scss +1 -0
  743. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.css +3 -0
  744. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.min.css +1 -0
  745. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +7 -0
  746. package/extensions/forms/blocks/Category/FirstBlock/FirstBlock.d.ts +2 -0
  747. package/extensions/forms/blocks/Category/FirstBlock/FirstBlock.js +39 -0
  748. package/extensions/forms/blocks/Category/FirstBlock/FirstBlock.js.map +1 -0
  749. package/extensions/forms/blocks/Category/FirstBlock/index.d.ts +2 -0
  750. package/extensions/forms/blocks/Category/FirstBlock/index.js +3 -0
  751. package/extensions/forms/blocks/Category/FirstBlock/index.js.map +1 -0
  752. package/extensions/forms/blocks/Category/index.d.ts +1 -0
  753. package/extensions/forms/blocks/Category/index.js +1 -0
  754. package/extensions/forms/blocks/Category/index.js.map +1 -0
  755. package/extensions/forms/blocks/index.d.ts +1 -0
  756. package/extensions/forms/blocks/index.js +3 -0
  757. package/extensions/forms/blocks/index.js.map +1 -0
  758. package/extensions/forms/hooks/index.d.ts +2 -5
  759. package/extensions/forms/hooks/index.js +2 -1
  760. package/extensions/forms/hooks/index.js.map +1 -1
  761. package/extensions/forms/hooks/useDataValue.d.ts +9 -0
  762. package/extensions/forms/hooks/useDataValue.js +33 -0
  763. package/extensions/forms/hooks/useDataValue.js.map +1 -0
  764. package/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  765. package/extensions/forms/hooks/useExternalValue.js +41 -0
  766. package/extensions/forms/hooks/useExternalValue.js.map +1 -0
  767. package/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  768. package/extensions/forms/hooks/useFieldProps.js +125 -106
  769. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  770. package/extensions/forms/hooks/usePath.d.ts +14 -0
  771. package/extensions/forms/hooks/usePath.js +66 -0
  772. package/extensions/forms/hooks/usePath.js.map +1 -0
  773. package/extensions/forms/hooks/useValueProps.js +16 -4
  774. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  775. package/extensions/forms/index.d.ts +2 -0
  776. package/extensions/forms/index.js +2 -0
  777. package/extensions/forms/index.js.map +1 -1
  778. package/extensions/forms/style/dnb-forms.css +3 -5
  779. package/extensions/forms/style/dnb-forms.min.css +1 -1
  780. package/extensions/forms/types.d.ts +10 -3
  781. package/extensions/forms/types.js.map +1 -1
  782. package/fragments/drawer-list/DrawerListHelpers.js +6 -2
  783. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  784. package/package.json +1 -1
  785. package/shared/Context.d.ts +3 -3
  786. package/shared/Context.js +8 -8
  787. package/shared/Context.js.map +1 -1
  788. package/shared/Eufemia.d.ts +1 -1
  789. package/shared/Eufemia.js +2 -2
  790. package/shared/Eufemia.js.map +1 -1
  791. package/shared/MediaQuery.js +19 -1
  792. package/shared/MediaQuery.js.map +1 -1
  793. package/shared/MediaQueryUtils.d.ts +12 -34
  794. package/shared/MediaQueryUtils.js +22 -12
  795. package/shared/MediaQueryUtils.js.map +1 -1
  796. package/shared/component-helper.d.ts +1 -1
  797. package/shared/component-helper.js +5 -1
  798. package/shared/component-helper.js.map +1 -1
  799. package/shared/useMedia.d.ts +7 -2
  800. package/shared/useMedia.js +14 -11
  801. package/shared/useMedia.js.map +1 -1
  802. package/shared/useMediaQuery.js +28 -9
  803. package/shared/useMediaQuery.js.map +1 -1
  804. package/style/core/scopes.scss +1 -1
  805. package/style/dnb-ui-basis.css +2 -3
  806. package/style/dnb-ui-basis.min.css +1 -1
  807. package/style/dnb-ui-body.css +1 -1
  808. package/style/dnb-ui-body.min.css +1 -1
  809. package/style/dnb-ui-components.css +22 -29
  810. package/style/dnb-ui-components.min.css +3 -3
  811. package/style/dnb-ui-core.css +2 -3
  812. package/style/dnb-ui-core.min.css +1 -1
  813. package/style/dnb-ui-extensions.css +3 -5
  814. package/style/dnb-ui-extensions.min.css +1 -1
  815. package/style/dnb-ui-forms.css +3 -5
  816. package/style/dnb-ui-forms.min.css +1 -1
  817. package/style/themes/theme-eiendom/eiendom-theme-components.css +30 -36
  818. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +5 -5
  819. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +7 -5
  820. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  821. package/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  822. package/style/themes/theme-eiendom/eiendom-theme-forms.css +7 -5
  823. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  824. package/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  825. package/style/themes/theme-sbanken/sbanken-theme-components.css +103 -112
  826. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  827. package/style/themes/theme-sbanken/sbanken-theme-components.scss +2 -2
  828. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +4 -5
  829. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  830. package/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  831. package/style/themes/theme-sbanken/sbanken-theme-forms.css +4 -5
  832. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  833. package/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  834. package/style/themes/theme-ui/ui-theme-components.css +30 -36
  835. package/style/themes/theme-ui/ui-theme-components.min.css +5 -5
  836. package/style/themes/theme-ui/ui-theme-extensions.css +7 -5
  837. package/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  838. package/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  839. package/style/themes/theme-ui/ui-theme-forms.css +7 -5
  840. package/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  841. package/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  842. package/umd/dnb-ui-basis.min.js +1 -1
  843. package/umd/dnb-ui-components.min.js +1 -1
  844. package/umd/dnb-ui-elements.min.js +1 -1
  845. package/umd/dnb-ui-extensions.min.js +3 -3
  846. package/umd/dnb-ui-lib.min.js +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Visibility.js","names":["_react","_interopRequireWildcard","require","_jsonPointer","_interopRequireDefault","_helpers","_useMountEffect","_HeightAnimation","_Context","_FieldProps","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","Visibility","_ref","visible","pathDefined","pathUndefined","pathTruthy","pathFalsy","pathTrue","pathFalse","pathValue","whenValue","inferData","animate","keepInDOM","fieldPropsWhenHidden","children","rest","dataContext","useContext","DataContext","useMountEffect","warn","check","pointer","data","Boolean","open","props","createElement","className","hidden","Fragment","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Form/Visibility/Visibility.tsx"],"sourcesContent":["import React, { AriaAttributes, useContext } from 'react'\nimport pointer from 'json-pointer'\nimport { warn } from '../../../../shared/helpers'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport HeightAnimation, {\n HeightAnimationProps,\n} from '../../../../components/HeightAnimation'\nimport DataContext from '../../DataContext/Context'\nimport FieldProps from '../FieldProps'\nimport type { UseFieldProps } from '../../types'\nimport type { DataAttributes } from '../../hooks/useFieldProps'\n\nexport type Props = {\n visible?: boolean\n /** Given data context path must be defined to show children */\n pathDefined?: string\n /** Given data context path must be undefined to show children */\n pathUndefined?: string\n /** Given data context path must be truthy to show children */\n pathTruthy?: string\n /** Given data context path must be falsy to show children */\n pathFalsy?: string\n /** Given data context path must be true to show children */\n pathTrue?: string\n /** Given data context path must be false to show children */\n pathFalse?: string\n /** Given data context path must match, as well as the \"whenValue\" value */\n pathValue?: string\n /** Given data context value must match this value to show children */\n whenValue?: unknown\n /** Infer visibility calling given derivative function with the whole data set. Should return true/false for visibility. */\n inferData?: (data: unknown) => boolean\n /** Animate the visibility change */\n animate?: boolean\n /** Keep the content in the DOM, even if it's not visible */\n keepInDOM?: boolean\n /** When visibility is hidden, and `keepInDOM` is true, pass these props to the children */\n fieldPropsWhenHidden?: UseFieldProps & DataAttributes & AriaAttributes\n element?: HeightAnimationProps['element']\n children: React.ReactNode\n}\n\nfunction Visibility({\n visible,\n pathDefined,\n pathUndefined,\n pathTruthy,\n pathFalsy,\n pathTrue,\n pathFalse,\n pathValue,\n whenValue,\n inferData,\n animate,\n keepInDOM,\n fieldPropsWhenHidden,\n children,\n ...rest\n}: Props) {\n const dataContext = useContext(DataContext)\n\n useMountEffect(() => {\n if (fieldPropsWhenHidden && !keepInDOM) {\n warn('Using \"fieldPropsWhenHidden\" requires \"keepInDOM\" to be true.')\n }\n })\n\n const check = () => {\n if (visible === false) {\n return\n }\n\n if (pathDefined && !pointer.has(dataContext.data, pathDefined)) {\n return\n }\n if (pathUndefined && pointer.has(dataContext.data, pathUndefined)) {\n return\n }\n\n if (\n pathTruthy &&\n (!pointer.has(dataContext.data, pathTruthy) ||\n !pointer.get(dataContext.data, pathTruthy))\n ) {\n return\n }\n if (\n pathFalsy &&\n pointer.has(dataContext.data, pathFalsy) &&\n Boolean(pointer.get(dataContext.data, pathFalsy))\n ) {\n return\n }\n\n if (\n pathTrue &&\n (!pointer.has(dataContext.data, pathTrue) ||\n pointer.get(dataContext.data, pathTrue) !== true)\n ) {\n return\n }\n if (\n pathFalse &&\n (!pointer.has(dataContext.data, pathFalse) ||\n pointer.get(dataContext.data, pathFalse) !== false)\n ) {\n return\n }\n\n if (\n pathValue &&\n !(\n pointer.has(dataContext.data, pathValue) &&\n pointer.get(dataContext.data, pathValue) === whenValue\n )\n ) {\n return\n }\n\n if (inferData && !inferData(dataContext.data)) {\n return\n }\n\n return true\n }\n\n const open = Boolean(check())\n\n if (animate) {\n const props = !open ? fieldPropsWhenHidden : null\n\n return (\n <HeightAnimation\n open={open}\n keepInDOM={keepInDOM}\n className=\"dnb-forms-visibility\"\n {...rest}\n >\n <FieldProps {...props}>{children}</FieldProps>\n </HeightAnimation>\n )\n }\n\n if (keepInDOM) {\n const props = !open ? fieldPropsWhenHidden : null\n return (\n <span className=\"dnb-forms-visibility\" hidden={!open}>\n <FieldProps {...props}>{children}</FieldProps>\n </span>\n )\n }\n\n return <>{open ? children : null}</>\n}\n\nVisibility._supportsSpacingProps = 'children'\nexport default Visibility\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AACA,IAAAI,eAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,gBAAA,GAAAH,sBAAA,CAAAF,OAAA;AAGA,IAAAM,QAAA,GAAAJ,sBAAA,CAAAF,OAAA;AACA,IAAAO,WAAA,GAAAL,sBAAA,CAAAF,OAAA;AAAsC,MAAAQ,SAAA;AAAA,SAAAN,uBAAAO,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAd,wBAAAU,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAQ,KAAA,GAAAL,wBAAA,CAAAC,WAAA,OAAAI,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAT,GAAA,YAAAQ,KAAA,CAAAE,GAAA,CAAAV,GAAA,SAAAW,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAhB,GAAA,QAAAgB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAnB,GAAA,EAAAgB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAf,GAAA,EAAAgB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAhB,GAAA,CAAAgB,GAAA,SAAAL,MAAA,CAAAT,OAAA,GAAAF,GAAA,MAAAQ,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAArB,GAAA,EAAAW,MAAA,YAAAA,MAAA;AAAA,SAAAW,SAAA,IAAAA,QAAA,GAAAT,MAAA,CAAAU,MAAA,GAAAV,MAAA,CAAAU,MAAA,CAAAC,IAAA,eAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,GAAAF,SAAA,CAAAD,CAAA,YAAAV,GAAA,IAAAa,MAAA,QAAAhB,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAU,MAAA,EAAAb,GAAA,KAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,gBAAAS,MAAA,YAAAH,QAAA,CAAAQ,KAAA,OAAAH,SAAA;AAAA,SAAAI,yBAAAF,MAAA,EAAAG,QAAA,QAAAH,MAAA,yBAAAJ,MAAA,GAAAQ,6BAAA,CAAAJ,MAAA,EAAAG,QAAA,OAAAhB,GAAA,EAAAU,CAAA,MAAAb,MAAA,CAAAqB,qBAAA,QAAAC,gBAAA,GAAAtB,MAAA,CAAAqB,qBAAA,CAAAL,MAAA,QAAAH,CAAA,MAAAA,CAAA,GAAAS,gBAAA,CAAAP,MAAA,EAAAF,CAAA,MAAAV,GAAA,GAAAmB,gBAAA,CAAAT,CAAA,OAAAM,QAAA,CAAAI,OAAA,CAAApB,GAAA,uBAAAH,MAAA,CAAAI,SAAA,CAAAoB,oBAAA,CAAAlB,IAAA,CAAAU,MAAA,EAAAb,GAAA,aAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,cAAAS,MAAA;AAAA,SAAAQ,8BAAAJ,MAAA,EAAAG,QAAA,QAAAH,MAAA,yBAAAJ,MAAA,WAAAa,UAAA,GAAAzB,MAAA,CAAA0B,IAAA,CAAAV,MAAA,OAAAb,GAAA,EAAAU,CAAA,OAAAA,CAAA,MAAAA,CAAA,GAAAY,UAAA,CAAAV,MAAA,EAAAF,CAAA,MAAAV,GAAA,GAAAsB,UAAA,CAAAZ,CAAA,OAAAM,QAAA,CAAAI,OAAA,CAAApB,GAAA,kBAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,YAAAS,MAAA;AAkCtC,SAASe,UAAUA,CAAAC,IAAA,EAgBT;EAAA,IAhBU;MAClBC,OAAO;MACPC,WAAW;MACXC,aAAa;MACbC,UAAU;MACVC,SAAS;MACTC,QAAQ;MACRC,SAAS;MACTC,SAAS;MACTC,SAAS;MACTC,SAAS;MACTC,OAAO;MACPC,SAAS;MACTC,oBAAoB;MACpBC;IAEK,CAAC,GAAAd,IAAA;IADHe,IAAI,GAAAzB,wBAAA,CAAAU,IAAA,EAAA1C,SAAA;EAEP,MAAM0D,WAAW,GAAG,IAAAC,iBAAU,EAACC,gBAAW,CAAC;EAE3C,IAAAC,uBAAc,EAAC,MAAM;IACnB,IAAIN,oBAAoB,IAAI,CAACD,SAAS,EAAE;MACtC,IAAAQ,aAAI,EAAC,+DAA+D,CAAC;IACvE;EACF,CAAC,CAAC;EAEF,MAAMC,KAAK,GAAGA,CAAA,KAAM;IAClB,IAAIpB,OAAO,KAAK,KAAK,EAAE;MACrB;IACF;IAEA,IAAIC,WAAW,IAAI,CAACoB,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAErB,WAAW,CAAC,EAAE;MAC9D;IACF;IACA,IAAIC,aAAa,IAAImB,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAEpB,aAAa,CAAC,EAAE;MACjE;IACF;IAEA,IACEC,UAAU,KACT,CAACkB,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAEnB,UAAU,CAAC,IACzC,CAACkB,oBAAO,CAACrD,GAAG,CAAC+C,WAAW,CAACO,IAAI,EAAEnB,UAAU,CAAC,CAAC,EAC7C;MACA;IACF;IACA,IACEC,SAAS,IACTiB,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAElB,SAAS,CAAC,IACxCmB,OAAO,CAACF,oBAAO,CAACrD,GAAG,CAAC+C,WAAW,CAACO,IAAI,EAAElB,SAAS,CAAC,CAAC,EACjD;MACA;IACF;IAEA,IACEC,QAAQ,KACP,CAACgB,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAEjB,QAAQ,CAAC,IACvCgB,oBAAO,CAACrD,GAAG,CAAC+C,WAAW,CAACO,IAAI,EAAEjB,QAAQ,CAAC,KAAK,IAAI,CAAC,EACnD;MACA;IACF;IACA,IACEC,SAAS,KACR,CAACe,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAEhB,SAAS,CAAC,IACxCe,oBAAO,CAACrD,GAAG,CAAC+C,WAAW,CAACO,IAAI,EAAEhB,SAAS,CAAC,KAAK,KAAK,CAAC,EACrD;MACA;IACF;IAEA,IACEC,SAAS,IACT,EACEc,oBAAO,CAACtD,GAAG,CAACgD,WAAW,CAACO,IAAI,EAAEf,SAAS,CAAC,IACxCc,oBAAO,CAACrD,GAAG,CAAC+C,WAAW,CAACO,IAAI,EAAEf,SAAS,CAAC,KAAKC,SAAS,CACvD,EACD;MACA;IACF;IAEA,IAAIC,SAAS,IAAI,CAACA,SAAS,CAACM,WAAW,CAACO,IAAI,CAAC,EAAE;MAC7C;IACF;IAEA,OAAO,IAAI;EACb,CAAC;EAED,MAAME,IAAI,GAAGD,OAAO,CAACH,KAAK,CAAC,CAAC,CAAC;EAE7B,IAAIV,OAAO,EAAE;IACX,MAAMe,KAAK,GAAG,CAACD,IAAI,GAAGZ,oBAAoB,GAAG,IAAI;IAEjD,OACEjE,MAAA,CAAAa,OAAA,CAAAkE,aAAA,CAACxE,gBAAA,CAAAM,OAAe,EAAAoB,QAAA;MACd4C,IAAI,EAAEA,IAAK;MACXb,SAAS,EAAEA,SAAU;MACrBgB,SAAS,EAAC;IAAsB,GAC5Bb,IAAI,GAERnE,MAAA,CAAAa,OAAA,CAAAkE,aAAA,CAACtE,WAAA,CAAAI,OAAU,EAAKiE,KAAK,EAAGZ,QAAqB,CAC9B,CAAC;EAEtB;EAEA,IAAIF,SAAS,EAAE;IACb,MAAMc,KAAK,GAAG,CAACD,IAAI,GAAGZ,oBAAoB,GAAG,IAAI;IACjD,OACEjE,MAAA,CAAAa,OAAA,CAAAkE,aAAA;MAAMC,SAAS,EAAC,sBAAsB;MAACC,MAAM,EAAE,CAACJ;IAAK,GACnD7E,MAAA,CAAAa,OAAA,CAAAkE,aAAA,CAACtE,WAAA,CAAAI,OAAU,EAAKiE,KAAK,EAAGZ,QAAqB,CACzC,CAAC;EAEX;EAEA,OAAOlE,MAAA,CAAAa,OAAA,CAAAkE,aAAA,CAAA/E,MAAA,CAAAa,OAAA,CAAAqE,QAAA,QAAGL,IAAI,GAAGX,QAAQ,GAAG,IAAO,CAAC;AACtC;AAEAf,UAAU,CAACgC,qBAAqB,GAAG,UAAU;AAAA,IAAAC,QAAA,GAC9BjC,UAAU;AAAAkC,OAAA,CAAAxE,OAAA,GAAAuE,QAAA"}
1
+ {"version":3,"file":"Visibility.js","names":["_react","_interopRequireWildcard","require","_jsonPointer","_interopRequireDefault","_helpers","_useMountEffect","_HeightAnimation","_Context","_SectionContext","_FieldProps","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","Visibility","_ref","visible","pathDefined","pathUndefined","pathTruthy","pathFalsy","pathTrue","pathFalse","pathValue","whenValue","visibleWhen","visibleWhenNot","inferData","filterData","animate","keepInDOM","fieldPropsWhenHidden","children","rest","dataContext","useContext","DataContext","sectionContext","SectionContext","sectionPath","path","composePath","useCallback","useMountEffect","warn","check","_dataContext$filterDa","data","filterDataHandler","hasPath","pointer","_visibleWhen","_visibleWhen2","value","withValue","result","getValue","Boolean","open","props","createElement","className","hidden","Fragment","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Form/Visibility/Visibility.tsx"],"sourcesContent":["import React, { AriaAttributes, useCallback, useContext } from 'react'\nimport pointer from 'json-pointer'\nimport { warn } from '../../../../shared/helpers'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport HeightAnimation, {\n HeightAnimationProps,\n} from '../../../../components/HeightAnimation'\nimport DataContext, { FilterData } from '../../DataContext/Context'\nimport SectionContext from '../Section/SectionContext'\nimport FieldProps from '../FieldProps'\nimport type { Path, UseFieldProps } from '../../types'\nimport type { DataAttributes } from '../../hooks/useFieldProps'\n\ntype VisibleWhen =\n | {\n path: string\n hasValue: unknown\n }\n | {\n path: string\n withValue: (value: unknown) => boolean\n }\n\nexport type Props = {\n visible?: boolean\n /** Given data context path must be defined to show children */\n pathDefined?: string\n /** Given data context path must be undefined to show children */\n pathUndefined?: string\n /** Given data context path must be truthy to show children */\n pathTruthy?: string\n /** Given data context path must be falsy to show children */\n pathFalsy?: string\n /** Given data context path must be true to show children */\n pathTrue?: string\n /** Given data context path must be false to show children */\n pathFalse?: string\n /** Provide a `path` and a `hasValue` property with the excepted value in order to show children. You can alternatively provide a `withValue` function that returns a boolean. The first parameter is the value of the path. */\n visibleWhen?: VisibleWhen\n /** Same as `visibleWhen`, but with inverted logic. */\n visibleWhenNot?: VisibleWhen\n /** Infer visibility calling given derivative function with the whole data set. Should return true/false for visibility. */\n inferData?: (data: unknown) => boolean\n /** Filter data based on provided criteria. The first parameter is the path, the second is the value, and the third is the props, and the fourth is the internal. Return false to filter out the data. */\n filterData?: FilterData\n /** Animate the visibility change */\n animate?: boolean\n /** Keep the content in the DOM, even if it's not visible */\n keepInDOM?: boolean\n /** When visibility is hidden, and `keepInDOM` is true, pass these props to the children */\n fieldPropsWhenHidden?: UseFieldProps & DataAttributes & AriaAttributes\n element?: HeightAnimationProps['element']\n children: React.ReactNode\n\n /** @deprecated Use `visibleWhen` instead */\n pathValue?: string\n /** @deprecated Use `visibleWhen` instead */\n whenValue?: unknown\n}\n\nfunction Visibility({\n visible,\n pathDefined,\n pathUndefined,\n pathTruthy,\n pathFalsy,\n pathTrue,\n pathFalse,\n pathValue,\n whenValue,\n visibleWhen,\n visibleWhenNot,\n inferData,\n filterData,\n animate,\n keepInDOM,\n fieldPropsWhenHidden,\n children,\n ...rest\n}: Props) {\n const dataContext = useContext(DataContext)\n const sectionContext = useContext(SectionContext)\n\n const sectionPath = sectionContext?.path\n const composePath = useCallback(\n (path: Path) => {\n return `${\n sectionPath && sectionPath !== '/' ? sectionPath : ''\n }${path}`\n },\n [sectionPath]\n )\n\n useMountEffect(() => {\n if (fieldPropsWhenHidden && !keepInDOM) {\n warn('Using \"fieldPropsWhenHidden\" requires \"keepInDOM\" to be true.')\n }\n })\n\n const check = () => {\n if (visible === false) {\n return\n }\n\n const data =\n (filterData &&\n dataContext.filterDataHandler?.(dataContext.data, filterData)) ||\n dataContext.data\n\n if (visibleWhen || visibleWhenNot) {\n if (visibleWhenNot) {\n visibleWhen = visibleWhenNot\n }\n const hasPath = pointer.has(data, composePath(visibleWhen.path))\n if (hasPath) {\n const value = pointer.get(data, composePath(visibleWhen.path))\n\n const withValue = visibleWhen?.['withValue']\n const result =\n (withValue && withValue?.(value) === false) ||\n (Object.prototype.hasOwnProperty.call(visibleWhen, 'hasValue') &&\n visibleWhen?.['hasValue'] !== value)\n\n if (visibleWhenNot) {\n if (!result) {\n return\n }\n } else if (result) {\n return\n }\n } else {\n return\n }\n }\n\n if (pathDefined && !pointer.has(data, composePath(pathDefined))) {\n return\n }\n if (pathUndefined && pointer.has(data, composePath(pathUndefined))) {\n return\n }\n\n const getValue = (path: Path) => {\n if (pointer.has(data, path)) {\n return pointer.get(data, path)\n }\n }\n\n if (pathTrue && getValue(composePath(pathTrue)) !== true) {\n return\n }\n if (pathFalse && getValue(composePath(pathFalse)) !== false) {\n return\n }\n if (\n pathTruthy &&\n Boolean(getValue(composePath(pathTruthy))) === false\n ) {\n return\n }\n if (pathFalsy && Boolean(getValue(composePath(pathFalsy))) === true) {\n return\n }\n if (inferData && !inferData(data)) {\n return\n }\n\n // Deprecated can be removed in v11\n if (pathValue && getValue(composePath(pathValue)) !== whenValue) {\n return\n }\n\n return true\n }\n\n const open = Boolean(check())\n\n if (animate) {\n const props = !open ? fieldPropsWhenHidden : null\n\n return (\n <HeightAnimation\n open={open}\n keepInDOM={Boolean(keepInDOM)}\n className=\"dnb-forms-visibility\"\n {...rest}\n >\n <FieldProps {...props}>{children}</FieldProps>\n </HeightAnimation>\n )\n }\n\n if (keepInDOM) {\n const props = !open ? fieldPropsWhenHidden : null\n return (\n <span className=\"dnb-forms-visibility\" hidden={!open}>\n <FieldProps {...props}>{children}</FieldProps>\n </span>\n )\n }\n\n return <>{open ? children : null}</>\n}\n\nVisibility._supportsSpacingProps = 'children'\nexport default Visibility\n"],"mappings":"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"}
@@ -35,14 +35,14 @@ const VisibilityProperties = {
35
35
  type: 'string',
36
36
  status: 'optional'
37
37
  },
38
- pathValue: {
39
- doc: 'Given data context path must match, as well as the `whenValue` value.',
40
- type: 'string',
38
+ visibleWhen: {
39
+ doc: 'Provide a `path` and a `hasValue` property with the excepted value in order to show children. You can alternatively provide a `withValue` function that returns a boolean. The first parameter is the value of the path.',
40
+ type: 'object',
41
41
  status: 'optional'
42
42
  },
43
- whenValue: {
44
- doc: 'The value to match. Should be used together with `pathValue`.',
45
- type: 'string',
43
+ visibleWhenNot: {
44
+ doc: 'Same as `visibleWhen`, but with inverted logic.',
45
+ type: 'object',
46
46
  status: 'optional'
47
47
  },
48
48
  inferData: {
@@ -65,6 +65,11 @@ const VisibilityProperties = {
65
65
  type: 'boolean',
66
66
  status: 'optional'
67
67
  },
68
+ filterData: {
69
+ doc: 'Filter data based on provided criteria. More info about `filterData` can be found in the [Getting Started](/uilib/extensions/forms/getting-started/#filter-data) documentation.',
70
+ type: ['object', 'function'],
71
+ status: 'optional'
72
+ },
68
73
  fieldPropsWhenHidden: {
69
74
  doc: 'When visibility is hidden, and `keepInDOM` is true, pass these props to the children.',
70
75
  type: 'various',
@@ -1 +1 @@
1
- {"version":3,"file":"VisibilityDocs.js","names":["VisibilityProperties","pathDefined","doc","type","status","pathUndefined","pathTruthy","pathFalsy","pathTrue","pathFalse","pathValue","whenValue","inferData","visible","animate","keepInDOM","fieldPropsWhenHidden","element","children","exports"],"sources":["../../../../../../src/extensions/forms/Form/Visibility/VisibilityDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const VisibilityProperties: PropertiesTableProps = {\n pathDefined: {\n doc: 'Given data context path must be defined to show children.',\n type: 'string',\n status: 'optional',\n },\n pathUndefined: {\n doc: 'Given data context path must be undefined to show children.',\n type: 'string',\n status: 'optional',\n },\n pathTruthy: {\n doc: 'Given data context path must be truthy to show children.',\n type: 'string',\n status: 'optional',\n },\n pathFalsy: {\n doc: 'Given data context path must be falsy to show children.',\n type: 'string',\n status: 'optional',\n },\n pathTrue: {\n doc: 'Given data context path must be true to show children.',\n type: 'string',\n status: 'optional',\n },\n pathFalse: {\n doc: 'Given data context path must be false to show children.',\n type: 'string',\n status: 'optional',\n },\n pathValue: {\n doc: 'Given data context path must match, as well as the `whenValue` value.',\n type: 'string',\n status: 'optional',\n },\n whenValue: {\n doc: 'The value to match. Should be used together with `pathValue`.',\n type: 'string',\n status: 'optional',\n },\n inferData: {\n doc: 'Will be called to decide by external logic, and show/hide contents based on the return value.',\n type: 'function',\n status: 'optional',\n },\n visible: {\n doc: 'Control visibility directly by boolean value.',\n type: 'boolean',\n status: 'optional',\n },\n animate: {\n doc: 'Define if the content should animate during show/hide.',\n type: 'boolean',\n status: 'optional',\n },\n keepInDOM: {\n doc: \"Keep the content in the DOM, even if it's not visible. Can be used to let fields run validation.\",\n type: 'boolean',\n status: 'optional',\n },\n fieldPropsWhenHidden: {\n doc: 'When visibility is hidden, and `keepInDOM` is true, pass these props to the children.',\n type: 'various',\n status: 'optional',\n },\n element: {\n doc: 'Define the type of element. Defaults to `div`. Only for when `animate` is true.',\n type: 'string or React.Element',\n status: 'optional',\n },\n children: {\n doc: 'Contents.',\n type: 'React.Node',\n status: 'required',\n },\n}\n"],"mappings":";;;;;;AAEO,MAAMA,oBAA0C,GAAG;EACxDC,WAAW,EAAE;IACXC,GAAG,EAAE,2DAA2D;IAChEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,aAAa,EAAE;IACbH,GAAG,EAAE,6DAA6D;IAClEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,UAAU,EAAE;IACVJ,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,SAAS,EAAE;IACTL,GAAG,EAAE,yDAAyD;IAC9DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,QAAQ,EAAE;IACRN,GAAG,EAAE,wDAAwD;IAC7DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,SAAS,EAAE;IACTP,GAAG,EAAE,yDAAyD;IAC9DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,SAAS,EAAE;IACTR,GAAG,EAAE,uEAAuE;IAC5EC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,SAAS,EAAE;IACTT,GAAG,EAAE,+DAA+D;IACpEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAE;IACTV,GAAG,EAAE,+FAA+F;IACpGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDS,OAAO,EAAE;IACPX,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDU,OAAO,EAAE;IACPZ,GAAG,EAAE,wDAAwD;IAC7DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDW,SAAS,EAAE;IACTb,GAAG,EAAE,kGAAkG;IACvGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDY,oBAAoB,EAAE;IACpBd,GAAG,EAAE,uFAAuF;IAC5FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDa,OAAO,EAAE;IACPf,GAAG,EAAE,iFAAiF;IACtFC,IAAI,EAAE,yBAAyB;IAC/BC,MAAM,EAAE;EACV,CAAC;EACDc,QAAQ,EAAE;IACRhB,GAAG,EAAE,WAAW;IAChBC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV;AACF,CAAC;AAAAe,OAAA,CAAAnB,oBAAA,GAAAA,oBAAA"}
1
+ {"version":3,"file":"VisibilityDocs.js","names":["VisibilityProperties","pathDefined","doc","type","status","pathUndefined","pathTruthy","pathFalsy","pathTrue","pathFalse","visibleWhen","visibleWhenNot","inferData","visible","animate","keepInDOM","filterData","fieldPropsWhenHidden","element","children","exports"],"sources":["../../../../../../src/extensions/forms/Form/Visibility/VisibilityDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const VisibilityProperties: PropertiesTableProps = {\n pathDefined: {\n doc: 'Given data context path must be defined to show children.',\n type: 'string',\n status: 'optional',\n },\n pathUndefined: {\n doc: 'Given data context path must be undefined to show children.',\n type: 'string',\n status: 'optional',\n },\n pathTruthy: {\n doc: 'Given data context path must be truthy to show children.',\n type: 'string',\n status: 'optional',\n },\n pathFalsy: {\n doc: 'Given data context path must be falsy to show children.',\n type: 'string',\n status: 'optional',\n },\n pathTrue: {\n doc: 'Given data context path must be true to show children.',\n type: 'string',\n status: 'optional',\n },\n pathFalse: {\n doc: 'Given data context path must be false to show children.',\n type: 'string',\n status: 'optional',\n },\n visibleWhen: {\n doc: 'Provide a `path` and a `hasValue` property with the excepted value in order to show children. You can alternatively provide a `withValue` function that returns a boolean. The first parameter is the value of the path.',\n type: 'object',\n status: 'optional',\n },\n visibleWhenNot: {\n doc: 'Same as `visibleWhen`, but with inverted logic.',\n type: 'object',\n status: 'optional',\n },\n inferData: {\n doc: 'Will be called to decide by external logic, and show/hide contents based on the return value.',\n type: 'function',\n status: 'optional',\n },\n visible: {\n doc: 'Control visibility directly by boolean value.',\n type: 'boolean',\n status: 'optional',\n },\n animate: {\n doc: 'Define if the content should animate during show/hide.',\n type: 'boolean',\n status: 'optional',\n },\n keepInDOM: {\n doc: \"Keep the content in the DOM, even if it's not visible. Can be used to let fields run validation.\",\n type: 'boolean',\n status: 'optional',\n },\n filterData: {\n doc: 'Filter data based on provided criteria. More info about `filterData` can be found in the [Getting Started](/uilib/extensions/forms/getting-started/#filter-data) documentation.',\n type: ['object', 'function'],\n status: 'optional',\n },\n fieldPropsWhenHidden: {\n doc: 'When visibility is hidden, and `keepInDOM` is true, pass these props to the children.',\n type: 'various',\n status: 'optional',\n },\n element: {\n doc: 'Define the type of element. Defaults to `div`. Only for when `animate` is true.',\n type: 'string or React.Element',\n status: 'optional',\n },\n children: {\n doc: 'Contents.',\n type: 'React.Node',\n status: 'required',\n },\n}\n"],"mappings":";;;;;;AAEO,MAAMA,oBAA0C,GAAG;EACxDC,WAAW,EAAE;IACXC,GAAG,EAAE,2DAA2D;IAChEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,aAAa,EAAE;IACbH,GAAG,EAAE,6DAA6D;IAClEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,UAAU,EAAE;IACVJ,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,SAAS,EAAE;IACTL,GAAG,EAAE,yDAAyD;IAC9DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,QAAQ,EAAE;IACRN,GAAG,EAAE,wDAAwD;IAC7DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,SAAS,EAAE;IACTP,GAAG,EAAE,yDAAyD;IAC9DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,0NAA0N;IAC/NC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,cAAc,EAAE;IACdT,GAAG,EAAE,iDAAiD;IACtDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAE;IACTV,GAAG,EAAE,+FAA+F;IACpGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDS,OAAO,EAAE;IACPX,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDU,OAAO,EAAE;IACPZ,GAAG,EAAE,wDAAwD;IAC7DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDW,SAAS,EAAE;IACTb,GAAG,EAAE,kGAAkG;IACvGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDY,UAAU,EAAE;IACVd,GAAG,EAAE,iLAAiL;IACtLC,IAAI,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC;IAC5BC,MAAM,EAAE;EACV,CAAC;EACDa,oBAAoB,EAAE;IACpBf,GAAG,EAAE,uFAAuF;IAC5FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDc,OAAO,EAAE;IACPhB,GAAG,EAAE,iFAAiF;IACtFC,IAAI,EAAE,yBAAyB;IAC/BC,MAAM,EAAE;EACV,CAAC;EACDe,QAAQ,EAAE;IACRjB,GAAG,EAAE,WAAW;IAChBC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV;AACF,CAAC;AAAAgB,OAAA,CAAApB,oBAAA,GAAAA,oBAAA"}
@@ -5,7 +5,7 @@ type PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}` ? Ke
5
5
  type PathType<T, P extends string> = P extends `/${infer Rest}` ? PathImpl<T, Rest> : never;
6
6
  type UseDataReturnUpdate<Data> = <P extends Path>(path: P, value: ((value: PathType<Data, P>) => unknown) | unknown) => void;
7
7
  export type UseDataReturnGetValue<Data> = <P extends Path>(path: P) => PathType<Data, P>;
8
- export type UseDataReturnFilterData<Data> = (filterDataHandler: FilterData) => Partial<Data>;
8
+ export type UseDataReturnFilterData<Data> = (filterDataHandler: FilterData, data?: Data) => Partial<Data>;
9
9
  type UseDataReturn<Data> = {
10
10
  data: Data;
11
11
  set: (newData: Data) => void;
@@ -19,8 +19,12 @@ function useData() {
19
19
  const [, forceUpdate] = (0, _react.useReducer)(() => ({}), {});
20
20
  sharedDataRef.current = (0, _useSharedState.useSharedState)(id, initialData, forceUpdate);
21
21
  const context = (0, _react.useContext)(_Context.default);
22
- if (!id && context !== null && context !== void 0 && context.data) {
23
- sharedDataRef.current.data = context.data;
22
+ if (!id) {
23
+ if (context !== null && context !== void 0 && context.data) {
24
+ sharedDataRef.current.data = context.data;
25
+ } else if (!(context !== null && context !== void 0 && context.hasContext)) {
26
+ throw new Error('useData needs to run inside DataContext (Form.Handler) or have a valid id');
27
+ }
24
28
  }
25
29
  const updateDataValue = context === null || context === void 0 ? void 0 : context.updateDataValue;
26
30
  const setData = context === null || context === void 0 ? void 0 : context.setData;
@@ -48,8 +52,8 @@ function useData() {
48
52
  }
49
53
  }
50
54
  }, [id, updateDataValue]);
51
- const filterData = (0, _react.useCallback)(filter => {
52
- const data = sharedDataRef.current.data;
55
+ const filterData = (0, _react.useCallback)(function (filter) {
56
+ let data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : sharedDataRef.current.data;
53
57
  if (id) {
54
58
  var _sharedAttachmentsRef, _sharedAttachmentsRef2;
55
59
  return (_sharedAttachmentsRef = sharedAttachmentsRef.current.data) === null || _sharedAttachmentsRef === void 0 ? void 0 : (_sharedAttachmentsRef2 = _sharedAttachmentsRef.filterDataHandler) === null || _sharedAttachmentsRef2 === void 0 ? void 0 : _sharedAttachmentsRef2.call(_sharedAttachmentsRef, data, filter);
@@ -1 +1 @@
1
- {"version":3,"file":"useData.js","names":["_react","require","_jsonPointer","_interopRequireDefault","_useSharedState","_useMountEffect","_Context","obj","__esModule","default","useData","id","arguments","length","undefined","initialData","sharedDataRef","useRef","sharedAttachmentsRef","forceUpdate","useReducer","current","useSharedState","context","useContext","DataContext","data","updateDataValue","setData","rerenderUseDataHook","setHandler","useCallback","newData","update","updateHandler","path","value","existingData","existingValue","pointer","has","get","newValue","set","extend","filterData","filter","_sharedAttachmentsRef","_sharedAttachmentsRef2","filterDataHandler","call","getValue","useMountEffect","hadInitialData","useMemo"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useData.tsx"],"sourcesContent":["import {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer from 'json-pointer'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport type { Path } from '../../types'\nimport DataContext, {\n FilterData,\n FilterDataHandler,\n} from '../../DataContext/Context'\n\ntype PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}`\n ? Key extends keyof T\n ? Rest extends ''\n ? T[Key]\n : PathImpl<T[Key], Rest>\n : never\n : T[P & keyof T]\n\ntype PathType<T, P extends string> = P extends `/${infer Rest}`\n ? PathImpl<T, Rest>\n : never\n\ntype UseDataReturnUpdate<Data> = <P extends Path>(\n path: P,\n value: ((value: PathType<Data, P>) => unknown) | unknown\n) => void\n\nexport type UseDataReturnGetValue<Data> = <P extends Path>(\n path: P\n) => PathType<Data, P>\n\nexport type UseDataReturnFilterData<Data> = (\n filterDataHandler: FilterData\n) => Partial<Data>\n\ntype UseDataReturn<Data> = {\n data: Data\n set: (newData: Data) => void\n update: UseDataReturnUpdate<Data>\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n}\n\ntype SharedAttachment<Data> = {\n rerenderUseDataHook: () => void\n filterDataHandler?: FilterDataHandler<Data>\n}\n\n/**\n * Custom hook that provides form data management functionality.\n *\n * @template Data - The type of data being managed.\n * @param {SharedStateId} id - The identifier for the data.\n * @param {Data} initialData - The initial data value (optional).\n * @returns {UseDataReturn<Data>} An object containing the data and data management functions.\n */\nexport default function useData<Data>(\n id: SharedStateId = undefined,\n initialData: Data = undefined\n): UseDataReturn<Data> {\n const sharedDataRef =\n useRef<ReturnType<typeof useSharedState<Data>>>(null)\n const sharedAttachmentsRef =\n useRef<ReturnType<typeof useSharedState<SharedAttachment<Data>>>>(null)\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n sharedDataRef.current = useSharedState<Data>(\n id,\n initialData,\n forceUpdate\n )\n\n // If no id is provided, use the context data\n const context = useContext(DataContext)\n if (!id && context?.data) {\n sharedDataRef.current.data = context.data\n }\n const updateDataValue = context?.updateDataValue\n const setData = context?.setData\n\n sharedAttachmentsRef.current = useSharedState<SharedAttachment<Data>>(\n id + '-attachments',\n { rerenderUseDataHook: forceUpdate }\n )\n\n const setHandler = useCallback(\n (newData: Data) => {\n if (id) {\n sharedDataRef.current.update(newData)\n } else {\n setData?.(newData)\n }\n },\n [id, setData]\n )\n\n const updateHandler = useCallback<UseDataReturnUpdate<Data>>(\n (path, value = undefined) => {\n const existingData = sharedDataRef.current.data || ({} as Data)\n const existingValue = pointer.has(existingData, path)\n ? pointer.get(existingData, path)\n : undefined\n\n // get new value\n const newValue =\n typeof value === 'function' ? value(existingValue) : value\n\n if (newValue !== existingValue) {\n // update existing data\n pointer.set(existingData, path, newValue)\n\n // update provider\n if (id) {\n sharedDataRef.current.extend(existingData)\n } else {\n updateDataValue(path, newValue)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const filterData = useCallback<UseDataReturn<Data>['filterData']>(\n (filter) => {\n const data = sharedDataRef.current.data\n\n if (id) {\n return sharedAttachmentsRef.current.data?.filterDataHandler?.(\n data,\n filter\n )\n }\n\n return context?.filterDataHandler(data, filter)\n },\n [context, id]\n )\n\n const getValue = useCallback<UseDataReturn<Data>['getValue']>((path) => {\n if (pointer.has(sharedDataRef.current.data, path)) {\n return pointer.get(sharedDataRef.current.data, path)\n }\n\n return undefined\n }, [])\n\n useMountEffect(() => {\n if (id && !sharedDataRef.current.hadInitialData && initialData) {\n sharedDataRef.current.extend(initialData)\n }\n })\n\n const { data } = sharedDataRef.current\n\n return useMemo(\n () => ({\n data,\n update: updateHandler,\n set: setHandler,\n getValue,\n filterData,\n }),\n [data, filterData, getValue, setHandler, updateHandler]\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"useData.js","names":["_react","require","_jsonPointer","_interopRequireDefault","_useSharedState","_useMountEffect","_Context","obj","__esModule","default","useData","id","arguments","length","undefined","initialData","sharedDataRef","useRef","sharedAttachmentsRef","forceUpdate","useReducer","current","useSharedState","context","useContext","DataContext","data","hasContext","Error","updateDataValue","setData","rerenderUseDataHook","setHandler","useCallback","newData","update","updateHandler","path","value","existingData","existingValue","pointer","has","get","newValue","set","extend","filterData","filter","_sharedAttachmentsRef","_sharedAttachmentsRef2","filterDataHandler","call","getValue","useMountEffect","hadInitialData","useMemo"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useData.tsx"],"sourcesContent":["import {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer from 'json-pointer'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport type { Path } from '../../types'\nimport DataContext, {\n FilterData,\n FilterDataHandler,\n} from '../../DataContext/Context'\n\ntype PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}`\n ? Key extends keyof T\n ? Rest extends ''\n ? T[Key]\n : PathImpl<T[Key], Rest>\n : never\n : T[P & keyof T]\n\ntype PathType<T, P extends string> = P extends `/${infer Rest}`\n ? PathImpl<T, Rest>\n : never\n\ntype UseDataReturnUpdate<Data> = <P extends Path>(\n path: P,\n value: ((value: PathType<Data, P>) => unknown) | unknown\n) => void\n\nexport type UseDataReturnGetValue<Data> = <P extends Path>(\n path: P\n) => PathType<Data, P>\n\nexport type UseDataReturnFilterData<Data> = (\n filterDataHandler: FilterData,\n data?: Data\n) => Partial<Data>\n\ntype UseDataReturn<Data> = {\n data: Data\n set: (newData: Data) => void\n update: UseDataReturnUpdate<Data>\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n}\n\ntype SharedAttachment<Data> = {\n rerenderUseDataHook: () => void\n filterDataHandler?: FilterDataHandler<Data>\n}\n\n/**\n * Custom hook that provides form data management functionality.\n *\n * @template Data - The type of data being managed.\n * @param {SharedStateId} id - The identifier for the data.\n * @param {Data} initialData - The initial data value (optional).\n * @returns {UseDataReturn<Data>} An object containing the data and data management functions.\n */\nexport default function useData<Data>(\n id: SharedStateId = undefined,\n initialData: Data = undefined\n): UseDataReturn<Data> {\n const sharedDataRef =\n useRef<ReturnType<typeof useSharedState<Data>>>(null)\n const sharedAttachmentsRef =\n useRef<ReturnType<typeof useSharedState<SharedAttachment<Data>>>>(null)\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n sharedDataRef.current = useSharedState<Data>(\n id,\n initialData,\n forceUpdate\n )\n\n // If no id is provided, use the context data\n const context = useContext(DataContext)\n if (!id) {\n if (context?.data) {\n sharedDataRef.current.data = context.data\n } else if (!context?.hasContext) {\n throw new Error(\n 'useData needs to run inside DataContext (Form.Handler) or have a valid id'\n )\n }\n }\n const updateDataValue = context?.updateDataValue\n const setData = context?.setData\n\n sharedAttachmentsRef.current = useSharedState<SharedAttachment<Data>>(\n id + '-attachments',\n { rerenderUseDataHook: forceUpdate }\n )\n\n const setHandler = useCallback(\n (newData: Data) => {\n if (id) {\n sharedDataRef.current.update(newData)\n } else {\n setData?.(newData)\n }\n },\n [id, setData]\n )\n\n const updateHandler = useCallback<UseDataReturnUpdate<Data>>(\n (path, value = undefined) => {\n const existingData = sharedDataRef.current.data || ({} as Data)\n const existingValue = pointer.has(existingData, path)\n ? pointer.get(existingData, path)\n : undefined\n\n // get new value\n const newValue =\n typeof value === 'function' ? value(existingValue) : value\n\n if (newValue !== existingValue) {\n // update existing data\n pointer.set(existingData, path, newValue)\n\n // update provider\n if (id) {\n sharedDataRef.current.extend(existingData)\n } else {\n updateDataValue(path, newValue)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const filterData = useCallback<UseDataReturn<Data>['filterData']>(\n (filter, data = sharedDataRef.current.data) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.filterDataHandler?.(\n data,\n filter\n )\n }\n\n return context?.filterDataHandler(data, filter)\n },\n [context, id]\n )\n\n const getValue = useCallback<UseDataReturn<Data>['getValue']>((path) => {\n if (pointer.has(sharedDataRef.current.data, path)) {\n return pointer.get(sharedDataRef.current.data, path)\n }\n\n return undefined\n }, [])\n\n useMountEffect(() => {\n if (id && !sharedDataRef.current.hadInitialData && initialData) {\n sharedDataRef.current.extend(initialData)\n }\n })\n\n const { data } = sharedDataRef.current\n\n return useMemo(\n () => ({\n data,\n update: updateHandler,\n set: setHandler,\n getValue,\n filterData,\n }),\n [data, filterData, getValue, setHandler, updateHandler]\n )\n}\n"],"mappings":"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"}
@@ -2,6 +2,7 @@ import { SharedStateId } from '../../../../shared/helpers/useSharedState';
2
2
  import { ContextState } from '../../DataContext/Context';
3
3
  type UseDataReturn = {
4
4
  hasErrors: ContextState['hasErrors'];
5
+ hasFieldError: ContextState['hasFieldError'];
5
6
  setFormError: (error: Error) => void;
6
7
  };
7
8
  export default function useError(id?: SharedStateId): UseDataReturn;
@@ -10,14 +10,15 @@ var _useSharedState = require("../../../../shared/helpers/useSharedState");
10
10
  var _Context = _interopRequireDefault(require("../../DataContext/Context"));
11
11
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
12
  function useError() {
13
- var _sharedAttachmentsRef, _sharedAttachmentsRef2, _sharedAttachmentsRef3, _sharedAttachmentsRef4;
13
+ var _sharedAttachmentsRef, _sharedAttachmentsRef2, _sharedAttachmentsRef3, _sharedAttachmentsRef4, _sharedAttachmentsRef5, _sharedAttachmentsRef6;
14
14
  let id = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined;
15
15
  const sharedAttachmentsRef = (0, _react.useRef)(null);
16
16
  sharedAttachmentsRef.current = (0, _useSharedState.useSharedState)(id + '-attachments');
17
17
  const fallback = (0, _react.useCallback)(() => false, []);
18
18
  const context = (0, _react.useContext)(_Context.default);
19
19
  const hasErrors = ((_sharedAttachmentsRef = sharedAttachmentsRef.current) === null || _sharedAttachmentsRef === void 0 ? void 0 : (_sharedAttachmentsRef2 = _sharedAttachmentsRef.data) === null || _sharedAttachmentsRef2 === void 0 ? void 0 : _sharedAttachmentsRef2.hasErrors) || !id && (context === null || context === void 0 ? void 0 : context.hasErrors) || fallback;
20
- const setSubmitState = ((_sharedAttachmentsRef3 = sharedAttachmentsRef.current) === null || _sharedAttachmentsRef3 === void 0 ? void 0 : (_sharedAttachmentsRef4 = _sharedAttachmentsRef3.data) === null || _sharedAttachmentsRef4 === void 0 ? void 0 : _sharedAttachmentsRef4.setSubmitState) || !id && (context === null || context === void 0 ? void 0 : context.setSubmitState) || fallback;
20
+ const hasFieldError = ((_sharedAttachmentsRef3 = sharedAttachmentsRef.current) === null || _sharedAttachmentsRef3 === void 0 ? void 0 : (_sharedAttachmentsRef4 = _sharedAttachmentsRef3.data) === null || _sharedAttachmentsRef4 === void 0 ? void 0 : _sharedAttachmentsRef4.hasFieldError) || !id && (context === null || context === void 0 ? void 0 : context.hasFieldError) || fallback;
21
+ const setSubmitState = ((_sharedAttachmentsRef5 = sharedAttachmentsRef.current) === null || _sharedAttachmentsRef5 === void 0 ? void 0 : (_sharedAttachmentsRef6 = _sharedAttachmentsRef5.data) === null || _sharedAttachmentsRef6 === void 0 ? void 0 : _sharedAttachmentsRef6.setSubmitState) || !id && (context === null || context === void 0 ? void 0 : context.setSubmitState) || fallback;
21
22
  const setFormError = (0, _react.useCallback)(error => {
22
23
  setSubmitState === null || setSubmitState === void 0 ? void 0 : setSubmitState({
23
24
  error
@@ -25,7 +26,8 @@ function useError() {
25
26
  }, [setSubmitState]);
26
27
  return (0, _react.useMemo)(() => ({
27
28
  hasErrors,
29
+ hasFieldError,
28
30
  setFormError
29
- }), [hasErrors, setFormError]);
31
+ }), [hasErrors, hasFieldError, setFormError]);
30
32
  }
31
33
  //# sourceMappingURL=useError.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useError.js","names":["_react","require","_useSharedState","_Context","_interopRequireDefault","obj","__esModule","default","useError","_sharedAttachmentsRef","_sharedAttachmentsRef2","_sharedAttachmentsRef3","_sharedAttachmentsRef4","id","arguments","length","undefined","sharedAttachmentsRef","useRef","current","useSharedState","fallback","useCallback","context","useContext","DataContext","hasErrors","data","setSubmitState","setFormError","error","useMemo"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useError.tsx"],"sourcesContent":["import { useCallback, useContext, useMemo, useRef } from 'react'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport DataContext, { ContextState } from '../../DataContext/Context'\n\ntype UseDataReturn = {\n hasErrors: ContextState['hasErrors']\n setFormError: (error: Error) => void\n}\n\nexport default function useError(\n id: SharedStateId = undefined\n): UseDataReturn {\n const sharedAttachmentsRef = useRef(null)\n sharedAttachmentsRef.current = useSharedState<UseDataReturn>(\n id + '-attachments'\n )\n\n const fallback = useCallback(() => false, [])\n\n // If no id is provided, use the context version\n const context = useContext(DataContext)\n const hasErrors =\n sharedAttachmentsRef.current?.data?.hasErrors ||\n (!id && context?.hasErrors) ||\n fallback\n\n // Error handling\n const setSubmitState =\n sharedAttachmentsRef.current?.data?.setSubmitState ||\n (!id && context?.setSubmitState) ||\n fallback\n const setFormError = useCallback(\n (error: Error) => {\n setSubmitState?.({ error })\n // console.error(error)\n },\n [setSubmitState]\n )\n\n return useMemo(\n () => ({ hasErrors, setFormError }),\n [hasErrors, setFormError]\n )\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AAIA,IAAAE,QAAA,GAAAC,sBAAA,CAAAH,OAAA;AAAqE,SAAAG,uBAAAC,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAOtD,SAASG,QAAQA,CAAA,EAEf;EAAA,IAAAC,qBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA;EAAA,IADfC,EAAiB,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAGE,SAAS;EAE7B,MAAMC,oBAAoB,GAAG,IAAAC,aAAM,EAAC,IAAI,CAAC;EACzCD,oBAAoB,CAACE,OAAO,GAAG,IAAAC,8BAAc,EAC3CP,EAAE,GAAG,cACP,CAAC;EAED,MAAMQ,QAAQ,GAAG,IAAAC,kBAAW,EAAC,MAAM,KAAK,EAAE,EAAE,CAAC;EAG7C,MAAMC,OAAO,GAAG,IAAAC,iBAAU,EAACC,gBAAW,CAAC;EACvC,MAAMC,SAAS,GACb,EAAAjB,qBAAA,GAAAQ,oBAAoB,CAACE,OAAO,cAAAV,qBAAA,wBAAAC,sBAAA,GAA5BD,qBAAA,CAA8BkB,IAAI,cAAAjB,sBAAA,uBAAlCA,sBAAA,CAAoCgB,SAAS,KAC5C,CAACb,EAAE,KAAIU,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEG,SAAS,CAAC,IAC3BL,QAAQ;EAGV,MAAMO,cAAc,GAClB,EAAAjB,sBAAA,GAAAM,oBAAoB,CAACE,OAAO,cAAAR,sBAAA,wBAAAC,sBAAA,GAA5BD,sBAAA,CAA8BgB,IAAI,cAAAf,sBAAA,uBAAlCA,sBAAA,CAAoCgB,cAAc,KACjD,CAACf,EAAE,KAAIU,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEK,cAAc,CAAC,IAChCP,QAAQ;EACV,MAAMQ,YAAY,GAAG,IAAAP,kBAAW,EAC7BQ,KAAY,IAAK;IAChBF,cAAc,aAAdA,cAAc,uBAAdA,cAAc,CAAG;MAAEE;IAAM,CAAC,CAAC;EAE7B,CAAC,EACD,CAACF,cAAc,CACjB,CAAC;EAED,OAAO,IAAAG,cAAO,EACZ,OAAO;IAAEL,SAAS;IAAEG;EAAa,CAAC,CAAC,EACnC,CAACH,SAAS,EAAEG,YAAY,CAC1B,CAAC;AACH"}
1
+ {"version":3,"file":"useError.js","names":["_react","require","_useSharedState","_Context","_interopRequireDefault","obj","__esModule","default","useError","_sharedAttachmentsRef","_sharedAttachmentsRef2","_sharedAttachmentsRef3","_sharedAttachmentsRef4","_sharedAttachmentsRef5","_sharedAttachmentsRef6","id","arguments","length","undefined","sharedAttachmentsRef","useRef","current","useSharedState","fallback","useCallback","context","useContext","DataContext","hasErrors","data","hasFieldError","setSubmitState","setFormError","error","useMemo"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useError.tsx"],"sourcesContent":["import { useCallback, useContext, useMemo, useRef } from 'react'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport DataContext, { ContextState } from '../../DataContext/Context'\n\ntype UseDataReturn = {\n hasErrors: ContextState['hasErrors']\n hasFieldError: ContextState['hasFieldError']\n setFormError: (error: Error) => void\n}\n\nexport default function useError(\n id: SharedStateId = undefined\n): UseDataReturn {\n const sharedAttachmentsRef = useRef(null)\n sharedAttachmentsRef.current = useSharedState<UseDataReturn>(\n id + '-attachments'\n )\n\n const fallback = useCallback(() => false, [])\n\n // If no id is provided, use the context version\n const context = useContext(DataContext)\n const hasErrors =\n sharedAttachmentsRef.current?.data?.hasErrors ||\n (!id && context?.hasErrors) ||\n fallback\n const hasFieldError =\n sharedAttachmentsRef.current?.data?.hasFieldError ||\n (!id && context?.hasFieldError) ||\n fallback\n\n // Error handling\n const setSubmitState =\n sharedAttachmentsRef.current?.data?.setSubmitState ||\n (!id && context?.setSubmitState) ||\n fallback\n const setFormError = useCallback(\n (error: Error) => {\n setSubmitState?.({ error })\n },\n [setSubmitState]\n )\n\n return useMemo(\n () => ({ hasErrors, hasFieldError, setFormError }),\n [hasErrors, hasFieldError, setFormError]\n )\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AAIA,IAAAE,QAAA,GAAAC,sBAAA,CAAAH,OAAA;AAAqE,SAAAG,uBAAAC,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAQtD,SAASG,QAAQA,CAAA,EAEf;EAAA,IAAAC,qBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA;EAAA,IADfC,EAAiB,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAGE,SAAS;EAE7B,MAAMC,oBAAoB,GAAG,IAAAC,aAAM,EAAC,IAAI,CAAC;EACzCD,oBAAoB,CAACE,OAAO,GAAG,IAAAC,8BAAc,EAC3CP,EAAE,GAAG,cACP,CAAC;EAED,MAAMQ,QAAQ,GAAG,IAAAC,kBAAW,EAAC,MAAM,KAAK,EAAE,EAAE,CAAC;EAG7C,MAAMC,OAAO,GAAG,IAAAC,iBAAU,EAACC,gBAAW,CAAC;EACvC,MAAMC,SAAS,GACb,EAAAnB,qBAAA,GAAAU,oBAAoB,CAACE,OAAO,cAAAZ,qBAAA,wBAAAC,sBAAA,GAA5BD,qBAAA,CAA8BoB,IAAI,cAAAnB,sBAAA,uBAAlCA,sBAAA,CAAoCkB,SAAS,KAC5C,CAACb,EAAE,KAAIU,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEG,SAAS,CAAC,IAC3BL,QAAQ;EACV,MAAMO,aAAa,GACjB,EAAAnB,sBAAA,GAAAQ,oBAAoB,CAACE,OAAO,cAAAV,sBAAA,wBAAAC,sBAAA,GAA5BD,sBAAA,CAA8BkB,IAAI,cAAAjB,sBAAA,uBAAlCA,sBAAA,CAAoCkB,aAAa,KAChD,CAACf,EAAE,KAAIU,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEK,aAAa,CAAC,IAC/BP,QAAQ;EAGV,MAAMQ,cAAc,GAClB,EAAAlB,sBAAA,GAAAM,oBAAoB,CAACE,OAAO,cAAAR,sBAAA,wBAAAC,sBAAA,GAA5BD,sBAAA,CAA8BgB,IAAI,cAAAf,sBAAA,uBAAlCA,sBAAA,CAAoCiB,cAAc,KACjD,CAAChB,EAAE,KAAIU,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEM,cAAc,CAAC,IAChCR,QAAQ;EACV,MAAMS,YAAY,GAAG,IAAAR,kBAAW,EAC7BS,KAAY,IAAK;IAChBF,cAAc,aAAdA,cAAc,uBAAdA,cAAc,CAAG;MAAEE;IAAM,CAAC,CAAC;EAC7B,CAAC,EACD,CAACF,cAAc,CACjB,CAAC;EAED,OAAO,IAAAG,cAAO,EACZ,OAAO;IAAEN,SAAS;IAAEE,aAAa;IAAEE;EAAa,CAAC,CAAC,EAClD,CAACJ,SAAS,EAAEE,aAAa,EAAEE,YAAY,CACzC,CAAC;AACH"}
@@ -7,6 +7,7 @@ export { default as ButtonRow } from './ButtonRow';
7
7
  export { default as MainHeading } from './MainHeading';
8
8
  export { default as SubHeading } from './SubHeading';
9
9
  export { default as Visibility } from './Visibility';
10
+ export { default as Section } from './Section';
10
11
  export { default as FieldProps } from './FieldProps';
11
12
  export { default as useData } from './data-context/useData';
12
13
  export { default as setData } from './data-context/setData';
@@ -39,6 +39,12 @@ Object.defineProperty(exports, "MainHeading", {
39
39
  return _MainHeading.default;
40
40
  }
41
41
  });
42
+ Object.defineProperty(exports, "Section", {
43
+ enumerable: true,
44
+ get: function () {
45
+ return _Section.default;
46
+ }
47
+ });
42
48
  Object.defineProperty(exports, "SubHeading", {
43
49
  enumerable: true,
44
50
  get: function () {
@@ -108,6 +114,7 @@ var _ButtonRow = _interopRequireDefault(require("./ButtonRow"));
108
114
  var _MainHeading = _interopRequireDefault(require("./MainHeading"));
109
115
  var _SubHeading = _interopRequireDefault(require("./SubHeading"));
110
116
  var _Visibility = _interopRequireDefault(require("./Visibility"));
117
+ var _Section = _interopRequireDefault(require("./Section"));
111
118
  var _FieldProps = _interopRequireDefault(require("./FieldProps"));
112
119
  var _useData = _interopRequireDefault(require("./data-context/useData"));
113
120
  var _setData = _interopRequireDefault(require("./data-context/setData"));
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_Handler","_interopRequireDefault","require","_Element","_Appearance","_SubmitButton","_SubmitIndicator","_ButtonRow","_MainHeading","_SubHeading","_Visibility","_FieldProps","_useData","_setData","_getData","_useError","_useTranslation","obj","__esModule","default"],"sources":["../../../../../src/extensions/forms/Form/index.ts"],"sourcesContent":["export { default as Handler } from './Handler'\nexport { default as Element } from './Element'\nexport { default as Appearance } from './Appearance'\nexport { default as SubmitButton } from './SubmitButton'\nexport { default as SubmitIndicator } from './SubmitIndicator'\nexport { default as ButtonRow } from './ButtonRow'\nexport { default as MainHeading } from './MainHeading'\nexport { default as SubHeading } from './SubHeading'\nexport { default as Visibility } from './Visibility'\nexport { default as FieldProps } from './FieldProps'\nexport { default as useData } from './data-context/useData'\nexport { default as setData } from './data-context/setData'\nexport { default as getData } from './data-context/getData'\nexport { default as useError } from './data-context/useError'\nexport { default as useTranslation } from '../hooks/useTranslation'\n\n/**\n * Can be removed in v11\n * @deprecated Use `useTranslation` instead\n */\nexport { default as useLocale } from '../hooks/useTranslation'\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,WAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,aAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,gBAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,UAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,YAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,WAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,WAAA,GAAAT,sBAAA,CAAAC,OAAA;AACA,IAAAS,WAAA,GAAAV,sBAAA,CAAAC,OAAA;AACA,IAAAU,QAAA,GAAAX,sBAAA,CAAAC,OAAA;AACA,IAAAW,QAAA,GAAAZ,sBAAA,CAAAC,OAAA;AACA,IAAAY,QAAA,GAAAb,sBAAA,CAAAC,OAAA;AACA,IAAAa,SAAA,GAAAd,sBAAA,CAAAC,OAAA;AACA,IAAAc,eAAA,GAAAf,sBAAA,CAAAC,OAAA;AAAmE,SAAAD,uBAAAgB,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA"}
1
+ {"version":3,"file":"index.js","names":["_Handler","_interopRequireDefault","require","_Element","_Appearance","_SubmitButton","_SubmitIndicator","_ButtonRow","_MainHeading","_SubHeading","_Visibility","_Section","_FieldProps","_useData","_setData","_getData","_useError","_useTranslation","obj","__esModule","default"],"sources":["../../../../../src/extensions/forms/Form/index.ts"],"sourcesContent":["export { default as Handler } from './Handler'\nexport { default as Element } from './Element'\nexport { default as Appearance } from './Appearance'\nexport { default as SubmitButton } from './SubmitButton'\nexport { default as SubmitIndicator } from './SubmitIndicator'\nexport { default as ButtonRow } from './ButtonRow'\nexport { default as MainHeading } from './MainHeading'\nexport { default as SubHeading } from './SubHeading'\nexport { default as Visibility } from './Visibility'\nexport { default as Section } from './Section'\nexport { default as FieldProps } from './FieldProps'\nexport { default as useData } from './data-context/useData'\nexport { default as setData } from './data-context/setData'\nexport { default as getData } from './data-context/getData'\nexport { default as useError } from './data-context/useError'\nexport { default as useTranslation } from '../hooks/useTranslation'\n\n/**\n * Can be removed in v11\n * @deprecated Use `useTranslation` instead\n */\nexport { default as useLocale } from '../hooks/useTranslation'\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,WAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,aAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,gBAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,UAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,YAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,WAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,WAAA,GAAAT,sBAAA,CAAAC,OAAA;AACA,IAAAS,QAAA,GAAAV,sBAAA,CAAAC,OAAA;AACA,IAAAU,WAAA,GAAAX,sBAAA,CAAAC,OAAA;AACA,IAAAW,QAAA,GAAAZ,sBAAA,CAAAC,OAAA;AACA,IAAAY,QAAA,GAAAb,sBAAA,CAAAC,OAAA;AACA,IAAAa,QAAA,GAAAd,sBAAA,CAAAC,OAAA;AACA,IAAAc,SAAA,GAAAf,sBAAA,CAAAC,OAAA;AACA,IAAAe,eAAA,GAAAhB,sBAAA,CAAAC,OAAA;AAAmE,SAAAD,uBAAAiB,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA"}
@@ -1,11 +1,18 @@
1
1
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
2
2
  import { ContainerMode } from '../Array/types';
3
+ export type ElementSectionProps = {
4
+ /**
5
+ * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.
6
+ * Defaults to `outline`.
7
+ */
8
+ variant?: 'outline' | 'basic';
9
+ };
3
10
  export type Props = {
4
11
  mode: ContainerMode;
5
12
  open?: boolean | undefined;
6
13
  ariaLabel?: string;
7
14
  openDelay?: number;
8
- };
15
+ } & ElementSectionProps;
9
16
  declare function ElementBlock(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
10
17
  declare namespace ElementBlock {
11
18
  var _supportsSpacingProps: boolean;
@@ -11,7 +11,7 @@ var _components = require("../../../../components");
11
11
  var _IterateElementContext = _interopRequireDefault(require("../IterateElementContext"));
12
12
  var _ElementBlockContext = _interopRequireDefault(require("./ElementBlockContext"));
13
13
  var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
14
- const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay"];
14
+ const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay", "variant"];
15
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
16
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
17
17
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -44,7 +44,8 @@ function ElementBlock(props) {
44
44
  onAnimationEnd,
45
45
  className,
46
46
  children,
47
- openDelay = 100
47
+ openDelay = 100,
48
+ variant = 'outline'
48
49
  } = props,
49
50
  restProps = _objectWithoutProperties(props, _excluded);
50
51
  const openRef = (0, _react.useRef)(open !== null && open !== void 0 ? open : containerMode === mode && !isNew);
@@ -111,7 +112,7 @@ function ElementBlock(props) {
111
112
  handleRemoveBlock
112
113
  }
113
114
  }, _react.default.createElement(_components.HeightAnimation, {
114
- className: (0, _classnames.default)('dnb-forms-iterate-block', className, isNew && 'dnb-forms-iterate-block--new', contextRef.current.hasErrorAndShowIt && 'dnb-forms-iterate-block--error'),
115
+ className: (0, _classnames.default)('dnb-forms-iterate-block', className, variant && `dnb-forms-iterate-block--variant-${variant}`, isNew && 'dnb-forms-iterate-block--new', contextRef.current.hasErrorAndShowIt && 'dnb-forms-iterate-block--error'),
115
116
  open: openRef.current,
116
117
  onAnimationEnd: handleAnimationEnd,
117
118
  duration: 450,
@@ -1 +1 @@
1
- {"version":3,"file":"ElementBlock.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateElementContext","_ElementBlockContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ElementBlock","props","forceUpdate","useReducer","contextRef","useRef","current","useContext","IterateElementContext","hasError","hasErrorAndShowIt","FieldBoundaryContext","containerMode","handleRemove","switchContainerMode","isNew","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","restProps","openRef","isRemoving","setOpenState","useCallback","useEffect","setTimeout","handleAnimationEnd","state","preventFocusOnErrorOpening","_contextRef$current","_contextRef$current$e","_contextRef$current$e2","_contextRef$current$e3","elementRef","focus","window","requestAnimationFrame","_document$activeEleme","document","activeElement","closest","_contextRef$current2","elements","containerRef","querySelectorAll","e","_contextRef$current3","_contextRef$current3$","fulfillRemove","handleRemoveBlock","keepItems","createElement","Provider","value","HeightAnimation","classnames","duration","keepInDOM","Flex","Stack","element","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/ElementBlock.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport ElementBlockContext from './ElementBlockContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from '../Array/types'\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n}\n\nfunction ElementBlock(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const contextRef = useRef<\n IterateElementContextState & {\n hasError?: boolean\n hasErrorAndShowIt?: boolean\n }\n >()\n contextRef.current = useContext(IterateElementContext) || {}\n\n const { hasError, hasErrorAndShowIt } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasErrorAndShowIt = hasErrorAndShowIt\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasErrorAndShowIt) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { handleRemove, switchContainerMode, containerMode, isNew } =\n contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n ...restProps\n } = props\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasErrorAndShowIt) {\n switchContainerMode('edit')\n }\n\n const preventFocusOnErrorOpening =\n !contextRef.current.hasErrorAndShowIt\n if (preventFocusOnErrorOpening) {\n if (state === 'opened') {\n contextRef.current?.elementRef?.current?.focus?.()\n } else {\n // Wait until the element is removed, then check if we can set focus\n window.requestAnimationFrame(() => {\n // try to focus on the second last element\n try {\n if (\n // But not when we focus is already inside our element\n !document.activeElement?.closest(\n '.dnb-forms-iterate__element'\n )\n ) {\n const elements =\n contextRef.current?.containerRef.current.querySelectorAll<HTMLDivElement>(\n '.dnb-forms-iterate__element'\n )\n elements[elements.length - 1].focus()\n }\n } catch (e) {\n /**/\n }\n })\n }\n }\n\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n contextRef.current?.fulfillRemove?.()\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n const handleRemoveBlock = useCallback(() => {\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, setOpenState])\n\n return (\n <ElementBlockContext.Provider value={{ handleRemoveBlock }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-iterate-block',\n isNew && 'dnb-forms-iterate-block--new',\n contextRef.current.hasErrorAndShowIt &&\n 'dnb-forms-iterate-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-iterate-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ElementBlockContext.Provider>\n )\n}\n\nElementBlock._supportsSpacingProps = true\nexport default ElementBlock\n"],"mappings":"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"}
1
+ {"version":3,"file":"ElementBlock.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateElementContext","_ElementBlockContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ElementBlock","props","forceUpdate","useReducer","contextRef","useRef","current","useContext","IterateElementContext","hasError","hasErrorAndShowIt","FieldBoundaryContext","containerMode","handleRemove","switchContainerMode","isNew","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","openRef","isRemoving","setOpenState","useCallback","useEffect","setTimeout","handleAnimationEnd","state","preventFocusOnErrorOpening","_contextRef$current","_contextRef$current$e","_contextRef$current$e2","_contextRef$current$e3","elementRef","focus","window","requestAnimationFrame","_document$activeEleme","document","activeElement","closest","_contextRef$current2","elements","containerRef","querySelectorAll","e","_contextRef$current3","_contextRef$current3$","fulfillRemove","handleRemoveBlock","keepItems","createElement","Provider","value","HeightAnimation","classnames","duration","keepInDOM","Flex","Stack","element","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/ElementBlock.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport ElementBlockContext from './ElementBlockContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from '../Array/types'\n\nexport type ElementSectionProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ElementSectionProps\n\nfunction ElementBlock(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const contextRef = useRef<\n IterateElementContextState & {\n hasError?: boolean\n hasErrorAndShowIt?: boolean\n }\n >()\n contextRef.current = useContext(IterateElementContext) || {}\n\n const { hasError, hasErrorAndShowIt } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasErrorAndShowIt = hasErrorAndShowIt\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasErrorAndShowIt) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { handleRemove, switchContainerMode, containerMode, isNew } =\n contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasErrorAndShowIt) {\n switchContainerMode('edit')\n }\n\n const preventFocusOnErrorOpening =\n !contextRef.current.hasErrorAndShowIt\n if (preventFocusOnErrorOpening) {\n if (state === 'opened') {\n contextRef.current?.elementRef?.current?.focus?.()\n } else {\n // Wait until the element is removed, then check if we can set focus\n window.requestAnimationFrame(() => {\n // try to focus on the second last element\n try {\n if (\n // But not when we focus is already inside our element\n !document.activeElement?.closest(\n '.dnb-forms-iterate__element'\n )\n ) {\n const elements =\n contextRef.current?.containerRef.current.querySelectorAll<HTMLDivElement>(\n '.dnb-forms-iterate__element'\n )\n elements[elements.length - 1].focus()\n }\n } catch (e) {\n /**/\n }\n })\n }\n }\n\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n contextRef.current?.fulfillRemove?.()\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n const handleRemoveBlock = useCallback(() => {\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, setOpenState])\n\n return (\n <ElementBlockContext.Provider value={{ handleRemoveBlock }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-iterate-block',\n variant && `dnb-forms-iterate-block--variant-${variant}`,\n isNew && 'dnb-forms-iterate-block--new',\n contextRef.current.hasErrorAndShowIt &&\n 'dnb-forms-iterate-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-iterate-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ElementBlockContext.Provider>\n )\n}\n\nElementBlock._supportsSpacingProps = true\nexport default ElementBlock\n"],"mappings":"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"}
@@ -1,5 +1,6 @@
1
1
  import React from 'react';
2
2
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
3
+ import { ElementSectionProps } from '../AnimatedContainer/ElementBlock';
3
4
  export type Props = {
4
5
  /**
5
6
  * The title of the EditContainer.
@@ -20,7 +21,7 @@ export type Props = {
20
21
  */
21
22
  toolbar?: React.ReactNode;
22
23
  };
23
- export type AllProps = Props & FlexContainerProps;
24
+ export type AllProps = Props & FlexContainerProps & ElementSectionProps;
24
25
  declare function EditContainer(props: AllProps): import("react/jsx-runtime").JSX.Element;
25
26
  declare namespace EditContainer {
26
27
  var _supportsSpacingProps: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"EditContainer.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_componentHelper","_elements","_IterateElementContext","_EditToolbarTools","_ElementBlock","_Toolbar2","_excluded","_Toolbar","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_objectWithoutProperties","source","excluded","target","_objectWithoutPropertiesLoose","i","getOwnPropertySymbols","sourceSymbolKeys","length","indexOf","propertyIsEnumerable","sourceKeys","keys","_extends","assign","bind","arguments","apply","EditContainer","props","createElement","EditContainerWithoutToolbar","toolbar","iterateElementContext","useContext","IterateElementContext","containerMode","isNew","_ref","children","className","title","titleWhenNew","restProps","wasNewRef","useRef","useEffect","current","blockTitle","ariaLabel","useMemo","convertJsxToString","mode","classnames","Lead","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 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\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":"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"}
1
+ {"version":3,"file":"EditContainer.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_componentHelper","_elements","_IterateElementContext","_EditToolbarTools","_ElementBlock","_Toolbar2","_excluded","_Toolbar","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_objectWithoutProperties","source","excluded","target","_objectWithoutPropertiesLoose","i","getOwnPropertySymbols","sourceSymbolKeys","length","indexOf","propertyIsEnumerable","sourceKeys","keys","_extends","assign","bind","arguments","apply","EditContainer","props","createElement","EditContainerWithoutToolbar","toolbar","iterateElementContext","useContext","IterateElementContext","containerMode","isNew","_ref","children","className","title","titleWhenNew","restProps","wasNewRef","useRef","useEffect","current","blockTitle","ariaLabel","useMemo","convertJsxToString","mode","classnames","Lead","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":"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"}
@@ -15,6 +15,11 @@ const EditContainerProperties = {
15
15
  type: 'React.Node',
16
16
  status: 'optional'
17
17
  },
18
+ variant: {
19
+ doc: 'Defines the variant of the container. Can be `outline` or `basic`. Defaults to `outline`.',
20
+ type: 'string',
21
+ status: 'optional'
22
+ },
18
23
  '[FlexVertical](/uilib/layout/flex/container/)': {
19
24
  doc: 'All Flex.Vertical properties.',
20
25
  type: 'Various',
@@ -1 +1 @@
1
- {"version":3,"file":"EditContainerDocs.js","names":["EditContainerProperties","title","doc","type","status","titleWhenNew","exports","EditContainerEvents"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainerDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const EditContainerProperties: PropertiesTableProps = {\n title: {\n doc: 'The title of the container.',\n type: 'React.Node',\n status: 'optional',\n },\n titleWhenNew: {\n doc: 'The title for a new item.',\n type: 'React.Node',\n status: 'optional',\n },\n '[FlexVertical](/uilib/layout/flex/container/)': {\n doc: 'All Flex.Vertical properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const EditContainerEvents: PropertiesTableProps = {}\n"],"mappings":";;;;;;AAEO,MAAMA,uBAA6C,GAAG;EAC3DC,KAAK,EAAE;IACLC,GAAG,EAAE,6BAA6B;IAClCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDC,YAAY,EAAE;IACZH,GAAG,EAAE,2BAA2B;IAChCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,+CAA+C,EAAE;IAC/CF,GAAG,EAAE,+BAA+B;IACpCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAAAE,OAAA,CAAAN,uBAAA,GAAAA,uBAAA;AAEM,MAAMO,mBAAyC,GAAG,CAAC,CAAC;AAAAD,OAAA,CAAAC,mBAAA,GAAAA,mBAAA"}
1
+ {"version":3,"file":"EditContainerDocs.js","names":["EditContainerProperties","title","doc","type","status","titleWhenNew","variant","exports","EditContainerEvents"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainerDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const EditContainerProperties: PropertiesTableProps = {\n title: {\n doc: 'The title of the container.',\n type: 'React.Node',\n status: 'optional',\n },\n titleWhenNew: {\n doc: 'The title for a new item.',\n type: 'React.Node',\n status: 'optional',\n },\n variant: {\n doc: 'Defines the variant of the container. Can be `outline` or `basic`. Defaults to `outline`.',\n type: 'string',\n status: 'optional',\n },\n '[FlexVertical](/uilib/layout/flex/container/)': {\n doc: 'All Flex.Vertical properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const EditContainerEvents: PropertiesTableProps = {}\n"],"mappings":";;;;;;AAEO,MAAMA,uBAA6C,GAAG;EAC3DC,KAAK,EAAE;IACLC,GAAG,EAAE,6BAA6B;IAClCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDC,YAAY,EAAE;IACZH,GAAG,EAAE,2BAA2B;IAChCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDE,OAAO,EAAE;IACPJ,GAAG,EAAE,2FAA2F;IAChGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACD,+CAA+C,EAAE;IAC/CF,GAAG,EAAE,+BAA+B;IACpCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAAAG,OAAA,CAAAP,uBAAA,GAAAA,uBAAA;AAEM,MAAMQ,mBAAyC,GAAG,CAAC,CAAC;AAAAD,OAAA,CAAAC,mBAAA,GAAAA,mBAAA"}
@@ -53,7 +53,7 @@ function EditToolbarTools() {
53
53
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
54
54
  }, [switchContainerMode]);
55
55
  return _react.default.createElement(_components.Flex.Horizontal, {
56
- spacing: "large"
56
+ gap: "large"
57
57
  }, _react.default.createElement(_components.Button, {
58
58
  variant: "tertiary",
59
59
  icon: _icons.check,
@@ -1 +1 @@
1
- {"version":3,"file":"EditToolbarTools.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateElementContext","_icons","_RemoveButton2","_FieldBoundaryContext","_RemoveButton","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EditToolbarTools","restoreOriginalValue","switchContainerMode","containerMode","arrayValue","index","isNew","useContext","IterateElementContext","hasErrorAndShowIt","FieldBoundaryContext","translation","useTranslation","Iterate","valueBackupRef","useRef","wasNew","useWasNew","useEffect","current","cancelHandler","useCallback","doneHandler","createElement","Flex","Horizontal","spacing","Button","variant","icon","check","icon_position","on_click","disabled","done","close","cancel","_ref","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button, Flex } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateElementContext from '../IterateElementContext'\nimport { check, close } from '../../../../icons'\nimport RemoveButton from '../RemoveButton'\nimport { ContainerMode } from '../Array/types'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport default function EditToolbarTools() {\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n arrayValue,\n index,\n isNew,\n } = useContext(IterateElementContext) || {}\n const { hasErrorAndShowIt } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().Iterate\n const valueBackupRef = useRef<unknown>()\n const wasNew = useWasNew({ isNew, containerMode })\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(() => {\n if (valueBackupRef.current) {\n restoreOriginalValue?.(valueBackupRef.current)\n }\n switchContainerMode?.('view')\n }, [restoreOriginalValue, switchContainerMode])\n const doneHandler = useCallback(() => {\n switchContainerMode?.('view')\n }, [switchContainerMode])\n\n return (\n <Flex.Horizontal spacing=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n disabled={hasErrorAndShowIt}\n >\n {translation.done}\n </Button>\n\n {wasNew ? (\n <RemoveButton />\n ) : (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancel}\n </Button>\n )}\n </Flex.Horizontal>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"EditToolbarTools.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateElementContext","_icons","_RemoveButton2","_FieldBoundaryContext","_RemoveButton","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EditToolbarTools","restoreOriginalValue","switchContainerMode","containerMode","arrayValue","index","isNew","useContext","IterateElementContext","hasErrorAndShowIt","FieldBoundaryContext","translation","useTranslation","Iterate","valueBackupRef","useRef","wasNew","useWasNew","useEffect","current","cancelHandler","useCallback","doneHandler","createElement","Flex","Horizontal","gap","Button","variant","icon","check","icon_position","on_click","disabled","done","close","cancel","_ref","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button, Flex } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateElementContext from '../IterateElementContext'\nimport { check, close } from '../../../../icons'\nimport RemoveButton from '../RemoveButton'\nimport { ContainerMode } from '../Array/types'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport default function EditToolbarTools() {\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n arrayValue,\n index,\n isNew,\n } = useContext(IterateElementContext) || {}\n const { hasErrorAndShowIt } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().Iterate\n const valueBackupRef = useRef<unknown>()\n const wasNew = useWasNew({ isNew, containerMode })\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(() => {\n if (valueBackupRef.current) {\n restoreOriginalValue?.(valueBackupRef.current)\n }\n switchContainerMode?.('view')\n }, [restoreOriginalValue, switchContainerMode])\n const doneHandler = useCallback(() => {\n switchContainerMode?.('view')\n }, [switchContainerMode])\n\n return (\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n disabled={hasErrorAndShowIt}\n >\n {translation.done}\n </Button>\n\n {wasNew ? (\n <RemoveButton />\n ) : (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancel}\n </Button>\n )}\n </Flex.Horizontal>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}