@nocios/crudify-ui 4.4.20 → 4.4.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ var u=e=>{let t=document.cookie.match(new RegExp("(^|;)\\s*"+e+"=([^;]+)"));return t?t[2]:null};function I(e={}){let{publicApiKey:t,env:r,appName:n,logo:i,loginActions:c,featureKeys:p,enableDebug:g=!1}=e,s={configSource:"none"},E=u("publicApiKey");if(E){let o=u("environment"),l=u("appName"),m=u("logo"),v=u("loginActions"),y=u("featureKeys"),R=u("theme");return s={publicApiKey:decodeURIComponent(E),env:o&&["dev","stg","api","prod"].includes(o)?o:"prod",appName:l?decodeURIComponent(l):void 0,logo:m?decodeURIComponent(m):void 0,loginActions:v?decodeURIComponent(v).split(",").map(f=>f.trim()).filter(Boolean):void 0,featureKeys:y?decodeURIComponent(y).split(",").map(f=>f.trim()).filter(Boolean):void 0,theme:R?(()=>{try{return JSON.parse(decodeURIComponent(R))}catch(f){g&&console.warn("[ConfigResolver] Failed to parse theme cookie:",f);return}})():void 0,configSource:"cookies"},g&&typeof window<"u"&&(window.__CRUDIFY_RESOLVED_CONFIG=s),s}return t&&(s={publicApiKey:t,env:r||"prod",appName:n,logo:i,loginActions:c,featureKeys:p,configSource:"props"},g&&typeof window<"u"&&(window.__CRUDIFY_RESOLVED_CONFIG=s)),s}function D(e={}){return I(e)}var N=["errors.{category}.{code}","errors.{code}","login.{code}","error.{code}","messages.{code}","{code}"],C={INVALID_CREDENTIALS:"auth",UNAUTHORIZED:"auth",INVALID_API_KEY:"auth",USER_NOT_FOUND:"auth",USER_NOT_ACTIVE:"auth",NO_PERMISSION:"auth",SESSION_EXPIRED:"auth",ITEM_NOT_FOUND:"data",NOT_FOUND:"data",IN_USE:"data",DUPLICATE_ENTRY:"data",FIELD_ERROR:"validation",BAD_REQUEST:"validation",INVALID_EMAIL:"validation",INVALID_CODE:"validation",REQUIRED_FIELD:"validation",INTERNAL_SERVER_ERROR:"system",DATABASE_CONNECTION_ERROR:"system",INVALID_CONFIGURATION:"system",UNKNOWN_OPERATION:"system",TIMEOUT_ERROR:"system",NETWORK_ERROR:"system",TOO_MANY_REQUESTS:"rate_limit"},S={INVALID_CREDENTIALS:"Invalid username or password",UNAUTHORIZED:"You are not authorized to perform this action",SESSION_EXPIRED:"Your session has expired. Please log in again.",USER_NOT_FOUND:"User not found",ITEM_NOT_FOUND:"Item not found",FIELD_ERROR:"Invalid field value",INTERNAL_SERVER_ERROR:"An internal error occurred",NETWORK_ERROR:"Network connection error",TIMEOUT_ERROR:"Request timeout",UNKNOWN_OPERATION:"Unknown operation",INVALID_EMAIL:"Invalid email format",INVALID_CODE:"Invalid code",TOO_MANY_REQUESTS:"Too many requests, please try again later"};function d(e,t){let{translateFn:r,currentLanguage:n,enableDebug:i}=t;i&&console.log(`\u{1F50D} [ErrorTranslation] Translating error code: ${e} (lang: ${n||"unknown"})`);let c=e.toUpperCase(),p=C[c],g=N.map(o=>o.replace("{category}",p||"general").replace("{code}",c));i&&console.log("\u{1F511} [ErrorTranslation] Searching keys:",g);for(let o of g){let l=r(o);if(i&&console.log(`\u{1F50D} [ErrorTranslation] Checking key: "${o}" -> result: "${l}" (same as key: ${l===o})`),l&&l!==o)return i&&console.log(`\u2705 [ErrorTranslation] Found translation at key: ${o} = "${l}"`),l}let s=S[c];if(s)return i&&console.log(`\u{1F504} [ErrorTranslation] Using default message: "${s}"`),s;let E=c.replace(/_/g," ").toLowerCase().replace(/\b\w/g,o=>o.toUpperCase());return i&&console.log(`\u26A0\uFE0F [ErrorTranslation] No translation found, using friendly code: "${E}"`),E}function O(e,t){return e.map(r=>d(r,t))}function b(e,t){let{enableDebug:r}=t;r&&console.log("\u{1F50D} [ErrorTranslation] Translating error:",e);let n=d(e.code,t);return n!==e.code.toUpperCase()&&n!==e.code?(r&&console.log(`\u2705 [ErrorTranslation] Using hierarchical translation: "${n}"`),e.field?`${e.field}: ${n}`:n):e.message&&!e.message.includes("Error:")&&e.message.length>0&&e.message!==e.code?(r&&console.log(`\u{1F504} [ErrorTranslation] No hierarchical translation found, using API message: "${e.message}"`),e.message):(r&&console.log(`\u26A0\uFE0F [ErrorTranslation] Using final fallback: "${n}"`),e.field?`${e.field}: ${n}`:n)}function k(e,t={}){let r={translateFn:e,currentLanguage:t.currentLanguage,enableDebug:t.enableDebug||!1};return{translateErrorCode:n=>d(n,r),translateErrorCodes:n=>O(n,r),translateError:n=>b(n,r),translateApiError:n=>n?.data?.response?.status?d(n.data.response.status,r):n?.status?d(n.status,r):n?.code?d(n.code,r):"Unknown error"}}var h=class e{constructor(){this.listeners=new Set;this.isHandlingAuthError=!1;this.lastErrorTime=0;this.lastEventType=null;this.DEBOUNCE_TIME=1e3}static getInstance(){return e.instance||(e.instance=new e),e.instance}emit(t,r){let n=Date.now();if(this.isHandlingAuthError&&this.lastEventType===t&&n-this.lastErrorTime<this.DEBOUNCE_TIME){console.log(`\u{1F6AB} AuthEventBus: Ignoring duplicate ${t} event (debounced)`);return}this.isHandlingAuthError=!0,this.lastErrorTime=n,this.lastEventType=t,console.log(`\u{1F4E2} AuthEventBus: Emitting ${t} event`,r);let i={type:t,details:r,timestamp:n};this.listeners.forEach(c=>{try{c(i)}catch(p){console.error("AuthEventBus: Error in listener",p)}}),setTimeout(()=>{this.isHandlingAuthError=!1,this.lastEventType=null},2e3)}subscribe(t){return this.listeners.add(t),()=>{this.listeners.delete(t)}}clear(){this.listeners.clear(),this.isHandlingAuthError=!1,this.lastEventType=null}isHandling(){return this.isHandlingAuthError}},P=h.getInstance();var a=class a{constructor(){this.isPatched=!1;this.refCount=0;this.listeners=new Set;this.originalPushState=window.history.pushState,this.originalReplaceState=window.history.replaceState}static getInstance(){return a.instance||(a.instance=new a),a.instance}subscribe(t){return this.listeners.add(t),this.refCount++,this.isPatched||this.applyPatches(),()=>{this.unsubscribe(t)}}unsubscribe(t){this.listeners.delete(t),this.refCount--,this.refCount===0&&this.isPatched&&this.removePatches()}applyPatches(){let t=this;window.history.pushState=function(...r){let n=t.originalPushState.apply(this,r);return t.notifyListeners(),n},window.history.replaceState=function(...r){let n=t.originalReplaceState.apply(this,r);return t.notifyListeners(),n},this.isPatched=!0}removePatches(){window.history.pushState=this.originalPushState,window.history.replaceState=this.originalReplaceState,this.isPatched=!1}notifyListeners(){this.listeners.forEach(t=>{try{t()}catch(r){console.error("NavigationTracker: Error in navigation listener",r)}})}static reset(){a.instance?.isPatched&&a.instance.removePatches(),a.instance=null}getSubscriberCount(){return this.refCount}isActive(){return this.isPatched}};a.instance=null;var T=a;var A=e=>{try{let t=e.split(".");if(t.length!==3)return console.warn("Invalid JWT format: token must have 3 parts"),null;let r=t[1],n=r+"=".repeat((4-r.length%4)%4);return JSON.parse(atob(n))}catch(t){return console.warn("Failed to decode JWT token:",t),null}},K=()=>{try{let e=null;if(e=sessionStorage.getItem("authToken"),console.log("\u{1F50D} getCurrentUserEmail - authToken:",e?`${e.substring(0,20)}...`:null),e||(e=sessionStorage.getItem("token"),console.log("\u{1F50D} getCurrentUserEmail - token:",e?`${e.substring(0,20)}...`:null)),e||(e=localStorage.getItem("authToken")||localStorage.getItem("token"),console.log("\u{1F50D} getCurrentUserEmail - localStorage:",e?`${e.substring(0,20)}...`:null)),!e)return console.warn("\u{1F50D} getCurrentUserEmail - No token found in any storage"),null;let t=A(e);if(!t)return console.warn("\u{1F50D} getCurrentUserEmail - Failed to decode token"),null;let r=t.email||t["cognito:username"]||null;return console.log("\u{1F50D} getCurrentUserEmail - Extracted email:",r),r}catch(e){return console.warn("Failed to get current user email:",e),null}},$=e=>{try{let t=A(e);if(!t||!t.exp)return!0;let r=Math.floor(Date.now()/1e3);return t.exp<r}catch{return!0}};export{u as a,I as b,D as c,d,O as e,b as f,k as g,P as h,T as i,A as j,K as k,$ as l};
@@ -1 +1 @@
1
- import{h as $,j as D}from"./chunk-6MBALWSY.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as v}from"react";import Q from"@nocios/crudify-browser";var G=(S={})=>{let{autoFetch:a=!0,retryOnError:N=!1,maxRetries:g=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:c,tokens:R}=D(),[E,d]=K(null),[y,A]=K(a&&T),[_,p]=K(null),u=v(null),o=v(!0),m=v(0),l=v(0),x=j(()=>c&&(c.email||c["cognito:username"])||null,[c]),P=j(()=>{d(null),p(null),A(!1),l.current=0},[]),w=j(async()=>{let F=x();if(!F){o.current&&(p("No user email available from session data"),A(!1));return}if(!I){o.current&&(p("Session not initialized"),A(!1));return}u.current&&u.current.abort();let e=new AbortController;u.current=e;let i=++m.current;try{o.current&&(A(!0),p(null));let r=await Q.readItems("users",{filter:{email:F},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 n=r.data.response.data,s=typeof n=="string"?JSON.parse(n):n;s&&s.items&&Array.isArray(s.items)&&s.items.length>0&&(t=s.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 n=r.data.data.response.data,s=typeof n=="string"?JSON.parse(n):n;s&&s.items&&Array.isArray(s.items)&&s.items.length>0&&(t=s.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&&A(!1),u.current===e&&(u.current=null)}},[I,x,N,g]);return z(()=>{a&&T&&I?w():T||P()},[a,T,I,w,P]),z(()=>(o.current=!0,()=>{o.current=!1,u.current&&(u.current.abort(),u.current=null)}),[]),{user:{session:c,data:E},loading:y,error:_,refreshProfile:w,clearProfile:P}};import{useCallback as W}from"react";var ee=()=>{let{isAuthenticated:S,isLoading:a,isInitialized:N,tokens:g,error:T,sessionData:I,login:c,logout:R,refreshTokens:E,clearError:d,getTokenInfo:y,isExpiringSoon:A,expiresIn:_,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:a,error:T,token:g?.accessToken||null,user:I,tokenExpiration:o,setToken:u,logout:R,refreshToken:E,login:c,isExpiringSoon:A,expiresIn:_,refreshExpiresIn:p,getTokenInfo:y,clearError:d}};import{useCallback as h}from"react";import U from"@nocios/crudify-browser";var oe=()=>{let{isInitialized:S,isLoading:a,error:N,isAuthenticated:g,login:T}=D(),I=h(()=>S&&!a&&!N,[S,a,N]),c=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]),A=h(async(o,m,l)=>(await R(),await U.updateItem(o,m,l)),[R]),_=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:A,deleteItem:_,transaction:p,login:u,isInitialized:S,isInitializing:a,initializationError:N,isReady:I,waitForReady:c}};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"},M={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:a}=$(),{showSuccessNotifications:N=!1,showErrorNotifications:g=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:c=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]),A=C(e=>["create","update","delete"].includes(e),[]),_=C((e,i)=>N?A(e)&&i?!0:R.some(r=>r.key===e):!1,[N,R,A]),p=C((e,i,r)=>{let t=r?.key&&typeof r.key=="string"?r.key:e,n=`action.onSuccess.${t}`,s=y(n);if(s!==E("error.unknown")){if(A(t)&&i){let f=`action.${i}Singular`,O=y(f);if(O!==E("error.unknown"))return E(n,{item:O});{let k=`action.onSuccess.${t}WithoutItem`,L=y(k);return L!==E("error.unknown")?L:s}}return s}return E("success.transaction")},[y,E,A]),u=C(e=>{if(e.errorCode&&T[e.errorCode])return T[e.errorCode];if(e.errorCode&&M[e.errorCode])return y(M[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 n=JSON.parse(t);if(Array.isArray(n)&&n.length>0){let s=n[0];if(s?.response?.errorCode){let f=s.response.errorCode;if(M[f])return y(M[f]);let O=[`errors.auth.${f}`,`errors.data.${f}`,`errors.system.${f}`,`errors.${f}`];for(let k of O){let L=y(k);if(L!==y("error.unknown"))return L}}if(s?.response?.data)return s.response.data}if(n?.response?.message){let s=n.response.message.toLowerCase();return s.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):s.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):n.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 n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}else if(t.success){let n=r?.actionConfig,s=n?.key||"create",f=n?.moduleKey||e;if(_(s,f)){let O=p(s,f,n);a(O,"success",{autoHideDuration:c})}}return t},[g,_,a,u,o,p,c,d]),l=C(async(e,i,r)=>{let t=await b.updateItem(e,i,r),n=r?.skipNotifications===!0;if(!n&&!t.success&&g&&d(t)){let s=u(t),f=o(t);a(s,f,{autoHideDuration:c})}else if(!n&&t.success){let s=r?.actionConfig,f=s?.key||"update",O=s?.moduleKey||e;if(_(f,O)){let k=p(f,O,s);a(k,"success",{autoHideDuration:c})}}return t},[g,_,a,u,o,p,c,d]),x=C(async(e,i,r)=>{let t=await b.deleteItem(e,i,r);if(!t.success&&g&&d(t)){let n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}else if(t.success){let n=r?.actionConfig,s=n?.key||"delete",f=n?.moduleKey||e;if(_(s,f)){let O=p(s,f,n);a(O,"success",{autoHideDuration:c})}}return t},[g,_,a,u,o,p,c,d]),P=C(async(e,i,r)=>{let t=await b.readItem(e,i,r);if(!t.success&&g&&d(t)){let n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}return t},[g,a,u,o,c,d]),w=C(async(e,i,r)=>{let t=await b.readItems(e,i,r);if(!t.success&&g&&d(t)){let n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}return t},[g,a,u,o,c,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 n=u(r),s=o(r);a(n,s,{autoHideDuration:c})}else if(!t&&r.success){let n="transaction",s,f=null;if(i?.actionConfig?(f=i.actionConfig,n=f.key,s=f.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(n=e[0].operation,f=R.find(O=>O.key===n),f&&(s=f.moduleKey)),_(n,s)){let O=p(n,s,f);a(O,"success",{autoHideDuration:c})}}return r},[g,_,a,u,o,p,c,d,R]),F=C((e,i)=>{if(!e.success&&g&&d(e)){let r=u(e),t=o(e);a(r,t,{autoHideDuration:c})}else e.success&&N&&i&&a(i,"success",{autoHideDuration:c});return e},[g,N,a,u,o,c,d,E]);return{createItem:m,updateItem:l,deleteItem:x,readItem:P,readItems:w,transaction:V,handleResponse:F,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-TZKAMU3P.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as v}from"react";import Q from"@nocios/crudify-browser";var G=(S={})=>{let{autoFetch:a=!0,retryOnError:N=!1,maxRetries:g=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:c,tokens:R}=D(),[E,d]=K(null),[y,A]=K(a&&T),[_,p]=K(null),u=v(null),o=v(!0),m=v(0),l=v(0),x=j(()=>c&&(c.email||c["cognito:username"])||null,[c]),P=j(()=>{d(null),p(null),A(!1),l.current=0},[]),w=j(async()=>{let F=x();if(!F){o.current&&(p("No user email available from session data"),A(!1));return}if(!I){o.current&&(p("Session not initialized"),A(!1));return}u.current&&u.current.abort();let e=new AbortController;u.current=e;let i=++m.current;try{o.current&&(A(!0),p(null));let r=await Q.readItems("users",{filter:{email:F},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 n=r.data.response.data,s=typeof n=="string"?JSON.parse(n):n;s&&s.items&&Array.isArray(s.items)&&s.items.length>0&&(t=s.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 n=r.data.data.response.data,s=typeof n=="string"?JSON.parse(n):n;s&&s.items&&Array.isArray(s.items)&&s.items.length>0&&(t=s.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&&A(!1),u.current===e&&(u.current=null)}},[I,x,N,g]);return z(()=>{a&&T&&I?w():T||P()},[a,T,I,w,P]),z(()=>(o.current=!0,()=>{o.current=!1,u.current&&(u.current.abort(),u.current=null)}),[]),{user:{session:c,data:E},loading:y,error:_,refreshProfile:w,clearProfile:P}};import{useCallback as W}from"react";var ee=()=>{let{isAuthenticated:S,isLoading:a,isInitialized:N,tokens:g,error:T,sessionData:I,login:c,logout:R,refreshTokens:E,clearError:d,getTokenInfo:y,isExpiringSoon:A,expiresIn:_,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:a,error:T,token:g?.accessToken||null,user:I,tokenExpiration:o,setToken:u,logout:R,refreshToken:E,login:c,isExpiringSoon:A,expiresIn:_,refreshExpiresIn:p,getTokenInfo:y,clearError:d}};import{useCallback as h}from"react";import U from"@nocios/crudify-browser";var oe=()=>{let{isInitialized:S,isLoading:a,error:N,isAuthenticated:g,login:T}=D(),I=h(()=>S&&!a&&!N,[S,a,N]),c=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]),A=h(async(o,m,l)=>(await R(),await U.updateItem(o,m,l)),[R]),_=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:A,deleteItem:_,transaction:p,login:u,isInitialized:S,isInitializing:a,initializationError:N,isReady:I,waitForReady:c}};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"},M={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:a}=$(),{showSuccessNotifications:N=!1,showErrorNotifications:g=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:c=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]),A=C(e=>["create","update","delete"].includes(e),[]),_=C((e,i)=>N?A(e)&&i?!0:R.some(r=>r.key===e):!1,[N,R,A]),p=C((e,i,r)=>{let t=r?.key&&typeof r.key=="string"?r.key:e,n=`action.onSuccess.${t}`,s=y(n);if(s!==E("error.unknown")){if(A(t)&&i){let f=`action.${i}Singular`,O=y(f);if(O!==E("error.unknown"))return E(n,{item:O});{let k=`action.onSuccess.${t}WithoutItem`,L=y(k);return L!==E("error.unknown")?L:s}}return s}return E("success.transaction")},[y,E,A]),u=C(e=>{if(e.errorCode&&T[e.errorCode])return T[e.errorCode];if(e.errorCode&&M[e.errorCode])return y(M[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 n=JSON.parse(t);if(Array.isArray(n)&&n.length>0){let s=n[0];if(s?.response?.errorCode){let f=s.response.errorCode;if(M[f])return y(M[f]);let O=[`errors.auth.${f}`,`errors.data.${f}`,`errors.system.${f}`,`errors.${f}`];for(let k of O){let L=y(k);if(L!==y("error.unknown"))return L}}if(s?.response?.data)return s.response.data}if(n?.response?.message){let s=n.response.message.toLowerCase();return s.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):s.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):n.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 n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}else if(t.success){let n=r?.actionConfig,s=n?.key||"create",f=n?.moduleKey||e;if(_(s,f)){let O=p(s,f,n);a(O,"success",{autoHideDuration:c})}}return t},[g,_,a,u,o,p,c,d]),l=C(async(e,i,r)=>{let t=await b.updateItem(e,i,r),n=r?.skipNotifications===!0;if(!n&&!t.success&&g&&d(t)){let s=u(t),f=o(t);a(s,f,{autoHideDuration:c})}else if(!n&&t.success){let s=r?.actionConfig,f=s?.key||"update",O=s?.moduleKey||e;if(_(f,O)){let k=p(f,O,s);a(k,"success",{autoHideDuration:c})}}return t},[g,_,a,u,o,p,c,d]),x=C(async(e,i,r)=>{let t=await b.deleteItem(e,i,r);if(!t.success&&g&&d(t)){let n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}else if(t.success){let n=r?.actionConfig,s=n?.key||"delete",f=n?.moduleKey||e;if(_(s,f)){let O=p(s,f,n);a(O,"success",{autoHideDuration:c})}}return t},[g,_,a,u,o,p,c,d]),P=C(async(e,i,r)=>{let t=await b.readItem(e,i,r);if(!t.success&&g&&d(t)){let n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}return t},[g,a,u,o,c,d]),w=C(async(e,i,r)=>{let t=await b.readItems(e,i,r);if(!t.success&&g&&d(t)){let n=u(t),s=o(t);a(n,s,{autoHideDuration:c})}return t},[g,a,u,o,c,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 n=u(r),s=o(r);a(n,s,{autoHideDuration:c})}else if(!t&&r.success){let n="transaction",s,f=null;if(i?.actionConfig?(f=i.actionConfig,n=f.key,s=f.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(n=e[0].operation,f=R.find(O=>O.key===n),f&&(s=f.moduleKey)),_(n,s)){let O=p(n,s,f);a(O,"success",{autoHideDuration:c})}}return r},[g,_,a,u,o,p,c,d,R]),F=C((e,i)=>{if(!e.success&&g&&d(e)){let r=u(e),t=o(e);a(r,t,{autoHideDuration:c})}else e.success&&N&&i&&a(i,"success",{autoHideDuration:c});return e},[g,N,a,u,o,c,d,E]);return{createItem:m,updateItem:l,deleteItem:x,readItem:P,readItems:w,transaction:V,handleResponse:F,getErrorMessage:u,getErrorSeverity:o,shouldShowNotification:d}};export{G as a,ee as b,oe as c,le as d};
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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 _chunkWUOGD7AZjs = require('./chunk-WUOGD7AZ.js');var _chunkYIIUEOXCjs = require('./chunk-YIIUEOXC.js');var _chunkFC7HOMNQjs = require('./chunk-FC7HOMNQ.js');var re={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":"Correo Electr\xF3nico","login.usernameOrEmailPlaceholder":"Ingresa tu correo electr\xF3nico","login.usernameRequired":"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..."}},tn= exports.b =()=>Object.keys(re),nn= exports.c =e=>re[e]||re.es;var _crudifybrowser = require('@nocios/crudify-browser'); var _crudifybrowser2 = _interopRequireDefault(_crudifybrowser);var yo="crudify_translations_",sr=3600*1e3;function ho(e){let o=0;for(let r=0;r<e.length;r++){let t=e.charCodeAt(r);o=(o<<5)-o+t,o=o&o}return Math.abs(o).toString(36)}var qe=class e{constructor(){this.enableDebug=!1;this.initializationPromise=null;this.isInitialized=!1}static getInstance(){return e.instance||(e.instance=new e),e.instance}setDebug(o){this.enableDebug=o}async ensureCrudifyInitialized(o,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 l=await _crudifybrowser2.default.init(o,this.enableDebug?"debug":"none");if(l.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(l.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(o){let{apiKey:r,featureKeys:t,crudifyEnv:l="stg",urlTranslations:a}=o;this.enableDebug&&console.log("[TranslationService] fetchTranslations called with:",{apiKeyHash:ho(r),crudifyEnv:l,featureKeys:t,hasUrlTranslations:!!a});let i=this.getFromCache(r),d=i?this.isCacheExpired(i):!0;if(i&&!d)return this.enableDebug&&console.log("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(i.data.translations,a);try{await this.ensureCrudifyInitialized(r,l)}catch(c){return console.error("[TranslationService] \u274C Failed to initialize crudify:",c),i?(console.warn("[TranslationService] \u26A0\uFE0F Using expired cache (init failed)"),this.mergeWithUrlTranslations(i.data.translations,a)):(console.warn("[TranslationService] \u26A0\uFE0F Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&console.log("[TranslationService] Fetching from API via crudify SDK");let c=await this.fetchFromAPI(t);this.hasDataChanged(i,c)||!i?this.saveToCache(r,c):this.refreshCacheTimestamp(r);let u=this.mergeWithUrlTranslations(c.translations,a);return this.enableDebug&&console.log("[TranslationService] Translations loaded:",{languages:Object.keys(u),keysCount:u[Object.keys(u)[0]]?Object.keys(u[Object.keys(u)[0]]).length:0}),u}catch(c){return console.error("[TranslationService] \u274C API fetch failed:",c),i?(console.warn("[TranslationService] \u26A0\uFE0F Using expired cache as fallback"),this.mergeWithUrlTranslations(i.data.translations,a)):(console.warn("[TranslationService] \u26A0\uFE0F Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(o){let r=await _crudifybrowser2.default.getTranslation(o);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(o,r){if(!r||Object.keys(r).length===0)return o;let t={};return Object.keys(o).forEach(l=>{t[l]={...o[l],...r}}),t}hasDataChanged(o,r){if(!o||o.data.timestamp!==r.timestamp)return!0;let t=this.hashData(r.translations);return o.dataHash!==t}hashData(o){let r=JSON.stringify(o),t=0;for(let l=0;l<r.length;l++){let a=r.charCodeAt(l);t=(t<<5)-t+a,t=t&t}return t.toString(36)}saveToCache(o,r){try{let t=this.getCacheKey(o),l={data:r,cachedAt:Date.now(),dataHash:this.hashData(r.translations)};localStorage.setItem(t,JSON.stringify(l)),this.enableDebug&&console.log("[TranslationService] Saved to cache:",t)}catch(t){console.error("[TranslationService] Failed to save cache:",t)}}getFromCache(o){try{let r=this.getCacheKey(o),t=localStorage.getItem(r);return t?JSON.parse(t):null}catch(r){return console.error("[TranslationService] Failed to read cache:",r),null}}refreshCacheTimestamp(o){try{let r=this.getFromCache(o);if(r){r.cachedAt=Date.now();let t=this.getCacheKey(o);localStorage.setItem(t,JSON.stringify(r))}}catch(r){console.error("[TranslationService] Failed to refresh cache timestamp:",r)}}isCacheExpired(o){return Date.now()-o.cachedAt>sr}hasValidCache(o){let r=this.getFromCache(o);return r?!this.isCacheExpired(r):!1}getCacheKey(o){return`${yo}${ho(o)}`}getCriticalTranslationsOnly(){return re}invalidateCache(o){let r=this.getCacheKey(o);localStorage.removeItem(r),this.enableDebug&&console.log("[TranslationService] Cache invalidated:",r)}async prefetchTranslations(o){try{await this.fetchTranslations(o),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(yo));r.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&console.log(`[TranslationService] Cleared ${r.length} cache entries`)}catch(o){console.error("[TranslationService] Failed to clear caches:",o)}}},_e= exports.e =qe.getInstance();var _react = require('react');var _jsxruntime = require('react/jsx-runtime');var Oe=null,He=!1,Co=_react.createContext.call(void 0, null);function bo(e,o,r){return{...e,...o,...r||{}}}function cr(e,o,r,t,l){_react.useEffect.call(void 0, ()=>{if(!t||!e||!o)return;let a=r||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!a||!a.addResourceBundle){l&&console.log("[TranslationsProvider] i18next not found, skipping auto-sync");return}l&&console.log("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:o}),Object.keys(e).forEach(i=>{e[i]&&Object.keys(e[i]).length>0&&(a.addResourceBundle(i,"translation",e[i],!0,!0),l&&console.log(`[TranslationsProvider] Synced ${Object.keys(e[i]).length} keys for language: ${i}`))}),a.language!==o&&(a.changeLanguage(o),l&&console.log(`[TranslationsProvider] Changed i18next language to: ${o}`))},[e,o,r,t,l])}var pn=({children:e,apiKey:o,crudifyEnv:r="prod",featureKeys:t,language:l="es",devTranslations:a,translationUrl:i,enableDebug:d=!1,skipAutoInit:c=!0,autoSyncI18n:h=!0,i18nInstance:u,loadingFallback:w,waitForInitialLoad:f=!0})=>{let n=_react.useMemo.call(void 0, ()=>_chunkFC7HOMNQjs.b.call(void 0, {publicApiKey:o,env:r,featureKeys:t,enableDebug:d}),[o,r,t,d]),s=n.publicApiKey||"",p=n.env||r||"prod",y=n.featureKeys||t,[P,m]=_react.useState.call(void 0, {}),[b,O]=_react.useState.call(void 0, !0),[oe,v]=_react.useState.call(void 0, !0),[g,T]=_react.useState.call(void 0, null),[S,F]=_react.useState.call(void 0, void 0),[de,Pe]=_react.useState.call(void 0, !1),fe=_react.useCallback.call(void 0, async()=>{if(!s){d&&console.log("[TranslationsProvider] No apiKey - skipping translation fetch"),O(!1),v(!1);return}if(de){d&&console.log("[TranslationsProvider] Skipping reload - using fallback translations");return}if(_e.hasValidCache(s)&&oe&&(d&&console.log("[TranslationsProvider] Valid cache found - not blocking initial render"),v(!1)),He&&Oe){d&&console.log("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let E=await Oe;m(E),O(!1);return}catch (e2){d&&console.warn("[TranslationsProvider] Global fetch failed, retrying")}}He=!0,O(!0),T(null);let D;if(i)try{d&&console.log(`[TranslationsProvider] Fetching translations from URL: ${i}`);let E=await fetch(i);if(!E.ok)throw new Error(`Failed to fetch translations: ${E.statusText}`);D=await E.json(),F(D),d&&console.log("[TranslationsProvider] URL translations loaded:",{keysCount:D?Object.keys(D).length:0})}catch(E){console.error("[TranslationsProvider] Failed to load URL translations:",E),D=void 0,F(void 0)}let Ce=(async()=>{try{_e.setDebug(d);let E=await _e.fetchTranslations({apiKey:s,crudifyEnv:p,featureKeys:y,urlTranslations:D}),W={};return Object.keys(E).forEach(C=>{let R=re[C]||{},k=E[C]||{};W[C]=bo(R,k,a)}),d&&console.log("[TranslationsProvider] Loaded translations:",{languages:Object.keys(W),keysCount:Object.keys(W[l]||{}).length}),W}catch(E){console.error("[TranslationsProvider] Failed to load:",E),T(E.message),Pe(!0);let W={};return Object.keys(re).forEach(C=>{let R=re[C],k=D||S||{};W[C]=bo(R,k,a)}),d&&console.log("[TranslationsProvider] Using fallback translations (critical + URL)"),W}})();Oe=Ce;try{let E=await Ce;m(E)}finally{O(!1),v(!1),He=!1,setTimeout(()=>{Oe=null},1e3)}},[s,p,y,i,a,d,l,de]);_react.useEffect.call(void 0, ()=>{fe();let M=setInterval(fe,3600*1e3);return()=>clearInterval(M)},[fe]);let Ae=_react.useMemo.call(void 0, ()=>(M,D)=>{let E=(P[l]||{})[M];if(!E){let W=Object.keys(P);for(let C of W)if(P[C][M]){E=P[C][M];break}}return E||(d&&console.warn(`[TranslationsProvider] Missing translation: "${M}"`),E=M),D&&typeof E=="string"&&Object.entries(D).forEach(([W,C])=>{let R=new RegExp(`{{${W}}}`,"g");E=E.replace(R,String(C))}),E},[P,l,d]);cr(P,l,u,h,d);let A={t:Ae,language:l,availableLanguages:Object.keys(P),translations:P,isLoading:b,error:g,refreshTranslations:fe};return s?f&&oe&&b?w||_jsxruntime.jsx.call(void 0, "div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:_jsxruntime.jsx.call(void 0, "div",{children:"Loading translations..."})}):_jsxruntime.jsx.call(void 0, Co.Provider,{value:A,children:e}):(d&&console.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e}))},xo= exports.g =()=>{let e=_react.useContext.call(void 0, Co);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};var _material = require('@mui/material');var To=(e,o)=>{let[r,t]=_react.useState.call(void 0, {}),[l,a]=_react.useState.call(void 0, !1),[i,d]=_react.useState.call(void 0, null);return _react.useEffect.call(void 0, ()=>{if(console.log("\u{1F527} [I18nProvider] Hybrid translation loading:",{hasProvidedTranslations:!!o&&Object.keys(o).length>0,hasUrl:!!e,providedKeys:o?Object.keys(o).length:0}),o&&Object.keys(o).length>0){console.log("\u2705 [I18nProvider] Using provided translations (highest priority)"),t(o),a(!1),d(null);return}if(!e){console.log("\u26A0\uFE0F [I18nProvider] No translations provided, using empty object (keys will show as-is)"),t({}),a(!1),d(null);return}console.log("\u{1F310} [I18nProvider] Loading translations from URL:",e);let c=!1;return a(!0),d(null),fetch(e).then(h=>{if(!h.ok)throw new Error(`Failed to load translations: ${h.status}`);return h.json()}).then(h=>{c||(console.log("\u2705 [I18nProvider] Translations loaded successfully from URL:",{url:e,keysLoaded:Object.keys(h).length}),t(h),a(!1))}).catch(h=>{c||(console.error("\u274C [I18nProvider] Failed to load translations from URL:",e,h),d(h.message),console.log("\u{1F504} [I18nProvider] Falling back to empty translations (keys will show as-is)"),t({}),a(!1))}),()=>{c=!0}},[e,o]),{translations:r,loading:l,error:i}};var Eo=_react.createContext.call(void 0, null),mr=()=>{try{return xo()}catch (e3){return null}},pr=(e,o)=>{if(o.includes(".")){let r=o.split(".").reduce((t,l)=>t&&typeof t=="object"?t[l]:void 0,e);if(r!==void 0)return r}if(e&&e[o])return e[o]},Ro=({children:e,translations:o,translationsUrl:r,language:t="en"})=>{let a=_optionalChain([mr, 'call', _2 => _2(), 'optionalAccess', _3 => _3.translations, 'optionalAccess', _4 => _4[t]])||{},{translations:i,loading:d}=To(r,o),c=_react.useMemo.call(void 0, ()=>({...a,...i,...o||{}}),[a,i,o]),h=_react.useMemo.call(void 0, ()=>(w,f)=>{let n=pr(c,w);return n==null&&(console.log(`\u{1F50D} [I18nProvider] Translation not found for key: "${w}" - showing key as-is`),n=w),f&&typeof n=="string"&&Object.entries(f).forEach(([s,p])=>{n=n.replace(new RegExp(`{{${s}}}`,"g"),p)}),typeof n=="string"?n:w},[c]),u=_react.useMemo.call(void 0, ()=>({t:h,language:t}),[h,t]);return d?_jsxruntime.jsx.call(void 0, "div",{children:"Loading translations..."}):_jsxruntime.jsx.call(void 0, Eo.Provider,{value:u,children:e})},j=()=>{let e=_react.useContext.call(void 0, Eo);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};var Io={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function br(e,o){switch(o.type){case"SET_SCREEN":let r={...e,currentScreen:o.payload.screen,searchParams:o.payload.params||e.searchParams,errors:{global:[]}},t=new URLSearchParams(r.searchParams),l=t.toString()?`?${t.toString()}`:window.location.pathname;try{window.history.replaceState({},"",l)}catch (e4){}return r;case"SET_SEARCH_PARAMS":return{...e,searchParams:o.payload};case"UPDATE_FORM_DATA":return{...e,formData:{...e.formData,...o.payload},errors:{...e.errors,...Object.keys(o.payload).reduce((a,i)=>({...a,[i]:void 0}),{})}};case"SET_LOADING":return{...e,loading:o.payload};case"SET_ERRORS":return{...e,errors:{...e.errors,...o.payload}};case"CLEAR_ERRORS":return{...e,errors:{global:[]}};case"SET_EMAIL_SENT":return{...e,emailSent:o.payload};case"SET_CODE_ALREADY_EXISTS":return{...e,codeAlreadyExists:o.payload};case"SET_CODE_VALIDATED":return{...e,codeValidated:o.payload};case"SET_FROM_CODE_VERIFICATION":return{...e,fromCodeVerification:o.payload};case"RESET_FORM":return{...e,formData:Io.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...e,config:o.payload};default:return e}}var Lo=_react.createContext.call(void 0, void 0),Ao=({children:e,initialScreen:o="login",config:r,autoReadFromCookies:t=!0})=>{let[l,a]=_react.useReducer.call(void 0, br,{...Io,currentScreen:o});_react.useEffect.call(void 0, ()=>{a({type:"INIT_CONFIG",payload:(()=>{let n={};if(t)try{let s=_chunkFC7HOMNQjs.a.call(void 0, "logo");if(s){let p=decodeURIComponent(s);p.startsWith("http")&&(n.logo=p)}}catch(s){console.error("Error reading configuration from cookies:",s)}return{publicApiKey:_optionalChain([r, 'optionalAccess', _5 => _5.publicApiKey]),env:_optionalChain([r, 'optionalAccess', _6 => _6.env]),appName:_optionalChain([r, 'optionalAccess', _7 => _7.appName]),logo:_optionalChain([r, 'optionalAccess', _8 => _8.logo])||n.logo,loginActions:_optionalChain([r, 'optionalAccess', _9 => _9.loginActions])}})()})},[r,t]),_react.useEffect.call(void 0, ()=>{let f=new URLSearchParams(window.location.search),n={};f.forEach((s,p)=>{n[p]=s}),Object.keys(n).length>0&&a({type:"SET_SEARCH_PARAMS",payload:n}),o==="checkCode"&&n.email&&a({type:"UPDATE_FORM_DATA",payload:{email:n.email,code:n.code||""}}),o==="resetPassword"&&n.link&&a({type:"SET_SEARCH_PARAMS",payload:n})},[o]);let w={state:l,dispatch:a,setScreen:(f,n)=>{a({type:"SET_SCREEN",payload:{screen:f,params:n}})},updateFormData:f=>{a({type:"UPDATE_FORM_DATA",payload:f})},setFieldError:(f,n)=>{a({type:"SET_ERRORS",payload:{[f]:n}})},clearErrors:()=>{a({type:"CLEAR_ERRORS"})},setLoading:f=>{a({type:"SET_LOADING",payload:f})}};return _jsxruntime.jsx.call(void 0, Lo.Provider,{value:w,children:e})},Fe=()=>{let e=_react.useContext.call(void 0, Lo);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};var Rr=({onScreenChange:e,onExternalNavigate:o,onLoginSuccess:r,onError:t,redirectUrl:l="/"})=>{let{crudify:a}=_chunkWUOGD7AZjs.c.call(void 0, ),{state:i,updateFormData:d,setFieldError:c,clearErrors:h,setLoading:u}=Fe(),{login:w}=_chunkWUOGD7AZjs.j.call(void 0, ),f=j(),{t:n}=f,s=f.i18n,p=_react.useRef.call(void 0, null),y=_chunkFC7HOMNQjs.g.call(void 0, n,{currentLanguage:_optionalChain([s, 'optionalAccess', _10 => _10.language]),enableDebug:!1}),P=()=>{if(i.searchParams.redirect)try{let g=decodeURIComponent(i.searchParams.redirect);if(g.startsWith("/")&&!g.startsWith("//"))return g}catch (e5){}return l||"/"};_react.useEffect.call(void 0, ()=>{let g=setTimeout(()=>{p.current&&p.current.focus()},100);return()=>clearTimeout(g)},[]);let m=g=>{console.log("\u{1F50D} [LoginForm] Translating parsed error:",g);let T=y.translateError({code:g.code,message:g.message,field:g.field});return console.log("\u{1F50D} [LoginForm] Translation result:",T),T},b=async()=>{if(!i.loading){if(!i.formData.username.trim()){c("username",n("login.usernameRequired"));return}if(!i.formData.password.trim()){c("password",n("login.passwordRequired"));return}h(),u(!0);try{let g=await w(i.formData.username,i.formData.password);if(u(!1),g.success){console.log("\u{1F510} LoginForm - Login successful via SessionProvider, calling onLoginSuccess");let T=P();r&&r(g.data,T)}else{let T=g.rawResponse||g;O(T)}}catch(g){u(!1);let S=_chunkYIIUEOXCjs.g.call(void 0, g).map(m);c("global",S),t&&t(S.join(", "))}}},O=g=>{let T=_chunkYIIUEOXCjs.g.call(void 0, g),S=[];T.forEach(F=>{F.field?c(F.field,m(F)):S.push(m(F))}),S.length>0&&c("global",S)};return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),b()},onKeyDown:g=>{g.key==="Enter"&&!i.loading&&(g.preventDefault(),b())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:n("login.usernameOrEmailLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"email",name:"email",type:"email",value:i.formData.username,disabled:i.loading,onChange:g=>d({username:g.target.value}),error:!!i.errors.username,helperText:i.errors.username,autoComplete:"email",placeholder:n("login.usernameOrEmailPlaceholder"),inputRef:p,required:!0})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:n("login.passwordLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"password",name:"password",type:"password",value:i.formData.password,disabled:i.loading,onChange:g=>d({password:g.target.value}),error:!!i.errors.password,helperText:i.errors.password,autoComplete:"current-password",placeholder:n("login.passwordPlaceholder"),required:!0})]}),_optionalChain([i, 'access', _11 => _11.config, 'access', _12 => _12.loginActions, 'optionalAccess', _13 => _13.includes, 'call', _14 => _14("forgotPassword")])&&_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:()=>{_optionalChain([e, 'optionalCall', _15 => _15("forgotPassword",i.searchParams)])},variant:"body2",color:"secondary",children:n("login.forgotPasswordLink")})}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:i.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:i.loading?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):n("login.loginButton")})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:i.errors.global&&i.errors.global.length>0&&i.errors.global.map((g,T)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",sx:{mt:2},severity:"error",children:_jsxruntime.jsx.call(void 0, "div",{children:g})},T))}),_optionalChain([i, 'access', _16 => _16.config, 'access', _17 => _17.loginActions, 'optionalAccess', _18 => _18.includes, 'call', _19 => _19("createUser")])&&_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[n("login.noAccountPrompt")," ",_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:()=>{let T=`/public/users/create${Object.keys(i.searchParams).length>0?`?${new URLSearchParams(i.searchParams).toString()}`:""}`;_optionalChain([o, 'optionalCall', _20 => _20(T)])},fontWeight:"medium",color:"secondary",children:n("login.signUpLink")})]})]})},Oo=Rr;var Or=({onScreenChange:e,onError:o})=>{let{crudify:r}=_chunkWUOGD7AZjs.c.call(void 0, ),[t,l]=_react.useState.call(void 0, ""),[a,i]=_react.useState.call(void 0, !1),[d,c]=_react.useState.call(void 0, []),[h,u]=_react.useState.call(void 0, null),[w,f]=_react.useState.call(void 0, !1),[n,s]=_react.useState.call(void 0, !1),p=_react.useRef.call(void 0, null),{t:y}=j();_react.useEffect.call(void 0, ()=>{p.current&&!w&&!n&&p.current.focus()},[w,n]);let P=g=>{let T=[`errors.auth.${g.code}`,`errors.data.${g.code}`,`errors.system.${g.code}`,`errors.${g.code}`,`forgotPassword.${g.code.toLowerCase()}`];for(let S of T){let F=y(S);if(F!==S)return F}return g.message||y("error.unknown")},m=g=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(g),b=async()=>{if(!(a||!r)){if(c([]),u(null),!t){u(y("forgotPassword.emailRequired"));return}if(!m(t)){u(y("forgotPassword.invalidEmail"));return}i(!0);try{let g=[{operation:"requestPasswordReset",data:{email:t}}],T=await r.transaction(g);if(T.success)T.data&&T.data.existingCodeValid?s(!0):f(!0);else{let F=_chunkYIIUEOXCjs.g.call(void 0, T).map(P);c(F)}}catch(g){let S=_chunkYIIUEOXCjs.g.call(void 0, g).map(P);c(S),o&&o(S.join(", "))}finally{i(!1)}}},O=()=>{_optionalChain([e, 'optionalCall', _21 => _21("login")])},oe=()=>{if(w||n){_optionalChain([e, 'optionalCall', _22 => _22("checkCode",{email:t})]);return}if(!t){u(y("forgotPassword.emailRequired"));return}if(!m(t)){u(y("forgotPassword.invalidEmail"));return}_optionalChain([e, 'optionalCall', _23 => _23("checkCode",{email:t})])};return w||n?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:y(n?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:n?"success.main":"grey.600"},children:y("forgotPassword.checkEmailInstructions")})]}),_jsxruntime.jsx.call(void 0, _material.Button,{type:"button",onClick:oe,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:y("forgotPassword.enterCodeLink")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:O,variant:"body2",color:"secondary",children:y("common.back")})})]})}):_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),b()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:y("forgotPassword.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.600"},children:y("forgotPassword.instructions")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:y("forgotPassword.emailLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:a,onChange:g=>l(g.target.value),error:!!h,helperText:h,autoComplete:"email",placeholder:y("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:p})]}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:a,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:a?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):y("forgotPassword.sendCodeButton")}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:O,variant:"body2",color:"secondary",children:y("common.back")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:oe,variant:"body2",color:"secondary",children:y("login.alreadyHaveCodeLink")})]})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:d.length>0&&d.map((g,T)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",sx:{mt:2},severity:"error",children:g},T))})]})},Bo=Or;var Br=({onScreenChange:e,onError:o,searchParams:r,onResetSuccess:t})=>{let{crudify:l}=_chunkWUOGD7AZjs.c.call(void 0, ),[a,i]=_react.useState.call(void 0, ""),[d,c]=_react.useState.call(void 0, ""),[h,u]=_react.useState.call(void 0, !1),[w,f]=_react.useState.call(void 0, []),[n,s]=_react.useState.call(void 0, null),[p,y]=_react.useState.call(void 0, null),[P,m]=_react.useState.call(void 0, ""),[b,O]=_react.useState.call(void 0, ""),[oe,v]=_react.useState.call(void 0, !1),[g,T]=_react.useState.call(void 0, !0),[S,F]=_react.useState.call(void 0, !1),[de,Pe]=_react.useState.call(void 0, null),[fe,Ae]=_react.useState.call(void 0, !1),{t:A}=j(),M=C=>{let R=[`errors.auth.${C.code}`,`errors.data.${C.code}`,`errors.system.${C.code}`,`errors.${C.code}`,`resetPassword.${C.code.toLowerCase()}`];for(let k of R){let q=A(k);if(q!==k)return q}return C.message||A("error.unknown")},D=C=>r?r instanceof URLSearchParams?r.get(C):r[C]||null:null;_react.useEffect.call(void 0, ()=>{if(r){if(r){let C=D("fromCodeVerification"),R=D("email"),k=D("code");if(C==="true"&&R&&k){m(R),O(k),v(!0),F(!0),T(!1);return}let q=D("link");if(q)try{let G=decodeURIComponent(q),[Y,xe]=G.split("/");if(Y&&xe&&Y.length===6){O(Y),m(xe),v(!1),Pe({email:xe,code:Y});return}}catch (e6){}if(R&&k){m(R),O(k),v(!1),Pe({email:R,code:k});return}}f([A("resetPassword.invalidCode")]),T(!1),setTimeout(()=>_optionalChain([e, 'optionalCall', _24 => _24("forgotPassword")]),3e3)}},[r,l,A,e]),_react.useEffect.call(void 0, ()=>{l&&de&&!fe&&(Ae(!0),(async(R,k)=>{try{let q=[{operation:"validatePasswordResetCode",data:{email:R,codePassword:k}}],G=await l.transaction(q);if(G.data&&Array.isArray(G.data)){let Y=G.data[0];if(Y&&Y.response&&Y.response.status==="OK"){F(!0);return}}if(G.success)F(!0);else{let xe=_chunkYIIUEOXCjs.g.call(void 0, G).map(M);f(xe),setTimeout(()=>_optionalChain([e, 'optionalCall', _25 => _25("forgotPassword")]),3e3)}}catch(q){let Y=_chunkYIIUEOXCjs.g.call(void 0, q).map(M);f(Y),setTimeout(()=>_optionalChain([e, 'optionalCall', _26 => _26("forgotPassword")]),3e3)}finally{T(!1),Pe(null),Ae(!1)}})(de.email,de.code))},[l,de,A,e]);let Ce=C=>C.length<8?A("resetPassword.passwordTooShort"):null,E=async()=>{if(h||!l)return;f([]),s(null),y(null);let C=!1;if(!a)s(A("resetPassword.newPasswordRequired")),C=!0;else{let R=Ce(a);R&&(s(R),C=!0)}if(d?a!==d&&(y(A("resetPassword.passwordsDoNotMatch")),C=!0):(y(A("resetPassword.confirmPasswordRequired")),C=!0),!C){u(!0);try{let R=[{operation:"validateAndResetPassword",data:{email:P,codePassword:b,newPassword:a}}],k=await l.transaction(R);if(k.success)f([]),setTimeout(()=>{_optionalChain([t, 'optionalCall', _27 => _27()])},1e3);else{let G=_chunkYIIUEOXCjs.g.call(void 0, k).map(M);f(G)}}catch(R){let q=_chunkYIIUEOXCjs.g.call(void 0, R).map(M);f(q),o&&o(q.join(", "))}u(!1)}},W=()=>{oe?_optionalChain([e, 'optionalCall', _28 => _28("checkCode",{email:P})]):_optionalChain([e, 'optionalCall', _29 => _29("forgotPassword")])};return g?_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:_jsxruntime.jsx.call(void 0, _material.CircularProgress,{})}):S?_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:A("resetPassword.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.600"},children:A("resetPassword.instructions")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:A("resetPassword.newPasswordLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:a,disabled:h,onChange:C=>i(C.target.value),error:!!n,helperText:n,autoComplete:"new-password",placeholder:A("resetPassword.newPasswordPlaceholder"),required:!0})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:A("resetPassword.confirmPasswordLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:d,disabled:h,onChange:C=>c(C.target.value),error:!!p,helperText:p,autoComplete:"new-password",placeholder:A("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:h,type:"button",onClick:E,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:h?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):A("resetPassword.resetPasswordButton")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:W,variant:"body2",color:"secondary",children:A("common.back")})})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:w.length>0&&w.map((C,R)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",sx:{mt:2},severity:"error",children:C},R))})]}):_jsxruntime.jsx.call(void 0, _material.Box,{children:w.length>0&&w.map((C,R)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",sx:{mt:2},severity:"error",children:C},R))})},Mo=Br;var Hr=({onScreenChange:e,onError:o,searchParams:r})=>{let{crudify:t}=_chunkWUOGD7AZjs.c.call(void 0, ),[l,a]=_react.useState.call(void 0, ""),[i,d]=_react.useState.call(void 0, !1),[c,h]=_react.useState.call(void 0, []),[u,w]=_react.useState.call(void 0, null),[f,n]=_react.useState.call(void 0, ""),s=_react.useRef.call(void 0, null),{t:p}=j(),y=v=>r?r instanceof URLSearchParams?r.get(v):r[v]||null:null,P=v=>{let g=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`checkCode.${v.code.toLowerCase()}`];for(let T of g){let S=p(T);if(S!==T)return S}return v.message||p("error.unknown")};_react.useEffect.call(void 0, ()=>{let v=y("email");v?n(v):_optionalChain([e, 'optionalCall', _30 => _30("forgotPassword")])},[r,e]),_react.useEffect.call(void 0, ()=>{s.current&&s.current.focus()},[]);let m=async()=>{if(!(i||!t)){if(h([]),w(null),!l){w(p("checkCode.codeRequired"));return}if(l.length!==6){w(p("checkCode.codeRequired"));return}d(!0);try{let v=[{operation:"validatePasswordResetCode",data:{email:f,codePassword:l}}],g=await t.transaction(v);if(g.success)_optionalChain([e, 'optionalCall', _31 => _31("resetPassword",{email:f,code:l,fromCodeVerification:"true"})]);else{let S=_chunkYIIUEOXCjs.g.call(void 0, g).map(P);h(S),d(!1)}}catch(v){let T=_chunkYIIUEOXCjs.g.call(void 0, v).map(P);h(T),d(!1),o&&o(T.join(", "))}}},b=()=>{_optionalChain([e, 'optionalCall', _32 => _32("forgotPassword")])},O=v=>{let g=v.target.value.replace(/\D/g,"").slice(0,6);a(g)};return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,onSubmit:v=>{v.preventDefault(),m()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p("checkCode.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.600"},children:p("checkCode.instructions")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:p("checkCode.codeLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"code",name:"code",type:"text",value:l,disabled:i,onChange:O,error:!!u,helperText:u,placeholder:p("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:s})]}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:i||l.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:i?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):p("checkCode.verifyButton")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:b,variant:"body2",color:"secondary",children:p("common.back")})})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:c.length>0&&c.map((v,g)=>_jsxruntime.jsx.call(void 0, _material.Alert,{sx:{mt:2},severity:"error",children:v},g))})]})},qo=Hr;var jo=({children:e,fallback:o})=>{let{isLoading:r,error:t,isInitialized:l}=_chunkWUOGD7AZjs.c.call(void 0, ),{t:a}=j();return r?o||_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[_jsxruntime.jsx.call(void 0, _material.CircularProgress,{}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",children:a("login.initializing")!=="login.initializing"?a("login.initializing"):"Initializing..."})]}):t?_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mt:2},children:_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",children:[a("login.initializationError")!=="login.initializationError"?a("login.initializationError"):"Initialization error",":"," ",t]})}):l?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e}):_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"warning",sx:{mt:2},children:_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",children:a("login.notInitialized")!=="login.notInitialized"?a("login.notInitialized"):"System not initialized"})})};var Qr=({onScreenChange:e,onExternalNavigate:o,onLoginSuccess:r,onError:t,redirectUrl:l="/"})=>{let{t:a}=j(),{state:i,setScreen:d}=Fe(),{config:c}=_chunkWUOGD7AZjs.j.call(void 0, ),{showNotification:h}=_chunkWUOGD7AZjs.h.call(void 0, ),u=(f,n)=>{let s=n;f==="login"?s={}:f==="forgotPassword"&&!n&&(s={}),d(f,s),_optionalChain([e, 'optionalCall', _33 => _33(f,s)])},w=()=>{let f={onScreenChange:u,onExternalNavigate:o,onError:t,redirectUrl:l};switch(i.currentScreen){case"forgotPassword":return _jsxruntime.jsx.call(void 0, Bo,{...f});case"checkCode":return _jsxruntime.jsx.call(void 0, qo,{...f,searchParams:i.searchParams});case"resetPassword":return _jsxruntime.jsx.call(void 0, Mo,{...f,searchParams:i.searchParams,onResetSuccess:()=>{let n=a("resetPassword.successMessage");h(n,"success"),u("login")}});default:return _jsxruntime.jsx.call(void 0, Oo,{...f,onLoginSuccess:r})}};return _jsxruntime.jsxs.call(void 0, jo,{children:[_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",mb:3},children:_jsxruntime.jsx.call(void 0, "img",{src:c.logo||"https://logos.crudia.com/nocios-default.png",alt:a("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:f=>{let n=f.target;n.src="https://logos.crudia.com/nocios-default.png"}})}),!c.logo&&c.appName&&_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:c.appName}),w()]})},Xr=({translations:e,translationsUrl:o,language:r="en",initialScreen:t="login",autoReadFromCookies:l=!0,...a})=>{let{config:i}=_chunkWUOGD7AZjs.j.call(void 0, );return _jsxruntime.jsx.call(void 0, Ro,{translations:e,translationsUrl:o,language:r,children:_jsxruntime.jsx.call(void 0, _chunkWUOGD7AZjs.b,{config:i,children:_jsxruntime.jsx.call(void 0, Ao,{config:i,initialScreen:t,autoReadFromCookies:l,children:_jsxruntime.jsx.call(void 0, Qr,{...a})})})})},vs= exports.h =Xr;var _iconsmaterial = require('@mui/icons-material');var yt=({showExtendedData:e=!0,showProfileCard:o=!0,autoRefresh:r=!0})=>{let{userProfile:t,loading:l,error:a,extendedData:i,refreshProfile:d}=_chunkWUOGD7AZjs.l.call(void 0, {autoFetch:r,retryOnError:!0,maxRetries:3}),[c,h]=_react.useState.call(void 0, !1);if(l)return _jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[_jsxruntime.jsx.call(void 0, _material.CircularProgress,{}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(a)return _jsxruntime.jsxs.call(void 0, _material.Alert,{severity:"error",action:_jsxruntime.jsx.call(void 0, _material.IconButton,{color:"inherit",size:"small",onClick:d,children:_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",a]});if(!t)return _jsxruntime.jsx.call(void 0, _material.Alert,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let u=_optionalChain([i, 'optionalAccess', _34 => _34.displayData])||{},w=_optionalChain([i, 'optionalAccess', _35 => _35.totalFields])||0,f=m=>{if(!m)return"No disponible";try{return new Date(m).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch (e7){return m}},n=(m,b)=>b==null?"No disponible":typeof b=="boolean"?b?"S\xED":"No":Array.isArray(b)?b.length>0?b.join(", "):"Ninguno":typeof b=="object"?JSON.stringify(b,null,2):String(b),s=[{key:"id",label:"ID",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Badge,{})},{key:"email",label:"Email",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Email,{})},{key:"username",label:"Usuario",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Person,{})},{key:"fullName",label:"Nombre completo",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.AccountCircle,{})},{key:"role",label:"Rol",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Security,{})}],p=[{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"}],y=[...s.map(m=>m.key),...p.map(m=>m.key),"permissions"],P=Object.keys(u).filter(m=>!y.includes(m)).map(m=>({key:m,label:m}));return _jsxruntime.jsxs.call(void 0, _material.Box,{children:[o&&_jsxruntime.jsx.call(void 0, _material.Card,{sx:{mb:2},children:_jsxruntime.jsxs.call(void 0, _material.CardContent,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",alignItems:"center",mb:2,children:[_jsxruntime.jsx.call(void 0, _material.Avatar,{src:u.avatar,sx:{width:56,height:56,mr:2},children:_optionalChain([u, 'access', _36 => _36.fullName, 'optionalAccess', _37 => _37[0]])||_optionalChain([u, 'access', _38 => _38.username, 'optionalAccess', _39 => _39[0]])||_optionalChain([u, 'access', _40 => _40.email, 'optionalAccess', _41 => _41[0]])}),_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",children:u.fullName||u.username||u.email}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",children:u.role||"Usuario"}),u.isActive!==void 0&&_jsxruntime.jsx.call(void 0, _material.Chip,{label:u.isActive?"Activo":"Inactivo",color:u.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),_jsxruntime.jsx.call(void 0, _material.Box,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:s.map(({key:m,label:b,icon:O})=>u[m]?_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",alignItems:"center",children:[_jsxruntime.jsx.call(void 0, _material.Box,{sx:{mr:1,color:"text.secondary"},children:O}),_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",children:b}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",children:n(m,u[m])})]})]},m):null)}),u.permissions&&Array.isArray(u.permissions)&&u.permissions.length>0&&_jsxruntime.jsxs.call(void 0, _material.Box,{mt:2,children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[u.permissions.slice(0,5).map((m,b)=>_jsxruntime.jsx.call(void 0, _material.Chip,{label:m,size:"small",variant:"outlined"},b)),u.permissions.length>5&&_jsxruntime.jsx.call(void 0, _material.Chip,{label:`+${u.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&_jsxruntime.jsx.call(void 0, _material.Card,{children:_jsxruntime.jsxs.call(void 0, _material.CardContent,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"h6",display:"flex",alignItems:"center",children:[_jsxruntime.jsx.call(void 0, _iconsmaterial.Info,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),_jsxruntime.jsx.call(void 0, _material.Chip,{label:`${w} campos totales`,size:"small"})]}),_jsxruntime.jsxs.call(void 0, _material.List,{dense:!0,children:[p.map(({key:m,label:b})=>u[m]!==void 0&&_jsxruntime.jsxs.call(void 0, _material.ListItem,{divider:!0,children:[_jsxruntime.jsx.call(void 0, _material.ListItemIcon,{children:_jsxruntime.jsx.call(void 0, _iconsmaterial.Schedule,{fontSize:"small"})}),_jsxruntime.jsx.call(void 0, _material.ListItemText,{primary:b,secondary:m.includes("At")||m.includes("Login")?f(u[m]):n(m,u[m])})]},m)),P.length>0&&_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, _material.Divider,{sx:{my:1}}),_jsxruntime.jsx.call(void 0, _material.ListItem,{children:_jsxruntime.jsx.call(void 0, _material.ListItemText,{primary:_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"subtitle2",children:["Campos Personalizados (",P.length,")"]}),_jsxruntime.jsx.call(void 0, _material.IconButton,{size:"small",onClick:()=>h(!c),children:c?_jsxruntime.jsx.call(void 0, _iconsmaterial.ExpandLess,{}):_jsxruntime.jsx.call(void 0, _iconsmaterial.ExpandMore,{})})]})})}),_jsxruntime.jsx.call(void 0, _material.Collapse,{in:c,children:P.map(({key:m,label:b})=>_jsxruntime.jsx.call(void 0, _material.ListItem,{sx:{pl:4},children:_jsxruntime.jsx.call(void 0, _material.ListItemText,{primary:b,secondary:n(m,u[m])})},m))})]})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",f(u.updatedAt)]}),_jsxruntime.jsx.call(void 0, _material.IconButton,{size:"small",onClick:d,disabled:l,children:_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",children:"Actualizar"})})]})]})})]})},ht= exports.i =yt;var Jo=["create","read","update","delete"],Qo= exports.k =["create","read","update","delete"];var _reacti18next = require('react-i18next');var It=({value:e,onChange:o,availableFields:r,error:t,disabled:l=!1})=>{let{t:a}=_reacti18next.useTranslation.call(void 0, ),[i,d]=_react.useState.call(void 0, "custom"),c=_react.useRef.call(void 0, !1);_react.useEffect.call(void 0, ()=>{let n=e||{allow:[],owner_allow:[],deny:[]},s=new Set(r),p=(n.allow||[]).filter(b=>s.has(b)),y=(n.owner_allow||[]).filter(b=>s.has(b)),P=(n.deny||[]).filter(b=>s.has(b));r.forEach(b=>{!p.includes(b)&&!y.includes(b)&&!P.includes(b)&&P.push(b)});let m={allow:p,owner_allow:y,deny:P};JSON.stringify(m)!==JSON.stringify(n)&&o(m),p.length===r.length?d("all"):P.length===r.length?d("none"):d("custom")},[r,e]);let h=()=>{c.current=!0,o({allow:[...r],owner_allow:[],deny:[]}),d("all"),setTimeout(()=>{c.current=!1},0)},u=()=>{c.current=!0,o({allow:[],owner_allow:[],deny:[...r]}),d("none"),setTimeout(()=>{c.current=!1},0)},w=n=>_optionalChain([e, 'optionalAccess', _42 => _42.allow, 'optionalAccess', _43 => _43.includes, 'call', _44 => _44(n)])?"allow":_optionalChain([e, 'optionalAccess', _45 => _45.owner_allow, 'optionalAccess', _46 => _46.includes, 'call', _47 => _47(n)])?"owner_allow":"deny",f=(n,s)=>{c.current=!0;let p=new Set(_optionalChain([e, 'optionalAccess', _48 => _48.allow])||[]),y=new Set(_optionalChain([e, 'optionalAccess', _49 => _49.owner_allow])||[]),P=new Set(_optionalChain([e, 'optionalAccess', _50 => _50.deny])||[]);p.delete(n),y.delete(n),P.delete(n),s==="allow"&&p.add(n),s==="owner_allow"&&y.add(n),s==="deny"&&P.add(n),o({allow:Array.from(p),owner_allow:Array.from(y),deny:Array.from(P)}),d("custom"),setTimeout(()=>{c.current=!1},0)};return r.length===0?_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:1},children:a("modules.form.publicPolicies.fields.conditions.label")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:a("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),t&&_jsxruntime.jsx.call(void 0, _material.FormHelperText,{error:!0,sx:{mt:1},children:t})]}):_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:2},children:a("modules.form.publicPolicies.fields.conditions.label")}),_jsxruntime.jsxs.call(void 0, _material.Stack,{direction:"row",spacing:1,sx:{mb:3},children:[_jsxruntime.jsx.call(void 0, _material.Button,{variant:i==="all"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.SelectAll,{}),onClick:h,disabled:l,size:"small",sx:{minWidth:120,...i==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:a("modules.form.publicPolicies.fields.conditions.allFields")}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:i==="none"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.ClearAll,{}),onClick:u,disabled:l,size:"small",sx:{minWidth:120,...i==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:a("modules.form.publicPolicies.fields.conditions.noFields")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:2},children:a("modules.form.publicPolicies.fields.conditions.help")}),_jsxruntime.jsx.call(void 0, _material.Stack,{spacing:1,children:r.map(n=>{let s=w(n);return _jsxruntime.jsxs.call(void 0, _material.Stack,{direction:"row",spacing:1,alignItems:"center",children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:n}),_jsxruntime.jsxs.call(void 0, _material.ToggleButtonGroup,{value:s,exclusive:!0,size:"small",children:[_jsxruntime.jsxs.call(void 0, _material.ToggleButton,{value:"allow",onClick:()=>f(n,"allow"),disabled:l,sx:{px:2,color:s==="allow"?"#ffffff":"#6b7280",backgroundColor:s==="allow"?"#16a34a":"#f3f4f6",borderColor:s==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:s==="allow"?"#15803d":"#e5e7eb",borderColor:s==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[_jsxruntime.jsx.call(void 0, _iconsmaterial.CheckCircle,{sx:{fontSize:16,mr:.5}}),a("modules.form.publicPolicies.fields.conditions.states.allow")]}),_jsxruntime.jsx.call(void 0, _material.ToggleButton,{value:"owner_allow",onClick:()=>f(n,"owner_allow"),disabled:l,sx:{px:2,color:s==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:s==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:s==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:s==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:s==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:a("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),_jsxruntime.jsxs.call(void 0, _material.ToggleButton,{value:"deny",onClick:()=>f(n,"deny"),disabled:l,sx:{px:2,color:s==="deny"?"#ffffff":"#6b7280",backgroundColor:s==="deny"?"#dc2626":"#f3f4f6",borderColor:s==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:s==="deny"?"#b91c1c":"#e5e7eb",borderColor:s==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[_jsxruntime.jsx.call(void 0, _iconsmaterial.Cancel,{sx:{fontSize:16,mr:.5}}),a("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},n)})})]}),t&&_jsxruntime.jsx.call(void 0, _material.FormHelperText,{error:!0,sx:{mt:1},children:t})]})},to=It;var Mt=_react.forwardRef.call(void 0, ({policy:e,onChange:o,onRemove:r,availableFields:t,isSubmitting:l=!1,usedActions:a,error:i},d)=>{let{t:c}=_reacti18next.useTranslation.call(void 0, ),h=new Set(Array.from(a||[]));h.delete(e.action);let u=Jo.map(w=>({value:w,label:c(`modules.form.publicPolicies.fields.action.options.${w}`)}));return _jsxruntime.jsxs.call(void 0, _material.Paper,{ref:d,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:c("modules.form.publicPolicies.policyTitle")}),_jsxruntime.jsx.call(void 0, _material.IconButton,{onClick:r,size:"small",disabled:l,"aria-label":c("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:_jsxruntime.jsx.call(void 0, _iconsmaterial.Delete,{})})]}),_jsxruntime.jsxs.call(void 0, _material.Stack,{spacing:3,children:[_jsxruntime.jsx.call(void 0, _material.Stack,{direction:{xs:"column",md:"row"},spacing:2,children:_jsxruntime.jsx.call(void 0, _material.Box,{sx:{flex:1,minWidth:200},children:_jsxruntime.jsxs.call(void 0, _material.FormControl,{fullWidth:!0,children:[_jsxruntime.jsx.call(void 0, _material.InputLabel,{children:c("modules.form.publicPolicies.fields.action.label")}),_jsxruntime.jsx.call(void 0, _material.Select,{value:e.action,label:c("modules.form.publicPolicies.fields.action.label"),disabled:l,onChange:w=>{let f=w.target.value,n={...e,action:f};f==="delete"?(n.permission="deny",delete n.fields):(n.fields={allow:[],owner_allow:[],deny:t},delete n.permission),o(n)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:u.map(w=>{let f=h.has(w.value);return _jsxruntime.jsx.call(void 0, _material.MenuItem,{value:w.value,disabled:f,children:w.label},w.value)})}),i&&_jsxruntime.jsx.call(void 0, _material.FormHelperText,{error:!0,children:i})]})})}),e.action==="delete"?_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:2},children:c("modules.form.publicPolicies.fields.conditions.label")}),_jsxruntime.jsxs.call(void 0, _material.Stack,{direction:"row",spacing:1,sx:{mb:3},children:[_jsxruntime.jsx.call(void 0, _material.Button,{variant:e.permission==="*"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.SelectAll,{}),onClick:()=>o({...e,permission:"*"}),disabled:l,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:c("modules.form.publicPolicies.fields.conditions.allFields")}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>o({...e,permission:"owner"}),disabled:l,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:c("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:e.permission==="deny"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.ClearAll,{}),onClick:()=>o({...e,permission:"deny"}),disabled:l,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:c("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):_jsxruntime.jsx.call(void 0, to,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:w=>o({...e,fields:w}),availableFields:t,disabled:l}),_jsxruntime.jsx.call(void 0, _material.Paper,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):_jsxruntime.jsxs.call(void 0, _material.Stack,{spacing:.5,divider:_jsxruntime.jsx.call(void 0, _material.Divider,{sx:{borderColor:"#e5e7eb"}}),children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:"#16a34a"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(_optionalChain([e, 'optionalAccess', _51 => _51.fields, 'optionalAccess', _52 => _52.allow])||[]).join(", ")||"-"]}),_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:"#0ea5e9"},children:[c("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(_optionalChain([e, 'optionalAccess', _53 => _53.fields, 'optionalAccess', _54 => _54.owner_allow])||[]).join(", ")||"-"]}),_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(_optionalChain([e, 'optionalAccess', _55 => _55.fields, 'optionalAccess', _56 => _56.deny])||[]).join(", ")||"-"]})]})})]})]})}),so=Mt;var Gt=()=>{let e=_optionalChain([globalThis, 'optionalAccess', _57 => _57.crypto]);return e&&typeof e.randomUUID=="function"?e.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},Yt=({policies:e,onChange:o,availableFields:r,errors:t,isSubmitting:l=!1})=>{let{t:a}=_reacti18next.useTranslation.call(void 0, ),i=_react.useRef.call(void 0, {}),d=new Set((e||[]).map(s=>s.action).filter(Boolean)),c=Qo.filter(s=>!d.has(s)),h=c.length>0,u=()=>{let s=c[0]||"create",p={id:Gt(),action:s};s==="delete"?p.permission="deny":p.fields={allow:[],owner_allow:[],deny:r};let y=[...e||[],p];o(y),setTimeout(()=>{let P=y.length-1,m=i.current[P];m&&m.scrollIntoView({behavior:"smooth",block:"center"})},100)},w=s=>{let p=[...e];p.splice(s,1),o(p)},f=(()=>{if(!t)return null;if(typeof t=="string")return t;let s=t._error;return typeof s=="string"?s:null})(),n=new Set((e||[]).map(s=>s.action));return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, _material.Divider,{sx:{borderColor:"#e0e4e7"}}),_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Box,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:a("modules.form.publicPolicies.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:a("modules.form.publicPolicies.description")})]})}),f&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mb:3},children:f}),_jsxruntime.jsxs.call(void 0, _material.Stack,{spacing:3,children:[(e||[]).length===0?_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"info",children:a("modules.form.publicPolicies.noPolicies")}):e.map((s,p)=>_jsxruntime.jsx.call(void 0, so,{ref:y=>{i.current[p]=y},policy:s,onChange:y=>{let P=[...e];P[p]=y,o(P)},onRemove:()=>w(p),availableFields:r,isSubmitting:l,usedActions:n,error:typeof t=="object"&&t&&s.id in t?t[s.id]:void 0},s.id)),h&&_jsxruntime.jsx.call(void 0, _material.Box,{children:_jsxruntime.jsx.call(void 0, _material.Button,{type:"button",variant:"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Add,{}),onClick:u,disabled:l,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:a("modules.form.publicPolicies.addPolicy")})})]})]})]})},la= exports.l =Yt;function pa(){let[e,o]=_react.useState.call(void 0, ""),[r,t]=_react.useState.call(void 0, ""),[l,a]=_react.useState.call(void 0, !1),{isAuthenticated:i,isLoading:d,error:c,login:h,logout:u,refreshTokens:w,clearError:f,isExpiringSoon:n,expiresIn:s}=_chunkWUOGD7AZjs.j.call(void 0, ),p=async m=>{if(m.preventDefault(),!e||!r)return;(await h(e,r)).success&&(o(""),t(""),a(!1))},y=async()=>{await u()},P=async()=>{await w()};return i?_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{maxWidth:600,mx:"auto",p:3},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",gutterBottom:!0,children:"Token Status"}),_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(s/1e3/60)," minutes"]}),n&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[_jsxruntime.jsx.call(void 0, _material.Button,{variant:"contained",onClick:P,disabled:d,startIcon:d?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:16}):null,children:"Refresh Tokens"}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:"outlined",color:"error",onClick:y,disabled:d,children:"Logout"})]}),c&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mt:2},onClose:f,children:c})]}):_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{maxWidth:400,mx:"auto",p:3},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),l?_jsxruntime.jsxs.call(void 0, "form",{onSubmit:p,children:[_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:m=>o(m.target.value),margin:"normal",required:!0,autoComplete:"email"}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,label:"Password",type:"password",value:r,onChange:m=>t(m.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),_jsxruntime.jsx.call(void 0, _material.Button,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:d,startIcon:d?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:16}):null,sx:{mt:3,mb:2},children:d?"Logging in...":"Login"})]}):_jsxruntime.jsx.call(void 0, _material.Button,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>a(!0),sx:{mt:2},children:"Show Login Form"}),c&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mt:2},onClose:f,children:c})]})}function ya(){let{isAuthenticated:e,isLoading:o,isExpiringSoon:r,expiresIn:t}=_chunkWUOGD7AZjs.j.call(void 0, );return o?_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",alignItems:"center",gap:1},children:[_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:16}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",children:"Loading session..."})]}):e?_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),r&&_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",children:"Not logged in"})}var _TextField = require('@mui/material/TextField'); var _TextField2 = _interopRequireDefault(_TextField);var _CircularProgress = require('@mui/material/CircularProgress'); var _CircularProgress2 = _interopRequireDefault(_CircularProgress);var _InputAdornment = require('@mui/material/InputAdornment'); var _InputAdornment2 = _interopRequireDefault(_InputAdornment);var _IconButton = require('@mui/material/IconButton'); var _IconButton2 = _interopRequireDefault(_IconButton);var _Refresh = require('@mui/icons-material/Refresh'); var _Refresh2 = _interopRequireDefault(_Refresh);var on=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),rn=({html:e})=>_jsxruntime.jsx.call(void 0, "span",{dangerouslySetInnerHTML:{__html:on(e)}}),Ea= exports.o =({config:e,value:o,onChange:r,label:t,error:l=!1,helperText:a,readOnly:i=!1,disabled:d=!1})=>{let{value:c,loading:h,error:u,regenerate:w}=_chunkWUOGD7AZjs.m.call(void 0, e,{autoFetch:!o,onSuccess:P=>{_optionalChain([r, 'optionalCall', _58 => _58(P)])}}),f=o||c,n=l||!!u,s=u||a,p=n&&s&&(s.toLowerCase().includes("duplicate")||s.toLowerCase().includes("duplicado")||s.toLowerCase().includes("duplicada")||s.toLowerCase().includes("unique")||s.toLowerCase().includes("\xFAnico")||s.toLowerCase().includes("unico")||s.toLowerCase().includes("\xFAnica")||s.toLowerCase().includes("unica")||s.toLowerCase().includes("already exists")||s.toLowerCase().includes("ya existe")||s.toLowerCase().includes("e11000"));return _jsxruntime.jsx.call(void 0, _TextField2.default,{label:t,fullWidth:!0,value:f,error:n,helperText:s?_jsxruntime.jsx.call(void 0, rn,{html:s}):" ",disabled:d,InputProps:{readOnly:!0,startAdornment:h?_jsxruntime.jsx.call(void 0, _InputAdornment2.default,{position:"start",children:_jsxruntime.jsx.call(void 0, _CircularProgress2.default,{size:20})}):void 0,endAdornment:p&&!h?_jsxruntime.jsx.call(void 0, _InputAdornment2.default,{position:"end",children:_jsxruntime.jsx.call(void 0, _IconButton2.default,{edge:"end",onClick:async()=>{!d&&!h&&await w()},disabled:d,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:_jsxruntime.jsx.call(void 0, _Refresh2.default,{})})}):void 0}})};exports.a = re; exports.b = tn; exports.c = nn; exports.d = qe; exports.e = _e; exports.f = pn; exports.g = xo; exports.h = vs; exports.i = ht; exports.j = Jo; exports.k = Qo; exports.l = la; exports.m = pa; exports.n = ya; exports.o = Ea;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); 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 u=e=>{let t=document.cookie.match(new RegExp("(^|;)\\s*"+e+"=([^;]+)"));return t?t[2]:null};function I(e={}){let{publicApiKey:t,env:r,appName:n,logo:i,loginActions:c,featureKeys:p,enableDebug:g=!1}=e,s={configSource:"none"},E=u("publicApiKey");if(E){let o=u("environment"),l=u("appName"),m=u("logo"),v=u("loginActions"),y=u("featureKeys"),R=u("theme");return s={publicApiKey:decodeURIComponent(E),env:o&&["dev","stg","api","prod"].includes(o)?o:"prod",appName:l?decodeURIComponent(l):void 0,logo:m?decodeURIComponent(m):void 0,loginActions:v?decodeURIComponent(v).split(",").map(f=>f.trim()).filter(Boolean):void 0,featureKeys:y?decodeURIComponent(y).split(",").map(f=>f.trim()).filter(Boolean):void 0,theme:R?(()=>{try{return JSON.parse(decodeURIComponent(R))}catch(f){g&&console.warn("[ConfigResolver] Failed to parse theme cookie:",f);return}})():void 0,configSource:"cookies"},g&&typeof window<"u"&&(window.__CRUDIFY_RESOLVED_CONFIG=s),s}return t&&(s={publicApiKey:t,env:r||"prod",appName:n,logo:i,loginActions:c,featureKeys:p,configSource:"props"},g&&typeof window<"u"&&(window.__CRUDIFY_RESOLVED_CONFIG=s)),s}function D(e={}){return I(e)}var N=["errors.{category}.{code}","errors.{code}","login.{code}","error.{code}","messages.{code}","{code}"],C={INVALID_CREDENTIALS:"auth",UNAUTHORIZED:"auth",INVALID_API_KEY:"auth",USER_NOT_FOUND:"auth",USER_NOT_ACTIVE:"auth",NO_PERMISSION:"auth",SESSION_EXPIRED:"auth",ITEM_NOT_FOUND:"data",NOT_FOUND:"data",IN_USE:"data",DUPLICATE_ENTRY:"data",FIELD_ERROR:"validation",BAD_REQUEST:"validation",INVALID_EMAIL:"validation",INVALID_CODE:"validation",REQUIRED_FIELD:"validation",INTERNAL_SERVER_ERROR:"system",DATABASE_CONNECTION_ERROR:"system",INVALID_CONFIGURATION:"system",UNKNOWN_OPERATION:"system",TIMEOUT_ERROR:"system",NETWORK_ERROR:"system",TOO_MANY_REQUESTS:"rate_limit"},S={INVALID_CREDENTIALS:"Invalid username or password",UNAUTHORIZED:"You are not authorized to perform this action",SESSION_EXPIRED:"Your session has expired. Please log in again.",USER_NOT_FOUND:"User not found",ITEM_NOT_FOUND:"Item not found",FIELD_ERROR:"Invalid field value",INTERNAL_SERVER_ERROR:"An internal error occurred",NETWORK_ERROR:"Network connection error",TIMEOUT_ERROR:"Request timeout",UNKNOWN_OPERATION:"Unknown operation",INVALID_EMAIL:"Invalid email format",INVALID_CODE:"Invalid code",TOO_MANY_REQUESTS:"Too many requests, please try again later"};function d(e,t){let{translateFn:r,currentLanguage:n,enableDebug:i}=t;i&&console.log(`\u{1F50D} [ErrorTranslation] Translating error code: ${e} (lang: ${n||"unknown"})`);let c=e.toUpperCase(),p=C[c],g=N.map(o=>o.replace("{category}",p||"general").replace("{code}",c));i&&console.log("\u{1F511} [ErrorTranslation] Searching keys:",g);for(let o of g){let l=r(o);if(i&&console.log(`\u{1F50D} [ErrorTranslation] Checking key: "${o}" -> result: "${l}" (same as key: ${l===o})`),l&&l!==o)return i&&console.log(`\u2705 [ErrorTranslation] Found translation at key: ${o} = "${l}"`),l}let s=S[c];if(s)return i&&console.log(`\u{1F504} [ErrorTranslation] Using default message: "${s}"`),s;let E=c.replace(/_/g," ").toLowerCase().replace(/\b\w/g,o=>o.toUpperCase());return i&&console.log(`\u26A0\uFE0F [ErrorTranslation] No translation found, using friendly code: "${E}"`),E}function O(e,t){return e.map(r=>d(r,t))}function b(e,t){let{enableDebug:r}=t;r&&console.log("\u{1F50D} [ErrorTranslation] Translating error:",e);let n=d(e.code,t);return n!==e.code.toUpperCase()&&n!==e.code?(r&&console.log(`\u2705 [ErrorTranslation] Using hierarchical translation: "${n}"`),e.field?`${e.field}: ${n}`:n):e.message&&!e.message.includes("Error:")&&e.message.length>0&&e.message!==e.code?(r&&console.log(`\u{1F504} [ErrorTranslation] No hierarchical translation found, using API message: "${e.message}"`),e.message):(r&&console.log(`\u26A0\uFE0F [ErrorTranslation] Using final fallback: "${n}"`),e.field?`${e.field}: ${n}`:n)}function k(e,t={}){let r={translateFn:e,currentLanguage:t.currentLanguage,enableDebug:t.enableDebug||!1};return{translateErrorCode:n=>d(n,r),translateErrorCodes:n=>O(n,r),translateError:n=>b(n,r),translateApiError:n=>_optionalChain([n, 'optionalAccess', _ => _.data, 'optionalAccess', _2 => _2.response, 'optionalAccess', _3 => _3.status])?d(n.data.response.status,r):_optionalChain([n, 'optionalAccess', _4 => _4.status])?d(n.status,r):_optionalChain([n, 'optionalAccess', _5 => _5.code])?d(n.code,r):"Unknown error"}}var h=class e{constructor(){this.listeners=new Set;this.isHandlingAuthError=!1;this.lastErrorTime=0;this.lastEventType=null;this.DEBOUNCE_TIME=1e3}static getInstance(){return e.instance||(e.instance=new e),e.instance}emit(t,r){let n=Date.now();if(this.isHandlingAuthError&&this.lastEventType===t&&n-this.lastErrorTime<this.DEBOUNCE_TIME){console.log(`\u{1F6AB} AuthEventBus: Ignoring duplicate ${t} event (debounced)`);return}this.isHandlingAuthError=!0,this.lastErrorTime=n,this.lastEventType=t,console.log(`\u{1F4E2} AuthEventBus: Emitting ${t} event`,r);let i={type:t,details:r,timestamp:n};this.listeners.forEach(c=>{try{c(i)}catch(p){console.error("AuthEventBus: Error in listener",p)}}),setTimeout(()=>{this.isHandlingAuthError=!1,this.lastEventType=null},2e3)}subscribe(t){return this.listeners.add(t),()=>{this.listeners.delete(t)}}clear(){this.listeners.clear(),this.isHandlingAuthError=!1,this.lastEventType=null}isHandling(){return this.isHandlingAuthError}},P= exports.h =h.getInstance();var a=class a{constructor(){this.isPatched=!1;this.refCount=0;this.listeners=new Set;this.originalPushState=window.history.pushState,this.originalReplaceState=window.history.replaceState}static getInstance(){return a.instance||(a.instance=new a),a.instance}subscribe(t){return this.listeners.add(t),this.refCount++,this.isPatched||this.applyPatches(),()=>{this.unsubscribe(t)}}unsubscribe(t){this.listeners.delete(t),this.refCount--,this.refCount===0&&this.isPatched&&this.removePatches()}applyPatches(){let t=this;window.history.pushState=function(...r){let n=t.originalPushState.apply(this,r);return t.notifyListeners(),n},window.history.replaceState=function(...r){let n=t.originalReplaceState.apply(this,r);return t.notifyListeners(),n},this.isPatched=!0}removePatches(){window.history.pushState=this.originalPushState,window.history.replaceState=this.originalReplaceState,this.isPatched=!1}notifyListeners(){this.listeners.forEach(t=>{try{t()}catch(r){console.error("NavigationTracker: Error in navigation listener",r)}})}static reset(){_optionalChain([a, 'access', _6 => _6.instance, 'optionalAccess', _7 => _7.isPatched])&&a.instance.removePatches(),a.instance=null}getSubscriberCount(){return this.refCount}isActive(){return this.isPatched}};a.instance=null;var T=a;var A=e=>{try{let t=e.split(".");if(t.length!==3)return console.warn("Invalid JWT format: token must have 3 parts"),null;let r=t[1],n=r+"=".repeat((4-r.length%4)%4);return JSON.parse(atob(n))}catch(t){return console.warn("Failed to decode JWT token:",t),null}},K= exports.k =()=>{try{let e=null;if(e=sessionStorage.getItem("authToken"),console.log("\u{1F50D} getCurrentUserEmail - authToken:",e?`${e.substring(0,20)}...`:null),e||(e=sessionStorage.getItem("token"),console.log("\u{1F50D} getCurrentUserEmail - token:",e?`${e.substring(0,20)}...`:null)),e||(e=localStorage.getItem("authToken")||localStorage.getItem("token"),console.log("\u{1F50D} getCurrentUserEmail - localStorage:",e?`${e.substring(0,20)}...`:null)),!e)return console.warn("\u{1F50D} getCurrentUserEmail - No token found in any storage"),null;let t=A(e);if(!t)return console.warn("\u{1F50D} getCurrentUserEmail - Failed to decode token"),null;let r=t.email||t["cognito:username"]||null;return console.log("\u{1F50D} getCurrentUserEmail - Extracted email:",r),r}catch(e){return console.warn("Failed to get current user email:",e),null}},$= exports.l =e=>{try{let t=A(e);if(!t||!t.exp)return!0;let r=Math.floor(Date.now()/1e3);return t.exp<r}catch (e2){return!0}};exports.a = u; exports.b = I; exports.c = D; exports.d = d; exports.e = O; exports.f = b; exports.g = k; exports.h = P; exports.i = T; exports.j = A; exports.k = K; exports.l = $;
@@ -0,0 +1 @@
1
+ import{b as uo,c as X,h as fo,j as ne,l as mo,m as po}from"./chunk-TZKAMU3P.mjs";import{g as V}from"./chunk-BJ6PIVZR.mjs";import{a as lo,b as co,g as go}from"./chunk-6GPSBDW6.mjs";var re={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":"Correo Electr\xF3nico","login.usernameOrEmailPlaceholder":"Ingresa tu correo electr\xF3nico","login.usernameRequired":"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..."}},tn=()=>Object.keys(re),nn=e=>re[e]||re.es;import ke from"@nocios/crudify-browser";var yo="crudify_translations_",sr=3600*1e3;function ho(e){let o=0;for(let r=0;r<e.length;r++){let t=e.charCodeAt(r);o=(o<<5)-o+t,o=o&o}return Math.abs(o).toString(36)}var qe=class e{constructor(){this.enableDebug=!1;this.initializationPromise=null;this.isInitialized=!1}static getInstance(){return e.instance||(e.instance=new e),e.instance}setDebug(o){this.enableDebug=o}async ensureCrudifyInitialized(o,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=ke.getTokenData();if(t&&t.endpoint){this.enableDebug&&console.log("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}ke.config(r);let l=await ke.init(o,this.enableDebug?"debug":"none");if(l.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(l.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(o){let{apiKey:r,featureKeys:t,crudifyEnv:l="stg",urlTranslations:a}=o;this.enableDebug&&console.log("[TranslationService] fetchTranslations called with:",{apiKeyHash:ho(r),crudifyEnv:l,featureKeys:t,hasUrlTranslations:!!a});let i=this.getFromCache(r),d=i?this.isCacheExpired(i):!0;if(i&&!d)return this.enableDebug&&console.log("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(i.data.translations,a);try{await this.ensureCrudifyInitialized(r,l)}catch(c){return console.error("[TranslationService] \u274C Failed to initialize crudify:",c),i?(console.warn("[TranslationService] \u26A0\uFE0F Using expired cache (init failed)"),this.mergeWithUrlTranslations(i.data.translations,a)):(console.warn("[TranslationService] \u26A0\uFE0F Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&console.log("[TranslationService] Fetching from API via crudify SDK");let c=await this.fetchFromAPI(t);this.hasDataChanged(i,c)||!i?this.saveToCache(r,c):this.refreshCacheTimestamp(r);let u=this.mergeWithUrlTranslations(c.translations,a);return this.enableDebug&&console.log("[TranslationService] Translations loaded:",{languages:Object.keys(u),keysCount:u[Object.keys(u)[0]]?Object.keys(u[Object.keys(u)[0]]).length:0}),u}catch(c){return console.error("[TranslationService] \u274C API fetch failed:",c),i?(console.warn("[TranslationService] \u26A0\uFE0F Using expired cache as fallback"),this.mergeWithUrlTranslations(i.data.translations,a)):(console.warn("[TranslationService] \u26A0\uFE0F Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(o){let r=await ke.getTranslation(o);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(o,r){if(!r||Object.keys(r).length===0)return o;let t={};return Object.keys(o).forEach(l=>{t[l]={...o[l],...r}}),t}hasDataChanged(o,r){if(!o||o.data.timestamp!==r.timestamp)return!0;let t=this.hashData(r.translations);return o.dataHash!==t}hashData(o){let r=JSON.stringify(o),t=0;for(let l=0;l<r.length;l++){let a=r.charCodeAt(l);t=(t<<5)-t+a,t=t&t}return t.toString(36)}saveToCache(o,r){try{let t=this.getCacheKey(o),l={data:r,cachedAt:Date.now(),dataHash:this.hashData(r.translations)};localStorage.setItem(t,JSON.stringify(l)),this.enableDebug&&console.log("[TranslationService] Saved to cache:",t)}catch(t){console.error("[TranslationService] Failed to save cache:",t)}}getFromCache(o){try{let r=this.getCacheKey(o),t=localStorage.getItem(r);return t?JSON.parse(t):null}catch(r){return console.error("[TranslationService] Failed to read cache:",r),null}}refreshCacheTimestamp(o){try{let r=this.getFromCache(o);if(r){r.cachedAt=Date.now();let t=this.getCacheKey(o);localStorage.setItem(t,JSON.stringify(r))}}catch(r){console.error("[TranslationService] Failed to refresh cache timestamp:",r)}}isCacheExpired(o){return Date.now()-o.cachedAt>sr}hasValidCache(o){let r=this.getFromCache(o);return r?!this.isCacheExpired(r):!1}getCacheKey(o){return`${yo}${ho(o)}`}getCriticalTranslationsOnly(){return re}invalidateCache(o){let r=this.getCacheKey(o);localStorage.removeItem(r),this.enableDebug&&console.log("[TranslationService] Cache invalidated:",r)}async prefetchTranslations(o){try{await this.fetchTranslations(o),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(yo));r.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&console.log(`[TranslationService] Cleared ${r.length} cache entries`)}catch(o){console.error("[TranslationService] Failed to clear caches:",o)}}},_e=qe.getInstance();import{createContext as ar,useContext as ir,useEffect as Po,useState as me,useMemo as wo,useCallback as lr}from"react";import{Fragment as dr,jsx as Ne}from"react/jsx-runtime";var Oe=null,He=!1,Co=ar(null);function bo(e,o,r){return{...e,...o,...r||{}}}function cr(e,o,r,t,l){Po(()=>{if(!t||!e||!o)return;let a=r||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!a||!a.addResourceBundle){l&&console.log("[TranslationsProvider] i18next not found, skipping auto-sync");return}l&&console.log("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:o}),Object.keys(e).forEach(i=>{e[i]&&Object.keys(e[i]).length>0&&(a.addResourceBundle(i,"translation",e[i],!0,!0),l&&console.log(`[TranslationsProvider] Synced ${Object.keys(e[i]).length} keys for language: ${i}`))}),a.language!==o&&(a.changeLanguage(o),l&&console.log(`[TranslationsProvider] Changed i18next language to: ${o}`))},[e,o,r,t,l])}var pn=({children:e,apiKey:o,crudifyEnv:r="prod",featureKeys:t,language:l="es",devTranslations:a,translationUrl:i,enableDebug:d=!1,skipAutoInit:c=!0,autoSyncI18n:h=!0,i18nInstance:u,loadingFallback:w,waitForInitialLoad:f=!0})=>{let n=wo(()=>co({publicApiKey:o,env:r,featureKeys:t,enableDebug:d}),[o,r,t,d]),s=n.publicApiKey||"",p=n.env||r||"prod",y=n.featureKeys||t,[P,m]=me({}),[b,O]=me(!0),[oe,v]=me(!0),[g,T]=me(null),[S,F]=me(void 0),[de,Pe]=me(!1),fe=lr(async()=>{if(!s){d&&console.log("[TranslationsProvider] No apiKey - skipping translation fetch"),O(!1),v(!1);return}if(de){d&&console.log("[TranslationsProvider] Skipping reload - using fallback translations");return}if(_e.hasValidCache(s)&&oe&&(d&&console.log("[TranslationsProvider] Valid cache found - not blocking initial render"),v(!1)),He&&Oe){d&&console.log("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let E=await Oe;m(E),O(!1);return}catch{d&&console.warn("[TranslationsProvider] Global fetch failed, retrying")}}He=!0,O(!0),T(null);let D;if(i)try{d&&console.log(`[TranslationsProvider] Fetching translations from URL: ${i}`);let E=await fetch(i);if(!E.ok)throw new Error(`Failed to fetch translations: ${E.statusText}`);D=await E.json(),F(D),d&&console.log("[TranslationsProvider] URL translations loaded:",{keysCount:D?Object.keys(D).length:0})}catch(E){console.error("[TranslationsProvider] Failed to load URL translations:",E),D=void 0,F(void 0)}let Ce=(async()=>{try{_e.setDebug(d);let E=await _e.fetchTranslations({apiKey:s,crudifyEnv:p,featureKeys:y,urlTranslations:D}),W={};return Object.keys(E).forEach(C=>{let R=re[C]||{},k=E[C]||{};W[C]=bo(R,k,a)}),d&&console.log("[TranslationsProvider] Loaded translations:",{languages:Object.keys(W),keysCount:Object.keys(W[l]||{}).length}),W}catch(E){console.error("[TranslationsProvider] Failed to load:",E),T(E.message),Pe(!0);let W={};return Object.keys(re).forEach(C=>{let R=re[C],k=D||S||{};W[C]=bo(R,k,a)}),d&&console.log("[TranslationsProvider] Using fallback translations (critical + URL)"),W}})();Oe=Ce;try{let E=await Ce;m(E)}finally{O(!1),v(!1),He=!1,setTimeout(()=>{Oe=null},1e3)}},[s,p,y,i,a,d,l,de]);Po(()=>{fe();let M=setInterval(fe,3600*1e3);return()=>clearInterval(M)},[fe]);let Ae=wo(()=>(M,D)=>{let E=(P[l]||{})[M];if(!E){let W=Object.keys(P);for(let C of W)if(P[C][M]){E=P[C][M];break}}return E||(d&&console.warn(`[TranslationsProvider] Missing translation: "${M}"`),E=M),D&&typeof E=="string"&&Object.entries(D).forEach(([W,C])=>{let R=new RegExp(`{{${W}}}`,"g");E=E.replace(R,String(C))}),E},[P,l,d]);cr(P,l,u,h,d);let A={t:Ae,language:l,availableLanguages:Object.keys(P),translations:P,isLoading:b,error:g,refreshTranslations:fe};return s?f&&oe&&b?w||Ne("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:Ne("div",{children:"Loading translations..."})}):Ne(Co.Provider,{value:A,children:e}):(d&&console.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),Ne(dr,{children:e}))},xo=()=>{let e=ir(Co);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};import{Box as Yr,Typography as Jr}from"@mui/material";import{createContext as gr,useContext as fr,useMemo as je}from"react";import{useState as Ke,useEffect as ur}from"react";var To=(e,o)=>{let[r,t]=Ke({}),[l,a]=Ke(!1),[i,d]=Ke(null);return ur(()=>{if(console.log("\u{1F527} [I18nProvider] Hybrid translation loading:",{hasProvidedTranslations:!!o&&Object.keys(o).length>0,hasUrl:!!e,providedKeys:o?Object.keys(o).length:0}),o&&Object.keys(o).length>0){console.log("\u2705 [I18nProvider] Using provided translations (highest priority)"),t(o),a(!1),d(null);return}if(!e){console.log("\u26A0\uFE0F [I18nProvider] No translations provided, using empty object (keys will show as-is)"),t({}),a(!1),d(null);return}console.log("\u{1F310} [I18nProvider] Loading translations from URL:",e);let c=!1;return a(!0),d(null),fetch(e).then(h=>{if(!h.ok)throw new Error(`Failed to load translations: ${h.status}`);return h.json()}).then(h=>{c||(console.log("\u2705 [I18nProvider] Translations loaded successfully from URL:",{url:e,keysLoaded:Object.keys(h).length}),t(h),a(!1))}).catch(h=>{c||(console.error("\u274C [I18nProvider] Failed to load translations from URL:",e,h),d(h.message),console.log("\u{1F504} [I18nProvider] Falling back to empty translations (keys will show as-is)"),t({}),a(!1))}),()=>{c=!0}},[e,o]),{translations:r,loading:l,error:i}};import{jsx as vo}from"react/jsx-runtime";var Eo=gr(null),mr=()=>{try{return xo()}catch{return null}},pr=(e,o)=>{if(o.includes(".")){let r=o.split(".").reduce((t,l)=>t&&typeof t=="object"?t[l]:void 0,e);if(r!==void 0)return r}if(e&&e[o])return e[o]},Ro=({children:e,translations:o,translationsUrl:r,language:t="en"})=>{let a=mr()?.translations?.[t]||{},{translations:i,loading:d}=To(r,o),c=je(()=>({...a,...i,...o||{}}),[a,i,o]),h=je(()=>(w,f)=>{let n=pr(c,w);return n==null&&(console.log(`\u{1F50D} [I18nProvider] Translation not found for key: "${w}" - showing key as-is`),n=w),f&&typeof n=="string"&&Object.entries(f).forEach(([s,p])=>{n=n.replace(new RegExp(`{{${s}}}`,"g"),p)}),typeof n=="string"?n:w},[c]),u=je(()=>({t:h,language:t}),[h,t]);return d?vo("div",{children:"Loading translations..."}):vo(Eo.Provider,{value:u,children:e})},j=()=>{let e=fr(Eo);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};import{createContext as yr,useContext as hr,useReducer as wr,useEffect as So}from"react";import{jsx as Pr}from"react/jsx-runtime";var Io={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function br(e,o){switch(o.type){case"SET_SCREEN":let r={...e,currentScreen:o.payload.screen,searchParams:o.payload.params||e.searchParams,errors:{global:[]}},t=new URLSearchParams(r.searchParams),l=t.toString()?`?${t.toString()}`:window.location.pathname;try{window.history.replaceState({},"",l)}catch{}return r;case"SET_SEARCH_PARAMS":return{...e,searchParams:o.payload};case"UPDATE_FORM_DATA":return{...e,formData:{...e.formData,...o.payload},errors:{...e.errors,...Object.keys(o.payload).reduce((a,i)=>({...a,[i]:void 0}),{})}};case"SET_LOADING":return{...e,loading:o.payload};case"SET_ERRORS":return{...e,errors:{...e.errors,...o.payload}};case"CLEAR_ERRORS":return{...e,errors:{global:[]}};case"SET_EMAIL_SENT":return{...e,emailSent:o.payload};case"SET_CODE_ALREADY_EXISTS":return{...e,codeAlreadyExists:o.payload};case"SET_CODE_VALIDATED":return{...e,codeValidated:o.payload};case"SET_FROM_CODE_VERIFICATION":return{...e,fromCodeVerification:o.payload};case"RESET_FORM":return{...e,formData:Io.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...e,config:o.payload};default:return e}}var Lo=yr(void 0),Ao=({children:e,initialScreen:o="login",config:r,autoReadFromCookies:t=!0})=>{let[l,a]=wr(br,{...Io,currentScreen:o});So(()=>{a({type:"INIT_CONFIG",payload:(()=>{let n={};if(t)try{let s=lo("logo");if(s){let p=decodeURIComponent(s);p.startsWith("http")&&(n.logo=p)}}catch(s){console.error("Error reading configuration from cookies:",s)}return{publicApiKey:r?.publicApiKey,env:r?.env,appName:r?.appName,logo:r?.logo||n.logo,loginActions:r?.loginActions}})()})},[r,t]),So(()=>{let f=new URLSearchParams(window.location.search),n={};f.forEach((s,p)=>{n[p]=s}),Object.keys(n).length>0&&a({type:"SET_SEARCH_PARAMS",payload:n}),o==="checkCode"&&n.email&&a({type:"UPDATE_FORM_DATA",payload:{email:n.email,code:n.code||""}}),o==="resetPassword"&&n.link&&a({type:"SET_SEARCH_PARAMS",payload:n})},[o]);let w={state:l,dispatch:a,setScreen:(f,n)=>{a({type:"SET_SCREEN",payload:{screen:f,params:n}})},updateFormData:f=>{a({type:"UPDATE_FORM_DATA",payload:f})},setFieldError:(f,n)=>{a({type:"SET_ERRORS",payload:{[f]:n}})},clearErrors:()=>{a({type:"CLEAR_ERRORS"})},setLoading:f=>{a({type:"SET_LOADING",payload:f})}};return Pr(Lo.Provider,{value:w,children:e})},Fe=()=>{let e=hr(Lo);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};import{useEffect as Cr,useRef as xr}from"react";import{Typography as $e,TextField as ko,Button as Tr,Box as Te,CircularProgress as vr,Alert as Er,Link as _o}from"@mui/material";import{Fragment as Sr,jsx as $,jsxs as ve}from"react/jsx-runtime";var Rr=({onScreenChange:e,onExternalNavigate:o,onLoginSuccess:r,onError:t,redirectUrl:l="/"})=>{let{crudify:a}=X(),{state:i,updateFormData:d,setFieldError:c,clearErrors:h,setLoading:u}=Fe(),{login:w}=ne(),f=j(),{t:n}=f,s=f.i18n,p=xr(null),y=go(n,{currentLanguage:s?.language,enableDebug:!1}),P=()=>{if(i.searchParams.redirect)try{let g=decodeURIComponent(i.searchParams.redirect);if(g.startsWith("/")&&!g.startsWith("//"))return g}catch{}return l||"/"};Cr(()=>{let g=setTimeout(()=>{p.current&&p.current.focus()},100);return()=>clearTimeout(g)},[]);let m=g=>{console.log("\u{1F50D} [LoginForm] Translating parsed error:",g);let T=y.translateError({code:g.code,message:g.message,field:g.field});return console.log("\u{1F50D} [LoginForm] Translation result:",T),T},b=async()=>{if(!i.loading){if(!i.formData.username.trim()){c("username",n("login.usernameRequired"));return}if(!i.formData.password.trim()){c("password",n("login.passwordRequired"));return}h(),u(!0);try{let g=await w(i.formData.username,i.formData.password);if(u(!1),g.success){console.log("\u{1F510} LoginForm - Login successful via SessionProvider, calling onLoginSuccess");let T=P();r&&r(g.data,T)}else{let T=g.rawResponse||g;O(T)}}catch(g){u(!1);let S=V(g).map(m);c("global",S),t&&t(S.join(", "))}}},O=g=>{let T=V(g),S=[];T.forEach(F=>{F.field?c(F.field,m(F)):S.push(m(F))}),S.length>0&&c("global",S)};return ve(Sr,{children:[ve(Te,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),b()},onKeyDown:g=>{g.key==="Enter"&&!i.loading&&(g.preventDefault(),b())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[ve(Te,{sx:{mb:1},children:[$($e,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:n("login.usernameOrEmailLabel")}),$(ko,{fullWidth:!0,id:"email",name:"email",type:"email",value:i.formData.username,disabled:i.loading,onChange:g=>d({username:g.target.value}),error:!!i.errors.username,helperText:i.errors.username,autoComplete:"email",placeholder:n("login.usernameOrEmailPlaceholder"),inputRef:p,required:!0})]}),ve(Te,{sx:{mb:1},children:[$($e,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:n("login.passwordLabel")}),$(ko,{fullWidth:!0,id:"password",name:"password",type:"password",value:i.formData.password,disabled:i.loading,onChange:g=>d({password:g.target.value}),error:!!i.errors.password,helperText:i.errors.password,autoComplete:"current-password",placeholder:n("login.passwordPlaceholder"),required:!0})]}),i.config.loginActions?.includes("forgotPassword")&&$(Te,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:$(_o,{sx:{cursor:"pointer"},onClick:()=>{e?.("forgotPassword",i.searchParams)},variant:"body2",color:"secondary",children:n("login.forgotPasswordLink")})}),$(Tr,{disabled:i.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:i.loading?$(vr,{size:20}):n("login.loginButton")})]}),$(Te,{children:i.errors.global&&i.errors.global.length>0&&i.errors.global.map((g,T)=>$(Er,{variant:"filled",sx:{mt:2},severity:"error",children:$("div",{children:g})},T))}),i.config.loginActions?.includes("createUser")&&ve($e,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[n("login.noAccountPrompt")," ",$(_o,{sx:{cursor:"pointer"},onClick:()=>{let T=`/public/users/create${Object.keys(i.searchParams).length>0?`?${new URLSearchParams(i.searchParams).toString()}`:""}`;o?.(T)},fontWeight:"medium",color:"secondary",children:n("login.signUpLink")})]})]})},Oo=Rr;import{useState as pe,useEffect as Ir,useRef as Lr}from"react";import{Typography as ye,TextField as Ar,Button as No,Box as se,CircularProgress as kr,Alert as _r,Link as Ge}from"@mui/material";import{Fragment as Fo,jsx as N,jsxs as ue}from"react/jsx-runtime";var Or=({onScreenChange:e,onError:o})=>{let{crudify:r}=X(),[t,l]=pe(""),[a,i]=pe(!1),[d,c]=pe([]),[h,u]=pe(null),[w,f]=pe(!1),[n,s]=pe(!1),p=Lr(null),{t:y}=j();Ir(()=>{p.current&&!w&&!n&&p.current.focus()},[w,n]);let P=g=>{let T=[`errors.auth.${g.code}`,`errors.data.${g.code}`,`errors.system.${g.code}`,`errors.${g.code}`,`forgotPassword.${g.code.toLowerCase()}`];for(let S of T){let F=y(S);if(F!==S)return F}return g.message||y("error.unknown")},m=g=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(g),b=async()=>{if(!(a||!r)){if(c([]),u(null),!t){u(y("forgotPassword.emailRequired"));return}if(!m(t)){u(y("forgotPassword.invalidEmail"));return}i(!0);try{let g=[{operation:"requestPasswordReset",data:{email:t}}],T=await r.transaction(g);if(T.success)T.data&&T.data.existingCodeValid?s(!0):f(!0);else{let F=V(T).map(P);c(F)}}catch(g){let S=V(g).map(P);c(S),o&&o(S.join(", "))}finally{i(!1)}}},O=()=>{e?.("login")},oe=()=>{if(w||n){e?.("checkCode",{email:t});return}if(!t){u(y("forgotPassword.emailRequired"));return}if(!m(t)){u(y("forgotPassword.invalidEmail"));return}e?.("checkCode",{email:t})};return w||n?N(Fo,{children:ue(se,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[ue(se,{sx:{mb:2},children:[N(ye,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:y(n?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),N(ye,{variant:"body2",sx:{color:n?"success.main":"grey.600"},children:y("forgotPassword.checkEmailInstructions")})]}),N(No,{type:"button",onClick:oe,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:y("forgotPassword.enterCodeLink")}),N(se,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:N(Ge,{sx:{cursor:"pointer"},onClick:O,variant:"body2",color:"secondary",children:y("common.back")})})]})}):ue(Fo,{children:[ue(se,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),b()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[ue(se,{sx:{mb:2},children:[N(ye,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:y("forgotPassword.title")}),N(ye,{variant:"body2",sx:{color:"grey.600"},children:y("forgotPassword.instructions")})]}),ue(se,{sx:{mb:1},children:[N(ye,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:y("forgotPassword.emailLabel")}),N(Ar,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:a,onChange:g=>l(g.target.value),error:!!h,helperText:h,autoComplete:"email",placeholder:y("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:p})]}),N(No,{disabled:a,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:a?N(kr,{size:20}):y("forgotPassword.sendCodeButton")}),ue(se,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[N(Ge,{sx:{cursor:"pointer"},onClick:O,variant:"body2",color:"secondary",children:y("common.back")}),N(ye,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),N(Ge,{sx:{cursor:"pointer"},onClick:oe,variant:"body2",color:"secondary",children:y("login.alreadyHaveCodeLink")})]})]}),N(se,{children:d.length>0&&d.map((g,T)=>N(_r,{variant:"filled",sx:{mt:2},severity:"error",children:g},T))})]})},Bo=Or;import{useState as H,useEffect as Do}from"react";import{Typography as Be,TextField as Uo,Button as Nr,Box as ae,CircularProgress as zo,Alert as Vo,Link as Fr}from"@mui/material";import{Fragment as Dr,jsx as B,jsxs as Ee}from"react/jsx-runtime";var Br=({onScreenChange:e,onError:o,searchParams:r,onResetSuccess:t})=>{let{crudify:l}=X(),[a,i]=H(""),[d,c]=H(""),[h,u]=H(!1),[w,f]=H([]),[n,s]=H(null),[p,y]=H(null),[P,m]=H(""),[b,O]=H(""),[oe,v]=H(!1),[g,T]=H(!0),[S,F]=H(!1),[de,Pe]=H(null),[fe,Ae]=H(!1),{t:A}=j(),M=C=>{let R=[`errors.auth.${C.code}`,`errors.data.${C.code}`,`errors.system.${C.code}`,`errors.${C.code}`,`resetPassword.${C.code.toLowerCase()}`];for(let k of R){let q=A(k);if(q!==k)return q}return C.message||A("error.unknown")},D=C=>r?r instanceof URLSearchParams?r.get(C):r[C]||null:null;Do(()=>{if(r){if(r){let C=D("fromCodeVerification"),R=D("email"),k=D("code");if(C==="true"&&R&&k){m(R),O(k),v(!0),F(!0),T(!1);return}let q=D("link");if(q)try{let G=decodeURIComponent(q),[Y,xe]=G.split("/");if(Y&&xe&&Y.length===6){O(Y),m(xe),v(!1),Pe({email:xe,code:Y});return}}catch{}if(R&&k){m(R),O(k),v(!1),Pe({email:R,code:k});return}}f([A("resetPassword.invalidCode")]),T(!1),setTimeout(()=>e?.("forgotPassword"),3e3)}},[r,l,A,e]),Do(()=>{l&&de&&!fe&&(Ae(!0),(async(R,k)=>{try{let q=[{operation:"validatePasswordResetCode",data:{email:R,codePassword:k}}],G=await l.transaction(q);if(G.data&&Array.isArray(G.data)){let Y=G.data[0];if(Y&&Y.response&&Y.response.status==="OK"){F(!0);return}}if(G.success)F(!0);else{let xe=V(G).map(M);f(xe),setTimeout(()=>e?.("forgotPassword"),3e3)}}catch(q){let Y=V(q).map(M);f(Y),setTimeout(()=>e?.("forgotPassword"),3e3)}finally{T(!1),Pe(null),Ae(!1)}})(de.email,de.code))},[l,de,A,e]);let Ce=C=>C.length<8?A("resetPassword.passwordTooShort"):null,E=async()=>{if(h||!l)return;f([]),s(null),y(null);let C=!1;if(!a)s(A("resetPassword.newPasswordRequired")),C=!0;else{let R=Ce(a);R&&(s(R),C=!0)}if(d?a!==d&&(y(A("resetPassword.passwordsDoNotMatch")),C=!0):(y(A("resetPassword.confirmPasswordRequired")),C=!0),!C){u(!0);try{let R=[{operation:"validateAndResetPassword",data:{email:P,codePassword:b,newPassword:a}}],k=await l.transaction(R);if(k.success)f([]),setTimeout(()=>{t?.()},1e3);else{let G=V(k).map(M);f(G)}}catch(R){let q=V(R).map(M);f(q),o&&o(q.join(", "))}u(!1)}},W=()=>{oe?e?.("checkCode",{email:P}):e?.("forgotPassword")};return g?B(ae,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:B(zo,{})}):S?Ee(Dr,{children:[Ee(ae,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Ee(ae,{sx:{mb:2},children:[B(Be,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:A("resetPassword.title")}),B(Be,{variant:"body2",sx:{color:"grey.600"},children:A("resetPassword.instructions")})]}),Ee(ae,{sx:{mb:1},children:[B(Be,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:A("resetPassword.newPasswordLabel")}),B(Uo,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:a,disabled:h,onChange:C=>i(C.target.value),error:!!n,helperText:n,autoComplete:"new-password",placeholder:A("resetPassword.newPasswordPlaceholder"),required:!0})]}),Ee(ae,{sx:{mb:1},children:[B(Be,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:A("resetPassword.confirmPasswordLabel")}),B(Uo,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:d,disabled:h,onChange:C=>c(C.target.value),error:!!p,helperText:p,autoComplete:"new-password",placeholder:A("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),B(Nr,{disabled:h,type:"button",onClick:E,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:h?B(zo,{size:20}):A("resetPassword.resetPasswordButton")}),B(ae,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:B(Fr,{sx:{cursor:"pointer"},onClick:W,variant:"body2",color:"secondary",children:A("common.back")})})]}),B(ae,{children:w.length>0&&w.map((C,R)=>B(Vo,{variant:"filled",sx:{mt:2},severity:"error",children:C},R))})]}):B(ae,{children:w.length>0&&w.map((C,R)=>B(Vo,{variant:"filled",sx:{mt:2},severity:"error",children:C},R))})},Mo=Br;import{useState as Re,useEffect as Wo,useRef as Ur}from"react";import{Typography as Ye,TextField as zr,Button as Vr,Box as Se,CircularProgress as Mr,Alert as Wr,Link as qr}from"@mui/material";import{Fragment as Kr,jsx as Z,jsxs as De}from"react/jsx-runtime";var Hr=({onScreenChange:e,onError:o,searchParams:r})=>{let{crudify:t}=X(),[l,a]=Re(""),[i,d]=Re(!1),[c,h]=Re([]),[u,w]=Re(null),[f,n]=Re(""),s=Ur(null),{t:p}=j(),y=v=>r?r instanceof URLSearchParams?r.get(v):r[v]||null:null,P=v=>{let g=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`checkCode.${v.code.toLowerCase()}`];for(let T of g){let S=p(T);if(S!==T)return S}return v.message||p("error.unknown")};Wo(()=>{let v=y("email");v?n(v):e?.("forgotPassword")},[r,e]),Wo(()=>{s.current&&s.current.focus()},[]);let m=async()=>{if(!(i||!t)){if(h([]),w(null),!l){w(p("checkCode.codeRequired"));return}if(l.length!==6){w(p("checkCode.codeRequired"));return}d(!0);try{let v=[{operation:"validatePasswordResetCode",data:{email:f,codePassword:l}}],g=await t.transaction(v);if(g.success)e?.("resetPassword",{email:f,code:l,fromCodeVerification:"true"});else{let S=V(g).map(P);h(S),d(!1)}}catch(v){let T=V(v).map(P);h(T),d(!1),o&&o(T.join(", "))}}},b=()=>{e?.("forgotPassword")},O=v=>{let g=v.target.value.replace(/\D/g,"").slice(0,6);a(g)};return De(Kr,{children:[De(Se,{component:"form",noValidate:!0,onSubmit:v=>{v.preventDefault(),m()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[De(Se,{sx:{mb:2},children:[Z(Ye,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p("checkCode.title")}),Z(Ye,{variant:"body2",sx:{color:"grey.600"},children:p("checkCode.instructions")})]}),De(Se,{sx:{mb:1},children:[Z(Ye,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:p("checkCode.codeLabel")}),Z(zr,{fullWidth:!0,id:"code",name:"code",type:"text",value:l,disabled:i,onChange:O,error:!!u,helperText:u,placeholder:p("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:s})]}),Z(Vr,{disabled:i||l.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:i?Z(Mr,{size:20}):p("checkCode.verifyButton")}),Z(Se,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:Z(qr,{sx:{cursor:"pointer"},onClick:b,variant:"body2",color:"secondary",children:p("common.back")})})]}),Z(Se,{children:c.length>0&&c.map((v,g)=>Z(Wr,{sx:{mt:2},severity:"error",children:v},g))})]})},qo=Hr;import{Box as jr,CircularProgress as $r,Alert as Ho,Typography as Je}from"@mui/material";import{Fragment as Gr,jsx as he,jsxs as Ko}from"react/jsx-runtime";var jo=({children:e,fallback:o})=>{let{isLoading:r,error:t,isInitialized:l}=X(),{t:a}=j();return r?o||Ko(jr,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[he($r,{}),he(Je,{variant:"body2",color:"text.secondary",children:a("login.initializing")!=="login.initializing"?a("login.initializing"):"Initializing..."})]}):t?he(Ho,{severity:"error",sx:{mt:2},children:Ko(Je,{variant:"body2",children:[a("login.initializationError")!=="login.initializationError"?a("login.initializationError"):"Initialization error",":"," ",t]})}):l?he(Gr,{children:e}):he(Ho,{severity:"warning",sx:{mt:2},children:he(Je,{variant:"body2",children:a("login.notInitialized")!=="login.notInitialized"?a("login.notInitialized"):"System not initialized"})})};import{jsx as J,jsxs as Zr}from"react/jsx-runtime";var Qr=({onScreenChange:e,onExternalNavigate:o,onLoginSuccess:r,onError:t,redirectUrl:l="/"})=>{let{t:a}=j(),{state:i,setScreen:d}=Fe(),{config:c}=ne(),{showNotification:h}=fo(),u=(f,n)=>{let s=n;f==="login"?s={}:f==="forgotPassword"&&!n&&(s={}),d(f,s),e?.(f,s)},w=()=>{let f={onScreenChange:u,onExternalNavigate:o,onError:t,redirectUrl:l};switch(i.currentScreen){case"forgotPassword":return J(Bo,{...f});case"checkCode":return J(qo,{...f,searchParams:i.searchParams});case"resetPassword":return J(Mo,{...f,searchParams:i.searchParams,onResetSuccess:()=>{let n=a("resetPassword.successMessage");h(n,"success"),u("login")}});default:return J(Oo,{...f,onLoginSuccess:r})}};return Zr(jo,{children:[J(Yr,{sx:{display:"flex",justifyContent:"center",mb:3},children:J("img",{src:c.logo||"https://logos.crudia.com/nocios-default.png",alt:a("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:f=>{let n=f.target;n.src="https://logos.crudia.com/nocios-default.png"}})}),!c.logo&&c.appName&&J(Jr,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:c.appName}),w()]})},Xr=({translations:e,translationsUrl:o,language:r="en",initialScreen:t="login",autoReadFromCookies:l=!0,...a})=>{let{config:i}=ne();return J(Ro,{translations:e,translationsUrl:o,language:r,children:J(uo,{config:i,children:J(Ao,{config:i,initialScreen:t,autoReadFromCookies:l,children:J(Qr,{...a})})})})},vs=Xr;import{Box as K,Card as $o,CardContent as Go,Typography as Q,Chip as Ue,Avatar as et,Divider as ot,CircularProgress as rt,Alert as Yo,List as tt,ListItem as Qe,ListItemText as Xe,ListItemIcon as nt,Collapse as st,IconButton as Ze}from"@mui/material";import{Person as at,Email as it,Badge as lt,Security as ct,Schedule as dt,AccountCircle as ut,ExpandMore as gt,ExpandLess as ft,Info as mt}from"@mui/icons-material";import{useState as pt}from"react";import{Fragment as wt,jsx as x,jsxs as I}from"react/jsx-runtime";var yt=({showExtendedData:e=!0,showProfileCard:o=!0,autoRefresh:r=!0})=>{let{userProfile:t,loading:l,error:a,extendedData:i,refreshProfile:d}=mo({autoFetch:r,retryOnError:!0,maxRetries:3}),[c,h]=pt(!1);if(l)return I(K,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[x(rt,{}),x(Q,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(a)return I(Yo,{severity:"error",action:x(Ze,{color:"inherit",size:"small",onClick:d,children:x(Q,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",a]});if(!t)return x(Yo,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let u=i?.displayData||{},w=i?.totalFields||0,f=m=>{if(!m)return"No disponible";try{return new Date(m).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return m}},n=(m,b)=>b==null?"No disponible":typeof b=="boolean"?b?"S\xED":"No":Array.isArray(b)?b.length>0?b.join(", "):"Ninguno":typeof b=="object"?JSON.stringify(b,null,2):String(b),s=[{key:"id",label:"ID",icon:x(lt,{})},{key:"email",label:"Email",icon:x(it,{})},{key:"username",label:"Usuario",icon:x(at,{})},{key:"fullName",label:"Nombre completo",icon:x(ut,{})},{key:"role",label:"Rol",icon:x(ct,{})}],p=[{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"}],y=[...s.map(m=>m.key),...p.map(m=>m.key),"permissions"],P=Object.keys(u).filter(m=>!y.includes(m)).map(m=>({key:m,label:m}));return I(K,{children:[o&&x($o,{sx:{mb:2},children:I(Go,{children:[I(K,{display:"flex",alignItems:"center",mb:2,children:[x(et,{src:u.avatar,sx:{width:56,height:56,mr:2},children:u.fullName?.[0]||u.username?.[0]||u.email?.[0]}),I(K,{children:[x(Q,{variant:"h6",children:u.fullName||u.username||u.email}),x(Q,{variant:"body2",color:"text.secondary",children:u.role||"Usuario"}),u.isActive!==void 0&&x(Ue,{label:u.isActive?"Activo":"Inactivo",color:u.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),x(K,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:s.map(({key:m,label:b,icon:O})=>u[m]?I(K,{display:"flex",alignItems:"center",children:[x(K,{sx:{mr:1,color:"text.secondary"},children:O}),I(K,{children:[x(Q,{variant:"caption",color:"text.secondary",children:b}),x(Q,{variant:"body2",children:n(m,u[m])})]})]},m):null)}),u.permissions&&Array.isArray(u.permissions)&&u.permissions.length>0&&I(K,{mt:2,children:[x(Q,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),I(K,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[u.permissions.slice(0,5).map((m,b)=>x(Ue,{label:m,size:"small",variant:"outlined"},b)),u.permissions.length>5&&x(Ue,{label:`+${u.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&x($o,{children:I(Go,{children:[I(K,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[I(Q,{variant:"h6",display:"flex",alignItems:"center",children:[x(mt,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),x(Ue,{label:`${w} campos totales`,size:"small"})]}),I(tt,{dense:!0,children:[p.map(({key:m,label:b})=>u[m]!==void 0&&I(Qe,{divider:!0,children:[x(nt,{children:x(dt,{fontSize:"small"})}),x(Xe,{primary:b,secondary:m.includes("At")||m.includes("Login")?f(u[m]):n(m,u[m])})]},m)),P.length>0&&I(wt,{children:[x(ot,{sx:{my:1}}),x(Qe,{children:x(Xe,{primary:I(K,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[I(Q,{variant:"subtitle2",children:["Campos Personalizados (",P.length,")"]}),x(Ze,{size:"small",onClick:()=>h(!c),children:c?x(ft,{}):x(gt,{})})]})})}),x(st,{in:c,children:P.map(({key:m,label:b})=>x(Qe,{sx:{pl:4},children:x(Xe,{primary:b,secondary:n(m,u[m])})},m))})]})]}),I(K,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[I(Q,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",f(u.updatedAt)]}),x(Ze,{size:"small",onClick:d,disabled:l,children:x(Q,{variant:"caption",children:"Actualizar"})})]})]})})]})},ht=yt;var Jo=["create","read","update","delete"],Qo=["create","read","update","delete"];import{useRef as Wt}from"react";import{useTranslation as qt}from"react-i18next";import{Box as Ve,Typography as or,Button as Ht,Stack as Kt,Alert as rr,Divider as jt}from"@mui/material";import{Add as $t}from"@mui/icons-material";import{forwardRef as Lt}from"react";import{useTranslation as At}from"react-i18next";import{Box as ge,FormControl as kt,InputLabel as _t,Select as Ot,MenuItem as Nt,IconButton as Ft,Typography as we,FormHelperText as Bt,Stack as ze,Paper as er,Divider as Dt,Button as no}from"@mui/material";import{Delete as Ut,SelectAll as zt,ClearAll as Vt}from"@mui/icons-material";import{useState as bt,useEffect as Pt,useRef as Ct}from"react";import{useTranslation as xt}from"react-i18next";import{Box as eo,Typography as Ie,Button as Xo,Stack as oo,FormHelperText as Zo,ToggleButton as ro,ToggleButtonGroup as Tt}from"@mui/material";import{CheckCircle as vt,Cancel as Et,SelectAll as Rt,ClearAll as St}from"@mui/icons-material";import{jsx as U,jsxs as ie}from"react/jsx-runtime";var It=({value:e,onChange:o,availableFields:r,error:t,disabled:l=!1})=>{let{t:a}=xt(),[i,d]=bt("custom"),c=Ct(!1);Pt(()=>{let n=e||{allow:[],owner_allow:[],deny:[]},s=new Set(r),p=(n.allow||[]).filter(b=>s.has(b)),y=(n.owner_allow||[]).filter(b=>s.has(b)),P=(n.deny||[]).filter(b=>s.has(b));r.forEach(b=>{!p.includes(b)&&!y.includes(b)&&!P.includes(b)&&P.push(b)});let m={allow:p,owner_allow:y,deny:P};JSON.stringify(m)!==JSON.stringify(n)&&o(m),p.length===r.length?d("all"):P.length===r.length?d("none"):d("custom")},[r,e]);let h=()=>{c.current=!0,o({allow:[...r],owner_allow:[],deny:[]}),d("all"),setTimeout(()=>{c.current=!1},0)},u=()=>{c.current=!0,o({allow:[],owner_allow:[],deny:[...r]}),d("none"),setTimeout(()=>{c.current=!1},0)},w=n=>e?.allow?.includes(n)?"allow":e?.owner_allow?.includes(n)?"owner_allow":"deny",f=(n,s)=>{c.current=!0;let p=new Set(e?.allow||[]),y=new Set(e?.owner_allow||[]),P=new Set(e?.deny||[]);p.delete(n),y.delete(n),P.delete(n),s==="allow"&&p.add(n),s==="owner_allow"&&y.add(n),s==="deny"&&P.add(n),o({allow:Array.from(p),owner_allow:Array.from(y),deny:Array.from(P)}),d("custom"),setTimeout(()=>{c.current=!1},0)};return r.length===0?ie(eo,{children:[U(Ie,{variant:"body2",color:"text.secondary",sx:{mb:1},children:a("modules.form.publicPolicies.fields.conditions.label")}),U(Ie,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:a("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),t&&U(Zo,{error:!0,sx:{mt:1},children:t})]}):ie(eo,{children:[U(Ie,{variant:"body2",color:"text.secondary",sx:{mb:2},children:a("modules.form.publicPolicies.fields.conditions.label")}),ie(oo,{direction:"row",spacing:1,sx:{mb:3},children:[U(Xo,{variant:i==="all"?"contained":"outlined",startIcon:U(Rt,{}),onClick:h,disabled:l,size:"small",sx:{minWidth:120,...i==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:a("modules.form.publicPolicies.fields.conditions.allFields")}),U(Xo,{variant:i==="none"?"contained":"outlined",startIcon:U(St,{}),onClick:u,disabled:l,size:"small",sx:{minWidth:120,...i==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:a("modules.form.publicPolicies.fields.conditions.noFields")})]}),ie(eo,{sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[U(Ie,{variant:"body2",color:"text.secondary",sx:{mb:2},children:a("modules.form.publicPolicies.fields.conditions.help")}),U(oo,{spacing:1,children:r.map(n=>{let s=w(n);return ie(oo,{direction:"row",spacing:1,alignItems:"center",children:[U(Ie,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:n}),ie(Tt,{value:s,exclusive:!0,size:"small",children:[ie(ro,{value:"allow",onClick:()=>f(n,"allow"),disabled:l,sx:{px:2,color:s==="allow"?"#ffffff":"#6b7280",backgroundColor:s==="allow"?"#16a34a":"#f3f4f6",borderColor:s==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:s==="allow"?"#15803d":"#e5e7eb",borderColor:s==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[U(vt,{sx:{fontSize:16,mr:.5}}),a("modules.form.publicPolicies.fields.conditions.states.allow")]}),U(ro,{value:"owner_allow",onClick:()=>f(n,"owner_allow"),disabled:l,sx:{px:2,color:s==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:s==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:s==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:s==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:s==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:a("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),ie(ro,{value:"deny",onClick:()=>f(n,"deny"),disabled:l,sx:{px:2,color:s==="deny"?"#ffffff":"#6b7280",backgroundColor:s==="deny"?"#dc2626":"#f3f4f6",borderColor:s==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:s==="deny"?"#b91c1c":"#e5e7eb",borderColor:s==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[U(Et,{sx:{fontSize:16,mr:.5}}),a("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},n)})})]}),t&&U(Zo,{error:!0,sx:{mt:1},children:t})]})},to=It;import{jsx as _,jsxs as z}from"react/jsx-runtime";var Mt=Lt(({policy:e,onChange:o,onRemove:r,availableFields:t,isSubmitting:l=!1,usedActions:a,error:i},d)=>{let{t:c}=At(),h=new Set(Array.from(a||[]));h.delete(e.action);let u=Jo.map(w=>({value:w,label:c(`modules.form.publicPolicies.fields.action.options.${w}`)}));return z(er,{ref:d,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[z(ge,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[_(we,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:c("modules.form.publicPolicies.policyTitle")}),_(Ft,{onClick:r,size:"small",disabled:l,"aria-label":c("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:_(Ut,{})})]}),z(ze,{spacing:3,children:[_(ze,{direction:{xs:"column",md:"row"},spacing:2,children:_(ge,{sx:{flex:1,minWidth:200},children:z(kt,{fullWidth:!0,children:[_(_t,{children:c("modules.form.publicPolicies.fields.action.label")}),_(Ot,{value:e.action,label:c("modules.form.publicPolicies.fields.action.label"),disabled:l,onChange:w=>{let f=w.target.value,n={...e,action:f};f==="delete"?(n.permission="deny",delete n.fields):(n.fields={allow:[],owner_allow:[],deny:t},delete n.permission),o(n)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:u.map(w=>{let f=h.has(w.value);return _(Nt,{value:w.value,disabled:f,children:w.label},w.value)})}),i&&_(Bt,{error:!0,children:i})]})})}),e.action==="delete"?z(ge,{children:[_(we,{variant:"body2",color:"text.secondary",sx:{mb:2},children:c("modules.form.publicPolicies.fields.conditions.label")}),z(ze,{direction:"row",spacing:1,sx:{mb:3},children:[_(no,{variant:e.permission==="*"?"contained":"outlined",startIcon:_(zt,{}),onClick:()=>o({...e,permission:"*"}),disabled:l,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:c("modules.form.publicPolicies.fields.conditions.allFields")}),_(no,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>o({...e,permission:"owner"}),disabled:l,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:c("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),_(no,{variant:e.permission==="deny"?"contained":"outlined",startIcon:_(Vt,{}),onClick:()=>o({...e,permission:"deny"}),disabled:l,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:c("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):_(to,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:w=>o({...e,fields:w}),availableFields:t,disabled:l}),_(er,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?z(we,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[z(ge,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):z(ze,{spacing:.5,divider:_(Dt,{sx:{borderColor:"#e5e7eb"}}),children:[z(we,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[z(ge,{component:"span",sx:{color:"#16a34a"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(e?.fields?.allow||[]).join(", ")||"-"]}),z(we,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[z(ge,{component:"span",sx:{color:"#0ea5e9"},children:[c("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(e?.fields?.owner_allow||[]).join(", ")||"-"]}),z(we,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[z(ge,{component:"span",sx:{color:"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(e?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),so=Mt;import{Fragment as Jt,jsx as ee,jsxs as Me}from"react/jsx-runtime";var Gt=()=>{let e=globalThis?.crypto;return e&&typeof e.randomUUID=="function"?e.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},Yt=({policies:e,onChange:o,availableFields:r,errors:t,isSubmitting:l=!1})=>{let{t:a}=qt(),i=Wt({}),d=new Set((e||[]).map(s=>s.action).filter(Boolean)),c=Qo.filter(s=>!d.has(s)),h=c.length>0,u=()=>{let s=c[0]||"create",p={id:Gt(),action:s};s==="delete"?p.permission="deny":p.fields={allow:[],owner_allow:[],deny:r};let y=[...e||[],p];o(y),setTimeout(()=>{let P=y.length-1,m=i.current[P];m&&m.scrollIntoView({behavior:"smooth",block:"center"})},100)},w=s=>{let p=[...e];p.splice(s,1),o(p)},f=(()=>{if(!t)return null;if(typeof t=="string")return t;let s=t._error;return typeof s=="string"?s:null})(),n=new Set((e||[]).map(s=>s.action));return Me(Jt,{children:[ee(jt,{sx:{borderColor:"#e0e4e7"}}),Me(Ve,{children:[ee(Ve,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:Me(Ve,{children:[ee(or,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:a("modules.form.publicPolicies.title")}),ee(or,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:a("modules.form.publicPolicies.description")})]})}),f&&ee(rr,{severity:"error",sx:{mb:3},children:f}),Me(Kt,{spacing:3,children:[(e||[]).length===0?ee(rr,{severity:"info",children:a("modules.form.publicPolicies.noPolicies")}):e.map((s,p)=>ee(so,{ref:y=>{i.current[p]=y},policy:s,onChange:y=>{let P=[...e];P[p]=y,o(P)},onRemove:()=>w(p),availableFields:r,isSubmitting:l,usedActions:n,error:typeof t=="object"&&t&&s.id in t?t[s.id]:void 0},s.id)),h&&ee(Ve,{children:ee(Ht,{type:"button",variant:"outlined",startIcon:ee($t,{}),onClick:u,disabled:l,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:a("modules.form.publicPolicies.addPolicy")})})]})]})]})},la=Yt;import{useState as ao}from"react";import{Button as We,TextField as tr,Box as be,Alert as Le,Typography as le,CircularProgress as io}from"@mui/material";import{jsx as L,jsxs as te}from"react/jsx-runtime";function pa(){let[e,o]=ao(""),[r,t]=ao(""),[l,a]=ao(!1),{isAuthenticated:i,isLoading:d,error:c,login:h,logout:u,refreshTokens:w,clearError:f,isExpiringSoon:n,expiresIn:s}=ne(),p=async m=>{if(m.preventDefault(),!e||!r)return;(await h(e,r)).success&&(o(""),t(""),a(!1))},y=async()=>{await u()},P=async()=>{await w()};return i?te(be,{sx:{maxWidth:600,mx:"auto",p:3},children:[L(le,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),L(Le,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),te(be,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[L(le,{variant:"h6",gutterBottom:!0,children:"Token Status"}),te(le,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(s/1e3/60)," minutes"]}),n&&L(Le,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),te(be,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[L(We,{variant:"contained",onClick:P,disabled:d,startIcon:d?L(io,{size:16}):null,children:"Refresh Tokens"}),L(We,{variant:"outlined",color:"error",onClick:y,disabled:d,children:"Logout"})]}),c&&L(Le,{severity:"error",sx:{mt:2},onClose:f,children:c})]}):te(be,{sx:{maxWidth:400,mx:"auto",p:3},children:[L(le,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),L(Le,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),l?te("form",{onSubmit:p,children:[L(tr,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:m=>o(m.target.value),margin:"normal",required:!0,autoComplete:"email"}),L(tr,{fullWidth:!0,label:"Password",type:"password",value:r,onChange:m=>t(m.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),L(We,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:d,startIcon:d?L(io,{size:16}):null,sx:{mt:3,mb:2},children:d?"Logging in...":"Login"})]}):L(We,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>a(!0),sx:{mt:2},children:"Show Login Form"}),c&&L(Le,{severity:"error",sx:{mt:2},onClose:f,children:c})]})}function ya(){let{isAuthenticated:e,isLoading:o,isExpiringSoon:r,expiresIn:t}=ne();return o?te(be,{sx:{display:"flex",alignItems:"center",gap:1},children:[L(io,{size:16}),L(le,{variant:"caption",children:"Loading session..."})]}):e?te(be,{children:[L(le,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),r&&te(le,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):L(le,{variant:"caption",color:"text.secondary",children:"Not logged in"})}import Qt from"@mui/material/TextField";import Xt from"@mui/material/CircularProgress";import nr from"@mui/material/InputAdornment";import Zt from"@mui/material/IconButton";import en from"@mui/icons-material/Refresh";import{jsx as ce}from"react/jsx-runtime";var on=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),rn=({html:e})=>ce("span",{dangerouslySetInnerHTML:{__html:on(e)}}),Ea=({config:e,value:o,onChange:r,label:t,error:l=!1,helperText:a,readOnly:i=!1,disabled:d=!1})=>{let{value:c,loading:h,error:u,regenerate:w}=po(e,{autoFetch:!o,onSuccess:P=>{r?.(P)}}),f=o||c,n=l||!!u,s=u||a,p=n&&s&&(s.toLowerCase().includes("duplicate")||s.toLowerCase().includes("duplicado")||s.toLowerCase().includes("duplicada")||s.toLowerCase().includes("unique")||s.toLowerCase().includes("\xFAnico")||s.toLowerCase().includes("unico")||s.toLowerCase().includes("\xFAnica")||s.toLowerCase().includes("unica")||s.toLowerCase().includes("already exists")||s.toLowerCase().includes("ya existe")||s.toLowerCase().includes("e11000"));return ce(Qt,{label:t,fullWidth:!0,value:f,error:n,helperText:s?ce(rn,{html:s}):" ",disabled:d,InputProps:{readOnly:!0,startAdornment:h?ce(nr,{position:"start",children:ce(Xt,{size:20})}):void 0,endAdornment:p&&!h?ce(nr,{position:"end",children:ce(Zt,{edge:"end",onClick:async()=>{!d&&!h&&await w()},disabled:d,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:ce(en,{})})}):void 0}})};export{re as a,tn as b,nn as c,qe as d,_e as e,pn as f,xo as g,vs as h,ht as i,Jo as j,Qo as k,la as l,pa as m,ya as n,Ea as o};