@letar/forms 1.1.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +308 -0
- package/README.md +9 -9
- package/README.ru.md +115 -30
- package/analytics.js +3 -0
- package/analytics.js.map +1 -0
- package/chunk-2PSXYC3I.js +1782 -0
- package/chunk-2PSXYC3I.js.map +1 -0
- package/chunk-5D6S6EGF.js +206 -0
- package/chunk-5D6S6EGF.js.map +1 -0
- package/{chunk-6QOPSQ3Z.js → chunk-6E7VJAJT.js} +3 -3
- package/{chunk-6QOPSQ3Z.js.map → chunk-6E7VJAJT.js.map} +1 -1
- package/chunk-CGXKRCSM.js +117 -0
- package/chunk-CGXKRCSM.js.map +1 -0
- package/{chunk-M2PNAAIR.js → chunk-DQUVUMCX.js} +30 -19
- package/chunk-DQUVUMCX.js.map +1 -0
- package/chunk-K3J4L26K.js +345 -0
- package/chunk-K3J4L26K.js.map +1 -0
- package/{chunk-PJETA6YN.js → chunk-MAYUFA5K.js} +5 -4
- package/chunk-MAYUFA5K.js.map +1 -0
- package/{chunk-4V6WBJ76.js → chunk-MVGXZNHP.js} +2 -2
- package/{chunk-4V6WBJ76.js.map → chunk-MVGXZNHP.js.map} +1 -1
- package/{chunk-XKKJKYWZ.js → chunk-MZDTJSF7.js} +3 -3
- package/{chunk-XKKJKYWZ.js.map → chunk-MZDTJSF7.js.map} +1 -1
- package/{chunk-KUNT5MSU.js → chunk-Q5EOF36Y.js} +3 -3
- package/chunk-Q5EOF36Y.js.map +1 -0
- package/{chunk-7FEQFDJ7.js → chunk-R2RTCKXY.js} +2 -2
- package/{chunk-7FEQFDJ7.js.map → chunk-R2RTCKXY.js.map} +1 -1
- package/{chunk-HWVOFWAT.js → chunk-XFWLD5EO.js} +225 -26
- package/chunk-XFWLD5EO.js.map +1 -0
- package/fields/boolean.js +3 -3
- package/fields/datetime.js +3 -3
- package/fields/number.js +3 -3
- package/fields/selection.js +3 -3
- package/fields/specialized.js +3 -3
- package/fields/text.js +3 -3
- package/hcaptcha-U4XIT3HS.js +64 -0
- package/hcaptcha-U4XIT3HS.js.map +1 -0
- package/i18n.js +1 -1
- package/index.js +3268 -51
- package/index.js.map +1 -1
- package/offline.js +1 -1
- package/package.json +33 -4
- package/recaptcha-PKAUAY2S.js +56 -0
- package/recaptcha-PKAUAY2S.js.map +1 -0
- package/server-errors.js +3 -0
- package/server-errors.js.map +1 -0
- package/turnstile-7FXTBSLW.js +36 -0
- package/turnstile-7FXTBSLW.js.map +1 -0
- package/validators/ru.js +73 -0
- package/validators/ru.js.map +1 -0
- package/chunk-GOELIS6T.js +0 -849
- package/chunk-GOELIS6T.js.map +0 -1
- package/chunk-HWVOFWAT.js.map +0 -1
- package/chunk-KUNT5MSU.js.map +0 -1
- package/chunk-M2PNAAIR.js.map +0 -1
- package/chunk-PJETA6YN.js.map +0 -1
package/fields/selection.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export { FieldAutocomplete, FieldCascadingSelect, FieldCheckboxCard, FieldCombobox, FieldListbox, FieldNativeSelect, FieldRadioCard, FieldRadioGroup, FieldSegmentedGroup, FieldSelect, FieldTags } from '../chunk-
|
|
2
|
-
import '../chunk-
|
|
3
|
-
import '../chunk-
|
|
1
|
+
export { FieldAutocomplete, FieldCascadingSelect, FieldCheckboxCard, FieldCombobox, FieldListbox, FieldNativeSelect, FieldRadioCard, FieldRadioGroup, FieldSegmentedGroup, FieldSelect, FieldTags } from '../chunk-MAYUFA5K.js';
|
|
2
|
+
import '../chunk-XFWLD5EO.js';
|
|
3
|
+
import '../chunk-R2RTCKXY.js';
|
|
4
4
|
//# sourceMappingURL=selection.js.map
|
|
5
5
|
//# sourceMappingURL=selection.js.map
|
package/fields/specialized.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export { FieldAddress, FieldCity, FieldColorPicker, FieldFileUpload, FieldOTPInput, FieldPhone, FieldPinInput } from '../chunk-
|
|
2
|
-
import '../chunk-
|
|
3
|
-
import '../chunk-
|
|
1
|
+
export { CardBrandIcon, CreditCardField, FieldAddress, FieldCity, FieldColorPicker, FieldFileUpload, FieldOTPInput, FieldPhone, FieldPinInput, FieldSignature, creditCardSchema, detectBrand, formatCardNumber, formatExpiry, isExpiryValid, luhn } from '../chunk-2PSXYC3I.js';
|
|
2
|
+
import '../chunk-XFWLD5EO.js';
|
|
3
|
+
import '../chunk-R2RTCKXY.js';
|
|
4
4
|
//# sourceMappingURL=specialized.js.map
|
|
5
5
|
//# sourceMappingURL=specialized.js.map
|
package/fields/text.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export { DEFAULT_TOOLBAR_BUTTONS, FieldEditable, FieldMaskedInput, FieldPassword, FieldPasswordStrength, FieldRichText, FieldString, FieldTextarea, TOOLBAR_CONFIG } from '../chunk-
|
|
2
|
-
import '../chunk-
|
|
3
|
-
import '../chunk-
|
|
1
|
+
export { DEFAULT_TOOLBAR_BUTTONS, FieldEditable, FieldMaskedInput, FieldPassword, FieldPasswordStrength, FieldRichText, FieldString, FieldTextarea, TOOLBAR_CONFIG } from '../chunk-DQUVUMCX.js';
|
|
2
|
+
import '../chunk-XFWLD5EO.js';
|
|
3
|
+
import '../chunk-R2RTCKXY.js';
|
|
4
4
|
//# sourceMappingURL=text.js.map
|
|
5
5
|
//# sourceMappingURL=text.js.map
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { useRef, useCallback, useEffect } from 'react';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
function HcaptchaProvider({
|
|
5
|
+
siteKey,
|
|
6
|
+
theme = "light",
|
|
7
|
+
size = "normal",
|
|
8
|
+
language,
|
|
9
|
+
onSuccess,
|
|
10
|
+
onError,
|
|
11
|
+
onExpire
|
|
12
|
+
}) {
|
|
13
|
+
const containerRef = useRef(null);
|
|
14
|
+
const widgetIdRef = useRef(null);
|
|
15
|
+
const handleCallback = useCallback(
|
|
16
|
+
(token) => {
|
|
17
|
+
onSuccess(token);
|
|
18
|
+
},
|
|
19
|
+
[onSuccess]
|
|
20
|
+
);
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
const scriptId = "hcaptcha-script";
|
|
23
|
+
if (!document.getElementById(scriptId)) {
|
|
24
|
+
const script = document.createElement("script");
|
|
25
|
+
script.id = scriptId;
|
|
26
|
+
script.src = "https://js.hcaptcha.com/1/api.js?render=explicit";
|
|
27
|
+
script.async = true;
|
|
28
|
+
script.defer = true;
|
|
29
|
+
document.head.appendChild(script);
|
|
30
|
+
}
|
|
31
|
+
const renderWidget = () => {
|
|
32
|
+
if (containerRef.current && window.hcaptcha && widgetIdRef.current === null) {
|
|
33
|
+
widgetIdRef.current = window.hcaptcha.render(containerRef.current, {
|
|
34
|
+
sitekey: siteKey,
|
|
35
|
+
theme: theme === "auto" ? "light" : theme,
|
|
36
|
+
size: size === "invisible" ? "invisible" : size,
|
|
37
|
+
hl: language,
|
|
38
|
+
callback: handleCallback,
|
|
39
|
+
"error-callback": () => onError?.(new Error("hCaptcha error")),
|
|
40
|
+
"expired-callback": () => onExpire?.()
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
const interval = setInterval(() => {
|
|
45
|
+
if (window.hcaptcha?.render) {
|
|
46
|
+
clearInterval(interval);
|
|
47
|
+
renderWidget();
|
|
48
|
+
}
|
|
49
|
+
}, 100);
|
|
50
|
+
const timeout = setTimeout(() => {
|
|
51
|
+
clearInterval(interval);
|
|
52
|
+
}, 1e4);
|
|
53
|
+
return () => {
|
|
54
|
+
clearInterval(interval);
|
|
55
|
+
clearTimeout(timeout);
|
|
56
|
+
widgetIdRef.current = null;
|
|
57
|
+
};
|
|
58
|
+
}, [siteKey, theme, size, language, handleCallback, onError, onExpire]);
|
|
59
|
+
return /* @__PURE__ */ jsx("div", { ref: containerRef });
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
export { HcaptchaProvider };
|
|
63
|
+
//# sourceMappingURL=hcaptcha-U4XIT3HS.js.map
|
|
64
|
+
//# sourceMappingURL=hcaptcha-U4XIT3HS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/lib/captcha/providers/hcaptcha.tsx"],"names":[],"mappings":";;;AAoBO,SAAS,gBAAA,CAAiB;AAAA,EAC/B,OAAA;AAAA,EACA,KAAA,GAAQ,OAAA;AAAA,EACR,IAAA,GAAO,QAAA;AAAA,EACP,QAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA;AACF,CAAA,EAA0B;AACxB,EAAA,MAAM,YAAA,GAAe,OAAuB,IAAI,CAAA;AAChD,EAAA,MAAM,WAAA,GAAc,OAAsB,IAAI,CAAA;AAE9C,EAAA,MAAM,cAAA,GAAiB,WAAA;AAAA,IACrB,CAAC,KAAA,KAAkB;AACjB,MAAA,SAAA,CAAU,KAAK,CAAA;AAAA,IACjB,CAAA;AAAA,IACA,CAAC,SAAS;AAAA,GACZ;AAEA,EAAA,SAAA,CAAU,MAAM;AAEd,IAAA,MAAM,QAAA,GAAW,iBAAA;AACjB,IAAA,IAAI,CAAC,QAAA,CAAS,cAAA,CAAe,QAAQ,CAAA,EAAG;AACtC,MAAA,MAAM,MAAA,GAAS,QAAA,CAAS,aAAA,CAAc,QAAQ,CAAA;AAC9C,MAAA,MAAA,CAAO,EAAA,GAAK,QAAA;AACZ,MAAA,MAAA,CAAO,GAAA,GAAM,kDAAA;AACb,MAAA,MAAA,CAAO,KAAA,GAAQ,IAAA;AACf,MAAA,MAAA,CAAO,KAAA,GAAQ,IAAA;AACf,MAAA,QAAA,CAAS,IAAA,CAAK,YAAY,MAAM,CAAA;AAAA,IAClC;AAEA,IAAA,MAAM,eAAe,MAAM;AACzB,MAAA,IAAI,aAAa,OAAA,IAAW,MAAA,CAAO,QAAA,IAAY,WAAA,CAAY,YAAY,IAAA,EAAM;AAC3E,QAAA,WAAA,CAAY,OAAA,GAAU,MAAA,CAAO,QAAA,CAAS,MAAA,CAAO,aAAa,OAAA,EAAS;AAAA,UACjE,OAAA,EAAS,OAAA;AAAA,UACT,KAAA,EAAO,KAAA,KAAU,MAAA,GAAS,OAAA,GAAU,KAAA;AAAA,UACpC,IAAA,EAAM,IAAA,KAAS,WAAA,GAAc,WAAA,GAAc,IAAA;AAAA,UAC3C,EAAA,EAAI,QAAA;AAAA,UACJ,QAAA,EAAU,cAAA;AAAA,UACV,kBAAkB,MAAM,OAAA,GAAU,IAAI,KAAA,CAAM,gBAAgB,CAAC,CAAA;AAAA,UAC7D,kBAAA,EAAoB,MAAM,QAAA;AAAW,SACtC,CAAA;AAAA,MACH;AAAA,IACF,CAAA;AAGA,IAAA,MAAM,QAAA,GAAW,YAAY,MAAM;AACjC,MAAA,IAAI,MAAA,CAAO,UAAU,MAAA,EAAQ;AAC3B,QAAA,aAAA,CAAc,QAAQ,CAAA;AACtB,QAAA,YAAA,EAAa;AAAA,MACf;AAAA,IACF,GAAG,GAAG,CAAA;AAGN,IAAA,MAAM,OAAA,GAAU,WAAW,MAAM;AAC/B,MAAA,aAAA,CAAc,QAAQ,CAAA;AAAA,IACxB,GAAG,GAAK,CAAA;AAER,IAAA,OAAO,MAAM;AACX,MAAA,aAAA,CAAc,QAAQ,CAAA;AACtB,MAAA,YAAA,CAAa,OAAO,CAAA;AACpB,MAAA,WAAA,CAAY,OAAA,GAAU,IAAA;AAAA,IACxB,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,OAAA,EAAS,KAAA,EAAO,MAAM,QAAA,EAAU,cAAA,EAAgB,OAAA,EAAS,QAAQ,CAAC,CAAA;AAEtE,EAAA,uBAAO,GAAA,CAAC,KAAA,EAAA,EAAI,GAAA,EAAK,YAAA,EAAc,CAAA;AACjC","file":"hcaptcha-U4XIT3HS.js","sourcesContent":["'use client'\n\nimport { useCallback, useEffect, useRef } from 'react'\nimport type { CaptchaSize, CaptchaTheme } from '../types'\n\n/** Пропсы для hCaptcha провайдера */\ninterface HcaptchaProviderProps {\n siteKey: string\n theme?: CaptchaTheme\n size?: CaptchaSize\n language?: string\n onSuccess: (token: string) => void\n onError?: (error: unknown) => void\n onExpire?: () => void\n}\n\n/**\n * Провайдер hCaptcha.\n * Загружает hCaptcha JS API через скрипт.\n */\nexport function HcaptchaProvider({\n siteKey,\n theme = 'light',\n size = 'normal',\n language,\n onSuccess,\n onError,\n onExpire,\n}: HcaptchaProviderProps) {\n const containerRef = useRef<HTMLDivElement>(null)\n const widgetIdRef = useRef<string | null>(null)\n\n const handleCallback = useCallback(\n (token: string) => {\n onSuccess(token)\n },\n [onSuccess]\n )\n\n useEffect(() => {\n // Загружаем hCaptcha API скрипт\n const scriptId = 'hcaptcha-script'\n if (!document.getElementById(scriptId)) {\n const script = document.createElement('script')\n script.id = scriptId\n script.src = 'https://js.hcaptcha.com/1/api.js?render=explicit'\n script.async = true\n script.defer = true\n document.head.appendChild(script)\n }\n\n const renderWidget = () => {\n if (containerRef.current && window.hcaptcha && widgetIdRef.current === null) {\n widgetIdRef.current = window.hcaptcha.render(containerRef.current, {\n sitekey: siteKey,\n theme: theme === 'auto' ? 'light' : theme,\n size: size === 'invisible' ? 'invisible' : size,\n hl: language,\n callback: handleCallback,\n 'error-callback': () => onError?.(new Error('hCaptcha error')),\n 'expired-callback': () => onExpire?.(),\n })\n }\n }\n\n // Проверяем готовность API каждые 100ms\n const interval = setInterval(() => {\n if (window.hcaptcha?.render) {\n clearInterval(interval)\n renderWidget()\n }\n }, 100)\n\n // Таймаут 10 секунд\n const timeout = setTimeout(() => {\n clearInterval(interval)\n }, 10000)\n\n return () => {\n clearInterval(interval)\n clearTimeout(timeout)\n widgetIdRef.current = null\n }\n }, [siteKey, theme, size, language, handleCallback, onError, onExpire])\n\n return <div ref={containerRef} />\n}\n\n// Типизация window.hcaptcha\ndeclare global {\n interface Window {\n hcaptcha?: {\n render: (container: HTMLElement, params: Record<string, unknown>) => string\n reset: (widgetId?: string) => void\n getResponse: (widgetId?: string) => string\n }\n }\n}\n"]}
|
package/i18n.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { FormI18nProvider, SIZE_ORIGINS, STRING_FORMATS, ZOD_ERROR_CODES, createFormErrorMap, getLocalizedValue, useFormI18n, useLocalizedOptions } from './chunk-
|
|
1
|
+
export { FormI18nProvider, SIZE_ORIGINS, STRING_FORMATS, ZOD_ERROR_CODES, createFormErrorMap, getLocalizedValue, useFormI18n, useLocalizedOptions } from './chunk-R2RTCKXY.js';
|
|
2
2
|
//# sourceMappingURL=i18n.js.map
|
|
3
3
|
//# sourceMappingURL=i18n.js.map
|