@scbt-ecom/ui 0.51.1 → 0.51.2
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.
package/dist/ui.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { j as p, c as We, R as Ye, B as E, u as Je, f as Qe, g as Ze, h as et, i as k, k as Re, l as tt, m as nt, n as U, o as ot, A as rt, H as it, I as N, p as lt, q as me, D as ut, V as st, O as at } from "./index-
|
|
2
|
-
import { d as Un, r as Kn, e as Xn, C as Wn, s as Yn, K as Jn, L as Qn, N as Zn, P as eo, a as to, S as no, U as oo, b as ro, t as io } from "./index-
|
|
1
|
+
import { j as p, c as We, R as Ye, B as E, u as Je, f as Qe, g as Ze, h as et, i as k, k as Re, l as tt, m as nt, n as U, o as ot, A as rt, H as it, I as N, p as lt, q as me, D as ut, V as st, O as at } from "./index-vcD48ARm.js";
|
|
2
|
+
import { d as Un, r as Kn, e as Xn, C as Wn, s as Yn, K as Jn, L as Qn, N as Zn, P as eo, a as to, S as no, U as oo, b as ro, t as io } from "./index-vcD48ARm.js";
|
|
3
3
|
import * as P from "react";
|
|
4
4
|
import { forwardRef as D, useState as he, useEffect as gt } from "react";
|
|
5
5
|
import { c as w, T as Se } from "./typeGuards-BigW-JS1.js";
|
package/dist/validation.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { z as s, p as I, i as N, f as T, D as L, s as D } from "./utils-Od0KoTas.js";
|
|
2
2
|
import { T as c } from "./typeGuards-BigW-JS1.js";
|
|
3
|
-
const R = /^[\u0400-\u04FF\u00CB\u00EB -]+$/, A = /^(?:[^-]+(?:-[^-]+){0,4}|[^-]+)$/, y = /^[a-zA-Zа-яА-ЯёЁ]+(?:\s*-\s*[a-zA-Zа-яА-ЯёЁ]+){0,4}(?:\s+[a-zA-Zа-яА-ЯёЁ]+(?:\s*-\s*[a-zA-Zа-яА-ЯёЁ]+){0,4})?$/i,
|
|
3
|
+
const R = /^[\u0400-\u04FF\u00CB\u00EB -]+$/, A = /^(?:[^-]+(?:-[^-]+){0,4}|[^-]+)$/, y = /^[a-zA-Zа-яА-ЯёЁ]+(?:\s*-\s*[a-zA-Zа-яА-ЯёЁ]+){0,4}(?:\s+[a-zA-Zа-яА-ЯёЁ]+(?:\s*-\s*[a-zA-Zа-яА-ЯёЁ]+){0,4})?$/i, m = {
|
|
4
4
|
REQUIRED: "Поле обязательно к заполнению",
|
|
5
5
|
MIN_LENGTH: "Минимальная длина символов должна быть не менее",
|
|
6
6
|
MAX_LENGTH: "Максимальная длина символов должна быть не более",
|
|
@@ -41,17 +41,17 @@ const R = /^[\u0400-\u04FF\u00CB\u00EB -]+$/, A = /^(?:[^-]+(?:-[^-]+){0,4}|[^-]
|
|
|
41
41
|
code: s.ZodIssueCode.custom,
|
|
42
42
|
message: "Неверно введено отчество"
|
|
43
43
|
}));
|
|
44
|
-
}), ae = s.string().length(10, { message:
|
|
44
|
+
}), ae = s.string().length(10, { message: m.INVALID_DATE }).superRefine((e, t) => {
|
|
45
45
|
const [o, d, n] = (e == null ? void 0 : e.split(".")) ?? "", i = I(`${o}/${d}/${n}`, "dd/MM/yyyy", /* @__PURE__ */ new Date());
|
|
46
46
|
+n <= 1950 && t.addIssue({
|
|
47
47
|
code: s.ZodIssueCode.custom,
|
|
48
|
-
message:
|
|
48
|
+
message: m.INVALID_DATE
|
|
49
49
|
}), N(i) || t.addIssue({
|
|
50
50
|
code: s.ZodIssueCode.custom,
|
|
51
|
-
message:
|
|
51
|
+
message: m.INVALID_DATE
|
|
52
52
|
}), (/* @__PURE__ */ new Date()).getTime() < new Date(i).getTime() && t.addIssue({
|
|
53
53
|
code: s.ZodIssueCode.custom,
|
|
54
|
-
message:
|
|
54
|
+
message: m.FUTURE_DATE_NOT_ALLOWED
|
|
55
55
|
});
|
|
56
56
|
}), re = s.string().superRefine((e, t) => {
|
|
57
57
|
const o = e.charAt(0);
|
|
@@ -62,12 +62,12 @@ const R = /^[\u0400-\u04FF\u00CB\u00EB -]+$/, A = /^(?:[^-]+(?:-[^-]+){0,4}|[^-]
|
|
|
62
62
|
code: s.ZodIssueCode.custom,
|
|
63
63
|
message: "Введите номер телефона полностью"
|
|
64
64
|
});
|
|
65
|
-
}).transform((e) => `7${e}`), ue = s.coerce.number().min(1e3, `${
|
|
65
|
+
}).transform((e) => `7${e}`), ue = s.coerce.number().min(1e3, `${m.FIX_LENGTH} 4`).max(9999, `${m.FIX_LENGTH} 4`).nullable().superRefine((e, t) => {
|
|
66
66
|
e === null && t.addIssue({
|
|
67
67
|
code: s.ZodIssueCode.invalid_type,
|
|
68
68
|
expected: "number",
|
|
69
69
|
received: "null",
|
|
70
|
-
message: `${
|
|
70
|
+
message: `${m.FIX_LENGTH} 4`
|
|
71
71
|
});
|
|
72
72
|
}).default(null), r = {
|
|
73
73
|
NON_EMPTY: () => "Поле не может быть пустым",
|
|
@@ -188,7 +188,7 @@ function U(e) {
|
|
|
188
188
|
const M = /^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/g, H = (e) => {
|
|
189
189
|
const { message: t, regexp: o = M } = e || {}, d = c.isString(o) ? new RegExp(o) : o;
|
|
190
190
|
return s.string().min(1, (t == null ? void 0 : t.min) || r.EMAIL_NON_EMPTY()).regex(d, (t == null ? void 0 : t.invalid) || r.EMAIL_INVALID()).default("");
|
|
191
|
-
},
|
|
191
|
+
}, p = (e) => {
|
|
192
192
|
const { message: t, regexp: o = M } = e || {}, d = c.isString(o) ? new RegExp(o) : o;
|
|
193
193
|
return s.string().refine(
|
|
194
194
|
(n) => c.isStringEmpty(n) ? !0 : d.test(n),
|
|
@@ -197,18 +197,18 @@ const M = /^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/g, H = (e) => {
|
|
|
197
197
|
}
|
|
198
198
|
).optional().transform((n) => (n == null ? void 0 : n.length) === 0 ? void 0 : n);
|
|
199
199
|
};
|
|
200
|
-
function
|
|
200
|
+
function w(e) {
|
|
201
201
|
const { required: t = !0 } = e || {};
|
|
202
|
-
return t ? H(e) :
|
|
202
|
+
return t ? H(e) : p(e);
|
|
203
203
|
}
|
|
204
204
|
const Z = (e) => {
|
|
205
205
|
const { min: t, max: o, message: d } = e || {};
|
|
206
206
|
let n = s.coerce.number();
|
|
207
207
|
return t && (n = n.min(t, (d == null ? void 0 : d.min) || r.MIN_VALUE(t))), o && (n = n.max(o, (d == null ? void 0 : d.min) || r.MAX_VALUE(o))), n.default(0);
|
|
208
|
-
},
|
|
208
|
+
}, Y = (e) => Z(e).optional().transform((t) => t || void 0);
|
|
209
209
|
function F(e) {
|
|
210
210
|
const { required: t = !0 } = e || {};
|
|
211
|
-
return t ? Z(e) :
|
|
211
|
+
return t ? Z(e) : Y(e);
|
|
212
212
|
}
|
|
213
213
|
const G = (e) => {
|
|
214
214
|
const { ignoreMask: t = !0, maskSymbols: o = /[()+_ -]/g, message: d } = e || {}, n = c.isString(o) ? new RegExp(o) : o;
|
|
@@ -278,7 +278,7 @@ const v = (e) => {
|
|
|
278
278
|
let i = s.string({ message: n == null ? void 0 : n.root });
|
|
279
279
|
return t && (i = i.min(t, { message: (n == null ? void 0 : n.min) || r.MIN_LENGTH(t) })), o && (i = i.max(o, { message: (n == null ? void 0 : n.max) || r.MAX_LENGTH(o) })), d && (i = i.length(d, { message: (n == null ? void 0 : n.length) || r.FIX_LENGTH(d) })), i.optional().transform((u) => u != null && u.length ? u : void 0);
|
|
280
280
|
};
|
|
281
|
-
function
|
|
281
|
+
function j(e) {
|
|
282
282
|
const { required: t = !0, ...o } = e || {};
|
|
283
283
|
return t ? v(o) : z(o);
|
|
284
284
|
}
|
|
@@ -288,10 +288,10 @@ const O = (e, t) => {
|
|
|
288
288
|
message: a,
|
|
289
289
|
...d
|
|
290
290
|
}).nullable().refine(Boolean, r.NON_EMPTY()).default(null);
|
|
291
|
-
},
|
|
291
|
+
}, B = (e, t) => O(e, t).optional();
|
|
292
292
|
function k(e, t) {
|
|
293
293
|
const { required: o, ...d } = t || {};
|
|
294
|
-
return o ? O(e, d) :
|
|
294
|
+
return o ? O(e, d) : B(e, d);
|
|
295
295
|
}
|
|
296
296
|
const C = /^(http:\/\/www\.|https:\/\/www\.|http:\/\/|https:\/\/)?[a-z0-9]+([-.]{1}[a-z0-9]+)*\.[a-z]{2,5}(:[0-9]{1,5})?(\/.*)?$/, W = (e) => {
|
|
297
297
|
const { message: t, regexp: o = C } = e || {}, d = c.isString(o) ? new RegExp(o) : o;
|
|
@@ -305,8 +305,8 @@ function Q(e) {
|
|
|
305
305
|
return t ? W(e) : K(e);
|
|
306
306
|
}
|
|
307
307
|
const J = {
|
|
308
|
-
getStringSchema:
|
|
309
|
-
getEmailSchema:
|
|
308
|
+
getStringSchema: j,
|
|
309
|
+
getEmailSchema: w,
|
|
310
310
|
getSelectSchema: q,
|
|
311
311
|
getNumberSchema: F,
|
|
312
312
|
getPhoneSchema: $,
|
|
@@ -411,13 +411,13 @@ class ce {
|
|
|
411
411
|
* })
|
|
412
412
|
*/
|
|
413
413
|
static zodMergeIntersection(t) {
|
|
414
|
-
const { left: o, right: d } = t._def, n = o instanceof s.ZodDiscriminatedUnion || o._def.typeName === "ZodDiscriminatedUnion" ? o._def.options[0] : o, i = d instanceof s.ZodDiscriminatedUnion ||
|
|
415
|
-
if (n instanceof s.ZodObject && i instanceof s.ZodObject)
|
|
414
|
+
const { left: o, right: d } = t._def, n = o instanceof s.ZodDiscriminatedUnion || o._def.typeName === "ZodDiscriminatedUnion" ? o._def.options[0] : o, i = d instanceof s.ZodDiscriminatedUnion || d._def.typeName === "ZodDiscriminatedUnion" ? d._def.options[0] : d;
|
|
415
|
+
if ((n._def.typeName === "ZodObject" || n instanceof s.ZodObject) && (i._def.typeName === "ZodObject" || i instanceof s.ZodObject))
|
|
416
416
|
return n.merge(i);
|
|
417
417
|
throw new Error(`Cannot merge schema type ${i._def.typeName} to ${n._def.typeName}`);
|
|
418
418
|
}
|
|
419
419
|
}
|
|
420
|
-
const
|
|
420
|
+
const E = {
|
|
421
421
|
NON_EMPTY: () => "Поле обязательно для заполнения",
|
|
422
422
|
VALUE_NO_WHITESPACE: () => "Укажите фамилию, имя и отчество через пробел",
|
|
423
423
|
ONLY_CYRILLIC: () => "Данные должны быть написаны кириллицей",
|
|
@@ -439,23 +439,23 @@ const m = {
|
|
|
439
439
|
g.ONLY_CYRILLIC.test(u) || a.addIssue({
|
|
440
440
|
code: s.ZodIssueCode.invalid_string,
|
|
441
441
|
validation: "regex",
|
|
442
|
-
message:
|
|
442
|
+
message: E.ONLY_CYRILLIC()
|
|
443
443
|
}), (!l || !f) && a.addIssue({
|
|
444
444
|
code: s.ZodIssueCode.invalid_string,
|
|
445
445
|
validation: "regex",
|
|
446
|
-
message: o ||
|
|
446
|
+
message: o || E.NAME_OR_SURNAME_NON_EMPTY()
|
|
447
447
|
}), g.CHECK_HYPHEN.test(l) || a.addIssue({
|
|
448
448
|
code: s.ZodIssueCode.invalid_string,
|
|
449
449
|
validation: "regex",
|
|
450
|
-
message: i ||
|
|
450
|
+
message: i || E.INVALID_NAME()
|
|
451
451
|
}), g.CHECK_HYPHEN.test(f) || a.addIssue({
|
|
452
452
|
code: s.ZodIssueCode.invalid_string,
|
|
453
453
|
validation: "regex",
|
|
454
|
-
message: d ||
|
|
454
|
+
message: d || E.INVALID_SURNAME()
|
|
455
455
|
}), _ && (g.PATRONYMIC.test(_) || a.addIssue({
|
|
456
456
|
code: s.ZodIssueCode.invalid_string,
|
|
457
457
|
validation: "regex",
|
|
458
|
-
message: n ||
|
|
458
|
+
message: n || E.INVALID_PATRONYMIC()
|
|
459
459
|
}));
|
|
460
460
|
}).transform((u) => u.trimEnd()).default("");
|
|
461
461
|
}, te = (e) => S(e).optional().transform((t) => t != null && t.length ? t : void 0);
|
|
@@ -473,7 +473,7 @@ export {
|
|
|
473
473
|
A as RgxCheckForHyphen,
|
|
474
474
|
y as RgxPatronymic,
|
|
475
475
|
R as RgxUnicode,
|
|
476
|
-
|
|
476
|
+
m as VALIDATION_MESSAGES,
|
|
477
477
|
ce as ZodUtils,
|
|
478
478
|
r as baseDefaultMessages,
|
|
479
479
|
J as baseValidationSchemas,
|
package/dist/validation.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validation.js","sources":["../lib/shared/validation/regExp.ts","../lib/shared/validation/messages.ts","../lib/shared/validation/zodValidation/dadataFio.ts","../lib/shared/validation/zodValidation/calendar.ts","../lib/shared/validation/zodValidation/phone.ts","../lib/shared/validation/zodValidation/otpCode.ts","../lib/shared/validation/base/base.constants.ts","../lib/shared/validation/base/date.validators.ts","../lib/shared/validation/base/email.validators.ts","../lib/shared/validation/base/number.validators.ts","../lib/shared/validation/base/phone.validators.ts","../lib/shared/validation/base/select.validators.ts","../lib/shared/validation/base/string.validators.ts","../lib/shared/validation/base/union.validators.ts","../lib/shared/validation/base/url.validators.ts","../lib/shared/validation/base/base.validators.ts","../lib/shared/validation/utils/zodUtils.ts","../lib/shared/validation/dadata/dadata.constants.ts","../lib/shared/validation/dadata/fio.validators.ts","../lib/shared/validation/dadata/index.ts","../lib/shared/validation/index.ts"],"sourcesContent":["export const RgxUnicode = /^[\\u0400-\\u04FF\\u00CB\\u00EB -]+$/ // Диапазон символов Unicode, включающий кириллические символы.*\nexport const RgxCheckForHyphen = /^(?:[^-]+(?:-[^-]+){0,4}|[^-]+)$/ // Проверяет количество дефисов a-b-c-d-e Валидный (до 4 дефисов), не валидный*\nexport const RgxPatronymic =\n /^[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4}(?:\\s+[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4})?$/i //Отчество для дадаты Отчество углы-ули Отчество-Отчество\n","export const VALIDATION_MESSAGES = {\n REQUIRED: 'Поле обязательно к заполнению',\n MIN_LENGTH: 'Минимальная длина символов должна быть не менее',\n MAX_LENGTH: 'Максимальная длина символов должна быть не более',\n FIX_LENGTH: 'Длина символов должна быть равна',\n MAX_LENGTH_ELEMENTS: 'Максимальное количество элементов должно быть не более',\n MIN_LENGTH_ELEMENTS: 'Минимальное количество элементов должно быть не менее',\n FIX_LENGTH_ELEMENTS: 'Количество элементов должно быть равно',\n INVALID_VALUE: 'Поле заполнено некорректно',\n INVALID_DATE: 'Введите корректную дату',\n FUTURE_DATE_NOT_ALLOWED: 'Нельзя выбрать дату позже текущей',\n INVALID_URL: 'Некорректная ссылка'\n} as const\n","import { z } from 'zod'\nimport { RgxCheckForHyphen, RgxPatronymic, RgxUnicode } from '../regExp'\n\nexport const formattedDadataFio = (value: string) => {\n const parts = value.trim().replace(/\\s+/g, ' ').split(' ')\n const [surname, name, ...patronymicArr] = parts\n const patronymic = patronymicArr?.join(' ')\n\n return {\n surname,\n name,\n patronymic\n }\n}\n\nexport const zodDadataFioSchema = z\n .string({ invalid_type_error: 'Обязательно к заполнению', required_error: 'Обязательно к заполнению' })\n .superRefine((value, ctx) => {\n if (value === '') {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Введите имя и фамилию'\n })\n }\n\n if (!RgxUnicode.test(value)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Должна быть только кириллица'\n })\n }\n\n const { surname, name, patronymic } = formattedDadataFio(value)\n\n if (!surname || !name) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Введите имя и фамилию'\n })\n }\n\n if (!RgxCheckForHyphen.test(name)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Неверно введено имя'\n })\n }\n\n if (!RgxCheckForHyphen.test(surname)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Неверно введена фамилия'\n })\n }\n\n if (patronymic) {\n if (!RgxPatronymic.test(patronymic)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Неверно введено отчество'\n })\n }\n }\n })\n","import { isValid, parse } from 'date-fns'\nimport { z } from 'zod'\nimport { VALIDATION_MESSAGES } from '../messages'\n\nexport const zodCalendarValidate = z\n .string()\n .length(10, { message: VALIDATION_MESSAGES.INVALID_DATE })\n .superRefine((val, ctx) => {\n const [day, month, year] = val?.split('.') ?? ''\n const parsed = parse(`${day}/${month}/${year}`, 'dd/MM/yyyy', new Date())\n\n if (+year <= 1950) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: VALIDATION_MESSAGES.INVALID_DATE\n })\n }\n\n if (!isValid(parsed)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: VALIDATION_MESSAGES.INVALID_DATE\n })\n }\n\n if (new Date().getTime() < new Date(parsed).getTime()) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: VALIDATION_MESSAGES.FUTURE_DATE_NOT_ALLOWED\n })\n }\n })\n","import { z } from 'zod'\n\nexport const zodPhoneSchema = z\n .string()\n .superRefine((value, ctx) => {\n const operatorCode = value.charAt(0)\n\n if (!['3', '4', '5', '6', '9'].includes(operatorCode)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Код города/оператора должен начинаться с цифры 3, 4, 5, 6 или 9'\n })\n }\n\n if (value.length !== 10) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Введите номер телефона полностью'\n })\n }\n })\n .transform((value) => `7${value}`)\n","import { z } from 'zod'\nimport { VALIDATION_MESSAGES } from '../messages'\n\nexport const zodOtpCodeSchema = z.coerce\n .number()\n .min(1000, `${VALIDATION_MESSAGES.FIX_LENGTH} 4`)\n .max(9999, `${VALIDATION_MESSAGES.FIX_LENGTH} 4`)\n .nullable()\n .superRefine((value, context) => {\n if (value === null) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_type,\n expected: 'number',\n received: 'null',\n message: `${VALIDATION_MESSAGES.FIX_LENGTH} 4`\n })\n }\n })\n .default(null)\n","import { type Primitive } from 'zod'\nimport { formatDateToLocaleString } from '$/shared/ui'\nimport { TypeGuards } from '$/shared/utils'\n\nexport const baseDefaultMessages = {\n NON_EMPTY: () => 'Поле не может быть пустым',\n MIN_LENGTH: (min: number) => `Поле должно содержать минимум символов: ${min}`,\n MAX_LENGTH: (max: number) => `Поле должно содержать максимум символов: ${max}`,\n FIX_LENGTH: (length: number) => `Поле должно быть фиксированной длины символов: ${length}`,\n MIN_VALUE: (min: number) => `Значение не может быть меньше чем ${min}`,\n MAX_VALUE: (max: number) => `Значение не может быть больше чем ${max}`,\n PHONE_NON_EMPTY: () => 'Номер телефона должен состоять из 11 цифр',\n PHONE_INVALID_OPERATOR: () => 'Код города/оператора должен начинаться с цифры 3, 4, 5, 6 или 9',\n EMAIL_INVALID: () => 'Email введен некорректно. Пример: example@domain.ru',\n EMAIL_NON_EMPTY: () => 'Введите адрес электронной почты',\n SELECT_NON_EMPTY: () => 'Выберите один из вариантов',\n SELECT_MULTIPLE_MIN_LENGTH: (length: number) => `Выберите не менее ${length} вариантов`,\n SELECT_MULTIPLE_MAX_LENGTH: (length: number) => `Выберите не более ${length} вариантов`,\n SELECT_FIX_LENGTH: (length: number) => `Поле должно быть фиксированного количества вариантов: ${length}`,\n DATE_INVALID_FORMAT: () => 'Дата указана некорректно',\n DATE_NON_EMPTY: () => 'Укажите дату',\n VALUE_OUT_OF_RANGE: <T extends Primitive>(range: T[]) => `Выберите один из вариантов ${range.join(', ')}`,\n DATE_MIN: (min: Date | string) => {\n const date = TypeGuards.isString(min) ? new Date(min) : min\n\n return `Выбранная дата должна быть не раньше ${formatDateToLocaleString(date)}`\n },\n DATE_MAX: (max: Date | string) => {\n const date = TypeGuards.isString(max) ? new Date(max) : max\n\n return `Выбранная дата должна быть не позже ${formatDateToLocaleString(date)}`\n },\n INVALID_URL: () => 'Ссылка введена некорректно. Пример: https://example.com, example.com'\n}\n","import { isValid, parse } from 'date-fns'\nimport z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { DATE_VISIBLE_PATTERN } from '$/shared/ui'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type DateValidationOptions<Required extends boolean> = {\n /**\n * валидация строки с учетом ISO формата\n * @default true\n */\n iso?: boolean\n /**\n * шаблон для валидации строки (будет проигнорирован, если `iso = true`)\n * @default 'dd.MM.yyyy'\n */\n pattern?: string\n /**\n * минимальная дата\n * `Date | ISO string`\n */\n min?: Date | string\n /**\n * максимальная дата\n * `Date | ISO string`\n */\n max?: Date | string\n /**\n * указывает что поле обязательное\n */\n required?: Required\n message?: {\n min?: string\n max?: string\n invalidDate?: string\n }\n}\n\n/**\n * Схема валидации обязательного поля даты\n */\nconst getDateRequired = (props?: Omit<DateValidationOptions<boolean>, 'required'>) => {\n const { iso = true, pattern = DATE_VISIBLE_PATTERN, min, max, message } = props || {}\n\n return z\n .string()\n .min(8, message?.min || baseDefaultMessages.DATE_NON_EMPTY())\n .superRefine((value, context) => {\n const validSymbolsLength = pattern.replace(/\\W/g, '').length\n const cleanedValue = value.replace(/[._-]/g, '')\n\n if (cleanedValue.length < validSymbolsLength) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: validSymbolsLength,\n type: 'date',\n inclusive: true,\n message: message?.min || baseDefaultMessages.DATE_NON_EMPTY()\n })\n }\n\n if (iso) {\n let date: Date | null = null\n\n try {\n date = new Date(value)\n } catch {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date!.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date!.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n } else {\n const date = parse(value, pattern, new Date())\n\n if (!isValid(date)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n }\n })\n .default('')\n}\ntype DateRequiredSchema = ReturnType<typeof getDateRequired>\n\n/**\n * Схема валидации опционального поля даты\n */\nconst getDateOptional = (props?: Omit<DateValidationOptions<boolean>, 'required'>) => {\n const { iso = true, pattern = DATE_VISIBLE_PATTERN, min, max, message } = props || {}\n\n return z\n .string()\n .transform((value) => (!value ? undefined : value))\n .superRefine((value, context) => {\n if (TypeGuards.isString(value) && Boolean(value.length)) {\n const validSymbolsLength = pattern.replace(/\\W/g, '').length\n const cleanedValue = value.replace(/[._-]/g, '')\n\n if (cleanedValue.length < validSymbolsLength) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: validSymbolsLength,\n type: 'date',\n inclusive: true,\n message: message?.min || baseDefaultMessages.DATE_NON_EMPTY()\n })\n }\n\n if (iso) {\n let date: Date | null = null\n\n try {\n date = new Date(value)\n } catch {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date!.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date!.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n } else {\n const date = parse(value, pattern, new Date())\n\n if (!isValid(date)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n }\n }\n })\n .optional()\n}\ntype DateOptionalSchema = ReturnType<typeof getDateOptional>\n\n/**\n * Схема валидации поля даты\n * @param {DateValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @typeParam `iso` - `boolean | undefined`\n * @typeParam `pattern` - `string | undefined`\n * @typeParam `message` - `{ [min | invalidOperator]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getDateSchema()\n * })\n * // will returns z.string()\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getDateSchema({ required: false })\n * })\n * // will returns z.string().optional()\n */\nexport function getDateSchema(props?: DateValidationOptions<true>): DateRequiredSchema\nexport function getDateSchema(props?: DateValidationOptions<false>): DateOptionalSchema\nexport function getDateSchema<Required extends boolean>(\n props?: DateValidationOptions<Required>\n): DateRequiredSchema | DateOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getDateRequired(props) : getDateOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type EmailValidationOptions<Required extends boolean> = {\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n /**\n * Регулярное выражение для проверки email на валидность\n */\n regexp?: RegExp | string\n message?: {\n min?: string\n invalid?: string\n }\n}\n\nconst EMAIL_REGEX = /^[\\w-.]+@([\\w-]+\\.)+[\\w-]{2,4}$/g\n\n/**\n * Схема валидации обязательного поля типа email\n */\nconst getEmailRequired = (props?: Omit<EmailValidationOptions<true>, 'required'>) => {\n const { message, regexp = EMAIL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return z\n .string()\n .min(1, message?.min || baseDefaultMessages.EMAIL_NON_EMPTY())\n .regex(regex, message?.invalid || baseDefaultMessages.EMAIL_INVALID())\n .default('')\n}\ntype EmailRequiredSchema = ReturnType<typeof getEmailRequired>\n\n/**\n * Схема валидации опционального поля типа email\n */\nconst getEmailOptional = (props?: Omit<EmailValidationOptions<false>, 'required'>) => {\n const { message, regexp = EMAIL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return z\n .string()\n .refine(\n (value) => {\n if (TypeGuards.isStringEmpty(value)) return true\n return regex.test(value)\n },\n {\n message: message?.invalid || baseDefaultMessages.EMAIL_INVALID()\n }\n )\n .optional()\n .transform((value) => (value?.length === 0 ? undefined : value))\n}\ntype EmailOptionalSchema = ReturnType<typeof getEmailOptional>\n\n/**\n * Схема валидации поля типа email\n * @param {EmailValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @typeParam `regexp` - `RegExp`\n * @typeParam `message` - `{ [min | invalid]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getEmailSchema()\n * })\n * // will returns z.string().min(1).email()\n *\n * @example with optional value\n * z.object({\n * field: zodValidators.base.getEmailSchema({ required: false })\n * })\n * // will returns z.string().min(1).email().optional()\n */\nexport function getEmailSchema(props?: EmailValidationOptions<true>): EmailRequiredSchema\nexport function getEmailSchema(props?: EmailValidationOptions<false>): EmailOptionalSchema\nexport function getEmailSchema<Required extends boolean>(\n props?: EmailValidationOptions<Required>\n): EmailRequiredSchema | EmailOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getEmailRequired(props) : getEmailOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type NumberValidationOptions<Required extends boolean> = {\n /**\n * минимальное значение\n * @default 0\n */\n min?: number\n /**\n * максимальное значение\n * @default undefined\n */\n max?: number\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: Partial<Record<keyof Omit<NumberValidationOptions<Required>, 'message'>, string>>\n}\n\n/**\n * Схема валидации обязательного поля числового типа\n */\nconst getNumberRequired = (props?: Omit<NumberValidationOptions<true>, 'required'>) => {\n const { min, max, message } = props || {}\n\n let schema = z.coerce.number()\n\n if (min) {\n schema = schema.min(min, message?.min || baseDefaultMessages.MIN_VALUE(min))\n }\n\n if (max) {\n schema = schema.max(max, message?.min || baseDefaultMessages.MAX_VALUE(max))\n }\n\n return schema.default(0)\n}\ntype NumberRequiredSchema = ReturnType<typeof getNumberRequired>\n\n/**\n * Схема валидации опционального поля числового типа\n */\nconst getNumberOptional = (props?: Omit<NumberValidationOptions<false>, 'required'>) => {\n return getNumberRequired(props)\n .optional()\n .transform((value) => (!value ? undefined : value))\n}\ntype NumberOptionalSchema = ReturnType<typeof getNumberOptional>\n\n/**\n * Схема валидации опционального поля числового типа\n * @param {NumberValidationOptions} props настройки схемы\n @typeParam `required` - `boolean`\n * @typeParam `min` - `number | undefined` `default: 1`\n * @typeParam `max` - `number | undefined` `default: undefined`\n * @typeParam `message` - `{ [min | max]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required min, max value\n * z.object({\n * field: zodValidators.base.getNumberSchema({ min: 10, max: 20 })\n * })\n * // will returns z.coerce.number().min(10).max(20)\n *\n * @example with optional min, max value\n * z.object({\n * field: zodValidators.base.getNumberSchema({ min: 10, max: 20, required: false })\n * })\n * // will returns z.coerce.number().min(10).max(20).optional()\n */\nexport function getNumberSchema(props?: NumberValidationOptions<true>): NumberRequiredSchema\nexport function getNumberSchema(props?: NumberValidationOptions<false>): NumberOptionalSchema\nexport function getNumberSchema<Required extends boolean>(\n props?: NumberValidationOptions<Required>\n): NumberRequiredSchema | NumberOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getNumberRequired(props) : getNumberOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type PhoneValidationOptions<Required extends boolean> = {\n /**\n * исключает маску в возвращаемом значении\n * @default true\n */\n ignoreMask?: boolean\n /**\n * игнорирует символы для проверки поля исключая данные символы\n * @default /[()+_ -]/g\n */\n maskSymbols?: RegExp | string\n /**\n * указывает что поле обязательное\n */\n required?: Required\n message?: {\n min?: string\n invalidOperator?: string\n }\n}\n\n/**\n * Схема валидации обязательного поля номера телефона\n */\nconst getPhoneRequired = (props?: Omit<PhoneValidationOptions<true>, 'required'>) => {\n const { ignoreMask = true, maskSymbols = /[()+_ -]/g, message } = props || {}\n\n const mask = TypeGuards.isString(maskSymbols) ? new RegExp(maskSymbols) : maskSymbols\n\n let schema = z.string().superRefine((value, context) => {\n const cleanValue = value.replace(mask, '')\n\n const operatorCode = cleanValue.charAt(1)\n\n if (!['3', '4', '5', '6', '7', '9'].includes(operatorCode)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: message?.invalidOperator || baseDefaultMessages.PHONE_INVALID_OPERATOR()\n })\n }\n\n if (cleanValue.length < 11) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: 11,\n inclusive: true,\n type: 'string',\n message: message?.min || baseDefaultMessages.PHONE_NON_EMPTY()\n })\n }\n })\n\n if (ignoreMask) {\n schema = schema.transform((value) => value.replace(mask, '')) as unknown as typeof schema\n }\n\n return schema.default('')\n}\ntype PhoneRequiredSchema = ReturnType<typeof getPhoneRequired>\n\n/**\n * Схема валидации опционального поля номера телефона\n */\nconst getPhoneOptional = (props?: Omit<PhoneValidationOptions<false>, 'required'>) => {\n const { ignoreMask = true, maskSymbols = /[()+_ -]/g, message } = props || {}\n\n const mask = TypeGuards.isString(maskSymbols) ? new RegExp(maskSymbols) : maskSymbols\n\n let schema = z.string().superRefine((value, context) => {\n const cleanValue = value.replace(mask, '')\n\n const operatorCode = cleanValue.charAt(1)\n\n if (!['3', '4', '5', '6', '7', '9'].includes(operatorCode)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: message?.invalidOperator || baseDefaultMessages.PHONE_INVALID_OPERATOR()\n })\n }\n\n if (cleanValue.length < 11) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: 11,\n inclusive: true,\n type: 'string',\n message: message?.min || baseDefaultMessages.PHONE_NON_EMPTY()\n })\n }\n })\n\n if (ignoreMask) {\n schema = schema.transform((value) => value.replace(mask, '')) as unknown as typeof schema\n }\n\n return schema.transform((value) => (!value ? undefined : value))\n}\ntype PhoneOptionalSchema = ReturnType<typeof getPhoneOptional>\n\n/**\n * Схема валидации опционального поля номера телефона\n * @param {PhoneValidationOptions} props настройки схемы\n @typeParam `required` - `boolean`\n * @typeParam `ignoreSeparators` - `boolean | undefined` `default: false`\n * @typeParam `maskSymbols` - `RegExp | undefined` `default: /[()+_ -]/g`\n * @typeParam `message` - `{ [min | invalidOperator]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getPhoneSchema()\n * })\n * // will returns z.string()\n *\n * @example with optional value\n * z.object({\n * field: zodValidators.base.getPhoneSchema({ required: false })\n * })\n * // will returns z.string().optional()\n */\nexport function getPhoneSchema(props?: PhoneValidationOptions<true>): PhoneRequiredSchema\nexport function getPhoneSchema(props?: PhoneValidationOptions<false>): PhoneOptionalSchema\nexport function getPhoneSchema<Required extends boolean>(\n props?: PhoneValidationOptions<Required>\n): PhoneRequiredSchema | PhoneOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getPhoneRequired(props) : getPhoneOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type SelectSingleValidationOptions<Required extends boolean, Multi extends boolean = false> = {\n /**\n * включает валидацию мульти селекта\n * @default false\n */\n multiple?: Multi\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: {\n single?: string\n multiple?: string\n }\n}\n\ntype SelectMultipleValidationOptions<Required extends boolean, Multi extends boolean = true> = SelectSingleValidationOptions<\n Required,\n Multi\n> & {\n /**\n * минимальное количество элементов\n * @default 0\n */\n minLength?: number\n /**\n * максимальное количество элементов\n * @default undefined\n */\n maxLength?: number\n /**\n * фиксированное количество элементов\n * @default undefined\n */\n length?: number\n message?: SelectSingleValidationOptions<Required, Multi> & {\n minLength?: string\n maxLength?: string\n length?: string\n }\n}\n\ntype SelectValidationOptions<Required extends boolean, Multi extends boolean> = Multi extends true\n ? SelectMultipleValidationOptions<Required, Multi>\n : SelectSingleValidationOptions<Required, Multi>\n\n/**\n * Схема валидации обязательного поля типа select\n */\nconst getSelectRequired = <Required extends boolean, Multi extends boolean>(props?: SelectValidationOptions<Required, Multi>) => {\n const { message } = props || {}\n\n const selectSchema = z\n .string()\n .min(1, message?.single || baseDefaultMessages.SELECT_NON_EMPTY())\n .nullable()\n .refine((value) => Boolean(value), message?.single || baseDefaultMessages.SELECT_NON_EMPTY())\n .default(null)\n\n if (props?.multiple) {\n let arraySchema = z\n .array(selectSchema)\n .min(props?.minLength || 0, message?.multiple || baseDefaultMessages.SELECT_MULTIPLE_MIN_LENGTH(props?.minLength || 0))\n\n if (props?.length) {\n return arraySchema\n .length(props.length, props.message?.length || baseDefaultMessages.SELECT_FIX_LENGTH(props.length))\n .default([])\n } else if (props?.maxLength) {\n arraySchema = arraySchema.max(\n props.maxLength,\n props.message?.maxLength || baseDefaultMessages.SELECT_MULTIPLE_MAX_LENGTH(props.maxLength)\n )\n }\n\n return arraySchema.default([])\n }\n\n return selectSchema\n}\ntype SelectRequiredSchema = ReturnType<typeof getSelectRequired>\n\n/**\n * Схема валидации опционального поля типа select\n */\nfunction getSelectOptional<Required extends boolean, Multi extends boolean>(\n props?: Omit<SelectValidationOptions<Required, Multi>, 'message'>\n) {\n const selectSchema = z.string().nullable().optional()\n\n if (props?.multiple) {\n return z.array(selectSchema).optional()\n }\n\n return selectSchema\n}\ntype SelectOptionalSchema = ReturnType<typeof getSelectOptional>\n\n/**\n * Схема валидации опционального поля типа select\n * @param {SelectValidationOptions} props настройки схемы\n @typeParam `required` - `boolean`\n * @typeParam `multiple` - `boolean`\n * @typeParam `minLength` - `number | undefined`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required single value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ multiple: false })\n * })\n * // will returns z.string().nullable()\n *\n * @example with required multiple value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ multiple: true })\n * })\n * // will returns z.array(z.string().nullable())\n *\n * @example with optional single value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ required: false, multiple: false })\n * })\n * // will returns z.string().nullable().optional()\n *\n * @example with optional multiple value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ required: false, multiple: true })\n * })\n * // will returns z.array(z.string().nullable().optional()).optional()\n */\nexport function getSelectSchema<Multi extends boolean>(props?: SelectValidationOptions<true, Multi>): SelectRequiredSchema\nexport function getSelectSchema<Multi extends boolean>(props?: SelectValidationOptions<false, Multi>): SelectOptionalSchema\nexport function getSelectSchema<Multi extends boolean, Required extends boolean>(\n props?: SelectValidationOptions<Required, Multi>\n): SelectRequiredSchema | SelectOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getSelectRequired(props) : getSelectOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type StringValidationOptions<Required extends boolean> = {\n /**\n * минимальное количество символов\n * @default 1\n */\n min?: number\n /**\n * максимальное количество символов\n * @default undefined\n */\n max?: number\n /**\n * фиксированная длина символов\n */\n length?: number\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: Partial<Record<keyof Omit<StringValidationOptions<Required>, 'message'> | 'root', string>>\n}\n\n/**\n * Схема валидации обязательного поля строкового типа\n */\nconst getStringRequired = (props?: Omit<StringValidationOptions<true>, 'required'>) => {\n const { min, max, length, message } = props || {}\n\n let schema = z.string({ message: message?.root })\n\n if (min) {\n schema = schema.min(min, { message: message?.min || baseDefaultMessages.MIN_LENGTH(min) })\n }\n\n if (max) {\n schema = schema.max(max, { message: message?.max || baseDefaultMessages.MAX_LENGTH(max) })\n }\n\n if (length) {\n schema = schema.length(length, { message: message?.length || baseDefaultMessages.FIX_LENGTH(length) })\n }\n\n return schema.refine((value) => Boolean(value.length), { message: message?.min || baseDefaultMessages.NON_EMPTY() }).default('')\n}\ntype StringRequiredSchema = ReturnType<typeof getStringRequired>\n\n/**\n * Схема валидации обязательного поля строкового типа\n */\nconst getStringOptional = (props?: Omit<StringValidationOptions<false>, 'required'>) => {\n const { min, max, length, message } = props || {}\n\n let schema = z.string({ message: message?.root })\n\n if (min) {\n schema = schema.min(min, { message: message?.min || baseDefaultMessages.MIN_LENGTH(min) })\n }\n\n if (max) {\n schema = schema.max(max, { message: message?.max || baseDefaultMessages.MAX_LENGTH(max) })\n }\n\n if (length) {\n schema = schema.length(length, { message: message?.length || baseDefaultMessages.FIX_LENGTH(length) })\n }\n\n return schema.optional().transform((value) => (!value?.length ? undefined : value))\n}\ntype StringOptionalSchema = ReturnType<typeof getStringOptional>\n\n/**\n * Схема валидации обязательного поля строкового типа\n * @param {StringValidationOptions} props настройки схемы\n * @typeParam `min` - `number | undefined` `default: 1`\n * @typeParam `max` - `number | undefined` `default: undefined`\n * @typeParam `message` - `{ [min | max]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required min value\n * z.object({\n * field: zodValidators.base.getStringSchema({ min: 10 })\n * })\n * // will returns z.string().min(10)\n *\n * @example with required min, max value\n * z.object({\n * field: zodValidators.base.getStringSchema({ min: 10, max: 20 })\n * })\n * // will returns z.string().min(10).max(20)\n *\n * @example with optional min value\n * z.object({\n * field: zodValidators.base.getStringSchema({ required: false, min: 10 })\n * })\n * // will returns z.string().min(10).optional()\n *\n * @example with optional min, max value\n * z.object({\n * field: zodValidators.base.getStringSchema({ required: false, min: 10, max: 20 })\n * })\n * // will returns z.string().min(10).max(20).optional()\n */\nexport function getStringSchema(props?: StringValidationOptions<true>): StringRequiredSchema\nexport function getStringSchema(props?: StringValidationOptions<false>): StringOptionalSchema\nexport function getStringSchema<Required extends boolean>(\n props?: StringValidationOptions<Required>\n): StringRequiredSchema | StringOptionalSchema {\n const { required = true, ...restProps } = props || {}\n\n return required ? getStringRequired(restProps) : getStringOptional(restProps)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type UnionValidationOptions<Required extends boolean, T extends z.Primitive> = {\n /**\n * сообщение об ошибке\n */\n message?: ((values: readonly T[]) => string) | string\n errorMap?: z.ZodErrorMap\n /**\n * сообщение об ошибке при не правильном типе значение\n */\n invalid_type_error?: string\n /**\n * сообщение об ошибке при отсутствии значения\n */\n required_error?: string\n /**\n * описание схемы\n */\n description?: string\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n}\n\n/**\n * Схема валидации обязательного поля из выборки\n */\nconst getUnionRequired = <T extends z.Primitive>(\n values: [T, T, ...T[]],\n props?: Omit<UnionValidationOptions<true, T>, 'required'>\n) => {\n const { message, ...restProps } = props || {}\n\n const [first, second, ...other] = values.map((value) => z.literal(value))\n\n const errorMessage = (() => {\n if (message) {\n return typeof message === 'function' ? message(values) : message\n }\n\n return baseDefaultMessages.VALUE_OUT_OF_RANGE(values)\n })()\n\n return z\n .union([first, second, ...other], {\n message: errorMessage,\n ...restProps\n })\n .nullable()\n .refine(Boolean, baseDefaultMessages.NON_EMPTY())\n .default(null)\n}\ntype UnionRequiredSchema<T extends z.Primitive> = ReturnType<typeof getUnionRequired<T>>\n\n/**\n * Схема валидации обязательного поля из выборки\n */\nconst getUnionOptional = <T extends z.Primitive>(values: [T, T, ...T[]], props?: UnionValidationOptions<false, T>) => {\n return getUnionRequired(values, props).optional()\n}\ntype UnionOptionalSchema<T extends z.Primitive> = ReturnType<typeof getUnionOptional<T>>\n\n/**\n * Схема валидации обязательного поля из выборки\n * @param {z.Primitive} values литералы\n * @param {z.RawCreateParams & { message: (values: z.Primitive[]) => string }} props настройки схемы\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required union value\n * z.object({\n * field: zodValidators.base.getUnionSchema(['A', 'B'] as const)\n * }) ^ it need to infer literal type\n * // will returns z.union([z.literal('A'), z.literal('B')])\n *\n * @example with optional union value\n * z.object({\n * field: zodValidators.base.getUnionSchema(['A', 'B'] as const, { required: false })\n * }) ^ it need to infer literal type\n * // will returns z.union([z.literal('A'), z.literal('B')]).optional()\n */\nexport function getUnionSchema<T extends z.Primitive>(\n values: [T, T, ...T[]],\n props?: UnionValidationOptions<true, T>\n): UnionRequiredSchema<T>\nexport function getUnionSchema<T extends z.Primitive>(\n values: [T, T, ...T[]],\n props?: UnionValidationOptions<false, T>\n): UnionOptionalSchema<T>\nexport function getUnionSchema<T extends z.Primitive, Required extends boolean>(\n values: [T, T, ...T[]],\n props?: UnionValidationOptions<Required, T>\n): UnionRequiredSchema<T> | UnionOptionalSchema<T> {\n const { required, ...restProps } = props || {}\n\n return required ? getUnionRequired(values, restProps) : getUnionOptional(values, restProps)\n}\n","import { string } from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type UrlValidationOptions<Required extends boolean> = {\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n /**\n * Регулярное выражение для проверки url на валидность\n */\n regexp?: RegExp | string\n message?: {\n min?: string\n invalid?: string\n }\n}\n\nconst URL_REGEX =\n /^(http:\\/\\/www\\.|https:\\/\\/www\\.|http:\\/\\/|https:\\/\\/)?[a-z0-9]+([-.]{1}[a-z0-9]+)*\\.[a-z]{2,5}(:[0-9]{1,5})?(\\/.*)?$/\n\n/**\n * Схема валидации обязательного поля ссылки\n */\nconst getUrlRequired = (props?: Omit<UrlValidationOptions<true>, 'required'>) => {\n const { message, regexp = URL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return string()\n .min(1, message?.min || baseDefaultMessages.NON_EMPTY())\n .regex(regex, message?.invalid || baseDefaultMessages.INVALID_URL())\n .default('')\n}\ntype UrlRequiredSchema = ReturnType<typeof getUrlRequired>\n\n/**\n * Схема валидации опционального поля ссылки\n */\nconst getUrlOptional = (props?: Omit<UrlValidationOptions<false>, 'required'>) => {\n const { message, regexp = URL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return string()\n .refine((value) => {\n if (TypeGuards.isStringEmpty(value)) return true\n return regex.test(value)\n }, message?.invalid || baseDefaultMessages.INVALID_URL())\n .optional()\n .transform((value) => (!value?.length ? undefined : value))\n}\ntype UrlOptionalSchema = ReturnType<typeof getUrlOptional>\n\nexport function getUrlSchema(props?: UrlValidationOptions<true>): UrlRequiredSchema\nexport function getUrlSchema(props?: UrlValidationOptions<false>): UrlOptionalSchema\n/**\n * Схема валидации поля ссылки\n * @param {UrlValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @typeParam `regexp` - `RegExp`\n * @typeParam `message` - `{ [min | invalid]: string }`\n * @returns схема валидации поля в соответствии с настройками\n */\nexport function getUrlSchema<Required extends boolean>(\n props?: UrlValidationOptions<Required>\n): UrlRequiredSchema | UrlOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getUrlRequired(props) : getUrlOptional(props)\n}\n","import { getDateSchema } from './date.validators'\nimport { getEmailSchema } from './email.validators'\nimport { getNumberSchema } from './number.validators'\nimport { getPhoneSchema } from './phone.validators'\nimport { getSelectSchema } from './select.validators'\nimport { getStringSchema } from './string.validators'\nimport { getUnionSchema } from './union.validators'\nimport { getUrlSchema } from './url.validators'\n\nexport const baseValidationSchemas = {\n getStringSchema,\n getEmailSchema,\n getSelectSchema,\n getNumberSchema,\n getPhoneSchema,\n getDateSchema,\n getUnionSchema,\n getUrlSchema\n}\n","import z from 'zod'\n\ntype ZodUtilsGetDefaultsOptions = {\n /**\n * Вставить в массив значение, исходя из внутренней схемы z.array\n */\n fillArrayWithValue?: boolean\n}\n\nexport class ZodUtils {\n /**\n * Функция для получения значения по умолчанию исходя из схемы\n * @param zodSchema схема формы\n * @param options настройки генерации значений по умолчанию\n * @returns объект значений по умолчанию\n *\n * @example\n * const schema = z.object({\n * name: zodValidators.base.getStringSchema(),\n * role: zodValidators.base.getUnionSchema(['UNKNOWN', 'ADMIN', 'MODERATOR', 'USER'] as const),\n * info: z.object({\n * address: zodValidators.base.getStringSchema(),\n * phone: zodValidators.base.getPhoneSchema({ ignoreMask: true }),\n * age: zodValidators.base.getNumberSchema()\n * })\n * })\n *\n * const defaultValues = ZodUtils.getZodDefaults(schema)\n *\n * // default values will be inferred from schema\n * // {\n * // name: '',\n * // role: 'UNKNOWN',\n * // info: {\n * // address: '',\n * // phone: '',\n * // age: 0\n * // }\n * // }\n */\n static getZodDefaults<ZodSchema extends z.AnyZodObject, Schema = z.TypeOf<ZodSchema>>(\n zodSchema: ZodSchema | z.ZodEffects<ZodSchema>,\n options?: ZodUtilsGetDefaultsOptions\n ): Schema {\n const { fillArrayWithValue } = options || {}\n\n if (zodSchema instanceof z.ZodEffects) {\n if (zodSchema.innerType() instanceof z.ZodEffects) {\n return this.getZodDefaults(zodSchema.innerType(), options)\n }\n\n return this.getZodDefaults(z.ZodObject.create(zodSchema.innerType().shape), options)\n }\n\n const getDefaultValue = (schema: z.ZodTypeAny): unknown => {\n switch (true) {\n case schema._def.typeName === 'ZodDefault' || schema instanceof z.ZodDefault:\n return (schema as z.ZodDefault<ZodSchema>)._def.defaultValue()\n case schema._def.typeName === 'ZodOptional' || schema instanceof z.ZodOptional:\n return undefined\n case schema._def.typeName === 'ZodNullable' || schema instanceof z.ZodNullable:\n return null\n case schema._def.typeName === 'ZodArray' || schema instanceof z.ZodArray:\n return fillArrayWithValue ? [getDefaultValue((schema as z.ZodArray<ZodSchema>).element)] : []\n case schema._def.typeName === 'ZodObject' || schema instanceof z.ZodObject:\n return this.getZodDefaults(schema as z.ZodObject<z.ZodRawShape>, options)\n case schema._def.typeName === 'ZodUnion' || schema instanceof z.ZodUnion:\n return getDefaultValue(schema._def.options[0])\n case schema._def.typeName === 'ZodLiteral' || schema instanceof z.ZodLiteral:\n return schema._def.value\n case schema._def.typeName === 'ZodDiscriminatedUnion' || schema instanceof z.ZodDiscriminatedUnion:\n return getDefaultValue(schema._def.options[0])\n case schema._def.typeName === 'ZodEnum' || schema instanceof z.ZodEnum:\n return schema._def.values[0]\n case schema._def.typeName === 'ZodString' || schema instanceof z.ZodString:\n return ''\n case schema._def.typeName === 'ZodNumber' || schema instanceof z.ZodNumber:\n return 0\n case schema._def.typeName === 'ZodBoolean' || schema instanceof z.ZodBoolean:\n return false\n case !('innerType' in schema._def):\n return undefined\n default:\n return getDefaultValue(schema._def.innerType)\n }\n }\n\n const defaults = {} as Schema\n\n const schemaEntries = Object.entries(zodSchema.shape) as [keyof Schema, z.ZodAny][]\n\n schemaEntries.map(([key, value]) => {\n defaults[key] = getDefaultValue(value) as Schema[keyof Schema]\n })\n\n return defaults\n }\n\n /**\n * Функция для объединения zod схождений\n * @param {ZodIntersection} zodSchema\n * @returns объединенная схема двух схождений\n *\n * @example\n * let schema = z.object({\n * foo: z.string()\n * })\n * // this will return intersection and we need\n * // to merge its left to right schema's\n * .and(\n * z.object({\n * bar: z.string()\n * })\n * )\n *\n * schema = ZodUtils.zodMergeIntersection(schema)\n *\n * // schema will be\n * z.object({\n * foo: z.string(),\n * bar: z.string()\n * })\n */\n static zodMergeIntersection<ZodLeft extends z.ZodTypeAny, ZodRight extends z.ZodTypeAny>(\n zodSchema: z.ZodIntersection<ZodLeft, ZodRight>\n ): z.ZodObject<z.objectUtil.MergeShapes<z.TypeOf<ZodLeft>, z.TypeOf<ZodRight>>> {\n const { left, right } = zodSchema._def\n\n const leftSchema =\n left instanceof z.ZodDiscriminatedUnion || left._def.typeName === 'ZodDiscriminatedUnion' ? left._def.options[0] : left\n const rightSchema =\n right instanceof z.ZodDiscriminatedUnion || left._def.typeName === 'ZodDiscriminatedUnion' ? right._def.options[0] : right\n\n if (leftSchema instanceof z.ZodObject && rightSchema instanceof z.ZodObject) {\n return leftSchema.merge(rightSchema)\n }\n\n throw new Error(`Cannot merge schema type ${rightSchema._def.typeName} to ${leftSchema._def.typeName}`)\n }\n}\n","export const fioDefaultMessages = {\n NON_EMPTY: () => 'Поле обязательно для заполнения',\n VALUE_NO_WHITESPACE: () => 'Укажите фамилию, имя и отчество через пробел',\n ONLY_CYRILLIC: () => 'Данные должны быть написаны кириллицей',\n NAME_OR_SURNAME_NON_EMPTY: () => 'Укажите имя и фамилию',\n INVALID_NAME: () => 'Неверно введено имя',\n INVALID_SURNAME: () => 'Неверно введена фамилия',\n INVALID_PATRONYMIC: () => 'Неверно введено отчество'\n}\n\nexport const fioRegex = {\n ONLY_CYRILLIC: /[\\u0400-\\u04FF\\u00CB\\u00EB -]/g,\n CHECK_HYPHEN: /^(?:[^-]+(?:-[^-]+){0,4}|[^-]+)$/,\n PATRONYMIC: /^[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4}(?:\\s+[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4})?$/i\n}\n","import z from 'zod'\nimport { fioDefaultMessages, fioRegex } from './dadata.constants'\n\nconst getFioParts = (value: string) => {\n const [surname, name, ...patronymicParts] = value.trim().replace(/\\s+/g, ' ').split(' ')\n const patronymic = patronymicParts.join(' ')\n\n return { surname, name, patronymic }\n}\n\nexport type FioValidationOptions<Required extends boolean> = {\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: {\n root?: string\n nameOrSurnameEmpty?: string\n invalidName?: string\n invalidSurname?: string\n invalidPatronymic?: string\n }\n}\n\n/**\n * Схема валидации обязательного поля автозаполнения ФИО\n */\nconst getFioRequired = (props?: Omit<FioValidationOptions<true>, 'required'>) => {\n const { message } = props || {}\n\n const { nameOrSurnameEmpty, invalidSurname, invalidPatronymic, invalidName } = message || {}\n\n return z\n .string()\n .superRefine((value, context) => {\n const { name, surname, patronymic } = getFioParts(value)\n\n if (!fioRegex.ONLY_CYRILLIC.test(value)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: fioDefaultMessages.ONLY_CYRILLIC()\n })\n }\n\n if (!name || !surname) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: nameOrSurnameEmpty || fioDefaultMessages.NAME_OR_SURNAME_NON_EMPTY()\n })\n }\n\n if (!fioRegex.CHECK_HYPHEN.test(name)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: invalidName || fioDefaultMessages.INVALID_NAME()\n })\n }\n\n if (!fioRegex.CHECK_HYPHEN.test(surname)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: invalidSurname || fioDefaultMessages.INVALID_SURNAME()\n })\n }\n\n if (patronymic) {\n if (!fioRegex.PATRONYMIC.test(patronymic)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: invalidPatronymic || fioDefaultMessages.INVALID_PATRONYMIC()\n })\n }\n }\n })\n .transform((value) => value.trimEnd())\n .default('')\n}\ntype FioRequiredSchema = ReturnType<typeof getFioRequired>\n\n/**\n * Схема валидации опционального поля автозаполнения ФИО\n */\nconst getFioOptional = (props?: Omit<FioValidationOptions<false>, 'required'>) => {\n return getFioRequired(props)\n .optional()\n .transform((value) => (!value?.length ? undefined : value))\n}\ntype FioOptionalSchema = ReturnType<typeof getFioOptional>\n\n/**\n * Схема валидации поля автозаполнения ФИО\n * @param {DateValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getFioSchema()\n * })\n * // will returns z.string()\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getFioSchema({ required: false })\n * })\n * // will returns z.string().optional()\n */\nexport function getFioSchema(props?: FioValidationOptions<true>): FioRequiredSchema\nexport function getFioSchema(props?: FioValidationOptions<false>): FioOptionalSchema\nexport function getFioSchema<Required extends boolean>(\n props?: FioValidationOptions<Required>\n): FioRequiredSchema | FioOptionalSchema {\n const { required = true, ...restProps } = props || {}\n\n return required ? getFioRequired(restProps) : getFioOptional(restProps)\n}\n","import { getFioSchema } from './fio.validators'\nexport type * from './fio.validators'\nexport { fioDefaultMessages } from './dadata.constants'\n\nexport const dadataValidationSchemas = {\n getFioSchema\n}\n","export * from './regExp'\nexport * from './messages'\nexport * from './zodValidation'\nexport * from './base'\nexport type * from './dadata'\nexport * from './utils'\nimport { baseValidationSchemas } from './base'\nimport { dadataValidationSchemas } from './dadata'\n\nexport const zodValidators = {\n base: baseValidationSchemas,\n dadata: dadataValidationSchemas\n}\n"],"names":["RgxUnicode","RgxCheckForHyphen","RgxPatronymic","VALIDATION_MESSAGES","formattedDadataFio","value","parts","surname","name","patronymicArr","patronymic","zodDadataFioSchema","z","ctx","zodCalendarValidate","val","day","month","year","parsed","parse","isValid","zodPhoneSchema","operatorCode","zodOtpCodeSchema","context","baseDefaultMessages","min","max","length","range","date","TypeGuards","formatDateToLocaleString","getDateRequired","props","iso","pattern","DATE_VISIBLE_PATTERN","message","validSymbolsLength","getDateOptional","getDateSchema","required","EMAIL_REGEX","getEmailRequired","regexp","regex","getEmailOptional","getEmailSchema","getNumberRequired","schema","getNumberOptional","getNumberSchema","getPhoneRequired","ignoreMask","maskSymbols","mask","cleanValue","getPhoneOptional","getPhoneSchema","getSelectRequired","selectSchema","arraySchema","_a","_b","getSelectOptional","getSelectSchema","getStringRequired","getStringOptional","getStringSchema","restProps","getUnionRequired","values","first","second","other","errorMessage","getUnionOptional","getUnionSchema","URL_REGEX","getUrlRequired","string","getUrlOptional","getUrlSchema","baseValidationSchemas","ZodUtils","zodSchema","options","fillArrayWithValue","getDefaultValue","defaults","key","left","right","leftSchema","rightSchema","fioDefaultMessages","fioRegex","getFioParts","patronymicParts","getFioRequired","nameOrSurnameEmpty","invalidSurname","invalidPatronymic","invalidName","getFioOptional","getFioSchema","dadataValidationSchemas","zodValidators"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"validation.js","sources":["../lib/shared/validation/regExp.ts","../lib/shared/validation/messages.ts","../lib/shared/validation/zodValidation/dadataFio.ts","../lib/shared/validation/zodValidation/calendar.ts","../lib/shared/validation/zodValidation/phone.ts","../lib/shared/validation/zodValidation/otpCode.ts","../lib/shared/validation/base/base.constants.ts","../lib/shared/validation/base/date.validators.ts","../lib/shared/validation/base/email.validators.ts","../lib/shared/validation/base/number.validators.ts","../lib/shared/validation/base/phone.validators.ts","../lib/shared/validation/base/select.validators.ts","../lib/shared/validation/base/string.validators.ts","../lib/shared/validation/base/union.validators.ts","../lib/shared/validation/base/url.validators.ts","../lib/shared/validation/base/base.validators.ts","../lib/shared/validation/utils/zodUtils.ts","../lib/shared/validation/dadata/dadata.constants.ts","../lib/shared/validation/dadata/fio.validators.ts","../lib/shared/validation/dadata/index.ts","../lib/shared/validation/index.ts"],"sourcesContent":["export const RgxUnicode = /^[\\u0400-\\u04FF\\u00CB\\u00EB -]+$/ // Диапазон символов Unicode, включающий кириллические символы.*\nexport const RgxCheckForHyphen = /^(?:[^-]+(?:-[^-]+){0,4}|[^-]+)$/ // Проверяет количество дефисов a-b-c-d-e Валидный (до 4 дефисов), не валидный*\nexport const RgxPatronymic =\n /^[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4}(?:\\s+[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4})?$/i //Отчество для дадаты Отчество углы-ули Отчество-Отчество\n","export const VALIDATION_MESSAGES = {\n REQUIRED: 'Поле обязательно к заполнению',\n MIN_LENGTH: 'Минимальная длина символов должна быть не менее',\n MAX_LENGTH: 'Максимальная длина символов должна быть не более',\n FIX_LENGTH: 'Длина символов должна быть равна',\n MAX_LENGTH_ELEMENTS: 'Максимальное количество элементов должно быть не более',\n MIN_LENGTH_ELEMENTS: 'Минимальное количество элементов должно быть не менее',\n FIX_LENGTH_ELEMENTS: 'Количество элементов должно быть равно',\n INVALID_VALUE: 'Поле заполнено некорректно',\n INVALID_DATE: 'Введите корректную дату',\n FUTURE_DATE_NOT_ALLOWED: 'Нельзя выбрать дату позже текущей',\n INVALID_URL: 'Некорректная ссылка'\n} as const\n","import { z } from 'zod'\nimport { RgxCheckForHyphen, RgxPatronymic, RgxUnicode } from '../regExp'\n\nexport const formattedDadataFio = (value: string) => {\n const parts = value.trim().replace(/\\s+/g, ' ').split(' ')\n const [surname, name, ...patronymicArr] = parts\n const patronymic = patronymicArr?.join(' ')\n\n return {\n surname,\n name,\n patronymic\n }\n}\n\nexport const zodDadataFioSchema = z\n .string({ invalid_type_error: 'Обязательно к заполнению', required_error: 'Обязательно к заполнению' })\n .superRefine((value, ctx) => {\n if (value === '') {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Введите имя и фамилию'\n })\n }\n\n if (!RgxUnicode.test(value)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Должна быть только кириллица'\n })\n }\n\n const { surname, name, patronymic } = formattedDadataFio(value)\n\n if (!surname || !name) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Введите имя и фамилию'\n })\n }\n\n if (!RgxCheckForHyphen.test(name)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Неверно введено имя'\n })\n }\n\n if (!RgxCheckForHyphen.test(surname)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Неверно введена фамилия'\n })\n }\n\n if (patronymic) {\n if (!RgxPatronymic.test(patronymic)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Неверно введено отчество'\n })\n }\n }\n })\n","import { isValid, parse } from 'date-fns'\nimport { z } from 'zod'\nimport { VALIDATION_MESSAGES } from '../messages'\n\nexport const zodCalendarValidate = z\n .string()\n .length(10, { message: VALIDATION_MESSAGES.INVALID_DATE })\n .superRefine((val, ctx) => {\n const [day, month, year] = val?.split('.') ?? ''\n const parsed = parse(`${day}/${month}/${year}`, 'dd/MM/yyyy', new Date())\n\n if (+year <= 1950) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: VALIDATION_MESSAGES.INVALID_DATE\n })\n }\n\n if (!isValid(parsed)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: VALIDATION_MESSAGES.INVALID_DATE\n })\n }\n\n if (new Date().getTime() < new Date(parsed).getTime()) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: VALIDATION_MESSAGES.FUTURE_DATE_NOT_ALLOWED\n })\n }\n })\n","import { z } from 'zod'\n\nexport const zodPhoneSchema = z\n .string()\n .superRefine((value, ctx) => {\n const operatorCode = value.charAt(0)\n\n if (!['3', '4', '5', '6', '9'].includes(operatorCode)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Код города/оператора должен начинаться с цифры 3, 4, 5, 6 или 9'\n })\n }\n\n if (value.length !== 10) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: 'Введите номер телефона полностью'\n })\n }\n })\n .transform((value) => `7${value}`)\n","import { z } from 'zod'\nimport { VALIDATION_MESSAGES } from '../messages'\n\nexport const zodOtpCodeSchema = z.coerce\n .number()\n .min(1000, `${VALIDATION_MESSAGES.FIX_LENGTH} 4`)\n .max(9999, `${VALIDATION_MESSAGES.FIX_LENGTH} 4`)\n .nullable()\n .superRefine((value, context) => {\n if (value === null) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_type,\n expected: 'number',\n received: 'null',\n message: `${VALIDATION_MESSAGES.FIX_LENGTH} 4`\n })\n }\n })\n .default(null)\n","import { type Primitive } from 'zod'\nimport { formatDateToLocaleString } from '$/shared/ui'\nimport { TypeGuards } from '$/shared/utils'\n\nexport const baseDefaultMessages = {\n NON_EMPTY: () => 'Поле не может быть пустым',\n MIN_LENGTH: (min: number) => `Поле должно содержать минимум символов: ${min}`,\n MAX_LENGTH: (max: number) => `Поле должно содержать максимум символов: ${max}`,\n FIX_LENGTH: (length: number) => `Поле должно быть фиксированной длины символов: ${length}`,\n MIN_VALUE: (min: number) => `Значение не может быть меньше чем ${min}`,\n MAX_VALUE: (max: number) => `Значение не может быть больше чем ${max}`,\n PHONE_NON_EMPTY: () => 'Номер телефона должен состоять из 11 цифр',\n PHONE_INVALID_OPERATOR: () => 'Код города/оператора должен начинаться с цифры 3, 4, 5, 6 или 9',\n EMAIL_INVALID: () => 'Email введен некорректно. Пример: example@domain.ru',\n EMAIL_NON_EMPTY: () => 'Введите адрес электронной почты',\n SELECT_NON_EMPTY: () => 'Выберите один из вариантов',\n SELECT_MULTIPLE_MIN_LENGTH: (length: number) => `Выберите не менее ${length} вариантов`,\n SELECT_MULTIPLE_MAX_LENGTH: (length: number) => `Выберите не более ${length} вариантов`,\n SELECT_FIX_LENGTH: (length: number) => `Поле должно быть фиксированного количества вариантов: ${length}`,\n DATE_INVALID_FORMAT: () => 'Дата указана некорректно',\n DATE_NON_EMPTY: () => 'Укажите дату',\n VALUE_OUT_OF_RANGE: <T extends Primitive>(range: T[]) => `Выберите один из вариантов ${range.join(', ')}`,\n DATE_MIN: (min: Date | string) => {\n const date = TypeGuards.isString(min) ? new Date(min) : min\n\n return `Выбранная дата должна быть не раньше ${formatDateToLocaleString(date)}`\n },\n DATE_MAX: (max: Date | string) => {\n const date = TypeGuards.isString(max) ? new Date(max) : max\n\n return `Выбранная дата должна быть не позже ${formatDateToLocaleString(date)}`\n },\n INVALID_URL: () => 'Ссылка введена некорректно. Пример: https://example.com, example.com'\n}\n","import { isValid, parse } from 'date-fns'\nimport z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { DATE_VISIBLE_PATTERN } from '$/shared/ui'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type DateValidationOptions<Required extends boolean> = {\n /**\n * валидация строки с учетом ISO формата\n * @default true\n */\n iso?: boolean\n /**\n * шаблон для валидации строки (будет проигнорирован, если `iso = true`)\n * @default 'dd.MM.yyyy'\n */\n pattern?: string\n /**\n * минимальная дата\n * `Date | ISO string`\n */\n min?: Date | string\n /**\n * максимальная дата\n * `Date | ISO string`\n */\n max?: Date | string\n /**\n * указывает что поле обязательное\n */\n required?: Required\n message?: {\n min?: string\n max?: string\n invalidDate?: string\n }\n}\n\n/**\n * Схема валидации обязательного поля даты\n */\nconst getDateRequired = (props?: Omit<DateValidationOptions<boolean>, 'required'>) => {\n const { iso = true, pattern = DATE_VISIBLE_PATTERN, min, max, message } = props || {}\n\n return z\n .string()\n .min(8, message?.min || baseDefaultMessages.DATE_NON_EMPTY())\n .superRefine((value, context) => {\n const validSymbolsLength = pattern.replace(/\\W/g, '').length\n const cleanedValue = value.replace(/[._-]/g, '')\n\n if (cleanedValue.length < validSymbolsLength) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: validSymbolsLength,\n type: 'date',\n inclusive: true,\n message: message?.min || baseDefaultMessages.DATE_NON_EMPTY()\n })\n }\n\n if (iso) {\n let date: Date | null = null\n\n try {\n date = new Date(value)\n } catch {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date!.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date!.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n } else {\n const date = parse(value, pattern, new Date())\n\n if (!isValid(date)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n }\n })\n .default('')\n}\ntype DateRequiredSchema = ReturnType<typeof getDateRequired>\n\n/**\n * Схема валидации опционального поля даты\n */\nconst getDateOptional = (props?: Omit<DateValidationOptions<boolean>, 'required'>) => {\n const { iso = true, pattern = DATE_VISIBLE_PATTERN, min, max, message } = props || {}\n\n return z\n .string()\n .transform((value) => (!value ? undefined : value))\n .superRefine((value, context) => {\n if (TypeGuards.isString(value) && Boolean(value.length)) {\n const validSymbolsLength = pattern.replace(/\\W/g, '').length\n const cleanedValue = value.replace(/[._-]/g, '')\n\n if (cleanedValue.length < validSymbolsLength) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: validSymbolsLength,\n type: 'date',\n inclusive: true,\n message: message?.min || baseDefaultMessages.DATE_NON_EMPTY()\n })\n }\n\n if (iso) {\n let date: Date | null = null\n\n try {\n date = new Date(value)\n } catch {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date!.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date!.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n } else {\n const date = parse(value, pattern, new Date())\n\n if (!isValid(date)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.invalidDate || baseDefaultMessages.DATE_INVALID_FORMAT()\n })\n }\n\n if (min) {\n if (date.getTime() < (TypeGuards.isString(min) ? new Date(min).getTime() : min.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.min || baseDefaultMessages.DATE_MIN(min)\n })\n }\n }\n\n if (max) {\n if (date.getTime() > (TypeGuards.isString(max) ? new Date(max).getTime() : max.getTime())) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_date,\n message: message?.max || baseDefaultMessages.DATE_MAX(max)\n })\n }\n }\n }\n }\n })\n .optional()\n}\ntype DateOptionalSchema = ReturnType<typeof getDateOptional>\n\n/**\n * Схема валидации поля даты\n * @param {DateValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @typeParam `iso` - `boolean | undefined`\n * @typeParam `pattern` - `string | undefined`\n * @typeParam `message` - `{ [min | invalidOperator]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getDateSchema()\n * })\n * // will returns z.string()\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getDateSchema({ required: false })\n * })\n * // will returns z.string().optional()\n */\nexport function getDateSchema(props?: DateValidationOptions<true>): DateRequiredSchema\nexport function getDateSchema(props?: DateValidationOptions<false>): DateOptionalSchema\nexport function getDateSchema<Required extends boolean>(\n props?: DateValidationOptions<Required>\n): DateRequiredSchema | DateOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getDateRequired(props) : getDateOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type EmailValidationOptions<Required extends boolean> = {\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n /**\n * Регулярное выражение для проверки email на валидность\n */\n regexp?: RegExp | string\n message?: {\n min?: string\n invalid?: string\n }\n}\n\nconst EMAIL_REGEX = /^[\\w-.]+@([\\w-]+\\.)+[\\w-]{2,4}$/g\n\n/**\n * Схема валидации обязательного поля типа email\n */\nconst getEmailRequired = (props?: Omit<EmailValidationOptions<true>, 'required'>) => {\n const { message, regexp = EMAIL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return z\n .string()\n .min(1, message?.min || baseDefaultMessages.EMAIL_NON_EMPTY())\n .regex(regex, message?.invalid || baseDefaultMessages.EMAIL_INVALID())\n .default('')\n}\ntype EmailRequiredSchema = ReturnType<typeof getEmailRequired>\n\n/**\n * Схема валидации опционального поля типа email\n */\nconst getEmailOptional = (props?: Omit<EmailValidationOptions<false>, 'required'>) => {\n const { message, regexp = EMAIL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return z\n .string()\n .refine(\n (value) => {\n if (TypeGuards.isStringEmpty(value)) return true\n return regex.test(value)\n },\n {\n message: message?.invalid || baseDefaultMessages.EMAIL_INVALID()\n }\n )\n .optional()\n .transform((value) => (value?.length === 0 ? undefined : value))\n}\ntype EmailOptionalSchema = ReturnType<typeof getEmailOptional>\n\n/**\n * Схема валидации поля типа email\n * @param {EmailValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @typeParam `regexp` - `RegExp`\n * @typeParam `message` - `{ [min | invalid]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getEmailSchema()\n * })\n * // will returns z.string().min(1).email()\n *\n * @example with optional value\n * z.object({\n * field: zodValidators.base.getEmailSchema({ required: false })\n * })\n * // will returns z.string().min(1).email().optional()\n */\nexport function getEmailSchema(props?: EmailValidationOptions<true>): EmailRequiredSchema\nexport function getEmailSchema(props?: EmailValidationOptions<false>): EmailOptionalSchema\nexport function getEmailSchema<Required extends boolean>(\n props?: EmailValidationOptions<Required>\n): EmailRequiredSchema | EmailOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getEmailRequired(props) : getEmailOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type NumberValidationOptions<Required extends boolean> = {\n /**\n * минимальное значение\n * @default 0\n */\n min?: number\n /**\n * максимальное значение\n * @default undefined\n */\n max?: number\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: Partial<Record<keyof Omit<NumberValidationOptions<Required>, 'message'>, string>>\n}\n\n/**\n * Схема валидации обязательного поля числового типа\n */\nconst getNumberRequired = (props?: Omit<NumberValidationOptions<true>, 'required'>) => {\n const { min, max, message } = props || {}\n\n let schema = z.coerce.number()\n\n if (min) {\n schema = schema.min(min, message?.min || baseDefaultMessages.MIN_VALUE(min))\n }\n\n if (max) {\n schema = schema.max(max, message?.min || baseDefaultMessages.MAX_VALUE(max))\n }\n\n return schema.default(0)\n}\ntype NumberRequiredSchema = ReturnType<typeof getNumberRequired>\n\n/**\n * Схема валидации опционального поля числового типа\n */\nconst getNumberOptional = (props?: Omit<NumberValidationOptions<false>, 'required'>) => {\n return getNumberRequired(props)\n .optional()\n .transform((value) => (!value ? undefined : value))\n}\ntype NumberOptionalSchema = ReturnType<typeof getNumberOptional>\n\n/**\n * Схема валидации опционального поля числового типа\n * @param {NumberValidationOptions} props настройки схемы\n @typeParam `required` - `boolean`\n * @typeParam `min` - `number | undefined` `default: 1`\n * @typeParam `max` - `number | undefined` `default: undefined`\n * @typeParam `message` - `{ [min | max]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required min, max value\n * z.object({\n * field: zodValidators.base.getNumberSchema({ min: 10, max: 20 })\n * })\n * // will returns z.coerce.number().min(10).max(20)\n *\n * @example with optional min, max value\n * z.object({\n * field: zodValidators.base.getNumberSchema({ min: 10, max: 20, required: false })\n * })\n * // will returns z.coerce.number().min(10).max(20).optional()\n */\nexport function getNumberSchema(props?: NumberValidationOptions<true>): NumberRequiredSchema\nexport function getNumberSchema(props?: NumberValidationOptions<false>): NumberOptionalSchema\nexport function getNumberSchema<Required extends boolean>(\n props?: NumberValidationOptions<Required>\n): NumberRequiredSchema | NumberOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getNumberRequired(props) : getNumberOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type PhoneValidationOptions<Required extends boolean> = {\n /**\n * исключает маску в возвращаемом значении\n * @default true\n */\n ignoreMask?: boolean\n /**\n * игнорирует символы для проверки поля исключая данные символы\n * @default /[()+_ -]/g\n */\n maskSymbols?: RegExp | string\n /**\n * указывает что поле обязательное\n */\n required?: Required\n message?: {\n min?: string\n invalidOperator?: string\n }\n}\n\n/**\n * Схема валидации обязательного поля номера телефона\n */\nconst getPhoneRequired = (props?: Omit<PhoneValidationOptions<true>, 'required'>) => {\n const { ignoreMask = true, maskSymbols = /[()+_ -]/g, message } = props || {}\n\n const mask = TypeGuards.isString(maskSymbols) ? new RegExp(maskSymbols) : maskSymbols\n\n let schema = z.string().superRefine((value, context) => {\n const cleanValue = value.replace(mask, '')\n\n const operatorCode = cleanValue.charAt(1)\n\n if (!['3', '4', '5', '6', '7', '9'].includes(operatorCode)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: message?.invalidOperator || baseDefaultMessages.PHONE_INVALID_OPERATOR()\n })\n }\n\n if (cleanValue.length < 11) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: 11,\n inclusive: true,\n type: 'string',\n message: message?.min || baseDefaultMessages.PHONE_NON_EMPTY()\n })\n }\n })\n\n if (ignoreMask) {\n schema = schema.transform((value) => value.replace(mask, '')) as unknown as typeof schema\n }\n\n return schema.default('')\n}\ntype PhoneRequiredSchema = ReturnType<typeof getPhoneRequired>\n\n/**\n * Схема валидации опционального поля номера телефона\n */\nconst getPhoneOptional = (props?: Omit<PhoneValidationOptions<false>, 'required'>) => {\n const { ignoreMask = true, maskSymbols = /[()+_ -]/g, message } = props || {}\n\n const mask = TypeGuards.isString(maskSymbols) ? new RegExp(maskSymbols) : maskSymbols\n\n let schema = z.string().superRefine((value, context) => {\n const cleanValue = value.replace(mask, '')\n\n const operatorCode = cleanValue.charAt(1)\n\n if (!['3', '4', '5', '6', '7', '9'].includes(operatorCode)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: message?.invalidOperator || baseDefaultMessages.PHONE_INVALID_OPERATOR()\n })\n }\n\n if (cleanValue.length < 11) {\n context.addIssue({\n code: z.ZodIssueCode.too_small,\n minimum: 11,\n inclusive: true,\n type: 'string',\n message: message?.min || baseDefaultMessages.PHONE_NON_EMPTY()\n })\n }\n })\n\n if (ignoreMask) {\n schema = schema.transform((value) => value.replace(mask, '')) as unknown as typeof schema\n }\n\n return schema.transform((value) => (!value ? undefined : value))\n}\ntype PhoneOptionalSchema = ReturnType<typeof getPhoneOptional>\n\n/**\n * Схема валидации опционального поля номера телефона\n * @param {PhoneValidationOptions} props настройки схемы\n @typeParam `required` - `boolean`\n * @typeParam `ignoreSeparators` - `boolean | undefined` `default: false`\n * @typeParam `maskSymbols` - `RegExp | undefined` `default: /[()+_ -]/g`\n * @typeParam `message` - `{ [min | invalidOperator]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getPhoneSchema()\n * })\n * // will returns z.string()\n *\n * @example with optional value\n * z.object({\n * field: zodValidators.base.getPhoneSchema({ required: false })\n * })\n * // will returns z.string().optional()\n */\nexport function getPhoneSchema(props?: PhoneValidationOptions<true>): PhoneRequiredSchema\nexport function getPhoneSchema(props?: PhoneValidationOptions<false>): PhoneOptionalSchema\nexport function getPhoneSchema<Required extends boolean>(\n props?: PhoneValidationOptions<Required>\n): PhoneRequiredSchema | PhoneOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getPhoneRequired(props) : getPhoneOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type SelectSingleValidationOptions<Required extends boolean, Multi extends boolean = false> = {\n /**\n * включает валидацию мульти селекта\n * @default false\n */\n multiple?: Multi\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: {\n single?: string\n multiple?: string\n }\n}\n\ntype SelectMultipleValidationOptions<Required extends boolean, Multi extends boolean = true> = SelectSingleValidationOptions<\n Required,\n Multi\n> & {\n /**\n * минимальное количество элементов\n * @default 0\n */\n minLength?: number\n /**\n * максимальное количество элементов\n * @default undefined\n */\n maxLength?: number\n /**\n * фиксированное количество элементов\n * @default undefined\n */\n length?: number\n message?: SelectSingleValidationOptions<Required, Multi> & {\n minLength?: string\n maxLength?: string\n length?: string\n }\n}\n\ntype SelectValidationOptions<Required extends boolean, Multi extends boolean> = Multi extends true\n ? SelectMultipleValidationOptions<Required, Multi>\n : SelectSingleValidationOptions<Required, Multi>\n\n/**\n * Схема валидации обязательного поля типа select\n */\nconst getSelectRequired = <Required extends boolean, Multi extends boolean>(props?: SelectValidationOptions<Required, Multi>) => {\n const { message } = props || {}\n\n const selectSchema = z\n .string()\n .min(1, message?.single || baseDefaultMessages.SELECT_NON_EMPTY())\n .nullable()\n .refine((value) => Boolean(value), message?.single || baseDefaultMessages.SELECT_NON_EMPTY())\n .default(null)\n\n if (props?.multiple) {\n let arraySchema = z\n .array(selectSchema)\n .min(props?.minLength || 0, message?.multiple || baseDefaultMessages.SELECT_MULTIPLE_MIN_LENGTH(props?.minLength || 0))\n\n if (props?.length) {\n return arraySchema\n .length(props.length, props.message?.length || baseDefaultMessages.SELECT_FIX_LENGTH(props.length))\n .default([])\n } else if (props?.maxLength) {\n arraySchema = arraySchema.max(\n props.maxLength,\n props.message?.maxLength || baseDefaultMessages.SELECT_MULTIPLE_MAX_LENGTH(props.maxLength)\n )\n }\n\n return arraySchema.default([])\n }\n\n return selectSchema\n}\ntype SelectRequiredSchema = ReturnType<typeof getSelectRequired>\n\n/**\n * Схема валидации опционального поля типа select\n */\nfunction getSelectOptional<Required extends boolean, Multi extends boolean>(\n props?: Omit<SelectValidationOptions<Required, Multi>, 'message'>\n) {\n const selectSchema = z.string().nullable().optional()\n\n if (props?.multiple) {\n return z.array(selectSchema).optional()\n }\n\n return selectSchema\n}\ntype SelectOptionalSchema = ReturnType<typeof getSelectOptional>\n\n/**\n * Схема валидации опционального поля типа select\n * @param {SelectValidationOptions} props настройки схемы\n @typeParam `required` - `boolean`\n * @typeParam `multiple` - `boolean`\n * @typeParam `minLength` - `number | undefined`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required single value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ multiple: false })\n * })\n * // will returns z.string().nullable()\n *\n * @example with required multiple value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ multiple: true })\n * })\n * // will returns z.array(z.string().nullable())\n *\n * @example with optional single value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ required: false, multiple: false })\n * })\n * // will returns z.string().nullable().optional()\n *\n * @example with optional multiple value\n * z.object({\n * field: zodValidators.base.getSelectSchema({ required: false, multiple: true })\n * })\n * // will returns z.array(z.string().nullable().optional()).optional()\n */\nexport function getSelectSchema<Multi extends boolean>(props?: SelectValidationOptions<true, Multi>): SelectRequiredSchema\nexport function getSelectSchema<Multi extends boolean>(props?: SelectValidationOptions<false, Multi>): SelectOptionalSchema\nexport function getSelectSchema<Multi extends boolean, Required extends boolean>(\n props?: SelectValidationOptions<Required, Multi>\n): SelectRequiredSchema | SelectOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getSelectRequired(props) : getSelectOptional(props)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type StringValidationOptions<Required extends boolean> = {\n /**\n * минимальное количество символов\n * @default 1\n */\n min?: number\n /**\n * максимальное количество символов\n * @default undefined\n */\n max?: number\n /**\n * фиксированная длина символов\n */\n length?: number\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: Partial<Record<keyof Omit<StringValidationOptions<Required>, 'message'> | 'root', string>>\n}\n\n/**\n * Схема валидации обязательного поля строкового типа\n */\nconst getStringRequired = (props?: Omit<StringValidationOptions<true>, 'required'>) => {\n const { min, max, length, message } = props || {}\n\n let schema = z.string({ message: message?.root })\n\n if (min) {\n schema = schema.min(min, { message: message?.min || baseDefaultMessages.MIN_LENGTH(min) })\n }\n\n if (max) {\n schema = schema.max(max, { message: message?.max || baseDefaultMessages.MAX_LENGTH(max) })\n }\n\n if (length) {\n schema = schema.length(length, { message: message?.length || baseDefaultMessages.FIX_LENGTH(length) })\n }\n\n return schema.refine((value) => Boolean(value.length), { message: message?.min || baseDefaultMessages.NON_EMPTY() }).default('')\n}\ntype StringRequiredSchema = ReturnType<typeof getStringRequired>\n\n/**\n * Схема валидации обязательного поля строкового типа\n */\nconst getStringOptional = (props?: Omit<StringValidationOptions<false>, 'required'>) => {\n const { min, max, length, message } = props || {}\n\n let schema = z.string({ message: message?.root })\n\n if (min) {\n schema = schema.min(min, { message: message?.min || baseDefaultMessages.MIN_LENGTH(min) })\n }\n\n if (max) {\n schema = schema.max(max, { message: message?.max || baseDefaultMessages.MAX_LENGTH(max) })\n }\n\n if (length) {\n schema = schema.length(length, { message: message?.length || baseDefaultMessages.FIX_LENGTH(length) })\n }\n\n return schema.optional().transform((value) => (!value?.length ? undefined : value))\n}\ntype StringOptionalSchema = ReturnType<typeof getStringOptional>\n\n/**\n * Схема валидации обязательного поля строкового типа\n * @param {StringValidationOptions} props настройки схемы\n * @typeParam `min` - `number | undefined` `default: 1`\n * @typeParam `max` - `number | undefined` `default: undefined`\n * @typeParam `message` - `{ [min | max]: string }`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required min value\n * z.object({\n * field: zodValidators.base.getStringSchema({ min: 10 })\n * })\n * // will returns z.string().min(10)\n *\n * @example with required min, max value\n * z.object({\n * field: zodValidators.base.getStringSchema({ min: 10, max: 20 })\n * })\n * // will returns z.string().min(10).max(20)\n *\n * @example with optional min value\n * z.object({\n * field: zodValidators.base.getStringSchema({ required: false, min: 10 })\n * })\n * // will returns z.string().min(10).optional()\n *\n * @example with optional min, max value\n * z.object({\n * field: zodValidators.base.getStringSchema({ required: false, min: 10, max: 20 })\n * })\n * // will returns z.string().min(10).max(20).optional()\n */\nexport function getStringSchema(props?: StringValidationOptions<true>): StringRequiredSchema\nexport function getStringSchema(props?: StringValidationOptions<false>): StringOptionalSchema\nexport function getStringSchema<Required extends boolean>(\n props?: StringValidationOptions<Required>\n): StringRequiredSchema | StringOptionalSchema {\n const { required = true, ...restProps } = props || {}\n\n return required ? getStringRequired(restProps) : getStringOptional(restProps)\n}\n","import z from 'zod'\nimport { baseDefaultMessages } from './base.constants'\n\nexport type UnionValidationOptions<Required extends boolean, T extends z.Primitive> = {\n /**\n * сообщение об ошибке\n */\n message?: ((values: readonly T[]) => string) | string\n errorMap?: z.ZodErrorMap\n /**\n * сообщение об ошибке при не правильном типе значение\n */\n invalid_type_error?: string\n /**\n * сообщение об ошибке при отсутствии значения\n */\n required_error?: string\n /**\n * описание схемы\n */\n description?: string\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n}\n\n/**\n * Схема валидации обязательного поля из выборки\n */\nconst getUnionRequired = <T extends z.Primitive>(\n values: [T, T, ...T[]],\n props?: Omit<UnionValidationOptions<true, T>, 'required'>\n) => {\n const { message, ...restProps } = props || {}\n\n const [first, second, ...other] = values.map((value) => z.literal(value))\n\n const errorMessage = (() => {\n if (message) {\n return typeof message === 'function' ? message(values) : message\n }\n\n return baseDefaultMessages.VALUE_OUT_OF_RANGE(values)\n })()\n\n return z\n .union([first, second, ...other], {\n message: errorMessage,\n ...restProps\n })\n .nullable()\n .refine(Boolean, baseDefaultMessages.NON_EMPTY())\n .default(null)\n}\ntype UnionRequiredSchema<T extends z.Primitive> = ReturnType<typeof getUnionRequired<T>>\n\n/**\n * Схема валидации обязательного поля из выборки\n */\nconst getUnionOptional = <T extends z.Primitive>(values: [T, T, ...T[]], props?: UnionValidationOptions<false, T>) => {\n return getUnionRequired(values, props).optional()\n}\ntype UnionOptionalSchema<T extends z.Primitive> = ReturnType<typeof getUnionOptional<T>>\n\n/**\n * Схема валидации обязательного поля из выборки\n * @param {z.Primitive} values литералы\n * @param {z.RawCreateParams & { message: (values: z.Primitive[]) => string }} props настройки схемы\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required union value\n * z.object({\n * field: zodValidators.base.getUnionSchema(['A', 'B'] as const)\n * }) ^ it need to infer literal type\n * // will returns z.union([z.literal('A'), z.literal('B')])\n *\n * @example with optional union value\n * z.object({\n * field: zodValidators.base.getUnionSchema(['A', 'B'] as const, { required: false })\n * }) ^ it need to infer literal type\n * // will returns z.union([z.literal('A'), z.literal('B')]).optional()\n */\nexport function getUnionSchema<T extends z.Primitive>(\n values: [T, T, ...T[]],\n props?: UnionValidationOptions<true, T>\n): UnionRequiredSchema<T>\nexport function getUnionSchema<T extends z.Primitive>(\n values: [T, T, ...T[]],\n props?: UnionValidationOptions<false, T>\n): UnionOptionalSchema<T>\nexport function getUnionSchema<T extends z.Primitive, Required extends boolean>(\n values: [T, T, ...T[]],\n props?: UnionValidationOptions<Required, T>\n): UnionRequiredSchema<T> | UnionOptionalSchema<T> {\n const { required, ...restProps } = props || {}\n\n return required ? getUnionRequired(values, restProps) : getUnionOptional(values, restProps)\n}\n","import { string } from 'zod'\nimport { baseDefaultMessages } from './base.constants'\nimport { TypeGuards } from '$/shared/utils'\n\nexport type UrlValidationOptions<Required extends boolean> = {\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n /**\n * Регулярное выражение для проверки url на валидность\n */\n regexp?: RegExp | string\n message?: {\n min?: string\n invalid?: string\n }\n}\n\nconst URL_REGEX =\n /^(http:\\/\\/www\\.|https:\\/\\/www\\.|http:\\/\\/|https:\\/\\/)?[a-z0-9]+([-.]{1}[a-z0-9]+)*\\.[a-z]{2,5}(:[0-9]{1,5})?(\\/.*)?$/\n\n/**\n * Схема валидации обязательного поля ссылки\n */\nconst getUrlRequired = (props?: Omit<UrlValidationOptions<true>, 'required'>) => {\n const { message, regexp = URL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return string()\n .min(1, message?.min || baseDefaultMessages.NON_EMPTY())\n .regex(regex, message?.invalid || baseDefaultMessages.INVALID_URL())\n .default('')\n}\ntype UrlRequiredSchema = ReturnType<typeof getUrlRequired>\n\n/**\n * Схема валидации опционального поля ссылки\n */\nconst getUrlOptional = (props?: Omit<UrlValidationOptions<false>, 'required'>) => {\n const { message, regexp = URL_REGEX } = props || {}\n\n const regex = TypeGuards.isString(regexp) ? new RegExp(regexp) : regexp\n\n return string()\n .refine((value) => {\n if (TypeGuards.isStringEmpty(value)) return true\n return regex.test(value)\n }, message?.invalid || baseDefaultMessages.INVALID_URL())\n .optional()\n .transform((value) => (!value?.length ? undefined : value))\n}\ntype UrlOptionalSchema = ReturnType<typeof getUrlOptional>\n\nexport function getUrlSchema(props?: UrlValidationOptions<true>): UrlRequiredSchema\nexport function getUrlSchema(props?: UrlValidationOptions<false>): UrlOptionalSchema\n/**\n * Схема валидации поля ссылки\n * @param {UrlValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @typeParam `regexp` - `RegExp`\n * @typeParam `message` - `{ [min | invalid]: string }`\n * @returns схема валидации поля в соответствии с настройками\n */\nexport function getUrlSchema<Required extends boolean>(\n props?: UrlValidationOptions<Required>\n): UrlRequiredSchema | UrlOptionalSchema {\n const { required = true } = props || {}\n\n return required ? getUrlRequired(props) : getUrlOptional(props)\n}\n","import { getDateSchema } from './date.validators'\nimport { getEmailSchema } from './email.validators'\nimport { getNumberSchema } from './number.validators'\nimport { getPhoneSchema } from './phone.validators'\nimport { getSelectSchema } from './select.validators'\nimport { getStringSchema } from './string.validators'\nimport { getUnionSchema } from './union.validators'\nimport { getUrlSchema } from './url.validators'\n\nexport const baseValidationSchemas = {\n getStringSchema,\n getEmailSchema,\n getSelectSchema,\n getNumberSchema,\n getPhoneSchema,\n getDateSchema,\n getUnionSchema,\n getUrlSchema\n}\n","import z from 'zod'\n\ntype ZodUtilsGetDefaultsOptions = {\n /**\n * Вставить в массив значение, исходя из внутренней схемы z.array\n */\n fillArrayWithValue?: boolean\n}\n\nexport class ZodUtils {\n /**\n * Функция для получения значения по умолчанию исходя из схемы\n * @param zodSchema схема формы\n * @param options настройки генерации значений по умолчанию\n * @returns объект значений по умолчанию\n *\n * @example\n * const schema = z.object({\n * name: zodValidators.base.getStringSchema(),\n * role: zodValidators.base.getUnionSchema(['UNKNOWN', 'ADMIN', 'MODERATOR', 'USER'] as const),\n * info: z.object({\n * address: zodValidators.base.getStringSchema(),\n * phone: zodValidators.base.getPhoneSchema({ ignoreMask: true }),\n * age: zodValidators.base.getNumberSchema()\n * })\n * })\n *\n * const defaultValues = ZodUtils.getZodDefaults(schema)\n *\n * // default values will be inferred from schema\n * // {\n * // name: '',\n * // role: 'UNKNOWN',\n * // info: {\n * // address: '',\n * // phone: '',\n * // age: 0\n * // }\n * // }\n */\n static getZodDefaults<ZodSchema extends z.AnyZodObject, Schema = z.TypeOf<ZodSchema>>(\n zodSchema: ZodSchema | z.ZodEffects<ZodSchema>,\n options?: ZodUtilsGetDefaultsOptions\n ): Schema {\n const { fillArrayWithValue } = options || {}\n\n if (zodSchema instanceof z.ZodEffects) {\n if (zodSchema.innerType() instanceof z.ZodEffects) {\n return this.getZodDefaults(zodSchema.innerType(), options)\n }\n\n return this.getZodDefaults(z.ZodObject.create(zodSchema.innerType().shape), options)\n }\n\n const getDefaultValue = (schema: z.ZodTypeAny): unknown => {\n switch (true) {\n case schema._def.typeName === 'ZodDefault' || schema instanceof z.ZodDefault:\n return (schema as z.ZodDefault<ZodSchema>)._def.defaultValue()\n case schema._def.typeName === 'ZodOptional' || schema instanceof z.ZodOptional:\n return undefined\n case schema._def.typeName === 'ZodNullable' || schema instanceof z.ZodNullable:\n return null\n case schema._def.typeName === 'ZodArray' || schema instanceof z.ZodArray:\n return fillArrayWithValue ? [getDefaultValue((schema as z.ZodArray<ZodSchema>).element)] : []\n case schema._def.typeName === 'ZodObject' || schema instanceof z.ZodObject:\n return this.getZodDefaults(schema as z.ZodObject<z.ZodRawShape>, options)\n case schema._def.typeName === 'ZodUnion' || schema instanceof z.ZodUnion:\n return getDefaultValue(schema._def.options[0])\n case schema._def.typeName === 'ZodLiteral' || schema instanceof z.ZodLiteral:\n return schema._def.value\n case schema._def.typeName === 'ZodDiscriminatedUnion' || schema instanceof z.ZodDiscriminatedUnion:\n return getDefaultValue(schema._def.options[0])\n case schema._def.typeName === 'ZodEnum' || schema instanceof z.ZodEnum:\n return schema._def.values[0]\n case schema._def.typeName === 'ZodString' || schema instanceof z.ZodString:\n return ''\n case schema._def.typeName === 'ZodNumber' || schema instanceof z.ZodNumber:\n return 0\n case schema._def.typeName === 'ZodBoolean' || schema instanceof z.ZodBoolean:\n return false\n case !('innerType' in schema._def):\n return undefined\n default:\n return getDefaultValue(schema._def.innerType)\n }\n }\n\n const defaults = {} as Schema\n\n const schemaEntries = Object.entries(zodSchema.shape) as [keyof Schema, z.ZodAny][]\n\n schemaEntries.map(([key, value]) => {\n defaults[key] = getDefaultValue(value) as Schema[keyof Schema]\n })\n\n return defaults\n }\n\n /**\n * Функция для объединения zod схождений\n * @param {ZodIntersection} zodSchema\n * @returns объединенная схема двух схождений\n *\n * @example\n * let schema = z.object({\n * foo: z.string()\n * })\n * // this will return intersection and we need\n * // to merge its left to right schema's\n * .and(\n * z.object({\n * bar: z.string()\n * })\n * )\n *\n * schema = ZodUtils.zodMergeIntersection(schema)\n *\n * // schema will be\n * z.object({\n * foo: z.string(),\n * bar: z.string()\n * })\n */\n static zodMergeIntersection<ZodLeft extends z.ZodTypeAny, ZodRight extends z.ZodTypeAny>(\n zodSchema: z.ZodIntersection<ZodLeft, ZodRight>\n ): z.ZodObject<z.objectUtil.MergeShapes<z.TypeOf<ZodLeft>, z.TypeOf<ZodRight>>> {\n const { left, right } = zodSchema._def\n\n const leftSchema =\n left instanceof z.ZodDiscriminatedUnion || left._def.typeName === 'ZodDiscriminatedUnion' ? left._def.options[0] : left\n const rightSchema =\n right instanceof z.ZodDiscriminatedUnion || right._def.typeName === 'ZodDiscriminatedUnion' ? right._def.options[0] : right\n\n if (\n (leftSchema._def.typeName === 'ZodObject' || leftSchema instanceof z.ZodObject) &&\n (rightSchema._def.typeName === 'ZodObject' || rightSchema instanceof z.ZodObject)\n ) {\n return leftSchema.merge(rightSchema)\n }\n\n throw new Error(`Cannot merge schema type ${rightSchema._def.typeName} to ${leftSchema._def.typeName}`)\n }\n}\n","export const fioDefaultMessages = {\n NON_EMPTY: () => 'Поле обязательно для заполнения',\n VALUE_NO_WHITESPACE: () => 'Укажите фамилию, имя и отчество через пробел',\n ONLY_CYRILLIC: () => 'Данные должны быть написаны кириллицей',\n NAME_OR_SURNAME_NON_EMPTY: () => 'Укажите имя и фамилию',\n INVALID_NAME: () => 'Неверно введено имя',\n INVALID_SURNAME: () => 'Неверно введена фамилия',\n INVALID_PATRONYMIC: () => 'Неверно введено отчество'\n}\n\nexport const fioRegex = {\n ONLY_CYRILLIC: /[\\u0400-\\u04FF\\u00CB\\u00EB -]/g,\n CHECK_HYPHEN: /^(?:[^-]+(?:-[^-]+){0,4}|[^-]+)$/,\n PATRONYMIC: /^[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4}(?:\\s+[a-zA-Zа-яА-ЯёЁ]+(?:\\s*-\\s*[a-zA-Zа-яА-ЯёЁ]+){0,4})?$/i\n}\n","import z from 'zod'\nimport { fioDefaultMessages, fioRegex } from './dadata.constants'\n\nconst getFioParts = (value: string) => {\n const [surname, name, ...patronymicParts] = value.trim().replace(/\\s+/g, ' ').split(' ')\n const patronymic = patronymicParts.join(' ')\n\n return { surname, name, patronymic }\n}\n\nexport type FioValidationOptions<Required extends boolean> = {\n /**\n * указывает что поле обязательное\n * @default true\n */\n required?: Required\n message?: {\n root?: string\n nameOrSurnameEmpty?: string\n invalidName?: string\n invalidSurname?: string\n invalidPatronymic?: string\n }\n}\n\n/**\n * Схема валидации обязательного поля автозаполнения ФИО\n */\nconst getFioRequired = (props?: Omit<FioValidationOptions<true>, 'required'>) => {\n const { message } = props || {}\n\n const { nameOrSurnameEmpty, invalidSurname, invalidPatronymic, invalidName } = message || {}\n\n return z\n .string()\n .superRefine((value, context) => {\n const { name, surname, patronymic } = getFioParts(value)\n\n if (!fioRegex.ONLY_CYRILLIC.test(value)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: fioDefaultMessages.ONLY_CYRILLIC()\n })\n }\n\n if (!name || !surname) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: nameOrSurnameEmpty || fioDefaultMessages.NAME_OR_SURNAME_NON_EMPTY()\n })\n }\n\n if (!fioRegex.CHECK_HYPHEN.test(name)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: invalidName || fioDefaultMessages.INVALID_NAME()\n })\n }\n\n if (!fioRegex.CHECK_HYPHEN.test(surname)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: invalidSurname || fioDefaultMessages.INVALID_SURNAME()\n })\n }\n\n if (patronymic) {\n if (!fioRegex.PATRONYMIC.test(patronymic)) {\n context.addIssue({\n code: z.ZodIssueCode.invalid_string,\n validation: 'regex',\n message: invalidPatronymic || fioDefaultMessages.INVALID_PATRONYMIC()\n })\n }\n }\n })\n .transform((value) => value.trimEnd())\n .default('')\n}\ntype FioRequiredSchema = ReturnType<typeof getFioRequired>\n\n/**\n * Схема валидации опционального поля автозаполнения ФИО\n */\nconst getFioOptional = (props?: Omit<FioValidationOptions<false>, 'required'>) => {\n return getFioRequired(props)\n .optional()\n .transform((value) => (!value?.length ? undefined : value))\n}\ntype FioOptionalSchema = ReturnType<typeof getFioOptional>\n\n/**\n * Схема валидации поля автозаполнения ФИО\n * @param {DateValidationOptions} props настройки схемы\n * @typeParam `required` - `boolean`\n * @returns схема валидации поля в соответствии с настройками\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getFioSchema()\n * })\n * // will returns z.string()\n *\n * @example with required value\n * z.object({\n * field: zodValidators.base.getFioSchema({ required: false })\n * })\n * // will returns z.string().optional()\n */\nexport function getFioSchema(props?: FioValidationOptions<true>): FioRequiredSchema\nexport function getFioSchema(props?: FioValidationOptions<false>): FioOptionalSchema\nexport function getFioSchema<Required extends boolean>(\n props?: FioValidationOptions<Required>\n): FioRequiredSchema | FioOptionalSchema {\n const { required = true, ...restProps } = props || {}\n\n return required ? getFioRequired(restProps) : getFioOptional(restProps)\n}\n","import { getFioSchema } from './fio.validators'\nexport type * from './fio.validators'\nexport { fioDefaultMessages } from './dadata.constants'\n\nexport const dadataValidationSchemas = {\n getFioSchema\n}\n","export * from './regExp'\nexport * from './messages'\nexport * from './zodValidation'\nexport * from './base'\nexport type * from './dadata'\nexport * from './utils'\nimport { baseValidationSchemas } from './base'\nimport { dadataValidationSchemas } from './dadata'\n\nexport const zodValidators = {\n base: baseValidationSchemas,\n dadata: dadataValidationSchemas\n}\n"],"names":["RgxUnicode","RgxCheckForHyphen","RgxPatronymic","VALIDATION_MESSAGES","formattedDadataFio","value","parts","surname","name","patronymicArr","patronymic","zodDadataFioSchema","z","ctx","zodCalendarValidate","val","day","month","year","parsed","parse","isValid","zodPhoneSchema","operatorCode","zodOtpCodeSchema","context","baseDefaultMessages","min","max","length","range","date","TypeGuards","formatDateToLocaleString","getDateRequired","props","iso","pattern","DATE_VISIBLE_PATTERN","message","validSymbolsLength","getDateOptional","getDateSchema","required","EMAIL_REGEX","getEmailRequired","regexp","regex","getEmailOptional","getEmailSchema","getNumberRequired","schema","getNumberOptional","getNumberSchema","getPhoneRequired","ignoreMask","maskSymbols","mask","cleanValue","getPhoneOptional","getPhoneSchema","getSelectRequired","selectSchema","arraySchema","_a","_b","getSelectOptional","getSelectSchema","getStringRequired","getStringOptional","getStringSchema","restProps","getUnionRequired","values","first","second","other","errorMessage","getUnionOptional","getUnionSchema","URL_REGEX","getUrlRequired","string","getUrlOptional","getUrlSchema","baseValidationSchemas","ZodUtils","zodSchema","options","fillArrayWithValue","getDefaultValue","defaults","key","left","right","leftSchema","rightSchema","fioDefaultMessages","fioRegex","getFioParts","patronymicParts","getFioRequired","nameOrSurnameEmpty","invalidSurname","invalidPatronymic","invalidName","getFioOptional","getFioSchema","dadataValidationSchemas","zodValidators"],"mappings":"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"}
|
package/dist/widget.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { j as t, B as y, H as j, c as h, R as k, P as F, b as D, I as f, C as I, a as G, L as U, d as B, A as v, e as Z } from "./index-
|
|
1
|
+
import { j as t, B as y, H as j, c as h, R as k, P as F, b as D, I as f, C as I, a as G, L as U, d as B, A as v, e as Z } from "./index-vcD48ARm.js";
|
|
2
2
|
import { s as $, c as L } from "./scrollToElement-BjUPRtGF.js";
|
|
3
3
|
import { c as p, T as c } from "./typeGuards-BigW-JS1.js";
|
|
4
4
|
import { a as b } from "./useDebounce-QgEEiWs9.js";
|