@nocios/crudify-ui 4.1.58 → 4.1.60

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.
@@ -1 +1 @@
1
- import{h as $,j as D}from"./chunk-FM2YKL4E.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as F}from"react";import Q from"@nocios/crudify-browser";var G=(S={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:g=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:a,tokens:R}=D(),[E,d]=K(null),[y,O]=K(!1),[A,p]=K(null),u=F(null),o=F(!0),m=F(0),l=F(0),L=j(()=>a&&(a.email||a["cognito:username"])||null,[a]),P=j(()=>{d(null),p(null),O(!1),l.current=0},[]),w=j(async()=>{let x=L();if(!x){o.current&&(p("No user email available from session data"),O(!1));return}if(!I){o.current&&(p("Session not initialized"),O(!1));return}u.current&&u.current.abort();let e=new AbortController;u.current=e;let i=++m.current;try{o.current&&(O(!0),p(null));let r=await Q.readItems("users",{filter:{email:x},pagination:{limit:1}});if(i===m.current&&o.current&&!e.signal.aborted){let t=null;if(r.success){if(Array.isArray(r.data)&&r.data.length>0)t=r.data[0];else if(r.data?.response?.data)try{let s=r.data.response.data,n=typeof s=="string"?JSON.parse(s):s;n&&n.items&&Array.isArray(n.items)&&n.items.length>0&&(t=n.items[0])}catch{}else if(r.data&&typeof r.data=="object")r.data.items&&Array.isArray(r.data.items)&&r.data.items.length>0&&(t=r.data.items[0]);else if(r.data?.data?.response?.data)try{let s=r.data.data.response.data,n=typeof s=="string"?JSON.parse(s):s;n&&n.items&&Array.isArray(n.items)&&n.items.length>0&&(t=n.items[0])}catch{}}t?(d(t),p(null),l.current=0):(p("User profile not found in database"),d(null))}}catch(r){if(i===m.current&&o.current){let t=r;if(t.name==="AbortError")return;N&&l.current<g&&(t.message?.includes("Network Error")||t.message?.includes("Failed to fetch"))?(l.current++,setTimeout(()=>{o.current&&w()},1e3*l.current)):(p("Failed to load user profile from database"),d(null))}}finally{i===m.current&&o.current&&O(!1),u.current===e&&(u.current=null)}},[I,L,N,g]);return z(()=>{c&&T&&I?w():T||P()},[c,T,I,w,P]),z(()=>(o.current=!0,()=>{o.current=!1,u.current&&(u.current.abort(),u.current=null)}),[]),{user:{session:a,data:E},loading:y,error:A,refreshProfile:w,clearProfile:P}};import{useCallback as W}from"react";var ee=()=>{let{isAuthenticated:S,isLoading:c,isInitialized:N,tokens:g,error:T,sessionData:I,login:a,logout:R,refreshTokens:E,clearError:d,getTokenInfo:y,isExpiringSoon:O,expiresIn:A,refreshExpiresIn:p}=D(),u=W(m=>{m?console.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):R()},[R]),o=g?.expiresAt?new Date(g.expiresAt):null;return{isAuthenticated:S,loading:c,error:T,token:g?.accessToken||null,user:I,tokenExpiration:o,setToken:u,logout:R,refreshToken:E,login:a,isExpiringSoon:O,expiresIn:A,refreshExpiresIn:p,getTokenInfo:y,clearError:d}};import{useCallback as h}from"react";import U from"@nocios/crudify-browser";var oe=()=>{let{isInitialized:S,isLoading:c,error:N,isAuthenticated:g,login:T}=D(),I=h(()=>S&&!c&&!N,[S,c,N]),a=h(async()=>new Promise((o,m)=>{let l=()=>{I()?o():N?m(new Error(N)):setTimeout(l,100)};l()}),[I,N]),R=h(async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),E=h(async(o,m,l)=>(await R(),await U.readItems(o,m||{},l)),[R]),d=h(async(o,m,l)=>(await R(),await U.readItem(o,m,l)),[R]),y=h(async(o,m,l)=>(await R(),await U.createItem(o,m,l)),[R]),O=h(async(o,m,l)=>(await R(),await U.updateItem(o,m,l)),[R]),A=h(async(o,m,l)=>(await R(),await U.deleteItem(o,m,l)),[R]),p=h(async(o,m)=>(await R(),await U.transaction(o,m)),[R]),u=h(async(o,m)=>{try{let l=await T(o,m);return l.success?{success:!0,data:l.tokens}:{success:!1,errors:l.error||"Login failed"}}catch(l){return{success:!1,errors:l instanceof Error?l.message:"Login failed"}}},[T]);return{readItems:E,readItem:d,createItem:y,updateItem:O,deleteItem:A,transaction:p,login:u,isInitialized:S,isInitializing:c,initializationError:N,isReady:I,waitForReady:a}};import{useCallback as C}from"react";import b from"@nocios/crudify-browser";var Y={INVALID_CREDENTIALS:"warning",UNAUTHORIZED:"warning",INVALID_API_KEY:"error",USER_NOT_FOUND:"warning",USER_NOT_ACTIVE:"warning",NO_PERMISSION:"warning",ITEM_NOT_FOUND:"info",NOT_FOUND:"info",IN_USE:"warning",FIELD_ERROR:"warning",BAD_REQUEST:"warning",INTERNAL_SERVER_ERROR:"error",DATABASE_CONNECTION_ERROR:"error",INVALID_CONFIGURATION:"error",UNKNOWN_OPERATION:"error",TOO_MANY_REQUESTS:"warning"},v={INVALID_CREDENTIALS:"errors.auth.INVALID_CREDENTIALS",UNAUTHORIZED:"errors.auth.UNAUTHORIZED",INVALID_API_KEY:"errors.auth.INVALID_API_KEY",USER_NOT_FOUND:"errors.auth.USER_NOT_FOUND",USER_NOT_ACTIVE:"errors.auth.USER_NOT_ACTIVE",NO_PERMISSION:"errors.auth.NO_PERMISSION",ITEM_NOT_FOUND:"errors.data.ITEM_NOT_FOUND",NOT_FOUND:"errors.data.NOT_FOUND",IN_USE:"errors.data.IN_USE",FIELD_ERROR:"errors.data.FIELD_ERROR",BAD_REQUEST:"errors.data.BAD_REQUEST",INTERNAL_SERVER_ERROR:"errors.system.INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"errors.system.DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"errors.system.INVALID_CONFIGURATION",UNKNOWN_OPERATION:"errors.system.UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"errors.system.TOO_MANY_REQUESTS"},le=(S={})=>{let{showNotification:c}=$(),{showSuccessNotifications:N=!1,showErrorNotifications:g=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:a=6e3,appStructure:R=[],translateFn:E=e=>e}=S,d=C(e=>!(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||e.errors._transaction?.includes("ONE_OR_MORE_OPERATIONS_FAILED")||e.errors._error?.includes("TOO_MANY_REQUESTS"))||!e.success&&e.data?.response?.status==="TOO_MANY_REQUESTS"),[]),y=C((e,i)=>{let r=E(e);return r===e?i||E("error.unknown"):r},[E]),O=C(e=>["create","update","delete"].includes(e),[]),A=C((e,i)=>N?O(e)&&i?!0:R.some(r=>r.key===e):!1,[N,R,O]),p=C((e,i,r)=>{let t=r?.key&&typeof r.key=="string"?r.key:e,s=`action.onSuccess.${t}`,n=y(s);if(n!==E("error.unknown")){if(O(t)&&i){let f=`action.${i}Singular`,_=y(f);if(_!==E("error.unknown"))return E(s,{item:_});{let M=`action.onSuccess.${t}WithoutItem`,k=y(M);return k!==E("error.unknown")?k:n}}return n}return E("success.transaction")},[y,E,O]),u=C(e=>{if(e.errorCode&&T[e.errorCode])return T[e.errorCode];if(e.errorCode&&v[e.errorCode])return y(v[e.errorCode]);if(e.errorCode){let i=[`errors.auth.${e.errorCode}`,`errors.data.${e.errorCode}`,`errors.system.${e.errorCode}`,`errors.${e.errorCode}`];for(let r of i){let t=y(r);if(t!==E("error.unknown"))return t}}if(typeof e.data=="string"&&e.data.startsWith("errors.")){let i=y(e.data);if(i!==E("error.unknown"))return i}if(e.errors&&Object.keys(e.errors).length>0){let i=Object.keys(e.errors);if(i.length===1&&i[0]==="_transaction"){let r=e.errors._transaction;if(r?.includes("ONE_OR_MORE_OPERATIONS_FAILED"))return"";if(Array.isArray(r)&&r.length>0){let t=r[0];if(typeof t=="string"&&t!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let s=JSON.parse(t);if(Array.isArray(s)&&s.length>0){let n=s[0];if(n?.response?.errorCode){let f=n.response.errorCode;if(v[f])return y(v[f]);let _=[`errors.auth.${f}`,`errors.data.${f}`,`errors.system.${f}`,`errors.${f}`];for(let M of _){let k=y(M);if(k!==y("error.unknown"))return k}}if(n?.response?.data)return n.response.data}if(s?.response?.message){let n=s.response.message.toLowerCase();return n.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):s.response.message}}catch{return t.toLowerCase().includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):t.toLowerCase().includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t}}return y("error.transaction","Error en la operaci\xF3n")}if(i.length===1&&i[0]==="_error"){let r=e.errors._error;return Array.isArray(r)?r[0]:String(r)}return i.length===1&&i[0]==="_graphql"?y("errors.system.DATABASE_CONNECTION_ERROR"):`${y("errors.data.FIELD_ERROR")}: ${i.join(", ")}`}return I||E("error.unknown")},[T,I,E,y]),o=C(e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),m=C(async(e,i,r)=>{let t=await b.createItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"create",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),l=C(async(e,i,r)=>{let t=await b.updateItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"update",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),L=C(async(e,i,r)=>{let t=await b.deleteItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"delete",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),P=C(async(e,i,r)=>{let t=await b.readItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}return t},[g,c,u,o,a,d]),w=C(async(e,i,r)=>{let t=await b.readItems(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}return t},[g,c,u,o,a,d]),V=C(async(e,i)=>{let r=await b.transaction(e,i),t=i?.skipNotifications===!0;if(!t&&!r.success&&g&&d(r)){let s=u(r),n=o(r);c(s,n,{autoHideDuration:a})}else if(!t&&r.success){let s="transaction",n,f=null;if(i?.actionConfig?(f=i.actionConfig,s=f.key,n=f.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(s=e[0].operation,f=R.find(_=>_.key===s),f&&(n=f.moduleKey)),A(s,n)){let _=p(s,n,f);c(_,"success",{autoHideDuration:a})}}return r},[g,A,c,u,o,p,a,d,R]),x=C((e,i)=>{if(!e.success&&g&&d(e)){let r=u(e),t=o(e);c(r,t,{autoHideDuration:a})}else e.success&&N&&i&&c(i,"success",{autoHideDuration:a});return e},[g,N,c,u,o,a,d,E]);return{createItem:m,updateItem:l,deleteItem:L,readItem:P,readItems:w,transaction:V,handleResponse:x,getErrorMessage:u,getErrorSeverity:o,shouldShowNotification:d}};export{G as a,ee as b,oe as c,le as d};
1
+ import{h as $,j as D}from"./chunk-IPMROPYS.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as F}from"react";import Q from"@nocios/crudify-browser";var G=(S={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:g=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:a,tokens:R}=D(),[E,d]=K(null),[y,O]=K(!1),[A,p]=K(null),u=F(null),o=F(!0),m=F(0),l=F(0),L=j(()=>a&&(a.email||a["cognito:username"])||null,[a]),P=j(()=>{d(null),p(null),O(!1),l.current=0},[]),w=j(async()=>{let x=L();if(!x){o.current&&(p("No user email available from session data"),O(!1));return}if(!I){o.current&&(p("Session not initialized"),O(!1));return}u.current&&u.current.abort();let e=new AbortController;u.current=e;let i=++m.current;try{o.current&&(O(!0),p(null));let r=await Q.readItems("users",{filter:{email:x},pagination:{limit:1}});if(i===m.current&&o.current&&!e.signal.aborted){let t=null;if(r.success){if(Array.isArray(r.data)&&r.data.length>0)t=r.data[0];else if(r.data?.response?.data)try{let s=r.data.response.data,n=typeof s=="string"?JSON.parse(s):s;n&&n.items&&Array.isArray(n.items)&&n.items.length>0&&(t=n.items[0])}catch{}else if(r.data&&typeof r.data=="object")r.data.items&&Array.isArray(r.data.items)&&r.data.items.length>0&&(t=r.data.items[0]);else if(r.data?.data?.response?.data)try{let s=r.data.data.response.data,n=typeof s=="string"?JSON.parse(s):s;n&&n.items&&Array.isArray(n.items)&&n.items.length>0&&(t=n.items[0])}catch{}}t?(d(t),p(null),l.current=0):(p("User profile not found in database"),d(null))}}catch(r){if(i===m.current&&o.current){let t=r;if(t.name==="AbortError")return;N&&l.current<g&&(t.message?.includes("Network Error")||t.message?.includes("Failed to fetch"))?(l.current++,setTimeout(()=>{o.current&&w()},1e3*l.current)):(p("Failed to load user profile from database"),d(null))}}finally{i===m.current&&o.current&&O(!1),u.current===e&&(u.current=null)}},[I,L,N,g]);return z(()=>{c&&T&&I?w():T||P()},[c,T,I,w,P]),z(()=>(o.current=!0,()=>{o.current=!1,u.current&&(u.current.abort(),u.current=null)}),[]),{user:{session:a,data:E},loading:y,error:A,refreshProfile:w,clearProfile:P}};import{useCallback as W}from"react";var ee=()=>{let{isAuthenticated:S,isLoading:c,isInitialized:N,tokens:g,error:T,sessionData:I,login:a,logout:R,refreshTokens:E,clearError:d,getTokenInfo:y,isExpiringSoon:O,expiresIn:A,refreshExpiresIn:p}=D(),u=W(m=>{m?console.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):R()},[R]),o=g?.expiresAt?new Date(g.expiresAt):null;return{isAuthenticated:S,loading:c,error:T,token:g?.accessToken||null,user:I,tokenExpiration:o,setToken:u,logout:R,refreshToken:E,login:a,isExpiringSoon:O,expiresIn:A,refreshExpiresIn:p,getTokenInfo:y,clearError:d}};import{useCallback as h}from"react";import U from"@nocios/crudify-browser";var oe=()=>{let{isInitialized:S,isLoading:c,error:N,isAuthenticated:g,login:T}=D(),I=h(()=>S&&!c&&!N,[S,c,N]),a=h(async()=>new Promise((o,m)=>{let l=()=>{I()?o():N?m(new Error(N)):setTimeout(l,100)};l()}),[I,N]),R=h(async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),E=h(async(o,m,l)=>(await R(),await U.readItems(o,m||{},l)),[R]),d=h(async(o,m,l)=>(await R(),await U.readItem(o,m,l)),[R]),y=h(async(o,m,l)=>(await R(),await U.createItem(o,m,l)),[R]),O=h(async(o,m,l)=>(await R(),await U.updateItem(o,m,l)),[R]),A=h(async(o,m,l)=>(await R(),await U.deleteItem(o,m,l)),[R]),p=h(async(o,m)=>(await R(),await U.transaction(o,m)),[R]),u=h(async(o,m)=>{try{let l=await T(o,m);return l.success?{success:!0,data:l.tokens}:{success:!1,errors:l.error||"Login failed"}}catch(l){return{success:!1,errors:l instanceof Error?l.message:"Login failed"}}},[T]);return{readItems:E,readItem:d,createItem:y,updateItem:O,deleteItem:A,transaction:p,login:u,isInitialized:S,isInitializing:c,initializationError:N,isReady:I,waitForReady:a}};import{useCallback as C}from"react";import b from"@nocios/crudify-browser";var Y={INVALID_CREDENTIALS:"warning",UNAUTHORIZED:"warning",INVALID_API_KEY:"error",USER_NOT_FOUND:"warning",USER_NOT_ACTIVE:"warning",NO_PERMISSION:"warning",ITEM_NOT_FOUND:"info",NOT_FOUND:"info",IN_USE:"warning",FIELD_ERROR:"warning",BAD_REQUEST:"warning",INTERNAL_SERVER_ERROR:"error",DATABASE_CONNECTION_ERROR:"error",INVALID_CONFIGURATION:"error",UNKNOWN_OPERATION:"error",TOO_MANY_REQUESTS:"warning"},v={INVALID_CREDENTIALS:"errors.auth.INVALID_CREDENTIALS",UNAUTHORIZED:"errors.auth.UNAUTHORIZED",INVALID_API_KEY:"errors.auth.INVALID_API_KEY",USER_NOT_FOUND:"errors.auth.USER_NOT_FOUND",USER_NOT_ACTIVE:"errors.auth.USER_NOT_ACTIVE",NO_PERMISSION:"errors.auth.NO_PERMISSION",ITEM_NOT_FOUND:"errors.data.ITEM_NOT_FOUND",NOT_FOUND:"errors.data.NOT_FOUND",IN_USE:"errors.data.IN_USE",FIELD_ERROR:"errors.data.FIELD_ERROR",BAD_REQUEST:"errors.data.BAD_REQUEST",INTERNAL_SERVER_ERROR:"errors.system.INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"errors.system.DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"errors.system.INVALID_CONFIGURATION",UNKNOWN_OPERATION:"errors.system.UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"errors.system.TOO_MANY_REQUESTS"},le=(S={})=>{let{showNotification:c}=$(),{showSuccessNotifications:N=!1,showErrorNotifications:g=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:a=6e3,appStructure:R=[],translateFn:E=e=>e}=S,d=C(e=>!(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||e.errors._transaction?.includes("ONE_OR_MORE_OPERATIONS_FAILED")||e.errors._error?.includes("TOO_MANY_REQUESTS"))||!e.success&&e.data?.response?.status==="TOO_MANY_REQUESTS"),[]),y=C((e,i)=>{let r=E(e);return r===e?i||E("error.unknown"):r},[E]),O=C(e=>["create","update","delete"].includes(e),[]),A=C((e,i)=>N?O(e)&&i?!0:R.some(r=>r.key===e):!1,[N,R,O]),p=C((e,i,r)=>{let t=r?.key&&typeof r.key=="string"?r.key:e,s=`action.onSuccess.${t}`,n=y(s);if(n!==E("error.unknown")){if(O(t)&&i){let f=`action.${i}Singular`,_=y(f);if(_!==E("error.unknown"))return E(s,{item:_});{let M=`action.onSuccess.${t}WithoutItem`,k=y(M);return k!==E("error.unknown")?k:n}}return n}return E("success.transaction")},[y,E,O]),u=C(e=>{if(e.errorCode&&T[e.errorCode])return T[e.errorCode];if(e.errorCode&&v[e.errorCode])return y(v[e.errorCode]);if(e.errorCode){let i=[`errors.auth.${e.errorCode}`,`errors.data.${e.errorCode}`,`errors.system.${e.errorCode}`,`errors.${e.errorCode}`];for(let r of i){let t=y(r);if(t!==E("error.unknown"))return t}}if(typeof e.data=="string"&&e.data.startsWith("errors.")){let i=y(e.data);if(i!==E("error.unknown"))return i}if(e.errors&&Object.keys(e.errors).length>0){let i=Object.keys(e.errors);if(i.length===1&&i[0]==="_transaction"){let r=e.errors._transaction;if(r?.includes("ONE_OR_MORE_OPERATIONS_FAILED"))return"";if(Array.isArray(r)&&r.length>0){let t=r[0];if(typeof t=="string"&&t!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let s=JSON.parse(t);if(Array.isArray(s)&&s.length>0){let n=s[0];if(n?.response?.errorCode){let f=n.response.errorCode;if(v[f])return y(v[f]);let _=[`errors.auth.${f}`,`errors.data.${f}`,`errors.system.${f}`,`errors.${f}`];for(let M of _){let k=y(M);if(k!==y("error.unknown"))return k}}if(n?.response?.data)return n.response.data}if(s?.response?.message){let n=s.response.message.toLowerCase();return n.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):s.response.message}}catch{return t.toLowerCase().includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):t.toLowerCase().includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t}}return y("error.transaction","Error en la operaci\xF3n")}if(i.length===1&&i[0]==="_error"){let r=e.errors._error;return Array.isArray(r)?r[0]:String(r)}return i.length===1&&i[0]==="_graphql"?y("errors.system.DATABASE_CONNECTION_ERROR"):`${y("errors.data.FIELD_ERROR")}: ${i.join(", ")}`}return I||E("error.unknown")},[T,I,E,y]),o=C(e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),m=C(async(e,i,r)=>{let t=await b.createItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"create",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),l=C(async(e,i,r)=>{let t=await b.updateItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"update",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),L=C(async(e,i,r)=>{let t=await b.deleteItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"delete",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),P=C(async(e,i,r)=>{let t=await b.readItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}return t},[g,c,u,o,a,d]),w=C(async(e,i,r)=>{let t=await b.readItems(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}return t},[g,c,u,o,a,d]),V=C(async(e,i)=>{let r=await b.transaction(e,i),t=i?.skipNotifications===!0;if(!t&&!r.success&&g&&d(r)){let s=u(r),n=o(r);c(s,n,{autoHideDuration:a})}else if(!t&&r.success){let s="transaction",n,f=null;if(i?.actionConfig?(f=i.actionConfig,s=f.key,n=f.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(s=e[0].operation,f=R.find(_=>_.key===s),f&&(n=f.moduleKey)),A(s,n)){let _=p(s,n,f);c(_,"success",{autoHideDuration:a})}}return r},[g,A,c,u,o,p,a,d,R]),x=C((e,i)=>{if(!e.success&&g&&d(e)){let r=u(e),t=o(e);c(r,t,{autoHideDuration:a})}else e.success&&N&&i&&c(i,"success",{autoHideDuration:a});return e},[g,N,c,u,o,a,d,E]);return{createItem:m,updateItem:l,deleteItem:L,readItem:P,readItems:w,transaction:V,handleResponse:x,getErrorMessage:u,getErrorSeverity:o,shouldShowNotification:d}};export{G as a,ee as b,oe as c,le as d};
@@ -1 +1 @@
1
- import{b as Yo,c as G,h as Qo,j as Q,l as Zo}from"./chunk-FM2YKL4E.mjs";import{g as z}from"./chunk-BJ6PIVZR.mjs";import{a as Jo,e as Xo}from"./chunk-5JKS55SE.mjs";import{Box as wr,Typography as Pr}from"@mui/material";import{createContext as Ne,useContext as Ve,useMemo as ee}from"react";import{useState as Bo,useEffect as Ue}from"react";var oe=(o,t)=>{let[a,i]=Bo({}),[f,n]=Bo(!1),[s,g]=Bo(null);return Ue(()=>{if(console.log("\u{1F527} [I18nProvider] Hybrid translation loading:",{hasProvidedTranslations:!!t&&Object.keys(t).length>0,hasUrl:!!o,providedKeys:t?Object.keys(t).length:0}),t&&Object.keys(t).length>0){console.log("\u2705 [I18nProvider] Using provided translations (highest priority)"),i(t),n(!1),g(null);return}if(!o){console.log("\u26A0\uFE0F [I18nProvider] No translations provided, using empty object (keys will show as-is)"),i({}),n(!1),g(null);return}console.log("\u{1F310} [I18nProvider] Loading translations from URL:",o);let l=!1;return n(!0),g(null),fetch(o).then(y=>{if(!y.ok)throw new Error(`Failed to load translations: ${y.status}`);return y.json()}).then(y=>{l||(console.log("\u2705 [I18nProvider] Translations loaded successfully from URL:",{url:o,keysLoaded:Object.keys(y).length}),i(y),n(!1))}).catch(y=>{l||(console.error("\u274C [I18nProvider] Failed to load translations from URL:",o,y),g(y.message),console.log("\u{1F504} [I18nProvider] Falling back to empty translations (keys will show as-is)"),i({}),n(!1))}),()=>{l=!0}},[o,t]),{translations:a,loading:f,error:s}};import{jsx as re}from"react/jsx-runtime";var te=Ne(null),Me=(o,t)=>o&&o[t]?o[t]:t.split(".").reduce((a,i)=>a&&typeof a=="object"?a[i]:void 0,o),ne=({children:o,translations:t,translationsUrl:a,language:i="en"})=>{let{translations:f,loading:n}=oe(a,t),s=ee(()=>(l,y)=>{let c=Me(f,l);return c==null&&(console.log(`\u{1F50D} [I18nProvider] Translation not found for key: "${l}" - showing key as-is`),c=l),y&&typeof c=="string"&&Object.entries(y).forEach(([h,d])=>{c=c.replace(new RegExp(`{{${h}}}`,"g"),d)}),typeof c=="string"?c:l},[f]),g=ee(()=>({t:s,language:i}),[s,i]);return n?re("div",{children:"Loading translations..."}):re(te.Provider,{value:g,children:o})},V=()=>{let o=Ve(te);if(!o)throw new Error("useTranslation must be used within I18nProvider");return o};import{createContext as He,useContext as $e,useReducer as je,useEffect as se}from"react";import{jsx as Ge}from"react/jsx-runtime";var ae={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function qe(o,t){switch(t.type){case"SET_SCREEN":let a={...o,currentScreen:t.payload.screen,searchParams:t.payload.params||o.searchParams,errors:{global:[]}},i=new URLSearchParams(a.searchParams),f=i.toString()?`?${i.toString()}`:window.location.pathname;try{window.history.replaceState({},"",f)}catch{}return a;case"SET_SEARCH_PARAMS":return{...o,searchParams:t.payload};case"UPDATE_FORM_DATA":return{...o,formData:{...o.formData,...t.payload},errors:{...o.errors,...Object.keys(t.payload).reduce((n,s)=>({...n,[s]:void 0}),{})}};case"SET_LOADING":return{...o,loading:t.payload};case"SET_ERRORS":return{...o,errors:{...o.errors,...t.payload}};case"CLEAR_ERRORS":return{...o,errors:{global:[]}};case"SET_EMAIL_SENT":return{...o,emailSent:t.payload};case"SET_CODE_ALREADY_EXISTS":return{...o,codeAlreadyExists:t.payload};case"SET_CODE_VALIDATED":return{...o,codeValidated:t.payload};case"SET_FROM_CODE_VERIFICATION":return{...o,fromCodeVerification:t.payload};case"RESET_FORM":return{...o,formData:ae.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...o,config:t.payload};default:return o}}var ie=He(void 0),le=({children:o,initialScreen:t="login",config:a,autoReadFromCookies:i=!0})=>{let[f,n]=je(qe,{...ae,currentScreen:t});se(()=>{n({type:"INIT_CONFIG",payload:(()=>{let e={};if(i)try{let r=Jo("logo");if(r){let m=decodeURIComponent(r);m.startsWith("http")&&(e.logo=m)}}catch(r){console.error("Error reading configuration from cookies:",r)}return{publicApiKey:a?.publicApiKey,env:a?.env,appName:a?.appName,logo:a?.logo||e.logo,loginActions:a?.loginActions}})()})},[a,i]),se(()=>{let d=new URLSearchParams(window.location.search),e={};d.forEach((r,m)=>{e[m]=r}),Object.keys(e).length>0&&n({type:"SET_SEARCH_PARAMS",payload:e}),t==="checkCode"&&e.email&&n({type:"UPDATE_FORM_DATA",payload:{email:e.email,code:e.code||""}}),t==="resetPassword"&&e.link&&n({type:"SET_SEARCH_PARAMS",payload:e})},[t]);let h={state:f,dispatch:n,setScreen:(d,e)=>{n({type:"SET_SCREEN",payload:{screen:d,params:e}})},updateFormData:d=>{n({type:"UPDATE_FORM_DATA",payload:d})},setFieldError:(d,e)=>{n({type:"SET_ERRORS",payload:{[d]:e}})},clearErrors:()=>{n({type:"CLEAR_ERRORS"})},setLoading:d=>{n({type:"SET_LOADING",payload:d})}};return Ge(ie.Provider,{value:h,children:o})},vo=()=>{let o=$e(ie);if(o===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return o};import{useEffect as Ke,useRef as Ye}from"react";import{Typography as Fo,TextField as ce,Button as Je,Box as fo,CircularProgress as Xe,Alert as Qe,Link as de}from"@mui/material";import{Fragment as or,jsx as M,jsxs as po}from"react/jsx-runtime";var Ze=({onScreenChange:o,onExternalNavigate:t,onLoginSuccess:a,onError:i,redirectUrl:f="/"})=>{let{crudify:n}=G(),{state:s,updateFormData:g,setFieldError:l,clearErrors:y,setLoading:c}=vo(),{login:h}=Q(),d=V(),{t:e}=d,r=d.i18n,m=Ye(null),P=Xo(e,{currentLanguage:r?.language,enableDebug:!1}),C=()=>{if(s.searchParams.redirect)try{let p=decodeURIComponent(s.searchParams.redirect);if(p.startsWith("/")&&!p.startsWith("//"))return p}catch{}return f||"/"};Ke(()=>{let p=setTimeout(()=>{m.current&&m.current.focus()},100);return()=>clearTimeout(p)},[]);let u=p=>{console.log("\u{1F50D} [LoginForm] Translating parsed error:",p);let S=P.translateError({code:p.code,message:p.message,field:p.field});return console.log("\u{1F50D} [LoginForm] Translation result:",S),S},x=async()=>{if(!s.loading){if(!s.formData.username.trim()){l("username",e("login.usernameRequired"));return}if(!s.formData.password.trim()){l("password",e("login.passwordRequired"));return}y(),c(!0);try{let p=await h(s.formData.username,s.formData.password);if(c(!1),p.success){console.log("\u{1F510} LoginForm - Login successful via SessionProvider, calling onLoginSuccess");let S=C();a&&a(p.data,S)}else{let S=p.rawResponse||p;w(S)}}catch(p){c(!1);let J=z(p).map(u);l("global",J),i&&i(J.join(", "))}}},w=p=>{z(p).forEach(J=>{if(J.field)l(J.field,u(J));else{let mo=s.errors.global||[];l("global",[...mo,u(J)])}})};return po(or,{children:[po(fo,{component:"form",noValidate:!0,onSubmit:p=>{p.preventDefault(),x()},onKeyDown:p=>{p.key==="Enter"&&!s.loading&&(p.preventDefault(),x())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[po(fo,{sx:{mb:1},children:[M(Fo,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:e("login.usernameOrEmailLabel")}),M(ce,{fullWidth:!0,id:"email",name:"email",type:"email",value:s.formData.username,disabled:s.loading,onChange:p=>g({username:p.target.value}),error:!!s.errors.username,helperText:s.errors.username,autoComplete:"email",placeholder:e("login.usernameOrEmailPlaceholder"),inputRef:m,required:!0})]}),po(fo,{sx:{mb:1},children:[M(Fo,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:e("login.passwordLabel")}),M(ce,{fullWidth:!0,id:"password",name:"password",type:"password",value:s.formData.password,disabled:s.loading,onChange:p=>g({password:p.target.value}),error:!!s.errors.password,helperText:s.errors.password,autoComplete:"current-password",placeholder:e("login.passwordPlaceholder"),required:!0})]}),s.config.loginActions?.includes("forgotPassword")&&M(fo,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:M(de,{sx:{cursor:"pointer"},onClick:()=>{o?.("forgotPassword",s.searchParams)},variant:"body2",color:"secondary",children:e("login.forgotPasswordLink")})}),M(Je,{disabled:s.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:s.loading?M(Xe,{size:20}):e("login.loginButton")})]}),M(fo,{children:s.errors.global&&s.errors.global.length>0&&s.errors.global.map((p,S)=>M(Qe,{variant:"filled",sx:{mt:2},severity:"error",children:M("div",{children:p})},S))}),s.config.loginActions?.includes("createUser")&&po(Fo,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[e("login.noAccountPrompt")," ",M(de,{sx:{cursor:"pointer"},onClick:()=>{let S=`/public/users/create${Object.keys(s.searchParams).length>0?`?${new URLSearchParams(s.searchParams).toString()}`:""}`;t?.(S)},fontWeight:"medium",color:"secondary",children:e("login.signUpLink")})]})]})},me=Ze;import{useState as so}from"react";import{Typography as ao,TextField as er,Button as ue,Box as Z,CircularProgress as rr,Alert as tr,Link as Do}from"@mui/material";import{Fragment as fe,jsx as B,jsxs as to}from"react/jsx-runtime";var nr=({onScreenChange:o,onError:t})=>{let{crudify:a}=G(),[i,f]=so(""),[n,s]=so(!1),[g,l]=so([]),[y,c]=so(null),[h,d]=so(!1),[e,r]=so(!1),{t:m}=V(),P=v=>{let E=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`forgotPassword.${v.code.toLowerCase()}`];for(let p of E){let S=m(p);if(S!==p)return S}return v.message||m("error.unknown")},C=v=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(v),u=async()=>{if(!(n||!a)){if(l([]),c(null),!i){c(m("forgotPassword.emailRequired"));return}if(!C(i)){c(m("forgotPassword.invalidEmail"));return}s(!0);try{let v=[{operation:"requestPasswordReset",data:{email:i}}],E=await a.transaction(v);if(E.success)E.data&&E.data.existingCodeValid?r(!0):d(!0);else{let S=z(E).map(P);l(S)}}catch(v){let p=z(v).map(P);l(p),t&&t(p.join(", "))}finally{s(!1)}}},x=()=>{o?.("login")},w=()=>{if(h||e){o?.("checkCode",{email:i});return}if(!i){c(m("forgotPassword.emailRequired"));return}if(!C(i)){c(m("forgotPassword.invalidEmail"));return}o?.("checkCode",{email:i})};return h||e?B(fe,{children:to(Z,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[to(Z,{sx:{mb:2},children:[B(ao,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m(e?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),B(ao,{variant:"body2",sx:{color:e?"success.main":"grey.600"},children:m("forgotPassword.checkEmailInstructions")})]}),B(ue,{type:"button",onClick:w,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:m("forgotPassword.enterCodeLink")}),B(Z,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:B(Do,{sx:{cursor:"pointer"},onClick:x,variant:"body2",color:"secondary",children:m("common.back")})})]})}):to(fe,{children:[to(Z,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[to(Z,{sx:{mb:2},children:[B(ao,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m("forgotPassword.title")}),B(ao,{variant:"body2",sx:{color:"grey.600"},children:m("forgotPassword.instructions")})]}),to(Z,{sx:{mb:1},children:[B(ao,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:m("forgotPassword.emailLabel")}),B(er,{fullWidth:!0,id:"email",name:"email",type:"email",value:i,disabled:n,onChange:v=>f(v.target.value),error:!!y,helperText:y,autoComplete:"email",placeholder:m("forgotPassword.emailPlaceholder"),required:!0})]}),B(ue,{disabled:n,type:"button",onClick:u,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?B(rr,{size:20}):m("forgotPassword.sendCodeButton")}),to(Z,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[B(Do,{sx:{cursor:"pointer"},onClick:x,variant:"body2",color:"secondary",children:m("common.back")}),B(ao,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),B(Do,{sx:{cursor:"pointer"},onClick:w,variant:"body2",color:"secondary",children:m("login.alreadyHaveCodeLink")})]})]}),B(Z,{children:g.length>0&&g.map((v,E)=>B(tr,{variant:"filled",sx:{mt:2},severity:"error",children:v},E))})]})},pe=nr;import{useState as U,useEffect as ge}from"react";import{Typography as To,TextField as ye,Button as sr,Box as oo,CircularProgress as xe,Alert as he,Link as ar}from"@mui/material";import{Fragment as lr,jsx as F,jsxs as go}from"react/jsx-runtime";var ir=({onScreenChange:o,onError:t,searchParams:a,onResetSuccess:i})=>{let{crudify:f}=G(),[n,s]=U(""),[g,l]=U(""),[y,c]=U(!1),[h,d]=U([]),[e,r]=U(null),[m,P]=U(null),[C,u]=U(""),[x,w]=U(""),[v,E]=U(!1),[p,S]=U(!0),[J,mo]=U(!1),[wo,Io]=U(null),[_e,Ko]=U(!1),{t:I}=V(),Po=T=>{let k=[`errors.auth.${T.code}`,`errors.data.${T.code}`,`errors.system.${T.code}`,`errors.${T.code}`,`resetPassword.${T.code.toLowerCase()}`];for(let O of k){let W=I(O);if(W!==O)return W}return T.message||I("error.unknown")},Co=T=>a?a instanceof URLSearchParams?a.get(T):a[T]||null:null;ge(()=>{if(a){if(a){let T=Co("fromCodeVerification"),k=Co("email"),O=Co("code");if(T==="true"&&k&&O){u(k),w(O),E(!0),mo(!0),S(!1);return}let W=Co("link");if(W)try{let H=decodeURIComponent(W),[$,uo]=H.split("/");if($&&uo&&$.length===6){w($),u(uo),E(!1),Io({email:uo,code:$});return}}catch{}if(k&&O){u(k),w(O),E(!1),Io({email:k,code:O});return}}d([I("resetPassword.invalidCode")]),S(!1),setTimeout(()=>o?.("forgotPassword"),3e3)}},[a,f,I,o]),ge(()=>{f&&wo&&!_e&&(Ko(!0),(async(k,O)=>{try{let W=[{operation:"validatePasswordResetCode",data:{email:k,codePassword:O}}],H=await f.transaction(W);if(H.data&&Array.isArray(H.data)){let $=H.data[0];if($&&$.response&&$.response.status==="OK"){mo(!0);return}}if(H.success)mo(!0);else{let uo=z(H).map(Po);d(uo),setTimeout(()=>o?.("forgotPassword"),3e3)}}catch(W){let $=z(W).map(Po);d($),setTimeout(()=>o?.("forgotPassword"),3e3)}finally{S(!1),Io(null),Ko(!1)}})(wo.email,wo.code))},[f,wo,I,o]);let Oe=T=>T.length<8?I("resetPassword.passwordTooShort"):null,ze=async()=>{if(y||!f)return;d([]),r(null),P(null);let T=!1;if(!n)r(I("resetPassword.newPasswordRequired")),T=!0;else{let k=Oe(n);k&&(r(k),T=!0)}if(g?n!==g&&(P(I("resetPassword.passwordsDoNotMatch")),T=!0):(P(I("resetPassword.confirmPasswordRequired")),T=!0),!T){c(!0);try{let k=[{operation:"validateAndResetPassword",data:{email:C,codePassword:x,newPassword:n}}],O=await f.transaction(k);if(O.success)d([]),setTimeout(()=>{i?.()},1e3);else{let H=z(O).map(Po);d(H)}}catch(k){let W=z(k).map(Po);d(W),t&&t(W.join(", "))}c(!1)}},We=()=>{v?o?.("checkCode",{email:C}):o?.("forgotPassword")};return p?F(oo,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:F(xe,{})}):J?go(lr,{children:[go(oo,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[go(oo,{sx:{mb:2},children:[F(To,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:I("resetPassword.title")}),F(To,{variant:"body2",sx:{color:"grey.600"},children:I("resetPassword.instructions")})]}),go(oo,{sx:{mb:1},children:[F(To,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:I("resetPassword.newPasswordLabel")}),F(ye,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:n,disabled:y,onChange:T=>s(T.target.value),error:!!e,helperText:e,autoComplete:"new-password",placeholder:I("resetPassword.newPasswordPlaceholder"),required:!0})]}),go(oo,{sx:{mb:1},children:[F(To,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:I("resetPassword.confirmPasswordLabel")}),F(ye,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:g,disabled:y,onChange:T=>l(T.target.value),error:!!m,helperText:m,autoComplete:"new-password",placeholder:I("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),F(sr,{disabled:y,type:"button",onClick:ze,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:y?F(xe,{size:20}):I("resetPassword.resetPasswordButton")}),F(oo,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:F(ar,{sx:{cursor:"pointer"},onClick:We,variant:"body2",color:"secondary",children:I("common.back")})})]}),F(oo,{children:h.length>0&&h.map((T,k)=>F(he,{variant:"filled",sx:{mt:2},severity:"error",children:T},k))})]}):F(oo,{children:h.length>0&&h.map((T,k)=>F(he,{variant:"filled",sx:{mt:2},severity:"error",children:T},k))})},be=ir;import{useState as yo,useEffect as cr}from"react";import{Typography as _o,TextField as dr,Button as mr,Box as xo,CircularProgress as ur,Alert as fr,Link as pr}from"@mui/material";import{Fragment as yr,jsx as K,jsxs as Eo}from"react/jsx-runtime";var gr=({onScreenChange:o,onError:t,searchParams:a})=>{let{crudify:i}=G(),[f,n]=yo(""),[s,g]=yo(!1),[l,y]=yo([]),[c,h]=yo(null),[d,e]=yo(""),{t:r}=V(),m=w=>a?a instanceof URLSearchParams?a.get(w):a[w]||null:null,P=w=>{let v=[`errors.auth.${w.code}`,`errors.data.${w.code}`,`errors.system.${w.code}`,`errors.${w.code}`,`checkCode.${w.code.toLowerCase()}`];for(let E of v){let p=r(E);if(p!==E)return p}return w.message||r("error.unknown")};cr(()=>{let w=m("email");w?e(w):o?.("forgotPassword")},[a,o]);let C=async()=>{if(!(s||!i)){if(y([]),h(null),!f){h(r("checkCode.codeRequired"));return}if(f.length!==6){h(r("checkCode.codeRequired"));return}g(!0);try{let w=[{operation:"validatePasswordResetCode",data:{email:d,codePassword:f}}],v=await i.transaction(w);if(v.success)o?.("resetPassword",{email:d,code:f,fromCodeVerification:"true"});else{let p=z(v).map(P);y(p),g(!1)}}catch(w){let E=z(w).map(P);y(E),g(!1),t&&t(E.join(", "))}}},u=()=>{o?.("forgotPassword")},x=w=>{let v=w.target.value.replace(/\D/g,"").slice(0,6);n(v)};return Eo(yr,{children:[Eo(xo,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Eo(xo,{sx:{mb:2},children:[K(_o,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:r("checkCode.title")}),K(_o,{variant:"body2",sx:{color:"grey.600"},children:r("checkCode.instructions")})]}),Eo(xo,{sx:{mb:1},children:[K(_o,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:r("checkCode.codeLabel")}),K(dr,{fullWidth:!0,id:"code",name:"code",type:"text",value:f,disabled:s,onChange:x,error:!!c,helperText:c,placeholder:r("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0})]}),K(mr,{disabled:s||f.length!==6,type:"button",onClick:C,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:s?K(ur,{size:20}):r("checkCode.verifyButton")}),K(xo,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:K(pr,{sx:{cursor:"pointer"},onClick:u,variant:"body2",color:"secondary",children:r("common.back")})})]}),K(xo,{children:l.length>0&&l.map((w,v)=>K(fr,{sx:{mt:2},severity:"error",children:w},v))})]})},we=gr;import{Box as xr,CircularProgress as hr,Alert as Pe,Typography as Oo}from"@mui/material";import{Fragment as br,jsx as io,jsxs as Ce}from"react/jsx-runtime";var ve=({children:o,fallback:t})=>{let{isLoading:a,error:i,isInitialized:f}=G(),{t:n}=V();return a?t||Ce(xr,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[io(hr,{}),io(Oo,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):i?io(Pe,{severity:"error",sx:{mt:2},children:Ce(Oo,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",i]})}):f?io(br,{children:o}):io(Pe,{severity:"warning",sx:{mt:2},children:io(Oo,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as j,jsxs as Tr}from"react/jsx-runtime";var Cr=({onScreenChange:o,onExternalNavigate:t,onLoginSuccess:a,onError:i,redirectUrl:f="/"})=>{let{t:n}=V(),{state:s,setScreen:g}=vo(),{config:l}=Q(),{showNotification:y}=Qo(),c=(d,e)=>{let r=e;d==="login"?r={}:d==="forgotPassword"&&!e&&(r={}),g(d,r),o?.(d,r)},h=()=>{let d={onScreenChange:c,onExternalNavigate:t,onError:i,redirectUrl:f};switch(s.currentScreen){case"forgotPassword":return j(pe,{...d});case"checkCode":return j(we,{...d,searchParams:s.searchParams});case"resetPassword":return j(be,{...d,searchParams:s.searchParams,onResetSuccess:()=>{let e=n("resetPassword.successMessage");y(e,"success"),c("login")}});default:return j(me,{...d,onLoginSuccess:a})}};return Tr(ve,{children:[j(wr,{sx:{display:"flex",justifyContent:"center",mb:3},children:j("img",{src:l.logo||"https://logos.crudia.com/nocios-default.png",alt:n("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:d=>{let e=d.target;e.src="https://logos.crudia.com/nocios-default.png"}})}),!l.logo&&l.appName&&j(Pr,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:l.appName}),h()]})},vr=({translations:o,translationsUrl:t,language:a="en",initialScreen:i="login",autoReadFromCookies:f=!0,...n})=>{let{config:s}=Q();return j(ne,{translations:o,translationsUrl:t,language:a,children:j(Yo,{config:s,children:j(le,{config:s,initialScreen:i,autoReadFromCookies:f,children:j(Cr,{...n})})})})},Ln=vr;import{Box as N,Card as Te,CardContent as Ee,Typography as q,Chip as So,Avatar as Er,Divider as Sr,CircularProgress as kr,Alert as Se,List as Lr,ListItem as zo,ListItemText as Wo,ListItemIcon as Rr,Collapse as Ar,IconButton as Uo}from"@mui/material";import{Person as Ir,Email as Br,Badge as Fr,Security as Dr,Schedule as _r,AccountCircle as Or,ExpandMore as zr,ExpandLess as Wr,Info as Ur}from"@mui/icons-material";import{useState as Nr}from"react";import{Fragment as Hr,jsx as b,jsxs as L}from"react/jsx-runtime";var Vr=({showExtendedData:o=!0,showProfileCard:t=!0,autoRefresh:a=!0})=>{let{userProfile:i,loading:f,error:n,extendedData:s,refreshProfile:g}=Zo({autoFetch:a,retryOnError:!0,maxRetries:3}),[l,y]=Nr(!1);if(f)return L(N,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[b(kr,{}),b(q,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return L(Se,{severity:"error",action:b(Uo,{color:"inherit",size:"small",onClick:g,children:b(q,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!i)return b(Se,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let c=s?.displayData||{},h=s?.totalFields||0,d=u=>{if(!u)return"No disponible";try{return new Date(u).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return u}},e=(u,x)=>x==null?"No disponible":typeof x=="boolean"?x?"S\xED":"No":Array.isArray(x)?x.length>0?x.join(", "):"Ninguno":typeof x=="object"?JSON.stringify(x,null,2):String(x),r=[{key:"id",label:"ID",icon:b(Fr,{})},{key:"email",label:"Email",icon:b(Br,{})},{key:"username",label:"Usuario",icon:b(Ir,{})},{key:"fullName",label:"Nombre completo",icon:b(Or,{})},{key:"role",label:"Rol",icon:b(Dr,{})}],m=[{key:"firstName",label:"Nombre"},{key:"lastName",label:"Apellido"},{key:"isActive",label:"Activo"},{key:"lastLogin",label:"\xDAltimo login"},{key:"createdAt",label:"Creado"},{key:"updatedAt",label:"Actualizado"}],P=[...r.map(u=>u.key),...m.map(u=>u.key),"permissions"],C=Object.keys(c).filter(u=>!P.includes(u)).map(u=>({key:u,label:u}));return L(N,{children:[t&&b(Te,{sx:{mb:2},children:L(Ee,{children:[L(N,{display:"flex",alignItems:"center",mb:2,children:[b(Er,{src:c.avatar,sx:{width:56,height:56,mr:2},children:c.fullName?.[0]||c.username?.[0]||c.email?.[0]}),L(N,{children:[b(q,{variant:"h6",children:c.fullName||c.username||c.email}),b(q,{variant:"body2",color:"text.secondary",children:c.role||"Usuario"}),c.isActive!==void 0&&b(So,{label:c.isActive?"Activo":"Inactivo",color:c.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),b(N,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:r.map(({key:u,label:x,icon:w})=>c[u]?L(N,{display:"flex",alignItems:"center",children:[b(N,{sx:{mr:1,color:"text.secondary"},children:w}),L(N,{children:[b(q,{variant:"caption",color:"text.secondary",children:x}),b(q,{variant:"body2",children:e(u,c[u])})]})]},u):null)}),c.permissions&&Array.isArray(c.permissions)&&c.permissions.length>0&&L(N,{mt:2,children:[b(q,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),L(N,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[c.permissions.slice(0,5).map((u,x)=>b(So,{label:u,size:"small",variant:"outlined"},x)),c.permissions.length>5&&b(So,{label:`+${c.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),o&&b(Te,{children:L(Ee,{children:[L(N,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[L(q,{variant:"h6",display:"flex",alignItems:"center",children:[b(Ur,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),b(So,{label:`${h} campos totales`,size:"small"})]}),L(Lr,{dense:!0,children:[m.map(({key:u,label:x})=>c[u]!==void 0&&L(zo,{divider:!0,children:[b(Rr,{children:b(_r,{fontSize:"small"})}),b(Wo,{primary:x,secondary:u.includes("At")||u.includes("Login")?d(c[u]):e(u,c[u])})]},u)),C.length>0&&L(Hr,{children:[b(Sr,{sx:{my:1}}),b(zo,{children:b(Wo,{primary:L(N,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[L(q,{variant:"subtitle2",children:["Campos Personalizados (",C.length,")"]}),b(Uo,{size:"small",onClick:()=>y(!l),children:l?b(Wr,{}):b(zr,{})})]})})}),b(Ar,{in:l,children:C.map(({key:u,label:x})=>b(zo,{sx:{pl:4},children:b(Wo,{primary:x,secondary:e(u,c[u])})},u))})]})]}),L(N,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[L(q,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",d(c.updatedAt)]}),b(Uo,{size:"small",onClick:g,disabled:f,children:b(q,{variant:"caption",children:"Actualizar"})})]})]})})]})},Mr=Vr;var ke=["create","read","update","delete"],Le=["create","read","update","delete"];import{useRef as ft}from"react";import{useTranslation as pt}from"react-i18next";import{Box as Lo,Typography as Be,Button as gt,Stack as yt,Alert as Fe,Divider as xt}from"@mui/material";import{Add as ht}from"@mui/icons-material";import{forwardRef as ot}from"react";import{useTranslation as et}from"react-i18next";import{Box as no,FormControl as rt,InputLabel as tt,Select as nt,MenuItem as st,IconButton as at,Typography as lo,FormHelperText as it,Stack as ko,Paper as Ie,Divider as lt,Button as $o}from"@mui/material";import{Delete as ct,SelectAll as dt,ClearAll as mt}from"@mui/icons-material";import{useState as $r,useEffect as jr,useRef as qr}from"react";import{useTranslation as Gr}from"react-i18next";import{Box as No,Typography as ho,Button as Re,Stack as Vo,FormHelperText as Ae,ToggleButton as Mo,ToggleButtonGroup as Kr}from"@mui/material";import{CheckCircle as Yr,Cancel as Jr,SelectAll as Xr,ClearAll as Qr}from"@mui/icons-material";import{jsx as D,jsxs as eo}from"react/jsx-runtime";var Zr=({value:o,onChange:t,availableFields:a,error:i,disabled:f=!1})=>{let{t:n}=Gr(),[s,g]=$r("custom"),l=qr(!1);jr(()=>{let e=o||{allow:[],owner_allow:[],deny:[]},r=new Set(a),m=(e.allow||[]).filter(x=>r.has(x)),P=(e.owner_allow||[]).filter(x=>r.has(x)),C=(e.deny||[]).filter(x=>r.has(x));a.forEach(x=>{!m.includes(x)&&!P.includes(x)&&!C.includes(x)&&C.push(x)});let u={allow:m,owner_allow:P,deny:C};JSON.stringify(u)!==JSON.stringify(e)&&t(u),m.length===a.length?g("all"):C.length===a.length?g("none"):g("custom")},[a,o]);let y=()=>{l.current=!0,t({allow:[...a],owner_allow:[],deny:[]}),g("all"),setTimeout(()=>{l.current=!1},0)},c=()=>{l.current=!0,t({allow:[],owner_allow:[],deny:[...a]}),g("none"),setTimeout(()=>{l.current=!1},0)},h=e=>o?.allow?.includes(e)?"allow":o?.owner_allow?.includes(e)?"owner_allow":"deny",d=(e,r)=>{l.current=!0;let m=new Set(o?.allow||[]),P=new Set(o?.owner_allow||[]),C=new Set(o?.deny||[]);m.delete(e),P.delete(e),C.delete(e),r==="allow"&&m.add(e),r==="owner_allow"&&P.add(e),r==="deny"&&C.add(e),t({allow:Array.from(m),owner_allow:Array.from(P),deny:Array.from(C)}),g("custom"),setTimeout(()=>{l.current=!1},0)};return a.length===0?eo(No,{children:[D(ho,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("modules.form.publicPolicies.fields.conditions.label")}),D(ho,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),i&&D(Ae,{error:!0,sx:{mt:1},children:i})]}):eo(No,{children:[D(ho,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.label")}),eo(Vo,{direction:"row",spacing:1,sx:{mb:3},children:[D(Re,{variant:s==="all"?"contained":"outlined",startIcon:D(Xr,{}),onClick:y,disabled:f,size:"small",sx:{minWidth:120,...s==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("modules.form.publicPolicies.fields.conditions.allFields")}),D(Re,{variant:s==="none"?"contained":"outlined",startIcon:D(Qr,{}),onClick:c,disabled:f,size:"small",sx:{minWidth:120,...s==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("modules.form.publicPolicies.fields.conditions.noFields")})]}),eo(No,{sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[D(ho,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.help")}),D(Vo,{spacing:1,children:a.map(e=>{let r=h(e);return eo(Vo,{direction:"row",spacing:1,alignItems:"center",children:[D(ho,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:e}),eo(Kr,{value:r,exclusive:!0,size:"small",children:[eo(Mo,{value:"allow",onClick:()=>d(e,"allow"),disabled:f,sx:{px:2,color:r==="allow"?"#ffffff":"#6b7280",backgroundColor:r==="allow"?"#16a34a":"#f3f4f6",borderColor:r==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:r==="allow"?"#15803d":"#e5e7eb",borderColor:r==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[D(Yr,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.allow")]}),D(Mo,{value:"owner_allow",onClick:()=>d(e,"owner_allow"),disabled:f,sx:{px:2,color:r==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:r==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:r==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:r==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:r==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),eo(Mo,{value:"deny",onClick:()=>d(e,"deny"),disabled:f,sx:{px:2,color:r==="deny"?"#ffffff":"#6b7280",backgroundColor:r==="deny"?"#dc2626":"#f3f4f6",borderColor:r==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:r==="deny"?"#b91c1c":"#e5e7eb",borderColor:r==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[D(Jr,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},e)})})]}),i&&D(Ae,{error:!0,sx:{mt:1},children:i})]})},Ho=Zr;import{jsx as A,jsxs as _}from"react/jsx-runtime";var ut=ot(({policy:o,onChange:t,onRemove:a,availableFields:i,isSubmitting:f=!1,usedActions:n,error:s},g)=>{let{t:l}=et(),y=new Set(Array.from(n||[]));y.delete(o.action);let c=ke.map(h=>({value:h,label:l(`modules.form.publicPolicies.fields.action.options.${h}`)}));return _(Ie,{ref:g,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[_(no,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[A(lo,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:l("modules.form.publicPolicies.policyTitle")}),A(at,{onClick:a,size:"small",disabled:f,"aria-label":l("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:A(ct,{})})]}),_(ko,{spacing:3,children:[A(ko,{direction:{xs:"column",md:"row"},spacing:2,children:A(no,{sx:{flex:1,minWidth:200},children:_(rt,{fullWidth:!0,children:[A(tt,{children:l("modules.form.publicPolicies.fields.action.label")}),A(nt,{value:o.action,label:l("modules.form.publicPolicies.fields.action.label"),disabled:f,onChange:h=>{let d=h.target.value,e={...o,action:d};d==="delete"?(e.permission="deny",delete e.fields):(e.fields={allow:[],owner_allow:[],deny:i},delete e.permission),t(e)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:c.map(h=>{let d=y.has(h.value);return A(st,{value:h.value,disabled:d,children:h.label},h.value)})}),s&&A(it,{error:!0,children:s})]})})}),o.action==="delete"?_(no,{children:[A(lo,{variant:"body2",color:"text.secondary",sx:{mb:2},children:l("modules.form.publicPolicies.fields.conditions.label")}),_(ko,{direction:"row",spacing:1,sx:{mb:3},children:[A($o,{variant:o.permission==="*"?"contained":"outlined",startIcon:A(dt,{}),onClick:()=>t({...o,permission:"*"}),disabled:f,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...o.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:l("modules.form.publicPolicies.fields.conditions.allFields")}),A($o,{variant:o.permission==="owner"?"contained":"outlined",onClick:()=>t({...o,permission:"owner"}),disabled:f,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...o.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:l("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),A($o,{variant:o.permission==="deny"?"contained":"outlined",startIcon:A(mt,{}),onClick:()=>t({...o,permission:"deny"}),disabled:f,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...o.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:l("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):A(Ho,{value:o.fields||{allow:[],owner_allow:[],deny:[]},onChange:h=>t({...o,fields:h}),availableFields:i,disabled:f}),A(Ie,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:o.action==="delete"?_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:o.permission==="*"?"#16a34a":o.permission==="owner"?"#0ea5e9":"#dc2626"},children:[l("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",o.permission||"-"]}):_(ko,{spacing:.5,divider:A(lt,{sx:{borderColor:"#e5e7eb"}}),children:[_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:"#16a34a"},children:[l("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(o?.fields?.allow||[]).join(", ")||"-"]}),_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:"#0ea5e9"},children:[l("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(o?.fields?.owner_allow||[]).join(", ")||"-"]}),_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:"#dc2626"},children:[l("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(o?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),jo=ut;import{Fragment as Pt,jsx as Y,jsxs as Ro}from"react/jsx-runtime";var bt=()=>{let o=globalThis?.crypto;return o&&typeof o.randomUUID=="function"?o.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},wt=({policies:o,onChange:t,availableFields:a,errors:i,isSubmitting:f=!1})=>{let{t:n}=pt(),s=ft({}),g=new Set((o||[]).map(r=>r.action).filter(Boolean)),l=Le.filter(r=>!g.has(r)),y=l.length>0,c=()=>{let r=l[0]||"create",m={id:bt(),action:r};r==="delete"?m.permission="deny":m.fields={allow:[],owner_allow:[],deny:a};let P=[...o||[],m];t(P),setTimeout(()=>{let C=P.length-1,u=s.current[C];u&&u.scrollIntoView({behavior:"smooth",block:"center"})},100)},h=r=>{let m=[...o];m.splice(r,1),t(m)},d=(()=>{if(!i)return null;if(typeof i=="string")return i;let r=i._error;return typeof r=="string"?r:null})(),e=new Set((o||[]).map(r=>r.action));return Ro(Pt,{children:[Y(xt,{sx:{borderColor:"#e0e4e7"}}),Ro(Lo,{children:[Y(Lo,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:Ro(Lo,{children:[Y(Be,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("modules.form.publicPolicies.title")}),Y(Be,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("modules.form.publicPolicies.description")})]})}),d&&Y(Fe,{severity:"error",sx:{mb:3},children:d}),Ro(yt,{spacing:3,children:[(o||[]).length===0?Y(Fe,{severity:"info",children:n("modules.form.publicPolicies.noPolicies")}):o.map((r,m)=>Y(jo,{ref:P=>{s.current[m]=P},policy:r,onChange:P=>{let C=[...o];C[m]=P,t(C)},onRemove:()=>h(m),availableFields:a,isSubmitting:f,usedActions:e,error:typeof i=="object"&&i&&r.id in i?i[r.id]:void 0},r.id)),y&&Y(Lo,{children:Y(gt,{type:"button",variant:"outlined",startIcon:Y(ht,{}),onClick:c,disabled:f,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("modules.form.publicPolicies.addPolicy")})})]})]})]})},us=wt;import{useState as qo}from"react";import{Button as Ao,TextField as De,Box as co,Alert as bo,Typography as ro,CircularProgress as Go}from"@mui/material";import{jsx as R,jsxs as X}from"react/jsx-runtime";function bs(){let[o,t]=qo(""),[a,i]=qo(""),[f,n]=qo(!1),{isAuthenticated:s,isLoading:g,error:l,login:y,logout:c,refreshTokens:h,clearError:d,isExpiringSoon:e,expiresIn:r}=Q(),m=async u=>{if(u.preventDefault(),!o||!a)return;(await y(o,a)).success&&(t(""),i(""),n(!1))},P=async()=>{await c()},C=async()=>{await h()};return s?X(co,{sx:{maxWidth:600,mx:"auto",p:3},children:[R(ro,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),R(bo,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),X(co,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[R(ro,{variant:"h6",gutterBottom:!0,children:"Token Status"}),X(ro,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(r/1e3/60)," minutes"]}),e&&R(bo,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),X(co,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[R(Ao,{variant:"contained",onClick:C,disabled:g,startIcon:g?R(Go,{size:16}):null,children:"Refresh Tokens"}),R(Ao,{variant:"outlined",color:"error",onClick:P,disabled:g,children:"Logout"})]}),l&&R(bo,{severity:"error",sx:{mt:2},onClose:d,children:l})]}):X(co,{sx:{maxWidth:400,mx:"auto",p:3},children:[R(ro,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),R(bo,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),f?X("form",{onSubmit:m,children:[R(De,{fullWidth:!0,label:"Email",type:"email",value:o,onChange:u=>t(u.target.value),margin:"normal",required:!0,autoComplete:"email"}),R(De,{fullWidth:!0,label:"Password",type:"password",value:a,onChange:u=>i(u.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),R(Ao,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:g,startIcon:g?R(Go,{size:16}):null,sx:{mt:3,mb:2},children:g?"Logging in...":"Login"})]}):R(Ao,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),l&&R(bo,{severity:"error",sx:{mt:2},onClose:d,children:l})]})}function ws(){let{isAuthenticated:o,isLoading:t,isExpiringSoon:a,expiresIn:i}=Q();return t?X(co,{sx:{display:"flex",alignItems:"center",gap:1},children:[R(Go,{size:16}),R(ro,{variant:"caption",children:"Loading session..."})]}):o?X(co,{children:[R(ro,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),a&&X(ro,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(i/1e3/60)," min"]})]}):R(ro,{variant:"caption",color:"text.secondary",children:"Not logged in"})}export{Ln as a,Mr as b,ke as c,Le as d,us as e,bs as f,ws as g};
1
+ import{b as Yo,c as G,h as Qo,j as Q,l as Zo}from"./chunk-IPMROPYS.mjs";import{g as z}from"./chunk-BJ6PIVZR.mjs";import{a as Jo,e as Xo}from"./chunk-5JKS55SE.mjs";import{Box as wr,Typography as Pr}from"@mui/material";import{createContext as Ne,useContext as Ve,useMemo as ee}from"react";import{useState as Bo,useEffect as Ue}from"react";var oe=(o,t)=>{let[a,i]=Bo({}),[f,n]=Bo(!1),[s,g]=Bo(null);return Ue(()=>{if(console.log("\u{1F527} [I18nProvider] Hybrid translation loading:",{hasProvidedTranslations:!!t&&Object.keys(t).length>0,hasUrl:!!o,providedKeys:t?Object.keys(t).length:0}),t&&Object.keys(t).length>0){console.log("\u2705 [I18nProvider] Using provided translations (highest priority)"),i(t),n(!1),g(null);return}if(!o){console.log("\u26A0\uFE0F [I18nProvider] No translations provided, using empty object (keys will show as-is)"),i({}),n(!1),g(null);return}console.log("\u{1F310} [I18nProvider] Loading translations from URL:",o);let l=!1;return n(!0),g(null),fetch(o).then(y=>{if(!y.ok)throw new Error(`Failed to load translations: ${y.status}`);return y.json()}).then(y=>{l||(console.log("\u2705 [I18nProvider] Translations loaded successfully from URL:",{url:o,keysLoaded:Object.keys(y).length}),i(y),n(!1))}).catch(y=>{l||(console.error("\u274C [I18nProvider] Failed to load translations from URL:",o,y),g(y.message),console.log("\u{1F504} [I18nProvider] Falling back to empty translations (keys will show as-is)"),i({}),n(!1))}),()=>{l=!0}},[o,t]),{translations:a,loading:f,error:s}};import{jsx as re}from"react/jsx-runtime";var te=Ne(null),Me=(o,t)=>o&&o[t]?o[t]:t.split(".").reduce((a,i)=>a&&typeof a=="object"?a[i]:void 0,o),ne=({children:o,translations:t,translationsUrl:a,language:i="en"})=>{let{translations:f,loading:n}=oe(a,t),s=ee(()=>(l,y)=>{let c=Me(f,l);return c==null&&(console.log(`\u{1F50D} [I18nProvider] Translation not found for key: "${l}" - showing key as-is`),c=l),y&&typeof c=="string"&&Object.entries(y).forEach(([h,d])=>{c=c.replace(new RegExp(`{{${h}}}`,"g"),d)}),typeof c=="string"?c:l},[f]),g=ee(()=>({t:s,language:i}),[s,i]);return n?re("div",{children:"Loading translations..."}):re(te.Provider,{value:g,children:o})},V=()=>{let o=Ve(te);if(!o)throw new Error("useTranslation must be used within I18nProvider");return o};import{createContext as He,useContext as $e,useReducer as je,useEffect as se}from"react";import{jsx as Ge}from"react/jsx-runtime";var ae={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function qe(o,t){switch(t.type){case"SET_SCREEN":let a={...o,currentScreen:t.payload.screen,searchParams:t.payload.params||o.searchParams,errors:{global:[]}},i=new URLSearchParams(a.searchParams),f=i.toString()?`?${i.toString()}`:window.location.pathname;try{window.history.replaceState({},"",f)}catch{}return a;case"SET_SEARCH_PARAMS":return{...o,searchParams:t.payload};case"UPDATE_FORM_DATA":return{...o,formData:{...o.formData,...t.payload},errors:{...o.errors,...Object.keys(t.payload).reduce((n,s)=>({...n,[s]:void 0}),{})}};case"SET_LOADING":return{...o,loading:t.payload};case"SET_ERRORS":return{...o,errors:{...o.errors,...t.payload}};case"CLEAR_ERRORS":return{...o,errors:{global:[]}};case"SET_EMAIL_SENT":return{...o,emailSent:t.payload};case"SET_CODE_ALREADY_EXISTS":return{...o,codeAlreadyExists:t.payload};case"SET_CODE_VALIDATED":return{...o,codeValidated:t.payload};case"SET_FROM_CODE_VERIFICATION":return{...o,fromCodeVerification:t.payload};case"RESET_FORM":return{...o,formData:ae.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...o,config:t.payload};default:return o}}var ie=He(void 0),le=({children:o,initialScreen:t="login",config:a,autoReadFromCookies:i=!0})=>{let[f,n]=je(qe,{...ae,currentScreen:t});se(()=>{n({type:"INIT_CONFIG",payload:(()=>{let e={};if(i)try{let r=Jo("logo");if(r){let m=decodeURIComponent(r);m.startsWith("http")&&(e.logo=m)}}catch(r){console.error("Error reading configuration from cookies:",r)}return{publicApiKey:a?.publicApiKey,env:a?.env,appName:a?.appName,logo:a?.logo||e.logo,loginActions:a?.loginActions}})()})},[a,i]),se(()=>{let d=new URLSearchParams(window.location.search),e={};d.forEach((r,m)=>{e[m]=r}),Object.keys(e).length>0&&n({type:"SET_SEARCH_PARAMS",payload:e}),t==="checkCode"&&e.email&&n({type:"UPDATE_FORM_DATA",payload:{email:e.email,code:e.code||""}}),t==="resetPassword"&&e.link&&n({type:"SET_SEARCH_PARAMS",payload:e})},[t]);let h={state:f,dispatch:n,setScreen:(d,e)=>{n({type:"SET_SCREEN",payload:{screen:d,params:e}})},updateFormData:d=>{n({type:"UPDATE_FORM_DATA",payload:d})},setFieldError:(d,e)=>{n({type:"SET_ERRORS",payload:{[d]:e}})},clearErrors:()=>{n({type:"CLEAR_ERRORS"})},setLoading:d=>{n({type:"SET_LOADING",payload:d})}};return Ge(ie.Provider,{value:h,children:o})},vo=()=>{let o=$e(ie);if(o===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return o};import{useEffect as Ke,useRef as Ye}from"react";import{Typography as Fo,TextField as ce,Button as Je,Box as fo,CircularProgress as Xe,Alert as Qe,Link as de}from"@mui/material";import{Fragment as or,jsx as M,jsxs as po}from"react/jsx-runtime";var Ze=({onScreenChange:o,onExternalNavigate:t,onLoginSuccess:a,onError:i,redirectUrl:f="/"})=>{let{crudify:n}=G(),{state:s,updateFormData:g,setFieldError:l,clearErrors:y,setLoading:c}=vo(),{login:h}=Q(),d=V(),{t:e}=d,r=d.i18n,m=Ye(null),P=Xo(e,{currentLanguage:r?.language,enableDebug:!1}),C=()=>{if(s.searchParams.redirect)try{let p=decodeURIComponent(s.searchParams.redirect);if(p.startsWith("/")&&!p.startsWith("//"))return p}catch{}return f||"/"};Ke(()=>{let p=setTimeout(()=>{m.current&&m.current.focus()},100);return()=>clearTimeout(p)},[]);let u=p=>{console.log("\u{1F50D} [LoginForm] Translating parsed error:",p);let S=P.translateError({code:p.code,message:p.message,field:p.field});return console.log("\u{1F50D} [LoginForm] Translation result:",S),S},x=async()=>{if(!s.loading){if(!s.formData.username.trim()){l("username",e("login.usernameRequired"));return}if(!s.formData.password.trim()){l("password",e("login.passwordRequired"));return}y(),c(!0);try{let p=await h(s.formData.username,s.formData.password);if(c(!1),p.success){console.log("\u{1F510} LoginForm - Login successful via SessionProvider, calling onLoginSuccess");let S=C();a&&a(p.data,S)}else{let S=p.rawResponse||p;w(S)}}catch(p){c(!1);let J=z(p).map(u);l("global",J),i&&i(J.join(", "))}}},w=p=>{z(p).forEach(J=>{if(J.field)l(J.field,u(J));else{let mo=s.errors.global||[];l("global",[...mo,u(J)])}})};return po(or,{children:[po(fo,{component:"form",noValidate:!0,onSubmit:p=>{p.preventDefault(),x()},onKeyDown:p=>{p.key==="Enter"&&!s.loading&&(p.preventDefault(),x())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[po(fo,{sx:{mb:1},children:[M(Fo,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:e("login.usernameOrEmailLabel")}),M(ce,{fullWidth:!0,id:"email",name:"email",type:"email",value:s.formData.username,disabled:s.loading,onChange:p=>g({username:p.target.value}),error:!!s.errors.username,helperText:s.errors.username,autoComplete:"email",placeholder:e("login.usernameOrEmailPlaceholder"),inputRef:m,required:!0})]}),po(fo,{sx:{mb:1},children:[M(Fo,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:e("login.passwordLabel")}),M(ce,{fullWidth:!0,id:"password",name:"password",type:"password",value:s.formData.password,disabled:s.loading,onChange:p=>g({password:p.target.value}),error:!!s.errors.password,helperText:s.errors.password,autoComplete:"current-password",placeholder:e("login.passwordPlaceholder"),required:!0})]}),s.config.loginActions?.includes("forgotPassword")&&M(fo,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:M(de,{sx:{cursor:"pointer"},onClick:()=>{o?.("forgotPassword",s.searchParams)},variant:"body2",color:"secondary",children:e("login.forgotPasswordLink")})}),M(Je,{disabled:s.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:s.loading?M(Xe,{size:20}):e("login.loginButton")})]}),M(fo,{children:s.errors.global&&s.errors.global.length>0&&s.errors.global.map((p,S)=>M(Qe,{variant:"filled",sx:{mt:2},severity:"error",children:M("div",{children:p})},S))}),s.config.loginActions?.includes("createUser")&&po(Fo,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[e("login.noAccountPrompt")," ",M(de,{sx:{cursor:"pointer"},onClick:()=>{let S=`/public/users/create${Object.keys(s.searchParams).length>0?`?${new URLSearchParams(s.searchParams).toString()}`:""}`;t?.(S)},fontWeight:"medium",color:"secondary",children:e("login.signUpLink")})]})]})},me=Ze;import{useState as so}from"react";import{Typography as ao,TextField as er,Button as ue,Box as Z,CircularProgress as rr,Alert as tr,Link as Do}from"@mui/material";import{Fragment as fe,jsx as B,jsxs as to}from"react/jsx-runtime";var nr=({onScreenChange:o,onError:t})=>{let{crudify:a}=G(),[i,f]=so(""),[n,s]=so(!1),[g,l]=so([]),[y,c]=so(null),[h,d]=so(!1),[e,r]=so(!1),{t:m}=V(),P=v=>{let E=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`forgotPassword.${v.code.toLowerCase()}`];for(let p of E){let S=m(p);if(S!==p)return S}return v.message||m("error.unknown")},C=v=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(v),u=async()=>{if(!(n||!a)){if(l([]),c(null),!i){c(m("forgotPassword.emailRequired"));return}if(!C(i)){c(m("forgotPassword.invalidEmail"));return}s(!0);try{let v=[{operation:"requestPasswordReset",data:{email:i}}],E=await a.transaction(v);if(E.success)E.data&&E.data.existingCodeValid?r(!0):d(!0);else{let S=z(E).map(P);l(S)}}catch(v){let p=z(v).map(P);l(p),t&&t(p.join(", "))}finally{s(!1)}}},x=()=>{o?.("login")},w=()=>{if(h||e){o?.("checkCode",{email:i});return}if(!i){c(m("forgotPassword.emailRequired"));return}if(!C(i)){c(m("forgotPassword.invalidEmail"));return}o?.("checkCode",{email:i})};return h||e?B(fe,{children:to(Z,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[to(Z,{sx:{mb:2},children:[B(ao,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m(e?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),B(ao,{variant:"body2",sx:{color:e?"success.main":"grey.600"},children:m("forgotPassword.checkEmailInstructions")})]}),B(ue,{type:"button",onClick:w,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:m("forgotPassword.enterCodeLink")}),B(Z,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:B(Do,{sx:{cursor:"pointer"},onClick:x,variant:"body2",color:"secondary",children:m("common.back")})})]})}):to(fe,{children:[to(Z,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[to(Z,{sx:{mb:2},children:[B(ao,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m("forgotPassword.title")}),B(ao,{variant:"body2",sx:{color:"grey.600"},children:m("forgotPassword.instructions")})]}),to(Z,{sx:{mb:1},children:[B(ao,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:m("forgotPassword.emailLabel")}),B(er,{fullWidth:!0,id:"email",name:"email",type:"email",value:i,disabled:n,onChange:v=>f(v.target.value),error:!!y,helperText:y,autoComplete:"email",placeholder:m("forgotPassword.emailPlaceholder"),required:!0})]}),B(ue,{disabled:n,type:"button",onClick:u,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?B(rr,{size:20}):m("forgotPassword.sendCodeButton")}),to(Z,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[B(Do,{sx:{cursor:"pointer"},onClick:x,variant:"body2",color:"secondary",children:m("common.back")}),B(ao,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),B(Do,{sx:{cursor:"pointer"},onClick:w,variant:"body2",color:"secondary",children:m("login.alreadyHaveCodeLink")})]})]}),B(Z,{children:g.length>0&&g.map((v,E)=>B(tr,{variant:"filled",sx:{mt:2},severity:"error",children:v},E))})]})},pe=nr;import{useState as U,useEffect as ge}from"react";import{Typography as To,TextField as ye,Button as sr,Box as oo,CircularProgress as xe,Alert as he,Link as ar}from"@mui/material";import{Fragment as lr,jsx as F,jsxs as go}from"react/jsx-runtime";var ir=({onScreenChange:o,onError:t,searchParams:a,onResetSuccess:i})=>{let{crudify:f}=G(),[n,s]=U(""),[g,l]=U(""),[y,c]=U(!1),[h,d]=U([]),[e,r]=U(null),[m,P]=U(null),[C,u]=U(""),[x,w]=U(""),[v,E]=U(!1),[p,S]=U(!0),[J,mo]=U(!1),[wo,Io]=U(null),[_e,Ko]=U(!1),{t:I}=V(),Po=T=>{let k=[`errors.auth.${T.code}`,`errors.data.${T.code}`,`errors.system.${T.code}`,`errors.${T.code}`,`resetPassword.${T.code.toLowerCase()}`];for(let O of k){let W=I(O);if(W!==O)return W}return T.message||I("error.unknown")},Co=T=>a?a instanceof URLSearchParams?a.get(T):a[T]||null:null;ge(()=>{if(a){if(a){let T=Co("fromCodeVerification"),k=Co("email"),O=Co("code");if(T==="true"&&k&&O){u(k),w(O),E(!0),mo(!0),S(!1);return}let W=Co("link");if(W)try{let H=decodeURIComponent(W),[$,uo]=H.split("/");if($&&uo&&$.length===6){w($),u(uo),E(!1),Io({email:uo,code:$});return}}catch{}if(k&&O){u(k),w(O),E(!1),Io({email:k,code:O});return}}d([I("resetPassword.invalidCode")]),S(!1),setTimeout(()=>o?.("forgotPassword"),3e3)}},[a,f,I,o]),ge(()=>{f&&wo&&!_e&&(Ko(!0),(async(k,O)=>{try{let W=[{operation:"validatePasswordResetCode",data:{email:k,codePassword:O}}],H=await f.transaction(W);if(H.data&&Array.isArray(H.data)){let $=H.data[0];if($&&$.response&&$.response.status==="OK"){mo(!0);return}}if(H.success)mo(!0);else{let uo=z(H).map(Po);d(uo),setTimeout(()=>o?.("forgotPassword"),3e3)}}catch(W){let $=z(W).map(Po);d($),setTimeout(()=>o?.("forgotPassword"),3e3)}finally{S(!1),Io(null),Ko(!1)}})(wo.email,wo.code))},[f,wo,I,o]);let Oe=T=>T.length<8?I("resetPassword.passwordTooShort"):null,ze=async()=>{if(y||!f)return;d([]),r(null),P(null);let T=!1;if(!n)r(I("resetPassword.newPasswordRequired")),T=!0;else{let k=Oe(n);k&&(r(k),T=!0)}if(g?n!==g&&(P(I("resetPassword.passwordsDoNotMatch")),T=!0):(P(I("resetPassword.confirmPasswordRequired")),T=!0),!T){c(!0);try{let k=[{operation:"validateAndResetPassword",data:{email:C,codePassword:x,newPassword:n}}],O=await f.transaction(k);if(O.success)d([]),setTimeout(()=>{i?.()},1e3);else{let H=z(O).map(Po);d(H)}}catch(k){let W=z(k).map(Po);d(W),t&&t(W.join(", "))}c(!1)}},We=()=>{v?o?.("checkCode",{email:C}):o?.("forgotPassword")};return p?F(oo,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:F(xe,{})}):J?go(lr,{children:[go(oo,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[go(oo,{sx:{mb:2},children:[F(To,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:I("resetPassword.title")}),F(To,{variant:"body2",sx:{color:"grey.600"},children:I("resetPassword.instructions")})]}),go(oo,{sx:{mb:1},children:[F(To,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:I("resetPassword.newPasswordLabel")}),F(ye,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:n,disabled:y,onChange:T=>s(T.target.value),error:!!e,helperText:e,autoComplete:"new-password",placeholder:I("resetPassword.newPasswordPlaceholder"),required:!0})]}),go(oo,{sx:{mb:1},children:[F(To,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:I("resetPassword.confirmPasswordLabel")}),F(ye,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:g,disabled:y,onChange:T=>l(T.target.value),error:!!m,helperText:m,autoComplete:"new-password",placeholder:I("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),F(sr,{disabled:y,type:"button",onClick:ze,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:y?F(xe,{size:20}):I("resetPassword.resetPasswordButton")}),F(oo,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:F(ar,{sx:{cursor:"pointer"},onClick:We,variant:"body2",color:"secondary",children:I("common.back")})})]}),F(oo,{children:h.length>0&&h.map((T,k)=>F(he,{variant:"filled",sx:{mt:2},severity:"error",children:T},k))})]}):F(oo,{children:h.length>0&&h.map((T,k)=>F(he,{variant:"filled",sx:{mt:2},severity:"error",children:T},k))})},be=ir;import{useState as yo,useEffect as cr}from"react";import{Typography as _o,TextField as dr,Button as mr,Box as xo,CircularProgress as ur,Alert as fr,Link as pr}from"@mui/material";import{Fragment as yr,jsx as K,jsxs as Eo}from"react/jsx-runtime";var gr=({onScreenChange:o,onError:t,searchParams:a})=>{let{crudify:i}=G(),[f,n]=yo(""),[s,g]=yo(!1),[l,y]=yo([]),[c,h]=yo(null),[d,e]=yo(""),{t:r}=V(),m=w=>a?a instanceof URLSearchParams?a.get(w):a[w]||null:null,P=w=>{let v=[`errors.auth.${w.code}`,`errors.data.${w.code}`,`errors.system.${w.code}`,`errors.${w.code}`,`checkCode.${w.code.toLowerCase()}`];for(let E of v){let p=r(E);if(p!==E)return p}return w.message||r("error.unknown")};cr(()=>{let w=m("email");w?e(w):o?.("forgotPassword")},[a,o]);let C=async()=>{if(!(s||!i)){if(y([]),h(null),!f){h(r("checkCode.codeRequired"));return}if(f.length!==6){h(r("checkCode.codeRequired"));return}g(!0);try{let w=[{operation:"validatePasswordResetCode",data:{email:d,codePassword:f}}],v=await i.transaction(w);if(v.success)o?.("resetPassword",{email:d,code:f,fromCodeVerification:"true"});else{let p=z(v).map(P);y(p),g(!1)}}catch(w){let E=z(w).map(P);y(E),g(!1),t&&t(E.join(", "))}}},u=()=>{o?.("forgotPassword")},x=w=>{let v=w.target.value.replace(/\D/g,"").slice(0,6);n(v)};return Eo(yr,{children:[Eo(xo,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Eo(xo,{sx:{mb:2},children:[K(_o,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:r("checkCode.title")}),K(_o,{variant:"body2",sx:{color:"grey.600"},children:r("checkCode.instructions")})]}),Eo(xo,{sx:{mb:1},children:[K(_o,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:r("checkCode.codeLabel")}),K(dr,{fullWidth:!0,id:"code",name:"code",type:"text",value:f,disabled:s,onChange:x,error:!!c,helperText:c,placeholder:r("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0})]}),K(mr,{disabled:s||f.length!==6,type:"button",onClick:C,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:s?K(ur,{size:20}):r("checkCode.verifyButton")}),K(xo,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:K(pr,{sx:{cursor:"pointer"},onClick:u,variant:"body2",color:"secondary",children:r("common.back")})})]}),K(xo,{children:l.length>0&&l.map((w,v)=>K(fr,{sx:{mt:2},severity:"error",children:w},v))})]})},we=gr;import{Box as xr,CircularProgress as hr,Alert as Pe,Typography as Oo}from"@mui/material";import{Fragment as br,jsx as io,jsxs as Ce}from"react/jsx-runtime";var ve=({children:o,fallback:t})=>{let{isLoading:a,error:i,isInitialized:f}=G(),{t:n}=V();return a?t||Ce(xr,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[io(hr,{}),io(Oo,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):i?io(Pe,{severity:"error",sx:{mt:2},children:Ce(Oo,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",i]})}):f?io(br,{children:o}):io(Pe,{severity:"warning",sx:{mt:2},children:io(Oo,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as j,jsxs as Tr}from"react/jsx-runtime";var Cr=({onScreenChange:o,onExternalNavigate:t,onLoginSuccess:a,onError:i,redirectUrl:f="/"})=>{let{t:n}=V(),{state:s,setScreen:g}=vo(),{config:l}=Q(),{showNotification:y}=Qo(),c=(d,e)=>{let r=e;d==="login"?r={}:d==="forgotPassword"&&!e&&(r={}),g(d,r),o?.(d,r)},h=()=>{let d={onScreenChange:c,onExternalNavigate:t,onError:i,redirectUrl:f};switch(s.currentScreen){case"forgotPassword":return j(pe,{...d});case"checkCode":return j(we,{...d,searchParams:s.searchParams});case"resetPassword":return j(be,{...d,searchParams:s.searchParams,onResetSuccess:()=>{let e=n("resetPassword.successMessage");y(e,"success"),c("login")}});default:return j(me,{...d,onLoginSuccess:a})}};return Tr(ve,{children:[j(wr,{sx:{display:"flex",justifyContent:"center",mb:3},children:j("img",{src:l.logo||"https://logos.crudia.com/nocios-default.png",alt:n("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:d=>{let e=d.target;e.src="https://logos.crudia.com/nocios-default.png"}})}),!l.logo&&l.appName&&j(Pr,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:l.appName}),h()]})},vr=({translations:o,translationsUrl:t,language:a="en",initialScreen:i="login",autoReadFromCookies:f=!0,...n})=>{let{config:s}=Q();return j(ne,{translations:o,translationsUrl:t,language:a,children:j(Yo,{config:s,children:j(le,{config:s,initialScreen:i,autoReadFromCookies:f,children:j(Cr,{...n})})})})},Ln=vr;import{Box as N,Card as Te,CardContent as Ee,Typography as q,Chip as So,Avatar as Er,Divider as Sr,CircularProgress as kr,Alert as Se,List as Lr,ListItem as zo,ListItemText as Wo,ListItemIcon as Rr,Collapse as Ar,IconButton as Uo}from"@mui/material";import{Person as Ir,Email as Br,Badge as Fr,Security as Dr,Schedule as _r,AccountCircle as Or,ExpandMore as zr,ExpandLess as Wr,Info as Ur}from"@mui/icons-material";import{useState as Nr}from"react";import{Fragment as Hr,jsx as b,jsxs as L}from"react/jsx-runtime";var Vr=({showExtendedData:o=!0,showProfileCard:t=!0,autoRefresh:a=!0})=>{let{userProfile:i,loading:f,error:n,extendedData:s,refreshProfile:g}=Zo({autoFetch:a,retryOnError:!0,maxRetries:3}),[l,y]=Nr(!1);if(f)return L(N,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[b(kr,{}),b(q,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return L(Se,{severity:"error",action:b(Uo,{color:"inherit",size:"small",onClick:g,children:b(q,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!i)return b(Se,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let c=s?.displayData||{},h=s?.totalFields||0,d=u=>{if(!u)return"No disponible";try{return new Date(u).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return u}},e=(u,x)=>x==null?"No disponible":typeof x=="boolean"?x?"S\xED":"No":Array.isArray(x)?x.length>0?x.join(", "):"Ninguno":typeof x=="object"?JSON.stringify(x,null,2):String(x),r=[{key:"id",label:"ID",icon:b(Fr,{})},{key:"email",label:"Email",icon:b(Br,{})},{key:"username",label:"Usuario",icon:b(Ir,{})},{key:"fullName",label:"Nombre completo",icon:b(Or,{})},{key:"role",label:"Rol",icon:b(Dr,{})}],m=[{key:"firstName",label:"Nombre"},{key:"lastName",label:"Apellido"},{key:"isActive",label:"Activo"},{key:"lastLogin",label:"\xDAltimo login"},{key:"createdAt",label:"Creado"},{key:"updatedAt",label:"Actualizado"}],P=[...r.map(u=>u.key),...m.map(u=>u.key),"permissions"],C=Object.keys(c).filter(u=>!P.includes(u)).map(u=>({key:u,label:u}));return L(N,{children:[t&&b(Te,{sx:{mb:2},children:L(Ee,{children:[L(N,{display:"flex",alignItems:"center",mb:2,children:[b(Er,{src:c.avatar,sx:{width:56,height:56,mr:2},children:c.fullName?.[0]||c.username?.[0]||c.email?.[0]}),L(N,{children:[b(q,{variant:"h6",children:c.fullName||c.username||c.email}),b(q,{variant:"body2",color:"text.secondary",children:c.role||"Usuario"}),c.isActive!==void 0&&b(So,{label:c.isActive?"Activo":"Inactivo",color:c.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),b(N,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:r.map(({key:u,label:x,icon:w})=>c[u]?L(N,{display:"flex",alignItems:"center",children:[b(N,{sx:{mr:1,color:"text.secondary"},children:w}),L(N,{children:[b(q,{variant:"caption",color:"text.secondary",children:x}),b(q,{variant:"body2",children:e(u,c[u])})]})]},u):null)}),c.permissions&&Array.isArray(c.permissions)&&c.permissions.length>0&&L(N,{mt:2,children:[b(q,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),L(N,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[c.permissions.slice(0,5).map((u,x)=>b(So,{label:u,size:"small",variant:"outlined"},x)),c.permissions.length>5&&b(So,{label:`+${c.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),o&&b(Te,{children:L(Ee,{children:[L(N,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[L(q,{variant:"h6",display:"flex",alignItems:"center",children:[b(Ur,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),b(So,{label:`${h} campos totales`,size:"small"})]}),L(Lr,{dense:!0,children:[m.map(({key:u,label:x})=>c[u]!==void 0&&L(zo,{divider:!0,children:[b(Rr,{children:b(_r,{fontSize:"small"})}),b(Wo,{primary:x,secondary:u.includes("At")||u.includes("Login")?d(c[u]):e(u,c[u])})]},u)),C.length>0&&L(Hr,{children:[b(Sr,{sx:{my:1}}),b(zo,{children:b(Wo,{primary:L(N,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[L(q,{variant:"subtitle2",children:["Campos Personalizados (",C.length,")"]}),b(Uo,{size:"small",onClick:()=>y(!l),children:l?b(Wr,{}):b(zr,{})})]})})}),b(Ar,{in:l,children:C.map(({key:u,label:x})=>b(zo,{sx:{pl:4},children:b(Wo,{primary:x,secondary:e(u,c[u])})},u))})]})]}),L(N,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[L(q,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",d(c.updatedAt)]}),b(Uo,{size:"small",onClick:g,disabled:f,children:b(q,{variant:"caption",children:"Actualizar"})})]})]})})]})},Mr=Vr;var ke=["create","read","update","delete"],Le=["create","read","update","delete"];import{useRef as ft}from"react";import{useTranslation as pt}from"react-i18next";import{Box as Lo,Typography as Be,Button as gt,Stack as yt,Alert as Fe,Divider as xt}from"@mui/material";import{Add as ht}from"@mui/icons-material";import{forwardRef as ot}from"react";import{useTranslation as et}from"react-i18next";import{Box as no,FormControl as rt,InputLabel as tt,Select as nt,MenuItem as st,IconButton as at,Typography as lo,FormHelperText as it,Stack as ko,Paper as Ie,Divider as lt,Button as $o}from"@mui/material";import{Delete as ct,SelectAll as dt,ClearAll as mt}from"@mui/icons-material";import{useState as $r,useEffect as jr,useRef as qr}from"react";import{useTranslation as Gr}from"react-i18next";import{Box as No,Typography as ho,Button as Re,Stack as Vo,FormHelperText as Ae,ToggleButton as Mo,ToggleButtonGroup as Kr}from"@mui/material";import{CheckCircle as Yr,Cancel as Jr,SelectAll as Xr,ClearAll as Qr}from"@mui/icons-material";import{jsx as D,jsxs as eo}from"react/jsx-runtime";var Zr=({value:o,onChange:t,availableFields:a,error:i,disabled:f=!1})=>{let{t:n}=Gr(),[s,g]=$r("custom"),l=qr(!1);jr(()=>{let e=o||{allow:[],owner_allow:[],deny:[]},r=new Set(a),m=(e.allow||[]).filter(x=>r.has(x)),P=(e.owner_allow||[]).filter(x=>r.has(x)),C=(e.deny||[]).filter(x=>r.has(x));a.forEach(x=>{!m.includes(x)&&!P.includes(x)&&!C.includes(x)&&C.push(x)});let u={allow:m,owner_allow:P,deny:C};JSON.stringify(u)!==JSON.stringify(e)&&t(u),m.length===a.length?g("all"):C.length===a.length?g("none"):g("custom")},[a,o]);let y=()=>{l.current=!0,t({allow:[...a],owner_allow:[],deny:[]}),g("all"),setTimeout(()=>{l.current=!1},0)},c=()=>{l.current=!0,t({allow:[],owner_allow:[],deny:[...a]}),g("none"),setTimeout(()=>{l.current=!1},0)},h=e=>o?.allow?.includes(e)?"allow":o?.owner_allow?.includes(e)?"owner_allow":"deny",d=(e,r)=>{l.current=!0;let m=new Set(o?.allow||[]),P=new Set(o?.owner_allow||[]),C=new Set(o?.deny||[]);m.delete(e),P.delete(e),C.delete(e),r==="allow"&&m.add(e),r==="owner_allow"&&P.add(e),r==="deny"&&C.add(e),t({allow:Array.from(m),owner_allow:Array.from(P),deny:Array.from(C)}),g("custom"),setTimeout(()=>{l.current=!1},0)};return a.length===0?eo(No,{children:[D(ho,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("modules.form.publicPolicies.fields.conditions.label")}),D(ho,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),i&&D(Ae,{error:!0,sx:{mt:1},children:i})]}):eo(No,{children:[D(ho,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.label")}),eo(Vo,{direction:"row",spacing:1,sx:{mb:3},children:[D(Re,{variant:s==="all"?"contained":"outlined",startIcon:D(Xr,{}),onClick:y,disabled:f,size:"small",sx:{minWidth:120,...s==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("modules.form.publicPolicies.fields.conditions.allFields")}),D(Re,{variant:s==="none"?"contained":"outlined",startIcon:D(Qr,{}),onClick:c,disabled:f,size:"small",sx:{minWidth:120,...s==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("modules.form.publicPolicies.fields.conditions.noFields")})]}),eo(No,{sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[D(ho,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.help")}),D(Vo,{spacing:1,children:a.map(e=>{let r=h(e);return eo(Vo,{direction:"row",spacing:1,alignItems:"center",children:[D(ho,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:e}),eo(Kr,{value:r,exclusive:!0,size:"small",children:[eo(Mo,{value:"allow",onClick:()=>d(e,"allow"),disabled:f,sx:{px:2,color:r==="allow"?"#ffffff":"#6b7280",backgroundColor:r==="allow"?"#16a34a":"#f3f4f6",borderColor:r==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:r==="allow"?"#15803d":"#e5e7eb",borderColor:r==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[D(Yr,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.allow")]}),D(Mo,{value:"owner_allow",onClick:()=>d(e,"owner_allow"),disabled:f,sx:{px:2,color:r==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:r==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:r==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:r==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:r==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),eo(Mo,{value:"deny",onClick:()=>d(e,"deny"),disabled:f,sx:{px:2,color:r==="deny"?"#ffffff":"#6b7280",backgroundColor:r==="deny"?"#dc2626":"#f3f4f6",borderColor:r==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:r==="deny"?"#b91c1c":"#e5e7eb",borderColor:r==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[D(Jr,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},e)})})]}),i&&D(Ae,{error:!0,sx:{mt:1},children:i})]})},Ho=Zr;import{jsx as A,jsxs as _}from"react/jsx-runtime";var ut=ot(({policy:o,onChange:t,onRemove:a,availableFields:i,isSubmitting:f=!1,usedActions:n,error:s},g)=>{let{t:l}=et(),y=new Set(Array.from(n||[]));y.delete(o.action);let c=ke.map(h=>({value:h,label:l(`modules.form.publicPolicies.fields.action.options.${h}`)}));return _(Ie,{ref:g,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[_(no,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[A(lo,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:l("modules.form.publicPolicies.policyTitle")}),A(at,{onClick:a,size:"small",disabled:f,"aria-label":l("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:A(ct,{})})]}),_(ko,{spacing:3,children:[A(ko,{direction:{xs:"column",md:"row"},spacing:2,children:A(no,{sx:{flex:1,minWidth:200},children:_(rt,{fullWidth:!0,children:[A(tt,{children:l("modules.form.publicPolicies.fields.action.label")}),A(nt,{value:o.action,label:l("modules.form.publicPolicies.fields.action.label"),disabled:f,onChange:h=>{let d=h.target.value,e={...o,action:d};d==="delete"?(e.permission="deny",delete e.fields):(e.fields={allow:[],owner_allow:[],deny:i},delete e.permission),t(e)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:c.map(h=>{let d=y.has(h.value);return A(st,{value:h.value,disabled:d,children:h.label},h.value)})}),s&&A(it,{error:!0,children:s})]})})}),o.action==="delete"?_(no,{children:[A(lo,{variant:"body2",color:"text.secondary",sx:{mb:2},children:l("modules.form.publicPolicies.fields.conditions.label")}),_(ko,{direction:"row",spacing:1,sx:{mb:3},children:[A($o,{variant:o.permission==="*"?"contained":"outlined",startIcon:A(dt,{}),onClick:()=>t({...o,permission:"*"}),disabled:f,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...o.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:l("modules.form.publicPolicies.fields.conditions.allFields")}),A($o,{variant:o.permission==="owner"?"contained":"outlined",onClick:()=>t({...o,permission:"owner"}),disabled:f,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...o.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:l("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),A($o,{variant:o.permission==="deny"?"contained":"outlined",startIcon:A(mt,{}),onClick:()=>t({...o,permission:"deny"}),disabled:f,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...o.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:l("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):A(Ho,{value:o.fields||{allow:[],owner_allow:[],deny:[]},onChange:h=>t({...o,fields:h}),availableFields:i,disabled:f}),A(Ie,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:o.action==="delete"?_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:o.permission==="*"?"#16a34a":o.permission==="owner"?"#0ea5e9":"#dc2626"},children:[l("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",o.permission||"-"]}):_(ko,{spacing:.5,divider:A(lt,{sx:{borderColor:"#e5e7eb"}}),children:[_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:"#16a34a"},children:[l("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(o?.fields?.allow||[]).join(", ")||"-"]}),_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:"#0ea5e9"},children:[l("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(o?.fields?.owner_allow||[]).join(", ")||"-"]}),_(lo,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(no,{component:"span",sx:{color:"#dc2626"},children:[l("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(o?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),jo=ut;import{Fragment as Pt,jsx as Y,jsxs as Ro}from"react/jsx-runtime";var bt=()=>{let o=globalThis?.crypto;return o&&typeof o.randomUUID=="function"?o.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},wt=({policies:o,onChange:t,availableFields:a,errors:i,isSubmitting:f=!1})=>{let{t:n}=pt(),s=ft({}),g=new Set((o||[]).map(r=>r.action).filter(Boolean)),l=Le.filter(r=>!g.has(r)),y=l.length>0,c=()=>{let r=l[0]||"create",m={id:bt(),action:r};r==="delete"?m.permission="deny":m.fields={allow:[],owner_allow:[],deny:a};let P=[...o||[],m];t(P),setTimeout(()=>{let C=P.length-1,u=s.current[C];u&&u.scrollIntoView({behavior:"smooth",block:"center"})},100)},h=r=>{let m=[...o];m.splice(r,1),t(m)},d=(()=>{if(!i)return null;if(typeof i=="string")return i;let r=i._error;return typeof r=="string"?r:null})(),e=new Set((o||[]).map(r=>r.action));return Ro(Pt,{children:[Y(xt,{sx:{borderColor:"#e0e4e7"}}),Ro(Lo,{children:[Y(Lo,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:Ro(Lo,{children:[Y(Be,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("modules.form.publicPolicies.title")}),Y(Be,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("modules.form.publicPolicies.description")})]})}),d&&Y(Fe,{severity:"error",sx:{mb:3},children:d}),Ro(yt,{spacing:3,children:[(o||[]).length===0?Y(Fe,{severity:"info",children:n("modules.form.publicPolicies.noPolicies")}):o.map((r,m)=>Y(jo,{ref:P=>{s.current[m]=P},policy:r,onChange:P=>{let C=[...o];C[m]=P,t(C)},onRemove:()=>h(m),availableFields:a,isSubmitting:f,usedActions:e,error:typeof i=="object"&&i&&r.id in i?i[r.id]:void 0},r.id)),y&&Y(Lo,{children:Y(gt,{type:"button",variant:"outlined",startIcon:Y(ht,{}),onClick:c,disabled:f,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("modules.form.publicPolicies.addPolicy")})})]})]})]})},us=wt;import{useState as qo}from"react";import{Button as Ao,TextField as De,Box as co,Alert as bo,Typography as ro,CircularProgress as Go}from"@mui/material";import{jsx as R,jsxs as X}from"react/jsx-runtime";function bs(){let[o,t]=qo(""),[a,i]=qo(""),[f,n]=qo(!1),{isAuthenticated:s,isLoading:g,error:l,login:y,logout:c,refreshTokens:h,clearError:d,isExpiringSoon:e,expiresIn:r}=Q(),m=async u=>{if(u.preventDefault(),!o||!a)return;(await y(o,a)).success&&(t(""),i(""),n(!1))},P=async()=>{await c()},C=async()=>{await h()};return s?X(co,{sx:{maxWidth:600,mx:"auto",p:3},children:[R(ro,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),R(bo,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),X(co,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[R(ro,{variant:"h6",gutterBottom:!0,children:"Token Status"}),X(ro,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(r/1e3/60)," minutes"]}),e&&R(bo,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),X(co,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[R(Ao,{variant:"contained",onClick:C,disabled:g,startIcon:g?R(Go,{size:16}):null,children:"Refresh Tokens"}),R(Ao,{variant:"outlined",color:"error",onClick:P,disabled:g,children:"Logout"})]}),l&&R(bo,{severity:"error",sx:{mt:2},onClose:d,children:l})]}):X(co,{sx:{maxWidth:400,mx:"auto",p:3},children:[R(ro,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),R(bo,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),f?X("form",{onSubmit:m,children:[R(De,{fullWidth:!0,label:"Email",type:"email",value:o,onChange:u=>t(u.target.value),margin:"normal",required:!0,autoComplete:"email"}),R(De,{fullWidth:!0,label:"Password",type:"password",value:a,onChange:u=>i(u.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),R(Ao,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:g,startIcon:g?R(Go,{size:16}):null,sx:{mt:3,mb:2},children:g?"Logging in...":"Login"})]}):R(Ao,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),l&&R(bo,{severity:"error",sx:{mt:2},onClose:d,children:l})]})}function ws(){let{isAuthenticated:o,isLoading:t,isExpiringSoon:a,expiresIn:i}=Q();return t?X(co,{sx:{display:"flex",alignItems:"center",gap:1},children:[R(Go,{size:16}),R(ro,{variant:"caption",children:"Loading session..."})]}):o?X(co,{children:[R(ro,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),a&&X(ro,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(i/1e3/60)," min"]})]}):R(ro,{variant:"caption",color:"text.secondary",children:"Not logged in"})}export{Ln as a,Mr as b,ke as c,Le as d,us as e,bs as f,ws as g};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk4VW4J2U2js = require('./chunk-4VW4J2U2.js');var _chunkDBU3TOSAjs = require('./chunk-DBU3TOSA.js');require('./chunk-YIIUEOXC.js');require('./chunk-AT74WV5W.js');var _react = require('react');var _jsxruntime = require('react/jsx-runtime');function G({showBelowMinutes:d=5,position:f="bottom-right",colorNormal:m="#ed6c02",colorCritical:x="#d32f2f",style:g,className:u}={}){let{isAuthenticated:o,tokens:t}=_chunkDBU3TOSAjs.f.call(void 0, ),[i,h]=_react.useState.call(void 0, 0),[y,S]=_react.useState.call(void 0, 100);if(_react.useEffect.call(void 0, ()=>{if(!o||!t)return;let P=setInterval(()=>{let C=Date.now(),p=t.expiresAt-C,w=900*1e3;h(Math.max(0,p)),S(Math.max(0,p/w*100))},1e3);return()=>clearInterval(P)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),b=Math.floor(i%6e4/1e3);if(e>=d)return null;let s=e<2,a=s?x:m,v={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[f];return _jsxruntime.jsxs.call(void 0, "div",{className:u,style:{position:"fixed",...v,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...g},children:[_jsxruntime.jsxs.call(void 0, "div",{style:{marginBottom:"8px"},children:[_jsxruntime.jsx.call(void 0, "div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),_jsxruntime.jsxs.call(void 0, "div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",b.toString().padStart(2,"0")]})]}),_jsxruntime.jsx.call(void 0, "div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:_jsxruntime.jsx.call(void 0, "div",{style:{width:`${y}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}exports.CrudifyLogin = _chunk4VW4J2U2js.a; exports.GlobalNotificationProvider = _chunkDBU3TOSAjs.g; exports.LoginComponent = _chunk4VW4J2U2js.f; exports.Policies = _chunk4VW4J2U2js.e; exports.SessionStatus = _chunk4VW4J2U2js.g; exports.SessionTimeIndicator = G; exports.UserProfileDisplay = _chunk4VW4J2U2js.b; exports.useGlobalNotification = _chunkDBU3TOSAjs.h;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk47DGJX3Jjs = require('./chunk-47DGJX3J.js');var _chunkMTP6BSGZjs = require('./chunk-MTP6BSGZ.js');require('./chunk-YIIUEOXC.js');require('./chunk-AT74WV5W.js');var _react = require('react');var _jsxruntime = require('react/jsx-runtime');function G({showBelowMinutes:d=5,position:f="bottom-right",colorNormal:m="#ed6c02",colorCritical:x="#d32f2f",style:g,className:u}={}){let{isAuthenticated:o,tokens:t}=_chunkMTP6BSGZjs.f.call(void 0, ),[i,h]=_react.useState.call(void 0, 0),[y,S]=_react.useState.call(void 0, 100);if(_react.useEffect.call(void 0, ()=>{if(!o||!t)return;let P=setInterval(()=>{let C=Date.now(),p=t.expiresAt-C,w=900*1e3;h(Math.max(0,p)),S(Math.max(0,p/w*100))},1e3);return()=>clearInterval(P)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),b=Math.floor(i%6e4/1e3);if(e>=d)return null;let s=e<2,a=s?x:m,v={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[f];return _jsxruntime.jsxs.call(void 0, "div",{className:u,style:{position:"fixed",...v,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...g},children:[_jsxruntime.jsxs.call(void 0, "div",{style:{marginBottom:"8px"},children:[_jsxruntime.jsx.call(void 0, "div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),_jsxruntime.jsxs.call(void 0, "div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",b.toString().padStart(2,"0")]})]}),_jsxruntime.jsx.call(void 0, "div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:_jsxruntime.jsx.call(void 0, "div",{style:{width:`${y}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}exports.CrudifyLogin = _chunk47DGJX3Jjs.a; exports.GlobalNotificationProvider = _chunkMTP6BSGZjs.g; exports.LoginComponent = _chunk47DGJX3Jjs.f; exports.Policies = _chunk47DGJX3Jjs.e; exports.SessionStatus = _chunk47DGJX3Jjs.g; exports.SessionTimeIndicator = G; exports.UserProfileDisplay = _chunk47DGJX3Jjs.b; exports.useGlobalNotification = _chunkMTP6BSGZjs.h;
@@ -1 +1 @@
1
- import{a as T,b as L,e as M,f as R,g as k}from"./chunk-GT5YJKPE.mjs";import{f as l,g as I,h as N}from"./chunk-FM2YKL4E.mjs";import"./chunk-BJ6PIVZR.mjs";import"./chunk-5JKS55SE.mjs";import{useEffect as B,useState as c}from"react";import{jsx as r,jsxs as n}from"react/jsx-runtime";function G({showBelowMinutes:d=5,position:f="bottom-right",colorNormal:m="#ed6c02",colorCritical:x="#d32f2f",style:g,className:u}={}){let{isAuthenticated:o,tokens:t}=l(),[i,h]=c(0),[y,S]=c(100);if(B(()=>{if(!o||!t)return;let P=setInterval(()=>{let C=Date.now(),p=t.expiresAt-C,w=900*1e3;h(Math.max(0,p)),S(Math.max(0,p/w*100))},1e3);return()=>clearInterval(P)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),b=Math.floor(i%6e4/1e3);if(e>=d)return null;let s=e<2,a=s?x:m,v={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[f];return n("div",{className:u,style:{position:"fixed",...v,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...g},children:[n("div",{style:{marginBottom:"8px"},children:[r("div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),n("div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",b.toString().padStart(2,"0")]})]}),r("div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:r("div",{style:{width:`${y}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}export{T as CrudifyLogin,I as GlobalNotificationProvider,R as LoginComponent,M as Policies,k as SessionStatus,G as SessionTimeIndicator,L as UserProfileDisplay,N as useGlobalNotification};
1
+ import{a as T,b as L,e as M,f as R,g as k}from"./chunk-UIDWACK3.mjs";import{f as l,g as I,h as N}from"./chunk-IPMROPYS.mjs";import"./chunk-BJ6PIVZR.mjs";import"./chunk-5JKS55SE.mjs";import{useEffect as B,useState as c}from"react";import{jsx as r,jsxs as n}from"react/jsx-runtime";function G({showBelowMinutes:d=5,position:f="bottom-right",colorNormal:m="#ed6c02",colorCritical:x="#d32f2f",style:g,className:u}={}){let{isAuthenticated:o,tokens:t}=l(),[i,h]=c(0),[y,S]=c(100);if(B(()=>{if(!o||!t)return;let P=setInterval(()=>{let C=Date.now(),p=t.expiresAt-C,w=900*1e3;h(Math.max(0,p)),S(Math.max(0,p/w*100))},1e3);return()=>clearInterval(P)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),b=Math.floor(i%6e4/1e3);if(e>=d)return null;let s=e<2,a=s?x:m,v={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[f];return n("div",{className:u,style:{position:"fixed",...v,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...g},children:[n("div",{style:{marginBottom:"8px"},children:[r("div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),n("div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",b.toString().padStart(2,"0")]})]}),r("div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:r("div",{style:{width:`${y}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}export{T as CrudifyLogin,I as GlobalNotificationProvider,R as LoginComponent,M as Policies,k as SessionStatus,G as SessionTimeIndicator,L as UserProfileDisplay,N as useGlobalNotification};
package/dist/hooks.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkWZEPLZEJjs = require('./chunk-WZEPLZEJ.js');var _chunkDBU3TOSAjs = require('./chunk-DBU3TOSA.js');require('./chunk-AT74WV5W.js');exports.useAuth = _chunkWZEPLZEJjs.b; exports.useCrudifyWithNotifications = _chunkWZEPLZEJjs.d; exports.useData = _chunkWZEPLZEJjs.c; exports.useSession = _chunkDBU3TOSAjs.f; exports.useUserData = _chunkWZEPLZEJjs.a; exports.useUserProfile = _chunkDBU3TOSAjs.l;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk5Y7BV2YMjs = require('./chunk-5Y7BV2YM.js');var _chunkMTP6BSGZjs = require('./chunk-MTP6BSGZ.js');require('./chunk-AT74WV5W.js');exports.useAuth = _chunk5Y7BV2YMjs.b; exports.useCrudifyWithNotifications = _chunk5Y7BV2YMjs.d; exports.useData = _chunk5Y7BV2YMjs.c; exports.useSession = _chunkMTP6BSGZjs.f; exports.useUserData = _chunk5Y7BV2YMjs.a; exports.useUserProfile = _chunkMTP6BSGZjs.l;
package/dist/hooks.mjs CHANGED
@@ -1 +1 @@
1
- import{a as s,b as r,c as o,d as a}from"./chunk-HYJWXWGO.mjs";import{f as e,l as t}from"./chunk-FM2YKL4E.mjs";import"./chunk-5JKS55SE.mjs";export{r as useAuth,a as useCrudifyWithNotifications,o as useData,e as useSession,s as useUserData,t as useUserProfile};
1
+ import{a as s,b as r,c as o,d as a}from"./chunk-PYCPFJM6.mjs";import{f as e,l as t}from"./chunk-IPMROPYS.mjs";import"./chunk-5JKS55SE.mjs";export{r as useAuth,a as useCrudifyWithNotifications,o as useData,e as useSession,s as useUserData,t as useUserProfile};
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _createStarExport(obj) { Object.keys(obj) .filter((key) => key !== "default" && key !== "__esModule") .forEach((key) => { if (exports.hasOwnProperty(key)) { return; } Object.defineProperty(exports, key, {enumerable: true, configurable: true, get: () => obj[key]}); }); } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _chunk4VW4J2U2js = require('./chunk-4VW4J2U2.js');var _chunkWZEPLZEJjs = require('./chunk-WZEPLZEJ.js');var _chunkDBU3TOSAjs = require('./chunk-DBU3TOSA.js');var _chunkNNY4A73Vjs = require('./chunk-NNY4A73V.js');var _chunkYIIUEOXCjs = require('./chunk-YIIUEOXC.js');var _chunkAT74WV5Wjs = require('./chunk-AT74WV5W.js');var _crudifybrowser = require('@nocios/crudify-browser'); var _crudifybrowser2 = _interopRequireDefault(_crudifybrowser); _createStarExport(_crudifybrowser);var _react = require('react');var _material = require('@mui/material');var _jsxruntime = require('react/jsx-runtime');var Ze=(i={})=>{try{let e=_chunkAT74WV5Wjs.a.call(void 0, "theme");if(e){let r=JSON.parse(decodeURIComponent(e));return{...i,...r}}}catch(e){console.warn("Error parsing theme from cookie:",e)}return i};function Je({children:i,defaultTheme:e={},disableCssBaseline:r=!1}){let t=_react.useMemo.call(void 0, ()=>{let o=Ze(e);return _material.createTheme.call(void 0, o)},[e]);return _jsxruntime.jsxs.call(void 0, _material.ThemeProvider,{theme:t,children:[!r&&_jsxruntime.jsx.call(void 0, _material.CssBaseline,{}),i]})}var _reactrouterdom = require('react-router-dom');var Xe={border:"5px solid rgba(0, 0, 0, 0.1)",borderTopColor:"#3B82F6",borderRadius:"50%",width:"50px",height:"50px",animation:"spin 1s linear infinite"},er=()=>_jsxruntime.jsx.call(void 0, "style",{children:`
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _createStarExport(obj) { Object.keys(obj) .filter((key) => key !== "default" && key !== "__esModule") .forEach((key) => { if (exports.hasOwnProperty(key)) { return; } Object.defineProperty(exports, key, {enumerable: true, configurable: true, get: () => obj[key]}); }); } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _chunk47DGJX3Jjs = require('./chunk-47DGJX3J.js');var _chunk5Y7BV2YMjs = require('./chunk-5Y7BV2YM.js');var _chunkMTP6BSGZjs = require('./chunk-MTP6BSGZ.js');var _chunkNNY4A73Vjs = require('./chunk-NNY4A73V.js');var _chunkYIIUEOXCjs = require('./chunk-YIIUEOXC.js');var _chunkAT74WV5Wjs = require('./chunk-AT74WV5W.js');var _crudifybrowser = require('@nocios/crudify-browser'); var _crudifybrowser2 = _interopRequireDefault(_crudifybrowser); _createStarExport(_crudifybrowser);var _react = require('react');var _material = require('@mui/material');var _jsxruntime = require('react/jsx-runtime');var Ze=(i={})=>{try{let e=_chunkAT74WV5Wjs.a.call(void 0, "theme");if(e){let r=JSON.parse(decodeURIComponent(e));return{...i,...r}}}catch(e){console.warn("Error parsing theme from cookie:",e)}return i};function Je({children:i,defaultTheme:e={},disableCssBaseline:r=!1}){let o=_react.useMemo.call(void 0, ()=>{let t=Ze(e);return _material.createTheme.call(void 0, t)},[e]);return _jsxruntime.jsxs.call(void 0, _material.ThemeProvider,{theme:o,children:[!r&&_jsxruntime.jsx.call(void 0, _material.CssBaseline,{}),i]})}var _reactrouterdom = require('react-router-dom');var Xe={border:"5px solid rgba(0, 0, 0, 0.1)",borderTopColor:"#3B82F6",borderRadius:"50%",width:"50px",height:"50px",animation:"spin 1s linear infinite"},er=()=>_jsxruntime.jsx.call(void 0, "style",{children:`
2
2
  @keyframes spin {
3
3
  0% { transform: rotate(0deg); }
4
4
  100% { transform: rotate(360deg); }
5
5
  }
6
- `});function F({stage:i="loading",message:e}){let t=e||{initializing:"Initializing application...","validating-session":"Validating session...",loading:"Loading..."}[i];return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, er,{}),_jsxruntime.jsxs.call(void 0, "div",{style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",height:"100vh",width:"100vw",backgroundColor:"#f0f2f5",fontFamily:'"Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',color:"#333",textAlign:"center",boxSizing:"border-box",padding:"20px",background:"#fff"},children:[_jsxruntime.jsx.call(void 0, "div",{style:Xe}),_jsxruntime.jsx.call(void 0, "p",{style:{fontSize:"1.25em",fontWeight:"500",marginTop:"24px",color:"#1f2937"},children:t})]})]})}var ir=/^[a-zA-Z0-9\-_./\?=&%#]+$/,tr=[/^https?:\/\//i,/^ftp:\/\//i,/^\/\//,/javascript:/i,/data:/i,/vbscript:/i,/about:/i,/\.\.\//,/\.\.\\/,/%2e%2e%2f/i,/%2e%2e%5c/i,/%2f%2f/i,/%5c%5c/i,/[\x00-\x1f\x7f-\x9f]/,/\\/],O= exports.validateInternalRedirect =(i,e="/")=>{if(!i||typeof i!="string")return e;let r=i.trim();if(!r)return e;if(!r.startsWith("/"))return console.warn("\u{1F6A8} Open redirect blocked (relative path):",i),e;if(!ir.test(r))return console.warn("\u{1F6A8} Open redirect blocked (invalid characters):",i),e;let t=r.toLowerCase();for(let n of tr)if(n.test(t))return console.warn("\u{1F6A8} Open redirect blocked (dangerous pattern):",i),e;let o=r.split("?")[0].split("/").filter(Boolean);if(o.length===0)return r;for(let n of o)if(n===".."||n.includes(":")||n.length>100)return console.warn("\u{1F6A8} Open redirect blocked (suspicious path part):",n),e;return r},H= exports.extractSafeRedirectFromUrl =(i,e="/")=>{try{let t=(typeof i=="string"?new URLSearchParams(i):i).get("redirect");if(!t)return e;let o=decodeURIComponent(t);return O(o,e)}catch(r){return console.warn("\u{1F6A8} Error parsing redirect parameter:",r),e}};function Z({children:i,loadingComponent:e,loginPath:r="/login"}){let{isAuthenticated:t,isLoading:o,isInitialized:n,tokens:s,error:a}=_chunkDBU3TOSAjs.j.call(void 0, ),l=_reactrouterdom.useLocation.call(void 0, );if(!n||o)return _jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e||_jsxruntime.jsx.call(void 0, F,{stage:"validating-session"})});let u=t&&_optionalChain([s, 'optionalAccess', _2 => _2.accessToken])&&s.accessToken.length>0;if(a||!t||!u){s&&(!s.accessToken||s.accessToken.length===0)&&localStorage.removeItem("crudify_tokens");let f=l.pathname+l.search,P=O(f),T=encodeURIComponent(P);return _jsxruntime.jsx.call(void 0, _reactrouterdom.Navigate,{to:`${r}?redirect=${T}`,replace:!0})}return _jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:i})}function j({children:i,redirectTo:e="/"}){let{isAuthenticated:r}=_chunkDBU3TOSAjs.j.call(void 0, ),t=_reactrouterdom.useLocation.call(void 0, );if(r){let o=new URLSearchParams(t.search),n=H(o,e);return _jsxruntime.jsx.call(void 0, _reactrouterdom.Navigate,{to:n,replace:!0})}return _jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:i})}var z=class i{constructor(){this.state={status:"UNINITIALIZED",priority:null,publicApiKey:null,env:null,error:null,initializedBy:null};this.initializationPromise=null;this.highPriorityInitializerPresent=!1;this.waitingForHighPriority=new Set;this.HIGH_PRIORITY_WAIT_TIMEOUT=100}static getInstance(){return i.instance||(i.instance=new i),i.instance}registerHighPriorityInitializer(){this.highPriorityInitializerPresent=!0}isHighPriorityInitializerPresent(){return this.highPriorityInitializerPresent}getState(){return{...this.state}}async initialize(e){let{priority:r,publicApiKey:t,env:o,enableLogging:n,requestedBy:s}=e;if(this.state.status==="INITIALIZED"){this.state.publicApiKey!==t&&console.warn(`[CrudifyInitialization] ${s} attempted to initialize with different key. Already initialized with key: ${_optionalChain([this, 'access', _3 => _3.state, 'access', _4 => _4.publicApiKey, 'optionalAccess', _5 => _5.slice, 'call', _6 => _6(0,10)])}... by ${this.state.initializedBy}`);return}if(this.initializationPromise)return n&&console.log(`[CrudifyInitialization] ${s} waiting for ongoing initialization...`),this.initializationPromise;if(r==="LOW"&&this.highPriorityInitializerPresent&&this.state.status==="UNINITIALIZED"){if(n&&console.log(`[CrudifyInitialization] ${s} (LOW priority) waiting for HIGH priority initializer...`),this.waitingForHighPriority.add(s),await this.waitForHighPriorityOrTimeout(n),this.waitingForHighPriority.delete(s),this.getState().status==="INITIALIZED"){n&&console.log(`[CrudifyInitialization] ${s} found initialization completed by HIGH priority`);return}n&&console.warn(`[CrudifyInitialization] ${s} timeout waiting for HIGH priority, initializing with LOW priority`)}r==="HIGH"&&this.state.status==="INITIALIZING"&&this.state.priority==="LOW"&&(console.warn(`[CrudifyInitialization] HIGH priority request from ${s} interrupting LOW priority initialization by ${this.state.initializedBy}`),this.state.status="UNINITIALIZED",this.initializationPromise=null),n&&console.log(`[CrudifyInitialization] ${s} starting initialization (${r} priority)...`),this.state.status="INITIALIZING",this.state.priority=r,this.state.initializedBy=s,this.initializationPromise=this.performInitialization(t,o,n);try{await this.initializationPromise,this.state.status="INITIALIZED",this.state.publicApiKey=t,this.state.env=o,this.state.error=null,n&&console.log(`[CrudifyInitialization] \u2705 Successfully initialized by ${s} (${r} priority)`)}catch(a){throw this.state.status="ERROR",this.state.error=a instanceof Error?a:new Error(String(a)),this.initializationPromise=null,console.error(`[CrudifyInitialization] \u274C Initialization failed for ${s}:`,a),a}}async waitForHighPriorityOrTimeout(e){return new Promise(r=>{let o=0,n=setInterval(()=>{if(o+=10,this.state.status==="INITIALIZED"&&this.state.priority==="HIGH"){clearInterval(n),r();return}if(this.state.status==="INITIALIZING"&&this.state.priority==="HIGH"){o=0;return}o>=this.HIGH_PRIORITY_WAIT_TIMEOUT&&(clearInterval(n),e&&console.log(`[CrudifyInitialization] Timeout waiting for HIGH priority (${this.HIGH_PRIORITY_WAIT_TIMEOUT}ms)`),r())},10)})}async performInitialization(e,r,t){let o=_crudifybrowser2.default.getTokenData();if(o&&o.endpoint){t&&console.log("[CrudifyInitialization] SDK already initialized externally");return}_crudifybrowser2.default.config(r);let n=t?"debug":"none",s=await _crudifybrowser2.default.init(e,n);if(s.success===!1)throw new Error(`Crudify initialization failed: ${JSON.stringify(s.errors||"Unknown error")}`);if(!s.data&&s.success!==!0)throw new Error(`Crudify initialization failed: ${JSON.stringify(s.errors||"Unknown error")}`)}reset(){this.state={status:"UNINITIALIZED",priority:null,publicApiKey:null,env:null,error:null,initializedBy:null},this.initializationPromise=null,this.highPriorityInitializerPresent=!1,this.waitingForHighPriority.clear()}isInitialized(){return this.state.status==="INITIALIZED"}getDiagnostics(){return{...this.state,waitingCount:this.waitingForHighPriority.size,waitingComponents:Array.from(this.waitingForHighPriority),hasActivePromise:this.initializationPromise!==null}}},_= exports.crudifyInitManager =z.getInstance();var ee=_react.createContext.call(void 0, void 0),gr= exports.CrudifyInitializer =({config:i,children:e,fallback:r=null,onInitialized:t,onError:o})=>{let[n,s]=_react.useState.call(void 0, !1),[a,l]=_react.useState.call(void 0, !1),[u,f]=_react.useState.call(void 0, null),P=_react.useRef.call(void 0, !1),T=_react.useRef.call(void 0, !1);_react.useEffect.call(void 0, ()=>{P.current||(_.registerHighPriorityInitializer(),P.current=!0),T.current||(T.current=!0,(async()=>{l(!0),f(null);try{await _.initialize({priority:"HIGH",publicApiKey:i.publicApiKey,env:i.env||"stg",enableLogging:i.enableLogging,requestedBy:"CrudifyInitializer"}),s(!0),l(!1),t&&t()}catch(R){let A=R instanceof Error?R:new Error(String(R));f(A),l(!1),o&&o(A)}})())},[i.publicApiKey,i.env,i.enableLogging,t,o]);let b={isInitialized:n,isInitializing:a,error:u};return a&&r?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:r}):(u&&console.error("[CrudifyInitializer] Initialization failed:",u),_jsxruntime.jsx.call(void 0, ee.Provider,{value:b,children:e}))},fr= exports.useCrudifyInitializer =()=>{let i=_react.useContext.call(void 0, ee);if(!i)throw new Error("useCrudifyInitializer must be used within CrudifyInitializer");return i};var p={es:{"checkCode.codeLabel":"C\xF3digo de Verificaci\xF3n","checkCode.codePlaceholder":"Ingresa el c\xF3digo de 6 d\xEDgitos","checkCode.codeRequired":"El c\xF3digo es obligatorio","checkCode.emailLabel":"Correo Electr\xF3nico","checkCode.emailPlaceholder":"Ingresa tu correo electr\xF3nico","checkCode.emailRequired":"El correo electr\xF3nico es obligatorio","checkCode.instructions":"Ingresa el c\xF3digo de 6 d\xEDgitos que enviamos a tu correo electr\xF3nico.","checkCode.invalidEmail":"Ingresa un correo electr\xF3nico v\xE1lido","checkCode.resendCodeLink":"Reenviar c\xF3digo","checkCode.title":"Verificar C\xF3digo","checkCode.verifyButton":"Verificar C\xF3digo","common.back":"Volver","common.backToLogin":"Volver","error.app.config":"Error de Configuraci\xF3n: {{message}}","error.app.initialization":"Error durante la inicializaci\xF3n final de la aplicaci\xF3n.","error.transaction":"Error en la operaci\xF3n","error.unknown":"Ocurri\xF3 un error desconocido.","errors.DUPLICATE":"El campo <b>{{field}}</b> debe ser \xFAnico.","errors.FOREIGN_KEY_NOT_FOUND":"El campo <b>{{field}}</b> debe referenciar un \xEDtem existente.","errors.INVALID_EMAIL":"El campo <b>{{field}}</b> debe ser un correo electr\xF3nico v\xE1lido.","errors.INVALID_OBJECT_ID":"El campo <b>{{field}}</b> debe ser un valor v\xE1lido.","errors.IN_USE":"El \xEDtem est\xE1 en uso y no puede ser eliminado.","errors.MAX_LENGTH":"El campo <b>{{field}}</b> no debe exceder los <b>{{length}}</b> caracteres.","errors.MIN_LENGTH":"El campo <b>{{field}}</b> debe tener al menos <b>{{length}}</b> caracteres.","errors.MUST_NOT_BE_EMAIL":"El campo <b>{{field}}</b> no debe ser un correo electr\xF3nico.","errors.NO_PERMISSION":"No tienes permiso para realizar esta acci\xF3n.","errors.NO_SPACES":"El campo <b>{{field}}</b> no debe contener espacios.","errors.ONE_OR_MORE_OPERATIONS_FAILED":"Error en la operaci\xF3n","errors.REQUIRED":"El campo <b>{{field}}</b> es obligatorio.","errors.TOKEN_HAS_EXPIRED":"La sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.","errors.TOO_MANY_REQUESTS":"L\xEDmite de solicitudes alcanzado. Por favor intenta m\xE1s tarde.","errors.UNAUTHORIZED":"No est\xE1s autorizado para realizar esta acci\xF3n.","errors.all_password_fields_required":"Todos los campos de contrase\xF1a son obligatorios","errors.auth.INVALID_API_KEY":"Clave de API inv\xE1lida","errors.auth.INVALID_CREDENTIALS":"Usuario y/o contrase\xF1a incorrectos","errors.auth.NO_PERMISSION":"No tienes permisos suficientes","errors.auth.SESSION_EXPIRED":"Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.","errors.auth.TOO_MANY_REQUESTS":"Demasiados intentos. Por favor espera 15 minutos e intenta nuevamente","errors.auth.UNAUTHORIZED":"No tienes permisos para realizar esta acci\xF3n","errors.auth.USER_NOT_ACTIVE":"Usuario no activo","errors.auth.USER_NOT_FOUND":"Usuario no encontrado","errors.data.BAD_REQUEST":"Solicitud inv\xE1lida","errors.data.FIELD_ERROR":"Error en los datos ingresados","errors.data.IN_USE":"El elemento est\xE1 en uso y no puede ser eliminado","errors.data.ITEM_NOT_FOUND":"El elemento solicitado no fue encontrado","errors.data.NOT_FOUND":"No se encontr\xF3 lo solicitado","errors.internal_error_changing_password":"Error interno al cambiar la contrase\xF1a. Intenta nuevamente","errors.password_min_length":"La contrase\xF1a debe tener al menos 8 caracteres","errors.password_mismatch":"Las contrase\xF1as no coinciden","errors.password_must_be_different":"La nueva contrase\xF1a debe ser diferente a la actual","errors.system.DATABASE_CONNECTION_ERROR":"Error de conexi\xF3n. Verifica tu conexi\xF3n a internet.","errors.system.INTERNAL_SERVER_ERROR":"Error interno del servidor. Intenta nuevamente.","errors.system.INVALID_CONFIGURATION":"Error de configuraci\xF3n del sistema","errors.system.TOO_MANY_REQUESTS":"Demasiadas solicitudes. Por favor espera un momento e intenta nuevamente","errors.system.UNKNOWN_OPERATION":"Operaci\xF3n no reconocida","errors.users_module_not_configured":"M\xF3dulo de usuarios no configurado","footer.copyright":"Nocios S.R.L. Todos los derechos reservados.","footer.version":"Versi\xF3n","forgotPassword.checkEmailInstructions":"Revisa tu bandeja de entrada para el c\xF3digo de verificaci\xF3n","forgotPassword.codeAlreadyExistsMessage":"Ya se envi\xF3 un c\xF3digo y a\xFAn es v\xE1lido","forgotPassword.emailLabel":"Correo Electr\xF3nico","forgotPassword.emailPlaceholder":"Ingresa tu correo electr\xF3nico","forgotPassword.emailRequired":"El correo electr\xF3nico es obligatorio","forgotPassword.emailSentMessage":"C\xF3digo enviado exitosamente","forgotPassword.enterCodeLink":"Ingresar C\xF3digo","forgotPassword.instructions":"Ingresa tu correo electr\xF3nico y te enviaremos un c\xF3digo para restablecer tu contrase\xF1a.","forgotPassword.invalidEmail":"Ingresa un correo electr\xF3nico v\xE1lido","forgotPassword.sendCodeButton":"Enviar C\xF3digo","forgotPassword.title":"Recuperar Contrase\xF1a","loading.app.configInitial":"Cargando configuraci\xF3n inicial...","loading.app.generic":"Cargando...","loading.app.starting":"Iniciando aplicaci\xF3n...","loading.app.themeSetup":"Generando tema...","loading.app.validatingSession":"Validando sesi\xF3n...","login.alreadyHaveCodeLink":"\xBFYa tienes un c\xF3digo?","login.forgotPasswordLink":"\xBFOlvidaste tu contrase\xF1a?","login.initializationError":"Error de inicializaci\xF3n","login.initializing":"Inicializando...","login.loginButton":"Iniciar Sesi\xF3n","login.logoAlt":"Logotipo","login.noAccountPrompt":"\xBFNo tienes una cuenta?","login.notInitialized":"Sistema no inicializado","login.passwordLabel":"Contrase\xF1a","login.passwordPlaceholder":"Ingresa tu contrase\xF1a","login.passwordRequired":"Contrase\xF1a es obligatoria","login.signUpLink":"Reg\xEDstrate","login.usernameOrEmailLabel":"Usuario o Correo Electr\xF3nico","login.usernameOrEmailPlaceholder":"Ingresa tu usuario o correo electr\xF3nico","login.usernameRequired":"Usuario o correo electr\xF3nico es obligatorio","resetPassword.codeExpiredOrInvalid":"El c\xF3digo ha expirado o es inv\xE1lido","resetPassword.confirmPasswordLabel":"Confirmar Contrase\xF1a","resetPassword.confirmPasswordPlaceholder":"Confirma tu nueva contrase\xF1a","resetPassword.confirmPasswordRequired":"Confirma tu contrase\xF1a","resetPassword.goToLoginButton":"Ir al Login","resetPassword.instructions":"Ingresa tu nueva contrase\xF1a.","resetPassword.invalidCode":"El c\xF3digo de verificaci\xF3n es inv\xE1lido. Por favor, verifica el enlace o solicita uno nuevo.","resetPassword.missingParameters":"Faltan par\xE1metros obligatorios","resetPassword.newPasswordLabel":"Nueva Contrase\xF1a","resetPassword.newPasswordPlaceholder":"Ingresa tu nueva contrase\xF1a","resetPassword.newPasswordRequired":"La nueva contrase\xF1a es obligatoria","resetPassword.passwordTooShort":"La contrase\xF1a debe tener al menos 8 caracteres","resetPassword.passwordsDoNotMatch":"Las contrase\xF1as no coinciden","resetPassword.requestNewCodeButton":"Solicitar Nuevo C\xF3digo","resetPassword.resetPasswordButton":"Restablecer Contrase\xF1a","resetPassword.successInstructions":"Ahora puedes iniciar sesi\xF3n con tu nueva contrase\xF1a","resetPassword.successMessage":"Contrase\xF1a restablecida exitosamente","resetPassword.title":"Nueva Contrase\xF1a","resetPassword.validatingCode":"Validando c\xF3digo..."},en:{"checkCode.codeLabel":"Verification Code","checkCode.codePlaceholder":"Enter 6-digit code","checkCode.codeRequired":"Code is required","checkCode.emailLabel":"Email Address","checkCode.emailPlaceholder":"Enter your email address","checkCode.emailRequired":"Email address is required","checkCode.instructions":"Enter the 6-digit code we sent to your email address.","checkCode.invalidEmail":"Enter a valid email address","checkCode.resendCodeLink":"Resend code","checkCode.title":"Verify Code","checkCode.verifyButton":"Verify Code","common.back":"Back","common.backToLogin":"Back to Login","error.app.config":"Configuration Error: {{message}}","error.app.initialization":"Error during final application initialization.","error.transaction":"Operation error","error.unknown":"An unknown error occurred.","errors.DUPLICATE":"The field <b>{{field}}</b> must be unique.","errors.FOREIGN_KEY_NOT_FOUND":"The field <b>{{field}}</b> must reference an existing item.","errors.INVALID_EMAIL":"The field <b>{{field}}</b> must be a valid email address.","errors.INVALID_OBJECT_ID":"The field <b>{{field}}</b> must be a valid value.","errors.IN_USE":"The item is currently in use and cannot be deleted.","errors.MAX_LENGTH":"The field <b>{{field}}</b> must not exceed <b>{{maxLength}}</b> characters.","errors.MIN_LENGTH":"The field <b>{{field}}</b> must have at least <b>{{minLength}}</b> characters.","errors.MUST_NOT_BE_EMAIL":"The field <b>{{field}}</b> must not be an email address.","errors.NO_PERMISSION":"You do not have permission to perform this action.","errors.NO_SPACES":"The field <b>{{field}}</b> must not contain spaces.","errors.ONE_OR_MORE_OPERATIONS_FAILED":"Operation error","errors.REQUIRED":"The field <b>{{field}}</b> is required.","errors.TOKEN_HAS_EXPIRED":"Your session has expired, please log in again.","errors.TOO_MANY_REQUESTS":"Request limit reached. Please try again later.","errors.UNAUTHORIZED":"You are not authorized to perform this action.","errors.all_password_fields_required":"All password fields are required","errors.auth.INVALID_API_KEY":"Invalid API key","errors.auth.INVALID_CREDENTIALS":"Incorrect username and/or password","errors.auth.NO_PERMISSION":"Insufficient permissions","errors.auth.SESSION_EXPIRED":"Your session has expired. Please log in again.","errors.auth.TOO_MANY_REQUESTS":"Too many attempts. Please wait 15 minutes and try again","errors.auth.UNAUTHORIZED":"You don't have permission to perform this action","errors.auth.USER_NOT_ACTIVE":"User account is not active","errors.auth.USER_NOT_FOUND":"User not found","errors.data.BAD_REQUEST":"Invalid request","errors.data.FIELD_ERROR":"Error in the provided data","errors.data.IN_USE":"The item is in use and cannot be deleted","errors.data.ITEM_NOT_FOUND":"The requested item was not found","errors.data.NOT_FOUND":"The requested resource was not found","errors.internal_error_changing_password":"Internal error changing password. Please try again","errors.password_min_length":"Password must be at least 8 characters","errors.password_mismatch":"Passwords do not match","errors.password_must_be_different":"New password must be different from current password","errors.system.DATABASE_CONNECTION_ERROR":"Connection error. Please check your internet connection.","errors.system.INTERNAL_SERVER_ERROR":"Internal server error. Please try again.","errors.system.INVALID_CONFIGURATION":"System configuration error","errors.system.TOO_MANY_REQUESTS":"Too many requests. Please wait a moment and try again","errors.system.UNKNOWN_OPERATION":"Unrecognized operation","errors.users_module_not_configured":"Users module not configured","footer.copyright":"Nocios S.R.L. All Rights Reserved.","footer.version":"Version","forgotPassword.checkEmailInstructions":"Check your inbox for the verification code","forgotPassword.codeAlreadyExistsMessage":"A code was already sent and is still valid","forgotPassword.emailLabel":"Email Address","forgotPassword.emailPlaceholder":"Enter your email address","forgotPassword.emailRequired":"Email address is required","forgotPassword.emailSentMessage":"Code sent successfully","forgotPassword.enterCodeLink":"Enter Code","forgotPassword.instructions":"Enter your email address and we'll send you a code to reset your password.","forgotPassword.invalidEmail":"Enter a valid email address","forgotPassword.sendCodeButton":"Send Code","forgotPassword.title":"Reset Password","loading.app.configInitial":"Loading initial configuration...","loading.app.generic":"Loading...","loading.app.starting":"Starting application...","loading.app.themeSetup":"Generating theme...","loading.app.validatingSession":"Validating session...","login.alreadyHaveCodeLink":"Already have a code?","login.forgotPasswordLink":"Forgot Password?","login.initializationError":"Initialization error","login.initializing":"Initializing...","login.loginButton":"Log In","login.logoAlt":"Logo","login.noAccountPrompt":"Don't have an account?","login.notInitialized":"System not initialized","login.passwordLabel":"Password","login.passwordPlaceholder":"Enter your password","login.passwordRequired":"Password is required","login.signUpLink":"Sign up","login.usernameOrEmailLabel":"Username or Email","login.usernameOrEmailPlaceholder":"Enter your username or email","login.usernameRequired":"Username or email is required","resetPassword.codeExpiredOrInvalid":"Code expired or invalid","resetPassword.confirmPasswordLabel":"Confirm Password","resetPassword.confirmPasswordPlaceholder":"Confirm your new password","resetPassword.confirmPasswordRequired":"Confirm your password","resetPassword.goToLoginButton":"Go to Login","resetPassword.instructions":"Enter your new password.","resetPassword.invalidCode":"The verification code is invalid. Please check the link or request a new one.","resetPassword.missingParameters":"Missing required parameters","resetPassword.newPasswordLabel":"New Password","resetPassword.newPasswordPlaceholder":"Enter your new password","resetPassword.newPasswordRequired":"New password is required","resetPassword.passwordTooShort":"Password must be at least 8 characters","resetPassword.passwordsDoNotMatch":"Passwords do not match","resetPassword.requestNewCodeButton":"Request New Code","resetPassword.resetPasswordButton":"Reset Password","resetPassword.successInstructions":"You can now log in with your new password","resetPassword.successMessage":"Password reset successfully","resetPassword.title":"New Password","resetPassword.validatingCode":"Validating code..."}},mr= exports.getCriticalLanguages =()=>Object.keys(p),hr= exports.getCriticalTranslations =i=>p[i]||p.es;var re="crudify_translations_",yr=3600*1e3,U= exports.TranslationService =class i{constructor(){this.enableDebug=!1;this.initializationPromise=null;this.isInitialized=!1}static getInstance(){return i.instance||(i.instance=new i),i.instance}setDebug(e){this.enableDebug=e}async ensureCrudifyInitialized(e,r){if(!this.isInitialized)return this.initializationPromise?(this.enableDebug&&console.log("[TranslationService] Waiting for crudify initialization..."),this.initializationPromise):(this.enableDebug&&console.log("[TranslationService] Initializing crudify SDK..."),this.initializationPromise=(async()=>{try{let t=_crudifybrowser2.default.getTokenData();if(t&&t.endpoint){this.enableDebug&&console.log("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}_crudifybrowser2.default.config(r);let o=await _crudifybrowser2.default.init(e,this.enableDebug?"debug":"none");if(o.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(o.errors||"Unknown error")}`);if(!o.data&&o.success!==!0)throw new Error(`Failed to initialize crudify: ${JSON.stringify(o.errors||"Unknown error")}`);this.isInitialized=!0,this.enableDebug&&console.log("[TranslationService] Crudify SDK initialized successfully")}catch(t){throw console.error("[TranslationService] Failed to initialize crudify:",t),this.initializationPromise=null,t}})(),this.initializationPromise)}async fetchTranslations(e){let{subscriberKey:r,apiKey:t,sections:o,crudifyEnv:n="stg",urlTranslations:s}=e,a=this.getFromCache(r),l=a?this.isCacheExpired(a):!0;if(a&&!l)return this.enableDebug&&console.log("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(a.data.translations,s);try{await this.ensureCrudifyInitialized(t,n)}catch(u){return console.error("[TranslationService] Failed to initialize crudify:",u),a?(console.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(a.data.translations,s)):(console.warn("[TranslationService] Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&console.log("[TranslationService] Fetching from API via crudify SDK...");let u=await this.fetchFromAPI(o);return this.hasDataChanged(a,u)||!a?(this.enableDebug&&console.log("[TranslationService] Data changed, updating cache"),this.saveToCache(r,u)):(this.enableDebug&&console.log("[TranslationService] Data unchanged, refreshing cache timestamp"),this.refreshCacheTimestamp(r)),this.mergeWithUrlTranslations(u.translations,s)}catch(u){return console.error("[TranslationService] API fetch failed:",u),a?(console.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(a.data.translations,s)):(console.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(e){let r=await _crudifybrowser2.default.getTranslation(e);if(!r.success)throw new Error(`Crudify API error: ${r.errors?JSON.stringify(r.errors):"Unknown error"}`);if(!r.data)throw new Error("No translation data in response");return r.data}mergeWithUrlTranslations(e,r){if(!r||Object.keys(r).length===0)return e;let t={};return Object.keys(e).forEach(o=>{t[o]={...e[o],...r}}),t}hasDataChanged(e,r){if(!e||e.data.timestamp!==r.timestamp)return!0;let t=this.hashData(r.translations);return e.dataHash!==t}hashData(e){let r=JSON.stringify(e),t=0;for(let o=0;o<r.length;o++){let n=r.charCodeAt(o);t=(t<<5)-t+n,t=t&t}return t.toString(36)}saveToCache(e,r){try{let t=this.getCacheKey(e),o={data:r,cachedAt:Date.now(),dataHash:this.hashData(r.translations)};localStorage.setItem(t,JSON.stringify(o)),this.enableDebug&&console.log("[TranslationService] Saved to cache:",t)}catch(t){console.error("[TranslationService] Failed to save cache:",t)}}getFromCache(e){try{let r=this.getCacheKey(e),t=localStorage.getItem(r);return t?JSON.parse(t):null}catch(r){return console.error("[TranslationService] Failed to read cache:",r),null}}refreshCacheTimestamp(e){try{let r=this.getFromCache(e);if(r){r.cachedAt=Date.now();let t=this.getCacheKey(e);localStorage.setItem(t,JSON.stringify(r))}}catch(r){console.error("[TranslationService] Failed to refresh cache timestamp:",r)}}isCacheExpired(e){return Date.now()-e.cachedAt>yr}getCacheKey(e){return`${re}${e}`}getCriticalTranslationsOnly(){return p}invalidateCache(e){let r=this.getCacheKey(e);localStorage.removeItem(r),this.enableDebug&&console.log("[TranslationService] Cache invalidated:",r)}async prefetchTranslations(e){try{await this.fetchTranslations(e),this.enableDebug&&console.log("[TranslationService] Prefetch completed")}catch(r){console.error("[TranslationService] Prefetch failed:",r)}}clearAllCaches(){try{let r=Object.keys(localStorage).filter(t=>t.startsWith(re));r.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&console.log(`[TranslationService] Cleared ${r.length} cache entries`)}catch(e){console.error("[TranslationService] Failed to clear caches:",e)}}},D= exports.translationService =U.getInstance();var oe=_react.createContext.call(void 0, null);function ie(i,e,r){return{...i,...e,...r||{}}}var vr=({children:i,subscriberKey:e,apiKey:r,crudifyEnv:t="stg",sections:o,language:n="es",devTranslations:s,translationUrl:a,enableDebug:l=!1,skipAutoInit:u=!0})=>{let[f,P]=_react.useState.call(void 0, {}),[T,b]=_react.useState.call(void 0, !0),[V,R]=_react.useState.call(void 0, null),[A,B]=_react.useState.call(void 0, void 0),[G,se]=_react.useState.call(void 0, !1),N=_react.useCallback.call(void 0, async()=>{if(G){l&&console.log("[TranslationsProvider] Skipping reload - using fallback translations");return}b(!0),R(null);let c;if(a)try{l&&console.log(`[TranslationsProvider] Fetching translations from URL: ${a}`);let g=await fetch(a);if(!g.ok)throw new Error(`Failed to fetch translations: ${g.statusText}`);c=await g.json(),B(c),l&&console.log("[TranslationsProvider] URL translations loaded:",{keysCount:c?Object.keys(c).length:0})}catch(g){console.error("[TranslationsProvider] Failed to load URL translations:",g),c=void 0,B(void 0)}try{D.setDebug(l);let g=await D.fetchTranslations({subscriberKey:e,apiKey:r,crudifyEnv:t,sections:o,urlTranslations:c}),h={};Object.keys(g).forEach(d=>{let C=p[d]||{},y=g[d]||{};h[d]=ie(C,y,s)}),P(h),l&&console.log("[TranslationsProvider] Loaded translations:",{languages:Object.keys(h),keysCount:Object.keys(h[n]||{}).length})}catch(g){console.error("[TranslationsProvider] Failed to load:",g),R(g.message),se(!0);let h={};Object.keys(p).forEach(d=>{let C=p[d],y=c||A||{};h[d]=ie(C,y,s)}),P(h),l&&console.log("[TranslationsProvider] Using fallback translations (critical + URL)")}finally{b(!1)}},[e,r,t,o,a,s,l,n,G]);_react.useEffect.call(void 0, ()=>{N();let c=setInterval(N,3600*1e3);return()=>clearInterval(c)},[N]);let ae={t:_react.useMemo.call(void 0, ()=>(c,g)=>{let d=(f[n]||{})[c];if(!d){let C=Object.keys(f);for(let y of C)if(f[y][c]){d=f[y][c];break}}return d||(l&&console.warn(`[TranslationsProvider] Missing translation: "${c}"`),d=c),g&&typeof d=="string"&&Object.entries(g).forEach(([C,y])=>{let le=new RegExp(`{{${C}}}`,"g");d=d.replace(le,String(y))}),d},[f,n,l]),language:n,availableLanguages:Object.keys(f),translations:f,isLoading:T,error:V,refreshTranslations:N};if(T){let c=_optionalChain([p, 'access', _7 => _7[n], 'optionalAccess', _8 => _8.loading])||"Loading...";return _jsxruntime.jsx.call(void 0, "div",{children:c})}return _jsxruntime.jsx.call(void 0, oe.Provider,{value:ae,children:i})},Er= exports.useTranslations =()=>{let i=_react.useContext.call(void 0, oe);if(!i)throw new Error("useTranslations must be used within TranslationsProvider");return i};var _crudifyadmin = require('@nocios/crudify-admin'); var _crudifyadmin2 = _interopRequireDefault(_crudifyadmin);var ne=!1,S=null;async function wr(){let e=_chunkDBU3TOSAjs.e.getInstance().getTokenInfo(),r=_optionalChain([e, 'optionalAccess', _9 => _9.apiEndpointAdmin]),t=_optionalChain([e, 'optionalAccess', _10 => _10.apiKeyEndpointAdmin]);return r&&t?{apiUrl:r,apiKey:t}:_chunkDBU3TOSAjs.a.waitForCredentials()}async function Sr(){if(!ne)return S||(S=(async()=>{try{let i=_chunkDBU3TOSAjs.e.getInstance(),{apiUrl:e,apiKey:r}=await wr();_crudifyadmin2.default.init({url:e,apiKey:r,getAdditionalHeaders:()=>{let t=i.getTokenInfo();return _optionalChain([t, 'optionalAccess', _11 => _11.crudifyTokens, 'optionalAccess', _12 => _12.accessToken])?{Authorization:`Bearer ${t.crudifyTokens.accessToken}`}:{}}}),ne=!0}catch(i){throw S=null,console.error("[crudifyAdminWrapper] Initialization failed:",i),i}})(),S)}async function I(i){try{await Sr();let e=await i();return!e.success&&_optionalChain([e, 'access', _13 => _13.errors, 'optionalAccess', _14 => _14.includes, 'call', _15 => _15("401")])?await _chunkDBU3TOSAjs.e.getInstance().refreshTokens()?await i():(console.error("[crudifyAdmin] Token refresh failed"),typeof window<"u"&&(window.location.href="/login"),e):e}catch(e){return console.error("[crudifyAdmin] Operation error:",e),{success:!1,errors:e instanceof Error?e.message:"Unknown error"}}}var br={listModules:()=>I(()=>_crudifyadmin2.default.listModules()),getModule:i=>I(()=>_crudifyadmin2.default.getModule(i)),createModule:i=>I(()=>_crudifyadmin2.default.createModule(i)),editModule:(i,e)=>I(()=>_crudifyadmin2.default.editModule(i,e)),deleteModule:i=>I(()=>_crudifyadmin2.default.deleteModule(i)),activateModule:i=>I(()=>_crudifyadmin2.default.activateModule(i)),deactivateModule:i=>I(()=>_crudifyadmin2.default.deactivateModule(i)),getModuleVersions:i=>I(()=>_crudifyadmin2.default.getModuleVersions(i))};exports.AuthRoute = j; exports.CRITICAL_TRANSLATIONS = p; exports.CrudifyInitializationManager = z; exports.CrudifyInitializer = gr; exports.CrudifyLogin = _chunk4VW4J2U2js.a; exports.CrudifyProvider = _chunkDBU3TOSAjs.b; exports.CrudifyThemeProvider = Je; exports.ERROR_CODES = _chunkYIIUEOXCjs.a; exports.ERROR_SEVERITY_MAP = _chunkYIIUEOXCjs.b; exports.GlobalNotificationProvider = _chunkDBU3TOSAjs.g; exports.LoginComponent = _chunk4VW4J2U2js.f; exports.POLICY_ACTIONS = _chunk4VW4J2U2js.c; exports.PREFERRED_POLICY_ORDER = _chunk4VW4J2U2js.d; exports.Policies = _chunk4VW4J2U2js.e; exports.ProtectedRoute = Z; exports.SessionDebugInfo = _chunkDBU3TOSAjs.k; exports.SessionLoadingScreen = F; exports.SessionManager = _chunkDBU3TOSAjs.e; exports.SessionProvider = _chunkDBU3TOSAjs.i; exports.SessionStatus = _chunk4VW4J2U2js.g; exports.TokenStorage = _chunkDBU3TOSAjs.d; exports.TranslationService = U; exports.TranslationsProvider = vr; exports.UserProfileDisplay = _chunk4VW4J2U2js.b; exports.createErrorTranslator = _chunkAT74WV5Wjs.e; exports.crudify = _crudifybrowser2.default; exports.crudifyAdmin = br; exports.crudifyInitManager = _; exports.decodeJwtSafely = _chunkAT74WV5Wjs.h; exports.extractSafeRedirectFromUrl = H; exports.getCookie = _chunkAT74WV5Wjs.a; exports.getCriticalLanguages = mr; exports.getCriticalTranslations = hr; exports.getCurrentUserEmail = _chunkAT74WV5Wjs.i; exports.getErrorMessage = _chunkYIIUEOXCjs.e; exports.handleCrudifyError = _chunkYIIUEOXCjs.g; exports.isTokenExpired = _chunkAT74WV5Wjs.j; exports.parseApiError = _chunkYIIUEOXCjs.c; exports.parseJavaScriptError = _chunkYIIUEOXCjs.f; exports.parseTransactionError = _chunkYIIUEOXCjs.d; exports.secureLocalStorage = _chunkNNY4A73Vjs.b; exports.secureSessionStorage = _chunkNNY4A73Vjs.a; exports.translateError = _chunkAT74WV5Wjs.d; exports.translateErrorCode = _chunkAT74WV5Wjs.b; exports.translateErrorCodes = _chunkAT74WV5Wjs.c; exports.translationService = D; exports.useAuth = _chunkWZEPLZEJjs.b; exports.useCrudify = _chunkDBU3TOSAjs.c; exports.useCrudifyInitializer = fr; exports.useCrudifyWithNotifications = _chunkWZEPLZEJjs.d; exports.useData = _chunkWZEPLZEJjs.c; exports.useGlobalNotification = _chunkDBU3TOSAjs.h; exports.useSession = _chunkDBU3TOSAjs.f; exports.useSessionContext = _chunkDBU3TOSAjs.j; exports.useTranslations = Er; exports.useUserData = _chunkWZEPLZEJjs.a; exports.useUserProfile = _chunkDBU3TOSAjs.l; exports.validateInternalRedirect = O;
6
+ `});function F({stage:i="loading",message:e}){let o=e||{initializing:"Initializing application...","validating-session":"Validating session...",loading:"Loading..."}[i];return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, er,{}),_jsxruntime.jsxs.call(void 0, "div",{style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",height:"100vh",width:"100vw",backgroundColor:"#f0f2f5",fontFamily:'"Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',color:"#333",textAlign:"center",boxSizing:"border-box",padding:"20px",background:"#fff"},children:[_jsxruntime.jsx.call(void 0, "div",{style:Xe}),_jsxruntime.jsx.call(void 0, "p",{style:{fontSize:"1.25em",fontWeight:"500",marginTop:"24px",color:"#1f2937"},children:o})]})]})}var ir=/^[a-zA-Z0-9\-_./\?=&%#]+$/,or=[/^https?:\/\//i,/^ftp:\/\//i,/^\/\//,/javascript:/i,/data:/i,/vbscript:/i,/about:/i,/\.\.\//,/\.\.\\/,/%2e%2e%2f/i,/%2e%2e%5c/i,/%2f%2f/i,/%5c%5c/i,/[\x00-\x1f\x7f-\x9f]/,/\\/],O= exports.validateInternalRedirect =(i,e="/")=>{if(!i||typeof i!="string")return e;let r=i.trim();if(!r)return e;if(!r.startsWith("/"))return console.warn("\u{1F6A8} Open redirect blocked (relative path):",i),e;if(!ir.test(r))return console.warn("\u{1F6A8} Open redirect blocked (invalid characters):",i),e;let o=r.toLowerCase();for(let s of or)if(s.test(o))return console.warn("\u{1F6A8} Open redirect blocked (dangerous pattern):",i),e;let t=r.split("?")[0].split("/").filter(Boolean);if(t.length===0)return r;for(let s of t)if(s===".."||s.includes(":")||s.length>100)return console.warn("\u{1F6A8} Open redirect blocked (suspicious path part):",s),e;return r},H= exports.extractSafeRedirectFromUrl =(i,e="/")=>{try{let o=(typeof i=="string"?new URLSearchParams(i):i).get("redirect");if(!o)return e;let t=decodeURIComponent(o);return O(t,e)}catch(r){return console.warn("\u{1F6A8} Error parsing redirect parameter:",r),e}};function Z({children:i,loadingComponent:e,loginPath:r="/login"}){let{isAuthenticated:o,isLoading:t,isInitialized:s,tokens:n,error:a}=_chunkMTP6BSGZjs.j.call(void 0, ),l=_reactrouterdom.useLocation.call(void 0, );if(!s||t)return _jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e||_jsxruntime.jsx.call(void 0, F,{stage:"validating-session"})});let u=o&&_optionalChain([n, 'optionalAccess', _2 => _2.accessToken])&&n.accessToken.length>0;if(a||!o||!u){n&&(!n.accessToken||n.accessToken.length===0)&&localStorage.removeItem("crudify_tokens");let f=l.pathname+l.search,P=O(f),T=encodeURIComponent(P);return _jsxruntime.jsx.call(void 0, _reactrouterdom.Navigate,{to:`${r}?redirect=${T}`,replace:!0})}return _jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:i})}function j({children:i,redirectTo:e="/"}){let{isAuthenticated:r}=_chunkMTP6BSGZjs.j.call(void 0, ),o=_reactrouterdom.useLocation.call(void 0, );if(r){let t=new URLSearchParams(o.search),s=H(t,e);return _jsxruntime.jsx.call(void 0, _reactrouterdom.Navigate,{to:s,replace:!0})}return _jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:i})}var x=class i{constructor(){this.state={status:"UNINITIALIZED",priority:null,publicApiKey:null,env:null,error:null,initializedBy:null};this.initializationPromise=null;this.highPriorityInitializerPresent=!1;this.waitingForHighPriority=new Set;this.HIGH_PRIORITY_WAIT_TIMEOUT=100}static getInstance(){return i.instance||(i.instance=new i),i.instance}registerHighPriorityInitializer(){this.highPriorityInitializerPresent=!0}isHighPriorityInitializerPresent(){return this.highPriorityInitializerPresent}getState(){return{...this.state}}async initialize(e){let{priority:r,publicApiKey:o,env:t,enableLogging:s,requestedBy:n}=e;if(this.state.status==="INITIALIZED"){this.state.publicApiKey!==o&&console.warn(`[CrudifyInitialization] ${n} attempted to initialize with different key. Already initialized with key: ${_optionalChain([this, 'access', _3 => _3.state, 'access', _4 => _4.publicApiKey, 'optionalAccess', _5 => _5.slice, 'call', _6 => _6(0,10)])}... by ${this.state.initializedBy}`);return}if(this.initializationPromise)return s&&console.log(`[CrudifyInitialization] ${n} waiting for ongoing initialization...`),this.initializationPromise;if(r==="LOW"&&this.highPriorityInitializerPresent&&this.state.status==="UNINITIALIZED"){if(s&&console.log(`[CrudifyInitialization] ${n} (LOW priority) waiting for HIGH priority initializer...`),this.waitingForHighPriority.add(n),await this.waitForHighPriorityOrTimeout(s),this.waitingForHighPriority.delete(n),this.getState().status==="INITIALIZED"){s&&console.log(`[CrudifyInitialization] ${n} found initialization completed by HIGH priority`);return}s&&console.warn(`[CrudifyInitialization] ${n} timeout waiting for HIGH priority, initializing with LOW priority`)}r==="HIGH"&&this.state.status==="INITIALIZING"&&this.state.priority==="LOW"&&(console.warn(`[CrudifyInitialization] HIGH priority request from ${n} interrupting LOW priority initialization by ${this.state.initializedBy}`),this.state.status="UNINITIALIZED",this.initializationPromise=null),s&&console.log(`[CrudifyInitialization] ${n} starting initialization (${r} priority)...`),this.state.status="INITIALIZING",this.state.priority=r,this.state.initializedBy=n,this.initializationPromise=this.performInitialization(o,t,s);try{await this.initializationPromise,this.state.status="INITIALIZED",this.state.publicApiKey=o,this.state.env=t,this.state.error=null,s&&console.log(`[CrudifyInitialization] \u2705 Successfully initialized by ${n} (${r} priority)`)}catch(a){throw this.state.status="ERROR",this.state.error=a instanceof Error?a:new Error(String(a)),this.initializationPromise=null,console.error(`[CrudifyInitialization] \u274C Initialization failed for ${n}:`,a),a}}async waitForHighPriorityOrTimeout(e){return new Promise(r=>{let t=0,s=setInterval(()=>{if(t+=10,this.state.status==="INITIALIZED"&&this.state.priority==="HIGH"){clearInterval(s),r();return}if(this.state.status==="INITIALIZING"&&this.state.priority==="HIGH"){t=0;return}t>=this.HIGH_PRIORITY_WAIT_TIMEOUT&&(clearInterval(s),e&&console.log(`[CrudifyInitialization] Timeout waiting for HIGH priority (${this.HIGH_PRIORITY_WAIT_TIMEOUT}ms)`),r())},10)})}async performInitialization(e,r,o){let t=_crudifybrowser2.default.getTokenData();if(t&&t.endpoint){o&&console.log("[CrudifyInitialization] SDK already initialized externally");return}_crudifybrowser2.default.config(r);let s=o?"debug":"none";console.log("[CrudifyInitialization] \u{1F50D} BEFORE crudify.init() call");let n=await _crudifybrowser2.default.init(e,s);if(console.log("[CrudifyInitialization] \u{1F50D} AFTER crudify.init() call"),console.log("[CrudifyInitialization] \u{1F50D} Response type:",typeof n),console.log("[CrudifyInitialization] \u{1F50D} Response value:",n),console.log("[CrudifyInitialization] \u{1F50D} Response.success:",_optionalChain([n, 'optionalAccess', _7 => _7.success])),console.log("[CrudifyInitialization] \u{1F50D} Response.data:",_optionalChain([n, 'optionalAccess', _8 => _8.data])),console.log("[CrudifyInitialization] \u{1F50D} Response.errors:",_optionalChain([n, 'optionalAccess', _9 => _9.errors])),n.success===!1)throw console.log("[CrudifyInitialization] \u274C Detected explicit failure (response.success === false)"),new Error(`Crudify initialization failed: ${JSON.stringify(n.errors||"Unknown error")}`);if(!n.data&&n.success!==!0)throw console.log("[CrudifyInitialization] \u274C Detected failure (!response.data && response.success !== true)"),console.log("[CrudifyInitialization] \u{1F50D} !response.data:",!n.data),console.log("[CrudifyInitialization] \u{1F50D} response.success !== true:",n.success!==!0),new Error(`Crudify initialization failed: ${JSON.stringify(n.errors||"Unknown error")}`);console.log("[CrudifyInitialization] \u2705 No explicit failure detected")}reset(){this.state={status:"UNINITIALIZED",priority:null,publicApiKey:null,env:null,error:null,initializedBy:null},this.initializationPromise=null,this.highPriorityInitializerPresent=!1,this.waitingForHighPriority.clear()}isInitialized(){return this.state.status==="INITIALIZED"}getDiagnostics(){return{...this.state,waitingCount:this.waitingForHighPriority.size,waitingComponents:Array.from(this.waitingForHighPriority),hasActivePromise:this.initializationPromise!==null}}},_= exports.crudifyInitManager =x.getInstance();var ee=_react.createContext.call(void 0, void 0),gr= exports.CrudifyInitializer =({config:i,children:e,fallback:r=null,onInitialized:o,onError:t})=>{let[s,n]=_react.useState.call(void 0, !1),[a,l]=_react.useState.call(void 0, !1),[u,f]=_react.useState.call(void 0, null),P=_react.useRef.call(void 0, !1),T=_react.useRef.call(void 0, !1);_react.useEffect.call(void 0, ()=>{P.current||(_.registerHighPriorityInitializer(),P.current=!0),T.current||(T.current=!0,(async()=>{l(!0),f(null);try{await _.initialize({priority:"HIGH",publicApiKey:i.publicApiKey,env:i.env||"stg",enableLogging:i.enableLogging,requestedBy:"CrudifyInitializer"}),n(!0),l(!1),o&&o()}catch(v){let A=v instanceof Error?v:new Error(String(v));f(A),l(!1),t&&t(A)}})())},[i.publicApiKey,i.env,i.enableLogging,o,t]);let b={isInitialized:s,isInitializing:a,error:u};return a&&r?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:r}):(u&&console.error("[CrudifyInitializer] Initialization failed:",u),_jsxruntime.jsx.call(void 0, ee.Provider,{value:b,children:e}))},fr= exports.useCrudifyInitializer =()=>{let i=_react.useContext.call(void 0, ee);if(!i)throw new Error("useCrudifyInitializer must be used within CrudifyInitializer");return i};var p={es:{"checkCode.codeLabel":"C\xF3digo de Verificaci\xF3n","checkCode.codePlaceholder":"Ingresa el c\xF3digo de 6 d\xEDgitos","checkCode.codeRequired":"El c\xF3digo es obligatorio","checkCode.emailLabel":"Correo Electr\xF3nico","checkCode.emailPlaceholder":"Ingresa tu correo electr\xF3nico","checkCode.emailRequired":"El correo electr\xF3nico es obligatorio","checkCode.instructions":"Ingresa el c\xF3digo de 6 d\xEDgitos que enviamos a tu correo electr\xF3nico.","checkCode.invalidEmail":"Ingresa un correo electr\xF3nico v\xE1lido","checkCode.resendCodeLink":"Reenviar c\xF3digo","checkCode.title":"Verificar C\xF3digo","checkCode.verifyButton":"Verificar C\xF3digo","common.back":"Volver","common.backToLogin":"Volver","error.app.config":"Error de Configuraci\xF3n: {{message}}","error.app.initialization":"Error durante la inicializaci\xF3n final de la aplicaci\xF3n.","error.transaction":"Error en la operaci\xF3n","error.unknown":"Ocurri\xF3 un error desconocido.","errors.DUPLICATE":"El campo <b>{{field}}</b> debe ser \xFAnico.","errors.FOREIGN_KEY_NOT_FOUND":"El campo <b>{{field}}</b> debe referenciar un \xEDtem existente.","errors.INVALID_EMAIL":"El campo <b>{{field}}</b> debe ser un correo electr\xF3nico v\xE1lido.","errors.INVALID_OBJECT_ID":"El campo <b>{{field}}</b> debe ser un valor v\xE1lido.","errors.IN_USE":"El \xEDtem est\xE1 en uso y no puede ser eliminado.","errors.MAX_LENGTH":"El campo <b>{{field}}</b> no debe exceder los <b>{{length}}</b> caracteres.","errors.MIN_LENGTH":"El campo <b>{{field}}</b> debe tener al menos <b>{{length}}</b> caracteres.","errors.MUST_NOT_BE_EMAIL":"El campo <b>{{field}}</b> no debe ser un correo electr\xF3nico.","errors.NO_PERMISSION":"No tienes permiso para realizar esta acci\xF3n.","errors.NO_SPACES":"El campo <b>{{field}}</b> no debe contener espacios.","errors.ONE_OR_MORE_OPERATIONS_FAILED":"Error en la operaci\xF3n","errors.REQUIRED":"El campo <b>{{field}}</b> es obligatorio.","errors.TOKEN_HAS_EXPIRED":"La sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.","errors.TOO_MANY_REQUESTS":"L\xEDmite de solicitudes alcanzado. Por favor intenta m\xE1s tarde.","errors.UNAUTHORIZED":"No est\xE1s autorizado para realizar esta acci\xF3n.","errors.all_password_fields_required":"Todos los campos de contrase\xF1a son obligatorios","errors.auth.INVALID_API_KEY":"Clave de API inv\xE1lida","errors.auth.INVALID_CREDENTIALS":"Usuario y/o contrase\xF1a incorrectos","errors.auth.NO_PERMISSION":"No tienes permisos suficientes","errors.auth.SESSION_EXPIRED":"Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.","errors.auth.TOO_MANY_REQUESTS":"Demasiados intentos. Por favor espera 15 minutos e intenta nuevamente","errors.auth.UNAUTHORIZED":"No tienes permisos para realizar esta acci\xF3n","errors.auth.USER_NOT_ACTIVE":"Usuario no activo","errors.auth.USER_NOT_FOUND":"Usuario no encontrado","errors.data.BAD_REQUEST":"Solicitud inv\xE1lida","errors.data.FIELD_ERROR":"Error en los datos ingresados","errors.data.IN_USE":"El elemento est\xE1 en uso y no puede ser eliminado","errors.data.ITEM_NOT_FOUND":"El elemento solicitado no fue encontrado","errors.data.NOT_FOUND":"No se encontr\xF3 lo solicitado","errors.internal_error_changing_password":"Error interno al cambiar la contrase\xF1a. Intenta nuevamente","errors.password_min_length":"La contrase\xF1a debe tener al menos 8 caracteres","errors.password_mismatch":"Las contrase\xF1as no coinciden","errors.password_must_be_different":"La nueva contrase\xF1a debe ser diferente a la actual","errors.system.DATABASE_CONNECTION_ERROR":"Error de conexi\xF3n. Verifica tu conexi\xF3n a internet.","errors.system.INTERNAL_SERVER_ERROR":"Error interno del servidor. Intenta nuevamente.","errors.system.INVALID_CONFIGURATION":"Error de configuraci\xF3n del sistema","errors.system.TOO_MANY_REQUESTS":"Demasiadas solicitudes. Por favor espera un momento e intenta nuevamente","errors.system.UNKNOWN_OPERATION":"Operaci\xF3n no reconocida","errors.users_module_not_configured":"M\xF3dulo de usuarios no configurado","footer.copyright":"Nocios S.R.L. Todos los derechos reservados.","footer.version":"Versi\xF3n","forgotPassword.checkEmailInstructions":"Revisa tu bandeja de entrada para el c\xF3digo de verificaci\xF3n","forgotPassword.codeAlreadyExistsMessage":"Ya se envi\xF3 un c\xF3digo y a\xFAn es v\xE1lido","forgotPassword.emailLabel":"Correo Electr\xF3nico","forgotPassword.emailPlaceholder":"Ingresa tu correo electr\xF3nico","forgotPassword.emailRequired":"El correo electr\xF3nico es obligatorio","forgotPassword.emailSentMessage":"C\xF3digo enviado exitosamente","forgotPassword.enterCodeLink":"Ingresar C\xF3digo","forgotPassword.instructions":"Ingresa tu correo electr\xF3nico y te enviaremos un c\xF3digo para restablecer tu contrase\xF1a.","forgotPassword.invalidEmail":"Ingresa un correo electr\xF3nico v\xE1lido","forgotPassword.sendCodeButton":"Enviar C\xF3digo","forgotPassword.title":"Recuperar Contrase\xF1a","loading.app.configInitial":"Cargando configuraci\xF3n inicial...","loading.app.generic":"Cargando...","loading.app.starting":"Iniciando aplicaci\xF3n...","loading.app.themeSetup":"Generando tema...","loading.app.validatingSession":"Validando sesi\xF3n...","login.alreadyHaveCodeLink":"\xBFYa tienes un c\xF3digo?","login.forgotPasswordLink":"\xBFOlvidaste tu contrase\xF1a?","login.initializationError":"Error de inicializaci\xF3n","login.initializing":"Inicializando...","login.loginButton":"Iniciar Sesi\xF3n","login.logoAlt":"Logotipo","login.noAccountPrompt":"\xBFNo tienes una cuenta?","login.notInitialized":"Sistema no inicializado","login.passwordLabel":"Contrase\xF1a","login.passwordPlaceholder":"Ingresa tu contrase\xF1a","login.passwordRequired":"Contrase\xF1a es obligatoria","login.signUpLink":"Reg\xEDstrate","login.usernameOrEmailLabel":"Usuario o Correo Electr\xF3nico","login.usernameOrEmailPlaceholder":"Ingresa tu usuario o correo electr\xF3nico","login.usernameRequired":"Usuario o correo electr\xF3nico es obligatorio","resetPassword.codeExpiredOrInvalid":"El c\xF3digo ha expirado o es inv\xE1lido","resetPassword.confirmPasswordLabel":"Confirmar Contrase\xF1a","resetPassword.confirmPasswordPlaceholder":"Confirma tu nueva contrase\xF1a","resetPassword.confirmPasswordRequired":"Confirma tu contrase\xF1a","resetPassword.goToLoginButton":"Ir al Login","resetPassword.instructions":"Ingresa tu nueva contrase\xF1a.","resetPassword.invalidCode":"El c\xF3digo de verificaci\xF3n es inv\xE1lido. Por favor, verifica el enlace o solicita uno nuevo.","resetPassword.missingParameters":"Faltan par\xE1metros obligatorios","resetPassword.newPasswordLabel":"Nueva Contrase\xF1a","resetPassword.newPasswordPlaceholder":"Ingresa tu nueva contrase\xF1a","resetPassword.newPasswordRequired":"La nueva contrase\xF1a es obligatoria","resetPassword.passwordTooShort":"La contrase\xF1a debe tener al menos 8 caracteres","resetPassword.passwordsDoNotMatch":"Las contrase\xF1as no coinciden","resetPassword.requestNewCodeButton":"Solicitar Nuevo C\xF3digo","resetPassword.resetPasswordButton":"Restablecer Contrase\xF1a","resetPassword.successInstructions":"Ahora puedes iniciar sesi\xF3n con tu nueva contrase\xF1a","resetPassword.successMessage":"Contrase\xF1a restablecida exitosamente","resetPassword.title":"Nueva Contrase\xF1a","resetPassword.validatingCode":"Validando c\xF3digo..."},en:{"checkCode.codeLabel":"Verification Code","checkCode.codePlaceholder":"Enter 6-digit code","checkCode.codeRequired":"Code is required","checkCode.emailLabel":"Email Address","checkCode.emailPlaceholder":"Enter your email address","checkCode.emailRequired":"Email address is required","checkCode.instructions":"Enter the 6-digit code we sent to your email address.","checkCode.invalidEmail":"Enter a valid email address","checkCode.resendCodeLink":"Resend code","checkCode.title":"Verify Code","checkCode.verifyButton":"Verify Code","common.back":"Back","common.backToLogin":"Back to Login","error.app.config":"Configuration Error: {{message}}","error.app.initialization":"Error during final application initialization.","error.transaction":"Operation error","error.unknown":"An unknown error occurred.","errors.DUPLICATE":"The field <b>{{field}}</b> must be unique.","errors.FOREIGN_KEY_NOT_FOUND":"The field <b>{{field}}</b> must reference an existing item.","errors.INVALID_EMAIL":"The field <b>{{field}}</b> must be a valid email address.","errors.INVALID_OBJECT_ID":"The field <b>{{field}}</b> must be a valid value.","errors.IN_USE":"The item is currently in use and cannot be deleted.","errors.MAX_LENGTH":"The field <b>{{field}}</b> must not exceed <b>{{maxLength}}</b> characters.","errors.MIN_LENGTH":"The field <b>{{field}}</b> must have at least <b>{{minLength}}</b> characters.","errors.MUST_NOT_BE_EMAIL":"The field <b>{{field}}</b> must not be an email address.","errors.NO_PERMISSION":"You do not have permission to perform this action.","errors.NO_SPACES":"The field <b>{{field}}</b> must not contain spaces.","errors.ONE_OR_MORE_OPERATIONS_FAILED":"Operation error","errors.REQUIRED":"The field <b>{{field}}</b> is required.","errors.TOKEN_HAS_EXPIRED":"Your session has expired, please log in again.","errors.TOO_MANY_REQUESTS":"Request limit reached. Please try again later.","errors.UNAUTHORIZED":"You are not authorized to perform this action.","errors.all_password_fields_required":"All password fields are required","errors.auth.INVALID_API_KEY":"Invalid API key","errors.auth.INVALID_CREDENTIALS":"Incorrect username and/or password","errors.auth.NO_PERMISSION":"Insufficient permissions","errors.auth.SESSION_EXPIRED":"Your session has expired. Please log in again.","errors.auth.TOO_MANY_REQUESTS":"Too many attempts. Please wait 15 minutes and try again","errors.auth.UNAUTHORIZED":"You don't have permission to perform this action","errors.auth.USER_NOT_ACTIVE":"User account is not active","errors.auth.USER_NOT_FOUND":"User not found","errors.data.BAD_REQUEST":"Invalid request","errors.data.FIELD_ERROR":"Error in the provided data","errors.data.IN_USE":"The item is in use and cannot be deleted","errors.data.ITEM_NOT_FOUND":"The requested item was not found","errors.data.NOT_FOUND":"The requested resource was not found","errors.internal_error_changing_password":"Internal error changing password. Please try again","errors.password_min_length":"Password must be at least 8 characters","errors.password_mismatch":"Passwords do not match","errors.password_must_be_different":"New password must be different from current password","errors.system.DATABASE_CONNECTION_ERROR":"Connection error. Please check your internet connection.","errors.system.INTERNAL_SERVER_ERROR":"Internal server error. Please try again.","errors.system.INVALID_CONFIGURATION":"System configuration error","errors.system.TOO_MANY_REQUESTS":"Too many requests. Please wait a moment and try again","errors.system.UNKNOWN_OPERATION":"Unrecognized operation","errors.users_module_not_configured":"Users module not configured","footer.copyright":"Nocios S.R.L. All Rights Reserved.","footer.version":"Version","forgotPassword.checkEmailInstructions":"Check your inbox for the verification code","forgotPassword.codeAlreadyExistsMessage":"A code was already sent and is still valid","forgotPassword.emailLabel":"Email Address","forgotPassword.emailPlaceholder":"Enter your email address","forgotPassword.emailRequired":"Email address is required","forgotPassword.emailSentMessage":"Code sent successfully","forgotPassword.enterCodeLink":"Enter Code","forgotPassword.instructions":"Enter your email address and we'll send you a code to reset your password.","forgotPassword.invalidEmail":"Enter a valid email address","forgotPassword.sendCodeButton":"Send Code","forgotPassword.title":"Reset Password","loading.app.configInitial":"Loading initial configuration...","loading.app.generic":"Loading...","loading.app.starting":"Starting application...","loading.app.themeSetup":"Generating theme...","loading.app.validatingSession":"Validating session...","login.alreadyHaveCodeLink":"Already have a code?","login.forgotPasswordLink":"Forgot Password?","login.initializationError":"Initialization error","login.initializing":"Initializing...","login.loginButton":"Log In","login.logoAlt":"Logo","login.noAccountPrompt":"Don't have an account?","login.notInitialized":"System not initialized","login.passwordLabel":"Password","login.passwordPlaceholder":"Enter your password","login.passwordRequired":"Password is required","login.signUpLink":"Sign up","login.usernameOrEmailLabel":"Username or Email","login.usernameOrEmailPlaceholder":"Enter your username or email","login.usernameRequired":"Username or email is required","resetPassword.codeExpiredOrInvalid":"Code expired or invalid","resetPassword.confirmPasswordLabel":"Confirm Password","resetPassword.confirmPasswordPlaceholder":"Confirm your new password","resetPassword.confirmPasswordRequired":"Confirm your password","resetPassword.goToLoginButton":"Go to Login","resetPassword.instructions":"Enter your new password.","resetPassword.invalidCode":"The verification code is invalid. Please check the link or request a new one.","resetPassword.missingParameters":"Missing required parameters","resetPassword.newPasswordLabel":"New Password","resetPassword.newPasswordPlaceholder":"Enter your new password","resetPassword.newPasswordRequired":"New password is required","resetPassword.passwordTooShort":"Password must be at least 8 characters","resetPassword.passwordsDoNotMatch":"Passwords do not match","resetPassword.requestNewCodeButton":"Request New Code","resetPassword.resetPasswordButton":"Reset Password","resetPassword.successInstructions":"You can now log in with your new password","resetPassword.successMessage":"Password reset successfully","resetPassword.title":"New Password","resetPassword.validatingCode":"Validating code..."}},mr= exports.getCriticalLanguages =()=>Object.keys(p),hr= exports.getCriticalTranslations =i=>p[i]||p.es;var re="crudify_translations_",yr=3600*1e3,U= exports.TranslationService =class i{constructor(){this.enableDebug=!1;this.initializationPromise=null;this.isInitialized=!1}static getInstance(){return i.instance||(i.instance=new i),i.instance}setDebug(e){this.enableDebug=e}async ensureCrudifyInitialized(e,r){if(!this.isInitialized)return this.initializationPromise?(this.enableDebug&&console.log("[TranslationService] Waiting for crudify initialization..."),this.initializationPromise):(this.enableDebug&&console.log("[TranslationService] Initializing crudify SDK..."),this.initializationPromise=(async()=>{try{let o=_crudifybrowser2.default.getTokenData();if(o&&o.endpoint){this.enableDebug&&console.log("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}_crudifybrowser2.default.config(r),console.log("[TranslationService] \u{1F50D} BEFORE crudify.init() call");let t=await _crudifybrowser2.default.init(e,this.enableDebug?"debug":"none");if(console.log("[TranslationService] \u{1F50D} AFTER crudify.init() call"),console.log("[TranslationService] \u{1F50D} Response type:",typeof t),console.log("[TranslationService] \u{1F50D} Response value:",t),console.log("[TranslationService] \u{1F50D} Response.success:",_optionalChain([t, 'optionalAccess', _10 => _10.success])),console.log("[TranslationService] \u{1F50D} Response.data:",_optionalChain([t, 'optionalAccess', _11 => _11.data])),console.log("[TranslationService] \u{1F50D} Response.errors:",_optionalChain([t, 'optionalAccess', _12 => _12.errors])),t.success===!1)throw console.log("[TranslationService] \u274C Detected explicit failure (response.success === false)"),new Error(`Failed to initialize crudify: ${JSON.stringify(t.errors||"Unknown error")}`);if(!t.data&&t.success!==!0)throw console.log("[TranslationService] \u274C Detected failure (!response.data && response.success !== true)"),console.log("[TranslationService] \u{1F50D} !response.data:",!t.data),console.log("[TranslationService] \u{1F50D} response.success !== true:",t.success!==!0),new Error(`Failed to initialize crudify: ${JSON.stringify(t.errors||"Unknown error")}`);console.log("[TranslationService] \u2705 No explicit failure detected, marking as initialized"),this.isInitialized=!0,this.enableDebug&&console.log("[TranslationService] Crudify SDK initialized successfully")}catch(o){throw console.error("[TranslationService] Failed to initialize crudify:",o),this.initializationPromise=null,o}})(),this.initializationPromise)}async fetchTranslations(e){let{subscriberKey:r,apiKey:o,sections:t,crudifyEnv:s="stg",urlTranslations:n}=e,a=this.getFromCache(r),l=a?this.isCacheExpired(a):!0;if(a&&!l)return this.enableDebug&&console.log("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(a.data.translations,n);try{await this.ensureCrudifyInitialized(o,s)}catch(u){return console.error("[TranslationService] Failed to initialize crudify:",u),a?(console.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(a.data.translations,n)):(console.warn("[TranslationService] Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&console.log("[TranslationService] Fetching from API via crudify SDK...");let u=await this.fetchFromAPI(t);return this.hasDataChanged(a,u)||!a?(this.enableDebug&&console.log("[TranslationService] Data changed, updating cache"),this.saveToCache(r,u)):(this.enableDebug&&console.log("[TranslationService] Data unchanged, refreshing cache timestamp"),this.refreshCacheTimestamp(r)),this.mergeWithUrlTranslations(u.translations,n)}catch(u){return console.error("[TranslationService] API fetch failed:",u),a?(console.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(a.data.translations,n)):(console.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(e){let r=await _crudifybrowser2.default.getTranslation(e);if(!r.success)throw new Error(`Crudify API error: ${r.errors?JSON.stringify(r.errors):"Unknown error"}`);if(!r.data)throw new Error("No translation data in response");return r.data}mergeWithUrlTranslations(e,r){if(!r||Object.keys(r).length===0)return e;let o={};return Object.keys(e).forEach(t=>{o[t]={...e[t],...r}}),o}hasDataChanged(e,r){if(!e||e.data.timestamp!==r.timestamp)return!0;let o=this.hashData(r.translations);return e.dataHash!==o}hashData(e){let r=JSON.stringify(e),o=0;for(let t=0;t<r.length;t++){let s=r.charCodeAt(t);o=(o<<5)-o+s,o=o&o}return o.toString(36)}saveToCache(e,r){try{let o=this.getCacheKey(e),t={data:r,cachedAt:Date.now(),dataHash:this.hashData(r.translations)};localStorage.setItem(o,JSON.stringify(t)),this.enableDebug&&console.log("[TranslationService] Saved to cache:",o)}catch(o){console.error("[TranslationService] Failed to save cache:",o)}}getFromCache(e){try{let r=this.getCacheKey(e),o=localStorage.getItem(r);return o?JSON.parse(o):null}catch(r){return console.error("[TranslationService] Failed to read cache:",r),null}}refreshCacheTimestamp(e){try{let r=this.getFromCache(e);if(r){r.cachedAt=Date.now();let o=this.getCacheKey(e);localStorage.setItem(o,JSON.stringify(r))}}catch(r){console.error("[TranslationService] Failed to refresh cache timestamp:",r)}}isCacheExpired(e){return Date.now()-e.cachedAt>yr}getCacheKey(e){return`${re}${e}`}getCriticalTranslationsOnly(){return p}invalidateCache(e){let r=this.getCacheKey(e);localStorage.removeItem(r),this.enableDebug&&console.log("[TranslationService] Cache invalidated:",r)}async prefetchTranslations(e){try{await this.fetchTranslations(e),this.enableDebug&&console.log("[TranslationService] Prefetch completed")}catch(r){console.error("[TranslationService] Prefetch failed:",r)}}clearAllCaches(){try{let r=Object.keys(localStorage).filter(o=>o.startsWith(re));r.forEach(o=>localStorage.removeItem(o)),this.enableDebug&&console.log(`[TranslationService] Cleared ${r.length} cache entries`)}catch(e){console.error("[TranslationService] Failed to clear caches:",e)}}},D= exports.translationService =U.getInstance();var te=_react.createContext.call(void 0, null);function ie(i,e,r){return{...i,...e,...r||{}}}var Cr=({children:i,subscriberKey:e,apiKey:r,crudifyEnv:o="stg",sections:t,language:s="es",devTranslations:n,translationUrl:a,enableDebug:l=!1,skipAutoInit:u=!0})=>{let[f,P]=_react.useState.call(void 0, {}),[T,b]=_react.useState.call(void 0, !0),[V,v]=_react.useState.call(void 0, null),[A,B]=_react.useState.call(void 0, void 0),[G,se]=_react.useState.call(void 0, !1),N=_react.useCallback.call(void 0, async()=>{if(G){l&&console.log("[TranslationsProvider] Skipping reload - using fallback translations");return}b(!0),v(null);let c;if(a)try{l&&console.log(`[TranslationsProvider] Fetching translations from URL: ${a}`);let g=await fetch(a);if(!g.ok)throw new Error(`Failed to fetch translations: ${g.statusText}`);c=await g.json(),B(c),l&&console.log("[TranslationsProvider] URL translations loaded:",{keysCount:c?Object.keys(c).length:0})}catch(g){console.error("[TranslationsProvider] Failed to load URL translations:",g),c=void 0,B(void 0)}try{D.setDebug(l);let g=await D.fetchTranslations({subscriberKey:e,apiKey:r,crudifyEnv:o,sections:t,urlTranslations:c}),h={};Object.keys(g).forEach(d=>{let R=p[d]||{},y=g[d]||{};h[d]=ie(R,y,n)}),P(h),l&&console.log("[TranslationsProvider] Loaded translations:",{languages:Object.keys(h),keysCount:Object.keys(h[s]||{}).length})}catch(g){console.error("[TranslationsProvider] Failed to load:",g),v(g.message),se(!0);let h={};Object.keys(p).forEach(d=>{let R=p[d],y=c||A||{};h[d]=ie(R,y,n)}),P(h),l&&console.log("[TranslationsProvider] Using fallback translations (critical + URL)")}finally{b(!1)}},[e,r,o,t,a,n,l,s,G]);_react.useEffect.call(void 0, ()=>{N();let c=setInterval(N,3600*1e3);return()=>clearInterval(c)},[N]);let ae={t:_react.useMemo.call(void 0, ()=>(c,g)=>{let d=(f[s]||{})[c];if(!d){let R=Object.keys(f);for(let y of R)if(f[y][c]){d=f[y][c];break}}return d||(l&&console.warn(`[TranslationsProvider] Missing translation: "${c}"`),d=c),g&&typeof d=="string"&&Object.entries(g).forEach(([R,y])=>{let le=new RegExp(`{{${R}}}`,"g");d=d.replace(le,String(y))}),d},[f,s,l]),language:s,availableLanguages:Object.keys(f),translations:f,isLoading:T,error:V,refreshTranslations:N};if(T){let c=_optionalChain([p, 'access', _13 => _13[s], 'optionalAccess', _14 => _14.loading])||"Loading...";return _jsxruntime.jsx.call(void 0, "div",{children:c})}return _jsxruntime.jsx.call(void 0, te.Provider,{value:ae,children:i})},Er= exports.useTranslations =()=>{let i=_react.useContext.call(void 0, te);if(!i)throw new Error("useTranslations must be used within TranslationsProvider");return i};var _crudifyadmin = require('@nocios/crudify-admin'); var _crudifyadmin2 = _interopRequireDefault(_crudifyadmin);var ne=!1,S=null;async function wr(){let e=_chunkMTP6BSGZjs.e.getInstance().getTokenInfo(),r=_optionalChain([e, 'optionalAccess', _15 => _15.apiEndpointAdmin]),o=_optionalChain([e, 'optionalAccess', _16 => _16.apiKeyEndpointAdmin]);return r&&o?{apiUrl:r,apiKey:o}:_chunkMTP6BSGZjs.a.waitForCredentials()}async function Sr(){if(!ne)return S||(S=(async()=>{try{let i=_chunkMTP6BSGZjs.e.getInstance(),{apiUrl:e,apiKey:r}=await wr();_crudifyadmin2.default.init({url:e,apiKey:r,getAdditionalHeaders:()=>{let o=i.getTokenInfo();return _optionalChain([o, 'optionalAccess', _17 => _17.crudifyTokens, 'optionalAccess', _18 => _18.accessToken])?{Authorization:`Bearer ${o.crudifyTokens.accessToken}`}:{}}}),ne=!0}catch(i){throw S=null,console.error("[crudifyAdminWrapper] Initialization failed:",i),i}})(),S)}async function I(i){try{await Sr();let e=await i();return!e.success&&_optionalChain([e, 'access', _19 => _19.errors, 'optionalAccess', _20 => _20.includes, 'call', _21 => _21("401")])?await _chunkMTP6BSGZjs.e.getInstance().refreshTokens()?await i():(console.error("[crudifyAdmin] Token refresh failed"),typeof window<"u"&&(window.location.href="/login"),e):e}catch(e){return console.error("[crudifyAdmin] Operation error:",e),{success:!1,errors:e instanceof Error?e.message:"Unknown error"}}}var br={listModules:()=>I(()=>_crudifyadmin2.default.listModules()),getModule:i=>I(()=>_crudifyadmin2.default.getModule(i)),createModule:i=>I(()=>_crudifyadmin2.default.createModule(i)),editModule:(i,e)=>I(()=>_crudifyadmin2.default.editModule(i,e)),deleteModule:i=>I(()=>_crudifyadmin2.default.deleteModule(i)),activateModule:i=>I(()=>_crudifyadmin2.default.activateModule(i)),deactivateModule:i=>I(()=>_crudifyadmin2.default.deactivateModule(i)),getModuleVersions:i=>I(()=>_crudifyadmin2.default.getModuleVersions(i))};exports.AuthRoute = j; exports.CRITICAL_TRANSLATIONS = p; exports.CrudifyInitializationManager = x; exports.CrudifyInitializer = gr; exports.CrudifyLogin = _chunk47DGJX3Jjs.a; exports.CrudifyProvider = _chunkMTP6BSGZjs.b; exports.CrudifyThemeProvider = Je; exports.ERROR_CODES = _chunkYIIUEOXCjs.a; exports.ERROR_SEVERITY_MAP = _chunkYIIUEOXCjs.b; exports.GlobalNotificationProvider = _chunkMTP6BSGZjs.g; exports.LoginComponent = _chunk47DGJX3Jjs.f; exports.POLICY_ACTIONS = _chunk47DGJX3Jjs.c; exports.PREFERRED_POLICY_ORDER = _chunk47DGJX3Jjs.d; exports.Policies = _chunk47DGJX3Jjs.e; exports.ProtectedRoute = Z; exports.SessionDebugInfo = _chunkMTP6BSGZjs.k; exports.SessionLoadingScreen = F; exports.SessionManager = _chunkMTP6BSGZjs.e; exports.SessionProvider = _chunkMTP6BSGZjs.i; exports.SessionStatus = _chunk47DGJX3Jjs.g; exports.TokenStorage = _chunkMTP6BSGZjs.d; exports.TranslationService = U; exports.TranslationsProvider = Cr; exports.UserProfileDisplay = _chunk47DGJX3Jjs.b; exports.createErrorTranslator = _chunkAT74WV5Wjs.e; exports.crudify = _crudifybrowser2.default; exports.crudifyAdmin = br; exports.crudifyInitManager = _; exports.decodeJwtSafely = _chunkAT74WV5Wjs.h; exports.extractSafeRedirectFromUrl = H; exports.getCookie = _chunkAT74WV5Wjs.a; exports.getCriticalLanguages = mr; exports.getCriticalTranslations = hr; exports.getCurrentUserEmail = _chunkAT74WV5Wjs.i; exports.getErrorMessage = _chunkYIIUEOXCjs.e; exports.handleCrudifyError = _chunkYIIUEOXCjs.g; exports.isTokenExpired = _chunkAT74WV5Wjs.j; exports.parseApiError = _chunkYIIUEOXCjs.c; exports.parseJavaScriptError = _chunkYIIUEOXCjs.f; exports.parseTransactionError = _chunkYIIUEOXCjs.d; exports.secureLocalStorage = _chunkNNY4A73Vjs.b; exports.secureSessionStorage = _chunkNNY4A73Vjs.a; exports.translateError = _chunkAT74WV5Wjs.d; exports.translateErrorCode = _chunkAT74WV5Wjs.b; exports.translateErrorCodes = _chunkAT74WV5Wjs.c; exports.translationService = D; exports.useAuth = _chunk5Y7BV2YMjs.b; exports.useCrudify = _chunkMTP6BSGZjs.c; exports.useCrudifyInitializer = fr; exports.useCrudifyWithNotifications = _chunk5Y7BV2YMjs.d; exports.useData = _chunk5Y7BV2YMjs.c; exports.useGlobalNotification = _chunkMTP6BSGZjs.h; exports.useSession = _chunkMTP6BSGZjs.f; exports.useSessionContext = _chunkMTP6BSGZjs.j; exports.useTranslations = Er; exports.useUserData = _chunk5Y7BV2YMjs.a; exports.useUserProfile = _chunkMTP6BSGZjs.l; exports.validateInternalRedirect = O;