@digigov/form 2.0.0-264e5fff → 2.0.0-290ada95

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 (621) hide show
  1. package/Field/ErrorGroup.d.ts +2 -2
  2. package/Field/ErrorGroup.js +53 -0
  3. package/Field/FieldBase.d.ts +1 -1
  4. package/Field/FieldBase.js +77 -0
  5. package/Field/FieldBaseContainer.d.ts +1 -1
  6. package/Field/FieldBaseContainer.js +43 -0
  7. package/Field/FieldConditional.d.ts +1 -1
  8. package/Field/FieldConditional.js +45 -0
  9. package/Field/index.d.ts +1 -1
  10. package/Field/index.js +69 -107
  11. package/Field/types.d.ts +3 -3
  12. package/Field/types.js +0 -0
  13. package/Field/utils/evaluateFieldWithConditions.d.ts +1 -1
  14. package/Field/utils/evaluateFieldWithConditions.js +19 -0
  15. package/Field/utils/resolveField.d.ts +2 -2
  16. package/Field/utils/resolveField.js +32 -0
  17. package/Field/utils/useField.d.ts +1 -1
  18. package/Field/utils/useField.js +47 -0
  19. package/FieldArray/BaseFieldArray.d.ts +1 -1
  20. package/FieldArray/BaseFieldArray.js +46 -0
  21. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.js +13 -0
  22. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js +117 -0
  23. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js +6 -0
  24. package/FieldArray/FormDialog/ArrayDisplay/index.js +32 -57
  25. package/FieldArray/FormDialog/ArrayEditModal.d.ts +1 -1
  26. package/FieldArray/FormDialog/ArrayEditModal.js +138 -0
  27. package/FieldArray/FormDialog/index.d.ts +1 -1
  28. package/FieldArray/FormDialog/index.js +142 -177
  29. package/FieldArray/index.d.ts +2 -2
  30. package/FieldArray/index.js +59 -86
  31. package/FieldObject/index.d.ts +2 -2
  32. package/FieldObject/index.js +52 -77
  33. package/Fieldset/FieldsetWithContext.js +27 -0
  34. package/Fieldset/index.d.ts +1 -1
  35. package/Fieldset/index.js +18 -30
  36. package/Fieldset/types.js +0 -0
  37. package/FormBuilder/index.d.ts +2 -2
  38. package/FormBuilder/index.js +226 -254
  39. package/FormContext.d.ts +1 -1
  40. package/FormContext.js +7 -0
  41. package/MultiplicityField/add-objects.d.ts +1 -1
  42. package/MultiplicityField/add-objects.js +107 -0
  43. package/MultiplicityField/index.d.ts +1 -1
  44. package/MultiplicityField/index.js +81 -119
  45. package/MultiplicityField/types.d.ts +1 -1
  46. package/MultiplicityField/types.js +0 -0
  47. package/Questions/Questions.d.ts +1 -1
  48. package/Questions/Questions.js +48 -0
  49. package/Questions/QuestionsContext.d.ts +1 -1
  50. package/Questions/QuestionsContext.js +10 -0
  51. package/Questions/Step/ReviewStep.js +32 -0
  52. package/Questions/Step/Step.d.ts +1 -1
  53. package/Questions/Step/Step.js +39 -0
  54. package/Questions/Step/StepArrayReview.d.ts +1 -1
  55. package/Questions/Step/StepArrayReview.js +35 -0
  56. package/Questions/Step/StepContext.d.ts +1 -1
  57. package/Questions/Step/StepContext.js +28 -0
  58. package/Questions/Step/StepDescription.js +18 -0
  59. package/Questions/Step/StepForm.d.ts +2 -2
  60. package/Questions/Step/StepForm.js +29 -0
  61. package/Questions/Step/StepQuote.js +5 -0
  62. package/Questions/Step/StepTitle.js +25 -0
  63. package/Questions/Step/getAddMoreFields.d.ts +2 -2
  64. package/Questions/Step/getAddMoreFields.js +24 -0
  65. package/Questions/Step/index.d.ts +11 -11
  66. package/Questions/Step/index.js +13 -16
  67. package/Questions/Step/types.d.ts +1 -1
  68. package/Questions/Step/types.js +0 -0
  69. package/Questions/getNextStep.d.ts +1 -1
  70. package/Questions/getNextStep.js +13 -0
  71. package/Questions/index.d.ts +2 -2
  72. package/Questions/index.js +4 -7
  73. package/Questions/types.d.ts +1 -1
  74. package/Questions/types.js +0 -0
  75. package/hooks/useFieldFocusManager.js +83 -0
  76. package/hooks/utils.js +60 -0
  77. package/index.d.ts +5 -5
  78. package/index.js +8 -13
  79. package/inputs/AutoCompleteInput/index.d.ts +2 -2
  80. package/inputs/AutoCompleteInput/index.js +38 -60
  81. package/inputs/Checkboxes/index.d.ts +2 -2
  82. package/inputs/Checkboxes/index.js +43 -76
  83. package/inputs/DateInput/index.d.ts +1 -1
  84. package/inputs/DateInput/index.js +123 -147
  85. package/inputs/DateTimeInput/index.d.ts +1 -1
  86. package/inputs/DateTimeInput/index.js +177 -207
  87. package/inputs/FileInput/index.d.ts +1 -1
  88. package/inputs/FileInput/index.js +54 -70
  89. package/inputs/ImageInput/index.d.ts +1 -1
  90. package/inputs/ImageInput/index.js +74 -74
  91. package/inputs/Input/index.d.ts +1 -1
  92. package/inputs/Input/index.js +60 -73
  93. package/inputs/Label/index.d.ts +1 -1
  94. package/inputs/Label/index.js +13 -16
  95. package/inputs/OtpInput/index.js +116 -145
  96. package/inputs/Radio/index.d.ts +2 -2
  97. package/inputs/Radio/index.js +70 -103
  98. package/inputs/Select/index.d.ts +2 -2
  99. package/inputs/Select/index.js +23 -32
  100. package/inputs/index.d.ts +9 -9
  101. package/inputs/index.js +10 -21
  102. package/inputs/registry.d.ts +1 -1
  103. package/inputs/registry.js +80 -0
  104. package/internal.d.ts +5 -5
  105. package/internal.js +6 -0
  106. package/lazy.d.ts +97 -0
  107. package/lazy.js +163 -0
  108. package/package.json +8 -8
  109. package/registry.d.ts +82 -0
  110. package/registry.js +170 -0
  111. package/src/Field/ErrorGroup.tsx +1 -1
  112. package/src/FormBuilder/doc.mdx +1 -1
  113. package/src/inputs/AutoCompleteInput/doc.mdx +2 -2
  114. package/src/inputs/Checkboxes/doc.mdx +3 -3
  115. package/src/inputs/DateInput/doc.mdx +1 -1
  116. package/src/inputs/DateTimeInput/doc.mdx +1 -1
  117. package/src/inputs/FileInput/doc.mdx +1 -1
  118. package/src/inputs/ImageInput/doc.mdx +3 -3
  119. package/src/inputs/Input/doc.mdx +10 -10
  120. package/src/inputs/Label/doc.mdx +1 -1
  121. package/src/inputs/OtpInput/doc.mdx +1 -1
  122. package/src/inputs/Radio/doc.mdx +3 -3
  123. package/src/inputs/Select/doc.mdx +1 -1
  124. package/{lazy/index.js → src/lazy.ts} +0 -25
  125. package/types.d.ts +4 -4
  126. package/types.js +1 -0
  127. package/utils.js +56 -0
  128. package/validators/index.d.ts +2 -2
  129. package/validators/index.js +112 -159
  130. package/validators/types.js +0 -0
  131. package/validators/utils/afm.js +19 -0
  132. package/validators/utils/amka.js +27 -0
  133. package/validators/utils/date.d.ts +2 -2
  134. package/validators/utils/date.js +95 -0
  135. package/validators/utils/datetime.d.ts +2 -2
  136. package/validators/utils/datetime.js +121 -0
  137. package/validators/utils/email.js +10 -0
  138. package/validators/utils/file.d.ts +2 -2
  139. package/validators/utils/file.js +31 -0
  140. package/validators/utils/iban.d.ts +2 -2
  141. package/validators/utils/iban.js +104 -0
  142. package/validators/utils/image.d.ts +2 -2
  143. package/validators/utils/image.js +65 -0
  144. package/validators/utils/index.d.ts +14 -14
  145. package/validators/utils/index.js +58 -96
  146. package/validators/utils/int.d.ts +1 -1
  147. package/validators/utils/int.js +13 -0
  148. package/validators/utils/number.d.ts +1 -1
  149. package/validators/utils/number.js +12 -0
  150. package/validators/utils/otp.d.ts +2 -2
  151. package/validators/utils/otp.js +21 -0
  152. package/validators/utils/phone.d.ts +2 -2
  153. package/validators/utils/phone.js +198 -0
  154. package/validators/utils/postal_code.d.ts +2 -2
  155. package/validators/utils/postal_code.js +18 -0
  156. package/validators/utils/text_limit.d.ts +2 -2
  157. package/validators/utils/text_limit.js +34 -0
  158. package/validators/utils/uuid4.js +14 -0
  159. package/Field/ErrorGroup/index.js +0 -48
  160. package/Field/ErrorGroup/package.json +0 -6
  161. package/Field/ErrorGroup.js.map +0 -7
  162. package/Field/FieldBase/index.js +0 -122
  163. package/Field/FieldBase/package.json +0 -6
  164. package/Field/FieldBase.js.map +0 -7
  165. package/Field/FieldBaseContainer/index.js +0 -52
  166. package/Field/FieldBaseContainer/package.json +0 -6
  167. package/Field/FieldBaseContainer.js.map +0 -7
  168. package/Field/FieldConditional/index.js +0 -89
  169. package/Field/FieldConditional/package.json +0 -6
  170. package/Field/FieldConditional.js.map +0 -7
  171. package/Field/index.js.map +0 -7
  172. package/Field/package.json +0 -6
  173. package/Field/types/index.js +0 -1
  174. package/Field/types/package.json +0 -6
  175. package/Field/types.js.map +0 -7
  176. package/Field/utils/evaluateFieldWithConditions/index.js +0 -26
  177. package/Field/utils/evaluateFieldWithConditions/package.json +0 -6
  178. package/Field/utils/evaluateFieldWithConditions.js.map +0 -7
  179. package/Field/utils/resolveField/index.js +0 -35
  180. package/Field/utils/resolveField/package.json +0 -6
  181. package/Field/utils/resolveField.js.map +0 -7
  182. package/Field/utils/useField/index.js +0 -66
  183. package/Field/utils/useField/package.json +0 -6
  184. package/Field/utils/useField.js.map +0 -7
  185. package/FieldArray/BaseFieldArray/index.js +0 -76
  186. package/FieldArray/BaseFieldArray/package.json +0 -6
  187. package/FieldArray/BaseFieldArray.js.map +0 -7
  188. package/FieldArray/FieldArray.stories.d.ts +0 -11
  189. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay/index.js +0 -23
  190. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay/package.json +0 -6
  191. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.js.map +0 -7
  192. package/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.d.ts +0 -13
  193. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +0 -184
  194. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/package.json +0 -6
  195. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +0 -7
  196. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/index.js +0 -11
  197. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/package.json +0 -6
  198. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +0 -7
  199. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Cards.d.ts +0 -2
  200. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.d.ts +0 -2
  201. package/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.d.ts +0 -2
  202. package/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnlyCards.d.ts +0 -2
  203. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.d.ts +0 -2
  204. package/FieldArray/FormDialog/ArrayDisplay/__stories__/SortableCards.d.ts +0 -2
  205. package/FieldArray/FormDialog/ArrayDisplay/index.js.map +0 -7
  206. package/FieldArray/FormDialog/ArrayDisplay/package.json +0 -6
  207. package/FieldArray/FormDialog/ArrayEditModal/index.js +0 -158
  208. package/FieldArray/FormDialog/ArrayEditModal/package.json +0 -6
  209. package/FieldArray/FormDialog/ArrayEditModal.js.map +0 -7
  210. package/FieldArray/FormDialog/index.js.map +0 -7
  211. package/FieldArray/FormDialog/package.json +0 -6
  212. package/FieldArray/__stories__/CardsWithError.d.ts +0 -15
  213. package/FieldArray/__stories__/Default.d.ts +0 -2
  214. package/FieldArray/__stories__/WithExactLength.d.ts +0 -2
  215. package/FieldArray/__stories__/WithModal.d.ts +0 -2
  216. package/FieldArray/index.js.map +0 -7
  217. package/FieldArray/package.json +0 -6
  218. package/FieldObject/index.js.map +0 -7
  219. package/FieldObject/package.json +0 -6
  220. package/Fieldset/FieldsetWithContext/index.js +0 -31
  221. package/Fieldset/FieldsetWithContext/package.json +0 -6
  222. package/Fieldset/FieldsetWithContext.js.map +0 -7
  223. package/Fieldset/index.js.map +0 -7
  224. package/Fieldset/package.json +0 -6
  225. package/Fieldset/types/index.js +0 -1
  226. package/Fieldset/types/package.json +0 -6
  227. package/Fieldset/types.js.map +0 -7
  228. package/Form.stories.d.ts +0 -4
  229. package/FormBuilder/FormBuilder.stories.d.ts +0 -12
  230. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +0 -3
  231. package/FormBuilder/__stories__/Default.d.ts +0 -3
  232. package/FormBuilder/__stories__/ErrorGrouping.d.ts +0 -3
  233. package/FormBuilder/index.js.map +0 -7
  234. package/FormBuilder/package.json +0 -6
  235. package/FormContext/index.js +0 -13
  236. package/FormContext/package.json +0 -6
  237. package/FormContext.js.map +0 -7
  238. package/MultiplicityField/MultiplicityField.stories.d.ts +0 -15
  239. package/MultiplicityField/__stories__/Default.d.ts +0 -2
  240. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +0 -2
  241. package/MultiplicityField/__stories__/WithExactLength.d.ts +0 -2
  242. package/MultiplicityField/__stories__/WithMaxLength.d.ts +0 -2
  243. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +0 -2
  244. package/MultiplicityField/__stories__/WithMinLength.d.ts +0 -2
  245. package/MultiplicityField/add-objects/index.js +0 -146
  246. package/MultiplicityField/add-objects/package.json +0 -6
  247. package/MultiplicityField/add-objects.js.map +0 -7
  248. package/MultiplicityField/index.js.map +0 -7
  249. package/MultiplicityField/package.json +0 -6
  250. package/MultiplicityField/types/index.js +0 -1
  251. package/MultiplicityField/types/package.json +0 -6
  252. package/MultiplicityField/types.js.map +0 -7
  253. package/Questions/Questions/index.js +0 -67
  254. package/Questions/Questions/package.json +0 -6
  255. package/Questions/Questions.js.map +0 -7
  256. package/Questions/Questions.stories.d.ts +0 -10
  257. package/Questions/QuestionsContext/index.js +0 -11
  258. package/Questions/QuestionsContext/package.json +0 -6
  259. package/Questions/QuestionsContext.js.map +0 -7
  260. package/Questions/Step/ReviewStep/index.js +0 -38
  261. package/Questions/Step/ReviewStep/package.json +0 -6
  262. package/Questions/Step/ReviewStep.js.map +0 -7
  263. package/Questions/Step/Step/index.js +0 -54
  264. package/Questions/Step/Step/package.json +0 -6
  265. package/Questions/Step/Step.js.map +0 -7
  266. package/Questions/Step/StepArrayReview/index.js +0 -42
  267. package/Questions/Step/StepArrayReview/package.json +0 -6
  268. package/Questions/Step/StepArrayReview.js.map +0 -7
  269. package/Questions/Step/StepContext/index.js +0 -23
  270. package/Questions/Step/StepContext/package.json +0 -6
  271. package/Questions/Step/StepContext.js.map +0 -7
  272. package/Questions/Step/StepDescription/index.js +0 -24
  273. package/Questions/Step/StepDescription/package.json +0 -6
  274. package/Questions/Step/StepDescription.js.map +0 -7
  275. package/Questions/Step/StepForm/index.js +0 -34
  276. package/Questions/Step/StepForm/package.json +0 -6
  277. package/Questions/Step/StepForm.js.map +0 -7
  278. package/Questions/Step/StepQuote/index.js +0 -11
  279. package/Questions/Step/StepQuote/package.json +0 -6
  280. package/Questions/Step/StepQuote.js.map +0 -7
  281. package/Questions/Step/StepTitle/index.js +0 -44
  282. package/Questions/Step/StepTitle/package.json +0 -6
  283. package/Questions/Step/StepTitle.js.map +0 -7
  284. package/Questions/Step/getAddMoreFields/index.js +0 -29
  285. package/Questions/Step/getAddMoreFields/package.json +0 -6
  286. package/Questions/Step/getAddMoreFields.js.map +0 -7
  287. package/Questions/Step/index.js.map +0 -7
  288. package/Questions/Step/package.json +0 -6
  289. package/Questions/Step/types/index.js +0 -1
  290. package/Questions/Step/types/package.json +0 -6
  291. package/Questions/Step/types.js.map +0 -7
  292. package/Questions/__stories__/Default.d.ts +0 -3
  293. package/Questions/getNextStep/index.js +0 -22
  294. package/Questions/getNextStep/package.json +0 -6
  295. package/Questions/getNextStep.js.map +0 -7
  296. package/Questions/index.js.map +0 -7
  297. package/Questions/package.json +0 -6
  298. package/Questions/types/index.js +0 -1
  299. package/Questions/types/package.json +0 -6
  300. package/Questions/types.js.map +0 -7
  301. package/cjs/Field/ErrorGroup/index.js +0 -82
  302. package/cjs/Field/ErrorGroup.js.map +0 -7
  303. package/cjs/Field/FieldBase/index.js +0 -155
  304. package/cjs/Field/FieldBase.js.map +0 -7
  305. package/cjs/Field/FieldBaseContainer/index.js +0 -85
  306. package/cjs/Field/FieldBaseContainer.js.map +0 -7
  307. package/cjs/Field/FieldConditional/index.js +0 -122
  308. package/cjs/Field/FieldConditional.js.map +0 -7
  309. package/cjs/Field/index.js +0 -143
  310. package/cjs/Field/index.js.map +0 -7
  311. package/cjs/Field/types/index.js +0 -16
  312. package/cjs/Field/types.js.map +0 -7
  313. package/cjs/Field/utils/evaluateFieldWithConditions/index.js +0 -49
  314. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +0 -7
  315. package/cjs/Field/utils/resolveField/index.js +0 -55
  316. package/cjs/Field/utils/resolveField.js.map +0 -7
  317. package/cjs/Field/utils/useField/index.js +0 -89
  318. package/cjs/Field/utils/useField.js.map +0 -7
  319. package/cjs/FieldArray/BaseFieldArray/index.js +0 -109
  320. package/cjs/FieldArray/BaseFieldArray.js.map +0 -7
  321. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay/index.js +0 -56
  322. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.js.map +0 -7
  323. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +0 -209
  324. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +0 -7
  325. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/index.js +0 -44
  326. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +0 -7
  327. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js +0 -90
  328. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js.map +0 -7
  329. package/cjs/FieldArray/FormDialog/ArrayEditModal/index.js +0 -186
  330. package/cjs/FieldArray/FormDialog/ArrayEditModal.js.map +0 -7
  331. package/cjs/FieldArray/FormDialog/index.js +0 -261
  332. package/cjs/FieldArray/FormDialog/index.js.map +0 -7
  333. package/cjs/FieldArray/index.js +0 -126
  334. package/cjs/FieldArray/index.js.map +0 -7
  335. package/cjs/FieldObject/index.js +0 -113
  336. package/cjs/FieldObject/index.js.map +0 -7
  337. package/cjs/Fieldset/FieldsetWithContext/index.js +0 -59
  338. package/cjs/Fieldset/FieldsetWithContext.js.map +0 -7
  339. package/cjs/Fieldset/index.js +0 -66
  340. package/cjs/Fieldset/index.js.map +0 -7
  341. package/cjs/Fieldset/types/index.js +0 -16
  342. package/cjs/Fieldset/types.js.map +0 -7
  343. package/cjs/FormBuilder/index.js +0 -303
  344. package/cjs/FormBuilder/index.js.map +0 -7
  345. package/cjs/FormContext/index.js +0 -37
  346. package/cjs/FormContext.js.map +0 -7
  347. package/cjs/MultiplicityField/add-objects/index.js +0 -179
  348. package/cjs/MultiplicityField/add-objects.js.map +0 -7
  349. package/cjs/MultiplicityField/index.js +0 -153
  350. package/cjs/MultiplicityField/index.js.map +0 -7
  351. package/cjs/MultiplicityField/types/index.js +0 -16
  352. package/cjs/MultiplicityField/types.js.map +0 -7
  353. package/cjs/Questions/Questions/index.js +0 -100
  354. package/cjs/Questions/Questions.js.map +0 -7
  355. package/cjs/Questions/QuestionsContext/index.js +0 -34
  356. package/cjs/Questions/QuestionsContext.js.map +0 -7
  357. package/cjs/Questions/Step/ReviewStep/index.js +0 -65
  358. package/cjs/Questions/Step/ReviewStep.js.map +0 -7
  359. package/cjs/Questions/Step/Step/index.js +0 -87
  360. package/cjs/Questions/Step/Step.js.map +0 -7
  361. package/cjs/Questions/Step/StepArrayReview/index.js +0 -67
  362. package/cjs/Questions/Step/StepArrayReview.js.map +0 -7
  363. package/cjs/Questions/Step/StepContext/index.js +0 -46
  364. package/cjs/Questions/Step/StepContext.js.map +0 -7
  365. package/cjs/Questions/Step/StepDescription/index.js +0 -58
  366. package/cjs/Questions/Step/StepDescription.js.map +0 -7
  367. package/cjs/Questions/Step/StepForm/index.js +0 -67
  368. package/cjs/Questions/Step/StepForm.js.map +0 -7
  369. package/cjs/Questions/Step/StepQuote/index.js +0 -44
  370. package/cjs/Questions/Step/StepQuote.js.map +0 -7
  371. package/cjs/Questions/Step/StepTitle/index.js +0 -76
  372. package/cjs/Questions/Step/StepTitle.js.map +0 -7
  373. package/cjs/Questions/Step/getAddMoreFields/index.js +0 -52
  374. package/cjs/Questions/Step/getAddMoreFields.js.map +0 -7
  375. package/cjs/Questions/Step/index.js +0 -59
  376. package/cjs/Questions/Step/index.js.map +0 -7
  377. package/cjs/Questions/Step/types/index.js +0 -16
  378. package/cjs/Questions/Step/types.js.map +0 -7
  379. package/cjs/Questions/getNextStep/index.js +0 -45
  380. package/cjs/Questions/getNextStep.js.map +0 -7
  381. package/cjs/Questions/index.js +0 -31
  382. package/cjs/Questions/index.js.map +0 -7
  383. package/cjs/Questions/types/index.js +0 -16
  384. package/cjs/Questions/types.js.map +0 -7
  385. package/cjs/hooks/useFieldFocusManager/index.js +0 -135
  386. package/cjs/hooks/useFieldFocusManager.js.map +0 -7
  387. package/cjs/hooks/utils/index.js +0 -98
  388. package/cjs/hooks/utils.js.map +0 -7
  389. package/cjs/index.js +0 -49
  390. package/cjs/index.js.map +0 -7
  391. package/cjs/inputs/AutoCompleteInput/index.js +0 -98
  392. package/cjs/inputs/AutoCompleteInput/index.js.map +0 -7
  393. package/cjs/inputs/Checkboxes/index.js +0 -112
  394. package/cjs/inputs/Checkboxes/index.js.map +0 -7
  395. package/cjs/inputs/DateInput/index.js +0 -188
  396. package/cjs/inputs/DateInput/index.js.map +0 -7
  397. package/cjs/inputs/DateTimeInput/index.js +0 -250
  398. package/cjs/inputs/DateTimeInput/index.js.map +0 -7
  399. package/cjs/inputs/FileInput/index.js +0 -110
  400. package/cjs/inputs/FileInput/index.js.map +0 -7
  401. package/cjs/inputs/ImageInput/__stories__/logo.d/index.js +0 -1
  402. package/cjs/inputs/ImageInput/__stories__/logo.d.js.map +0 -7
  403. package/cjs/inputs/ImageInput/index.js +0 -130
  404. package/cjs/inputs/ImageInput/index.js.map +0 -7
  405. package/cjs/inputs/Input/index.js +0 -115
  406. package/cjs/inputs/Input/index.js.map +0 -7
  407. package/cjs/inputs/Label/index.js +0 -50
  408. package/cjs/inputs/Label/index.js.map +0 -7
  409. package/cjs/inputs/OtpInput/index.js +0 -186
  410. package/cjs/inputs/OtpInput/index.js.map +0 -7
  411. package/cjs/inputs/Radio/index.js +0 -136
  412. package/cjs/inputs/Radio/index.js.map +0 -7
  413. package/cjs/inputs/Select/index.js +0 -63
  414. package/cjs/inputs/Select/index.js.map +0 -7
  415. package/cjs/inputs/index.js +0 -62
  416. package/cjs/inputs/index.js.map +0 -7
  417. package/cjs/inputs/registry/index.js +0 -121
  418. package/cjs/inputs/registry.js.map +0 -7
  419. package/cjs/internal/index.js +0 -38
  420. package/cjs/internal.js.map +0 -7
  421. package/cjs/lazy/index.js +0 -114
  422. package/cjs/lazy.js.map +0 -7
  423. package/cjs/registry/index.js +0 -209
  424. package/cjs/registry.js.map +0 -7
  425. package/cjs/types/index.js +0 -22
  426. package/cjs/types.js.map +0 -7
  427. package/cjs/utils/index.js +0 -106
  428. package/cjs/utils.js.map +0 -7
  429. package/cjs/validators/index.js +0 -179
  430. package/cjs/validators/index.js.map +0 -7
  431. package/cjs/validators/types/index.js +0 -16
  432. package/cjs/validators/types.js.map +0 -7
  433. package/cjs/validators/utils/afm/index.js +0 -55
  434. package/cjs/validators/utils/afm.js.map +0 -7
  435. package/cjs/validators/utils/amka/index.js +0 -60
  436. package/cjs/validators/utils/amka.js.map +0 -7
  437. package/cjs/validators/utils/date/index.js +0 -161
  438. package/cjs/validators/utils/date.js.map +0 -7
  439. package/cjs/validators/utils/datetime/index.js +0 -245
  440. package/cjs/validators/utils/datetime.js.map +0 -7
  441. package/cjs/validators/utils/email/index.js +0 -39
  442. package/cjs/validators/utils/email.js.map +0 -7
  443. package/cjs/validators/utils/file/index.js +0 -61
  444. package/cjs/validators/utils/file.js.map +0 -7
  445. package/cjs/validators/utils/iban/index.js +0 -142
  446. package/cjs/validators/utils/iban.js.map +0 -7
  447. package/cjs/validators/utils/image/index.js +0 -102
  448. package/cjs/validators/utils/image.js.map +0 -7
  449. package/cjs/validators/utils/index.js +0 -152
  450. package/cjs/validators/utils/index.js.map +0 -7
  451. package/cjs/validators/utils/int/index.js +0 -48
  452. package/cjs/validators/utils/int.js.map +0 -7
  453. package/cjs/validators/utils/number/index.js +0 -44
  454. package/cjs/validators/utils/number.js.map +0 -7
  455. package/cjs/validators/utils/otp/index.js +0 -54
  456. package/cjs/validators/utils/otp.js.map +0 -7
  457. package/cjs/validators/utils/phone/index.js +0 -198
  458. package/cjs/validators/utils/phone.js.map +0 -7
  459. package/cjs/validators/utils/postal_code/index.js +0 -54
  460. package/cjs/validators/utils/postal_code.js.map +0 -7
  461. package/cjs/validators/utils/text_limit/index.js +0 -69
  462. package/cjs/validators/utils/text_limit.js.map +0 -7
  463. package/cjs/validators/utils/uuid4/index.js +0 -46
  464. package/cjs/validators/utils/uuid4.js.map +0 -7
  465. package/hooks/__tests__/utils.spec.d.ts +0 -1
  466. package/hooks/useFieldFocusManager/index.js +0 -116
  467. package/hooks/useFieldFocusManager/package.json +0 -6
  468. package/hooks/useFieldFocusManager.js.map +0 -7
  469. package/hooks/utils/index.js +0 -73
  470. package/hooks/utils/package.json +0 -6
  471. package/hooks/utils.js.map +0 -7
  472. package/index.js.map +0 -7
  473. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +0 -11
  474. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +0 -3
  475. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +0 -3
  476. package/inputs/AutoCompleteInput/index.js.map +0 -7
  477. package/inputs/AutoCompleteInput/package.json +0 -6
  478. package/inputs/Checkboxes/Checkboxes.stories.d.ts +0 -12
  479. package/inputs/Checkboxes/__stories__/Conditional.d.ts +0 -3
  480. package/inputs/Checkboxes/__stories__/Default.d.ts +0 -3
  481. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +0 -3
  482. package/inputs/Checkboxes/index.js.map +0 -7
  483. package/inputs/Checkboxes/package.json +0 -6
  484. package/inputs/DateInput/DateInput.stories.d.ts +0 -14
  485. package/inputs/DateInput/__stories__/Default.d.ts +0 -3
  486. package/inputs/DateInput/__stories__/WithDefaultValue.d.ts +0 -3
  487. package/inputs/DateInput/__stories__/WithInitialValue.d.ts +0 -3
  488. package/inputs/DateInput/__stories__/WithWrongDefaultValue.d.ts +0 -3
  489. package/inputs/DateInput/__stories__/WithWrongInitialValue.d.ts +0 -3
  490. package/inputs/DateInput/index.js.map +0 -7
  491. package/inputs/DateInput/package.json +0 -6
  492. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +0 -14
  493. package/inputs/DateTimeInput/__stories__/Default.d.ts +0 -3
  494. package/inputs/DateTimeInput/__stories__/WithDefaultValue.d.ts +0 -3
  495. package/inputs/DateTimeInput/__stories__/WithInitialValue.d.ts +0 -3
  496. package/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.d.ts +0 -3
  497. package/inputs/DateTimeInput/__stories__/WithWrongInitialValue.d.ts +0 -3
  498. package/inputs/DateTimeInput/index.js.map +0 -7
  499. package/inputs/DateTimeInput/package.json +0 -6
  500. package/inputs/FileInput/FileInput.stories.d.ts +0 -11
  501. package/inputs/FileInput/__stories__/Default.d.ts +0 -3
  502. package/inputs/FileInput/__stories__/WithBorderAndLink.d.ts +0 -3
  503. package/inputs/FileInput/index.js.map +0 -7
  504. package/inputs/FileInput/package.json +0 -6
  505. package/inputs/ImageInput/ImageInput.stories.d.ts +0 -13
  506. package/inputs/ImageInput/__stories__/Default.d.ts +0 -3
  507. package/inputs/ImageInput/__stories__/MaxSize.d.ts +0 -3
  508. package/inputs/ImageInput/__stories__/WithInitialValues.d.ts +0 -3
  509. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +0 -3
  510. package/inputs/ImageInput/__stories__/logo.d/index.js +0 -1
  511. package/inputs/ImageInput/__stories__/logo.d/package.json +0 -6
  512. package/inputs/ImageInput/__stories__/logo.d.js.map +0 -7
  513. package/inputs/ImageInput/index.js.map +0 -7
  514. package/inputs/ImageInput/package.json +0 -6
  515. package/inputs/Input/Input.stories.d.ts +0 -23
  516. package/inputs/Input/__stories__/AFM.d.ts +0 -3
  517. package/inputs/Input/__stories__/AMKA.d.ts +0 -3
  518. package/inputs/Input/__stories__/Boolean.d.ts +0 -3
  519. package/inputs/Input/__stories__/Email.d.ts +0 -3
  520. package/inputs/Input/__stories__/IBAN.d.ts +0 -3
  521. package/inputs/Input/__stories__/Integer.d.ts +0 -3
  522. package/inputs/Input/__stories__/LandlineNumber.d.ts +0 -3
  523. package/inputs/Input/__stories__/MobilePhone.d.ts +0 -3
  524. package/inputs/Input/__stories__/PhoneNumber.d.ts +0 -3
  525. package/inputs/Input/__stories__/PostalCode.d.ts +0 -3
  526. package/inputs/Input/__stories__/Rate.d.ts +0 -3
  527. package/inputs/Input/__stories__/String.d.ts +0 -3
  528. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +0 -3
  529. package/inputs/Input/__stories__/TextWithLimit.d.ts +0 -3
  530. package/inputs/Input/index.js.map +0 -7
  531. package/inputs/Input/package.json +0 -6
  532. package/inputs/Label/Label.stories.d.ts +0 -10
  533. package/inputs/Label/__stories__/Default.d.ts +0 -3
  534. package/inputs/Label/index.js.map +0 -7
  535. package/inputs/Label/package.json +0 -6
  536. package/inputs/OtpInput/OtpInput.stories.d.ts +0 -10
  537. package/inputs/OtpInput/__stories__/Default.d.ts +0 -3
  538. package/inputs/OtpInput/index.js.map +0 -7
  539. package/inputs/OtpInput/package.json +0 -6
  540. package/inputs/Radio/Radio.stories.d.ts +0 -12
  541. package/inputs/Radio/__stories__/Conditional.d.ts +0 -3
  542. package/inputs/Radio/__stories__/Default.d.ts +0 -3
  543. package/inputs/Radio/__stories__/WithDivider.d.ts +0 -3
  544. package/inputs/Radio/index.js.map +0 -7
  545. package/inputs/Radio/package.json +0 -6
  546. package/inputs/Select/Select.stories.d.ts +0 -10
  547. package/inputs/Select/__stories__/Default.d.ts +0 -3
  548. package/inputs/Select/index.js.map +0 -7
  549. package/inputs/Select/package.json +0 -6
  550. package/inputs/index.js.map +0 -7
  551. package/inputs/package.json +0 -6
  552. package/inputs/registry/index.js +0 -86
  553. package/inputs/registry/package.json +0 -6
  554. package/inputs/registry.js.map +0 -7
  555. package/internal/index.js +0 -10
  556. package/internal/package.json +0 -6
  557. package/internal.js.map +0 -7
  558. package/lazy/package.json +0 -6
  559. package/registry/index.js +0 -179
  560. package/registry/package.json +0 -6
  561. package/src/lazy.js +0 -81
  562. package/types/index.js +0 -2
  563. package/types/package.json +0 -6
  564. package/types.js.map +0 -7
  565. package/utils/index.js +0 -82
  566. package/utils/package.json +0 -6
  567. package/utils.js.map +0 -7
  568. package/validators/index.js.map +0 -7
  569. package/validators/package.json +0 -6
  570. package/validators/types/index.js +0 -1
  571. package/validators/types/package.json +0 -6
  572. package/validators/types.js.map +0 -7
  573. package/validators/utils/afm/index.js +0 -31
  574. package/validators/utils/afm/package.json +0 -6
  575. package/validators/utils/afm.js.map +0 -7
  576. package/validators/utils/amka/index.js +0 -36
  577. package/validators/utils/amka/package.json +0 -6
  578. package/validators/utils/amka.js.map +0 -7
  579. package/validators/utils/date/index.js +0 -126
  580. package/validators/utils/date/package.json +0 -6
  581. package/validators/utils/date.js.map +0 -7
  582. package/validators/utils/datetime/index.js +0 -210
  583. package/validators/utils/datetime/package.json +0 -6
  584. package/validators/utils/datetime.js.map +0 -7
  585. package/validators/utils/email/index.js +0 -16
  586. package/validators/utils/email/package.json +0 -6
  587. package/validators/utils/email.js.map +0 -7
  588. package/validators/utils/file/index.js +0 -38
  589. package/validators/utils/file/package.json +0 -6
  590. package/validators/utils/file.js.map +0 -7
  591. package/validators/utils/iban/index.js +0 -118
  592. package/validators/utils/iban/package.json +0 -6
  593. package/validators/utils/iban.js.map +0 -7
  594. package/validators/utils/image/index.js +0 -79
  595. package/validators/utils/image/package.json +0 -6
  596. package/validators/utils/image.js.map +0 -7
  597. package/validators/utils/index.js.map +0 -7
  598. package/validators/utils/int/index.js +0 -24
  599. package/validators/utils/int/package.json +0 -6
  600. package/validators/utils/int.js.map +0 -7
  601. package/validators/utils/number/index.js +0 -20
  602. package/validators/utils/number/package.json +0 -6
  603. package/validators/utils/number.js.map +0 -7
  604. package/validators/utils/otp/index.js +0 -30
  605. package/validators/utils/otp/package.json +0 -6
  606. package/validators/utils/otp.js.map +0 -7
  607. package/validators/utils/package.json +0 -6
  608. package/validators/utils/phone/index.js +0 -172
  609. package/validators/utils/phone/package.json +0 -6
  610. package/validators/utils/phone.js.map +0 -7
  611. package/validators/utils/postal_code/index.js +0 -30
  612. package/validators/utils/postal_code/package.json +0 -6
  613. package/validators/utils/postal_code.js.map +0 -7
  614. package/validators/utils/text_limit/index.js +0 -45
  615. package/validators/utils/text_limit/package.json +0 -6
  616. package/validators/utils/text_limit.js.map +0 -7
  617. package/validators/utils/uuid4/index.js +0 -22
  618. package/validators/utils/uuid4/package.json +0 -6
  619. package/validators/utils/uuid4.js.map +0 -7
  620. package/validators/validators.spec.d.ts +0 -1
  621. package/src/{registry.js → registry.ts} +6 -6
@@ -1,118 +0,0 @@
1
- function validateIban(value, countryCode) {
2
- value = value.replace(/\s/g, "").replace(/-/g, "");
3
- if (value.match(/^[0-9]*$/i)) {
4
- if (value.length !== 25) {
5
- return false;
6
- }
7
- } else {
8
- value = value.toUpperCase();
9
- if (countryCode) {
10
- if (!value.startsWith(countryCode.toUpperCase())) {
11
- return false;
12
- }
13
- if (value.length === ibanCountryCodesLengths[countryCode.toUpperCase()]) {
14
- return true;
15
- }
16
- }
17
- if (value.length !== 27) {
18
- return false;
19
- }
20
- }
21
- return true;
22
- }
23
- const IBAN_VALIDATOR = (field) => {
24
- const countryCode = field?.extra?.country;
25
- return {
26
- name: "iban-validator",
27
- message: "form.error.iban",
28
- test: (value) => {
29
- if (!value) {
30
- return true;
31
- }
32
- return validateIban(value, countryCode);
33
- }
34
- };
35
- };
36
- const ibanCountryCodesLengths = {
37
- AD: 24,
38
- AT: 20,
39
- AZ: 28,
40
- BH: 22,
41
- BY: 28,
42
- BE: 16,
43
- BA: 20,
44
- BR: 29,
45
- BG: 22,
46
- CR: 22,
47
- HR: 21,
48
- CY: 28,
49
- CZ: 24,
50
- DK: 18,
51
- DO: 28,
52
- EG: 29,
53
- SV: 28,
54
- EE: 20,
55
- FO: 18,
56
- FI: 18,
57
- FR: 27,
58
- GE: 22,
59
- DE: 22,
60
- GI: 23,
61
- GR: 27,
62
- GL: 18,
63
- GT: 28,
64
- VA: 22,
65
- HU: 28,
66
- IS: 26,
67
- IQ: 23,
68
- IE: 22,
69
- IL: 23,
70
- IT: 27,
71
- JO: 30,
72
- KZ: 20,
73
- XK: 20,
74
- KW: 30,
75
- LV: 21,
76
- LB: 28,
77
- LI: 21,
78
- LT: 20,
79
- LU: 20,
80
- MT: 31,
81
- MR: 27,
82
- MU: 30,
83
- MD: 24,
84
- MC: 27,
85
- ME: 22,
86
- NL: 18,
87
- MK: 19,
88
- NO: 15,
89
- PK: 24,
90
- PS: 29,
91
- PL: 28,
92
- PT: 25,
93
- QA: 29,
94
- RO: 24,
95
- LC: 32,
96
- SM: 27,
97
- ST: 25,
98
- SA: 24,
99
- RS: 22,
100
- SC: 31,
101
- SK: 24,
102
- SI: 19,
103
- ES: 24,
104
- SE: 24,
105
- CH: 21,
106
- TL: 23,
107
- TN: 24,
108
- TR: 26,
109
- UA: 29,
110
- AE: 23,
111
- GB: 22,
112
- VG: 24
113
- };
114
- export {
115
- IBAN_VALIDATOR,
116
- validateIban
117
- };
118
- //# sourceMappingURL=iban.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/iban/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/iban.ts"],
4
- "sourcesContent": ["import type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\nexport function validateIban(value: string, countryCode: string): boolean {\n value = value.replace(/\\s/g, '').replace(/-/g, '');\n if (value.match(/^[0-9]*$/i)) {\n // this is for greek iban without the country code\n if (value.length !== 25) {\n return false;\n }\n } else {\n value = value.toUpperCase();\n if (countryCode) {\n if (!value.startsWith(countryCode.toUpperCase())) {\n return false;\n }\n if (value.length === ibanCountryCodesLengths[countryCode.toUpperCase()]) {\n return true;\n }\n }\n if (value.length !== 27) {\n // this is for greek iban\n return false;\n }\n }\n return true;\n}\n\nexport const IBAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n const countryCode = field?.extra?.country;\n return {\n name: 'iban-validator',\n message: 'form.error.iban',\n test: (value: string): boolean => {\n if (!value) {\n return true;\n }\n return validateIban(value, countryCode);\n },\n };\n};\n\nconst ibanCountryCodesLengths = {\n AD: 24,\n AT: 20,\n AZ: 28,\n BH: 22,\n BY: 28,\n BE: 16,\n BA: 20,\n BR: 29,\n BG: 22,\n CR: 22,\n HR: 21,\n CY: 28,\n CZ: 24,\n DK: 18,\n DO: 28,\n EG: 29,\n SV: 28,\n EE: 20,\n FO: 18,\n FI: 18,\n FR: 27,\n GE: 22,\n DE: 22,\n GI: 23,\n GR: 27,\n GL: 18,\n GT: 28,\n VA: 22,\n HU: 28,\n IS: 26,\n IQ: 23,\n IE: 22,\n IL: 23,\n IT: 27,\n JO: 30,\n KZ: 20,\n XK: 20,\n KW: 30,\n LV: 21,\n LB: 28,\n LI: 21,\n LT: 20,\n LU: 20,\n MT: 31,\n MR: 27,\n MU: 30,\n MD: 24,\n MC: 27,\n ME: 22,\n NL: 18,\n MK: 19,\n NO: 15,\n PK: 24,\n PS: 29,\n PL: 28,\n PT: 25,\n QA: 29,\n RO: 24,\n LC: 32,\n SM: 27,\n ST: 25,\n SA: 24,\n RS: 22,\n SC: 31,\n SK: 24,\n SI: 19,\n ES: 24,\n SE: 24,\n CH: 21,\n TL: 23,\n TN: 24,\n TR: 26,\n UA: 29,\n AE: 23,\n GB: 22,\n VG: 24,\n};\n"],
5
- "mappings": "AAEO,SAAS,aAAa,OAAe,aAA8B;AACxE,UAAQ,MAAM,QAAQ,OAAO,EAAE,EAAE,QAAQ,MAAM,EAAE;AACjD,MAAI,MAAM,MAAM,WAAW,GAAG;AAE5B,QAAI,MAAM,WAAW,IAAI;AACvB,aAAO;AAAA,IACT;AAAA,EACF,OAAO;AACL,YAAQ,MAAM,YAAY;AAC1B,QAAI,aAAa;AACf,UAAI,CAAC,MAAM,WAAW,YAAY,YAAY,CAAC,GAAG;AAChD,eAAO;AAAA,MACT;AACA,UAAI,MAAM,WAAW,wBAAwB,YAAY,YAAY,CAAC,GAAG;AACvE,eAAO;AAAA,MACT;AAAA,IACF;AACA,QAAI,MAAM,WAAW,IAAI;AAEvB,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;AAEO,MAAM,iBAAiB,CAAC,UAAsC;AACnE,QAAM,cAAc,OAAO,OAAO;AAClC,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA,MACT;AACA,aAAO,aAAa,OAAO,WAAW;AAAA,IACxC;AAAA,EACF;AACF;AAEA,MAAM,0BAA0B;AAAA,EAC9B,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;",
6
- "names": []
7
- }
@@ -1,79 +0,0 @@
1
- const DEFAULT_IMAGE_MAX_HEIGHT_SIZE = 2e3;
2
- const DEFAULT_IMAGE_MAX_WIDTH_SIZE = 2e3;
3
- const DEFAULT_IMAGE_MIN_HEIGHT_SIZE = 100;
4
- const DEFAULT_IMAGE_MIN_WIDTH_SIZE = 100;
5
- function getImageDimensions(file) {
6
- return new Promise((resolve, reject) => {
7
- const reader = new FileReader();
8
- reader.onload = (event) => {
9
- const img = new Image();
10
- img.onload = () => {
11
- resolve({ width: img.width, height: img.height });
12
- };
13
- img.onerror = reject;
14
- const result = event?.target?.result;
15
- if (result && typeof result === "string") {
16
- img.src = result;
17
- } else {
18
- reject(new Error("Invalid file format"));
19
- }
20
- };
21
- reader.onerror = reject;
22
- reader.readAsDataURL(file);
23
- });
24
- }
25
- const IMAGE_DIMENSION_VALIDATOR = (field) => ({
26
- name: "image-dimension-validator",
27
- message: (value) => {
28
- const minHeight = field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;
29
- const minWidth = field?.extra?.limit?.minWidth || DEFAULT_IMAGE_MIN_WIDTH_SIZE;
30
- const maxHeight = field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;
31
- const maxWidth = field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;
32
- if (!value || value.length === 0) {
33
- return {
34
- name: "image-validator",
35
- message: "form.error.required"
36
- };
37
- } else {
38
- return {
39
- key: "form.error.image.image_dimension_size",
40
- context: {
41
- maxHeight,
42
- maxWidth,
43
- minHeight,
44
- minWidth
45
- }
46
- };
47
- }
48
- },
49
- test: async (value) => {
50
- if (!value || value.length === 0) {
51
- return true;
52
- }
53
- const file = value[0];
54
- const { width, height } = await getImageDimensions(file);
55
- const maxHeight = field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;
56
- const maxWidth = field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;
57
- const minHeight = field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;
58
- const minWidth = field?.extra?.limit?.minWidth || DEFAULT_IMAGE_MIN_WIDTH_SIZE;
59
- if (!file) {
60
- return true;
61
- }
62
- try {
63
- if (height > maxHeight || width > maxWidth) {
64
- return false;
65
- }
66
- if (height < minHeight || width < minWidth) {
67
- return false;
68
- }
69
- return true;
70
- } catch (error) {
71
- console.error("Error getting image dimensions:", error);
72
- return false;
73
- }
74
- }
75
- });
76
- export {
77
- IMAGE_DIMENSION_VALIDATOR
78
- };
79
- //# sourceMappingURL=image.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/image/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/image.ts"],
4
- "sourcesContent": ["import type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\n\nconst DEFAULT_IMAGE_MAX_HEIGHT_SIZE = 2000;\nconst DEFAULT_IMAGE_MAX_WIDTH_SIZE = 2000;\nconst DEFAULT_IMAGE_MIN_HEIGHT_SIZE = 100;\nconst DEFAULT_IMAGE_MIN_WIDTH_SIZE = 100;\n\nfunction getImageDimensions(\n file: File\n): Promise<{ width: number; height: number }> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onload = (event) => {\n const img = new Image();\n img.onload = () => {\n resolve({ width: img.width, height: img.height });\n };\n img.onerror = reject;\n const result = event?.target?.result;\n if (result && typeof result === 'string') {\n img.src = result;\n } else {\n reject(new Error('Invalid file format'));\n }\n };\n reader.onerror = reject;\n reader.readAsDataURL(file);\n });\n}\n\nexport const IMAGE_DIMENSION_VALIDATOR = (\n field: FieldSpec\n): ValidatorSchema => ({\n name: 'image-dimension-validator',\n message: (value: any) => {\n const minHeight =\n field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;\n const minWidth =\n field?.extra?.limit?.minWidth || DEFAULT_IMAGE_MIN_WIDTH_SIZE;\n const maxHeight =\n field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;\n const maxWidth =\n field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;\n if (!value || value.length === 0) {\n return {\n name: 'image-validator',\n message: 'form.error.required',\n };\n } else {\n return {\n key: 'form.error.image.image_dimension_size',\n context: {\n maxHeight: maxHeight,\n maxWidth: maxWidth,\n minHeight: minHeight,\n minWidth: minWidth,\n },\n };\n }\n },\n test: async (value: File[]): Promise<boolean> => {\n if (!value || value.length === 0) {\n return true;\n }\n const file = value[0];\n const { width, height } = await getImageDimensions(file);\n const maxHeight =\n field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;\n const maxWidth =\n field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;\n const minHeight =\n field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;\n const minWidth =\n field?.extra?.limit?.minWidth || DEFAULT_IMAGE_MIN_WIDTH_SIZE;\n if (!file) {\n return true;\n }\n try {\n if (height > maxHeight || width > maxWidth) {\n return false;\n }\n if (height < minHeight || width < minWidth) {\n return false;\n }\n return true;\n } catch (error) {\n console.error('Error getting image dimensions:', error);\n return false; // Return false in case of an error.\n }\n },\n});\n"],
5
- "mappings": "AAGA,MAAM,gCAAgC;AACtC,MAAM,+BAA+B;AACrC,MAAM,gCAAgC;AACtC,MAAM,+BAA+B;AAErC,SAAS,mBACP,MAC4C;AAC5C,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,UAAM,SAAS,IAAI,WAAW;AAC9B,WAAO,SAAS,CAAC,UAAU;AACzB,YAAM,MAAM,IAAI,MAAM;AACtB,UAAI,SAAS,MAAM;AACjB,gBAAQ,EAAE,OAAO,IAAI,OAAO,QAAQ,IAAI,OAAO,CAAC;AAAA,MAClD;AACA,UAAI,UAAU;AACd,YAAM,SAAS,OAAO,QAAQ;AAC9B,UAAI,UAAU,OAAO,WAAW,UAAU;AACxC,YAAI,MAAM;AAAA,MACZ,OAAO;AACL,eAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,MACzC;AAAA,IACF;AACA,WAAO,UAAU;AACjB,WAAO,cAAc,IAAI;AAAA,EAC3B,CAAC;AACH;AAEO,MAAM,4BAA4B,CACvC,WACqB;AAAA,EACrB,MAAM;AAAA,EACN,SAAS,CAAC,UAAe;AACvB,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC,aAAO;AAAA,QACL,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,IACF,OAAO;AACL,aAAO;AAAA,QACL,KAAK;AAAA,QACL,SAAS;AAAA,UACP;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EACA,MAAM,OAAO,UAAoC;AAC/C,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC,aAAO;AAAA,IACT;AACA,UAAM,OAAO,MAAM,CAAC;AACpB,UAAM,EAAE,OAAO,OAAO,IAAI,MAAM,mBAAmB,IAAI;AACvD,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,QAAI,CAAC,MAAM;AACT,aAAO;AAAA,IACT;AACA,QAAI;AACF,UAAI,SAAS,aAAa,QAAQ,UAAU;AAC1C,eAAO;AAAA,MACT;AACA,UAAI,SAAS,aAAa,QAAQ,UAAU;AAC1C,eAAO;AAAA,MACT;AACA,aAAO;AAAA,IACT,SAAS,OAAO;AACd,cAAQ,MAAM,mCAAmC,KAAK;AACtD,aAAO;AAAA,IACT;AAAA,EACF;AACF;",
6
- "names": []
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/index.ts"],
4
- "sourcesContent": ["import * as yup from 'yup';\nimport type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport * from '@digigov/form/validators/utils/afm';\nexport * from '@digigov/form/validators/utils/amka';\nexport * from '@digigov/form/validators/utils/file';\nexport * from '@digigov/form/validators/utils/iban';\nexport * from '@digigov/form/validators/utils/otp';\nexport * from '@digigov/form/validators/utils/image';\nexport * from '@digigov/form/validators/utils/phone';\nexport * from '@digigov/form/validators/utils/postal_code';\nexport * from '@digigov/form/validators/utils/uuid4';\nexport * from '@digigov/form/validators/utils/text_limit';\nexport * from '@digigov/form/validators/utils/date';\nexport * from '@digigov/form/validators/utils/datetime';\n\nexport function getYupField(field: FieldSpec, yupTypeMap: Record<string, any>) {\n const yupField = yupTypeMap[field?.type || 'string'] || yupTypeMap['string'];\n return yupField(field);\n}\nexport function computeShape(\n fields: FieldSpec[],\n yupTypeMap: Record<string, ValidatorSchema>,\n validatorRegistry: Record<string, ValidatorSchema[]> | undefined\n) {\n const fieldSchemas = {};\n const objectFields: Record<string, FieldSpec[]> = {};\n fields.forEach((field) => {\n let yupField = getYupField(field, yupTypeMap);\n if (field.condition) {\n for (const key in field.condition) {\n let then: any, otherwise: any;\n if (field.condition[key].then) {\n if (field.condition[key].then?.required === false) {\n then = yupField.nullable();\n } else if (field.condition[key].then?.required === true) {\n then = yupField.nullable().required('form.error.required');\n }\n }\n if (field.condition[key].else) {\n if (field.condition[key].else?.required === false) {\n otherwise = yupField.nullable();\n } else if (field.condition[key].else?.required === true) {\n otherwise = yupField.nullable().required('form.error.required');\n }\n }\n if (then || otherwise) {\n yupField = yupField.when(key, {\n is: (val) => {\n //@ts-ignore\n const is = field.condition[key].is;\n if (is === val || (Array.isArray(val) && val.includes(is))) {\n return true;\n } else {\n return false;\n }\n },\n then,\n otherwise,\n });\n }\n }\n } else if (field.required) {\n yupField = yupField.nullable().required('form.error.required');\n }\n if (validatorRegistry && field.type && validatorRegistry[field.type]) {\n if (Array.isArray(validatorRegistry[field.type])) {\n validatorRegistry[field.type].forEach((validator: any) => {\n yupField = yupField.test(validator);\n });\n } else {\n yupField = yupField.test(validatorRegistry[field.type]);\n }\n }\n if (field.validators) {\n field.validators.forEach((validator) => {\n yupField = yupField.test(validator);\n });\n }\n fieldSchemas[field.key] = yupField;\n });\n for (const objectKey in objectFields) {\n fieldSchemas[objectKey] = getYupObjectShape(\n objectFields[objectKey],\n yupTypeMap,\n validatorRegistry\n );\n }\n return fieldSchemas;\n}\n\nexport function getYupObjectShape(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fields: FieldSpec[] | any,\n yupTypeMap: Record<string, any>,\n validatorRegistry?: Record<string, ValidatorSchema[]>\n) {\n if (!fields.current) {\n const fieldSchemas = computeShape(fields, yupTypeMap, validatorRegistry);\n return yup.object().shape(fieldSchemas);\n }\n\n return yup.lazy(function () {\n const fieldSchemas = computeShape(\n Object.values(fields.current).filter(\n (f: FieldSpec) => !f.key.includes('.')\n ) as FieldSpec[],\n yupTypeMap,\n validatorRegistry\n );\n return yup.object().shape(fieldSchemas);\n });\n}\n"],
5
- "mappings": "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",
6
- "names": []
7
- }
@@ -1,24 +0,0 @@
1
- function validateIntNumber(number) {
2
- if (number === void 0) {
3
- return false;
4
- } else {
5
- return Number.isInteger(number) && Number(number) > 0;
6
- }
7
- }
8
- const INT_VALIDATOR = () => {
9
- return {
10
- name: "int-validator",
11
- message: "form.error.positive_integer_number",
12
- test: (value) => {
13
- if (value === void 0) {
14
- return true;
15
- }
16
- return validateIntNumber(value);
17
- }
18
- };
19
- };
20
- export {
21
- INT_VALIDATOR,
22
- validateIntNumber
23
- };
24
- //# sourceMappingURL=int.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/int/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/int.ts"],
4
- "sourcesContent": ["import type { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport function validateIntNumber(number: number): boolean {\n if (number === undefined) {\n return false;\n } else {\n return Number.isInteger(number) && Number(number) > 0;\n }\n}\n\nexport const INT_VALIDATOR = (): ValidatorSchema => {\n return {\n name: 'int-validator',\n message: 'form.error.positive_integer_number',\n test: (value: number): boolean => {\n if (value === undefined) {\n return true;\n }\n return validateIntNumber(value);\n },\n };\n};\n"],
5
- "mappings": "AAEO,SAAS,kBAAkB,QAAyB;AACzD,MAAI,WAAW,QAAW;AACxB,WAAO;AAAA,EACT,OAAO;AACL,WAAO,OAAO,UAAU,MAAM,KAAK,OAAO,MAAM,IAAI;AAAA,EACtD;AACF;AAEO,MAAM,gBAAgB,MAAuB;AAClD,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,UAAU,QAAW;AACvB,eAAO;AAAA,MACT;AACA,aAAO,kBAAkB,KAAK;AAAA,IAChC;AAAA,EACF;AACF;",
6
- "names": []
7
- }
@@ -1,20 +0,0 @@
1
- function validateNumber(number) {
2
- return !Number.isNaN(number);
3
- }
4
- const NUMBER_VALIDATOR = () => {
5
- return {
6
- name: "number-validator",
7
- message: "form.error.number",
8
- test: (value) => {
9
- if (value === void 0) {
10
- return true;
11
- }
12
- return validateNumber(value);
13
- }
14
- };
15
- };
16
- export {
17
- NUMBER_VALIDATOR,
18
- validateNumber
19
- };
20
- //# sourceMappingURL=number.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/number/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/number.ts"],
4
- "sourcesContent": ["import type { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport function validateNumber(number: number): boolean {\n return !Number.isNaN(number);\n}\n\nexport const NUMBER_VALIDATOR = (): ValidatorSchema => {\n return {\n name: 'number-validator',\n message: 'form.error.number',\n test: (value: number): boolean => {\n if (value === undefined) {\n return true;\n }\n return validateNumber(value);\n },\n };\n};\n"],
5
- "mappings": "AAEO,SAAS,eAAe,QAAyB;AACtD,SAAO,CAAC,OAAO,MAAM,MAAM;AAC7B;AAEO,MAAM,mBAAmB,MAAuB;AACrD,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,UAAU,QAAW;AACvB,eAAO;AAAA,MACT;AACA,aAAO,eAAe,KAAK;AAAA,IAC7B;AAAA,EACF;AACF;",
6
- "names": []
7
- }
@@ -1,30 +0,0 @@
1
- function validateOtp(value, maxLength) {
2
- if (value.length === maxLength) {
3
- return true;
4
- } else {
5
- return false;
6
- }
7
- }
8
- const OTP_VALIDATOR = (field) => {
9
- const maxLength = field?.maxLength;
10
- return {
11
- name: "otp-validator",
12
- message: {
13
- key: "form.error.otp.less_than",
14
- context: {
15
- maxLength: field?.maxLength
16
- }
17
- },
18
- test: (value) => {
19
- if (!value) {
20
- return true;
21
- }
22
- return validateOtp(value, maxLength);
23
- }
24
- };
25
- };
26
- export {
27
- OTP_VALIDATOR,
28
- validateOtp
29
- };
30
- //# sourceMappingURL=otp.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/otp/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/otp.ts"],
4
- "sourcesContent": ["import type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\nexport function validateOtp(value: string, maxLength: number): boolean {\n if (value.length === maxLength) {\n return true;\n } else {\n return false;\n }\n}\n\nexport const OTP_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n const maxLength = field?.maxLength;\n return {\n name: 'otp-validator',\n message: {\n key: 'form.error.otp.less_than',\n context: {\n maxLength: field?.maxLength,\n },\n },\n test: (value: string): boolean => {\n if (!value) {\n return true;\n }\n return validateOtp(value, maxLength as number);\n },\n };\n};\n"],
5
- "mappings": "AAEO,SAAS,YAAY,OAAe,WAA4B;AACrE,MAAI,MAAM,WAAW,WAAW;AAC9B,WAAO;AAAA,EACT,OAAO;AACL,WAAO;AAAA,EACT;AACF;AAEO,MAAM,gBAAgB,CAAC,UAAsC;AAClE,QAAM,YAAY,OAAO;AACzB,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,MACP,KAAK;AAAA,MACL,SAAS;AAAA,QACP,WAAW,OAAO;AAAA,MACpB;AAAA,IACF;AAAA,IACA,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA,MACT;AACA,aAAO,YAAY,OAAO,SAAmB;AAAA,IAC/C;AAAA,EACF;AACF;",
6
- "names": []
7
- }
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../cjs/validators/utils/index.js"
6
- }
@@ -1,172 +0,0 @@
1
- const countryPhoneData = {
2
- GR: [
3
- "30",
4
- "00",
5
- "5005000\\d{3}|8\\d{9,11}|(?:[269]\\d|70)\\d{8}",
6
- [10, 11, 12],
7
- [
8
- ["(\\d{2})(\\d{4})(\\d{4})", "$1 $2 $3", ["21|7"]],
9
- [
10
- "(\\d{4})(\\d{6})",
11
- "$1 $2",
12
- ["2(?:2|3[2-57-9]|4[2-469]|5[2-59]|6[2-9]|7[2-69]|8[2-49])|5"]
13
- ],
14
- ["(\\d{3})(\\d{3})(\\d{4})", "$1 $2 $3", ["[2689]"]],
15
- ["(\\d{3})(\\d{3,4})(\\d{5})", "$1 $2 $3", ["8"]]
16
- ],
17
- 0,
18
- 0,
19
- 0,
20
- 0,
21
- 0,
22
- 0,
23
- [
24
- [
25
- "2(?:1\\d\\d|2(?:2[1-46-9]|[36][1-8]|4[1-7]|5[1-4]|7[1-5]|[89][1-9])|3(?:1\\d|2[1-57]|[35][1-3]|4[13]|7[1-7]|8[124-6]|9[1-79])|4(?:1\\d|2[1-8]|3[1-4]|4[13-5]|6[1-578]|9[1-5])|5(?:1\\d|[29][1-4]|3[1-5]|4[124]|5[1-6])|6(?:1\\d|[269][1-6]|3[1245]|4[1-7]|5[13-9]|7[14]|8[1-5])|7(?:1\\d|2[1-5]|3[1-6]|4[1-7]|5[1-57]|6[135]|9[125-7])|8(?:1\\d|2[1-5]|[34][1-4]|9[1-57]))\\d{6}",
26
- [10]
27
- ],
28
- ["68[57-9]\\d{7}|(?:69|94)\\d{8}", [10]],
29
- ["800\\d{7,9}"],
30
- ["90[19]\\d{7}", [10]],
31
- ["70\\d{8}", [10]],
32
- 0,
33
- ["5005000\\d{3}", [10]],
34
- 0,
35
- 0,
36
- ["8(?:0[16]|12|[27]5|50)\\d{7}", [10]]
37
- ]
38
- ]
39
- };
40
- function expandPhoneNumberStructure(compressed) {
41
- const countries = Object.keys(compressed);
42
- const expanded = {};
43
- for (const country of countries) {
44
- expanded[country] = {
45
- fixedLine: {
46
- possibleLengths: {
47
- _national: compressed[country][3].map(String)
48
- },
49
- nationalNumberPattern: compressed[country][11][0][0]
50
- },
51
- mobile: {
52
- nationalNumberPattern: compressed[country][11][1][0]
53
- },
54
- tollFree: {
55
- nationalNumberPattern: compressed[country][11][2][0]
56
- },
57
- premiumRate: {
58
- nationalNumberPattern: compressed[country][11][3][0]
59
- },
60
- sharedCost: {
61
- nationalNumberPattern: compressed[country][11][9][0]
62
- },
63
- personalNumber: {
64
- nationalNumberPattern: compressed[country][11][4][0]
65
- },
66
- uan: {
67
- nationalNumberPattern: compressed[country][11][6][0]
68
- },
69
- id: country,
70
- countryCode: compressed[country][0],
71
- internationalPrefix: compressed[country][1]
72
- };
73
- }
74
- return expanded;
75
- }
76
- const PHONENUMBER_SPEC = expandPhoneNumberStructure(countryPhoneData);
77
- function discoverPhoneType(phoneNumber, config) {
78
- const cleanNumber = phoneNumber.replace(/\D/g, "").replace(/\s/g, "").replace(/^\+/, "").replace(new RegExp("^" + config.internationalPrefix, ""), "").replace(new RegExp("^" + config.countryCode, ""), "");
79
- const categories = {
80
- landline: config.fixedLine,
81
- mobile: config.mobile,
82
- "toll-free": config.tollFree,
83
- "premium-rate": config.premiumRate
84
- };
85
- for (const [categoryName, categoryDetails] of Object.entries(categories)) {
86
- const pattern = new RegExp(
87
- "^(" + categoryDetails.nationalNumberPattern.replace(/\s/g, "") + ")$",
88
- ""
89
- );
90
- if (cleanNumber.match(pattern)) {
91
- return categoryName;
92
- }
93
- }
94
- return "unknown";
95
- }
96
- function getNumberType(phoneNumber, country) {
97
- const spec = PHONENUMBER_SPEC[country.toUpperCase()];
98
- if (!spec) {
99
- throw new Error(`Country ${country} is not supported`);
100
- }
101
- const type = discoverPhoneType(phoneNumber, spec);
102
- return type;
103
- }
104
- function isPhoneNumberValid(phoneNumber, countries, types = ["mobile", "landline"]) {
105
- return countries.some((country) => {
106
- const numberType = getNumberType(phoneNumber, country);
107
- if (numberType && types.includes(numberType)) {
108
- return true;
109
- }
110
- return false;
111
- });
112
- }
113
- function isNumberOfType(phoneNumber, country, type) {
114
- const numberType = getNumberType(phoneNumber, country);
115
- if (numberType === type) {
116
- return true;
117
- }
118
- return false;
119
- }
120
- function validatePhoneNumber(phoneNumber, countries = ["gr"], typeOfPhoneNumber) {
121
- if (!countries || countries.length === 0) {
122
- return true;
123
- }
124
- return isPhoneNumberValid(
125
- phoneNumber,
126
- countries,
127
- typeOfPhoneNumber ? [typeOfPhoneNumber] : void 0
128
- );
129
- }
130
- function validateMobile(value) {
131
- return isNumberOfType(value, "gr", "mobile");
132
- }
133
- const MOBILE_PHONE_VALIDATOR = {
134
- name: "mobile-phone-validator",
135
- message: "form.error.mobile_phone",
136
- test: (value) => {
137
- if (value) {
138
- return validateMobile(value);
139
- }
140
- return true;
141
- }
142
- };
143
- const PHONE_NUMBER_VALIDATOR = (field) => {
144
- const countryCodes = field?.extra?.countries;
145
- const typeOfPhone = field?.extra?.phoneType;
146
- return {
147
- name: "phone-number-validator",
148
- message: () => {
149
- if (typeOfPhone === "mobile") {
150
- return "form.error.mobile_phone";
151
- }
152
- if (typeOfPhone === "landline") {
153
- return "form.error.landline";
154
- } else {
155
- return "form.error.phone_number";
156
- }
157
- },
158
- test: (value) => {
159
- if (!value) {
160
- return true;
161
- }
162
- return validatePhoneNumber(value, countryCodes, typeOfPhone);
163
- }
164
- };
165
- };
166
- export {
167
- MOBILE_PHONE_VALIDATOR,
168
- PHONE_NUMBER_VALIDATOR,
169
- discoverPhoneType,
170
- validatePhoneNumber
171
- };
172
- //# sourceMappingURL=phone.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/phone/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/phone.ts"],
4
- "sourcesContent": ["import type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport type PhoneNumberType = 'landline' | 'mobile' | null;\n// add more countries from here libphonenumber-js/metadata.full.json\nconst countryPhoneData = {\n GR: [\n '30',\n '00',\n '5005000\\\\d{3}|8\\\\d{9,11}|(?:[269]\\\\d|70)\\\\d{8}',\n [10, 11, 12],\n [\n ['(\\\\d{2})(\\\\d{4})(\\\\d{4})', '$1 $2 $3', ['21|7']],\n [\n '(\\\\d{4})(\\\\d{6})',\n '$1 $2',\n ['2(?:2|3[2-57-9]|4[2-469]|5[2-59]|6[2-9]|7[2-69]|8[2-49])|5'],\n ],\n ['(\\\\d{3})(\\\\d{3})(\\\\d{4})', '$1 $2 $3', ['[2689]']],\n ['(\\\\d{3})(\\\\d{3,4})(\\\\d{5})', '$1 $2 $3', ['8']],\n ],\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n [\n [\n '2(?:1\\\\d\\\\d|2(?:2[1-46-9]|[36][1-8]|4[1-7]|5[1-4]|7[1-5]|[89][1-9])|3(?:1\\\\d|2[1-57]|[35][1-3]|4[13]|7[1-7]|8[124-6]|9[1-79])|4(?:1\\\\d|2[1-8]|3[1-4]|4[13-5]|6[1-578]|9[1-5])|5(?:1\\\\d|[29][1-4]|3[1-5]|4[124]|5[1-6])|6(?:1\\\\d|[269][1-6]|3[1245]|4[1-7]|5[13-9]|7[14]|8[1-5])|7(?:1\\\\d|2[1-5]|3[1-6]|4[1-7]|5[1-57]|6[135]|9[125-7])|8(?:1\\\\d|2[1-5]|[34][1-4]|9[1-57]))\\\\d{6}',\n [10],\n ],\n ['68[57-9]\\\\d{7}|(?:69|94)\\\\d{8}', [10]],\n ['800\\\\d{7,9}'],\n ['90[19]\\\\d{7}', [10]],\n ['70\\\\d{8}', [10]],\n 0,\n ['5005000\\\\d{3}', [10]],\n 0,\n 0,\n ['8(?:0[16]|12|[27]5|50)\\\\d{7}', [10]],\n ],\n ],\n};\n\nfunction expandPhoneNumberStructure(compressed) {\n const countries = Object.keys(compressed);\n const expanded: any = {};\n for (const country of countries) {\n expanded[country] = {\n fixedLine: {\n possibleLengths: {\n _national: compressed[country][3].map(String),\n },\n nationalNumberPattern: compressed[country][11][0][0],\n },\n mobile: {\n nationalNumberPattern: compressed[country][11][1][0],\n },\n tollFree: {\n nationalNumberPattern: compressed[country][11][2][0],\n },\n premiumRate: {\n nationalNumberPattern: compressed[country][11][3][0],\n },\n sharedCost: {\n nationalNumberPattern: compressed[country][11][9][0],\n },\n personalNumber: {\n nationalNumberPattern: compressed[country][11][4][0],\n },\n uan: {\n nationalNumberPattern: compressed[country][11][6][0],\n },\n id: country,\n countryCode: compressed[country][0],\n internationalPrefix: compressed[country][1],\n };\n }\n return expanded;\n}\nconst PHONENUMBER_SPEC = expandPhoneNumberStructure(countryPhoneData);\nexport function discoverPhoneType(phoneNumber: string, config: any): string {\n const cleanNumber = phoneNumber\n .replace(/\\D/g, '')\n .replace(/\\s/g, '')\n .replace(/^\\+/, '')\n .replace(new RegExp('^' + config.internationalPrefix, ''), '')\n .replace(new RegExp('^' + config.countryCode, ''), '');\n const categories = {\n landline: config.fixedLine,\n mobile: config.mobile,\n 'toll-free': config.tollFree,\n 'premium-rate': config.premiumRate,\n };\n\n for (const [categoryName, categoryDetails] of Object.entries(categories)) {\n const pattern = new RegExp(\n '^(' + categoryDetails.nationalNumberPattern.replace(/\\s/g, '') + ')$',\n ''\n );\n if (cleanNumber.match(pattern)) {\n return categoryName; // Returns the category name if the number matches the pattern\n }\n }\n\n // If no category matches, return 'Unknown'\n return 'unknown';\n}\nfunction getNumberType(phoneNumber: string, country: string) {\n const spec = PHONENUMBER_SPEC[country.toUpperCase()];\n if (!spec) {\n throw new Error(`Country ${country} is not supported`);\n }\n const type = discoverPhoneType(phoneNumber, spec);\n return type;\n}\n\nfunction isPhoneNumberValid(\n phoneNumber: string,\n countries: string[],\n types = ['mobile', 'landline']\n) {\n return countries.some((country) => {\n const numberType = getNumberType(phoneNumber, country);\n if (numberType && types.includes(numberType)) {\n return true;\n }\n return false;\n });\n}\nfunction isNumberOfType(phoneNumber: string, country: string, type: string) {\n const numberType = getNumberType(phoneNumber, country);\n if (numberType === type) {\n return true;\n }\n return false;\n}\nexport function validatePhoneNumber(\n phoneNumber: string,\n countries: string[] = ['gr'],\n typeOfPhoneNumber?: PhoneNumberType\n): boolean {\n if (!countries || countries.length === 0) {\n return true;\n }\n return isPhoneNumberValid(\n phoneNumber,\n countries,\n typeOfPhoneNumber ? [typeOfPhoneNumber] : undefined\n );\n}\n\nfunction validateMobile(value): boolean {\n return isNumberOfType(value, 'gr', 'mobile');\n}\n\nexport const MOBILE_PHONE_VALIDATOR = {\n name: 'mobile-phone-validator',\n message: 'form.error.mobile_phone',\n test: (value): boolean => {\n if (value) {\n return validateMobile(value);\n }\n return true;\n },\n};\n\nexport const PHONE_NUMBER_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n const countryCodes = field?.extra?.countries;\n const typeOfPhone: PhoneNumberType | null = field?.extra?.phoneType;\n return {\n name: 'phone-number-validator',\n message: (): string => {\n if (typeOfPhone === 'mobile') {\n return 'form.error.mobile_phone';\n }\n if (typeOfPhone === 'landline') {\n return 'form.error.landline';\n } else {\n return 'form.error.phone_number';\n }\n },\n test: (value: string): boolean => {\n if (!value) {\n return true;\n }\n return validatePhoneNumber(value, countryCodes, typeOfPhone);\n },\n };\n};\n"],
5
- "mappings": "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",
6
- "names": []
7
- }
@@ -1,30 +0,0 @@
1
- const CODE_REGEX = /^[12345678][0-9]{4}$/;
2
- function validatePostalCode(number, countries) {
3
- if (!countries) {
4
- return false;
5
- } else {
6
- if (countries.length === 1 && countries[0].toUpperCase() === "GR") {
7
- return CODE_REGEX.test(number);
8
- } else {
9
- return true;
10
- }
11
- }
12
- }
13
- const POSTALCODE_VALIDATOR = (field) => {
14
- const countryCode = field?.extra?.countries;
15
- return {
16
- name: "postal-code-validator",
17
- message: "form.error.postalCode",
18
- test: (value) => {
19
- if (!value) {
20
- return true;
21
- }
22
- return validatePostalCode(value, countryCode);
23
- }
24
- };
25
- };
26
- export {
27
- POSTALCODE_VALIDATOR,
28
- validatePostalCode
29
- };
30
- //# sourceMappingURL=postal_code.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "sideEffects": false,
3
- "module": "./index.js",
4
- "types": "./index.d.ts",
5
- "main": "../../../cjs/validators/utils/postal_code/index.js"
6
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/validators/utils/postal_code.ts"],
4
- "sourcesContent": ["import type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\n\nconst CODE_REGEX = /^[12345678][0-9]{4}$/;\nexport function validatePostalCode(\n number: string,\n countries: string[]\n): boolean {\n if (!countries) {\n return false;\n } else {\n if (countries.length === 1 && countries[0].toUpperCase() === 'GR') {\n // Greek postal code must be 5 digits long and shouldn't start with 0 or 9.\n return CODE_REGEX.test(number);\n } else {\n return true;\n }\n }\n}\n\nexport const POSTALCODE_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n const countryCode = field?.extra?.countries;\n return {\n name: 'postal-code-validator',\n message: 'form.error.postalCode',\n test: (value: string): boolean => {\n if (!value) {\n return true;\n }\n return validatePostalCode(value, countryCode);\n },\n };\n};\n"],
5
- "mappings": "AAGA,MAAM,aAAa;AACZ,SAAS,mBACd,QACA,WACS;AACT,MAAI,CAAC,WAAW;AACd,WAAO;AAAA,EACT,OAAO;AACL,QAAI,UAAU,WAAW,KAAK,UAAU,CAAC,EAAE,YAAY,MAAM,MAAM;AAEjE,aAAO,WAAW,KAAK,MAAM;AAAA,IAC/B,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAEO,MAAM,uBAAuB,CAAC,UAAsC;AACzE,QAAM,cAAc,OAAO,OAAO;AAClC,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA,MACT;AACA,aAAO,mBAAmB,OAAO,WAAW;AAAA,IAC9C;AAAA,EACF;AACF;",
6
- "names": []
7
- }