@dnb/eufemia 10.45.0 → 10.47.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 (792) hide show
  1. package/CHANGELOG.md +58 -0
  2. package/cjs/components/CopyOnClick.d.ts +12 -0
  3. package/cjs/components/CopyOnClick.js +24 -0
  4. package/cjs/components/CopyOnClick.js.map +1 -0
  5. package/cjs/components/accordion/Accordion.d.ts +17 -1
  6. package/cjs/components/accordion/Accordion.js +4 -2
  7. package/cjs/components/accordion/Accordion.js.map +1 -1
  8. package/cjs/components/accordion/AccordionContext.d.ts +4 -0
  9. package/cjs/components/accordion/AccordionContext.js.map +1 -1
  10. package/cjs/components/accordion/AccordionDocs.js +6 -1
  11. package/cjs/components/accordion/AccordionDocs.js.map +1 -1
  12. package/cjs/components/accordion/AccordionGroup.js +5 -3
  13. package/cjs/components/accordion/AccordionGroup.js.map +1 -1
  14. package/cjs/components/accordion/AccordionProviderContext.d.ts +4 -0
  15. package/cjs/components/accordion/AccordionProviderContext.js.map +1 -1
  16. package/cjs/components/accordion/AccordionStore.js +2 -1
  17. package/cjs/components/accordion/AccordionStore.js.map +1 -1
  18. package/cjs/components/accordion/style/dnb-accordion.css +3 -3
  19. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  20. package/cjs/components/autocomplete/style/dnb-autocomplete.css +1 -1
  21. package/cjs/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  22. package/cjs/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  23. package/cjs/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  24. package/cjs/components/button/Button.d.ts +1 -1
  25. package/cjs/components/button/Button.js +5 -2
  26. package/cjs/components/button/Button.js.map +1 -1
  27. package/cjs/components/card/style/dnb-card.css +1 -1
  28. package/cjs/components/card/style/dnb-card.min.css +1 -1
  29. package/cjs/components/copy-on-click/CopyOnClick.d.ts +9 -0
  30. package/cjs/components/copy-on-click/CopyOnClick.js +73 -0
  31. package/cjs/components/copy-on-click/CopyOnClick.js.map +1 -0
  32. package/cjs/components/copy-on-click/CopyOnClickDocs.d.ts +2 -0
  33. package/cjs/components/copy-on-click/CopyOnClickDocs.js +30 -0
  34. package/cjs/components/copy-on-click/CopyOnClickDocs.js.map +1 -0
  35. package/cjs/components/copy-on-click/index.d.ts +7 -0
  36. package/cjs/components/copy-on-click/index.js +24 -0
  37. package/cjs/components/copy-on-click/index.js.map +1 -0
  38. package/cjs/components/copy-on-click/style/dnb-copy-on-click.css +7 -0
  39. package/cjs/components/copy-on-click/style/dnb-copy-on-click.min.css +1 -0
  40. package/cjs/components/copy-on-click/style/dnb-copy-on-click.scss +10 -0
  41. package/cjs/components/copy-on-click/style/index.d.ts +5 -0
  42. package/cjs/components/copy-on-click/style/index.js +4 -0
  43. package/cjs/components/copy-on-click/style/index.js.map +1 -0
  44. package/cjs/components/copy-on-click/style.d.ts +5 -0
  45. package/cjs/components/copy-on-click/style.js +4 -0
  46. package/cjs/components/copy-on-click/style.js.map +1 -0
  47. package/cjs/components/copy-on-click/types.d.ts +24 -0
  48. package/cjs/components/copy-on-click/types.js +1 -0
  49. package/cjs/components/copy-on-click/types.js.map +1 -0
  50. package/cjs/components/drawer/style/dnb-drawer.css +3 -3
  51. package/cjs/components/drawer/style/dnb-drawer.min.css +1 -1
  52. package/cjs/components/dropdown/style/dnb-dropdown.css +1 -1
  53. package/cjs/components/dropdown/style/dnb-dropdown.min.css +1 -1
  54. package/cjs/components/flex/Container.js +9 -1
  55. package/cjs/components/flex/Container.js.map +1 -1
  56. package/cjs/components/flex/utils.d.ts +1 -1
  57. package/cjs/components/flex/utils.js +1 -1
  58. package/cjs/components/flex/utils.js.map +1 -1
  59. package/cjs/components/form-row/style/dnb-form-row.css +1 -1
  60. package/cjs/components/form-row/style/dnb-form-row.min.css +1 -1
  61. package/cjs/components/grid/style/dnb-grid.css +6 -6
  62. package/cjs/components/grid/style/dnb-grid.min.css +1 -1
  63. package/cjs/components/index.d.ts +2 -1
  64. package/cjs/components/index.js +7 -0
  65. package/cjs/components/index.js.map +1 -1
  66. package/cjs/components/lib.d.ts +6 -1
  67. package/cjs/components/lib.js +8 -0
  68. package/cjs/components/lib.js.map +1 -1
  69. package/cjs/components/pagination/Pagination.d.ts +27 -1
  70. package/cjs/components/pagination/Pagination.js +3 -1
  71. package/cjs/components/pagination/Pagination.js.map +1 -1
  72. package/cjs/components/pagination/PaginationInfinity.js +20 -8
  73. package/cjs/components/pagination/PaginationInfinity.js.map +1 -1
  74. package/cjs/components/progress-indicator/ProgressIndicator.js +2 -2
  75. package/cjs/components/progress-indicator/ProgressIndicator.js.map +1 -1
  76. package/cjs/components/section/style/dnb-section.css +2 -2
  77. package/cjs/components/section/style/dnb-section.min.css +2 -2
  78. package/cjs/components/space/style/dnb-space.css +2 -2
  79. package/cjs/components/space/style/dnb-space.min.css +1 -1
  80. package/cjs/components/tabs/Tabs.js +2 -2
  81. package/cjs/components/tabs/Tabs.js.map +1 -1
  82. package/cjs/components/tag/Tag.js +2 -2
  83. package/cjs/components/tag/Tag.js.map +1 -1
  84. package/cjs/components/toggle-button/style/dnb-toggle-button.css +1 -1
  85. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  86. package/cjs/extensions/forms/DataContext/Context.d.ts +10 -7
  87. package/cjs/extensions/forms/DataContext/Context.js +0 -1
  88. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  89. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +7 -7
  90. package/cjs/extensions/forms/DataContext/Provider/Provider.js +60 -34
  91. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  92. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +2 -7
  93. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  94. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +15 -3
  95. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +12 -3
  96. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  97. package/cjs/extensions/forms/Field/ArraySelection/ArraySelectionDocs.js +10 -0
  98. package/cjs/extensions/forms/Field/ArraySelection/ArraySelectionDocs.js.map +1 -1
  99. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  100. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  101. package/cjs/extensions/forms/Field/Email/Email.js +1 -1
  102. package/cjs/extensions/forms/Field/Email/Email.js.map +1 -1
  103. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +36 -8
  104. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  105. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.d.ts +2 -0
  106. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +20 -0
  107. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -0
  108. package/cjs/extensions/forms/Field/Number/Number.d.ts +2 -2
  109. package/cjs/extensions/forms/Field/Number/Number.js +33 -31
  110. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  111. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.d.ts +3 -1
  112. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +11 -3
  113. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  114. package/cjs/extensions/forms/Field/Selection/Selection.d.ts +1 -1
  115. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  116. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js +6 -1
  117. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  118. package/cjs/extensions/forms/Field/Slider/Slider.js +7 -7
  119. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -1
  120. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +3 -4
  121. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  122. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  123. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  124. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  125. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  126. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  127. package/cjs/extensions/forms/Form/Handler/Handler.js +1 -3
  128. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  129. package/cjs/extensions/forms/Form/Isolation/Isolation.d.ts +1 -1
  130. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  131. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js +0 -1
  132. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  133. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  134. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  135. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  136. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +9 -5
  137. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  138. package/cjs/extensions/forms/Form/data-context/useData.js +9 -7
  139. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  140. package/cjs/extensions/forms/Iterate/Array/Array.js +4 -4
  141. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  142. package/cjs/extensions/forms/Value/Date/Date.d.ts +1 -1
  143. package/cjs/extensions/forms/Value/Date/Date.js +15 -5
  144. package/cjs/extensions/forms/Value/Date/Date.js.map +1 -1
  145. package/cjs/extensions/forms/Value/Date/DateDocs.js +1 -1
  146. package/cjs/extensions/forms/Value/Date/DateDocs.js.map +1 -1
  147. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +7 -0
  148. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.js +54 -0
  149. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -0
  150. package/cjs/extensions/forms/Value/SelectCountry/index.d.ts +2 -0
  151. package/cjs/extensions/forms/Value/SelectCountry/index.js +27 -0
  152. package/cjs/extensions/forms/Value/SelectCountry/index.js.map +1 -0
  153. package/cjs/extensions/forms/Value/Selection/SelectionDocs.js +1 -1
  154. package/cjs/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -1
  155. package/cjs/extensions/forms/Value/index.d.ts +1 -0
  156. package/cjs/extensions/forms/Value/index.js +7 -0
  157. package/cjs/extensions/forms/Value/index.js.map +1 -1
  158. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +4 -3
  159. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  160. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.css +5 -2
  161. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  162. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.scss +3 -0
  163. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  164. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  165. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
  166. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  167. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -4
  168. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  169. package/cjs/extensions/forms/constants/countries.d.ts +5 -2
  170. package/cjs/extensions/forms/constants/countries.js +72 -0
  171. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  172. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -0
  173. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -1
  174. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  175. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -0
  176. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -0
  177. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -0
  178. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -1
  179. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  180. package/cjs/extensions/forms/hooks/DataValueDocs.js +7 -7
  181. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  182. package/cjs/extensions/forms/hooks/useDataValue.d.ts +2 -1
  183. package/cjs/extensions/forms/hooks/useDataValue.js +7 -7
  184. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  185. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -1
  186. package/cjs/extensions/forms/hooks/useFieldProps.js +296 -115
  187. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  188. package/cjs/extensions/forms/style/dnb-forms.css +13 -10
  189. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  190. package/cjs/extensions/forms/types.d.ts +33 -4
  191. package/cjs/extensions/forms/types.js.map +1 -1
  192. package/cjs/index.d.ts +2 -1
  193. package/cjs/index.js +7 -0
  194. package/cjs/index.js.map +1 -1
  195. package/cjs/shared/Context.js +4 -6
  196. package/cjs/shared/Context.js.map +1 -1
  197. package/cjs/shared/Eufemia.d.ts +1 -1
  198. package/cjs/shared/Eufemia.js +2 -2
  199. package/cjs/shared/Eufemia.js.map +1 -1
  200. package/cjs/shared/locales/en-GB.d.ts +3 -0
  201. package/cjs/shared/locales/en-GB.js +3 -0
  202. package/cjs/shared/locales/en-GB.js.map +1 -1
  203. package/cjs/shared/locales/en-US.d.ts +3 -0
  204. package/cjs/shared/locales/index.d.ts +6 -0
  205. package/cjs/shared/locales/nb-NO.d.ts +3 -0
  206. package/cjs/shared/locales/nb-NO.js +3 -0
  207. package/cjs/shared/locales/nb-NO.js.map +1 -1
  208. package/cjs/style/core/scopes.scss +1 -1
  209. package/cjs/style/core/utilities.scss +3 -6
  210. package/cjs/style/dnb-ui-basis.css +1 -1
  211. package/cjs/style/dnb-ui-basis.min.css +1 -1
  212. package/cjs/style/dnb-ui-body.css +1 -1
  213. package/cjs/style/dnb-ui-body.min.css +1 -1
  214. package/cjs/style/dnb-ui-components.css +45 -34
  215. package/cjs/style/dnb-ui-components.min.css +5 -5
  216. package/cjs/style/dnb-ui-components.scss +1 -0
  217. package/cjs/style/dnb-ui-core.css +1 -1
  218. package/cjs/style/dnb-ui-core.min.css +1 -1
  219. package/cjs/style/dnb-ui-elements.css +1 -1
  220. package/cjs/style/dnb-ui-elements.min.css +1 -1
  221. package/cjs/style/dnb-ui-extensions.css +13 -10
  222. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  223. package/cjs/style/dnb-ui-forms.css +13 -10
  224. package/cjs/style/dnb-ui-forms.min.css +1 -1
  225. package/cjs/style/dnb-ui-fragments.css +2 -2
  226. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  227. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  228. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  229. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +59 -45
  230. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  231. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  232. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  233. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +13 -10
  234. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  235. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +13 -10
  236. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  237. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  238. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  239. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +59 -45
  240. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  241. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  242. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  243. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +13 -10
  244. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  245. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +13 -10
  246. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  247. package/cjs/style/themes/theme-ui/ui-theme-basis.css +1 -1
  248. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  249. package/cjs/style/themes/theme-ui/ui-theme-components.css +59 -45
  250. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  251. package/cjs/style/themes/theme-ui/ui-theme-elements.css +1 -1
  252. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  253. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +13 -10
  254. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  255. package/cjs/style/themes/theme-ui/ui-theme-forms.css +13 -10
  256. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  257. package/cjs/style/themes/theme-ui/ui-theme-tags.css +1 -1
  258. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  259. package/components/CopyOnClick.d.ts +12 -0
  260. package/components/CopyOnClick.js +4 -0
  261. package/components/CopyOnClick.js.map +1 -0
  262. package/components/accordion/Accordion.d.ts +17 -1
  263. package/components/accordion/Accordion.js +4 -2
  264. package/components/accordion/Accordion.js.map +1 -1
  265. package/components/accordion/AccordionContext.d.ts +4 -0
  266. package/components/accordion/AccordionContext.js.map +1 -1
  267. package/components/accordion/AccordionDocs.js +6 -1
  268. package/components/accordion/AccordionDocs.js.map +1 -1
  269. package/components/accordion/AccordionGroup.js +5 -3
  270. package/components/accordion/AccordionGroup.js.map +1 -1
  271. package/components/accordion/AccordionProviderContext.d.ts +4 -0
  272. package/components/accordion/AccordionProviderContext.js.map +1 -1
  273. package/components/accordion/AccordionStore.js +2 -1
  274. package/components/accordion/AccordionStore.js.map +1 -1
  275. package/components/accordion/style/dnb-accordion.css +3 -3
  276. package/components/accordion/style/dnb-accordion.min.css +1 -1
  277. package/components/autocomplete/style/dnb-autocomplete.css +1 -1
  278. package/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  279. package/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  280. package/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  281. package/components/button/Button.d.ts +1 -1
  282. package/components/button/Button.js +5 -2
  283. package/components/button/Button.js.map +1 -1
  284. package/components/card/style/dnb-card.css +1 -1
  285. package/components/card/style/dnb-card.min.css +1 -1
  286. package/components/copy-on-click/CopyOnClick.d.ts +9 -0
  287. package/components/copy-on-click/CopyOnClick.js +63 -0
  288. package/components/copy-on-click/CopyOnClick.js.map +1 -0
  289. package/components/copy-on-click/CopyOnClickDocs.d.ts +2 -0
  290. package/components/copy-on-click/CopyOnClickDocs.js +23 -0
  291. package/components/copy-on-click/CopyOnClickDocs.js.map +1 -0
  292. package/components/copy-on-click/index.d.ts +7 -0
  293. package/components/copy-on-click/index.js +4 -0
  294. package/components/copy-on-click/index.js.map +1 -0
  295. package/components/copy-on-click/style/dnb-copy-on-click.css +7 -0
  296. package/components/copy-on-click/style/dnb-copy-on-click.min.css +1 -0
  297. package/components/copy-on-click/style/dnb-copy-on-click.scss +10 -0
  298. package/components/copy-on-click/style/index.d.ts +5 -0
  299. package/components/copy-on-click/style/index.js +1 -0
  300. package/components/copy-on-click/style/index.js.map +1 -0
  301. package/components/copy-on-click/style.d.ts +5 -0
  302. package/components/copy-on-click/style.js +1 -0
  303. package/components/copy-on-click/style.js.map +1 -0
  304. package/components/copy-on-click/types.d.ts +24 -0
  305. package/components/copy-on-click/types.js +1 -0
  306. package/components/copy-on-click/types.js.map +1 -0
  307. package/components/drawer/style/dnb-drawer.css +3 -3
  308. package/components/drawer/style/dnb-drawer.min.css +1 -1
  309. package/components/dropdown/style/dnb-dropdown.css +1 -1
  310. package/components/dropdown/style/dnb-dropdown.min.css +1 -1
  311. package/components/flex/Container.js +10 -2
  312. package/components/flex/Container.js.map +1 -1
  313. package/components/flex/utils.d.ts +1 -1
  314. package/components/flex/utils.js +1 -1
  315. package/components/flex/utils.js.map +1 -1
  316. package/components/form-row/style/dnb-form-row.css +1 -1
  317. package/components/form-row/style/dnb-form-row.min.css +1 -1
  318. package/components/grid/style/dnb-grid.css +6 -6
  319. package/components/grid/style/dnb-grid.min.css +1 -1
  320. package/components/index.d.ts +2 -1
  321. package/components/index.js +2 -1
  322. package/components/index.js.map +1 -1
  323. package/components/lib.d.ts +6 -1
  324. package/components/lib.js +3 -1
  325. package/components/lib.js.map +1 -1
  326. package/components/pagination/Pagination.d.ts +27 -1
  327. package/components/pagination/Pagination.js +3 -1
  328. package/components/pagination/Pagination.js.map +1 -1
  329. package/components/pagination/PaginationInfinity.js +20 -8
  330. package/components/pagination/PaginationInfinity.js.map +1 -1
  331. package/components/progress-indicator/ProgressIndicator.js +2 -2
  332. package/components/progress-indicator/ProgressIndicator.js.map +1 -1
  333. package/components/section/style/dnb-section.css +2 -2
  334. package/components/section/style/dnb-section.min.css +2 -2
  335. package/components/space/style/dnb-space.css +2 -2
  336. package/components/space/style/dnb-space.min.css +1 -1
  337. package/components/tabs/Tabs.js +2 -2
  338. package/components/tabs/Tabs.js.map +1 -1
  339. package/components/tag/Tag.js +2 -2
  340. package/components/tag/Tag.js.map +1 -1
  341. package/components/toggle-button/style/dnb-toggle-button.css +1 -1
  342. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  343. package/es/components/CopyOnClick.d.ts +12 -0
  344. package/es/components/CopyOnClick.js +4 -0
  345. package/es/components/CopyOnClick.js.map +1 -0
  346. package/es/components/accordion/Accordion.d.ts +17 -1
  347. package/es/components/accordion/Accordion.js +4 -2
  348. package/es/components/accordion/Accordion.js.map +1 -1
  349. package/es/components/accordion/AccordionContext.d.ts +4 -0
  350. package/es/components/accordion/AccordionContext.js.map +1 -1
  351. package/es/components/accordion/AccordionDocs.js +6 -1
  352. package/es/components/accordion/AccordionDocs.js.map +1 -1
  353. package/es/components/accordion/AccordionGroup.js +5 -3
  354. package/es/components/accordion/AccordionGroup.js.map +1 -1
  355. package/es/components/accordion/AccordionProviderContext.d.ts +4 -0
  356. package/es/components/accordion/AccordionProviderContext.js.map +1 -1
  357. package/es/components/accordion/AccordionStore.js +2 -1
  358. package/es/components/accordion/AccordionStore.js.map +1 -1
  359. package/es/components/accordion/style/dnb-accordion.css +3 -3
  360. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  361. package/es/components/autocomplete/style/dnb-autocomplete.css +1 -1
  362. package/es/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  363. package/es/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  364. package/es/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  365. package/es/components/button/Button.d.ts +1 -1
  366. package/es/components/button/Button.js +5 -2
  367. package/es/components/button/Button.js.map +1 -1
  368. package/es/components/card/style/dnb-card.css +1 -1
  369. package/es/components/card/style/dnb-card.min.css +1 -1
  370. package/es/components/copy-on-click/CopyOnClick.d.ts +9 -0
  371. package/es/components/copy-on-click/CopyOnClick.js +63 -0
  372. package/es/components/copy-on-click/CopyOnClick.js.map +1 -0
  373. package/es/components/copy-on-click/CopyOnClickDocs.d.ts +2 -0
  374. package/es/components/copy-on-click/CopyOnClickDocs.js +23 -0
  375. package/es/components/copy-on-click/CopyOnClickDocs.js.map +1 -0
  376. package/es/components/copy-on-click/index.d.ts +7 -0
  377. package/es/components/copy-on-click/index.js +4 -0
  378. package/es/components/copy-on-click/index.js.map +1 -0
  379. package/es/components/copy-on-click/style/dnb-copy-on-click.css +7 -0
  380. package/es/components/copy-on-click/style/dnb-copy-on-click.min.css +1 -0
  381. package/es/components/copy-on-click/style/dnb-copy-on-click.scss +10 -0
  382. package/es/components/copy-on-click/style/index.d.ts +5 -0
  383. package/es/components/copy-on-click/style/index.js +1 -0
  384. package/es/components/copy-on-click/style/index.js.map +1 -0
  385. package/es/components/copy-on-click/style.d.ts +5 -0
  386. package/es/components/copy-on-click/style.js +1 -0
  387. package/es/components/copy-on-click/style.js.map +1 -0
  388. package/es/components/copy-on-click/types.d.ts +24 -0
  389. package/es/components/copy-on-click/types.js +1 -0
  390. package/es/components/copy-on-click/types.js.map +1 -0
  391. package/es/components/drawer/style/dnb-drawer.css +3 -3
  392. package/es/components/drawer/style/dnb-drawer.min.css +1 -1
  393. package/es/components/dropdown/style/dnb-dropdown.css +1 -1
  394. package/es/components/dropdown/style/dnb-dropdown.min.css +1 -1
  395. package/es/components/flex/Container.js +10 -2
  396. package/es/components/flex/Container.js.map +1 -1
  397. package/es/components/flex/utils.d.ts +1 -1
  398. package/es/components/flex/utils.js +1 -1
  399. package/es/components/flex/utils.js.map +1 -1
  400. package/es/components/form-row/style/dnb-form-row.css +1 -1
  401. package/es/components/form-row/style/dnb-form-row.min.css +1 -1
  402. package/es/components/grid/style/dnb-grid.css +6 -6
  403. package/es/components/grid/style/dnb-grid.min.css +1 -1
  404. package/es/components/index.d.ts +2 -1
  405. package/es/components/index.js +2 -1
  406. package/es/components/index.js.map +1 -1
  407. package/es/components/lib.d.ts +6 -1
  408. package/es/components/lib.js +3 -1
  409. package/es/components/lib.js.map +1 -1
  410. package/es/components/pagination/Pagination.d.ts +27 -1
  411. package/es/components/pagination/Pagination.js +3 -1
  412. package/es/components/pagination/Pagination.js.map +1 -1
  413. package/es/components/pagination/PaginationInfinity.js +20 -8
  414. package/es/components/pagination/PaginationInfinity.js.map +1 -1
  415. package/es/components/progress-indicator/ProgressIndicator.js +2 -2
  416. package/es/components/progress-indicator/ProgressIndicator.js.map +1 -1
  417. package/es/components/section/style/dnb-section.css +2 -2
  418. package/es/components/section/style/dnb-section.min.css +2 -2
  419. package/es/components/space/style/dnb-space.css +2 -2
  420. package/es/components/space/style/dnb-space.min.css +1 -1
  421. package/es/components/tabs/Tabs.js +2 -2
  422. package/es/components/tabs/Tabs.js.map +1 -1
  423. package/es/components/tag/Tag.js +2 -2
  424. package/es/components/tag/Tag.js.map +1 -1
  425. package/es/components/toggle-button/style/dnb-toggle-button.css +1 -1
  426. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  427. package/es/extensions/forms/DataContext/Context.d.ts +10 -7
  428. package/es/extensions/forms/DataContext/Context.js +0 -1
  429. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  430. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +7 -7
  431. package/es/extensions/forms/DataContext/Provider/Provider.js +59 -33
  432. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  433. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +2 -7
  434. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  435. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +15 -3
  436. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +12 -3
  437. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  438. package/es/extensions/forms/Field/ArraySelection/ArraySelectionDocs.js +10 -0
  439. package/es/extensions/forms/Field/ArraySelection/ArraySelectionDocs.js.map +1 -1
  440. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  441. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  442. package/es/extensions/forms/Field/Email/Email.js +1 -1
  443. package/es/extensions/forms/Field/Email/Email.js.map +1 -1
  444. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +37 -9
  445. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  446. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.d.ts +2 -0
  447. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +13 -0
  448. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -0
  449. package/es/extensions/forms/Field/Number/Number.d.ts +2 -2
  450. package/es/extensions/forms/Field/Number/Number.js +33 -31
  451. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  452. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.d.ts +3 -1
  453. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +8 -1
  454. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  455. package/es/extensions/forms/Field/Selection/Selection.d.ts +1 -1
  456. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  457. package/es/extensions/forms/Field/Selection/SelectionDocs.js +6 -1
  458. package/es/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  459. package/es/extensions/forms/Field/Slider/Slider.js +7 -7
  460. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -1
  461. package/es/extensions/forms/FieldBlock/FieldBlock.js +3 -4
  462. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  463. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  464. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  465. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  466. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  467. package/es/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  468. package/es/extensions/forms/Form/Handler/Handler.js +1 -3
  469. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  470. package/es/extensions/forms/Form/Isolation/Isolation.d.ts +1 -1
  471. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  472. package/es/extensions/forms/Form/Isolation/IsolationDocs.js +0 -1
  473. package/es/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  474. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  475. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  476. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  477. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +9 -5
  478. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  479. package/es/extensions/forms/Form/data-context/useData.js +9 -7
  480. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  481. package/es/extensions/forms/Iterate/Array/Array.js +4 -4
  482. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  483. package/es/extensions/forms/Value/Date/Date.d.ts +1 -1
  484. package/es/extensions/forms/Value/Date/Date.js +15 -5
  485. package/es/extensions/forms/Value/Date/Date.js.map +1 -1
  486. package/es/extensions/forms/Value/Date/DateDocs.js +1 -1
  487. package/es/extensions/forms/Value/Date/DateDocs.js.map +1 -1
  488. package/es/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +7 -0
  489. package/es/extensions/forms/Value/SelectCountry/SelectCountry.js +44 -0
  490. package/es/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -0
  491. package/es/extensions/forms/Value/SelectCountry/index.d.ts +2 -0
  492. package/es/extensions/forms/Value/SelectCountry/index.js +3 -0
  493. package/es/extensions/forms/Value/SelectCountry/index.js.map +1 -0
  494. package/es/extensions/forms/Value/Selection/SelectionDocs.js +1 -1
  495. package/es/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -1
  496. package/es/extensions/forms/Value/index.d.ts +1 -0
  497. package/es/extensions/forms/Value/index.js +1 -0
  498. package/es/extensions/forms/Value/index.js.map +1 -1
  499. package/es/extensions/forms/ValueBlock/ValueBlock.js +4 -3
  500. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  501. package/es/extensions/forms/ValueBlock/style/dnb-value-block.css +5 -2
  502. package/es/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  503. package/es/extensions/forms/ValueBlock/style/dnb-value-block.scss +3 -0
  504. package/es/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  505. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  506. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
  507. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  508. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -4
  509. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  510. package/es/extensions/forms/constants/countries.d.ts +5 -2
  511. package/es/extensions/forms/constants/countries.js +72 -0
  512. package/es/extensions/forms/constants/countries.js.map +1 -1
  513. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -0
  514. package/es/extensions/forms/constants/locales/en-GB.js +3 -1
  515. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  516. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -0
  517. package/es/extensions/forms/constants/locales/index.d.ts +4 -0
  518. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -0
  519. package/es/extensions/forms/constants/locales/nb-NO.js +3 -1
  520. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  521. package/es/extensions/forms/hooks/DataValueDocs.js +7 -7
  522. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  523. package/es/extensions/forms/hooks/useDataValue.d.ts +2 -1
  524. package/es/extensions/forms/hooks/useDataValue.js +7 -7
  525. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  526. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -1
  527. package/es/extensions/forms/hooks/useFieldProps.js +288 -112
  528. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  529. package/es/extensions/forms/style/dnb-forms.css +13 -10
  530. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  531. package/es/extensions/forms/types.d.ts +33 -4
  532. package/es/extensions/forms/types.js.map +1 -1
  533. package/es/index.d.ts +2 -1
  534. package/es/index.js +2 -1
  535. package/es/index.js.map +1 -1
  536. package/es/shared/Context.js +4 -6
  537. package/es/shared/Context.js.map +1 -1
  538. package/es/shared/Eufemia.d.ts +1 -1
  539. package/es/shared/Eufemia.js +2 -2
  540. package/es/shared/Eufemia.js.map +1 -1
  541. package/es/shared/locales/en-GB.d.ts +3 -0
  542. package/es/shared/locales/en-GB.js +3 -0
  543. package/es/shared/locales/en-GB.js.map +1 -1
  544. package/es/shared/locales/en-US.d.ts +3 -0
  545. package/es/shared/locales/index.d.ts +6 -0
  546. package/es/shared/locales/nb-NO.d.ts +3 -0
  547. package/es/shared/locales/nb-NO.js +3 -0
  548. package/es/shared/locales/nb-NO.js.map +1 -1
  549. package/es/style/core/scopes.scss +1 -1
  550. package/es/style/core/utilities.scss +3 -6
  551. package/es/style/dnb-ui-basis.css +1 -1
  552. package/es/style/dnb-ui-basis.min.css +1 -1
  553. package/es/style/dnb-ui-body.css +1 -1
  554. package/es/style/dnb-ui-body.min.css +1 -1
  555. package/es/style/dnb-ui-components.css +45 -34
  556. package/es/style/dnb-ui-components.min.css +5 -5
  557. package/es/style/dnb-ui-components.scss +1 -0
  558. package/es/style/dnb-ui-core.css +1 -1
  559. package/es/style/dnb-ui-core.min.css +1 -1
  560. package/es/style/dnb-ui-elements.css +1 -1
  561. package/es/style/dnb-ui-elements.min.css +1 -1
  562. package/es/style/dnb-ui-extensions.css +13 -10
  563. package/es/style/dnb-ui-extensions.min.css +1 -1
  564. package/es/style/dnb-ui-forms.css +13 -10
  565. package/es/style/dnb-ui-forms.min.css +1 -1
  566. package/es/style/dnb-ui-fragments.css +2 -2
  567. package/es/style/dnb-ui-fragments.min.css +1 -1
  568. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  569. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  570. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +59 -45
  571. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  572. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  573. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  574. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +13 -10
  575. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  576. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +13 -10
  577. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  578. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  579. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  580. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +59 -45
  581. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  582. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  583. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  584. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +13 -10
  585. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  586. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +13 -10
  587. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  588. package/es/style/themes/theme-ui/ui-theme-basis.css +1 -1
  589. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  590. package/es/style/themes/theme-ui/ui-theme-components.css +59 -45
  591. package/es/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  592. package/es/style/themes/theme-ui/ui-theme-elements.css +1 -1
  593. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  594. package/es/style/themes/theme-ui/ui-theme-extensions.css +13 -10
  595. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  596. package/es/style/themes/theme-ui/ui-theme-forms.css +13 -10
  597. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  598. package/es/style/themes/theme-ui/ui-theme-tags.css +1 -1
  599. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  600. package/esm/dnb-ui-basis.min.mjs +1 -1
  601. package/esm/dnb-ui-components.min.mjs +1 -1
  602. package/esm/dnb-ui-elements.min.mjs +1 -1
  603. package/esm/dnb-ui-extensions.min.mjs +5 -5
  604. package/esm/dnb-ui-lib.min.mjs +1 -1
  605. package/extensions/forms/DataContext/Context.d.ts +10 -7
  606. package/extensions/forms/DataContext/Context.js +0 -1
  607. package/extensions/forms/DataContext/Context.js.map +1 -1
  608. package/extensions/forms/DataContext/Provider/Provider.d.ts +7 -7
  609. package/extensions/forms/DataContext/Provider/Provider.js +60 -34
  610. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  611. package/extensions/forms/DataContext/Provider/ProviderDocs.js +2 -7
  612. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  613. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +15 -3
  614. package/extensions/forms/Field/ArraySelection/ArraySelection.js +12 -3
  615. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  616. package/extensions/forms/Field/ArraySelection/ArraySelectionDocs.js +10 -0
  617. package/extensions/forms/Field/ArraySelection/ArraySelectionDocs.js.map +1 -1
  618. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  619. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  620. package/extensions/forms/Field/Email/Email.js +1 -1
  621. package/extensions/forms/Field/Email/Email.js.map +1 -1
  622. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +37 -9
  623. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  624. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.d.ts +2 -0
  625. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +13 -0
  626. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -0
  627. package/extensions/forms/Field/Number/Number.d.ts +2 -2
  628. package/extensions/forms/Field/Number/Number.js +33 -31
  629. package/extensions/forms/Field/Number/Number.js.map +1 -1
  630. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.d.ts +3 -1
  631. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +8 -1
  632. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  633. package/extensions/forms/Field/Selection/Selection.d.ts +1 -1
  634. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  635. package/extensions/forms/Field/Selection/SelectionDocs.js +6 -1
  636. package/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  637. package/extensions/forms/Field/Slider/Slider.js +7 -7
  638. package/extensions/forms/Field/Slider/Slider.js.map +1 -1
  639. package/extensions/forms/FieldBlock/FieldBlock.js +3 -4
  640. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  641. package/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  642. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  643. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  644. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  645. package/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  646. package/extensions/forms/Form/Handler/Handler.js +1 -3
  647. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  648. package/extensions/forms/Form/Isolation/Isolation.d.ts +1 -1
  649. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  650. package/extensions/forms/Form/Isolation/IsolationDocs.js +0 -1
  651. package/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  652. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  653. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  654. package/extensions/forms/Form/Section/Section.js.map +1 -1
  655. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +9 -5
  656. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  657. package/extensions/forms/Form/data-context/useData.js +9 -7
  658. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  659. package/extensions/forms/Iterate/Array/Array.js +4 -4
  660. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  661. package/extensions/forms/Value/Date/Date.d.ts +1 -1
  662. package/extensions/forms/Value/Date/Date.js +15 -5
  663. package/extensions/forms/Value/Date/Date.js.map +1 -1
  664. package/extensions/forms/Value/Date/DateDocs.js +1 -1
  665. package/extensions/forms/Value/Date/DateDocs.js.map +1 -1
  666. package/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +7 -0
  667. package/extensions/forms/Value/SelectCountry/SelectCountry.js +44 -0
  668. package/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -0
  669. package/extensions/forms/Value/SelectCountry/index.d.ts +2 -0
  670. package/extensions/forms/Value/SelectCountry/index.js +3 -0
  671. package/extensions/forms/Value/SelectCountry/index.js.map +1 -0
  672. package/extensions/forms/Value/Selection/SelectionDocs.js +1 -1
  673. package/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -1
  674. package/extensions/forms/Value/index.d.ts +1 -0
  675. package/extensions/forms/Value/index.js +1 -0
  676. package/extensions/forms/Value/index.js.map +1 -1
  677. package/extensions/forms/ValueBlock/ValueBlock.js +4 -3
  678. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  679. package/extensions/forms/ValueBlock/style/dnb-value-block.css +5 -2
  680. package/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  681. package/extensions/forms/ValueBlock/style/dnb-value-block.scss +3 -0
  682. package/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  683. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  684. package/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
  685. package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  686. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -4
  687. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  688. package/extensions/forms/constants/countries.d.ts +5 -2
  689. package/extensions/forms/constants/countries.js +72 -0
  690. package/extensions/forms/constants/countries.js.map +1 -1
  691. package/extensions/forms/constants/locales/en-GB.d.ts +2 -0
  692. package/extensions/forms/constants/locales/en-GB.js +3 -1
  693. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  694. package/extensions/forms/constants/locales/en-US.d.ts +2 -0
  695. package/extensions/forms/constants/locales/index.d.ts +4 -0
  696. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -0
  697. package/extensions/forms/constants/locales/nb-NO.js +3 -1
  698. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  699. package/extensions/forms/hooks/DataValueDocs.js +7 -7
  700. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  701. package/extensions/forms/hooks/useDataValue.d.ts +2 -1
  702. package/extensions/forms/hooks/useDataValue.js +7 -7
  703. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  704. package/extensions/forms/hooks/useFieldProps.d.ts +1 -1
  705. package/extensions/forms/hooks/useFieldProps.js +297 -116
  706. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  707. package/extensions/forms/style/dnb-forms.css +13 -10
  708. package/extensions/forms/style/dnb-forms.min.css +1 -1
  709. package/extensions/forms/types.d.ts +33 -4
  710. package/extensions/forms/types.js.map +1 -1
  711. package/index.d.ts +2 -1
  712. package/index.js +2 -1
  713. package/index.js.map +1 -1
  714. package/package.json +2 -1
  715. package/shared/Context.js +4 -6
  716. package/shared/Context.js.map +1 -1
  717. package/shared/Eufemia.d.ts +1 -1
  718. package/shared/Eufemia.js +2 -2
  719. package/shared/Eufemia.js.map +1 -1
  720. package/shared/locales/en-GB.d.ts +3 -0
  721. package/shared/locales/en-GB.js +3 -0
  722. package/shared/locales/en-GB.js.map +1 -1
  723. package/shared/locales/en-US.d.ts +3 -0
  724. package/shared/locales/index.d.ts +6 -0
  725. package/shared/locales/nb-NO.d.ts +3 -0
  726. package/shared/locales/nb-NO.js +3 -0
  727. package/shared/locales/nb-NO.js.map +1 -1
  728. package/style/core/scopes.scss +1 -1
  729. package/style/core/utilities.scss +3 -6
  730. package/style/dnb-ui-basis.css +1 -1
  731. package/style/dnb-ui-basis.min.css +1 -1
  732. package/style/dnb-ui-body.css +1 -1
  733. package/style/dnb-ui-body.min.css +1 -1
  734. package/style/dnb-ui-components.css +45 -34
  735. package/style/dnb-ui-components.min.css +5 -5
  736. package/style/dnb-ui-components.scss +1 -0
  737. package/style/dnb-ui-core.css +1 -1
  738. package/style/dnb-ui-core.min.css +1 -1
  739. package/style/dnb-ui-elements.css +1 -1
  740. package/style/dnb-ui-elements.min.css +1 -1
  741. package/style/dnb-ui-extensions.css +13 -10
  742. package/style/dnb-ui-extensions.min.css +1 -1
  743. package/style/dnb-ui-forms.css +13 -10
  744. package/style/dnb-ui-forms.min.css +1 -1
  745. package/style/dnb-ui-fragments.css +2 -2
  746. package/style/dnb-ui-fragments.min.css +1 -1
  747. package/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  748. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  749. package/style/themes/theme-eiendom/eiendom-theme-components.css +59 -45
  750. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  751. package/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  752. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  753. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +13 -10
  754. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  755. package/style/themes/theme-eiendom/eiendom-theme-forms.css +13 -10
  756. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  757. package/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  758. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  759. package/style/themes/theme-sbanken/sbanken-theme-components.css +59 -45
  760. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  761. package/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  762. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  763. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +13 -10
  764. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  765. package/style/themes/theme-sbanken/sbanken-theme-forms.css +13 -10
  766. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  767. package/style/themes/theme-ui/ui-theme-basis.css +1 -1
  768. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  769. package/style/themes/theme-ui/ui-theme-components.css +59 -45
  770. package/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  771. package/style/themes/theme-ui/ui-theme-elements.css +1 -1
  772. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  773. package/style/themes/theme-ui/ui-theme-extensions.css +13 -10
  774. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  775. package/style/themes/theme-ui/ui-theme-forms.css +13 -10
  776. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  777. package/style/themes/theme-ui/ui-theme-tags.css +1 -1
  778. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  779. package/umd/dnb-ui-basis.min.js +1 -1
  780. package/umd/dnb-ui-components.min.js +1 -1
  781. package/umd/dnb-ui-elements.min.js +1 -1
  782. package/umd/dnb-ui-extensions.min.js +5 -5
  783. package/umd/dnb-ui-lib.min.js +1 -1
  784. package/cjs/shared/helpers/useUnmountEffect.d.ts +0 -4
  785. package/cjs/shared/helpers/useUnmountEffect.js +0 -14
  786. package/cjs/shared/helpers/useUnmountEffect.js.map +0 -1
  787. package/es/shared/helpers/useUnmountEffect.d.ts +0 -4
  788. package/es/shared/helpers/useUnmountEffect.js +0 -9
  789. package/es/shared/helpers/useUnmountEffect.js.map +0 -1
  790. package/shared/helpers/useUnmountEffect.d.ts +0 -4
  791. package/shared/helpers/useUnmountEffect.js +0 -9
  792. package/shared/helpers/useUnmountEffect.js.map +0 -1
@@ -16,8 +16,6 @@ var _FieldPropsContext = _interopRequireDefault(require("../Form/FieldProps/Fiel
16
16
  var _componentHelper = require("../../../shared/component-helper");
17
17
  var _useId = _interopRequireDefault(require("../../../shared/helpers/useId"));
18
18
  var _useUpdateEffect = _interopRequireDefault(require("../../../shared/helpers/useUpdateEffect"));
19
- var _useMountEffect = _interopRequireDefault(require("../../../shared/helpers/useMountEffect"));
20
- var _useUnmountEffect = _interopRequireDefault(require("../../../shared/helpers/useUnmountEffect"));
21
19
  var _FieldBlockContext = _interopRequireDefault(require("../FieldBlock/FieldBlockContext"));
22
20
  var _IterateItemContext = _interopRequireDefault(require("../Iterate/IterateItemContext"));
23
21
  var _SectionContext = _interopRequireDefault(require("../Form/Section/SectionContext"));
@@ -28,6 +26,7 @@ var _useSharedState = require("../../../shared/helpers/useSharedState");
28
26
  var _isAsync = require("../../../shared/helpers/isAsync");
29
27
  var _useTranslation = _interopRequireDefault(require("./useTranslation"));
30
28
  var _useExternalValue2 = _interopRequireDefault(require("./useExternalValue"));
29
+ var _useDataValue = _interopRequireDefault(require("./useDataValue"));
31
30
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
32
31
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
33
32
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
@@ -67,6 +66,7 @@ function useFieldProps(localeProps) {
67
66
  onChange,
68
67
  onBlurValidator,
69
68
  validator,
69
+ exportValidators,
70
70
  schema,
71
71
  validateInitially,
72
72
  validateUnchanged,
@@ -89,7 +89,11 @@ function useFieldProps(localeProps) {
89
89
  return res;
90
90
  }
91
91
  } = props;
92
- const [, forceUpdate] = (0, _react.useReducer)(() => ({}), {});
92
+ const [salt, forceUpdate] = (0, _react.useReducer)(() => ({}), {});
93
+ const isInternalRerenderRef = (0, _react.useRef)(undefined);
94
+ (0, _react.useMemo)(() => {
95
+ isInternalRerenderRef.current = salt;
96
+ }, [salt]);
93
97
  const {
94
98
  startProcess
95
99
  } = (0, _useProcessManager.default)();
@@ -120,10 +124,13 @@ function useFieldProps(localeProps) {
120
124
  setFieldError: setFieldErrorDataContext,
121
125
  setFieldProps: setPropsDataContext,
122
126
  setHasVisibleError: setHasVisibleErrorDataContext,
127
+ handleMountField,
128
+ handleUnMountField,
129
+ setFieldEventListener,
123
130
  errors: dataContextErrors,
124
131
  showAllErrors,
125
132
  contextErrorMessages
126
- } = dataContext !== null && dataContext !== void 0 ? dataContext : {};
133
+ } = dataContext || {};
127
134
  const onChangeContext = dataContext === null || dataContext === void 0 ? void 0 : (_dataContext$props = dataContext.props) === null || _dataContext$props === void 0 ? void 0 : _dataContext$props.onChange;
128
135
  const disabled = disabledProp !== null && disabledProp !== void 0 ? disabledProp : props.readOnly;
129
136
  const inFieldBlock = Boolean(fieldBlockContext);
@@ -131,18 +138,18 @@ function useFieldProps(localeProps) {
131
138
  setFieldState: setFieldStateFieldBlock,
132
139
  showFieldError: showFieldErrorFieldBlock,
133
140
  mountedFieldsRef: mountedFieldsRefFieldBlock
134
- } = fieldBlockContext !== null && fieldBlockContext !== void 0 ? fieldBlockContext : {};
141
+ } = fieldBlockContext || {};
135
142
  const {
136
143
  handleChange: handleChangeIterateContext
137
- } = iterateItemContext !== null && iterateItemContext !== void 0 ? iterateItemContext : {};
144
+ } = iterateItemContext || {};
138
145
  const {
139
146
  path: sectionPath,
140
147
  errorPrioritization
141
- } = sectionContext !== null && sectionContext !== void 0 ? sectionContext : {};
148
+ } = sectionContext || {};
142
149
  const {
143
150
  setFieldError,
144
151
  showBoundaryErrors
145
- } = fieldBoundaryContext !== null && fieldBoundaryContext !== void 0 ? fieldBoundaryContext : {};
152
+ } = fieldBoundaryContext || {};
146
153
  const hasPath = Boolean(pathProp);
147
154
  const {
148
155
  path,
@@ -162,8 +169,8 @@ function useFieldProps(localeProps) {
162
169
  emptyValue
163
170
  })) !== null && _useExternalValue !== void 0 ? _useExternalValue : defaultValueRef.current;
164
171
  const valueRef = (0, _react.useRef)(externalValue);
165
- const changedRef = (0, _react.useRef)(false);
166
- const hasFocusRef = (0, _react.useRef)(false);
172
+ const changedRef = (0, _react.useRef)();
173
+ const hasFocusRef = (0, _react.useRef)();
167
174
  const required = (0, _react.useMemo)(() => {
168
175
  if (requiredProp) {
169
176
  return requiredProp;
@@ -194,9 +201,9 @@ function useFieldProps(localeProps) {
194
201
  return path ? dataContextErrors === null || dataContextErrors === void 0 ? void 0 : dataContextErrors[identifier] : undefined;
195
202
  }, [dataContextErrors, identifier, path]);
196
203
  const contextErrorRef = (0, _react.useRef)(dataContextError);
197
- const validatorRef = (0, _react.useRef)(validator);
204
+ const onChangeValidatorRef = (0, _react.useRef)(validator);
198
205
  (0, _useUpdateEffect.default)(() => {
199
- validatorRef.current = validator;
206
+ onChangeValidatorRef.current = validator;
200
207
  }, [validator]);
201
208
  const onBlurValidatorRef = (0, _react.useRef)(onBlurValidator);
202
209
  (0, _useUpdateEffect.default)(() => {
@@ -276,22 +283,21 @@ function useFieldProps(localeProps) {
276
283
  }
277
284
  }, [setFieldStateDataContext, identifier, validateInitially]);
278
285
  const revealError = (0, _react.useCallback)(() => {
279
- revealErrorRef.current = true;
280
- showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, true);
281
- if (localErrorRef.current) {
282
- setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, true);
283
- } else {
284
- setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, false);
286
+ if (!revealErrorRef.current) {
287
+ revealErrorRef.current = true;
288
+ showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, true);
289
+ setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, !!localErrorRef.current);
285
290
  }
286
- }, [showFieldErrorFieldBlock, identifier, setHasVisibleErrorDataContext]);
291
+ }, [identifier, setHasVisibleErrorDataContext, showFieldErrorFieldBlock]);
287
292
  const hideError = (0, _react.useCallback)(() => {
288
- revealErrorRef.current = false;
289
- showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, false);
290
- setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, false);
291
- }, [setHasVisibleErrorDataContext, identifier, showFieldErrorFieldBlock]);
293
+ if (revealErrorRef.current) {
294
+ revealErrorRef.current = false;
295
+ showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, false);
296
+ setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, false);
297
+ }
298
+ }, [identifier, setHasVisibleErrorDataContext, showFieldErrorFieldBlock]);
292
299
  const prepareError = (0, _react.useCallback)(error => {
293
300
  if (error instanceof _types.FormError) {
294
- var _error$messageValues;
295
301
  let message = error.message;
296
302
  const {
297
303
  validationRule
@@ -303,11 +309,11 @@ function useFieldProps(localeProps) {
303
309
  message = fieldMessage;
304
310
  }
305
311
  }
306
- const messagehasValues = Object.entries((_error$messageValues = error.messageValues) !== null && _error$messageValues !== void 0 ? _error$messageValues : {}).reduce((message, _ref2) => {
312
+ const messageHasValues = Object.entries(error.messageValues || {}).reduce((message, _ref2) => {
307
313
  let [key, value] = _ref2;
308
314
  return message.replace(`{${key}}`, value);
309
315
  }, message);
310
- error.message = messagehasValues;
316
+ error.message = messageHasValues;
311
317
  return error;
312
318
  }
313
319
  return error;
@@ -327,6 +333,75 @@ function useFieldProps(localeProps) {
327
333
  var _ref4;
328
334
  return Boolean((_ref4 = errorProp !== null && errorProp !== void 0 ? errorProp : localErrorRef.current) !== null && _ref4 !== void 0 ? _ref4 : contextErrorRef.current);
329
335
  }, [errorProp]);
336
+ const connectWithPathListenerRef = (0, _react.useRef)(async () => {
337
+ if (localErrorRef.current || validateUnchanged || continuousValidation) {
338
+ if (onChangeValidatorRef.current) {
339
+ runOnChangeValidator();
340
+ }
341
+ }
342
+ if (localErrorRef.current && onBlurValidatorRef.current) {
343
+ runOnBlurValidator();
344
+ }
345
+ });
346
+ const {
347
+ getValueByPath
348
+ } = (0, _useDataValue.default)();
349
+ const exportValidatorsRef = (0, _react.useRef)(exportValidators);
350
+ exportValidatorsRef.current = exportValidators;
351
+ const additionalArgs = (0, _react.useMemo)(() => {
352
+ const errorMessages = _objectSpread(_objectSpread({}, contextErrorMessages), errorMessagesRef.current);
353
+ const args = _objectSpread(_objectSpread({}, errorMessages), {}, {
354
+ errorMessages,
355
+ validators: exportValidatorsRef.current,
356
+ connectWithPath: path => {
357
+ setFieldEventListener === null || setFieldEventListener === void 0 ? void 0 : setFieldEventListener(path, 'onPathChange', connectWithPathListenerRef.current);
358
+ return {
359
+ getValue: () => getValueByPath(path)
360
+ };
361
+ }
362
+ });
363
+ return args;
364
+ }, [contextErrorMessages, getValueByPath, setFieldEventListener]);
365
+ const extendWithExportedValidators = (0, _react.useCallback)((validator, result) => {
366
+ if (exportValidatorsRef.current && !result && (validator === onChangeValidatorRef.current || validator === onBlurValidatorRef.current) && !Array.isArray(result)) {
367
+ return Object.values(exportValidatorsRef.current);
368
+ }
369
+ return result;
370
+ }, []);
371
+ const callValidatorFnSync = (0, _react.useCallback)(function (validator) {
372
+ let value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : valueRef.current;
373
+ if (typeof validator !== 'function') {
374
+ return undefined;
375
+ }
376
+ const result = extendWithExportedValidators(validator, validator(value, additionalArgs));
377
+ if (Array.isArray(result)) {
378
+ for (const validator of result) {
379
+ const result = callValidatorFnSync(validator, value);
380
+ if (result instanceof Error) {
381
+ return result;
382
+ }
383
+ }
384
+ return;
385
+ }
386
+ return result;
387
+ }, [additionalArgs, extendWithExportedValidators]);
388
+ const callValidatorFnAsync = (0, _react.useCallback)(async function (validator) {
389
+ let value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : valueRef.current;
390
+ if (typeof validator !== 'function') {
391
+ return undefined;
392
+ }
393
+ const result = extendWithExportedValidators(validator, await validator(value, additionalArgs));
394
+ if (Array.isArray(result)) {
395
+ for (const validator of result) {
396
+ const result = await callValidatorFnAsync(validator, value);
397
+ if (result instanceof Error) {
398
+ return result;
399
+ }
400
+ }
401
+ return;
402
+ }
403
+ return result;
404
+ }, [additionalArgs, extendWithExportedValidators]);
330
405
  const stateId = (0, _useId.default)();
331
406
  const persistErrorState = (0, _react.useCallback)(function (method) {
332
407
  let errorArg = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
@@ -359,23 +434,19 @@ function useFieldProps(localeProps) {
359
434
  persistErrorState('wipe');
360
435
  hasLocalErrorRef.current = false;
361
436
  }, [persistErrorState]);
362
- const callValidator = (0, _react.useCallback)(async () => {
363
- if (typeof validatorRef.current !== 'function') {
364
- return;
365
- }
366
- const runAsync = (0, _isAsync.isAsync)(validatorRef.current);
367
- if (runAsync) {
368
- defineAsyncProcess('validator');
369
- setFieldState('validating');
370
- hideError();
371
- }
372
- const opts = _objectSpread(_objectSpread({}, contextErrorMessages), errorMessagesRef.current);
373
- const tmpValue = valueRef.current;
374
- const result = await validatorRef.current(valueRef.current, opts);
375
- const unchangedValue = tmpValue === valueRef.current;
437
+ const validatorCacheRef = (0, _react.useRef)({
438
+ onChangeValidator: null,
439
+ onBlurValidator: null
440
+ });
441
+ const revealOnChangeValidatorResult = (0, _react.useCallback)(_ref5 => {
442
+ let {
443
+ result,
444
+ unchangedValue
445
+ } = _ref5;
446
+ const runAsync = (0, _isAsync.isAsync)(onChangeValidatorRef.current);
376
447
  if (unchangedValue) {
377
448
  persistErrorState('gracefully', result);
378
- if (continuousValidation || runAsync) {
449
+ if (validateInitially && !changedRef.current || validateUnchanged || continuousValidation || runAsync) {
379
450
  window.requestAnimationFrame(() => {
380
451
  revealError();
381
452
  forceUpdate();
@@ -390,30 +461,132 @@ function useFieldProps(localeProps) {
390
461
  setFieldState('pending');
391
462
  }
392
463
  }
393
- return result;
394
- }, [contextErrorMessages, continuousValidation, hideError, persistErrorState, defineAsyncProcess, setFieldState, revealError]);
464
+ }, [continuousValidation, defineAsyncProcess, persistErrorState, revealError, setFieldState, validateInitially, validateUnchanged]);
465
+ const callOnChangeValidator = (0, _react.useCallback)(async () => {
466
+ if (typeof onChangeValidatorRef.current !== 'function') {
467
+ return {};
468
+ }
469
+ const tmpValue = valueRef.current;
470
+ let result = (0, _isAsync.isAsync)(onChangeValidatorRef.current) ? await callValidatorFnAsync(onChangeValidatorRef.current) : callValidatorFnSync(onChangeValidatorRef.current);
471
+ if (result instanceof Promise) {
472
+ result = await result;
473
+ }
474
+ const unchangedValue = tmpValue === valueRef.current;
475
+ return {
476
+ result,
477
+ unchangedValue
478
+ };
479
+ }, [callValidatorFnAsync, callValidatorFnSync]);
480
+ const startOnChangeValidatorValidation = (0, _react.useCallback)(async () => {
481
+ if (typeof onChangeValidatorRef.current !== 'function') {
482
+ return;
483
+ }
484
+ if ((0, _isAsync.isAsync)(onChangeValidatorRef.current)) {
485
+ defineAsyncProcess('validator');
486
+ setFieldState('validating');
487
+ hideError();
488
+ }
489
+ const tmpValue = valueRef.current;
490
+ let result = (0, _isAsync.isAsync)(onChangeValidatorRef.current) ? await callValidatorFnAsync(onChangeValidatorRef.current) : callValidatorFnSync(onChangeValidatorRef.current);
491
+ if (result instanceof Promise) {
492
+ result = await result;
493
+ }
494
+ const unchangedValue = tmpValue === valueRef.current;
495
+ revealOnChangeValidatorResult({
496
+ result,
497
+ unchangedValue
498
+ });
499
+ return {
500
+ result
501
+ };
502
+ }, [callValidatorFnAsync, callValidatorFnSync, defineAsyncProcess, hideError, revealOnChangeValidatorResult, setFieldState]);
503
+ const runOnChangeValidator = (0, _react.useCallback)(async () => {
504
+ if (!onChangeValidatorRef.current) {
505
+ return;
506
+ }
507
+ const {
508
+ result,
509
+ unchangedValue
510
+ } = await callOnChangeValidator();
511
+ if (String(result) !== String(validatorCacheRef.current.onChangeValidator)) {
512
+ if (result) {
513
+ revealOnChangeValidatorResult({
514
+ result,
515
+ unchangedValue
516
+ });
517
+ } else {
518
+ hideError();
519
+ clearErrorState();
520
+ }
521
+ }
522
+ validatorCacheRef.current.onChangeValidator = result || null;
523
+ }, [callOnChangeValidator, clearErrorState, hideError, revealOnChangeValidatorResult]);
395
524
  const callOnBlurValidator = (0, _react.useCallback)(async function () {
396
525
  let {
397
- valueOverride = null
526
+ overrideValue = null
398
527
  } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
399
528
  if (typeof onBlurValidatorRef.current !== 'function') {
400
- return;
529
+ return {};
401
530
  }
402
- const value = transformers.current.toEvent(valueOverride !== null && valueOverride !== void 0 ? valueOverride : valueRef.current, 'onBlurValidator');
403
- const runAsync = (0, _isAsync.isAsync)(onBlurValidatorRef.current);
404
- if (runAsync) {
405
- defineAsyncProcess('onBlurValidator');
406
- setFieldState('validating');
531
+ const value = transformers.current.toEvent(overrideValue !== null && overrideValue !== void 0 ? overrideValue : valueRef.current, 'onBlurValidator');
532
+ let result = (0, _isAsync.isAsync)(onBlurValidatorRef.current) ? await callValidatorFnAsync(onBlurValidatorRef.current, value) : callValidatorFnSync(onBlurValidatorRef.current, value);
533
+ if (result instanceof Promise) {
534
+ result = await result;
407
535
  }
408
- const result = await onBlurValidatorRef.current(value);
536
+ return {
537
+ result
538
+ };
539
+ }, [callValidatorFnAsync, callValidatorFnSync]);
540
+ const revealOnBlurValidatorResult = (0, _react.useCallback)(_ref6 => {
541
+ let {
542
+ result
543
+ } = _ref6;
409
544
  persistErrorState('gracefully', result);
410
- if (runAsync) {
545
+ if ((0, _isAsync.isAsync)(onBlurValidatorRef.current)) {
411
546
  defineAsyncProcess(undefined);
412
547
  setFieldState(result instanceof Error ? 'error' : 'complete');
413
548
  }
414
549
  revealError();
415
- forceUpdate();
416
- }, [persistErrorState, defineAsyncProcess, setFieldState, revealError]);
550
+ }, [defineAsyncProcess, persistErrorState, revealError, setFieldState]);
551
+ const startOnBlurValidatorProcess = (0, _react.useCallback)(async function () {
552
+ let {
553
+ overrideValue = null
554
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
555
+ if (typeof onBlurValidatorRef.current !== 'function') {
556
+ return;
557
+ }
558
+ if ((0, _isAsync.isAsync)(onBlurValidatorRef.current)) {
559
+ defineAsyncProcess('onBlurValidator');
560
+ setFieldState('validating');
561
+ }
562
+ const {
563
+ result
564
+ } = await callOnBlurValidator({
565
+ overrideValue
566
+ });
567
+ revealOnBlurValidatorResult({
568
+ result
569
+ });
570
+ }, [callOnBlurValidator, defineAsyncProcess, revealOnBlurValidatorResult, setFieldState]);
571
+ const runOnBlurValidator = (0, _react.useCallback)(async () => {
572
+ if (!onBlurValidatorRef.current) {
573
+ return;
574
+ }
575
+ const {
576
+ result
577
+ } = await callOnBlurValidator();
578
+ if (String(result) !== String(validatorCacheRef.current.onBlurValidator) && revealErrorRef.current) {
579
+ if (result) {
580
+ revealOnBlurValidatorResult({
581
+ result
582
+ });
583
+ } else {
584
+ hideError();
585
+ clearErrorState();
586
+ }
587
+ }
588
+ validatorCacheRef.current.onBlurValidator = result || null;
589
+ }, [callOnBlurValidator, clearErrorState, hideError, revealOnBlurValidatorResult]);
417
590
  const prioritizeContextSchema = (0, _react.useMemo)(() => {
418
591
  if (errorPrioritization) {
419
592
  const schemaPath = identifier.split('/').join('/properties/');
@@ -450,8 +623,10 @@ function useFieldProps(localeProps) {
450
623
  const error = (0, _ajv.ajvErrorsToOneFormError)(schemaValidatorRef.current.errors, valueRef.current);
451
624
  throw error;
452
625
  }
453
- if (validatorRef.current && (changedRef.current || validateInitially)) {
454
- const result = await callValidator();
626
+ if (onChangeValidatorRef.current && (changedRef.current || validateInitially || validateUnchanged)) {
627
+ const {
628
+ result
629
+ } = await startOnChangeValidatorValidation();
455
630
  if (result instanceof Error) {
456
631
  throw result;
457
632
  }
@@ -466,7 +641,7 @@ function useFieldProps(localeProps) {
466
641
  persistErrorState('weak', error);
467
642
  }
468
643
  }
469
- }, [startProcess, disabled, hideError, setFieldState, clearErrorState, emptyValue, requiredProp, required, prioritizeContextSchema, validateInitially, callValidator, persistErrorState]);
644
+ }, [startProcess, disabled, hideError, setFieldState, clearErrorState, emptyValue, requiredProp, required, prioritizeContextSchema, validateInitially, validateUnchanged, startOnChangeValidatorValidation, persistErrorState]);
470
645
  const handleError = (0, _react.useCallback)(() => {
471
646
  if (continuousValidation || continuousValidation !== false && !hasFocusRef.current) {
472
647
  revealError();
@@ -474,9 +649,9 @@ function useFieldProps(localeProps) {
474
649
  hideError();
475
650
  }
476
651
  }, [continuousValidation, hideError, revealError]);
477
- const setHasFocus = (0, _react.useCallback)(async (hasFocus, valueOverride, additionalArgs) => {
652
+ const setHasFocus = (0, _react.useCallback)(async (hasFocus, overrideValue, additionalArgs) => {
478
653
  const getArgs = type => {
479
- const value = transformers.current.toEvent(valueOverride !== null && valueOverride !== void 0 ? valueOverride : valueRef.current, type);
654
+ const value = transformers.current.toEvent(overrideValue !== null && overrideValue !== void 0 ? overrideValue : valueRef.current, type);
480
655
  const transformedAdditionalArgs = transformers.current.transformAdditionalArgs(additionalArgs, value);
481
656
  return typeof transformedAdditionalArgs !== 'undefined' ? [value, transformedAdditionalArgs] : [value];
482
657
  };
@@ -491,28 +666,28 @@ function useFieldProps(localeProps) {
491
666
  if (!changedRef.current && !validateUnchanged) {
492
667
  return;
493
668
  }
494
- addToPool('onBlurValidator', async () => await callOnBlurValidator({
495
- valueOverride
669
+ addToPool('onBlurValidator', async () => await startOnBlurValidatorProcess({
670
+ overrideValue
496
671
  }), (0, _isAsync.isAsync)(onBlurValidatorRef.current));
497
672
  await runPool(() => {
498
673
  revealError();
499
674
  forceUpdate();
500
675
  });
501
676
  }
502
- }, [addToPool, callOnBlurValidator, onBlur, onFocus, runPool, revealError, validateUnchanged]);
503
- const yieldAsyncProcess = (0, _react.useCallback)(async _ref5 => {
677
+ }, [onFocus, onBlur, validateUnchanged, addToPool, runPool, startOnBlurValidatorProcess, revealError]);
678
+ const yieldAsyncProcess = (0, _react.useCallback)(async _ref7 => {
504
679
  let {
505
680
  name,
506
681
  waitFor
507
- } = _ref5;
682
+ } = _ref7;
508
683
  return new Promise(resolve => {
509
684
  const validateProcesses = () => {
510
- const result = waitFor.some(_ref6 => {
685
+ const result = waitFor.some(_ref8 => {
511
686
  let {
512
687
  processName,
513
688
  withStates,
514
689
  hasValue
515
- } = _ref6;
690
+ } = _ref8;
516
691
  const hasMatchingValue = hasValue === validatedValue.current;
517
692
  const result = (typeof hasValue === 'undefined' ? false : !hasMatchingValue) || (processName ? processName === asyncProcessRef.current : true) && (withStates === null || withStates === void 0 ? void 0 : withStates.some(state => {
518
693
  return state === fieldStateRef.current;
@@ -607,7 +782,7 @@ function useFieldProps(localeProps) {
607
782
  if (hasPath) {
608
783
  handlePathChangeUnvalidatedDataContext(identifier, newValue);
609
784
  }
610
- addToPool('validator', validateValue, (0, _isAsync.isAsync)(validatorRef.current));
785
+ addToPool('validator', validateValue, (0, _isAsync.isAsync)(onChangeValidatorRef.current));
611
786
  addToPool('onChangeContext', callOnChangeContext, (0, _isAsync.isAsync)(onChangeContext));
612
787
  await runPool(() => {
613
788
  handleError();
@@ -670,16 +845,18 @@ function useFieldProps(localeProps) {
670
845
  const handleFocus = (0, _react.useCallback)(() => setHasFocus(true), [setHasFocus]);
671
846
  const handleBlur = (0, _react.useCallback)(() => setHasFocus(false), [setHasFocus]);
672
847
  setPropsDataContext === null || setPropsDataContext === void 0 ? void 0 : setPropsDataContext(identifier, props);
673
- (0, _useMountEffect.default)(() => {
674
- dataContext === null || dataContext === void 0 ? void 0 : dataContext.handleMountField(identifier);
848
+ (0, _react.useEffect)(() => {
849
+ handleMountField(identifier);
850
+ return () => {
851
+ handleUnMountField(identifier);
852
+ setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(identifier, undefined);
853
+ setFieldError === null || setFieldError === void 0 ? void 0 : setFieldError(identifier, undefined);
854
+ localErrorRef.current = undefined;
855
+ };
856
+ }, [handleMountField, handleUnMountField, identifier, setFieldError, setFieldErrorDataContext]);
857
+ (0, _react.useEffect)(() => {
675
858
  validateValue();
676
- });
677
- (0, _useUnmountEffect.default)(() => {
678
- dataContext === null || dataContext === void 0 ? void 0 : dataContext.handleUnMountField(identifier);
679
- setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(identifier, undefined);
680
- setFieldError === null || setFieldError === void 0 ? void 0 : setFieldError(identifier, undefined);
681
- localErrorRef.current = undefined;
682
- });
859
+ }, [validateValue]);
683
860
  (0, _useUpdateEffect.default)(() => {
684
861
  var _dataContext$ajvInsta2;
685
862
  schemaValidatorRef.current = schema ? (_dataContext$ajvInsta2 = dataContext.ajvInstance) === null || _dataContext$ajvInsta2 === void 0 ? void 0 : _dataContext$ajvInsta2.compile(schema) : undefined;
@@ -710,6 +887,14 @@ function useFieldProps(localeProps) {
710
887
  }
711
888
  }
712
889
  }, [clearErrorState, dataContextError, handleError, persistErrorState, prepareError, validateInitially]);
890
+ (0, _react.useEffect)(() => {
891
+ if (itemPath && valueProp !== undefined) {
892
+ (0, _componentHelper.warn)(`Using value="${valueProp}" prop inside Iterate is not supported yet`);
893
+ }
894
+ if (itemPath && defaultValue !== undefined) {
895
+ (0, _componentHelper.warn)(`Using defaultValue="${defaultValue}" prop inside Iterate is not supported yet`);
896
+ }
897
+ }, [defaultValue, itemPath, valueProp]);
713
898
  (0, _react.useEffect)(() => {
714
899
  if (hasPath) {
715
900
  let value = valueProp;
@@ -734,7 +919,7 @@ function useFieldProps(localeProps) {
734
919
  validateDataDataContext === null || validateDataDataContext === void 0 ? void 0 : validateDataDataContext();
735
920
  }
736
921
  }
737
- }, [dataContext.data, dataContext.id, hasPath, identifier, updateDataValueDataContext, validateDataDataContext, valueProp]);
922
+ }, [dataContext.data, dataContext.id, defaultValue, hasPath, identifier, updateDataValueDataContext, validateDataDataContext, valueProp]);
738
923
  (0, _react.useEffect)(() => {
739
924
  if (showAllErrors || showBoundaryErrors) {
740
925
  if (fieldStateRef.current !== 'validating') {
@@ -745,7 +930,7 @@ function useFieldProps(localeProps) {
745
930
  }
746
931
  }, [hideError, revealError, showAllErrors, showBoundaryErrors]);
747
932
  (0, _react.useEffect)(() => {
748
- if (dataContext.formState === 'pending' && (validatorRef.current || onBlurValidatorRef.current)) {
933
+ if (dataContext.formState === 'pending' && (onChangeValidatorRef.current || onBlurValidatorRef.current)) {
749
934
  hideError();
750
935
  forceUpdate();
751
936
  }
@@ -754,50 +939,43 @@ function useFieldProps(localeProps) {
754
939
  if (hasError()) {
755
940
  return;
756
941
  }
757
- addToPool('validator', callValidator, (0, _isAsync.isAsync)(validatorRef.current));
758
- addToPool('onBlurValidator', callOnBlurValidator, (0, _isAsync.isAsync)(onBlurValidatorRef.current));
942
+ addToPool('validator', startOnChangeValidatorValidation, (0, _isAsync.isAsync)(onChangeValidatorRef.current));
943
+ addToPool('onBlurValidator', startOnBlurValidatorProcess, (0, _isAsync.isAsync)(onBlurValidatorRef.current));
759
944
  await runPool();
760
- }, [addToPool, callOnBlurValidator, callValidator, hasError, runPool]);
761
- (0, _useMountEffect.default)(() => {
762
- var _dataContext$setField;
763
- dataContext === null || dataContext === void 0 ? void 0 : (_dataContext$setField = dataContext.setFieldEventListener) === null || _dataContext$setField === void 0 ? void 0 : _dataContext$setField.call(dataContext, identifier, 'onSubmit', onSubmitHandler);
764
- });
765
- (0, _useMountEffect.default)(() => {
945
+ }, [addToPool, startOnBlurValidatorProcess, hasError, runPool, startOnChangeValidatorValidation]);
946
+ (0, _react.useEffect)(() => {
947
+ setFieldEventListener === null || setFieldEventListener === void 0 ? void 0 : setFieldEventListener(identifier, 'onSubmit', onSubmitHandler);
948
+ }, [identifier, onSubmitHandler, setFieldEventListener]);
949
+ (0, _react.useEffect)(() => {
766
950
  if (inFieldBlock) {
767
- if (errorProp) {
768
- setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
769
- identifier,
770
- type: 'error',
771
- content: errorProp,
772
- showInitially: true,
773
- show: true
774
- });
775
- }
776
- if (warning) {
777
- setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
778
- identifier,
779
- type: 'warning',
780
- content: warning,
781
- showInitially: true,
782
- show: true
783
- });
784
- }
785
- if (info) {
786
- setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
787
- identifier,
788
- type: 'info',
789
- content: info,
790
- showInitially: true,
791
- show: true
792
- });
793
- }
951
+ setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
952
+ identifier,
953
+ type: 'error',
954
+ content: errorProp,
955
+ showInitially: true,
956
+ show: true
957
+ });
958
+ setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
959
+ identifier,
960
+ type: 'warning',
961
+ content: warning,
962
+ showInitially: true,
963
+ show: true
964
+ });
965
+ setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
966
+ identifier,
967
+ type: 'info',
968
+ content: info,
969
+ showInitially: true,
970
+ show: true
971
+ });
794
972
  return () => {
795
973
  if (mountedFieldsRefFieldBlock) {
796
974
  mountedFieldsRefFieldBlock.current[identifier] = true;
797
975
  }
798
976
  };
799
977
  }
800
- });
978
+ }, [errorProp, identifier, inFieldBlock, info, mountedFieldsRefFieldBlock, setFieldStateFieldBlock, warning]);
801
979
  const infoRef = (0, _react.useRef)(info);
802
980
  const warningRef = (0, _react.useRef)(warning);
803
981
  (0, _useUpdateEffect.default)(() => {
@@ -843,13 +1021,16 @@ function useFieldProps(localeProps) {
843
1021
  };
844
1022
  const sharedData = (0, _useSharedState.useSharedState)('field-block-props-' + id);
845
1023
  sharedData.set(fieldBlockProps);
1024
+ (0, _react.useEffect)(() => {
1025
+ isInternalRerenderRef.current = undefined;
1026
+ });
846
1027
  return _objectSpread(_objectSpread(_objectSpread({}, props), fieldBlockProps), {}, {
847
1028
  name: props.name || ((_props$path = props.path) === null || _props$path === void 0 ? void 0 : _props$path.replace('/', '')) || id,
848
1029
  autoComplete: (_props$autoComplete = props.autoComplete) !== null && _props$autoComplete !== void 0 ? _props$autoComplete : dataContext.autoComplete === true ? 'on' : undefined,
849
1030
  id,
850
1031
  value: transformers.current.transformIn(transformers.current.toInput(valueRef.current)),
851
1032
  hasError: hasVisibleError,
852
- isChanged: changedRef.current,
1033
+ isChanged: Boolean(changedRef.current),
853
1034
  props,
854
1035
  htmlAttributes,
855
1036
  setHasFocus,