@incodetech/core 2.0.0-rc.0 → 2.0.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 (178) hide show
  1. package/package.json +3 -3
  2. package/dist/Actor-CI32dTbG.d.ts +0 -2
  3. package/dist/BaseWasmProvider-C_DLEI40.esm.js +0 -1118
  4. package/dist/BrowserStorageProvider-CuOW1Er2.esm.js +0 -55
  5. package/dist/BrowserTimerProvider-DhNc_x02.esm.js +0 -22
  6. package/dist/ITimerCapability-C67ZRskg.esm.js +0 -7
  7. package/dist/IpifyProvider-D7jx52AL.esm.js +0 -139
  8. package/dist/Manager-C8PrhBOx.d.ts +0 -19
  9. package/dist/MotionSensorProvider-4v7xkqAp.esm.js +0 -254
  10. package/dist/OpenViduRecordingProvider-CMu6XVdc.esm.js +0 -87
  11. package/dist/StateMachine-BCQrZJhf.d.ts +0 -2
  12. package/dist/WasmUtilProvider-j98OJf-S.esm.js +0 -114
  13. package/dist/addressSearch-BpTbTWCa.esm.js +0 -430
  14. package/dist/ae-signature-DDDZmWXj.esm.js +0 -12
  15. package/dist/ae-signature.d.ts +0 -25
  16. package/dist/ae-signature.esm.js +0 -8
  17. package/dist/antifraud.d.ts +0 -57
  18. package/dist/antifraud.esm.js +0 -45
  19. package/dist/antifraudStateMachine-O0TMf6yc.esm.js +0 -39
  20. package/dist/api-CESGtpbH.esm.js +0 -53
  21. package/dist/authentication.d.ts +0 -12
  22. package/dist/authentication.esm.js +0 -25
  23. package/dist/authenticationManager-5M-fKzXx.esm.js +0 -67
  24. package/dist/authenticationManager-C83GNIhl.d.ts +0 -66
  25. package/dist/authenticationStateMachine-BMZqatiF.esm.js +0 -139
  26. package/dist/backCameraStream-DMdMeGk2.esm.js +0 -346
  27. package/dist/browserSimulation-gxD8cSpM.esm.js +0 -20
  28. package/dist/camera-DBSxa6ML.d.ts +0 -4
  29. package/dist/camera-PA2Ljri3.esm.js +0 -22
  30. package/dist/camera.d.ts +0 -15
  31. package/dist/camera.esm.js +0 -5
  32. package/dist/chunk-CRF6K_H_.esm.js +0 -49
  33. package/dist/consent.d.ts +0 -398
  34. package/dist/consent.esm.js +0 -79
  35. package/dist/consentStateMachine-CCT-B60O.esm.js +0 -151
  36. package/dist/cpf-PPz2Njto.esm.js +0 -38
  37. package/dist/cpf-ocr.d.ts +0 -204
  38. package/dist/cpf-ocr.esm.js +0 -177
  39. package/dist/cross-document-data-match.d.ts +0 -34
  40. package/dist/cross-document-data-match.esm.js +0 -71
  41. package/dist/curp-validation.d.ts +0 -188
  42. package/dist/curp-validation.esm.js +0 -110
  43. package/dist/curpValidationStateMachine-CitWLr2c.esm.js +0 -595
  44. package/dist/custom-fields.d.ts +0 -115
  45. package/dist/custom-fields.esm.js +0 -177
  46. package/dist/custom-watchlist.d.ts +0 -66
  47. package/dist/custom-watchlist.esm.js +0 -86
  48. package/dist/dateUtils-UoN5xswP.esm.js +0 -23
  49. package/dist/deepsightLoader-Cm4JIT_z.esm.js +0 -52
  50. package/dist/deepsightService-CEVxzehb.d.ts +0 -412
  51. package/dist/deepsightService-O74l4Y__.esm.js +0 -489
  52. package/dist/device.d.ts +0 -46
  53. package/dist/device.esm.js +0 -106
  54. package/dist/displayErrors-DqJ_IbsG.d.ts +0 -39
  55. package/dist/document-capture.d.ts +0 -906
  56. package/dist/document-capture.esm.js +0 -156
  57. package/dist/document-upload.d.ts +0 -331
  58. package/dist/document-upload.esm.js +0 -203
  59. package/dist/documentCaptureStateMachine-BqzTDy9k.esm.js +0 -394
  60. package/dist/dynamic-forms.d.ts +0 -178
  61. package/dist/dynamic-forms.esm.js +0 -323
  62. package/dist/ekyb.d.ts +0 -148
  63. package/dist/ekyb.esm.js +0 -127
  64. package/dist/ekybStateMachine-B59rQjgj.esm.js +0 -674
  65. package/dist/ekyc.d.ts +0 -164
  66. package/dist/ekyc.esm.js +0 -104
  67. package/dist/ekycStateMachine-oeO0Iekd.esm.js +0 -10626
  68. package/dist/electronic-signature.d.ts +0 -4
  69. package/dist/electronic-signature.esm.js +0 -7
  70. package/dist/electronicSignatureManager-D9OHzTpG.esm.js +0 -428
  71. package/dist/email.d.ts +0 -4
  72. package/dist/email.esm.js +0 -9
  73. package/dist/emailManager-DIfnS5g1.d.ts +0 -352
  74. package/dist/emailManager-wAV0LE-H.esm.js +0 -238
  75. package/dist/emailStateMachine-DOf4j58N.esm.js +0 -292
  76. package/dist/endpoints-CnN3SyDa.esm.js +0 -87
  77. package/dist/events-D6-e4vok.esm.js +0 -596
  78. package/dist/events.d.ts +0 -265
  79. package/dist/events.esm.js +0 -4
  80. package/dist/extensibility.d.ts +0 -122
  81. package/dist/extensibility.esm.js +0 -43
  82. package/dist/face-match.d.ts +0 -228
  83. package/dist/face-match.esm.js +0 -173
  84. package/dist/faceCaptureManagerFactory-Dh2PdGlF.esm.js +0 -290
  85. package/dist/faceCaptureManagerFactory-yqtpxjnN.d.ts +0 -690
  86. package/dist/faceCaptureSetup-B3faSpYA.esm.js +0 -873
  87. package/dist/faceMatchStateMachine-DNFrxTFS.esm.js +0 -127
  88. package/dist/flow-events.d.ts +0 -6
  89. package/dist/flow-events.esm.js +0 -0
  90. package/dist/flow.d.ts +0 -358
  91. package/dist/flow.esm.js +0 -825
  92. package/dist/flowCompletionService-DhkT4SRY.d.ts +0 -10
  93. package/dist/flowCompletionService-P54yzGvA.esm.js +0 -13
  94. package/dist/flowServices-DTsm-Vf1.esm.js +0 -188
  95. package/dist/geolocation.d.ts +0 -127
  96. package/dist/geolocation.esm.js +0 -89
  97. package/dist/geolocationStateMachine-asasuHY2.esm.js +0 -105
  98. package/dist/getBrowser-BSXUTWXw.esm.js +0 -41
  99. package/dist/getDeviceClass-BSntT9_j.esm.js +0 -14
  100. package/dist/government-validation.d.ts +0 -67
  101. package/dist/government-validation.esm.js +0 -81
  102. package/dist/governmentValidationStateMachine-BDDYrJTo.esm.js +0 -271
  103. package/dist/home.d.ts +0 -99
  104. package/dist/home.esm.js +0 -61
  105. package/dist/http.d.ts +0 -68
  106. package/dist/http.esm.js +0 -3
  107. package/dist/id-ocr.d.ts +0 -635
  108. package/dist/id-ocr.esm.js +0 -86
  109. package/dist/id-verification.d.ts +0 -190
  110. package/dist/id-verification.esm.js +0 -43
  111. package/dist/id.d.ts +0 -24
  112. package/dist/id.esm.js +0 -164
  113. package/dist/idCaptureManager-B9TGA5dq.d.ts +0 -956
  114. package/dist/idCaptureManager-DMK0GIt3.esm.js +0 -581
  115. package/dist/idCaptureStateMachine-Bq0fVZXl.esm.js +0 -2954
  116. package/dist/idOcrStateMachine-YbjjC_Gg.esm.js +0 -388
  117. package/dist/idVerificationStateMachine-xbw9HP1Z.esm.js +0 -71
  118. package/dist/identity-reuse.d.ts +0 -530
  119. package/dist/identity-reuse.esm.js +0 -274
  120. package/dist/index-BLKtMA0g.d.ts +0 -1177
  121. package/dist/index-BcRG8rtJ.d.ts +0 -97
  122. package/dist/index.d.ts +0 -3
  123. package/dist/index.esm.js +0 -12
  124. package/dist/invokeOnCaptureCallback-rc6kBHo5.esm.js +0 -30
  125. package/dist/lib-BB0B_qQX.esm.js +0 -12499
  126. package/dist/mandatory-consent.d.ts +0 -412
  127. package/dist/mandatory-consent.esm.js +0 -78
  128. package/dist/mandatoryConsentStateMachine-Cnco1jvn.esm.js +0 -126
  129. package/dist/openviduLazy-Cm0XFh_v.esm.js +0 -3
  130. package/dist/openviduLazy-Cok70ZSg.esm.js +0 -12
  131. package/dist/permissionServices-D_i6nzEw.esm.js +0 -50
  132. package/dist/phone.d.ts +0 -4
  133. package/dist/phone.esm.js +0 -9
  134. package/dist/phoneManager-B6M30hKE.d.ts +0 -397
  135. package/dist/phoneManager-DAJbGhlY.esm.js +0 -256
  136. package/dist/phoneStateMachine-CuPARRaT.esm.js +0 -351
  137. package/dist/platform-CfrjKhmi.esm.js +0 -83
  138. package/dist/qe-signature-DFo_Cc-I.esm.js +0 -12
  139. package/dist/qe-signature.d.ts +0 -25
  140. package/dist/qe-signature.esm.js +0 -8
  141. package/dist/recordingService-Ig2UgbLv.esm.js +0 -1003
  142. package/dist/redirect-to-mobile.d.ts +0 -107
  143. package/dist/redirect-to-mobile.esm.js +0 -102
  144. package/dist/redirectToMobileStateMachine-BOEqe46A.esm.js +0 -249
  145. package/dist/runChildModule-CqqwqAkW.esm.js +0 -219
  146. package/dist/selfie.d.ts +0 -26
  147. package/dist/selfie.esm.js +0 -146
  148. package/dist/selfieManager-D0lSgd-J.d.ts +0 -68
  149. package/dist/selfieManager-Duisl7qN.esm.js +0 -60
  150. package/dist/selfieStateMachine-D76whWEf.esm.js +0 -68
  151. package/dist/session-BS-d_vuE.esm.js +0 -3206
  152. package/dist/session.d.ts +0 -217
  153. package/dist/session.esm.js +0 -9
  154. package/dist/setup-Buy-hyj4.esm.js +0 -887
  155. package/dist/setup-C5AITV8m.d.ts +0 -254
  156. package/dist/signature.d.ts +0 -94
  157. package/dist/signature.esm.js +0 -66
  158. package/dist/signatureStateMachine-B5-QVUve.esm.js +0 -132
  159. package/dist/stats-CIfiPzb1.esm.js +0 -16
  160. package/dist/stats.d.ts +0 -16
  161. package/dist/stats.esm.js +0 -4
  162. package/dist/trust-graph.d.ts +0 -54
  163. package/dist/trust-graph.esm.js +0 -56
  164. package/dist/types-B06Ypu2F.d.ts +0 -49
  165. package/dist/types-BP1m8VRw.d.ts +0 -340
  166. package/dist/types-CAD4va6a.d.ts +0 -5
  167. package/dist/types-CFV9G_7j.d.ts +0 -24
  168. package/dist/warmup-CEcppFiS.d.ts +0 -63
  169. package/dist/wasm.d.ts +0 -15
  170. package/dist/wasm.esm.js +0 -12
  171. package/dist/watchlist-for-business.d.ts +0 -79
  172. package/dist/watchlist-for-business.esm.js +0 -148
  173. package/dist/watchlist.d.ts +0 -62
  174. package/dist/watchlist.esm.js +0 -86
  175. package/dist/watchlistServices-DMbUhkBX.esm.js +0 -12
  176. package/dist/workflow.d.ts +0 -907
  177. package/dist/workflow.esm.js +0 -702
  178. package/dist/xstate.esm-B70JrNqo.esm.js +0 -3404
@@ -1,595 +0,0 @@
1
- import { t as api } from "./api-CESGtpbH.esm.js";
2
- import { t as endpoints } from "./endpoints-CnN3SyDa.esm.js";
3
- import { a as fromPromise, r as assign, t as setup } from "./xstate.esm-B70JrNqo.esm.js";
4
-
5
- //#region src/modules/curp-validation/curpValidationUtils.ts
6
- const CURP_PATTERN = /^([A-Z][AEIOUX][A-Z]{2}\d{2}(?:0[1-9]|1[0-2])(?:0[1-9]|[12]\d|3[01])[HMX](?:AS|B[CS]|C[CLMSH]|D[FG]|G[TR]|HG|JC|M[CNS]|N[ETL]|OC|PL|Q[TR]|S[PLR]|T[CSL]|VZ|YN|ZS)[B-DF-HJ-NP-TV-Z]{3}[A-Z\d])(\d)$/;
7
- const CURP_LENGTH = 18;
8
- function isValidCurp(curp) {
9
- return typeof curp === "string" && curp.length === CURP_LENGTH && CURP_PATTERN.test(curp.toUpperCase());
10
- }
11
- /** Convert YYYY-MM-DD to DD/MM/YYYY for the API */
12
- function formatDateForApi(date) {
13
- const [year, month, day] = date.split("-");
14
- return `${day}/${month}/${year}`;
15
- }
16
- const mexicanStates = [
17
- {
18
- value: "NE",
19
- label: "Born Abroad"
20
- },
21
- {
22
- value: "AS",
23
- label: "Aguascalientes"
24
- },
25
- {
26
- value: "BC",
27
- label: "Baja California"
28
- },
29
- {
30
- value: "BS",
31
- label: "Baja California Sur"
32
- },
33
- {
34
- value: "CC",
35
- label: "Campeche"
36
- },
37
- {
38
- value: "CL",
39
- label: "Coahuila de Zaragoza"
40
- },
41
- {
42
- value: "CM",
43
- label: "Colima"
44
- },
45
- {
46
- value: "CS",
47
- label: "Chiapas"
48
- },
49
- {
50
- value: "CH",
51
- label: "Chihuahua"
52
- },
53
- {
54
- value: "DF",
55
- label: "Distrito Federal"
56
- },
57
- {
58
- value: "DG",
59
- label: "Durango"
60
- },
61
- {
62
- value: "GT",
63
- label: "Guanajuato"
64
- },
65
- {
66
- value: "GR",
67
- label: "Guerrero"
68
- },
69
- {
70
- value: "HG",
71
- label: "Hidalgo"
72
- },
73
- {
74
- value: "JC",
75
- label: "Jalisco"
76
- },
77
- {
78
- value: "MC",
79
- label: "Estado de México"
80
- },
81
- {
82
- value: "MN",
83
- label: "Michoacan de Ocampo"
84
- },
85
- {
86
- value: "MS",
87
- label: "Morelos"
88
- },
89
- {
90
- value: "NT",
91
- label: "Nayarit"
92
- },
93
- {
94
- value: "NL",
95
- label: "Nuevo León"
96
- },
97
- {
98
- value: "OC",
99
- label: "Oaxaca"
100
- },
101
- {
102
- value: "PL",
103
- label: "Puebla"
104
- },
105
- {
106
- value: "QT",
107
- label: "Queretaro de Arteaga"
108
- },
109
- {
110
- value: "QR",
111
- label: "Quintana Roo"
112
- },
113
- {
114
- value: "SP",
115
- label: "San Luis Potosi"
116
- },
117
- {
118
- value: "SL",
119
- label: "Sinaloa"
120
- },
121
- {
122
- value: "SR",
123
- label: "Sonora"
124
- },
125
- {
126
- value: "TC",
127
- label: "Tabasco"
128
- },
129
- {
130
- value: "TS",
131
- label: "Tamaulipas"
132
- },
133
- {
134
- value: "TL",
135
- label: "Tlaxcala"
136
- },
137
- {
138
- value: "VZ",
139
- label: "Veracruz"
140
- },
141
- {
142
- value: "YN",
143
- label: "Yucatan"
144
- },
145
- {
146
- value: "ZS",
147
- label: "Zacatecas"
148
- }
149
- ];
150
-
151
- //#endregion
152
- //#region src/modules/curp-validation/curpValidationServices.ts
153
- async function fetchOcrData(signal) {
154
- const res = await api.get(endpoints.ocrData, { signal });
155
- if (!res.ok) throw new Error(`GET ${endpoints.ocrData} failed: ${res.status} ${res.statusText}`);
156
- return res.data;
157
- }
158
- async function addCurp(curp, signal) {
159
- const res = await api.post(endpoints.addCurp, { curp }, { signal });
160
- if (!res.ok) throw new Error(`POST ${endpoints.addCurp} failed: ${res.status} ${res.statusText}`);
161
- return res.data;
162
- }
163
- async function addCurpV2(form, signal) {
164
- const payload = {
165
- name: form.name,
166
- firstLastName: form.firstLastName,
167
- secondLastName: form.secondLastName,
168
- gender: form.gender,
169
- birthDate: formatDateForApi(form.birthDate),
170
- state: form.birthState
171
- };
172
- const res = await api.post(endpoints.addCurpV2, payload, { signal });
173
- if (!res.ok) throw new Error(`POST ${endpoints.addCurpV2} failed: ${res.status} ${res.statusText}`);
174
- return res.data;
175
- }
176
-
177
- //#endregion
178
- //#region src/modules/curp-validation/curpFields.ts
179
- /**
180
- * Declarative schema for the CURP generation form.
181
- *
182
- * `secondLastName` is intentionally optional: many people in Mexico have
183
- * only a single paternal surname. It carries no validation rules.
184
- */
185
- const GENERATE_CURP_FIELDS = [
186
- {
187
- key: "name",
188
- labelKey: "curp.labels.firstName",
189
- type: "text",
190
- required: true,
191
- autoComplete: "given-name",
192
- validation: [{ type: "required" }]
193
- },
194
- {
195
- key: "firstLastName",
196
- labelKey: "curp.labels.firstLast",
197
- type: "text",
198
- required: true,
199
- validation: [{ type: "required" }]
200
- },
201
- {
202
- key: "secondLastName",
203
- labelKey: "curp.labels.secondLast",
204
- type: "text",
205
- required: false
206
- },
207
- {
208
- key: "gender",
209
- labelKey: "curp.labels.genderV2",
210
- type: "dropdown",
211
- required: true,
212
- validation: [{ type: "required" }]
213
- },
214
- {
215
- key: "birthDate",
216
- labelKey: "curp.labels.dob",
217
- type: "date",
218
- required: true,
219
- validation: [{ type: "required" }]
220
- },
221
- {
222
- key: "birthState",
223
- labelKey: "curp.labels.birthState",
224
- type: "dropdown",
225
- required: true,
226
- validation: [{ type: "required" }]
227
- }
228
- ];
229
- /**
230
- * Config for the single field on the CURP entry gateway screen.
231
- *
232
- * Validation contains only `curpFormat` — there is intentionally no
233
- * `required` rule. The user can legitimately leave this field empty
234
- * and use the "I don't have my CURP" button to switch to the Generate
235
- * flow; surfacing a "required" error on blur of an empty field would
236
- * be misleading.
237
- *
238
- * The Continue button on this screen is gated by a UI-level no-op guard
239
- * (`curp.length === 0`) instead, which lives in `curpInput.tsx`.
240
- */
241
- const ENTER_CURP_FIELD = {
242
- key: "curp",
243
- labelKey: "curp.placeholder.curp",
244
- validation: [{ type: "curpFormat" }]
245
- };
246
-
247
- //#endregion
248
- //#region src/modules/curp-validation/curpValidators.ts
249
- /**
250
- * Registry of pure validator functions keyed by rule type.
251
- *
252
- * Each validator returns an i18n key when the value violates the rule,
253
- * or `undefined` when the rule passes. Order of evaluation for a field
254
- * is the order rules appear in that field's `validation` array; the
255
- * first failing rule wins.
256
- */
257
- const createValidators = () => ({
258
- required: (value) => value.trim().length === 0 ? "curp.errors.fieldRequired" : void 0,
259
- curpFormat: (value) => {
260
- if (value.trim().length === 0) return void 0;
261
- return isValidCurp(value) ? void 0 : "curp.errors.invalidCurpFormat";
262
- }
263
- });
264
- const normalizeFieldValue = (value) => typeof value === "string" ? value : String(value ?? "");
265
- const evaluateRules = (value, validation, validators) => {
266
- if (!validation) return void 0;
267
- for (const rule of validation) {
268
- const error = validators[rule.type](value);
269
- if (error) return error;
270
- }
271
- };
272
- /**
273
- * Runs every Generate-CURP field through its validation rules and returns
274
- * a map of field-key → first failing i18n error key. Fields that pass are
275
- * absent from the result. An empty object signals "no errors".
276
- */
277
- const validateGenerateCurpForm = (data, fields) => {
278
- const validators = createValidators();
279
- return fields.reduce((errors, field) => {
280
- const error = evaluateRules(normalizeFieldValue(data[field.key]), field.validation, validators);
281
- if (error) errors[field.key] = error;
282
- return errors;
283
- }, {});
284
- };
285
- /**
286
- * Runs a single Generate-CURP field through its validation rules.
287
- * Returns the first failing i18n error key, or `undefined`.
288
- */
289
- const validateGenerateCurpField = (data, fieldKey, fields) => {
290
- const field = fields.find((f) => f.key === fieldKey);
291
- if (!field) return void 0;
292
- const validators = createValidators();
293
- return evaluateRules(normalizeFieldValue(data[fieldKey]), field.validation, validators);
294
- };
295
- /**
296
- * Runs the single CURP-entry field through its validation rules.
297
- * Used by both the on-blur validator and the submit-click validator
298
- * on the CURP entry gateway screen.
299
- */
300
- const validateEnterCurpField = (curp, field = ENTER_CURP_FIELD) => {
301
- const validators = createValidators();
302
- return evaluateRules(normalizeFieldValue(curp), field.validation, validators);
303
- };
304
-
305
- //#endregion
306
- //#region src/modules/curp-validation/curpValidationStateMachine.ts
307
- const DEFAULT_GENERATE_FORM = {
308
- name: "",
309
- firstLastName: "",
310
- secondLastName: "",
311
- gender: "",
312
- birthDate: "",
313
- birthState: ""
314
- };
315
- const removeKey = (errors, key) => {
316
- if (!errors?.[key]) return errors;
317
- const next = { ...errors };
318
- delete next[key];
319
- return Object.keys(next).length > 0 ? next : void 0;
320
- };
321
- const removeKeys = (errors, keys) => {
322
- if (!errors) return void 0;
323
- const next = { ...errors };
324
- for (const key of keys) delete next[key];
325
- return Object.keys(next).length > 0 ? next : void 0;
326
- };
327
- const upsertKey = (errors, key, message) => {
328
- const next = { ...errors ?? {} };
329
- if (message) next[key] = message;
330
- else delete next[key];
331
- return Object.keys(next).length > 0 ? next : void 0;
332
- };
333
- const curpValidationMachine = setup({
334
- types: {
335
- context: {},
336
- events: {},
337
- input: {}
338
- },
339
- actors: {
340
- fetchOcrData: fromPromise(async ({ signal }) => {
341
- return fetchOcrData(signal);
342
- }),
343
- verifyCurp: fromPromise(async ({ input, signal }) => {
344
- return addCurp(input.curp, signal);
345
- }),
346
- generateCurpActor: fromPromise(async ({ input, signal }) => {
347
- return addCurpV2(input.form, signal);
348
- })
349
- },
350
- actions: {
351
- setCurpFromOcr: assign(({ event }) => {
352
- return { curp: (event.output?.curp ?? "").toUpperCase() };
353
- }),
354
- setCurp: assign(({ event }) => {
355
- return { curp: event.curp.toUpperCase() };
356
- }),
357
- clearEnterCurpFieldError: assign(({ context }) => ({ enterCurpValidationErrors: removeKey(context.enterCurpValidationErrors, "curp") })),
358
- validateEnterCurpFieldAction: assign(({ context }) => ({ enterCurpValidationErrors: upsertKey(context.enterCurpValidationErrors, "curp", validateEnterCurpField(context.curp)) })),
359
- computeEnterCurpValidationResult: assign(({ context }) => {
360
- const message = validateEnterCurpField(context.curp);
361
- return { enterCurpValidationErrors: message ? { curp: message } : void 0 };
362
- }),
363
- resetEnterCurpValidationErrors: assign({ enterCurpValidationErrors: () => void 0 }),
364
- setGenerateForm: assign(({ context, event }) => {
365
- const e = event;
366
- return {
367
- generateForm: {
368
- ...context.generateForm,
369
- ...e.form
370
- },
371
- generateCurpValidationErrors: removeKeys(context.generateCurpValidationErrors, Object.keys(e.form))
372
- };
373
- }),
374
- validateGenerateCurpFieldAction: assign(({ context, event }) => {
375
- if (event.type !== "VALIDATE_FIELD") return {};
376
- if (event.field === "curp") return {};
377
- const message = validateGenerateCurpField(context.generateForm, event.field, GENERATE_CURP_FIELDS);
378
- return { generateCurpValidationErrors: upsertKey(context.generateCurpValidationErrors, event.field, message) };
379
- }),
380
- computeGenerateValidationResult: assign(({ context }) => {
381
- const errors = validateGenerateCurpForm(context.generateForm, GENERATE_CURP_FIELDS);
382
- return { generateCurpValidationErrors: Object.keys(errors).length > 0 ? errors : void 0 };
383
- }),
384
- resetGenerateCurpValidationErrors: assign({ generateCurpValidationErrors: () => void 0 }),
385
- setGeneratedCurp: assign(({ event }) => {
386
- const curp = event.output?.curp ?? "";
387
- return {
388
- generatedCurp: curp,
389
- curp
390
- };
391
- }),
392
- decrementRetries: assign(({ context }) => ({ retriesLeft: Math.max(0, context.retriesLeft - 1) })),
393
- setFromGenerate: assign({ fromGenerate: () => true }),
394
- clearFromGenerate: assign({ fromGenerate: () => false }),
395
- setError: assign(({ event }) => ({ error: String(event.error) }))
396
- },
397
- guards: {
398
- hasPrefillFromOcr: ({ context }) => context.config.prefillFromOcr !== false,
399
- hasOcrCurp: ({ event }) => {
400
- return !!event.output?.curp?.trim();
401
- },
402
- canRetry: ({ context }) => context.retriesLeft > 0,
403
- isDeceased: ({ event }) => {
404
- return event.output?.deceasedStatus === "DECEASED";
405
- },
406
- isScrapingFallback: ({ event }) => {
407
- return event.output?.result === "Attempting validation by scraping method";
408
- },
409
- isGenerateSuccess: ({ event }) => {
410
- const output = event.output;
411
- return !!(output?.success && output?.curp);
412
- },
413
- isVerifySuccess: ({ event }) => {
414
- return event.output?.success === true;
415
- },
416
- shouldVerify: ({ context }) => context.curp.trim().length > 0 && Object.keys(context.enterCurpValidationErrors ?? {}).length === 0,
417
- isGenerateFormValidGuard: ({ context }) => Object.keys(context.generateCurpValidationErrors ?? {}).length === 0
418
- }
419
- }).createMachine({
420
- id: "curpValidation",
421
- initial: "idle",
422
- context: ({ input }) => ({
423
- config: input.config,
424
- curp: "",
425
- generateForm: { ...DEFAULT_GENERATE_FORM },
426
- retriesLeft: input.config.maxRetries ?? 1,
427
- generatedCurp: void 0,
428
- error: void 0,
429
- fromGenerate: false
430
- }),
431
- states: {
432
- idle: { on: {
433
- LOAD: [{
434
- target: "loading",
435
- guard: "hasPrefillFromOcr"
436
- }, { target: "enterCurp" }],
437
- CLOSE: "closed"
438
- } },
439
- loading: {
440
- invoke: {
441
- id: "fetchOcrData",
442
- src: "fetchOcrData",
443
- onDone: [{
444
- target: "verifying",
445
- guard: "hasOcrCurp",
446
- actions: "setCurpFromOcr"
447
- }, { target: "enterCurp" }],
448
- onError: { target: "enterCurp" }
449
- },
450
- on: { CLOSE: "closed" }
451
- },
452
- enterCurp: {
453
- entry: "resetEnterCurpValidationErrors",
454
- initial: "inputting",
455
- states: {
456
- inputting: { on: {
457
- SET_CURP: { actions: ["setCurp", "clearEnterCurpFieldError"] },
458
- VALIDATE_FIELD: {
459
- guard: ({ event }) => event.field === "curp",
460
- actions: "validateEnterCurpFieldAction"
461
- },
462
- VERIFY: { target: "validatingVerify" },
463
- SWITCH_TO_GENERATE: {
464
- target: "#curpValidation.generateCurp",
465
- actions: "setFromGenerate"
466
- }
467
- } },
468
- validatingVerify: {
469
- entry: "computeEnterCurpValidationResult",
470
- always: [{
471
- guard: "shouldVerify",
472
- target: "#curpValidation.verifying"
473
- }, { target: "inputting" }]
474
- }
475
- },
476
- on: { CLOSE: "#curpValidation.closed" }
477
- },
478
- verifying: {
479
- invoke: {
480
- id: "verifyCurp",
481
- src: "verifyCurp",
482
- input: ({ context }) => ({ curp: context.curp }),
483
- onDone: [{
484
- target: "success",
485
- guard: "isVerifySuccess"
486
- }, {
487
- target: "failure",
488
- actions: "decrementRetries"
489
- }],
490
- onError: {
491
- target: "failure",
492
- actions: ["decrementRetries", "setError"]
493
- }
494
- },
495
- on: { CLOSE: "closed" }
496
- },
497
- success: {
498
- after: { 3e3: "finished" },
499
- on: { CLOSE: "closed" }
500
- },
501
- failure: {
502
- on: {
503
- RETRY: [{
504
- target: "generateCurp",
505
- guard: ({ context }) => context.retriesLeft > 0 && context.fromGenerate
506
- }, {
507
- target: "enterCurp",
508
- guard: ({ context }) => context.retriesLeft > 0 && !context.fromGenerate,
509
- actions: "clearFromGenerate"
510
- }],
511
- CLOSE: "closed"
512
- },
513
- after: { 3e3: [{
514
- target: "finished",
515
- guard: ({ context }) => context.retriesLeft <= 0
516
- }] }
517
- },
518
- generateCurp: {
519
- entry: "resetGenerateCurpValidationErrors",
520
- initial: "inputting",
521
- states: {
522
- inputting: { on: {
523
- SET_GENERATE_FORM: { actions: "setGenerateForm" },
524
- VALIDATE_FIELD: {
525
- guard: ({ event }) => event.field !== "curp",
526
- actions: "validateGenerateCurpFieldAction"
527
- },
528
- GENERATE: { target: "validatingGenerate" }
529
- } },
530
- validatingGenerate: {
531
- entry: "computeGenerateValidationResult",
532
- always: [{
533
- guard: "isGenerateFormValidGuard",
534
- target: "#curpValidation.generating"
535
- }, { target: "inputting" }]
536
- }
537
- },
538
- on: { CLOSE: "#curpValidation.closed" }
539
- },
540
- generating: {
541
- invoke: {
542
- id: "generateCurpActor",
543
- src: "generateCurpActor",
544
- input: ({ context }) => ({ form: context.generateForm }),
545
- onDone: [
546
- {
547
- target: "finished",
548
- guard: "isScrapingFallback"
549
- },
550
- {
551
- target: "finished",
552
- guard: "isDeceased"
553
- },
554
- {
555
- target: "confirmCurp",
556
- guard: "isGenerateSuccess",
557
- actions: "setGeneratedCurp"
558
- },
559
- {
560
- target: "generateError",
561
- actions: "setFromGenerate"
562
- }
563
- ],
564
- onError: {
565
- target: "generateError",
566
- actions: ["setFromGenerate", "setError"]
567
- }
568
- },
569
- on: { CLOSE: "closed" }
570
- },
571
- confirmCurp: { on: {
572
- CONFIRM: { target: "verifying" },
573
- CLOSE: "closed"
574
- } },
575
- generateError: {
576
- on: {
577
- RETRY: {
578
- target: "generateCurp",
579
- guard: "canRetry",
580
- actions: "decrementRetries"
581
- },
582
- CLOSE: "closed"
583
- },
584
- after: { 3e3: [{
585
- target: "finished",
586
- guard: ({ context }) => context.retriesLeft <= 0
587
- }] }
588
- },
589
- finished: { type: "final" },
590
- closed: { type: "final" }
591
- }
592
- });
593
-
594
- //#endregion
595
- export { mexicanStates as i, ENTER_CURP_FIELD as n, GENERATE_CURP_FIELDS as r, curpValidationMachine as t };
@@ -1,115 +0,0 @@
1
- import { t as Manager } from "./Manager-C8PrhBOx.js";
2
- import "./Actor-CI32dTbG.js";
3
-
4
- //#region src/modules/custom-fields/types.d.ts
5
- type CustomFieldType = 'INTEGER' | 'DOUBLE' | 'BOOLEAN' | 'STRING' | 'DATE';
6
- type CustomField = {
7
- name: string;
8
- alias: string;
9
- type: CustomFieldType;
10
- };
11
- type CustomFieldsConfig = {
12
- title: string;
13
- customFields: CustomField[];
14
- };
15
- //#endregion
16
- //#region src/modules/custom-fields/customFieldsStateMachine.d.ts
17
- type CustomFieldsResult = 'success' | 'failed';
18
- declare const customFieldsMachine: any;
19
- //#endregion
20
- //#region src/modules/custom-fields/customFieldsActor.d.ts
21
- type CreateCustomFieldsActorOptions = {
22
- config: CustomFieldsConfig;
23
- };
24
- //#endregion
25
- //#region src/modules/custom-fields/customFieldsManager.d.ts
26
- /**
27
- * A `CustomField` enriched with a computed `label` for display.
28
- * Label is derived from `alias` when present, otherwise auto-formatted from `name`.
29
- */
30
- type MappedCustomField = CustomField & {
31
- label: string;
32
- };
33
- /** Custom fields manager is in initial state, waiting for `load()` to be called */
34
- type CustomFieldsIdleState = {
35
- status: 'idle';
36
- };
37
- /**
38
- * Ready for field input — use `setField()` and `submit()`
39
- * @property title - Form title from configuration
40
- * @property customFields - Field definitions with computed display labels
41
- * @property canSubmit - True when all non-boolean fields have a non-empty value
42
- */
43
- type CustomFieldsInputtingState = {
44
- status: 'inputting';
45
- title: string;
46
- customFields: MappedCustomField[];
47
- canSubmit: boolean;
48
- };
49
- /** Fields are being submitted to the backend */
50
- type CustomFieldsSubmittingState = {
51
- status: 'submitting';
52
- title: string;
53
- };
54
- /** API call succeeded — success page is visible for ~3 s before finishing */
55
- type CustomFieldsSuccessState = {
56
- status: 'success';
57
- };
58
- /** Custom fields flow complete. `result` indicates whether the API call succeeded or failed. */
59
- type CustomFieldsFinishedState = {
60
- status: 'finished';
61
- result: CustomFieldsResult | null;
62
- };
63
- /**
64
- * Union of all possible custom fields manager states.
65
- */
66
- type CustomFieldsState = CustomFieldsIdleState | CustomFieldsInputtingState | CustomFieldsSubmittingState | CustomFieldsSuccessState | CustomFieldsFinishedState;
67
- /**
68
- * Creates a custom fields manager for headless or UI-driven usage.
69
- *
70
- * @param options - Configuration options
71
- * @param options.config - Custom fields configuration (title + field definitions)
72
- *
73
- * @returns Custom fields manager with state, API methods, and subscription
74
- *
75
- * @example Headless usage
76
- * ```typescript
77
- * const manager = createCustomFieldsManager({
78
- * config: {
79
- * title: 'Additional Information',
80
- * customFields: [{ name: 'company', alias: 'Company', type: 'STRING' }],
81
- * },
82
- * });
83
- *
84
- * manager.subscribe((state) => console.log(state.status));
85
- * manager.load();
86
- * manager.setField('company', 'Incode');
87
- * manager.submit();
88
- * manager.stop();
89
- * ```
90
- */
91
- declare function createCustomFieldsManager(options: CreateCustomFieldsActorOptions): Manager<CustomFieldsState> & {
92
- /**
93
- * Initializes the custom fields flow.
94
- * Transitions from 'idle' to 'inputting'.
95
- * Must be called before any other method.
96
- */
97
- load(): void;
98
- /**
99
- * Updates the value of a single field.
100
- * Should be called when state is 'inputting'.
101
- *
102
- * @param name - The field name (matches CustomField.name)
103
- * @param value - The field value (string, number, or boolean)
104
- */
105
- setField(name: string, value: string | number | boolean): void;
106
- /**
107
- * Submits all custom field values to the backend.
108
- * Transitions to 'submitting', then 'finished' regardless of outcome.
109
- */
110
- submit(): void;
111
- };
112
- /** Type representing a custom fields manager instance. */
113
- type CustomFieldsManager = ReturnType<typeof createCustomFieldsManager>;
114
- //#endregion
115
- export { type CustomField, type CustomFieldType, type CustomFieldsConfig, type CustomFieldsManager, type CustomFieldsState, type MappedCustomField, createCustomFieldsManager, customFieldsMachine };