zustic 1.0.9 → 1.1.1
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/hook-form/index.d.mts +80 -0
- package/dist/hook-form/index.d.ts +80 -0
- package/dist/hook-form/index.js +1 -0
- package/dist/hook-form/index.mjs +1 -0
- package/dist/i18n/index.d.mts +24 -0
- package/dist/i18n/index.d.ts +24 -0
- package/dist/i18n/index.js +1 -0
- package/dist/i18n/index.mjs +1 -0
- package/package.json +11 -1
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
|
|
3
|
+
type RequiredRule = boolean | {
|
|
4
|
+
value: boolean;
|
|
5
|
+
message: string;
|
|
6
|
+
};
|
|
7
|
+
type NumberRule = number | {
|
|
8
|
+
value: number;
|
|
9
|
+
message: string;
|
|
10
|
+
};
|
|
11
|
+
type Field<T> = {
|
|
12
|
+
value: T;
|
|
13
|
+
error?: string | null;
|
|
14
|
+
required?: RequiredRule;
|
|
15
|
+
pattern?: {
|
|
16
|
+
value: RegExp;
|
|
17
|
+
message: string;
|
|
18
|
+
};
|
|
19
|
+
min?: NumberRule;
|
|
20
|
+
max?: NumberRule;
|
|
21
|
+
};
|
|
22
|
+
type ResolverResult<T> = {
|
|
23
|
+
values?: T;
|
|
24
|
+
errors?: Partial<Record<keyof T, string>>;
|
|
25
|
+
};
|
|
26
|
+
type Resolver<T> = (values: T) => ResolverResult<T> | Promise<ResolverResult<T>>;
|
|
27
|
+
interface HookFormParams<T> {
|
|
28
|
+
defaultValues: {
|
|
29
|
+
[K in keyof T]: Field<T[K]> | T[K];
|
|
30
|
+
};
|
|
31
|
+
resolver?: Resolver<T>;
|
|
32
|
+
}
|
|
33
|
+
interface ControllerProps<T> {
|
|
34
|
+
field: keyof T;
|
|
35
|
+
render: (value: string, error: string, onChange: (value: string) => void) => React.ReactNode;
|
|
36
|
+
}
|
|
37
|
+
type HandleSubmitType<T> = (cb: (data: T) => void) => (e: React.FormEvent<HTMLFormElement>) => void;
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Creates a Zod resolver for form validation.
|
|
41
|
+
*
|
|
42
|
+
* @param schema - Zod schema object
|
|
43
|
+
* @returns A resolver function that takes values and returns { values, errors }
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* const resolver = zodResolver(schema);
|
|
47
|
+
* const result = resolver({ email: 'test@test.com' });
|
|
48
|
+
* // { values: { email: 'test@test.com' } }
|
|
49
|
+
*/
|
|
50
|
+
declare const zodResolver: (schema: any) => (values: any) => {
|
|
51
|
+
values: any;
|
|
52
|
+
errors?: undefined;
|
|
53
|
+
} | {
|
|
54
|
+
errors: Record<string, string>;
|
|
55
|
+
values?: undefined;
|
|
56
|
+
};
|
|
57
|
+
/**
|
|
58
|
+
* Creates a Yup resolver for form validation.
|
|
59
|
+
*
|
|
60
|
+
* @param schema - Yup schema object
|
|
61
|
+
* @returns An async resolver function that takes values and returns { values, errors }
|
|
62
|
+
*
|
|
63
|
+
* @example
|
|
64
|
+
* const resolver = await yupResolver(schema)(values);
|
|
65
|
+
* // { values: {...} } or { errors: {...} }
|
|
66
|
+
*/
|
|
67
|
+
declare const yupResolver: (schema: any) => (values: any) => Promise<{
|
|
68
|
+
values: any;
|
|
69
|
+
errors?: undefined;
|
|
70
|
+
} | {
|
|
71
|
+
errors: Record<string, string>;
|
|
72
|
+
values?: undefined;
|
|
73
|
+
}>;
|
|
74
|
+
|
|
75
|
+
declare function createForm<T>(params: HookFormParams<T>): () => {
|
|
76
|
+
handleSubmit: HandleSubmitType<T>;
|
|
77
|
+
Controller: ({ field, render }: ControllerProps<T>) => react.ReactNode;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export { createForm, yupResolver, zodResolver };
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
|
|
3
|
+
type RequiredRule = boolean | {
|
|
4
|
+
value: boolean;
|
|
5
|
+
message: string;
|
|
6
|
+
};
|
|
7
|
+
type NumberRule = number | {
|
|
8
|
+
value: number;
|
|
9
|
+
message: string;
|
|
10
|
+
};
|
|
11
|
+
type Field<T> = {
|
|
12
|
+
value: T;
|
|
13
|
+
error?: string | null;
|
|
14
|
+
required?: RequiredRule;
|
|
15
|
+
pattern?: {
|
|
16
|
+
value: RegExp;
|
|
17
|
+
message: string;
|
|
18
|
+
};
|
|
19
|
+
min?: NumberRule;
|
|
20
|
+
max?: NumberRule;
|
|
21
|
+
};
|
|
22
|
+
type ResolverResult<T> = {
|
|
23
|
+
values?: T;
|
|
24
|
+
errors?: Partial<Record<keyof T, string>>;
|
|
25
|
+
};
|
|
26
|
+
type Resolver<T> = (values: T) => ResolverResult<T> | Promise<ResolverResult<T>>;
|
|
27
|
+
interface HookFormParams<T> {
|
|
28
|
+
defaultValues: {
|
|
29
|
+
[K in keyof T]: Field<T[K]> | T[K];
|
|
30
|
+
};
|
|
31
|
+
resolver?: Resolver<T>;
|
|
32
|
+
}
|
|
33
|
+
interface ControllerProps<T> {
|
|
34
|
+
field: keyof T;
|
|
35
|
+
render: (value: string, error: string, onChange: (value: string) => void) => React.ReactNode;
|
|
36
|
+
}
|
|
37
|
+
type HandleSubmitType<T> = (cb: (data: T) => void) => (e: React.FormEvent<HTMLFormElement>) => void;
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Creates a Zod resolver for form validation.
|
|
41
|
+
*
|
|
42
|
+
* @param schema - Zod schema object
|
|
43
|
+
* @returns A resolver function that takes values and returns { values, errors }
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* const resolver = zodResolver(schema);
|
|
47
|
+
* const result = resolver({ email: 'test@test.com' });
|
|
48
|
+
* // { values: { email: 'test@test.com' } }
|
|
49
|
+
*/
|
|
50
|
+
declare const zodResolver: (schema: any) => (values: any) => {
|
|
51
|
+
values: any;
|
|
52
|
+
errors?: undefined;
|
|
53
|
+
} | {
|
|
54
|
+
errors: Record<string, string>;
|
|
55
|
+
values?: undefined;
|
|
56
|
+
};
|
|
57
|
+
/**
|
|
58
|
+
* Creates a Yup resolver for form validation.
|
|
59
|
+
*
|
|
60
|
+
* @param schema - Yup schema object
|
|
61
|
+
* @returns An async resolver function that takes values and returns { values, errors }
|
|
62
|
+
*
|
|
63
|
+
* @example
|
|
64
|
+
* const resolver = await yupResolver(schema)(values);
|
|
65
|
+
* // { values: {...} } or { errors: {...} }
|
|
66
|
+
*/
|
|
67
|
+
declare const yupResolver: (schema: any) => (values: any) => Promise<{
|
|
68
|
+
values: any;
|
|
69
|
+
errors?: undefined;
|
|
70
|
+
} | {
|
|
71
|
+
errors: Record<string, string>;
|
|
72
|
+
values?: undefined;
|
|
73
|
+
}>;
|
|
74
|
+
|
|
75
|
+
declare function createForm<T>(params: HookFormParams<T>): () => {
|
|
76
|
+
handleSubmit: HandleSubmitType<T>;
|
|
77
|
+
Controller: ({ field, render }: ControllerProps<T>) => react.ReactNode;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export { createForm, yupResolver, zodResolver };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";var T=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var E=Object.prototype.hasOwnProperty;var C=(e,r)=>{for(var t in r)T(e,t,{get:r[t],enumerable:!0})},M=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let u of P(r))!E.call(e,u)&&u!==t&&T(e,u,{get:()=>r[u],enumerable:!(n=w(r,u))||n.enumerable});return e};var q=e=>M(T({},"__esModule",{value:!0}),e);var H={};C(H,{createForm:()=>z,yupResolver:()=>V,zodResolver:()=>x});module.exports=q(H);var h=require("react");function S(e,r=[]){let t,n=[],u=a=>{let s=typeof a=="function"?a(t):a;t={...t,...s},n.forEach(i=>i())},p=()=>t,c=N(u,p,r);t=e(c,p);let m=a=>(n.push(a),()=>{n=n.filter(s=>s!==a)});return(a=s=>s)=>(0,h.useSyncExternalStore)(m,()=>a(t))}var N=(e,r,t)=>!t||t.length===0?e:t.reduceRight((n,u)=>u(e,r)(n),e);function j(e){return e.charAt(0).toUpperCase()+e.slice(1)}function R(e,r){return e?typeof e=="boolean"?{value:e,message:e?`${j(r)} is required`:""}:e:{value:!1,message:""}}function v(e,r){return e===void 0?null:typeof e=="number"?{value:e,message:r==="min"?`Minimum is ${e}`:`Maximum is ${e}`}:e}function g(e){let r={};return Object.keys(e||{}).forEach(t=>{let n=e[t];typeof n=="object"&&"value"in n&&(r[t]=n.value)}),r}var x=e=>r=>{let t=e.safeParse(r);if(t.success)return{values:t.data};let n={};return t.error.issues.forEach(u=>{let p=u.path[0];n[p]=u.message}),{errors:n}},V=e=>async r=>{try{return{values:await e.validate(r,{abortEarly:!1})}}catch(t){let n={};return t.inner.forEach(u=>{n[u.path]=u.message}),{errors:n}}};function F(e){let r={};return Object.keys(e).forEach(t=>{let n=e[t];n&&typeof n=="object"&&"value"in n?r[t]={error:"",...n}:r[t]={value:n,error:""}}),r}function b(e,r){if(typeof r=="number"){let t=Number(e);return isNaN(t)?t:0}return typeof r=="boolean"?!!e:e}function z(e){let{defaultValues:r,resolver:t}=e,n=F(r),u=S((c,m)=>({...n,setFieldValue:(a,s)=>{var o;let i=m()[a];c({[a]:{...i,value:b(s,(o=n[a])==null?void 0:o.value)}})},defaultValidateField:a=>{var d;let s=m()[a],i="",o=b(s.value,(d=s[a])==null?void 0:d.value),y=R(s.required,a),l=v(s.min,"min"),f=v(s.max,"max");return y.value&&!o?i=y.message:typeof o=="string"&&s.pattern&&!s.pattern.value.test(o)?i=s.pattern.message:l&&(typeof o=="string"&&o.length<l.value||typeof o=="number"&&o<l.value)?i=l.message:f&&(typeof o=="string"&&o.length>f.value||typeof o=="number"&&o>f.value)&&(i=f.message),c({[a]:{...s,error:i}}),i},resolverValidate:async a=>{if(!t)return;let s=m(),i=s[a],o="",y=g(s),l=await t(y);if(l!=null&&l.errors){let f=l.errors[a];f&&(o=f)}return c({[a]:{...i,error:o}}),o},handleSubmit:a=>async s=>{s.preventDefault();let i=!1,o=m(),y=g(o),l=Object.keys(y);if(t){for(let f of l)await o.resolverValidate(f)&&(i=!0);i||a(y);return}for(let f of l)await o.defaultValidateField(f)&&(i=!0);i||a(y)}}));function p({field:c,render:m}){let a=u(),s=a[c].value,i=a[c].error,o=a.setFieldValue,y=a.defaultValidateField,l=a.resolverValidate;return m(s,i,async k=>{if(o(c,k),t){await l(c);return}y(c)})}return()=>({handleSubmit:u(m=>m.handleSubmit),Controller:p})}0&&(module.exports={createForm,yupResolver,zodResolver});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as b}from"../chunk-RXPCG2VZ.mjs";function x(e){return e.charAt(0).toUpperCase()+e.slice(1)}function h(e,n){return e?typeof e=="boolean"?{value:e,message:e?`${x(n)} is required`:""}:e:{value:!1,message:""}}function v(e,n){return e===void 0?null:typeof e=="number"?{value:e,message:n==="min"?`Minimum is ${e}`:`Maximum is ${e}`}:e}function g(e){let n={};return Object.keys(e||{}).forEach(r=>{let s=e[r];typeof s=="object"&&"value"in s&&(n[r]=s.value)}),n}var F=e=>n=>{let r=e.safeParse(n);if(r.success)return{values:r.data};let s={};return r.error.issues.forEach(m=>{let d=m.path[0];s[d]=m.message}),{errors:s}},k=e=>async n=>{try{return{values:await e.validate(n,{abortEarly:!1})}}catch(r){let s={};return r.inner.forEach(m=>{s[m.path]=m.message}),{errors:s}}};function R(e){let n={};return Object.keys(e).forEach(r=>{let s=e[r];s&&typeof s=="object"&&"value"in s?n[r]={error:"",...s}:n[r]={value:s,error:""}}),n}function T(e,n){if(typeof n=="number"){let r=Number(e);return isNaN(r)?r:0}return typeof n=="boolean"?!!e:e}function w(e){let{defaultValues:n,resolver:r}=e,s=R(n),m=b((c,y)=>({...s,setFieldValue:(a,o)=>{var t;let u=y()[a];c({[a]:{...u,value:T(o,(t=s[a])==null?void 0:t.value)}})},defaultValidateField:a=>{var p;let o=y()[a],u="",t=T(o.value,(p=o[a])==null?void 0:p.value),f=h(o.required,a),i=v(o.min,"min"),l=v(o.max,"max");return f.value&&!t?u=f.message:typeof t=="string"&&o.pattern&&!o.pattern.value.test(t)?u=o.pattern.message:i&&(typeof t=="string"&&t.length<i.value||typeof t=="number"&&t<i.value)?u=i.message:l&&(typeof t=="string"&&t.length>l.value||typeof t=="number"&&t>l.value)&&(u=l.message),c({[a]:{...o,error:u}}),u},resolverValidate:async a=>{if(!r)return;let o=y(),u=o[a],t="",f=g(o),i=await r(f);if(i!=null&&i.errors){let l=i.errors[a];l&&(t=l)}return c({[a]:{...u,error:t}}),t},handleSubmit:a=>async o=>{o.preventDefault();let u=!1,t=y(),f=g(t),i=Object.keys(f);if(r){for(let l of i)await t.resolverValidate(l)&&(u=!0);u||a(f);return}for(let l of i)await t.defaultValidateField(l)&&(u=!0);u||a(f)}}));function d({field:c,render:y}){let a=m(),o=a[c].value,u=a[c].error,t=a.setFieldValue,f=a.defaultValidateField,i=a.resolverValidate;return y(o,u,async V=>{if(t(c,V),r){await i(c);return}f(c)})}return()=>({handleSubmit:m(y=>y.handleSubmit),Controller:d})}export{w as createForm,k as yupResolver,F as zodResolver};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
interface I18nParams<T, L> {
|
|
2
|
+
initialLan: L;
|
|
3
|
+
resource: (lan: L) => Promise<T> | T;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* Recursively gets all nested keys from object using dot notation.
|
|
7
|
+
* Safely handles deep nesting without infinite recursion.
|
|
8
|
+
*/
|
|
9
|
+
type Join<K extends string | number, P extends string | number> = `${K}${'' extends P ? '' : `.${P}`}`;
|
|
10
|
+
type Prev = [never, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, ...0[]];
|
|
11
|
+
type NestedKeys<T, D extends number = 9> = D extends never ? never : T extends object ? {
|
|
12
|
+
[K in keyof T]-?: K extends string ? T[K] extends (infer U)[] ? K : T[K] extends object ? K | Join<K, NestedKeys<T[K], Prev[D]>> : K : never;
|
|
13
|
+
}[keyof T & string] : never;
|
|
14
|
+
type TranslationKey<T> = NestedKeys<T> & string;
|
|
15
|
+
|
|
16
|
+
declare function createI18n<T = any, L = any>(params: I18nParams<T, L>): () => {
|
|
17
|
+
t: (key: TranslationKey<T>) => string;
|
|
18
|
+
lan: L;
|
|
19
|
+
updateTranslation: (lang: L) => void;
|
|
20
|
+
isUpdating: boolean;
|
|
21
|
+
isInitialLoading: boolean;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export { createI18n };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
interface I18nParams<T, L> {
|
|
2
|
+
initialLan: L;
|
|
3
|
+
resource: (lan: L) => Promise<T> | T;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* Recursively gets all nested keys from object using dot notation.
|
|
7
|
+
* Safely handles deep nesting without infinite recursion.
|
|
8
|
+
*/
|
|
9
|
+
type Join<K extends string | number, P extends string | number> = `${K}${'' extends P ? '' : `.${P}`}`;
|
|
10
|
+
type Prev = [never, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, ...0[]];
|
|
11
|
+
type NestedKeys<T, D extends number = 9> = D extends never ? never : T extends object ? {
|
|
12
|
+
[K in keyof T]-?: K extends string ? T[K] extends (infer U)[] ? K : T[K] extends object ? K | Join<K, NestedKeys<T[K], Prev[D]>> : K : never;
|
|
13
|
+
}[keyof T & string] : never;
|
|
14
|
+
type TranslationKey<T> = NestedKeys<T> & string;
|
|
15
|
+
|
|
16
|
+
declare function createI18n<T = any, L = any>(params: I18nParams<T, L>): () => {
|
|
17
|
+
t: (key: TranslationKey<T>) => string;
|
|
18
|
+
lan: L;
|
|
19
|
+
updateTranslation: (lang: L) => void;
|
|
20
|
+
isUpdating: boolean;
|
|
21
|
+
isInitialLoading: boolean;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export { createI18n };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";"use client";var c=Object.defineProperty;var U=Object.getOwnPropertyDescriptor;var h=Object.getOwnPropertyNames;var w=Object.prototype.hasOwnProperty;var M=(e,a)=>{for(var t in a)c(e,t,{get:a[t],enumerable:!0})},x=(e,a,t,n)=>{if(a&&typeof a=="object"||typeof a=="function")for(let i of h(a))!w.call(e,i)&&i!==t&&c(e,i,{get:()=>a[i],enumerable:!(n=U(a,i))||n.enumerable});return e};var b=e=>x(c({},"__esModule",{value:!0}),e);var C={};M(C,{createI18n:()=>E});module.exports=b(C);var m=require("react");function S(e,a=[]){let t,n=[],i=r=>{let s=typeof r=="function"?r(t):r;t={...t,...s},n.forEach(d=>d())},l=()=>t,u=v(i,l,a);t=e(u,l);let o=r=>(n.push(r),()=>{n=n.filter(s=>s!==r)});return(r=s=>s)=>(0,m.useSyncExternalStore)(o,()=>r(t))}var v=(e,a,t)=>!t||t.length===0?e:t.reduceRight((n,i)=>i(e,a)(n),e);var y=require("react");function E(e){let{resource:a,initialLan:t}=e,n=0,i=S((l,u)=>({lan:t,data:null,isUpdating:!1,isInitialLoading:!0,async load(o){let r=++n,s=u().data===null;l({isUpdating:!s,isInitialLoading:s});let d=await Promise.resolve(a(o));r===n&&l({data:d,isUpdating:!1,isInitialLoading:!1})},update(o){l({lan:o})}}));return function(){let{lan:u,data:o,update:r,isUpdating:s,isInitialLoading:d,load:L}=i();(0,y.useEffect)(()=>{L(u)},[u]);function g(p){var f;return!o||d?"":(f=p.split(".").reduce((T,I)=>T==null?void 0:T[I],o))!=null?f:p}function P(p){r(p)}return{t:g,lan:u,updateTranslation:P,isUpdating:s,isInitialLoading:d}}}0&&(module.exports={createI18n});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use client";import{a as d}from"../chunk-RXPCG2VZ.mjs";import{useEffect as I}from"react";function S(p){let{resource:f,initialLan:L}=p,l=0,T=d((a,t)=>({lan:L,data:null,isUpdating:!1,isInitialLoading:!0,async load(n){let s=++l,i=t().data===null;a({isUpdating:!i,isInitialLoading:i});let e=await Promise.resolve(f(n));s===l&&a({data:e,isUpdating:!1,isInitialLoading:!1})},update(n){a({lan:n})}}));return function(){let{lan:t,data:n,update:s,isUpdating:i,isInitialLoading:e,load:c}=T();I(()=>{c(t)},[t]);function g(r){var u;return!n||e?"":(u=r.split(".").reduce((o,y)=>o==null?void 0:o[y],n))!=null?u:r}function m(r){s(r)}return{t:g,lan:t,updateTranslation:m,isUpdating:i,isInitialLoading:e}}}export{S as createI18n};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "zustic",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.1.1",
|
|
4
4
|
"description": "A fast, minimal state management solution for React ecosystems. Works seamlessly with React, Next.js, and React Native, offering predictable state updates with a tiny footprint.",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"build": "tsup",
|
|
@@ -16,6 +16,16 @@
|
|
|
16
16
|
"types": "./dist/query/index.d.ts",
|
|
17
17
|
"import": "./dist/query/index.mjs",
|
|
18
18
|
"require": "./dist/query/index.js"
|
|
19
|
+
},
|
|
20
|
+
"./i18n": {
|
|
21
|
+
"types": "./dist/i18n/index.d.ts",
|
|
22
|
+
"import": "./dist/i18n/index.mjs",
|
|
23
|
+
"require": "./dist/i18n/index.js"
|
|
24
|
+
},
|
|
25
|
+
"./hook-form": {
|
|
26
|
+
"types": "./dist/hook-form/index.d.ts",
|
|
27
|
+
"import": "./dist/hook-form/index.mjs",
|
|
28
|
+
"require": "./dist/hook-form/index.js"
|
|
19
29
|
}
|
|
20
30
|
},
|
|
21
31
|
"directories": {
|