@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
@@ -11,11 +11,9 @@ import { FormError } from '../types';
11
11
  import { Context as DataContext } from '../DataContext';
12
12
  import { clearedData } from '../DataContext/Provider/Provider';
13
13
  import FieldPropsContext from '../Form/FieldProps/FieldPropsContext';
14
- import { combineDescribedBy } from '../../../shared/component-helper';
14
+ import { combineDescribedBy, warn } from '../../../shared/component-helper';
15
15
  import useId from '../../../shared/helpers/useId';
16
16
  import useUpdateEffect from '../../../shared/helpers/useUpdateEffect';
17
- import useMountEffect from '../../../shared/helpers/useMountEffect';
18
- import useUnmountEffect from '../../../shared/helpers/useUnmountEffect';
19
17
  import FieldBlockContext from '../FieldBlock/FieldBlockContext';
20
18
  import IterateElementContext from '../Iterate/IterateItemContext';
21
19
  import SectionContext from '../Form/Section/SectionContext';
@@ -26,6 +24,7 @@ import { createSharedState, useSharedState } from '../../../shared/helpers/useSh
26
24
  import { isAsync } from '../../../shared/helpers/isAsync';
27
25
  import useTranslation from './useTranslation';
28
26
  import useExternalValue from './useExternalValue';
27
+ import useDataValue from './useDataValue';
29
28
  export default function useFieldProps(localeProps, {
30
29
  executeOnChangeRegardlessOfError = false
31
30
  } = {}) {
@@ -51,6 +50,7 @@ export default function useFieldProps(localeProps, {
51
50
  onChange,
52
51
  onBlurValidator,
53
52
  validator,
53
+ exportValidators,
54
54
  schema,
55
55
  validateInitially,
56
56
  validateUnchanged,
@@ -72,7 +72,11 @@ export default function useFieldProps(localeProps, {
72
72
  return res;
73
73
  }
74
74
  } = props;
75
- const [, forceUpdate] = useReducer(() => ({}), {});
75
+ const [salt, forceUpdate] = useReducer(() => ({}), {});
76
+ const isInternalRerenderRef = useRef(undefined);
77
+ useMemo(() => {
78
+ isInternalRerenderRef.current = salt;
79
+ }, [salt]);
76
80
  const {
77
81
  startProcess
78
82
  } = useProcessManager();
@@ -103,10 +107,13 @@ export default function useFieldProps(localeProps, {
103
107
  setFieldError: setFieldErrorDataContext,
104
108
  setFieldProps: setPropsDataContext,
105
109
  setHasVisibleError: setHasVisibleErrorDataContext,
110
+ handleMountField,
111
+ handleUnMountField,
112
+ setFieldEventListener,
106
113
  errors: dataContextErrors,
107
114
  showAllErrors,
108
115
  contextErrorMessages
109
- } = dataContext !== null && dataContext !== void 0 ? dataContext : {};
116
+ } = dataContext || {};
110
117
  const onChangeContext = dataContext === null || dataContext === void 0 ? void 0 : (_dataContext$props = dataContext.props) === null || _dataContext$props === void 0 ? void 0 : _dataContext$props.onChange;
111
118
  const disabled = disabledProp !== null && disabledProp !== void 0 ? disabledProp : props.readOnly;
112
119
  const inFieldBlock = Boolean(fieldBlockContext);
@@ -114,18 +121,18 @@ export default function useFieldProps(localeProps, {
114
121
  setFieldState: setFieldStateFieldBlock,
115
122
  showFieldError: showFieldErrorFieldBlock,
116
123
  mountedFieldsRef: mountedFieldsRefFieldBlock
117
- } = fieldBlockContext !== null && fieldBlockContext !== void 0 ? fieldBlockContext : {};
124
+ } = fieldBlockContext || {};
118
125
  const {
119
126
  handleChange: handleChangeIterateContext
120
- } = iterateItemContext !== null && iterateItemContext !== void 0 ? iterateItemContext : {};
127
+ } = iterateItemContext || {};
121
128
  const {
122
129
  path: sectionPath,
123
130
  errorPrioritization
124
- } = sectionContext !== null && sectionContext !== void 0 ? sectionContext : {};
131
+ } = sectionContext || {};
125
132
  const {
126
133
  setFieldError,
127
134
  showBoundaryErrors
128
- } = fieldBoundaryContext !== null && fieldBoundaryContext !== void 0 ? fieldBoundaryContext : {};
135
+ } = fieldBoundaryContext || {};
129
136
  const hasPath = Boolean(pathProp);
130
137
  const {
131
138
  path,
@@ -145,8 +152,8 @@ export default function useFieldProps(localeProps, {
145
152
  emptyValue
146
153
  })) !== null && _useExternalValue !== void 0 ? _useExternalValue : defaultValueRef.current;
147
154
  const valueRef = useRef(externalValue);
148
- const changedRef = useRef(false);
149
- const hasFocusRef = useRef(false);
155
+ const changedRef = useRef();
156
+ const hasFocusRef = useRef();
150
157
  const required = useMemo(() => {
151
158
  if (requiredProp) {
152
159
  return requiredProp;
@@ -177,9 +184,9 @@ export default function useFieldProps(localeProps, {
177
184
  return path ? dataContextErrors === null || dataContextErrors === void 0 ? void 0 : dataContextErrors[identifier] : undefined;
178
185
  }, [dataContextErrors, identifier, path]);
179
186
  const contextErrorRef = useRef(dataContextError);
180
- const validatorRef = useRef(validator);
187
+ const onChangeValidatorRef = useRef(validator);
181
188
  useUpdateEffect(() => {
182
- validatorRef.current = validator;
189
+ onChangeValidatorRef.current = validator;
183
190
  }, [validator]);
184
191
  const onBlurValidatorRef = useRef(onBlurValidator);
185
192
  useUpdateEffect(() => {
@@ -258,22 +265,21 @@ export default function useFieldProps(localeProps, {
258
265
  }
259
266
  }, [setFieldStateDataContext, identifier, validateInitially]);
260
267
  const revealError = useCallback(() => {
261
- revealErrorRef.current = true;
262
- showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, true);
263
- if (localErrorRef.current) {
264
- setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, true);
265
- } else {
266
- setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, false);
268
+ if (!revealErrorRef.current) {
269
+ revealErrorRef.current = true;
270
+ showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, true);
271
+ setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, !!localErrorRef.current);
267
272
  }
268
- }, [showFieldErrorFieldBlock, identifier, setHasVisibleErrorDataContext]);
273
+ }, [identifier, setHasVisibleErrorDataContext, showFieldErrorFieldBlock]);
269
274
  const hideError = useCallback(() => {
270
- revealErrorRef.current = false;
271
- showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, false);
272
- setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, false);
273
- }, [setHasVisibleErrorDataContext, identifier, showFieldErrorFieldBlock]);
275
+ if (revealErrorRef.current) {
276
+ revealErrorRef.current = false;
277
+ showFieldErrorFieldBlock === null || showFieldErrorFieldBlock === void 0 ? void 0 : showFieldErrorFieldBlock(identifier, false);
278
+ setHasVisibleErrorDataContext === null || setHasVisibleErrorDataContext === void 0 ? void 0 : setHasVisibleErrorDataContext(identifier, false);
279
+ }
280
+ }, [identifier, setHasVisibleErrorDataContext, showFieldErrorFieldBlock]);
274
281
  const prepareError = useCallback(error => {
275
282
  if (error instanceof FormError) {
276
- var _error$messageValues;
277
283
  let message = error.message;
278
284
  const {
279
285
  validationRule
@@ -285,10 +291,10 @@ export default function useFieldProps(localeProps, {
285
291
  message = fieldMessage;
286
292
  }
287
293
  }
288
- const messagehasValues = Object.entries((_error$messageValues = error.messageValues) !== null && _error$messageValues !== void 0 ? _error$messageValues : {}).reduce((message, [key, value]) => {
294
+ const messageHasValues = Object.entries(error.messageValues || {}).reduce((message, [key, value]) => {
289
295
  return message.replace(`{${key}}`, value);
290
296
  }, message);
291
- error.message = messagehasValues;
297
+ error.message = messageHasValues;
292
298
  return error;
293
299
  }
294
300
  return error;
@@ -308,6 +314,73 @@ export default function useFieldProps(localeProps, {
308
314
  var _ref2;
309
315
  return Boolean((_ref2 = errorProp !== null && errorProp !== void 0 ? errorProp : localErrorRef.current) !== null && _ref2 !== void 0 ? _ref2 : contextErrorRef.current);
310
316
  }, [errorProp]);
317
+ const connectWithPathListenerRef = useRef(async () => {
318
+ if (localErrorRef.current || validateUnchanged || continuousValidation) {
319
+ if (onChangeValidatorRef.current) {
320
+ runOnChangeValidator();
321
+ }
322
+ }
323
+ if (localErrorRef.current && onBlurValidatorRef.current) {
324
+ runOnBlurValidator();
325
+ }
326
+ });
327
+ const {
328
+ getValueByPath
329
+ } = useDataValue();
330
+ const exportValidatorsRef = useRef(exportValidators);
331
+ exportValidatorsRef.current = exportValidators;
332
+ const additionalArgs = useMemo(() => {
333
+ const errorMessages = _objectSpread(_objectSpread({}, contextErrorMessages), errorMessagesRef.current);
334
+ const args = _objectSpread(_objectSpread({}, errorMessages), {}, {
335
+ errorMessages,
336
+ validators: exportValidatorsRef.current,
337
+ connectWithPath: path => {
338
+ setFieldEventListener === null || setFieldEventListener === void 0 ? void 0 : setFieldEventListener(path, 'onPathChange', connectWithPathListenerRef.current);
339
+ return {
340
+ getValue: () => getValueByPath(path)
341
+ };
342
+ }
343
+ });
344
+ return args;
345
+ }, [contextErrorMessages, getValueByPath, setFieldEventListener]);
346
+ const extendWithExportedValidators = useCallback((validator, result) => {
347
+ if (exportValidatorsRef.current && !result && (validator === onChangeValidatorRef.current || validator === onBlurValidatorRef.current) && !Array.isArray(result)) {
348
+ return Object.values(exportValidatorsRef.current);
349
+ }
350
+ return result;
351
+ }, []);
352
+ const callValidatorFnSync = useCallback((validator, value = valueRef.current) => {
353
+ if (typeof validator !== 'function') {
354
+ return undefined;
355
+ }
356
+ const result = extendWithExportedValidators(validator, validator(value, additionalArgs));
357
+ if (Array.isArray(result)) {
358
+ for (const validator of result) {
359
+ const result = callValidatorFnSync(validator, value);
360
+ if (result instanceof Error) {
361
+ return result;
362
+ }
363
+ }
364
+ return;
365
+ }
366
+ return result;
367
+ }, [additionalArgs, extendWithExportedValidators]);
368
+ const callValidatorFnAsync = useCallback(async (validator, value = valueRef.current) => {
369
+ if (typeof validator !== 'function') {
370
+ return undefined;
371
+ }
372
+ const result = extendWithExportedValidators(validator, await validator(value, additionalArgs));
373
+ if (Array.isArray(result)) {
374
+ for (const validator of result) {
375
+ const result = await callValidatorFnAsync(validator, value);
376
+ if (result instanceof Error) {
377
+ return result;
378
+ }
379
+ }
380
+ return;
381
+ }
382
+ return result;
383
+ }, [additionalArgs, extendWithExportedValidators]);
311
384
  const stateId = useId();
312
385
  const persistErrorState = useCallback((method, errorArg = undefined) => {
313
386
  const error = prepareError(errorArg);
@@ -339,23 +412,18 @@ export default function useFieldProps(localeProps, {
339
412
  persistErrorState('wipe');
340
413
  hasLocalErrorRef.current = false;
341
414
  }, [persistErrorState]);
342
- const callValidator = useCallback(async () => {
343
- if (typeof validatorRef.current !== 'function') {
344
- return;
345
- }
346
- const runAsync = isAsync(validatorRef.current);
347
- if (runAsync) {
348
- defineAsyncProcess('validator');
349
- setFieldState('validating');
350
- hideError();
351
- }
352
- const opts = _objectSpread(_objectSpread({}, contextErrorMessages), errorMessagesRef.current);
353
- const tmpValue = valueRef.current;
354
- const result = await validatorRef.current(valueRef.current, opts);
355
- const unchangedValue = tmpValue === valueRef.current;
415
+ const validatorCacheRef = useRef({
416
+ onChangeValidator: null,
417
+ onBlurValidator: null
418
+ });
419
+ const revealOnChangeValidatorResult = useCallback(({
420
+ result,
421
+ unchangedValue
422
+ }) => {
423
+ const runAsync = isAsync(onChangeValidatorRef.current);
356
424
  if (unchangedValue) {
357
425
  persistErrorState('gracefully', result);
358
- if (continuousValidation || runAsync) {
426
+ if (validateInitially && !changedRef.current || validateUnchanged || continuousValidation || runAsync) {
359
427
  window.requestAnimationFrame(() => {
360
428
  revealError();
361
429
  forceUpdate();
@@ -370,29 +438,129 @@ export default function useFieldProps(localeProps, {
370
438
  setFieldState('pending');
371
439
  }
372
440
  }
373
- return result;
374
- }, [contextErrorMessages, continuousValidation, hideError, persistErrorState, defineAsyncProcess, setFieldState, revealError]);
441
+ }, [continuousValidation, defineAsyncProcess, persistErrorState, revealError, setFieldState, validateInitially, validateUnchanged]);
442
+ const callOnChangeValidator = useCallback(async () => {
443
+ if (typeof onChangeValidatorRef.current !== 'function') {
444
+ return {};
445
+ }
446
+ const tmpValue = valueRef.current;
447
+ let result = isAsync(onChangeValidatorRef.current) ? await callValidatorFnAsync(onChangeValidatorRef.current) : callValidatorFnSync(onChangeValidatorRef.current);
448
+ if (result instanceof Promise) {
449
+ result = await result;
450
+ }
451
+ const unchangedValue = tmpValue === valueRef.current;
452
+ return {
453
+ result,
454
+ unchangedValue
455
+ };
456
+ }, [callValidatorFnAsync, callValidatorFnSync]);
457
+ const startOnChangeValidatorValidation = useCallback(async () => {
458
+ if (typeof onChangeValidatorRef.current !== 'function') {
459
+ return;
460
+ }
461
+ if (isAsync(onChangeValidatorRef.current)) {
462
+ defineAsyncProcess('validator');
463
+ setFieldState('validating');
464
+ hideError();
465
+ }
466
+ const tmpValue = valueRef.current;
467
+ let result = isAsync(onChangeValidatorRef.current) ? await callValidatorFnAsync(onChangeValidatorRef.current) : callValidatorFnSync(onChangeValidatorRef.current);
468
+ if (result instanceof Promise) {
469
+ result = await result;
470
+ }
471
+ const unchangedValue = tmpValue === valueRef.current;
472
+ revealOnChangeValidatorResult({
473
+ result,
474
+ unchangedValue
475
+ });
476
+ return {
477
+ result
478
+ };
479
+ }, [callValidatorFnAsync, callValidatorFnSync, defineAsyncProcess, hideError, revealOnChangeValidatorResult, setFieldState]);
480
+ const runOnChangeValidator = useCallback(async () => {
481
+ if (!onChangeValidatorRef.current) {
482
+ return;
483
+ }
484
+ const {
485
+ result,
486
+ unchangedValue
487
+ } = await callOnChangeValidator();
488
+ if (String(result) !== String(validatorCacheRef.current.onChangeValidator)) {
489
+ if (result) {
490
+ revealOnChangeValidatorResult({
491
+ result,
492
+ unchangedValue
493
+ });
494
+ } else {
495
+ hideError();
496
+ clearErrorState();
497
+ }
498
+ }
499
+ validatorCacheRef.current.onChangeValidator = result || null;
500
+ }, [callOnChangeValidator, clearErrorState, hideError, revealOnChangeValidatorResult]);
375
501
  const callOnBlurValidator = useCallback(async ({
376
- valueOverride = null
502
+ overrideValue = null
377
503
  } = {}) => {
378
504
  if (typeof onBlurValidatorRef.current !== 'function') {
379
- return;
505
+ return {};
380
506
  }
381
- const value = transformers.current.toEvent(valueOverride !== null && valueOverride !== void 0 ? valueOverride : valueRef.current, 'onBlurValidator');
382
- const runAsync = isAsync(onBlurValidatorRef.current);
383
- if (runAsync) {
384
- defineAsyncProcess('onBlurValidator');
385
- setFieldState('validating');
507
+ const value = transformers.current.toEvent(overrideValue !== null && overrideValue !== void 0 ? overrideValue : valueRef.current, 'onBlurValidator');
508
+ let result = isAsync(onBlurValidatorRef.current) ? await callValidatorFnAsync(onBlurValidatorRef.current, value) : callValidatorFnSync(onBlurValidatorRef.current, value);
509
+ if (result instanceof Promise) {
510
+ result = await result;
386
511
  }
387
- const result = await onBlurValidatorRef.current(value);
512
+ return {
513
+ result
514
+ };
515
+ }, [callValidatorFnAsync, callValidatorFnSync]);
516
+ const revealOnBlurValidatorResult = useCallback(({
517
+ result
518
+ }) => {
388
519
  persistErrorState('gracefully', result);
389
- if (runAsync) {
520
+ if (isAsync(onBlurValidatorRef.current)) {
390
521
  defineAsyncProcess(undefined);
391
522
  setFieldState(result instanceof Error ? 'error' : 'complete');
392
523
  }
393
524
  revealError();
394
- forceUpdate();
395
- }, [persistErrorState, defineAsyncProcess, setFieldState, revealError]);
525
+ }, [defineAsyncProcess, persistErrorState, revealError, setFieldState]);
526
+ const startOnBlurValidatorProcess = useCallback(async ({
527
+ overrideValue = null
528
+ } = {}) => {
529
+ if (typeof onBlurValidatorRef.current !== 'function') {
530
+ return;
531
+ }
532
+ if (isAsync(onBlurValidatorRef.current)) {
533
+ defineAsyncProcess('onBlurValidator');
534
+ setFieldState('validating');
535
+ }
536
+ const {
537
+ result
538
+ } = await callOnBlurValidator({
539
+ overrideValue
540
+ });
541
+ revealOnBlurValidatorResult({
542
+ result
543
+ });
544
+ }, [callOnBlurValidator, defineAsyncProcess, revealOnBlurValidatorResult, setFieldState]);
545
+ const runOnBlurValidator = useCallback(async () => {
546
+ if (!onBlurValidatorRef.current) {
547
+ return;
548
+ }
549
+ const {
550
+ result
551
+ } = await callOnBlurValidator();
552
+ if (String(result) !== String(validatorCacheRef.current.onBlurValidator) && revealErrorRef.current) {
553
+ if (result) {
554
+ revealOnBlurValidatorResult({
555
+ result
556
+ });
557
+ } else {
558
+ hideError();
559
+ clearErrorState();
560
+ }
561
+ }
562
+ validatorCacheRef.current.onBlurValidator = result || null;
563
+ }, [callOnBlurValidator, clearErrorState, hideError, revealOnBlurValidatorResult]);
396
564
  const prioritizeContextSchema = useMemo(() => {
397
565
  if (errorPrioritization) {
398
566
  const schemaPath = identifier.split('/').join('/properties/');
@@ -429,8 +597,10 @@ export default function useFieldProps(localeProps, {
429
597
  const error = ajvErrorsToOneFormError(schemaValidatorRef.current.errors, valueRef.current);
430
598
  throw error;
431
599
  }
432
- if (validatorRef.current && (changedRef.current || validateInitially)) {
433
- const result = await callValidator();
600
+ if (onChangeValidatorRef.current && (changedRef.current || validateInitially || validateUnchanged)) {
601
+ const {
602
+ result
603
+ } = await startOnChangeValidatorValidation();
434
604
  if (result instanceof Error) {
435
605
  throw result;
436
606
  }
@@ -445,7 +615,7 @@ export default function useFieldProps(localeProps, {
445
615
  persistErrorState('weak', error);
446
616
  }
447
617
  }
448
- }, [startProcess, disabled, hideError, setFieldState, clearErrorState, emptyValue, requiredProp, required, prioritizeContextSchema, validateInitially, callValidator, persistErrorState]);
618
+ }, [startProcess, disabled, hideError, setFieldState, clearErrorState, emptyValue, requiredProp, required, prioritizeContextSchema, validateInitially, validateUnchanged, startOnChangeValidatorValidation, persistErrorState]);
449
619
  const handleError = useCallback(() => {
450
620
  if (continuousValidation || continuousValidation !== false && !hasFocusRef.current) {
451
621
  revealError();
@@ -453,9 +623,9 @@ export default function useFieldProps(localeProps, {
453
623
  hideError();
454
624
  }
455
625
  }, [continuousValidation, hideError, revealError]);
456
- const setHasFocus = useCallback(async (hasFocus, valueOverride, additionalArgs) => {
626
+ const setHasFocus = useCallback(async (hasFocus, overrideValue, additionalArgs) => {
457
627
  const getArgs = type => {
458
- const value = transformers.current.toEvent(valueOverride !== null && valueOverride !== void 0 ? valueOverride : valueRef.current, type);
628
+ const value = transformers.current.toEvent(overrideValue !== null && overrideValue !== void 0 ? overrideValue : valueRef.current, type);
459
629
  const transformedAdditionalArgs = transformers.current.transformAdditionalArgs(additionalArgs, value);
460
630
  return typeof transformedAdditionalArgs !== 'undefined' ? [value, transformedAdditionalArgs] : [value];
461
631
  };
@@ -470,15 +640,15 @@ export default function useFieldProps(localeProps, {
470
640
  if (!changedRef.current && !validateUnchanged) {
471
641
  return;
472
642
  }
473
- addToPool('onBlurValidator', async () => await callOnBlurValidator({
474
- valueOverride
643
+ addToPool('onBlurValidator', async () => await startOnBlurValidatorProcess({
644
+ overrideValue
475
645
  }), isAsync(onBlurValidatorRef.current));
476
646
  await runPool(() => {
477
647
  revealError();
478
648
  forceUpdate();
479
649
  });
480
650
  }
481
- }, [addToPool, callOnBlurValidator, onBlur, onFocus, runPool, revealError, validateUnchanged]);
651
+ }, [onFocus, onBlur, validateUnchanged, addToPool, runPool, startOnBlurValidatorProcess, revealError]);
482
652
  const yieldAsyncProcess = useCallback(async ({
483
653
  name,
484
654
  waitFor
@@ -584,7 +754,7 @@ export default function useFieldProps(localeProps, {
584
754
  if (hasPath) {
585
755
  handlePathChangeUnvalidatedDataContext(identifier, newValue);
586
756
  }
587
- addToPool('validator', validateValue, isAsync(validatorRef.current));
757
+ addToPool('validator', validateValue, isAsync(onChangeValidatorRef.current));
588
758
  addToPool('onChangeContext', callOnChangeContext, isAsync(onChangeContext));
589
759
  await runPool(() => {
590
760
  handleError();
@@ -646,16 +816,18 @@ export default function useFieldProps(localeProps, {
646
816
  const handleFocus = useCallback(() => setHasFocus(true), [setHasFocus]);
647
817
  const handleBlur = useCallback(() => setHasFocus(false), [setHasFocus]);
648
818
  setPropsDataContext === null || setPropsDataContext === void 0 ? void 0 : setPropsDataContext(identifier, props);
649
- useMountEffect(() => {
650
- dataContext === null || dataContext === void 0 ? void 0 : dataContext.handleMountField(identifier);
819
+ useEffect(() => {
820
+ handleMountField(identifier);
821
+ return () => {
822
+ handleUnMountField(identifier);
823
+ setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(identifier, undefined);
824
+ setFieldError === null || setFieldError === void 0 ? void 0 : setFieldError(identifier, undefined);
825
+ localErrorRef.current = undefined;
826
+ };
827
+ }, [handleMountField, handleUnMountField, identifier, setFieldError, setFieldErrorDataContext]);
828
+ useEffect(() => {
651
829
  validateValue();
652
- });
653
- useUnmountEffect(() => {
654
- dataContext === null || dataContext === void 0 ? void 0 : dataContext.handleUnMountField(identifier);
655
- setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(identifier, undefined);
656
- setFieldError === null || setFieldError === void 0 ? void 0 : setFieldError(identifier, undefined);
657
- localErrorRef.current = undefined;
658
- });
830
+ }, [validateValue]);
659
831
  useUpdateEffect(() => {
660
832
  var _dataContext$ajvInsta2;
661
833
  schemaValidatorRef.current = schema ? (_dataContext$ajvInsta2 = dataContext.ajvInstance) === null || _dataContext$ajvInsta2 === void 0 ? void 0 : _dataContext$ajvInsta2.compile(schema) : undefined;
@@ -686,6 +858,14 @@ export default function useFieldProps(localeProps, {
686
858
  }
687
859
  }
688
860
  }, [clearErrorState, dataContextError, handleError, persistErrorState, prepareError, validateInitially]);
861
+ useEffect(() => {
862
+ if (itemPath && valueProp !== undefined) {
863
+ warn(`Using value="${valueProp}" prop inside Iterate is not supported yet`);
864
+ }
865
+ if (itemPath && defaultValue !== undefined) {
866
+ warn(`Using defaultValue="${defaultValue}" prop inside Iterate is not supported yet`);
867
+ }
868
+ }, [defaultValue, itemPath, valueProp]);
689
869
  useEffect(() => {
690
870
  if (hasPath) {
691
871
  let value = valueProp;
@@ -710,7 +890,7 @@ export default function useFieldProps(localeProps, {
710
890
  validateDataDataContext === null || validateDataDataContext === void 0 ? void 0 : validateDataDataContext();
711
891
  }
712
892
  }
713
- }, [dataContext.data, dataContext.id, hasPath, identifier, updateDataValueDataContext, validateDataDataContext, valueProp]);
893
+ }, [dataContext.data, dataContext.id, defaultValue, hasPath, identifier, updateDataValueDataContext, validateDataDataContext, valueProp]);
714
894
  useEffect(() => {
715
895
  if (showAllErrors || showBoundaryErrors) {
716
896
  if (fieldStateRef.current !== 'validating') {
@@ -721,7 +901,7 @@ export default function useFieldProps(localeProps, {
721
901
  }
722
902
  }, [hideError, revealError, showAllErrors, showBoundaryErrors]);
723
903
  useEffect(() => {
724
- if (dataContext.formState === 'pending' && (validatorRef.current || onBlurValidatorRef.current)) {
904
+ if (dataContext.formState === 'pending' && (onChangeValidatorRef.current || onBlurValidatorRef.current)) {
725
905
  hideError();
726
906
  forceUpdate();
727
907
  }
@@ -730,50 +910,43 @@ export default function useFieldProps(localeProps, {
730
910
  if (hasError()) {
731
911
  return;
732
912
  }
733
- addToPool('validator', callValidator, isAsync(validatorRef.current));
734
- addToPool('onBlurValidator', callOnBlurValidator, isAsync(onBlurValidatorRef.current));
913
+ addToPool('validator', startOnChangeValidatorValidation, isAsync(onChangeValidatorRef.current));
914
+ addToPool('onBlurValidator', startOnBlurValidatorProcess, isAsync(onBlurValidatorRef.current));
735
915
  await runPool();
736
- }, [addToPool, callOnBlurValidator, callValidator, hasError, runPool]);
737
- useMountEffect(() => {
738
- var _dataContext$setField;
739
- 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);
740
- });
741
- useMountEffect(() => {
916
+ }, [addToPool, startOnBlurValidatorProcess, hasError, runPool, startOnChangeValidatorValidation]);
917
+ useEffect(() => {
918
+ setFieldEventListener === null || setFieldEventListener === void 0 ? void 0 : setFieldEventListener(identifier, 'onSubmit', onSubmitHandler);
919
+ }, [identifier, onSubmitHandler, setFieldEventListener]);
920
+ useEffect(() => {
742
921
  if (inFieldBlock) {
743
- if (errorProp) {
744
- setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
745
- identifier,
746
- type: 'error',
747
- content: errorProp,
748
- showInitially: true,
749
- show: true
750
- });
751
- }
752
- if (warning) {
753
- setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
754
- identifier,
755
- type: 'warning',
756
- content: warning,
757
- showInitially: true,
758
- show: true
759
- });
760
- }
761
- if (info) {
762
- setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
763
- identifier,
764
- type: 'info',
765
- content: info,
766
- showInitially: true,
767
- show: true
768
- });
769
- }
922
+ setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
923
+ identifier,
924
+ type: 'error',
925
+ content: errorProp,
926
+ showInitially: true,
927
+ show: true
928
+ });
929
+ setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
930
+ identifier,
931
+ type: 'warning',
932
+ content: warning,
933
+ showInitially: true,
934
+ show: true
935
+ });
936
+ setFieldStateFieldBlock === null || setFieldStateFieldBlock === void 0 ? void 0 : setFieldStateFieldBlock({
937
+ identifier,
938
+ type: 'info',
939
+ content: info,
940
+ showInitially: true,
941
+ show: true
942
+ });
770
943
  return () => {
771
944
  if (mountedFieldsRefFieldBlock) {
772
945
  mountedFieldsRefFieldBlock.current[identifier] = true;
773
946
  }
774
947
  };
775
948
  }
776
- });
949
+ }, [errorProp, identifier, inFieldBlock, info, mountedFieldsRefFieldBlock, setFieldStateFieldBlock, warning]);
777
950
  const infoRef = useRef(info);
778
951
  const warningRef = useRef(warning);
779
952
  useUpdateEffect(() => {
@@ -819,13 +992,16 @@ export default function useFieldProps(localeProps, {
819
992
  };
820
993
  const sharedData = useSharedState('field-block-props-' + id);
821
994
  sharedData.set(fieldBlockProps);
995
+ useEffect(() => {
996
+ isInternalRerenderRef.current = undefined;
997
+ });
822
998
  return _objectSpread(_objectSpread(_objectSpread({}, props), fieldBlockProps), {}, {
823
999
  name: props.name || ((_props$path = props.path) === null || _props$path === void 0 ? void 0 : _props$path.replace('/', '')) || id,
824
1000
  autoComplete: (_props$autoComplete = props.autoComplete) !== null && _props$autoComplete !== void 0 ? _props$autoComplete : dataContext.autoComplete === true ? 'on' : undefined,
825
1001
  id,
826
1002
  value: transformers.current.transformIn(transformers.current.toInput(valueRef.current)),
827
1003
  hasError: hasVisibleError,
828
- isChanged: changedRef.current,
1004
+ isChanged: Boolean(changedRef.current),
829
1005
  props,
830
1006
  htmlAttributes,
831
1007
  setHasFocus,