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.
@@ -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.0.9",
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": {