@rilaykit/core 4.0.0 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- 'use strict';var zod=require('zod');function P(o,e){return typeof o=="function"?o(e):o}function b(o,e){return {...o,...e}}function h(o,e){let r=o.filter((n,t)=>o.indexOf(n)!==t);if(r.length>0)throw new Error(`Duplicate ${e} IDs: ${r.join(", ")}`)}function S(o,e,r){if(o.filter(t=>e.some(a=>!t[a])).length>0)throw new Error(`Missing required fields in ${r}: ${e.join(", ")}`)}var R=class{constructor(){this.counters=new Map;}next(e){let r=this.counters.get(e)||0;return this.counters.set(e,r+1),`${e}-${r+1}`}reset(e){e?this.counters.delete(e):this.counters.clear();}},y=class{constructor(){this.errors=[];}add(e,r,n){return this.errors.push({code:e,message:r,path:n}),this}addIf(e,r,n,t){return e&&this.add(r,n,t),this}build(){return [...this.errors]}hasErrors(){return this.errors.length>0}clear(){return this.errors=[],this}},V={hasValue:o=>o!=null&&o!=="",isArray:o=>Array.isArray(o),arrayMinLength:(o,e)=>o.length>=e,arrayMaxLength:(o,e)=>o.length<=e};function F(o){return Array.isArray(o)?o:[o]}function C(o){if(o===null||typeof o!="object")return o;if(o instanceof Date)return new Date(o.getTime());if(Array.isArray(o))return o.map(r=>C(r));let e={};for(let r in o)Object.prototype.hasOwnProperty.call(o,r)&&(e[r]=C(o[r]));return e}function g(o,e,r){let n={...o};for(let t in e)r&&!r.includes(t)||e[t]!==void 0&&(n[t]=e[t]);return n}var w=class o{constructor(){this.components=new Map;this.formRenderConfig={};this.workflowRenderConfig={};}static create(){return new o}addComponent(e,r){let n={id:e,type:e,...r};return this.components.set(e,n),this}configure(e){let r=["rowRenderer","bodyRenderer","submitButtonRenderer","fieldRenderer"],n=["stepperRenderer","nextButtonRenderer","previousButtonRenderer","skipButtonRenderer"],t={},a={};for(let[i,s]of Object.entries(e))r.includes(i)?t[i]=s:n.includes(i)&&(a[i]=s);return this.formRenderConfig=g(this.formRenderConfig,t),this.workflowRenderConfig=g(this.workflowRenderConfig,a),this}getFormRenderConfig(){return {...this.formRenderConfig}}getWorkflowRenderConfig(){return {...this.workflowRenderConfig}}getComponent(e){return this.components.get(e)}getAllComponents(){return Array.from(this.components.values())}hasComponent(e){return this.components.has(e)}removeComponent(e){return this.components.delete(e)}clear(){this.components.clear();}getStats(){let e=Array.from(this.components.values());return {total:e.length,byType:e.reduce((r,n)=>(r[n.type]=(r[n.type]||0)+1,r),{}),hasCustomRenderers:{row:!!this.formRenderConfig.rowRenderer,body:!!this.formRenderConfig.bodyRenderer,submitButton:!!this.formRenderConfig.submitButtonRenderer,field:!!this.formRenderConfig.fieldRenderer,stepper:!!this.workflowRenderConfig.stepperRenderer,workflowNextButton:!!this.workflowRenderConfig.nextButtonRenderer,workflowPreviousButton:!!this.workflowRenderConfig.previousButtonRenderer,workflowSkipButton:!!this.workflowRenderConfig.skipButtonRenderer}}}validate(){let e=new y,r=Array.from(this.components.values()),n=r.map(a=>a.id);try{h(n,"component");}catch(a){e.add("DUPLICATE_IDS",a instanceof Error?a.message:String(a));}let t=r.filter(a=>!a.renderer);return e.addIf(t.length>0,"MISSING_RENDERER",`Components without renderer: ${t.map(a=>a.id).join(", ")}`),e.build().map(a=>a.message)}};var p=o=>async e=>{try{return await o.parseAsync(e),{isValid:!0,errors:[]}}catch(r){return r&&typeof r=="object"&&"errors"in r&&Array.isArray(r.errors)?{isValid:false,errors:r.errors.map(n=>({code:n.code,message:n.message,path:n.path?n.path.map(String):[]}))}:{isValid:false,errors:[{code:"unknown",message:r instanceof Error?r.message:"Unknown validation error"}]}}},k=o=>async(e,r,n)=>{try{let t=await o(e,r);return t===!0?{isValid:!0,errors:[]}:t===!1?{isValid:!1,errors:[{code:"validation_failed",message:"Validation failed"}]}:{isValid:!1,errors:[{code:"validation_failed",message:String(t)}]}}catch(t){return {isValid:false,errors:[{code:"validation_error",message:t instanceof Error?t.message:"Validation error"}]}}},D=(o,e="all")=>async(r,n,t)=>{let a=await Promise.all(o.map(d=>d(r,n,t)));if(e==="all"){let d=a.flatMap(l=>l.errors);return {isValid:a.every(l=>l.isValid),errors:d}}return a.some(d=>d.isValid)?{isValid:true,errors:[]}:{isValid:false,errors:a.flatMap(d=>d.errors)}},N=(o,e)=>async(r,n,t)=>o(r,n)?e(r,n,t):{isValid:true,errors:[]},I={required:(o="This field is required")=>k(e=>e==null||e===""?o:!0),email:(o="Invalid email format")=>p(zod.z.string().email(o)),minLength:(o,e)=>p(zod.z.string().min(o,e||`Minimum ${o} characters required`)),maxLength:(o,e)=>p(zod.z.string().max(o,e||`Maximum ${o} characters allowed`)),pattern:(o,e="Invalid format")=>p(zod.z.string().regex(o,e)),numberRange:(o,e,r)=>{let n=zod.z.number();return o!==void 0&&(n=n.min(o,r||`Value must be at least ${o}`)),e!==void 0&&(n=n.max(e,r||`Value must be at most ${e}`)),p(n)},url:(o="Invalid URL format")=>p(zod.z.string().url(o)),phoneNumber:(o="Invalid phone number format")=>p(zod.z.string().regex(/^\+?[\d\s\-\(\)]+$/,o)),asyncValidation:(o,e=300)=>{let r=new Map;return (n,t,a)=>new Promise(i=>{let s=`${t.fieldId}-${JSON.stringify(n)}`;r.has(s)&&clearTimeout(r.get(s));let d=setTimeout(async()=>{try{let l=await o(n,t);i(l===!0?{isValid:!0,errors:[]}:{isValid:!1,errors:[{code:"async_validation_failed",message:typeof l=="string"?l:"Async validation failed"}]});}catch(l){i({isValid:false,errors:[{code:"async_validation_error",message:l instanceof Error?l.message:"Async validation error"}]});}finally{r.delete(s);}},e);r.set(s,d);})}},A=(o,e=[])=>({isValid:o,errors:e}),$=(o,e,r)=>({code:o,message:e,path:r});var m=class{constructor(){this.name="localStorage";}async save(e,r){try{localStorage.setItem(e,JSON.stringify(r));}catch(n){throw new Error(`Failed to save to localStorage: ${n}`)}}async load(e){try{let r=localStorage.getItem(e);return r?JSON.parse(r):null}catch(r){throw new Error(`Failed to load from localStorage: ${r}`)}}async remove(e){try{localStorage.removeItem(e);}catch(r){throw new Error(`Failed to remove from localStorage: ${r}`)}}async exists(e){return localStorage.getItem(e)!==null}async list(e){let r=[];for(let n=0;n<localStorage.length;n++){let t=localStorage.key(n);t&&(!e||t.includes(e))&&r.push(t);}return r}},u=class{constructor(){this.name="sessionStorage";}async save(e,r){try{sessionStorage.setItem(e,JSON.stringify(r));}catch(n){throw new Error(`Failed to save to sessionStorage: ${n}`)}}async load(e){try{let r=sessionStorage.getItem(e);return r?JSON.parse(r):null}catch(r){throw new Error(`Failed to load from sessionStorage: ${r}`)}}async remove(e){try{sessionStorage.removeItem(e);}catch(r){throw new Error(`Failed to remove from sessionStorage: ${r}`)}}async exists(e){return sessionStorage.getItem(e)!==null}async list(e){let r=[];for(let n=0;n<sessionStorage.length;n++){let t=sessionStorage.key(n);t&&(!e||t.includes(e))&&r.push(t);}return r}},f=class{constructor(){this.name="memory";this.storage=new Map;}async save(e,r){this.storage.set(e,{...r});}async load(e){let r=this.storage.get(e);return r?{...r}:null}async remove(e){this.storage.delete(e);}async exists(e){return this.storage.has(e)}async list(e){let r=Array.from(this.storage.keys());return e?r.filter(n=>n.includes(e)):r}clear(){this.storage.clear();}},x=class{constructor(e,r=[]){this.primary=e;this.fallbacks=r;this.name="composite";}async save(e,r){let n=[this.primary,...this.fallbacks];for(let t of n)try{await t.save(e,r);return}catch(a){console.warn(`Failed to save with ${t.name}:`,a);}throw new Error("All persistence adapters failed to save")}async load(e){let r=[this.primary,...this.fallbacks];for(let n of r)try{let t=await n.load(e);if(t)return t}catch(t){console.warn(`Failed to load with ${n.name}:`,t);}return null}async remove(e){let r=[this.primary,...this.fallbacks],n=[];for(let t of r)try{await t.remove(e);}catch(a){n.push(a);}if(n.length===r.length)throw new Error(`All adapters failed to remove: ${n.map(t=>t.message).join(", ")}`)}async exists(e){let r=[this.primary,...this.fallbacks];for(let n of r)try{if(await n.exists(e))return !0}catch(t){console.warn(`Failed to check existence with ${n.name}:`,t);}return false}async list(e){try{return await this.primary.list?.(e)||[]}catch(r){console.warn("Failed to list with primary adapter:",r);for(let n of this.fallbacks)try{return await n.list?.(e)||[]}catch(t){console.warn(`Failed to list with fallback ${n.name}:`,t);}return []}}};var q={localStorage(o={}){return {adapter:new m,debounceMs:1e3,autoSave:true,saveOnStepChange:true,...o}},sessionStorage(o={}){return {adapter:new u,debounceMs:1e3,autoSave:true,saveOnStepChange:true,...o}},memory(o={}){return {adapter:new f,debounceMs:0,autoSave:true,saveOnStepChange:true,...o}},custom(o,e={}){return {adapter:o,debounceMs:1e3,autoSave:true,saveOnStepChange:true,...e}}};function _(o,e,r={}){let n=e||new f;return {adapter:{name:`resilient-${o.name}`,async save(a,i){try{await o.save(a,i);}catch(s){console.warn("Primary persistence failed, using fallback:",s),await n.save(a,i);}},async load(a){try{let i=await o.load(a);if(i)return i}catch(i){console.warn("Primary persistence load failed, trying fallback:",i);}return await n.load(a)},async remove(a){let i=[];try{await o.remove(a);}catch(s){i.push(s);}try{await n.remove(a);}catch(s){i.push(s);}if(i.length===2)throw new Error(`Both adapters failed: ${i.map(s=>s.message).join(", ")}`)},async exists(a){try{if(await o.exists(a))return !0}catch(i){console.warn("Primary persistence exists check failed:",i);}try{return await n.exists(a)}catch(i){return console.warn("Fallback persistence exists check failed:",i),false}},async list(a){try{return await o.list?.(a)||[]}catch(i){console.warn("Primary persistence list failed:",i);try{return await n.list?.(a)||[]}catch(s){return console.warn("Fallback persistence list failed:",s),[]}}}},debounceMs:1e3,autoSave:true,saveOnStepChange:true,maxRetries:3,retryDelayMs:1e3,...r}}exports.CompositeAdapter=x;exports.IdGenerator=R;exports.LocalStorageAdapter=m;exports.MemoryAdapter=f;exports.SessionStorageAdapter=u;exports.ValidationErrorBuilder=y;exports.ValidationPatterns=V;exports.combineValidators=D;exports.commonValidators=I;exports.configureObject=g;exports.createConditionalValidator=N;exports.createCustomValidator=k;exports.createResilientPersistence=_;exports.createValidationError=$;exports.createValidationResult=A;exports.createZodValidator=p;exports.deepClone=C;exports.ensureUnique=h;exports.mergeInto=b;exports.normalizeToArray=F;exports.persistence=q;exports.resolveRendererChildren=P;exports.ril=w;exports.validateRequired=S;
1
+ 'use strict';function R(e,r){return typeof e=="function"?e(r):e}function v({children:e,renderAs:r,renderer:t,name:n,props:o}){if(r==="children"||r===true){if(typeof e!="function")throw new Error(`When renderAs="children" is used, children must be a function that returns React elements for ${n}`);return e(o)}if(!t)throw new Error(`No renderer provided for ${n}`);if(typeof t!="function")throw new Error(`Renderer must be a function for ${n}`);let l={...o,children:R(e,o)};return t(l)}function W(e,r){return {...e,...r}}function C(e,r){let t=e.filter((n,o)=>e.indexOf(n)!==o);if(t.length>0)throw new Error(`Duplicate ${r} IDs: ${t.join(", ")}`)}function z(e,r,t){if(e.filter(o=>r.some(i=>!o[i])).length>0)throw new Error(`Missing required fields in ${t}: ${r.join(", ")}`)}var V=class{constructor(){this.counters=new Map;}next(r){let t=this.counters.get(r)||0;return this.counters.set(r,t+1),`${r}-${t+1}`}reset(r){r?this.counters.delete(r):this.counters.clear();}};function U(e){return Array.isArray(e)?e:[e]}function T(e){if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(Array.isArray(e))return e.map(t=>T(t));let r={};for(let t in e)Object.prototype.hasOwnProperty.call(e,t)&&(r[t]=T(e[t]));return r}function u(e,r,t){let n={...e};for(let o in r)t&&!t.includes(o)||r[o]!==void 0&&(n[o]=r[o]);return n}var f=class e{constructor(){this.components=new Map;this.formRenderConfig={};this.workflowRenderConfig={};}static create(){return new e}addComponent(r,t){let n={id:r,type:r,...t};return this.components.set(r,n),this}configure(r){let t=["rowRenderer","bodyRenderer","submitButtonRenderer","fieldRenderer"],n=["stepperRenderer","nextButtonRenderer","previousButtonRenderer","skipButtonRenderer"],o={},i={};for(let[l,g]of Object.entries(r))t.includes(l)?o[l]=g:n.includes(l)&&(i[l]=g);return this.formRenderConfig=u(this.formRenderConfig,o),this.workflowRenderConfig=u(this.workflowRenderConfig,i),this}getFormRenderConfig(){return {...this.formRenderConfig}}getWorkflowRenderConfig(){return {...this.workflowRenderConfig}}getComponent(r){return this.components.get(r)}getAllComponents(){return Array.from(this.components.values())}hasComponent(r){return this.components.has(r)}removeComponent(r){return this.components.delete(r)}clear(){this.components.clear();}getStats(){let r=Array.from(this.components.values());return {total:r.length,byType:r.reduce((t,n)=>(t[n.type]=(t[n.type]||0)+1,t),{}),hasCustomRenderers:{row:!!this.formRenderConfig.rowRenderer,body:!!this.formRenderConfig.bodyRenderer,submitButton:!!this.formRenderConfig.submitButtonRenderer,field:!!this.formRenderConfig.fieldRenderer,stepper:!!this.workflowRenderConfig.stepperRenderer,workflowNextButton:!!this.workflowRenderConfig.nextButtonRenderer,workflowPreviousButton:!!this.workflowRenderConfig.previousButtonRenderer,workflowSkipButton:!!this.workflowRenderConfig.skipButtonRenderer}}}validate(){let r=[],t=Array.from(this.components.values()),n=t.map(i=>i.id);try{C(n,"component");}catch(i){r.push(i instanceof Error?i.message:String(i));}let o=t.filter(i=>!i.renderer);return o.length>0&&r.push(`Components without renderer: ${o.map(i=>i.id).join(", ")}`),r}};function d(e,r=[]){return {isValid:e,errors:[...r]}}function a(){return d(true,[])}function s(e,r,t){return d(false,[{message:e,code:r,path:t}])}function c(e){let r=[],t=true;for(let n of e)n.isValid||(t=false),r.push(...n.errors);return d(t,r)}function h(e,r,t){let n=e.map(o=>{let i=o(r,t);if(i instanceof Promise)throw new Error("Use runValidatorsAsync for async validators");return i});return c(n)}async function y(e,r,t){let n=await Promise.all(e.map(o=>o(r,t)));return c(n)}function w(e={}){return {fieldId:e.fieldId,formId:e.formId,stepId:e.stepId,workflowId:e.workflowId,allFormData:e.allFormData||{},stepData:e.stepData||{},workflowData:e.workflowData||{}}}function x(e="This field is required"){return r=>r==null||r===""||Array.isArray(r)&&r.length===0?s(e,"REQUIRED"):a()}function F(e,r){return t=>!t||t.length<e?s(r||`Must be at least ${e} characters long`,"MIN_LENGTH",`length.${e}`):a()}function A(e,r){return t=>t&&t.length>e?s(r||`Must be no more than ${e} characters long`,"MAX_LENGTH",`length.${e}`):a()}function b(e,r){return t=>t&&!e.test(t)?s(r||"Invalid format","PATTERN_MISMATCH",`pattern.${e.source}`):a()}function k(e="Please enter a valid email address"){let r=/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;return t=>t&&!r.test(t)?s(e,"INVALID_EMAIL"):a()}function N(e="Please enter a valid URL"){let r=/^https?:\/\/(?:[-\w.])+(?:\:[0-9]+)?(?:\/(?:[\w/_.])*(?:\?(?:[\w&=%.])*)?(?:\#(?:[\w.])*)?)?$/;return t=>t&&!r.test(t)?s(e,"INVALID_URL"):a()}function E(e="Must be a valid number"){return r=>{let t=typeof r=="string"?Number.parseFloat(r):r;return Number.isNaN(t)||!Number.isFinite(t)?s(e,"INVALID_NUMBER"):a()}}function I(e,r){return t=>{let n=typeof t=="string"?Number.parseFloat(t):t;return !Number.isNaN(n)&&n<e?s(r||`Must be at least ${e}`,"MIN_VALUE",`min.${e}`):a()}}function P(e,r){return t=>{let n=typeof t=="string"?Number.parseFloat(t):t;return !Number.isNaN(n)&&n>e?s(r||`Must be no more than ${e}`,"MAX_VALUE",`max.${e}`):a()}}function L(e,r,t){return (n,o)=>e(n,o)?a():s(r,t||"CUSTOM_VALIDATION_FAILED")}function B(e,r){return (t,n)=>{let o=n.allFormData?.[e];return t!==o?s(r||"Fields must match","FIELD_MISMATCH",`match.${e}`):a()}}function D(e,r){return (t,n)=>e(t,n)?r(t,n):a()}function $(e,r,t){return async(n,o)=>{try{return await e(n,o)?a():s(r,t||"ASYNC_VALIDATION_FAILED")}catch(i){return s(i instanceof Error?i.message:"Async validation error","ASYNC_ERROR")}}}var p=class{constructor(){this.name="ZodValidationAdapter";this.version="1.0.0";}createFieldValidator(r){return (t,n)=>{try{let o=r.safeParse(t);return o.success?a():{isValid:!1,errors:o.error.errors.map(l=>({message:l.message,code:"VALIDATION_ERROR",path:l.path.join(".")}))}}catch(o){return s(o instanceof Error?o.message:"Validation failed","VALIDATION_ERROR")}}}createFormValidator(r){return (t,n)=>{try{let o=r.safeParse(t);return o.success?a():{isValid:!1,errors:o.error.errors.map(l=>({message:l.message,code:"VALIDATION_ERROR",path:l.path.join(".")}))}}catch(o){return s(o instanceof Error?o.message:"Form validation failed","VALIDATION_ERROR")}}}};function m(){return new p}function _(e){return m().createFieldValidator(e)}function O(e){return m().createFormValidator(e)}exports.ComponentRendererWrapper=v;exports.IdGenerator=V;exports.async=$;exports.combineValidationResults=c;exports.configureObject=u;exports.createValidationContext=w;exports.createValidationResult=d;exports.createZodAdapter=m;exports.custom=L;exports.deepClone=T;exports.email=k;exports.ensureUnique=C;exports.matchField=B;exports.max=P;exports.maxLength=A;exports.mergeInto=W;exports.min=I;exports.minLength=F;exports.normalizeToArray=U;exports.number=E;exports.pattern=b;exports.required=x;exports.resolveRendererChildren=R;exports.ril=f;exports.runValidators=h;exports.runValidatorsAsync=y;exports.url=N;exports.validateRequired=z;exports.when=D;exports.zodFieldValidator=_;exports.zodFormValidator=O;
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- import {z}from'zod';function P(o,e){return typeof o=="function"?o(e):o}function b(o,e){return {...o,...e}}function h(o,e){let r=o.filter((n,t)=>o.indexOf(n)!==t);if(r.length>0)throw new Error(`Duplicate ${e} IDs: ${r.join(", ")}`)}function S(o,e,r){if(o.filter(t=>e.some(a=>!t[a])).length>0)throw new Error(`Missing required fields in ${r}: ${e.join(", ")}`)}var R=class{constructor(){this.counters=new Map;}next(e){let r=this.counters.get(e)||0;return this.counters.set(e,r+1),`${e}-${r+1}`}reset(e){e?this.counters.delete(e):this.counters.clear();}},y=class{constructor(){this.errors=[];}add(e,r,n){return this.errors.push({code:e,message:r,path:n}),this}addIf(e,r,n,t){return e&&this.add(r,n,t),this}build(){return [...this.errors]}hasErrors(){return this.errors.length>0}clear(){return this.errors=[],this}},V={hasValue:o=>o!=null&&o!=="",isArray:o=>Array.isArray(o),arrayMinLength:(o,e)=>o.length>=e,arrayMaxLength:(o,e)=>o.length<=e};function F(o){return Array.isArray(o)?o:[o]}function C(o){if(o===null||typeof o!="object")return o;if(o instanceof Date)return new Date(o.getTime());if(Array.isArray(o))return o.map(r=>C(r));let e={};for(let r in o)Object.prototype.hasOwnProperty.call(o,r)&&(e[r]=C(o[r]));return e}function g(o,e,r){let n={...o};for(let t in e)r&&!r.includes(t)||e[t]!==void 0&&(n[t]=e[t]);return n}var w=class o{constructor(){this.components=new Map;this.formRenderConfig={};this.workflowRenderConfig={};}static create(){return new o}addComponent(e,r){let n={id:e,type:e,...r};return this.components.set(e,n),this}configure(e){let r=["rowRenderer","bodyRenderer","submitButtonRenderer","fieldRenderer"],n=["stepperRenderer","nextButtonRenderer","previousButtonRenderer","skipButtonRenderer"],t={},a={};for(let[i,s]of Object.entries(e))r.includes(i)?t[i]=s:n.includes(i)&&(a[i]=s);return this.formRenderConfig=g(this.formRenderConfig,t),this.workflowRenderConfig=g(this.workflowRenderConfig,a),this}getFormRenderConfig(){return {...this.formRenderConfig}}getWorkflowRenderConfig(){return {...this.workflowRenderConfig}}getComponent(e){return this.components.get(e)}getAllComponents(){return Array.from(this.components.values())}hasComponent(e){return this.components.has(e)}removeComponent(e){return this.components.delete(e)}clear(){this.components.clear();}getStats(){let e=Array.from(this.components.values());return {total:e.length,byType:e.reduce((r,n)=>(r[n.type]=(r[n.type]||0)+1,r),{}),hasCustomRenderers:{row:!!this.formRenderConfig.rowRenderer,body:!!this.formRenderConfig.bodyRenderer,submitButton:!!this.formRenderConfig.submitButtonRenderer,field:!!this.formRenderConfig.fieldRenderer,stepper:!!this.workflowRenderConfig.stepperRenderer,workflowNextButton:!!this.workflowRenderConfig.nextButtonRenderer,workflowPreviousButton:!!this.workflowRenderConfig.previousButtonRenderer,workflowSkipButton:!!this.workflowRenderConfig.skipButtonRenderer}}}validate(){let e=new y,r=Array.from(this.components.values()),n=r.map(a=>a.id);try{h(n,"component");}catch(a){e.add("DUPLICATE_IDS",a instanceof Error?a.message:String(a));}let t=r.filter(a=>!a.renderer);return e.addIf(t.length>0,"MISSING_RENDERER",`Components without renderer: ${t.map(a=>a.id).join(", ")}`),e.build().map(a=>a.message)}};var p=o=>async e=>{try{return await o.parseAsync(e),{isValid:!0,errors:[]}}catch(r){return r&&typeof r=="object"&&"errors"in r&&Array.isArray(r.errors)?{isValid:false,errors:r.errors.map(n=>({code:n.code,message:n.message,path:n.path?n.path.map(String):[]}))}:{isValid:false,errors:[{code:"unknown",message:r instanceof Error?r.message:"Unknown validation error"}]}}},k=o=>async(e,r,n)=>{try{let t=await o(e,r);return t===!0?{isValid:!0,errors:[]}:t===!1?{isValid:!1,errors:[{code:"validation_failed",message:"Validation failed"}]}:{isValid:!1,errors:[{code:"validation_failed",message:String(t)}]}}catch(t){return {isValid:false,errors:[{code:"validation_error",message:t instanceof Error?t.message:"Validation error"}]}}},D=(o,e="all")=>async(r,n,t)=>{let a=await Promise.all(o.map(d=>d(r,n,t)));if(e==="all"){let d=a.flatMap(l=>l.errors);return {isValid:a.every(l=>l.isValid),errors:d}}return a.some(d=>d.isValid)?{isValid:true,errors:[]}:{isValid:false,errors:a.flatMap(d=>d.errors)}},N=(o,e)=>async(r,n,t)=>o(r,n)?e(r,n,t):{isValid:true,errors:[]},I={required:(o="This field is required")=>k(e=>e==null||e===""?o:!0),email:(o="Invalid email format")=>p(z.string().email(o)),minLength:(o,e)=>p(z.string().min(o,e||`Minimum ${o} characters required`)),maxLength:(o,e)=>p(z.string().max(o,e||`Maximum ${o} characters allowed`)),pattern:(o,e="Invalid format")=>p(z.string().regex(o,e)),numberRange:(o,e,r)=>{let n=z.number();return o!==void 0&&(n=n.min(o,r||`Value must be at least ${o}`)),e!==void 0&&(n=n.max(e,r||`Value must be at most ${e}`)),p(n)},url:(o="Invalid URL format")=>p(z.string().url(o)),phoneNumber:(o="Invalid phone number format")=>p(z.string().regex(/^\+?[\d\s\-\(\)]+$/,o)),asyncValidation:(o,e=300)=>{let r=new Map;return (n,t,a)=>new Promise(i=>{let s=`${t.fieldId}-${JSON.stringify(n)}`;r.has(s)&&clearTimeout(r.get(s));let d=setTimeout(async()=>{try{let l=await o(n,t);i(l===!0?{isValid:!0,errors:[]}:{isValid:!1,errors:[{code:"async_validation_failed",message:typeof l=="string"?l:"Async validation failed"}]});}catch(l){i({isValid:false,errors:[{code:"async_validation_error",message:l instanceof Error?l.message:"Async validation error"}]});}finally{r.delete(s);}},e);r.set(s,d);})}},A=(o,e=[])=>({isValid:o,errors:e}),$=(o,e,r)=>({code:o,message:e,path:r});var m=class{constructor(){this.name="localStorage";}async save(e,r){try{localStorage.setItem(e,JSON.stringify(r));}catch(n){throw new Error(`Failed to save to localStorage: ${n}`)}}async load(e){try{let r=localStorage.getItem(e);return r?JSON.parse(r):null}catch(r){throw new Error(`Failed to load from localStorage: ${r}`)}}async remove(e){try{localStorage.removeItem(e);}catch(r){throw new Error(`Failed to remove from localStorage: ${r}`)}}async exists(e){return localStorage.getItem(e)!==null}async list(e){let r=[];for(let n=0;n<localStorage.length;n++){let t=localStorage.key(n);t&&(!e||t.includes(e))&&r.push(t);}return r}},u=class{constructor(){this.name="sessionStorage";}async save(e,r){try{sessionStorage.setItem(e,JSON.stringify(r));}catch(n){throw new Error(`Failed to save to sessionStorage: ${n}`)}}async load(e){try{let r=sessionStorage.getItem(e);return r?JSON.parse(r):null}catch(r){throw new Error(`Failed to load from sessionStorage: ${r}`)}}async remove(e){try{sessionStorage.removeItem(e);}catch(r){throw new Error(`Failed to remove from sessionStorage: ${r}`)}}async exists(e){return sessionStorage.getItem(e)!==null}async list(e){let r=[];for(let n=0;n<sessionStorage.length;n++){let t=sessionStorage.key(n);t&&(!e||t.includes(e))&&r.push(t);}return r}},f=class{constructor(){this.name="memory";this.storage=new Map;}async save(e,r){this.storage.set(e,{...r});}async load(e){let r=this.storage.get(e);return r?{...r}:null}async remove(e){this.storage.delete(e);}async exists(e){return this.storage.has(e)}async list(e){let r=Array.from(this.storage.keys());return e?r.filter(n=>n.includes(e)):r}clear(){this.storage.clear();}},x=class{constructor(e,r=[]){this.primary=e;this.fallbacks=r;this.name="composite";}async save(e,r){let n=[this.primary,...this.fallbacks];for(let t of n)try{await t.save(e,r);return}catch(a){console.warn(`Failed to save with ${t.name}:`,a);}throw new Error("All persistence adapters failed to save")}async load(e){let r=[this.primary,...this.fallbacks];for(let n of r)try{let t=await n.load(e);if(t)return t}catch(t){console.warn(`Failed to load with ${n.name}:`,t);}return null}async remove(e){let r=[this.primary,...this.fallbacks],n=[];for(let t of r)try{await t.remove(e);}catch(a){n.push(a);}if(n.length===r.length)throw new Error(`All adapters failed to remove: ${n.map(t=>t.message).join(", ")}`)}async exists(e){let r=[this.primary,...this.fallbacks];for(let n of r)try{if(await n.exists(e))return !0}catch(t){console.warn(`Failed to check existence with ${n.name}:`,t);}return false}async list(e){try{return await this.primary.list?.(e)||[]}catch(r){console.warn("Failed to list with primary adapter:",r);for(let n of this.fallbacks)try{return await n.list?.(e)||[]}catch(t){console.warn(`Failed to list with fallback ${n.name}:`,t);}return []}}};var q={localStorage(o={}){return {adapter:new m,debounceMs:1e3,autoSave:true,saveOnStepChange:true,...o}},sessionStorage(o={}){return {adapter:new u,debounceMs:1e3,autoSave:true,saveOnStepChange:true,...o}},memory(o={}){return {adapter:new f,debounceMs:0,autoSave:true,saveOnStepChange:true,...o}},custom(o,e={}){return {adapter:o,debounceMs:1e3,autoSave:true,saveOnStepChange:true,...e}}};function _(o,e,r={}){let n=e||new f;return {adapter:{name:`resilient-${o.name}`,async save(a,i){try{await o.save(a,i);}catch(s){console.warn("Primary persistence failed, using fallback:",s),await n.save(a,i);}},async load(a){try{let i=await o.load(a);if(i)return i}catch(i){console.warn("Primary persistence load failed, trying fallback:",i);}return await n.load(a)},async remove(a){let i=[];try{await o.remove(a);}catch(s){i.push(s);}try{await n.remove(a);}catch(s){i.push(s);}if(i.length===2)throw new Error(`Both adapters failed: ${i.map(s=>s.message).join(", ")}`)},async exists(a){try{if(await o.exists(a))return !0}catch(i){console.warn("Primary persistence exists check failed:",i);}try{return await n.exists(a)}catch(i){return console.warn("Fallback persistence exists check failed:",i),false}},async list(a){try{return await o.list?.(a)||[]}catch(i){console.warn("Primary persistence list failed:",i);try{return await n.list?.(a)||[]}catch(s){return console.warn("Fallback persistence list failed:",s),[]}}}},debounceMs:1e3,autoSave:true,saveOnStepChange:true,maxRetries:3,retryDelayMs:1e3,...r}}export{x as CompositeAdapter,R as IdGenerator,m as LocalStorageAdapter,f as MemoryAdapter,u as SessionStorageAdapter,y as ValidationErrorBuilder,V as ValidationPatterns,D as combineValidators,I as commonValidators,g as configureObject,N as createConditionalValidator,k as createCustomValidator,_ as createResilientPersistence,$ as createValidationError,A as createValidationResult,p as createZodValidator,C as deepClone,h as ensureUnique,b as mergeInto,F as normalizeToArray,q as persistence,P as resolveRendererChildren,w as ril,S as validateRequired};
1
+ function R(e,r){return typeof e=="function"?e(r):e}function v({children:e,renderAs:r,renderer:t,name:n,props:o}){if(r==="children"||r===true){if(typeof e!="function")throw new Error(`When renderAs="children" is used, children must be a function that returns React elements for ${n}`);return e(o)}if(!t)throw new Error(`No renderer provided for ${n}`);if(typeof t!="function")throw new Error(`Renderer must be a function for ${n}`);let l={...o,children:R(e,o)};return t(l)}function W(e,r){return {...e,...r}}function C(e,r){let t=e.filter((n,o)=>e.indexOf(n)!==o);if(t.length>0)throw new Error(`Duplicate ${r} IDs: ${t.join(", ")}`)}function z(e,r,t){if(e.filter(o=>r.some(i=>!o[i])).length>0)throw new Error(`Missing required fields in ${t}: ${r.join(", ")}`)}var V=class{constructor(){this.counters=new Map;}next(r){let t=this.counters.get(r)||0;return this.counters.set(r,t+1),`${r}-${t+1}`}reset(r){r?this.counters.delete(r):this.counters.clear();}};function U(e){return Array.isArray(e)?e:[e]}function T(e){if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(Array.isArray(e))return e.map(t=>T(t));let r={};for(let t in e)Object.prototype.hasOwnProperty.call(e,t)&&(r[t]=T(e[t]));return r}function u(e,r,t){let n={...e};for(let o in r)t&&!t.includes(o)||r[o]!==void 0&&(n[o]=r[o]);return n}var f=class e{constructor(){this.components=new Map;this.formRenderConfig={};this.workflowRenderConfig={};}static create(){return new e}addComponent(r,t){let n={id:r,type:r,...t};return this.components.set(r,n),this}configure(r){let t=["rowRenderer","bodyRenderer","submitButtonRenderer","fieldRenderer"],n=["stepperRenderer","nextButtonRenderer","previousButtonRenderer","skipButtonRenderer"],o={},i={};for(let[l,g]of Object.entries(r))t.includes(l)?o[l]=g:n.includes(l)&&(i[l]=g);return this.formRenderConfig=u(this.formRenderConfig,o),this.workflowRenderConfig=u(this.workflowRenderConfig,i),this}getFormRenderConfig(){return {...this.formRenderConfig}}getWorkflowRenderConfig(){return {...this.workflowRenderConfig}}getComponent(r){return this.components.get(r)}getAllComponents(){return Array.from(this.components.values())}hasComponent(r){return this.components.has(r)}removeComponent(r){return this.components.delete(r)}clear(){this.components.clear();}getStats(){let r=Array.from(this.components.values());return {total:r.length,byType:r.reduce((t,n)=>(t[n.type]=(t[n.type]||0)+1,t),{}),hasCustomRenderers:{row:!!this.formRenderConfig.rowRenderer,body:!!this.formRenderConfig.bodyRenderer,submitButton:!!this.formRenderConfig.submitButtonRenderer,field:!!this.formRenderConfig.fieldRenderer,stepper:!!this.workflowRenderConfig.stepperRenderer,workflowNextButton:!!this.workflowRenderConfig.nextButtonRenderer,workflowPreviousButton:!!this.workflowRenderConfig.previousButtonRenderer,workflowSkipButton:!!this.workflowRenderConfig.skipButtonRenderer}}}validate(){let r=[],t=Array.from(this.components.values()),n=t.map(i=>i.id);try{C(n,"component");}catch(i){r.push(i instanceof Error?i.message:String(i));}let o=t.filter(i=>!i.renderer);return o.length>0&&r.push(`Components without renderer: ${o.map(i=>i.id).join(", ")}`),r}};function d(e,r=[]){return {isValid:e,errors:[...r]}}function a(){return d(true,[])}function s(e,r,t){return d(false,[{message:e,code:r,path:t}])}function c(e){let r=[],t=true;for(let n of e)n.isValid||(t=false),r.push(...n.errors);return d(t,r)}function h(e,r,t){let n=e.map(o=>{let i=o(r,t);if(i instanceof Promise)throw new Error("Use runValidatorsAsync for async validators");return i});return c(n)}async function y(e,r,t){let n=await Promise.all(e.map(o=>o(r,t)));return c(n)}function w(e={}){return {fieldId:e.fieldId,formId:e.formId,stepId:e.stepId,workflowId:e.workflowId,allFormData:e.allFormData||{},stepData:e.stepData||{},workflowData:e.workflowData||{}}}function x(e="This field is required"){return r=>r==null||r===""||Array.isArray(r)&&r.length===0?s(e,"REQUIRED"):a()}function F(e,r){return t=>!t||t.length<e?s(r||`Must be at least ${e} characters long`,"MIN_LENGTH",`length.${e}`):a()}function A(e,r){return t=>t&&t.length>e?s(r||`Must be no more than ${e} characters long`,"MAX_LENGTH",`length.${e}`):a()}function b(e,r){return t=>t&&!e.test(t)?s(r||"Invalid format","PATTERN_MISMATCH",`pattern.${e.source}`):a()}function k(e="Please enter a valid email address"){let r=/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;return t=>t&&!r.test(t)?s(e,"INVALID_EMAIL"):a()}function N(e="Please enter a valid URL"){let r=/^https?:\/\/(?:[-\w.])+(?:\:[0-9]+)?(?:\/(?:[\w/_.])*(?:\?(?:[\w&=%.])*)?(?:\#(?:[\w.])*)?)?$/;return t=>t&&!r.test(t)?s(e,"INVALID_URL"):a()}function E(e="Must be a valid number"){return r=>{let t=typeof r=="string"?Number.parseFloat(r):r;return Number.isNaN(t)||!Number.isFinite(t)?s(e,"INVALID_NUMBER"):a()}}function I(e,r){return t=>{let n=typeof t=="string"?Number.parseFloat(t):t;return !Number.isNaN(n)&&n<e?s(r||`Must be at least ${e}`,"MIN_VALUE",`min.${e}`):a()}}function P(e,r){return t=>{let n=typeof t=="string"?Number.parseFloat(t):t;return !Number.isNaN(n)&&n>e?s(r||`Must be no more than ${e}`,"MAX_VALUE",`max.${e}`):a()}}function L(e,r,t){return (n,o)=>e(n,o)?a():s(r,t||"CUSTOM_VALIDATION_FAILED")}function B(e,r){return (t,n)=>{let o=n.allFormData?.[e];return t!==o?s(r||"Fields must match","FIELD_MISMATCH",`match.${e}`):a()}}function D(e,r){return (t,n)=>e(t,n)?r(t,n):a()}function $(e,r,t){return async(n,o)=>{try{return await e(n,o)?a():s(r,t||"ASYNC_VALIDATION_FAILED")}catch(i){return s(i instanceof Error?i.message:"Async validation error","ASYNC_ERROR")}}}var p=class{constructor(){this.name="ZodValidationAdapter";this.version="1.0.0";}createFieldValidator(r){return (t,n)=>{try{let o=r.safeParse(t);return o.success?a():{isValid:!1,errors:o.error.errors.map(l=>({message:l.message,code:"VALIDATION_ERROR",path:l.path.join(".")}))}}catch(o){return s(o instanceof Error?o.message:"Validation failed","VALIDATION_ERROR")}}}createFormValidator(r){return (t,n)=>{try{let o=r.safeParse(t);return o.success?a():{isValid:!1,errors:o.error.errors.map(l=>({message:l.message,code:"VALIDATION_ERROR",path:l.path.join(".")}))}}catch(o){return s(o instanceof Error?o.message:"Form validation failed","VALIDATION_ERROR")}}}};function m(){return new p}function _(e){return m().createFieldValidator(e)}function O(e){return m().createFormValidator(e)}export{v as ComponentRendererWrapper,V as IdGenerator,$ as async,c as combineValidationResults,u as configureObject,w as createValidationContext,d as createValidationResult,m as createZodAdapter,L as custom,T as deepClone,k as email,C as ensureUnique,B as matchField,P as max,A as maxLength,W as mergeInto,I as min,F as minLength,U as normalizeToArray,E as number,b as pattern,x as required,R as resolveRendererChildren,f as ril,h as runValidators,y as runValidatorsAsync,N as url,z as validateRequired,D as when,_ as zodFieldValidator,O as zodFormValidator};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rilaykit/core",
3
- "version": "4.0.0",
3
+ "version": "5.0.0",
4
4
  "description": "Core types, configurations, and utilities for the RilayKit form library",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",