@nocios/crudify-ui 4.4.78 → 4.4.82
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-ARGPCO6I.js → chunk-2M2IM334.js} +1 -1
- package/dist/{chunk-EHDTUR6X.mjs → chunk-5GNPQK6D.mjs} +1 -1
- package/dist/{chunk-FRLGHMXE.js → chunk-7YI7UR5P.js} +1 -1
- package/dist/chunk-DJ3T7VVS.js +1 -0
- package/dist/chunk-E2B7CUHD.js +3 -0
- package/dist/chunk-EWX62JA4.mjs +3 -0
- package/dist/{chunk-QCGDLS4D.js → chunk-FK52OAX7.js} +1 -1
- package/dist/chunk-HQKET2ZX.mjs +1 -0
- package/dist/{chunk-3NGJBTRH.mjs → chunk-HVWKFUDX.mjs} +1 -1
- package/dist/{chunk-FRHTVRUM.mjs → chunk-PXFVXBFM.mjs} +1 -1
- package/dist/components.js +1 -1
- package/dist/components.mjs +1 -1
- package/dist/hooks.js +1 -1
- package/dist/hooks.mjs +1 -1
- package/dist/index.js +2 -2
- package/dist/index.mjs +2 -2
- package/dist/utils.js +1 -1
- package/dist/utils.mjs +1 -1
- package/package.json +1 -1
- package/dist/chunk-34FAL7YW.js +0 -1
- package/dist/chunk-AKTAAP5I.js +0 -1
- package/dist/chunk-G5OBPMIH.mjs +0 -1
- package/dist/chunk-SUWV767V.mjs +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _chunkDJ3T7VVSjs = require('./chunk-DJ3T7VVS.js');var _cryptojs = require('crypto-js'); var _cryptojs2 = _interopRequireDefault(_cryptojs);var c=class{constructor(t="sessionStorage"){this.encryptionKey=this.generateEncryptionKey(),this.storage=t==="localStorage"?window.localStorage:window.sessionStorage}generateEncryptionKey(){let t=[navigator.userAgent,navigator.language,new Date().getTimezoneOffset(),screen.colorDepth,screen.width,screen.height,"crudify-login"].join("|");return _cryptojs2.default.SHA256(t).toString()}setItem(t,e,n){try{let r=_cryptojs2.default.AES.encrypt(e,this.encryptionKey).toString();if(this.storage.setItem(t,r),n){let s=new Date().getTime()+n*60*1e3;this.storage.setItem(`${t}_expiry`,s.toString())}}catch(r){_chunkDJ3T7VVSjs.a.error("Failed to encrypt and store data",r instanceof Error?r:{message:String(r)})}}getItem(t){try{let e=`${t}_expiry`,n=this.storage.getItem(e);if(n){let g=parseInt(n,10);if(new Date().getTime()>g)return this.removeItem(t),null}let r=this.storage.getItem(t);if(!r)return null;let i=_cryptojs2.default.AES.decrypt(r,this.encryptionKey).toString(_cryptojs2.default.enc.Utf8);return i||(_chunkDJ3T7VVSjs.a.warn("Failed to decrypt stored data - may be corrupted"),this.removeItem(t),null)}catch(e){return _chunkDJ3T7VVSjs.a.error("Failed to decrypt data",e instanceof Error?e:{message:String(e)}),this.removeItem(t),null}}removeItem(t){this.storage.removeItem(t),this.storage.removeItem(`${t}_expiry`)}setToken(t){try{let e=t.split(".");if(e.length===3){let n=JSON.parse(atob(e[1]));if(n.exp){let r=n.exp*1e3,s=new Date().getTime(),i=Math.floor((r-s)/(60*1e3));if(i>0){this.setItem("authToken",t,i);return}}}}catch (e2){_chunkDJ3T7VVSjs.a.warn("Failed to parse token expiry, using default expiry")}this.setItem("authToken",t,1440)}getToken(){let t=this.getItem("authToken");if(t)try{let e=t.split(".");if(e.length===3){let n=JSON.parse(atob(e[1]));if(n.exp){let r=Math.floor(Date.now()/1e3);if(n.exp<r)return this.removeItem("authToken"),null}}}catch (e3){return _chunkDJ3T7VVSjs.a.warn("Failed to validate token expiry"),this.removeItem("authToken"),null}return t}},y= exports.a =new c("sessionStorage"),h= exports.b =new c("localStorage");exports.a = y; exports.b = h;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{b as Er,c as ie,h as Sr,j as me,l as Ir,m as kr,p as Lr}from"./chunk-G5OBPMIH.mjs";import{g as G}from"./chunk-BJ6PIVZR.mjs";import{a as x,b as vr,c as Tr,h as Rr}from"./chunk-SUWV767V.mjs";var de={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...","modules.form.publicPolicies.fields.conditions.customEdit":"Edici\xF3n personalizada"},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...","modules.form.publicPolicies.fields.conditions.customEdit":"Custom Edit"}},yi=()=>Object.keys(de),hi=e=>de[e]||de.es;import We from"@nocios/crudify-browser";var Ar="crudify_translations_",Fo=3600*1e3;function Fr(e){let r=0;for(let o=0;o<e.length;o++){let t=e.charCodeAt(o);r=(r<<5)-r+t,r=r&r}return Math.abs(r).toString(36)}var or=class e{constructor(){this.enableDebug=!1;this.initializationPromise=null;this.isInitialized=!1}static getInstance(){return e.instance||(e.instance=new e),e.instance}setDebug(r){this.enableDebug=r}async ensureCrudifyInitialized(r,o){if(!this.isInitialized)return this.initializationPromise?(this.enableDebug&&x.debug("[TranslationService] Waiting for crudify initialization..."),this.initializationPromise):(this.enableDebug&&x.debug("[TranslationService] Initializing crudify SDK..."),this.initializationPromise=(async()=>{try{let t=We.getTokenData();if(t&&t.endpoint){this.enableDebug&&x.debug("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}We.config(o);let s=await We.init(r,this.enableDebug?"debug":"none");if(s.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(s.errors||"Unknown error")}`);this.isInitialized=!0,this.enableDebug&&x.debug("[TranslationService] Crudify SDK initialized successfully")}catch(t){throw x.error("[TranslationService] Failed to initialize crudify",t instanceof Error?t:{message:String(t)}),this.initializationPromise=null,t}})(),this.initializationPromise)}async fetchTranslations(r){let{apiKey:o,featureKeys:t,crudifyEnv:s="stg",urlTranslations:n}=r;this.enableDebug&&x.debug("[TranslationService] fetchTranslations called with:",{apiKeyHash:Fr(o),crudifyEnv:s,featureKeys:t,hasUrlTranslations:!!n});let i=this.getFromCache(o),l=i?this.isCacheExpired(i):!0;if(i&&!l)return this.enableDebug&&x.debug("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(i.data.translations,n);try{await this.ensureCrudifyInitialized(o,s)}catch(c){return x.error("[TranslationService] Failed to initialize crudify",c instanceof Error?c:{message:String(c)}),i?(x.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(i.data.translations,n)):(x.warn("[TranslationService] Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&x.debug("[TranslationService] Fetching from API via crudify SDK");let c=await this.fetchFromAPI(t);this.hasDataChanged(i,c)||!i?this.saveToCache(o,c):this.refreshCacheTimestamp(o);let u=this.mergeWithUrlTranslations(c.translations,n);return this.enableDebug&&x.debug("[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 x.error("[TranslationService] API fetch failed",c instanceof Error?c:{message:String(c)}),i?(x.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(i.data.translations,n)):(x.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(r){let o=await We.getTranslation(r);if(!o.success)throw new Error(`Crudify API error: ${o.errors?JSON.stringify(o.errors):"Unknown error"}`);if(!o.data)throw new Error("No translation data in response");return o.data}mergeWithUrlTranslations(r,o){if(!o||Object.keys(o).length===0)return r;let t={};return Object.keys(r).forEach(s=>{t[s]={...r[s],...o}}),t}hasDataChanged(r,o){if(!r||r.data.timestamp!==o.timestamp)return!0;let t=this.hashData(o.translations);return r.dataHash!==t}hashData(r){let o=JSON.stringify(r),t=0;for(let s=0;s<o.length;s++){let n=o.charCodeAt(s);t=(t<<5)-t+n,t=t&t}return t.toString(36)}saveToCache(r,o){try{let t=this.getCacheKey(r),s={data:o,cachedAt:Date.now(),dataHash:this.hashData(o.translations)};localStorage.setItem(t,JSON.stringify(s)),this.enableDebug&&x.debug("[TranslationService] Saved to cache:",{cacheKey:t})}catch(t){x.error("[TranslationService] Failed to save cache",t instanceof Error?t:{message:String(t)})}}getFromCache(r){try{let o=this.getCacheKey(r),t=localStorage.getItem(o);return t?JSON.parse(t):null}catch(o){return x.error("[TranslationService] Failed to read cache",o instanceof Error?o:{message:String(o)}),null}}refreshCacheTimestamp(r){try{let o=this.getFromCache(r);if(o){o.cachedAt=Date.now();let t=this.getCacheKey(r);localStorage.setItem(t,JSON.stringify(o))}}catch(o){x.error("[TranslationService] Failed to refresh cache timestamp",o instanceof Error?o:{message:String(o)})}}isCacheExpired(r){return Date.now()-r.cachedAt>Fo}hasValidCache(r){let o=this.getFromCache(r);return o?!this.isCacheExpired(o):!1}getCacheKey(r){return`${Ar}${Fr(r)}`}getCriticalTranslationsOnly(){return de}invalidateCache(r){let o=this.getCacheKey(r);localStorage.removeItem(o),this.enableDebug&&x.debug("[TranslationService] Cache invalidated:",{cacheKey:o})}async prefetchTranslations(r){try{await this.fetchTranslations(r),this.enableDebug&&x.debug("[TranslationService] Prefetch completed")}catch(o){x.error("[TranslationService] Prefetch failed",o instanceof Error?o:{message:String(o)})}}clearAllCaches(){try{let o=Object.keys(localStorage).filter(t=>t.startsWith(Ar));o.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&x.debug(`[TranslationService] Cleared ${o.length} cache entries`)}catch(r){x.error("[TranslationService] Failed to clear caches",r instanceof Error?r:{message:String(r)})}}},He=or.getInstance();import{createContext as _o,useContext as Oo,useEffect as Br,useState as Ie,useMemo as _r,useCallback as Bo}from"react";import{Fragment as No,jsx as je}from"react/jsx-runtime";var qe=null,tr=!1,Dr=_o(null);function Or(e,r,o){return{...e,...r,...o||{}}}function Do(e,r,o,t,s){Br(()=>{if(!t||!e||!r)return;let n=o||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!n||!n.addResourceBundle){s&&x.debug("[TranslationsProvider] i18next not found, skipping auto-sync");return}s&&x.debug("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:r}),Object.keys(e).forEach(i=>{e[i]&&Object.keys(e[i]).length>0&&(n.addResourceBundle(i,"translation",e[i],!0,!0),s&&x.debug(`[TranslationsProvider] Synced ${Object.keys(e[i]).length} keys for language: ${i}`))}),n.language!==r&&(n.changeLanguage(r),s&&x.debug(`[TranslationsProvider] Changed i18next language to: ${r}`))},[e,r,o,t,s])}var ki=({children:e,apiKey:r,crudifyEnv:o="prod",featureKeys:t,language:s="es",devTranslations:n,translationUrl:i,enableDebug:l=!1,skipAutoInit:c=!0,autoSyncI18n:h=!0,i18nInstance:u,loadingFallback:b,waitForInitialLoad:g=!0})=>{let a=_r(()=>Tr({publicApiKey:r,env:o,featureKeys:t,enableDebug:l}),[r,o,t,l]),d=a.publicApiKey||"",w=a.env||o||"prod",p=a.featureKeys||t,[y,m]=Ie({}),[P,I]=Ie(!0),[V,C]=Ie(!0),[f,T]=Ie(null),[A,O]=Ie(void 0),[le,xe]=Ie(!1),ne=Bo(async()=>{if(!d){l&&x.debug("[TranslationsProvider] No apiKey - skipping translation fetch"),I(!1),C(!1);return}if(le){l&&x.debug("[TranslationsProvider] Skipping reload - using fallback translations");return}if(He.hasValidCache(d)&&V&&(l&&x.debug("[TranslationsProvider] Valid cache found - not blocking initial render"),C(!1)),tr&&qe){l&&x.debug("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let R=await qe;m(R),I(!1);return}catch{l&&x.warn("[TranslationsProvider] Global fetch failed, retrying")}}tr=!0,I(!0),T(null);let _;if(i)try{l&&x.debug(`[TranslationsProvider] Fetching translations from URL: ${i}`);let R=await fetch(i);if(!R.ok)throw new Error(`Failed to fetch translations: ${R.statusText}`);_=await R.json(),O(_),l&&x.debug("[TranslationsProvider] URL translations loaded:",{keysCount:_?Object.keys(_).length:0})}catch(R){x.error("[TranslationsProvider] Failed to load URL translations",R instanceof Error?R:{message:String(R)}),_=void 0,O(void 0)}let Re=(async()=>{try{He.setDebug(l);let R=await He.fetchTranslations({apiKey:d,crudifyEnv:w,featureKeys:p,urlTranslations:_}),q={};return Object.keys(R).forEach(v=>{let k=de[v]||{},B=R[v]||{};q[v]=Or(k,B,n)}),l&&x.debug("[TranslationsProvider] Loaded translations:",{languages:Object.keys(q),keysCount:Object.keys(q[s]||{}).length}),q}catch(R){x.error("[TranslationsProvider] Failed to load",R instanceof Error?R:{message:String(R)}),T(R instanceof Error?R.message:String(R)),xe(!0);let q={};return Object.keys(de).forEach(v=>{let k=de[v],B=_||A||{};q[v]=Or(k,B,n)}),l&&x.debug("[TranslationsProvider] Using fallback translations (critical + URL)"),q}})();qe=Re;try{let R=await Re;m(R)}finally{I(!1),C(!1),tr=!1,setTimeout(()=>{qe=null},1e3)}},[d,w,p,i,n,l,s,le]);Br(()=>{ne();let W=setInterval(ne,3600*1e3);return()=>clearInterval(W)},[ne]);let ge=_r(()=>(W,_)=>{let R=(y[s]||{})[W];if(!R){let q=Object.keys(y);for(let v of q)if(y[v][W]){R=y[v][W];break}}return R||(l&&x.warn(`[TranslationsProvider] Missing translation: "${W}"`),R=W),_&&typeof R=="string"&&Object.entries(_).forEach(([q,v])=>{let k=new RegExp(`{{${q}}}`,"g");R=R.replace(k,String(v))}),R},[y,s,l]);Do(y,s,u,h,l);let F={t:ge,language:s,availableLanguages:Object.keys(y),translations:y,isLoading:P,error:f,refreshTranslations:ne};return d?g&&V&&P?b||je("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:je("div",{children:"Loading translations..."})}):je(Dr.Provider,{value:F,children:e}):(l&&x.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),je(No,{children:e}))},Nr=()=>{let e=Oo(Dr);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};import{Box as Pt,Typography as vt}from"@mui/material";import{createContext as Uo,useContext as Mo,useMemo as ir}from"react";import{useState as nr,useEffect as zo}from"react";var zr=(e,r)=>{let[o,t]=nr({}),[s,n]=nr(!1),[i,l]=nr(null);return zo(()=>{if(r&&Object.keys(r).length>0){t(r),n(!1),l(null);return}if(!e){t({}),n(!1),l(null);return}let c=!1;return n(!0),l(null),fetch(e).then(h=>{if(!h.ok)throw new Error(`Failed to load translations: ${h.status}`);return h.json()}).then(h=>{c||(t(h),n(!1))}).catch(h=>{c||(x.error("[I18nProvider] Failed to load translations from URL",h instanceof Error?h:{message:String(h),url:e}),l(h instanceof Error?h.message:String(h)),t({}),n(!1))}),()=>{c=!0}},[e,r]),{translations:o,loading:s,error:i}};import{jsx as Ur}from"react/jsx-runtime";var Mr=Uo(null),Vo=()=>{try{return Nr()}catch{return null}},Wo=(e,r)=>{if(r.includes(".")){let o=r.split(".").reduce((t,s)=>t&&typeof t=="object"?t[s]:void 0,e);if(o!==void 0)return o}if(e&&e[r])return e[r]},Vr=({children:e,translations:r,translationsUrl:o,language:t="en"})=>{let n=Vo()?.translations?.[t]||{},{translations:i,loading:l}=zr(o,r),c=ir(()=>({...n,...i,...r||{}}),[n,i,r]),h=ir(()=>(b,g)=>{let a=Wo(c,b);return a==null&&(a=b),g&&typeof a=="string"&&Object.entries(g).forEach(([d,w])=>{a=a.replace(new RegExp(`{{${d}}}`,"g"),w)}),typeof a=="string"?a:b},[c]),u=ir(()=>({t:h,language:t}),[h,t]);return l?Ur("div",{children:"Loading translations..."}):Ur(Mr.Provider,{value:u,children:e})},Z=()=>{let e=Mo(Mr);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};import{createContext as Ho,useContext as qo,useReducer as jo,useEffect as Wr}from"react";import{jsx as Ko}from"react/jsx-runtime";var Hr={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function $o(e,r){switch(r.type){case"SET_SCREEN":let o={...e,currentScreen:r.payload.screen,searchParams:r.payload.params||e.searchParams,errors:{global:[]}},t=new URLSearchParams(o.searchParams),s=t.toString()?`?${t.toString()}`:window.location.pathname;try{window.history.replaceState({},"",s)}catch{}return o;case"SET_SEARCH_PARAMS":return{...e,searchParams:r.payload};case"UPDATE_FORM_DATA":return{...e,formData:{...e.formData,...r.payload},errors:{...e.errors,...Object.keys(r.payload).reduce((n,i)=>({...n,[i]:void 0}),{})}};case"SET_LOADING":return{...e,loading:r.payload};case"SET_ERRORS":return{...e,errors:{...e.errors,...r.payload}};case"CLEAR_ERRORS":return{...e,errors:{global:[]}};case"SET_EMAIL_SENT":return{...e,emailSent:r.payload};case"SET_CODE_ALREADY_EXISTS":return{...e,codeAlreadyExists:r.payload};case"SET_CODE_VALIDATED":return{...e,codeValidated:r.payload};case"SET_FROM_CODE_VERIFICATION":return{...e,fromCodeVerification:r.payload};case"RESET_FORM":return{...e,formData:Hr.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...e,config:r.payload};default:return e}}var qr=Ho(void 0),jr=({children:e,initialScreen:r="login",config:o,autoReadFromCookies:t=!0})=>{let[s,n]=jo($o,{...Hr,currentScreen:r});Wr(()=>{n({type:"INIT_CONFIG",payload:(()=>{let a={};if(t)try{let d=vr("logo");if(d){let w=decodeURIComponent(d);w.startsWith("http")&&(a.logo=w)}}catch(d){x.error("Error reading configuration from cookies",d instanceof Error?d:{message:String(d)})}return{publicApiKey:o?.publicApiKey,env:o?.env,appName:o?.appName,logo:o?.logo||a.logo,loginActions:o?.loginActions}})()})},[o,t]),Wr(()=>{let g=new URLSearchParams(window.location.search),a={};g.forEach((d,w)=>{a[w]=d}),Object.keys(a).length>0&&n({type:"SET_SEARCH_PARAMS",payload:a}),r==="checkCode"&&a.email&&n({type:"UPDATE_FORM_DATA",payload:{email:a.email,code:a.code||""}}),r==="resetPassword"&&a.link&&n({type:"SET_SEARCH_PARAMS",payload:a})},[r]);let b={state:s,dispatch:n,setScreen:(g,a)=>{n({type:"SET_SCREEN",payload:{screen:g,params:a}})},updateFormData:g=>{n({type:"UPDATE_FORM_DATA",payload:g})},setFieldError:(g,a)=>{n({type:"SET_ERRORS",payload:{[g]:a}})},clearErrors:()=>{n({type:"CLEAR_ERRORS"})},setLoading:g=>{n({type:"SET_LOADING",payload:g})}};return Ko(qr.Provider,{value:b,children:e})},$e=()=>{let e=qo(qr);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};import{useEffect as Go,useRef as Yo}from"react";import{Typography as sr,TextField as $r,Button as Xo,Box as Oe,CircularProgress as Jo,Alert as Qo,Link as Kr}from"@mui/material";import{Fragment as et,jsx as ee,jsxs as Be}from"react/jsx-runtime";var Zo=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:s="/"})=>{let{crudify:n}=ie(),{state:i,updateFormData:l,setFieldError:c,clearErrors:h,setLoading:u}=$e(),{login:b}=me(),g=Z(),{t:a}=g,d=g.i18n,w=Yo(null),p=Rr(a,{currentLanguage:d?.language,enableDebug:!1}),y=()=>{if(i.searchParams.redirect)try{let f=decodeURIComponent(i.searchParams.redirect);if(f.startsWith("/")&&!f.startsWith("//"))return f}catch{}return s||"/"};Go(()=>{let f=setTimeout(()=>{w.current&&w.current.focus()},100);return()=>clearTimeout(f)},[]);let m=f=>p.translateError({code:f.code,message:f.message,field:f.field}),P=async()=>{if(!i.loading){if(!i.formData.username.trim()){c("username",a("login.usernameRequired"));return}if(!i.formData.password.trim()){c("password",a("login.passwordRequired"));return}h(),u(!0);try{let f=await b(i.formData.username,i.formData.password);if(u(!1),f.success){let T=y();o&&o(f.data,T)}else{let T=f.rawResponse||f;I(T)}}catch(f){u(!1);let A=G(f).map(m);c("global",A),t&&t(A.join(", "))}}},I=f=>{let T=G(f),A=[];T.forEach(O=>{O.field?c(O.field,m(O)):A.push(m(O))}),A.length>0&&c("global",A)};return Be(et,{children:[Be(Oe,{component:"form",noValidate:!0,onSubmit:f=>{f.preventDefault(),P()},onKeyDown:f=>{f.key==="Enter"&&!i.loading&&(f.preventDefault(),P())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Be(Oe,{sx:{mb:1},children:[ee(sr,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:a("login.usernameOrEmailLabel")}),ee($r,{fullWidth:!0,id:"email",name:"email",type:"email",value:i.formData.username,disabled:i.loading,onChange:f=>l({username:f.target.value}),error:!!i.errors.username,helperText:i.errors.username,autoComplete:"email",placeholder:a("login.usernameOrEmailPlaceholder"),inputRef:w,required:!0})]}),Be(Oe,{sx:{mb:1},children:[ee(sr,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:a("login.passwordLabel")}),ee($r,{fullWidth:!0,id:"password",name:"password",type:"password",value:i.formData.password,disabled:i.loading,onChange:f=>l({password:f.target.value}),error:!!i.errors.password,helperText:i.errors.password,autoComplete:"current-password",placeholder:a("login.passwordPlaceholder"),required:!0})]}),i.config.loginActions?.includes("forgotPassword")&&ee(Oe,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:ee(Kr,{sx:{cursor:"pointer"},onClick:()=>{e?.("forgotPassword",i.searchParams)},variant:"body2",color:"secondary",children:a("login.forgotPasswordLink")})}),ee(Xo,{disabled:i.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:i.loading?ee(Jo,{size:20}):a("login.loginButton")})]}),ee(Oe,{children:i.errors.global&&i.errors.global.length>0&&i.errors.global.map((f,T)=>ee(Qo,{variant:"filled",sx:{mt:2},severity:"error",children:ee("div",{children:f})},T))}),i.config.loginActions?.includes("createUser")&&Be(sr,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[a("login.noAccountPrompt")," ",ee(Kr,{sx:{cursor:"pointer"},onClick:()=>{let T=`/public/users/create${Object.keys(i.searchParams).length>0?`?${new URLSearchParams(i.searchParams).toString()}`:""}`;r?.(T)},fontWeight:"medium",color:"secondary",children:a("login.signUpLink")})]})]})},Gr=Zo;import{useState as ke,useEffect as rt,useRef as ot}from"react";import{Typography as Le,TextField as tt,Button as Yr,Box as pe,CircularProgress as nt,Alert as it,Link as ar}from"@mui/material";import{Fragment as Xr,jsx as M,jsxs as Pe}from"react/jsx-runtime";var st=({onScreenChange:e,onError:r})=>{let{crudify:o}=ie(),[t,s]=ke(""),[n,i]=ke(!1),[l,c]=ke([]),[h,u]=ke(null),[b,g]=ke(!1),[a,d]=ke(!1),w=ot(null),{t:p}=Z();rt(()=>{w.current&&!b&&!a&&w.current.focus()},[b,a]);let y=f=>{let T=[`errors.auth.${f.code}`,`errors.data.${f.code}`,`errors.system.${f.code}`,`errors.${f.code}`,`forgotPassword.${f.code.toLowerCase()}`];for(let A of T){let O=p(A);if(O!==A)return O}return f.message||p("error.unknown")},m=f=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(f),P=async()=>{if(!(n||!o)){if(c([]),u(null),!t){u(p("forgotPassword.emailRequired"));return}if(!m(t)){u(p("forgotPassword.invalidEmail"));return}i(!0);try{let f=[{operation:"requestPasswordReset",data:{email:t}}],T=await o.transaction(f);if(T.success)T.data&&T.data.existingCodeValid?d(!0):g(!0);else{let O=G(T).map(y);c(O)}}catch(f){let A=G(f).map(y);c(A),r&&r(A.join(", "))}finally{i(!1)}}},I=()=>{e?.("login")},V=()=>{if(b||a){e?.("checkCode",{email:t});return}if(!t){u(p("forgotPassword.emailRequired"));return}if(!m(t)){u(p("forgotPassword.invalidEmail"));return}e?.("checkCode",{email:t})};return b||a?M(Xr,{children:Pe(pe,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[Pe(pe,{sx:{mb:2},children:[M(Le,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p(a?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),M(Le,{variant:"body2",sx:{color:a?"success.main":"grey.600"},children:p("forgotPassword.checkEmailInstructions")})]}),M(Yr,{type:"button",onClick:V,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:p("forgotPassword.enterCodeLink")}),M(pe,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:M(ar,{sx:{cursor:"pointer"},onClick:I,variant:"body2",color:"secondary",children:p("common.back")})})]})}):Pe(Xr,{children:[Pe(pe,{component:"form",noValidate:!0,onSubmit:f=>{f.preventDefault(),P()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Pe(pe,{sx:{mb:2},children:[M(Le,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p("forgotPassword.title")}),M(Le,{variant:"body2",sx:{color:"grey.600"},children:p("forgotPassword.instructions")})]}),Pe(pe,{sx:{mb:1},children:[M(Le,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:p("forgotPassword.emailLabel")}),M(tt,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:n,onChange:f=>s(f.target.value),error:!!h,helperText:h,autoComplete:"email",placeholder:p("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:w})]}),M(Yr,{disabled:n,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?M(nt,{size:20}):p("forgotPassword.sendCodeButton")}),Pe(pe,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[M(ar,{sx:{cursor:"pointer"},onClick:I,variant:"body2",color:"secondary",children:p("common.back")}),M(Le,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),M(ar,{sx:{cursor:"pointer"},onClick:V,variant:"body2",color:"secondary",children:p("login.alreadyHaveCodeLink")})]})]}),M(pe,{children:l.length>0&&l.map((f,T)=>M(it,{variant:"filled",sx:{mt:2},severity:"error",children:f},T))})]})},Jr=st;import{useState as J,useEffect as Qr}from"react";import{Typography as Ke,TextField as Zr,Button as at,Box as fe,CircularProgress as eo,Alert as ro,Link as lt}from"@mui/material";import{Fragment as dt,jsx as H,jsxs as De}from"react/jsx-runtime";var ct=({onScreenChange:e,onError:r,searchParams:o,onResetSuccess:t})=>{let{crudify:s}=ie(),[n,i]=J(""),[l,c]=J(""),[h,u]=J(!1),[b,g]=J([]),[a,d]=J(null),[w,p]=J(null),[y,m]=J(""),[P,I]=J(""),[V,C]=J(!1),[f,T]=J(!0),[A,O]=J(!1),[le,xe]=J(null),[ne,ge]=J(!1),{t:F}=Z(),W=v=>{let k=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`resetPassword.${v.code.toLowerCase()}`];for(let B of k){let j=F(B);if(j!==B)return j}return v.message||F("error.unknown")},_=v=>o?o instanceof URLSearchParams?o.get(v):o[v]||null:null;Qr(()=>{if(o){if(o){let v=_("fromCodeVerification"),k=_("email"),B=_("code");if(v==="true"&&k&&B){m(k),I(B),C(!0),O(!0),T(!1);return}let j=_("link");if(j)try{let Y=decodeURIComponent(j),[X,ce]=Y.split("/");if(X&&ce&&X.length===6){I(X),m(ce),C(!1),xe({email:ce,code:X});return}}catch{}if(k&&B){m(k),I(B),C(!1),xe({email:k,code:B});return}}g([F("resetPassword.invalidCode")]),T(!1),setTimeout(()=>e?.("forgotPassword"),3e3)}},[o,s,F,e]),Qr(()=>{s&&le&&!ne&&(ge(!0),(async(k,B)=>{try{let j=[{operation:"validatePasswordResetCode",data:{email:k,codePassword:B}}],Y=await s.transaction(j);if(Y.data&&Array.isArray(Y.data)){let X=Y.data[0];if(X&&X.response&&X.response.status==="OK"){O(!0);return}}if(Y.success)O(!0);else{let ce=G(Y).map(W);g(ce),setTimeout(()=>e?.("forgotPassword"),3e3)}}catch(j){let X=G(j).map(W);g(X),setTimeout(()=>e?.("forgotPassword"),3e3)}finally{T(!1),xe(null),ge(!1)}})(le.email,le.code))},[s,le,F,e]);let Re=v=>v.length<8?F("resetPassword.passwordTooShort"):null,R=async()=>{if(h||!s)return;g([]),d(null),p(null);let v=!1;if(!n)d(F("resetPassword.newPasswordRequired")),v=!0;else{let k=Re(n);k&&(d(k),v=!0)}if(l?n!==l&&(p(F("resetPassword.passwordsDoNotMatch")),v=!0):(p(F("resetPassword.confirmPasswordRequired")),v=!0),!v){u(!0);try{let k=[{operation:"validateAndResetPassword",data:{email:y,codePassword:P,newPassword:n}}],B=await s.transaction(k);if(B.success)g([]),setTimeout(()=>{t?.()},1e3);else{let Y=G(B).map(W);g(Y)}}catch(k){let j=G(k).map(W);g(j),r&&r(j.join(", "))}u(!1)}},q=()=>{V?e?.("checkCode",{email:y}):e?.("forgotPassword")};return f?H(fe,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:H(eo,{})}):A?De(dt,{children:[De(fe,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[De(fe,{sx:{mb:2},children:[H(Ke,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:F("resetPassword.title")}),H(Ke,{variant:"body2",sx:{color:"grey.600"},children:F("resetPassword.instructions")})]}),De(fe,{sx:{mb:1},children:[H(Ke,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:F("resetPassword.newPasswordLabel")}),H(Zr,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:n,disabled:h,onChange:v=>i(v.target.value),error:!!a,helperText:a,autoComplete:"new-password",placeholder:F("resetPassword.newPasswordPlaceholder"),required:!0})]}),De(fe,{sx:{mb:1},children:[H(Ke,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:F("resetPassword.confirmPasswordLabel")}),H(Zr,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:l,disabled:h,onChange:v=>c(v.target.value),error:!!w,helperText:w,autoComplete:"new-password",placeholder:F("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),H(at,{disabled:h,type:"button",onClick:R,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:h?H(eo,{size:20}):F("resetPassword.resetPasswordButton")}),H(fe,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:H(lt,{sx:{cursor:"pointer"},onClick:q,variant:"body2",color:"secondary",children:F("common.back")})})]}),H(fe,{children:b.length>0&&b.map((v,k)=>H(ro,{variant:"filled",sx:{mt:2},severity:"error",children:v},k))})]}):H(fe,{children:b.length>0&&b.map((v,k)=>H(ro,{variant:"filled",sx:{mt:2},severity:"error",children:v},k))})},oo=ct;import{useState as Ne,useEffect as to,useRef as ut}from"react";import{Typography as lr,TextField as gt,Button as mt,Box as ze,CircularProgress as pt,Alert as ft,Link as yt}from"@mui/material";import{Fragment as bt,jsx as se,jsxs as Ge}from"react/jsx-runtime";var ht=({onScreenChange:e,onError:r,searchParams:o})=>{let{crudify:t}=ie(),[s,n]=Ne(""),[i,l]=Ne(!1),[c,h]=Ne([]),[u,b]=Ne(null),[g,a]=Ne(""),d=ut(null),{t:w}=Z(),p=C=>o?o instanceof URLSearchParams?o.get(C):o[C]||null:null,y=C=>{let f=[`errors.auth.${C.code}`,`errors.data.${C.code}`,`errors.system.${C.code}`,`errors.${C.code}`,`checkCode.${C.code.toLowerCase()}`];for(let T of f){let A=w(T);if(A!==T)return A}return C.message||w("error.unknown")};to(()=>{let C=p("email");C?a(C):e?.("forgotPassword")},[o,e]),to(()=>{d.current&&d.current.focus()},[]);let m=async()=>{if(!(i||!t)){if(h([]),b(null),!s){b(w("checkCode.codeRequired"));return}if(s.length!==6){b(w("checkCode.codeRequired"));return}l(!0);try{let C=[{operation:"validatePasswordResetCode",data:{email:g,codePassword:s}}],f=await t.transaction(C);if(f.success)e?.("resetPassword",{email:g,code:s,fromCodeVerification:"true"});else{let A=G(f).map(y);h(A),l(!1)}}catch(C){let T=G(C).map(y);h(T),l(!1),r&&r(T.join(", "))}}},P=()=>{e?.("forgotPassword")},I=C=>{let f=C.target.value.replace(/\D/g,"").slice(0,6);n(f)};return Ge(bt,{children:[Ge(ze,{component:"form",noValidate:!0,onSubmit:C=>{C.preventDefault(),m()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Ge(ze,{sx:{mb:2},children:[se(lr,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:w("checkCode.title")}),se(lr,{variant:"body2",sx:{color:"grey.600"},children:w("checkCode.instructions")})]}),Ge(ze,{sx:{mb:1},children:[se(lr,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:w("checkCode.codeLabel")}),se(gt,{fullWidth:!0,id:"code",name:"code",type:"text",value:s,disabled:i,onChange:I,error:!!u,helperText:u,placeholder:w("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:d})]}),se(mt,{disabled:i||s.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:i?se(pt,{size:20}):w("checkCode.verifyButton")}),se(ze,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:se(yt,{sx:{cursor:"pointer"},onClick:P,variant:"body2",color:"secondary",children:w("common.back")})})]}),se(ze,{children:c.length>0&&c.map((C,f)=>se(ft,{sx:{mt:2},severity:"error",children:C},f))})]})},no=ht;import{Box as wt,CircularProgress as xt,Alert as io,Typography as cr}from"@mui/material";import{Fragment as Ct,jsx as Ae,jsxs as so}from"react/jsx-runtime";var ao=({children:e,fallback:r})=>{let{isLoading:o,error:t,isInitialized:s}=ie(),{t:n}=Z();return o?r||so(wt,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[Ae(xt,{}),Ae(cr,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):t?Ae(io,{severity:"error",sx:{mt:2},children:so(cr,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",t]})}):s?Ae(Ct,{children:e}):Ae(io,{severity:"warning",sx:{mt:2},children:Ae(cr,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as oe,jsxs as Rt}from"react/jsx-runtime";var Tt=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:s="/"})=>{let{t:n}=Z(),{state:i,setScreen:l}=$e(),{config:c}=me(),{showNotification:h}=Sr(),u=(g,a)=>{let d=a;g==="login"?d={}:g==="forgotPassword"&&!a&&(d={}),l(g,d),e?.(g,d)},b=()=>{let g={onScreenChange:u,onExternalNavigate:r,onError:t,redirectUrl:s};switch(i.currentScreen){case"forgotPassword":return oe(Jr,{...g});case"checkCode":return oe(no,{...g,searchParams:i.searchParams});case"resetPassword":return oe(oo,{...g,searchParams:i.searchParams,onResetSuccess:()=>{let a=n("resetPassword.successMessage");h(a,"success"),u("login")}});default:return oe(Gr,{...g,onLoginSuccess:o})}};return Rt(ao,{children:[oe(Pt,{sx:{display:"flex",justifyContent:"center",mb:3},children:oe("img",{src:c.logo||"https://logos.crudia.com/nocios-default.png",alt:n("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:g=>{let a=g.target;a.src="https://logos.crudia.com/nocios-default.png"}})}),!c.logo&&c.appName&&oe(vt,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:c.appName}),b()]})},Et=({translations:e,translationsUrl:r,language:o="en",initialScreen:t="login",autoReadFromCookies:s=!0,...n})=>{let{config:i}=me();return oe(Vr,{translations:e,translationsUrl:r,language:o,children:oe(Er,{config:i,children:oe(jr,{config:i,initialScreen:t,autoReadFromCookies:s,children:oe(Tt,{...n})})})})},Ms=Et;import{Box as Q,Card as lo,CardContent as co,Typography as te,Chip as Ye,Avatar as St,Divider as It,CircularProgress as kt,Alert as uo,List as Lt,ListItem as dr,ListItemText as ur,ListItemIcon as At,Collapse as Ft,IconButton as gr}from"@mui/material";import{Person as _t,Email as Ot,Badge as Bt,Security as Dt,Schedule as Nt,AccountCircle as zt,ExpandMore as Ut,ExpandLess as Mt,Info as Vt}from"@mui/icons-material";import{useState as Wt}from"react";import{Fragment as jt,jsx as E,jsxs as D}from"react/jsx-runtime";var Ht=({showExtendedData:e=!0,showProfileCard:r=!0,autoRefresh:o=!0})=>{let{userProfile:t,loading:s,error:n,extendedData:i,refreshProfile:l}=Ir({autoFetch:o,retryOnError:!0,maxRetries:3}),[c,h]=Wt(!1);if(s)return D(Q,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[E(kt,{}),E(te,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return D(uo,{severity:"error",action:E(gr,{color:"inherit",size:"small",onClick:l,children:E(te,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!t)return E(uo,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let u=i?.displayData||{},b=i?.totalFields||0,g=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}},a=(m,P)=>P==null?"No disponible":typeof P=="boolean"?P?"S\xED":"No":Array.isArray(P)?P.length>0?P.join(", "):"Ninguno":typeof P=="object"?JSON.stringify(P,null,2):String(P),d=[{key:"id",label:"ID",icon:E(Bt,{})},{key:"email",label:"Email",icon:E(Ot,{})},{key:"username",label:"Usuario",icon:E(_t,{})},{key:"fullName",label:"Nombre completo",icon:E(zt,{})},{key:"role",label:"Rol",icon:E(Dt,{})}],w=[{key:"firstName",label:"Nombre"},{key:"lastName",label:"Apellido"},{key:"isActive",label:"Activo"},{key:"lastLogin",label:"\xDAltimo login"},{key:"createdAt",label:"Creado"},{key:"updatedAt",label:"Actualizado"}],p=[...d.map(m=>m.key),...w.map(m=>m.key),"permissions"],y=Object.keys(u).filter(m=>!p.includes(m)).map(m=>({key:m,label:m}));return D(Q,{children:[r&&E(lo,{sx:{mb:2},children:D(co,{children:[D(Q,{display:"flex",alignItems:"center",mb:2,children:[E(St,{src:u.avatar,sx:{width:56,height:56,mr:2},children:u.fullName?.[0]||u.username?.[0]||u.email?.[0]}),D(Q,{children:[E(te,{variant:"h6",children:u.fullName||u.username||u.email}),E(te,{variant:"body2",color:"text.secondary",children:u.role||"Usuario"}),u.isActive!==void 0&&E(Ye,{label:u.isActive?"Activo":"Inactivo",color:u.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),E(Q,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:d.map(({key:m,label:P,icon:I})=>u[m]?D(Q,{display:"flex",alignItems:"center",children:[E(Q,{sx:{mr:1,color:"text.secondary"},children:I}),D(Q,{children:[E(te,{variant:"caption",color:"text.secondary",children:P}),E(te,{variant:"body2",children:a(m,u[m])})]})]},m):null)}),u.permissions&&Array.isArray(u.permissions)&&u.permissions.length>0&&D(Q,{mt:2,children:[E(te,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),D(Q,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[u.permissions.slice(0,5).map((m,P)=>E(Ye,{label:m,size:"small",variant:"outlined"},P)),u.permissions.length>5&&E(Ye,{label:`+${u.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&E(lo,{children:D(co,{children:[D(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[D(te,{variant:"h6",display:"flex",alignItems:"center",children:[E(Vt,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),E(Ye,{label:`${b} campos totales`,size:"small"})]}),D(Lt,{dense:!0,children:[w.map(({key:m,label:P})=>u[m]!==void 0&&D(dr,{divider:!0,children:[E(At,{children:E(Nt,{fontSize:"small"})}),E(ur,{primary:P,secondary:m.includes("At")||m.includes("Login")?g(u[m]):a(m,u[m])})]},m)),y.length>0&&D(jt,{children:[E(It,{sx:{my:1}}),E(dr,{children:E(ur,{primary:D(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[D(te,{variant:"subtitle2",children:["Campos Personalizados (",y.length,")"]}),E(gr,{size:"small",onClick:()=>h(!c),children:c?E(Mt,{}):E(Ut,{})})]})})}),E(Ft,{in:c,children:y.map(({key:m,label:P})=>E(dr,{sx:{pl:4},children:E(ur,{primary:P,secondary:a(m,u[m])})},m))})]})]}),D(Q,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[D(te,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",g(u.updatedAt)]}),E(gr,{size:"small",onClick:l,disabled:s,children:E(te,{variant:"caption",children:"Actualizar"})})]})]})})]})},qt=Ht;var go=["create","read","update","delete"],mo=["create","read","update","delete"];import{useRef as fn}from"react";import{useTranslation as yn}from"react-i18next";import{Box as Qe,Typography as xo,Button as hn,Stack as bn,Alert as Co,Divider as wn}from"@mui/material";import{Add as xn}from"@mui/icons-material";import{forwardRef as rn}from"react";import{useTranslation as on}from"react-i18next";import{Box as ve,FormControl as tn,InputLabel as nn,Select as sn,MenuItem as an,IconButton as ln,Typography as Fe,FormHelperText as cn,Stack as Je,Paper as wo,Divider as dn,Button as yr}from"@mui/material";import{Delete as un,SelectAll as gn,ClearAll as mn}from"@mui/icons-material";import{useState as po,useEffect as fo,useRef as yo}from"react";import{useTranslation as $t}from"react-i18next";import{Box as Xe,Typography as Ue,Button as ho,Stack as mr,FormControlLabel as Kt,FormHelperText as bo,Switch as Gt,ToggleButton as pr,ToggleButtonGroup as Yt}from"@mui/material";import{CheckCircle as Xt,Cancel as Jt,SelectAll as Qt,ClearAll as Zt}from"@mui/icons-material";import{jsx as z,jsxs as ye}from"react/jsx-runtime";var en=({value:e,onChange:r,availableFields:o,error:t,disabled:s=!1})=>{let{t:n}=$t(),[i,l]=po("custom"),[c,h]=po(!1),u=yo(null);fo(()=>{c&&u.current?.scrollIntoView({behavior:"smooth",block:"start"})},[c]);let b=yo(!1);fo(()=>{let p=e||{allow:[],owner_allow:[],deny:[]},y=new Set(o),m=(p.allow||[]).filter(C=>y.has(C)),P=(p.owner_allow||[]).filter(C=>y.has(C)),I=(p.deny||[]).filter(C=>y.has(C));o.forEach(C=>{!m.includes(C)&&!P.includes(C)&&!I.includes(C)&&I.push(C)});let V={allow:m,owner_allow:P,deny:I};JSON.stringify(V)!==JSON.stringify(p)&&r(V),m.length===o.length?l("all"):I.length===o.length?l("none"):l("custom")},[o,e]);let g=()=>{b.current=!0,r({allow:[...o],owner_allow:[],deny:[]}),l("all"),setTimeout(()=>{b.current=!1},0)},a=()=>{b.current=!0,r({allow:[],owner_allow:[],deny:[...o]}),l("none"),setTimeout(()=>{b.current=!1},0)},d=p=>e?.allow?.includes(p)?"allow":e?.owner_allow?.includes(p)?"owner_allow":"deny",w=(p,y)=>{b.current=!0;let m=new Set(e?.allow||[]),P=new Set(e?.owner_allow||[]),I=new Set(e?.deny||[]);m.delete(p),P.delete(p),I.delete(p),y==="allow"&&m.add(p),y==="owner_allow"&&P.add(p),y==="deny"&&I.add(p),r({allow:Array.from(m),owner_allow:Array.from(P),deny:Array.from(I)}),l("custom"),setTimeout(()=>{b.current=!1},0)};return o.length===0?ye(Xe,{children:[z(Ue,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("modules.form.publicPolicies.fields.conditions.label")}),z(Ue,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),t&&z(bo,{error:!0,sx:{mt:1},children:t})]}):ye(Xe,{children:[z(Ue,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.label")}),ye(mr,{direction:"row",spacing:1,alignItems:"center",sx:{mb:c?3:1},children:[z(ho,{variant:i==="all"?"contained":"outlined",startIcon:z(Qt,{}),onClick:g,disabled:s,size:"small",sx:{minWidth:120,...i==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("modules.form.publicPolicies.fields.conditions.allFields")}),z(ho,{variant:i==="none"?"contained":"outlined",startIcon:z(Zt,{}),onClick:a,disabled:s,size:"small",sx:{minWidth:120,...i==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("modules.form.publicPolicies.fields.conditions.noFields")}),z(Xe,{sx:{display:"flex",alignItems:"center",px:1.5,py:.35,borderRadius:"999px",backgroundColor:"#f3f4f6",border:"1px solid #d1d9e0"},children:z(Kt,{control:z(Gt,{size:"small",checked:c,onChange:()=>h(p=>!p),disabled:s,color:"primary",sx:{transform:"scale(1.15)",transformOrigin:"center",m:0}}),label:n("modules.form.publicPolicies.fields.conditions.customEdit"),labelPlacement:"end",sx:{ml:0,".MuiFormControlLabel-label":{fontSize:"0.75rem"}}})})]}),c&&ye(Xe,{ref:u,sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[z(Ue,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.help")}),z(mr,{spacing:1,children:o.map(p=>{let y=d(p);return ye(mr,{direction:"row",spacing:1,alignItems:"center",children:[z(Ue,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:p}),ye(Yt,{value:y,exclusive:!0,size:"small",children:[ye(pr,{value:"allow",onClick:()=>w(p,"allow"),disabled:s,sx:{px:2,color:y==="allow"?"#ffffff":"#6b7280",backgroundColor:y==="allow"?"#16a34a":"#f3f4f6",borderColor:y==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:y==="allow"?"#15803d":"#e5e7eb",borderColor:y==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[z(Xt,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.allow")]}),z(pr,{value:"owner_allow",onClick:()=>w(p,"owner_allow"),disabled:s,sx:{px:2,color:y==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:y==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:y==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:y==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:y==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),ye(pr,{value:"deny",onClick:()=>w(p,"deny"),disabled:s,sx:{px:2,color:y==="deny"?"#ffffff":"#6b7280",backgroundColor:y==="deny"?"#dc2626":"#f3f4f6",borderColor:y==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:y==="deny"?"#b91c1c":"#e5e7eb",borderColor:y==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[z(Jt,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},p)})})]}),t&&z(bo,{error:!0,sx:{mt:1},children:t})]})},fr=en;import{jsx as U,jsxs as $}from"react/jsx-runtime";var pn=rn(({policy:e,onChange:r,onRemove:o,availableFields:t,isSubmitting:s=!1,usedActions:n,error:i},l)=>{let{t:c}=on(),h=new Set(Array.from(n||[]));h.delete(e.action);let u=go.map(b=>({value:b,label:c(`modules.form.publicPolicies.fields.action.options.${b}`)}));return $(wo,{ref:l,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[$(ve,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[U(Fe,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:c("modules.form.publicPolicies.policyTitle")}),U(ln,{onClick:o,size:"small",disabled:s,"aria-label":c("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:U(un,{})})]}),$(Je,{spacing:1,children:[U(Je,{direction:{xs:"column",md:"row"},spacing:2,children:U(ve,{sx:{flex:1,minWidth:200},children:$(tn,{fullWidth:!0,children:[U(nn,{children:c("modules.form.publicPolicies.fields.action.label")}),U(sn,{value:e.action,label:c("modules.form.publicPolicies.fields.action.label"),disabled:s,onChange:b=>{let g=b.target.value,a={...e,action:g};g==="delete"?(a.permission="deny",delete a.fields):(a.fields={allow:[],owner_allow:[],deny:t},delete a.permission),r(a)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:u.map(b=>{let g=h.has(b.value);return U(an,{value:b.value,disabled:g,children:b.label},b.value)})}),i&&U(cn,{error:!0,children:i})]})})}),e.action==="delete"?$(ve,{children:[U(Fe,{variant:"body2",color:"text.secondary",sx:{mb:2},children:c("modules.form.publicPolicies.fields.conditions.label")}),$(Je,{direction:"row",spacing:1,sx:{mb:1},children:[U(yr,{variant:e.permission==="*"?"contained":"outlined",startIcon:U(gn,{}),onClick:()=>r({...e,permission:"*"}),disabled:s,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:c("modules.form.publicPolicies.fields.conditions.allFields")}),U(yr,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>r({...e,permission:"owner"}),disabled:s,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:c("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),U(yr,{variant:e.permission==="deny"?"contained":"outlined",startIcon:U(mn,{}),onClick:()=>r({...e,permission:"deny"}),disabled:s,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:c("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):U(fr,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:b=>r({...e,fields:b}),availableFields:t,disabled:s}),U(wo,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):$(Je,{spacing:.5,divider:U(dn,{sx:{borderColor:"#e5e7eb"}}),children:[$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:"#16a34a"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(e?.fields?.allow||[]).join(", ")||"-"]}),$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:"#0ea5e9"},children:[c("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(e?.fields?.owner_allow||[]).join(", ")||"-"]}),$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(e?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),hr=pn;import{Fragment as vn,jsx as ae,jsxs as Ze}from"react/jsx-runtime";var Cn=()=>{let e=globalThis?.crypto;return e&&typeof e.randomUUID=="function"?e.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},Pn=({policies:e,onChange:r,availableFields:o,errors:t,isSubmitting:s=!1})=>{let{t:n}=yn(),i=fn({}),l=new Set((e||[]).map(d=>d.action).filter(Boolean)),c=mo.filter(d=>!l.has(d)),h=c.length>0,u=()=>{let d=c[0]||"create",w={id:Cn(),action:d};d==="delete"?w.permission="deny":w.fields={allow:[],owner_allow:[],deny:o};let p=[...e||[],w];r(p),setTimeout(()=>{let y=p.length-1,m=i.current[y];m&&m.scrollIntoView({behavior:"smooth",block:"center"})},100)},b=d=>{let w=[...e];w.splice(d,1),r(w)},g=(()=>{if(!t)return null;if(typeof t=="string")return t;let d=t._error;return typeof d=="string"?d:null})(),a=new Set((e||[]).map(d=>d.action));return Ze(vn,{children:[ae(wn,{sx:{borderColor:"#e0e4e7"}}),Ze(Qe,{children:[ae(Qe,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:Ze(Qe,{children:[ae(xo,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("modules.form.publicPolicies.title")}),ae(xo,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("modules.form.publicPolicies.description")})]})}),g&&ae(Co,{severity:"error",sx:{mb:3},children:g}),Ze(bn,{spacing:3,children:[(e||[]).length===0?ae(Co,{severity:"info",children:n("modules.form.publicPolicies.noPolicies")}):e.map((d,w)=>ae(hr,{ref:p=>{i.current[w]=p},policy:d,onChange:p=>{let y=[...e];y[w]=p,r(y)},onRemove:()=>b(w),availableFields:o,isSubmitting:s,usedActions:a,error:typeof t=="object"&&t&&d.id in t?t[d.id]:void 0},d.id)),h&&ae(Qe,{children:ae(hn,{type:"button",variant:"outlined",startIcon:ae(xn,{}),onClick:u,disabled:s,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("modules.form.publicPolicies.addPolicy")})})]})]})]})},Ta=Pn;import{useState as br}from"react";import{Button as er,TextField as Po,Box as _e,Alert as Me,Typography as he,CircularProgress as wr}from"@mui/material";import{jsx as N,jsxs as ue}from"react/jsx-runtime";function Aa(){let[e,r]=br(""),[o,t]=br(""),[s,n]=br(!1),{isAuthenticated:i,isLoading:l,error:c,login:h,logout:u,refreshTokens:b,clearError:g,isExpiringSoon:a,expiresIn:d}=me(),w=async m=>{if(m.preventDefault(),!e||!o)return;(await h(e,o)).success&&(r(""),t(""),n(!1))},p=async()=>{await u()},y=async()=>{await b()};return i?ue(_e,{sx:{maxWidth:600,mx:"auto",p:3},children:[N(he,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),N(Me,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),ue(_e,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[N(he,{variant:"h6",gutterBottom:!0,children:"Token Status"}),ue(he,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(d/1e3/60)," minutes"]}),a&&N(Me,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),ue(_e,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[N(er,{variant:"contained",onClick:y,disabled:l,startIcon:l?N(wr,{size:16}):null,children:"Refresh Tokens"}),N(er,{variant:"outlined",color:"error",onClick:p,disabled:l,children:"Logout"})]}),c&&N(Me,{severity:"error",sx:{mt:2},onClose:g,children:c})]}):ue(_e,{sx:{maxWidth:400,mx:"auto",p:3},children:[N(he,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),N(Me,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),s?ue("form",{onSubmit:w,children:[N(Po,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:m=>r(m.target.value),margin:"normal",required:!0,autoComplete:"email"}),N(Po,{fullWidth:!0,label:"Password",type:"password",value:o,onChange:m=>t(m.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),N(er,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:l,startIcon:l?N(wr,{size:16}):null,sx:{mt:3,mb:2},children:l?"Logging in...":"Login"})]}):N(er,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),c&&N(Me,{severity:"error",sx:{mt:2},onClose:g,children:c})]})}function Fa(){let{isAuthenticated:e,isLoading:r,isExpiringSoon:o,expiresIn:t}=me();return r?ue(_e,{sx:{display:"flex",alignItems:"center",gap:1},children:[N(wr,{size:16}),N(he,{variant:"caption",children:"Loading session..."})]}):e?ue(_e,{children:[N(he,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),o&&ue(he,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):N(he,{variant:"caption",color:"text.secondary",children:"Not logged in"})}import Tn from"@mui/material/TextField";import En from"@mui/material/CircularProgress";import vo from"@mui/material/InputAdornment";import Rn from"@mui/material/IconButton";import Sn from"@mui/icons-material/Refresh";import{jsx as be}from"react/jsx-runtime";var In=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),kn=({html:e})=>be("span",{dangerouslySetInnerHTML:{__html:In(e)}}),Va=({config:e,value:r,onChange:o,label:t,error:s=!1,helperText:n,readOnly:i=!1,disabled:l=!1})=>{let{value:c,loading:h,error:u,regenerate:b}=kr(e,{autoFetch:!r,onSuccess:y=>{o?.(y)}}),g=r||c,a=s||!!u,d=u||n,w=a&&d&&(d.toLowerCase().includes("duplicate")||d.toLowerCase().includes("duplicado")||d.toLowerCase().includes("duplicada")||d.toLowerCase().includes("unique")||d.toLowerCase().includes("\xFAnico")||d.toLowerCase().includes("unico")||d.toLowerCase().includes("\xFAnica")||d.toLowerCase().includes("unica")||d.toLowerCase().includes("already exists")||d.toLowerCase().includes("ya existe")||d.toLowerCase().includes("e11000"));return be(Tn,{label:t,fullWidth:!0,value:g,error:a,helperText:d?be(kn,{html:d}):" ",disabled:l,InputProps:{readOnly:!0,startAdornment:h?be(vo,{position:"start",children:be(En,{size:20})}):void 0,endAdornment:w&&!h?be(vo,{position:"end",children:be(Rn,{edge:"end",onClick:async()=>{!l&&!h&&await b()},disabled:l,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:be(Sn,{})})}):void 0}})};import To,{useCallback as Ve,useRef as Eo,useState as So}from"react";import Te from"@mui/material/Box";import Ee from"@mui/material/Typography";import Ro from"@mui/material/IconButton";import Ln from"@mui/material/LinearProgress";import xr from"@mui/material/CircularProgress";import An from"@mui/material/Chip";import Fn from"@mui/material/Paper";import _n from"@mui/material/List";import On from"@mui/material/ListItem";import Bn from"@mui/material/ListItemText";import Dn from"@mui/material/ListItemSecondaryAction";import Nn from"@mui/material/FormHelperText";import zn from"@mui/icons-material/CloudUpload";import Un from"@mui/icons-material/InsertDriveFile";import Mn from"@mui/icons-material/Image";import Vn from"@mui/icons-material/PictureAsPdf";import Wn from"@mui/icons-material/Delete";import Hn from"@mui/icons-material/Refresh";import qn from"@mui/icons-material/CheckCircle";import jn from"@mui/icons-material/Error";import gl from"@mui/icons-material/BrokenImage";import{jsx as S,jsxs as we}from"react/jsx-runtime";var Io=e=>{if(e===0)return"0 B";let r=1024,o=["B","KB","MB","GB"],t=Math.floor(Math.log(e)/Math.log(r));return`${parseFloat((e/Math.pow(r,t)).toFixed(1))} ${o[t]}`},$n=e=>e.startsWith("image/")?S(Mn,{color:"primary"}):e==="application/pdf"?S(Vn,{color:"error"}):S(Un,{color:"action"}),Kn=e=>{switch(e){case"completed":return S(qn,{color:"success",fontSize:"small"});case"error":return S(jn,{color:"error",fontSize:"small"});case"uploading":case"pending":return S(xr,{size:16});case"removing":return S(xr,{size:16,color:"error"});default:return null}},Gn=({file:e,baseUrl:r,disabled:o,onRemove:t,onRetry:s})=>{let[n,i]=So(!1),l=!o&&e.status!=="uploading"&&e.status!=="removing",c=!o&&e.status==="error"&&e.file,h=e.contentType.startsWith("image/"),u=e.visibility==="public"||e.filePath?.startsWith("public/")||e.filePath?.startsWith(r),g=!e.filePath||!u?null:e.filePath.startsWith("http://")||e.filePath.startsWith("https://")||e.filePath.startsWith(r)?e.filePath:`${r}${e.filePath}`,a=e.status==="completed"&&g,d=()=>h&&a&&!n?S(Te,{component:a?"a":"div",href:g||void 0,target:"_blank",rel:"noopener noreferrer",sx:{width:48,height:48,borderRadius:1,overflow:"hidden",display:"flex",alignItems:"center",justifyContent:"center",bgcolor:"grey.100",border:"1px solid",borderColor:"divider",cursor:a?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,"&:hover":a?{borderColor:"primary.main",transform:"scale(1.05)"}:{}},children:S("img",{src:g,alt:e.name,style:{width:"100%",height:"100%",objectFit:"cover"},onError:()=>i(!0)})}):S(Te,{component:a?"a":"div",href:g||void 0,target:"_blank",rel:"noopener noreferrer",sx:{width:48,height:48,borderRadius:1,display:"flex",alignItems:"center",justifyContent:"center",bgcolor:"grey.50",border:"1px solid",borderColor:"divider",cursor:a?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,textDecoration:"none","&:hover":a?{borderColor:"primary.main",bgcolor:"action.hover"}:{}},children:$n(e.contentType)});return we(On,{sx:{borderRadius:1,mb:.5,bgcolor:e.status==="error"?"error.lighter":"background.paper",border:"1px solid",borderColor:e.status==="error"?"error.light":"divider",gap:1.5},children:[d(),S(Bn,{primary:we(Te,{sx:{display:"flex",alignItems:"center",gap:1},children:[S(Ee,{variant:"body2",noWrap:!0,sx:{maxWidth:200,overflow:"hidden",textOverflow:"ellipsis"},children:e.name}),Kn(e.status)]}),secondary:we(Te,{children:[e.size>0&&S(Ee,{variant:"caption",color:"text.secondary",children:Io(e.size)}),e.status==="uploading"&&S(Ln,{variant:"determinate",value:e.progress,sx:{mt:.5,height:4,borderRadius:2}}),e.status==="error"&&e.errorMessage&&S(Ee,{variant:"caption",color:"error",display:"block",children:e.errorMessage}),a&&S(Ee,{variant:"caption",color:"primary",display:"block",children:h?"Click thumbnail to view":"Click to download"})]})}),we(Dn,{children:[c&&S(Ro,{edge:"end",size:"small",onClick:()=>s(e.id),color:"primary",title:"Retry",children:S(Hn,{fontSize:"small"})}),l&&S(Ro,{edge:"end",size:"small",onClick:()=>t(e.id),color:"error",title:"Delete",children:S(Wn,{fontSize:"small"})})]})]})};var pl=({label:e,accept:r,maxFileSize:o=10*1024*1024,multiple:t=!1,maxFiles:s,minFiles:n=0,required:i=!1,disabled:l=!1,error:c=!1,helperText:h,onChange:u,onValidation:b,initialFiles:g,placeholder:a,showFileList:d=!0,visibility:w="private",showPreview:p=!0,baseUrl:y})=>{let m=Eo(null),[P,I]=So(!1),V=t?s:1,C=i?Math.max(n,1):n,f={acceptedTypes:r,maxFileSize:o,maxFiles:V,minFiles:C,visibility:w,onFilesChange:L=>{let re=L.filter(Ce=>Ce.status==="completed"&&Ce.filePath).map(Ce=>{let Se=Ce.filePath;return Se.startsWith(y)||Se.startsWith("http://")||Se.startsWith("https://")?Se:y?`${y}${Se}`:Se});u?.(re)}},{files:T,isUploading:A,addFiles:O,removeFile:le,retryUpload:xe,isValid:ne,validationError:ge,initializeFiles:F,isTouched:W,markAsTouched:_,getPreviewUrl:Re}=Lr(f),R=Eo(!1);To.useEffect(()=>{g&&g.length>0&&!R.current&&(R.current=!0,F(g))},[g,F]),To.useEffect(()=>{b?.(ne,ge)},[ne,ge,b]);let q=Ve(L=>{_();let re=L.target.files;re&&re.length>0&&O(re),m.current&&(m.current.value="")},[O,_]),v=Ve(()=>{l||(_(),m.current?.click())},[l,_]),k=Ve(L=>{L.preventDefault(),L.stopPropagation(),l||I(!0)},[l]),B=Ve(L=>{L.preventDefault(),L.stopPropagation(),I(!1)},[]),j=Ve(L=>{if(L.preventDefault(),L.stopPropagation(),I(!1),l)return;_();let re=L.dataTransfer.files;re&&re.length>0&&O(re)},[l,O,_]),Y=r?.join(",")||"",X=!l&&(t||T.length===0),ce=c||W&&!ne,Pr=h||(W?ge:null);return we(Te,{sx:{width:"100%"},children:[e&&we(Ee,{variant:"body2",sx:{mb:1,fontWeight:500,color:ce?"error.main":"text.primary"},children:[e,i&&S("span",{style:{color:"red"},children:" *"})]}),S("input",{ref:m,type:"file",accept:Y,multiple:t,onChange:q,disabled:l,style:{display:"none"}}),X&&we(Fn,{variant:"outlined",onClick:v,onDragOver:k,onDragLeave:B,onDrop:j,sx:{p:3,textAlign:"center",cursor:l?"not-allowed":"pointer",borderStyle:"dashed",borderWidth:2,borderColor:P?"primary.main":ce?"error.main":"divider",bgcolor:P?"primary.lighter":l?"action.disabledBackground":"background.paper",transition:"all 0.2s ease","&:hover":l?{}:{borderColor:"primary.main",bgcolor:"action.hover"}},children:[S(zn,{sx:{fontSize:48,color:P?"primary.main":l?"action.disabled":"action.active",mb:1}}),S(Ee,{variant:"body2",color:l?"text.disabled":"text.secondary",children:(()=>{if(a)return a;let L=[];if(P)return"Drop file here";if(L.push("Drag files here or click to select"),r&&r.length>0){let re=r.map(Ce=>Ce.split("/")[1]?.toUpperCase()||Ce).join(", ");L.push(`Allowed types: ${re}`)}return o&&L.push(`Max ${Io(o)} per file`),V!==void 0&&t&&L.push(`Max ${V} files`),L[0]})()}),r&&r.length>0&&!P&&S(Te,{sx:{mt:1,display:"flex",gap:.5,justifyContent:"center",flexWrap:"wrap"},children:r.map(L=>S(An,{label:L.split("/")[1]?.toUpperCase()||L,size:"small",variant:"outlined",sx:{fontSize:"0.7rem"}},L))})]}),d&&T.length>0&&S(_n,{dense:!0,sx:{mt:1,p:0},children:T.map(L=>S(Gn,{file:L,baseUrl:y,disabled:l,onRemove:le,onRetry:xe},L.id))}),A&&we(Te,{sx:{display:"flex",alignItems:"center",gap:1,mt:1},children:[S(xr,{size:16}),S(Ee,{variant:"caption",color:"text.secondary",children:"Uploading files..."})]}),Pr&&S(Nn,{error:ce,sx:{mt:.5},children:Pr})]})};import{useCallback as Yn,useRef as Xn,useEffect as Jn}from"react";import ko from"@mui/material/Box";import Lo from"@mui/material/Typography";import Ao from"@mui/material/FormHelperText";import{MDXEditor as Qn,headingsPlugin as Zn,listsPlugin as ei,quotePlugin as ri,thematicBreakPlugin as oi,markdownShortcutPlugin as ti,linkPlugin as ni,linkDialogPlugin as ii,tablePlugin as si,toolbarPlugin as ai,UndoRedo as li,BoldItalicUnderlineToggles as ci,BlockTypeSelect as di,CreateLink as ui,InsertTable as gi,ListsToggle as mi,Separator as rr}from"@mdxeditor/editor";import"@mdxeditor/editor/style.css";import{Fragment as pi,jsx as K,jsxs as Cr}from"react/jsx-runtime";var Tl=({label:e,value:r="",onChange:o,required:t=!1,disabled:s=!1,error:n=!1,helperText:i,placeholder:l="Write here...",minHeight:c=200,maxHeight:h=500})=>{let u=Xn(null);Jn(()=>{u.current&&u.current.getMarkdown()!==r&&u.current.setMarkdown(r||"")},[r]);let b=Yn(g=>{o?.(g)},[o]);return Cr(ko,{sx:{width:"100%"},children:[e&&Cr(Lo,{component:"label",sx:{display:"block",mb:.5,fontSize:"0.875rem",fontWeight:500,color:n?"error.main":"text.primary"},children:[e,t&&K(Lo,{component:"span",color:"error.main",sx:{ml:.5},children:"*"})]}),K(ko,{sx:{border:1,borderColor:n?"error.main":"divider",borderRadius:1,overflow:"hidden",opacity:s?.6:1,pointerEvents:s?"none":"auto","& .mdxeditor":{minHeight:c,maxHeight:h,overflow:"auto"},"& .mdxeditor-toolbar":{borderBottom:1,borderColor:"divider",backgroundColor:"background.default"},"& .mdxeditor-root-contenteditable":{padding:2,minHeight:c-50}},children:K(Qn,{ref:u,markdown:r||"",onChange:b,placeholder:l,readOnly:s,plugins:[Zn(),ei(),ri(),oi(),ti(),ni(),ii(),si(),ai({toolbarContents:()=>Cr(pi,{children:[K(li,{}),K(rr,{}),K(ci,{}),K(rr,{}),K(di,{}),K(rr,{}),K(mi,{}),K(rr,{}),K(ui,{}),K(gi,{})]})})]})}),i&&K(Ao,{error:n,sx:{mx:0,mt:.5},children:i}),!i&&K(Ao,{sx:{mx:0,mt:.5},children:"\xA0"})]})};export{de as a,yi as b,hi as c,or as d,He as e,ki as f,Nr as g,Ms as h,qt as i,go as j,mo as k,Ta as l,Aa as m,Fa as n,Va as o,pl as p,Tl as q};
|
|
1
|
+
import{b as Er,c as ie,h as Sr,j as me,l as Ir,m as kr,p as Lr}from"./chunk-EWX62JA4.mjs";import{g as G}from"./chunk-BJ6PIVZR.mjs";import{a as x,b as vr,c as Tr,h as Rr}from"./chunk-HQKET2ZX.mjs";var de={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...","modules.form.publicPolicies.fields.conditions.customEdit":"Edici\xF3n personalizada"},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...","modules.form.publicPolicies.fields.conditions.customEdit":"Custom Edit"}},yi=()=>Object.keys(de),hi=e=>de[e]||de.es;import We from"@nocios/crudify-browser";var Ar="crudify_translations_",Fo=3600*1e3;function Fr(e){let r=0;for(let o=0;o<e.length;o++){let t=e.charCodeAt(o);r=(r<<5)-r+t,r=r&r}return Math.abs(r).toString(36)}var or=class e{constructor(){this.enableDebug=!1;this.initializationPromise=null;this.isInitialized=!1}static getInstance(){return e.instance||(e.instance=new e),e.instance}setDebug(r){this.enableDebug=r}async ensureCrudifyInitialized(r,o){if(!this.isInitialized)return this.initializationPromise?(this.enableDebug&&x.debug("[TranslationService] Waiting for crudify initialization..."),this.initializationPromise):(this.enableDebug&&x.debug("[TranslationService] Initializing crudify SDK..."),this.initializationPromise=(async()=>{try{let t=We.getTokenData();if(t&&t.endpoint){this.enableDebug&&x.debug("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}We.config(o);let s=await We.init(r,this.enableDebug?"debug":"none");if(s.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(s.errors||"Unknown error")}`);this.isInitialized=!0,this.enableDebug&&x.debug("[TranslationService] Crudify SDK initialized successfully")}catch(t){throw x.error("[TranslationService] Failed to initialize crudify",t instanceof Error?t:{message:String(t)}),this.initializationPromise=null,t}})(),this.initializationPromise)}async fetchTranslations(r){let{apiKey:o,featureKeys:t,crudifyEnv:s="stg",urlTranslations:n}=r;this.enableDebug&&x.debug("[TranslationService] fetchTranslations called with:",{apiKeyHash:Fr(o),crudifyEnv:s,featureKeys:t,hasUrlTranslations:!!n});let i=this.getFromCache(o),l=i?this.isCacheExpired(i):!0;if(i&&!l)return this.enableDebug&&x.debug("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(i.data.translations,n);try{await this.ensureCrudifyInitialized(o,s)}catch(c){return x.error("[TranslationService] Failed to initialize crudify",c instanceof Error?c:{message:String(c)}),i?(x.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(i.data.translations,n)):(x.warn("[TranslationService] Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&x.debug("[TranslationService] Fetching from API via crudify SDK");let c=await this.fetchFromAPI(t);this.hasDataChanged(i,c)||!i?this.saveToCache(o,c):this.refreshCacheTimestamp(o);let u=this.mergeWithUrlTranslations(c.translations,n);return this.enableDebug&&x.debug("[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 x.error("[TranslationService] API fetch failed",c instanceof Error?c:{message:String(c)}),i?(x.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(i.data.translations,n)):(x.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(r){let o=await We.getTranslation(r);if(!o.success)throw new Error(`Crudify API error: ${o.errors?JSON.stringify(o.errors):"Unknown error"}`);if(!o.data)throw new Error("No translation data in response");return o.data}mergeWithUrlTranslations(r,o){if(!o||Object.keys(o).length===0)return r;let t={};return Object.keys(r).forEach(s=>{t[s]={...r[s],...o}}),t}hasDataChanged(r,o){if(!r||r.data.timestamp!==o.timestamp)return!0;let t=this.hashData(o.translations);return r.dataHash!==t}hashData(r){let o=JSON.stringify(r),t=0;for(let s=0;s<o.length;s++){let n=o.charCodeAt(s);t=(t<<5)-t+n,t=t&t}return t.toString(36)}saveToCache(r,o){try{let t=this.getCacheKey(r),s={data:o,cachedAt:Date.now(),dataHash:this.hashData(o.translations)};localStorage.setItem(t,JSON.stringify(s)),this.enableDebug&&x.debug("[TranslationService] Saved to cache:",{cacheKey:t})}catch(t){x.error("[TranslationService] Failed to save cache",t instanceof Error?t:{message:String(t)})}}getFromCache(r){try{let o=this.getCacheKey(r),t=localStorage.getItem(o);return t?JSON.parse(t):null}catch(o){return x.error("[TranslationService] Failed to read cache",o instanceof Error?o:{message:String(o)}),null}}refreshCacheTimestamp(r){try{let o=this.getFromCache(r);if(o){o.cachedAt=Date.now();let t=this.getCacheKey(r);localStorage.setItem(t,JSON.stringify(o))}}catch(o){x.error("[TranslationService] Failed to refresh cache timestamp",o instanceof Error?o:{message:String(o)})}}isCacheExpired(r){return Date.now()-r.cachedAt>Fo}hasValidCache(r){let o=this.getFromCache(r);return o?!this.isCacheExpired(o):!1}getCacheKey(r){return`${Ar}${Fr(r)}`}getCriticalTranslationsOnly(){return de}invalidateCache(r){let o=this.getCacheKey(r);localStorage.removeItem(o),this.enableDebug&&x.debug("[TranslationService] Cache invalidated:",{cacheKey:o})}async prefetchTranslations(r){try{await this.fetchTranslations(r),this.enableDebug&&x.debug("[TranslationService] Prefetch completed")}catch(o){x.error("[TranslationService] Prefetch failed",o instanceof Error?o:{message:String(o)})}}clearAllCaches(){try{let o=Object.keys(localStorage).filter(t=>t.startsWith(Ar));o.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&x.debug(`[TranslationService] Cleared ${o.length} cache entries`)}catch(r){x.error("[TranslationService] Failed to clear caches",r instanceof Error?r:{message:String(r)})}}},He=or.getInstance();import{createContext as _o,useContext as Oo,useEffect as Br,useState as Ie,useMemo as _r,useCallback as Bo}from"react";import{Fragment as No,jsx as je}from"react/jsx-runtime";var qe=null,tr=!1,Dr=_o(null);function Or(e,r,o){return{...e,...r,...o||{}}}function Do(e,r,o,t,s){Br(()=>{if(!t||!e||!r)return;let n=o||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!n||!n.addResourceBundle){s&&x.debug("[TranslationsProvider] i18next not found, skipping auto-sync");return}s&&x.debug("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:r}),Object.keys(e).forEach(i=>{e[i]&&Object.keys(e[i]).length>0&&(n.addResourceBundle(i,"translation",e[i],!0,!0),s&&x.debug(`[TranslationsProvider] Synced ${Object.keys(e[i]).length} keys for language: ${i}`))}),n.language!==r&&(n.changeLanguage(r),s&&x.debug(`[TranslationsProvider] Changed i18next language to: ${r}`))},[e,r,o,t,s])}var ki=({children:e,apiKey:r,crudifyEnv:o="prod",featureKeys:t,language:s="es",devTranslations:n,translationUrl:i,enableDebug:l=!1,skipAutoInit:c=!0,autoSyncI18n:h=!0,i18nInstance:u,loadingFallback:b,waitForInitialLoad:g=!0})=>{let a=_r(()=>Tr({publicApiKey:r,env:o,featureKeys:t,enableDebug:l}),[r,o,t,l]),d=a.publicApiKey||"",w=a.env||o||"prod",p=a.featureKeys||t,[y,m]=Ie({}),[P,I]=Ie(!0),[V,C]=Ie(!0),[f,T]=Ie(null),[A,O]=Ie(void 0),[le,xe]=Ie(!1),ne=Bo(async()=>{if(!d){l&&x.debug("[TranslationsProvider] No apiKey - skipping translation fetch"),I(!1),C(!1);return}if(le){l&&x.debug("[TranslationsProvider] Skipping reload - using fallback translations");return}if(He.hasValidCache(d)&&V&&(l&&x.debug("[TranslationsProvider] Valid cache found - not blocking initial render"),C(!1)),tr&&qe){l&&x.debug("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let R=await qe;m(R),I(!1);return}catch{l&&x.warn("[TranslationsProvider] Global fetch failed, retrying")}}tr=!0,I(!0),T(null);let _;if(i)try{l&&x.debug(`[TranslationsProvider] Fetching translations from URL: ${i}`);let R=await fetch(i);if(!R.ok)throw new Error(`Failed to fetch translations: ${R.statusText}`);_=await R.json(),O(_),l&&x.debug("[TranslationsProvider] URL translations loaded:",{keysCount:_?Object.keys(_).length:0})}catch(R){x.error("[TranslationsProvider] Failed to load URL translations",R instanceof Error?R:{message:String(R)}),_=void 0,O(void 0)}let Re=(async()=>{try{He.setDebug(l);let R=await He.fetchTranslations({apiKey:d,crudifyEnv:w,featureKeys:p,urlTranslations:_}),q={};return Object.keys(R).forEach(v=>{let k=de[v]||{},B=R[v]||{};q[v]=Or(k,B,n)}),l&&x.debug("[TranslationsProvider] Loaded translations:",{languages:Object.keys(q),keysCount:Object.keys(q[s]||{}).length}),q}catch(R){x.error("[TranslationsProvider] Failed to load",R instanceof Error?R:{message:String(R)}),T(R instanceof Error?R.message:String(R)),xe(!0);let q={};return Object.keys(de).forEach(v=>{let k=de[v],B=_||A||{};q[v]=Or(k,B,n)}),l&&x.debug("[TranslationsProvider] Using fallback translations (critical + URL)"),q}})();qe=Re;try{let R=await Re;m(R)}finally{I(!1),C(!1),tr=!1,setTimeout(()=>{qe=null},1e3)}},[d,w,p,i,n,l,s,le]);Br(()=>{ne();let W=setInterval(ne,3600*1e3);return()=>clearInterval(W)},[ne]);let ge=_r(()=>(W,_)=>{let R=(y[s]||{})[W];if(!R){let q=Object.keys(y);for(let v of q)if(y[v][W]){R=y[v][W];break}}return R||(l&&x.warn(`[TranslationsProvider] Missing translation: "${W}"`),R=W),_&&typeof R=="string"&&Object.entries(_).forEach(([q,v])=>{let k=new RegExp(`{{${q}}}`,"g");R=R.replace(k,String(v))}),R},[y,s,l]);Do(y,s,u,h,l);let F={t:ge,language:s,availableLanguages:Object.keys(y),translations:y,isLoading:P,error:f,refreshTranslations:ne};return d?g&&V&&P?b||je("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:je("div",{children:"Loading translations..."})}):je(Dr.Provider,{value:F,children:e}):(l&&x.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),je(No,{children:e}))},Nr=()=>{let e=Oo(Dr);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};import{Box as Pt,Typography as vt}from"@mui/material";import{createContext as Uo,useContext as Mo,useMemo as ir}from"react";import{useState as nr,useEffect as zo}from"react";var zr=(e,r)=>{let[o,t]=nr({}),[s,n]=nr(!1),[i,l]=nr(null);return zo(()=>{if(r&&Object.keys(r).length>0){t(r),n(!1),l(null);return}if(!e){t({}),n(!1),l(null);return}let c=!1;return n(!0),l(null),fetch(e).then(h=>{if(!h.ok)throw new Error(`Failed to load translations: ${h.status}`);return h.json()}).then(h=>{c||(t(h),n(!1))}).catch(h=>{c||(x.error("[I18nProvider] Failed to load translations from URL",h instanceof Error?h:{message:String(h),url:e}),l(h instanceof Error?h.message:String(h)),t({}),n(!1))}),()=>{c=!0}},[e,r]),{translations:o,loading:s,error:i}};import{jsx as Ur}from"react/jsx-runtime";var Mr=Uo(null),Vo=()=>{try{return Nr()}catch{return null}},Wo=(e,r)=>{if(r.includes(".")){let o=r.split(".").reduce((t,s)=>t&&typeof t=="object"?t[s]:void 0,e);if(o!==void 0)return o}if(e&&e[r])return e[r]},Vr=({children:e,translations:r,translationsUrl:o,language:t="en"})=>{let n=Vo()?.translations?.[t]||{},{translations:i,loading:l}=zr(o,r),c=ir(()=>({...n,...i,...r||{}}),[n,i,r]),h=ir(()=>(b,g)=>{let a=Wo(c,b);return a==null&&(a=b),g&&typeof a=="string"&&Object.entries(g).forEach(([d,w])=>{a=a.replace(new RegExp(`{{${d}}}`,"g"),w)}),typeof a=="string"?a:b},[c]),u=ir(()=>({t:h,language:t}),[h,t]);return l?Ur("div",{children:"Loading translations..."}):Ur(Mr.Provider,{value:u,children:e})},Z=()=>{let e=Mo(Mr);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};import{createContext as Ho,useContext as qo,useReducer as jo,useEffect as Wr}from"react";import{jsx as Ko}from"react/jsx-runtime";var Hr={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function $o(e,r){switch(r.type){case"SET_SCREEN":let o={...e,currentScreen:r.payload.screen,searchParams:r.payload.params||e.searchParams,errors:{global:[]}},t=new URLSearchParams(o.searchParams),s=t.toString()?`?${t.toString()}`:window.location.pathname;try{window.history.replaceState({},"",s)}catch{}return o;case"SET_SEARCH_PARAMS":return{...e,searchParams:r.payload};case"UPDATE_FORM_DATA":return{...e,formData:{...e.formData,...r.payload},errors:{...e.errors,...Object.keys(r.payload).reduce((n,i)=>({...n,[i]:void 0}),{})}};case"SET_LOADING":return{...e,loading:r.payload};case"SET_ERRORS":return{...e,errors:{...e.errors,...r.payload}};case"CLEAR_ERRORS":return{...e,errors:{global:[]}};case"SET_EMAIL_SENT":return{...e,emailSent:r.payload};case"SET_CODE_ALREADY_EXISTS":return{...e,codeAlreadyExists:r.payload};case"SET_CODE_VALIDATED":return{...e,codeValidated:r.payload};case"SET_FROM_CODE_VERIFICATION":return{...e,fromCodeVerification:r.payload};case"RESET_FORM":return{...e,formData:Hr.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...e,config:r.payload};default:return e}}var qr=Ho(void 0),jr=({children:e,initialScreen:r="login",config:o,autoReadFromCookies:t=!0})=>{let[s,n]=jo($o,{...Hr,currentScreen:r});Wr(()=>{n({type:"INIT_CONFIG",payload:(()=>{let a={};if(t)try{let d=vr("logo");if(d){let w=decodeURIComponent(d);w.startsWith("http")&&(a.logo=w)}}catch(d){x.error("Error reading configuration from cookies",d instanceof Error?d:{message:String(d)})}return{publicApiKey:o?.publicApiKey,env:o?.env,appName:o?.appName,logo:o?.logo||a.logo,loginActions:o?.loginActions}})()})},[o,t]),Wr(()=>{let g=new URLSearchParams(window.location.search),a={};g.forEach((d,w)=>{a[w]=d}),Object.keys(a).length>0&&n({type:"SET_SEARCH_PARAMS",payload:a}),r==="checkCode"&&a.email&&n({type:"UPDATE_FORM_DATA",payload:{email:a.email,code:a.code||""}}),r==="resetPassword"&&a.link&&n({type:"SET_SEARCH_PARAMS",payload:a})},[r]);let b={state:s,dispatch:n,setScreen:(g,a)=>{n({type:"SET_SCREEN",payload:{screen:g,params:a}})},updateFormData:g=>{n({type:"UPDATE_FORM_DATA",payload:g})},setFieldError:(g,a)=>{n({type:"SET_ERRORS",payload:{[g]:a}})},clearErrors:()=>{n({type:"CLEAR_ERRORS"})},setLoading:g=>{n({type:"SET_LOADING",payload:g})}};return Ko(qr.Provider,{value:b,children:e})},$e=()=>{let e=qo(qr);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};import{useEffect as Go,useRef as Yo}from"react";import{Typography as sr,TextField as $r,Button as Xo,Box as Oe,CircularProgress as Jo,Alert as Qo,Link as Kr}from"@mui/material";import{Fragment as et,jsx as ee,jsxs as Be}from"react/jsx-runtime";var Zo=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:s="/"})=>{let{crudify:n}=ie(),{state:i,updateFormData:l,setFieldError:c,clearErrors:h,setLoading:u}=$e(),{login:b}=me(),g=Z(),{t:a}=g,d=g.i18n,w=Yo(null),p=Rr(a,{currentLanguage:d?.language,enableDebug:!1}),y=()=>{if(i.searchParams.redirect)try{let f=decodeURIComponent(i.searchParams.redirect);if(f.startsWith("/")&&!f.startsWith("//"))return f}catch{}return s||"/"};Go(()=>{let f=setTimeout(()=>{w.current&&w.current.focus()},100);return()=>clearTimeout(f)},[]);let m=f=>p.translateError({code:f.code,message:f.message,field:f.field}),P=async()=>{if(!i.loading){if(!i.formData.username.trim()){c("username",a("login.usernameRequired"));return}if(!i.formData.password.trim()){c("password",a("login.passwordRequired"));return}h(),u(!0);try{let f=await b(i.formData.username,i.formData.password);if(u(!1),f.success){let T=y();o&&o(f.data,T)}else{let T=f.rawResponse||f;I(T)}}catch(f){u(!1);let A=G(f).map(m);c("global",A),t&&t(A.join(", "))}}},I=f=>{let T=G(f),A=[];T.forEach(O=>{O.field?c(O.field,m(O)):A.push(m(O))}),A.length>0&&c("global",A)};return Be(et,{children:[Be(Oe,{component:"form",noValidate:!0,onSubmit:f=>{f.preventDefault(),P()},onKeyDown:f=>{f.key==="Enter"&&!i.loading&&(f.preventDefault(),P())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Be(Oe,{sx:{mb:1},children:[ee(sr,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:a("login.usernameOrEmailLabel")}),ee($r,{fullWidth:!0,id:"email",name:"email",type:"email",value:i.formData.username,disabled:i.loading,onChange:f=>l({username:f.target.value}),error:!!i.errors.username,helperText:i.errors.username,autoComplete:"email",placeholder:a("login.usernameOrEmailPlaceholder"),inputRef:w,required:!0})]}),Be(Oe,{sx:{mb:1},children:[ee(sr,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:a("login.passwordLabel")}),ee($r,{fullWidth:!0,id:"password",name:"password",type:"password",value:i.formData.password,disabled:i.loading,onChange:f=>l({password:f.target.value}),error:!!i.errors.password,helperText:i.errors.password,autoComplete:"current-password",placeholder:a("login.passwordPlaceholder"),required:!0})]}),i.config.loginActions?.includes("forgotPassword")&&ee(Oe,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:ee(Kr,{sx:{cursor:"pointer"},onClick:()=>{e?.("forgotPassword",i.searchParams)},variant:"body2",color:"secondary",children:a("login.forgotPasswordLink")})}),ee(Xo,{disabled:i.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:i.loading?ee(Jo,{size:20}):a("login.loginButton")})]}),ee(Oe,{children:i.errors.global&&i.errors.global.length>0&&i.errors.global.map((f,T)=>ee(Qo,{variant:"filled",sx:{mt:2},severity:"error",children:ee("div",{children:f})},T))}),i.config.loginActions?.includes("createUser")&&Be(sr,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[a("login.noAccountPrompt")," ",ee(Kr,{sx:{cursor:"pointer"},onClick:()=>{let T=`/public/users/create${Object.keys(i.searchParams).length>0?`?${new URLSearchParams(i.searchParams).toString()}`:""}`;r?.(T)},fontWeight:"medium",color:"secondary",children:a("login.signUpLink")})]})]})},Gr=Zo;import{useState as ke,useEffect as rt,useRef as ot}from"react";import{Typography as Le,TextField as tt,Button as Yr,Box as pe,CircularProgress as nt,Alert as it,Link as ar}from"@mui/material";import{Fragment as Xr,jsx as M,jsxs as Pe}from"react/jsx-runtime";var st=({onScreenChange:e,onError:r})=>{let{crudify:o}=ie(),[t,s]=ke(""),[n,i]=ke(!1),[l,c]=ke([]),[h,u]=ke(null),[b,g]=ke(!1),[a,d]=ke(!1),w=ot(null),{t:p}=Z();rt(()=>{w.current&&!b&&!a&&w.current.focus()},[b,a]);let y=f=>{let T=[`errors.auth.${f.code}`,`errors.data.${f.code}`,`errors.system.${f.code}`,`errors.${f.code}`,`forgotPassword.${f.code.toLowerCase()}`];for(let A of T){let O=p(A);if(O!==A)return O}return f.message||p("error.unknown")},m=f=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(f),P=async()=>{if(!(n||!o)){if(c([]),u(null),!t){u(p("forgotPassword.emailRequired"));return}if(!m(t)){u(p("forgotPassword.invalidEmail"));return}i(!0);try{let f=[{operation:"requestPasswordReset",data:{email:t}}],T=await o.transaction(f);if(T.success)T.data&&T.data.existingCodeValid?d(!0):g(!0);else{let O=G(T).map(y);c(O)}}catch(f){let A=G(f).map(y);c(A),r&&r(A.join(", "))}finally{i(!1)}}},I=()=>{e?.("login")},V=()=>{if(b||a){e?.("checkCode",{email:t});return}if(!t){u(p("forgotPassword.emailRequired"));return}if(!m(t)){u(p("forgotPassword.invalidEmail"));return}e?.("checkCode",{email:t})};return b||a?M(Xr,{children:Pe(pe,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[Pe(pe,{sx:{mb:2},children:[M(Le,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p(a?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),M(Le,{variant:"body2",sx:{color:a?"success.main":"grey.600"},children:p("forgotPassword.checkEmailInstructions")})]}),M(Yr,{type:"button",onClick:V,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:p("forgotPassword.enterCodeLink")}),M(pe,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:M(ar,{sx:{cursor:"pointer"},onClick:I,variant:"body2",color:"secondary",children:p("common.back")})})]})}):Pe(Xr,{children:[Pe(pe,{component:"form",noValidate:!0,onSubmit:f=>{f.preventDefault(),P()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Pe(pe,{sx:{mb:2},children:[M(Le,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p("forgotPassword.title")}),M(Le,{variant:"body2",sx:{color:"grey.600"},children:p("forgotPassword.instructions")})]}),Pe(pe,{sx:{mb:1},children:[M(Le,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:p("forgotPassword.emailLabel")}),M(tt,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:n,onChange:f=>s(f.target.value),error:!!h,helperText:h,autoComplete:"email",placeholder:p("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:w})]}),M(Yr,{disabled:n,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?M(nt,{size:20}):p("forgotPassword.sendCodeButton")}),Pe(pe,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[M(ar,{sx:{cursor:"pointer"},onClick:I,variant:"body2",color:"secondary",children:p("common.back")}),M(Le,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),M(ar,{sx:{cursor:"pointer"},onClick:V,variant:"body2",color:"secondary",children:p("login.alreadyHaveCodeLink")})]})]}),M(pe,{children:l.length>0&&l.map((f,T)=>M(it,{variant:"filled",sx:{mt:2},severity:"error",children:f},T))})]})},Jr=st;import{useState as J,useEffect as Qr}from"react";import{Typography as Ke,TextField as Zr,Button as at,Box as fe,CircularProgress as eo,Alert as ro,Link as lt}from"@mui/material";import{Fragment as dt,jsx as H,jsxs as De}from"react/jsx-runtime";var ct=({onScreenChange:e,onError:r,searchParams:o,onResetSuccess:t})=>{let{crudify:s}=ie(),[n,i]=J(""),[l,c]=J(""),[h,u]=J(!1),[b,g]=J([]),[a,d]=J(null),[w,p]=J(null),[y,m]=J(""),[P,I]=J(""),[V,C]=J(!1),[f,T]=J(!0),[A,O]=J(!1),[le,xe]=J(null),[ne,ge]=J(!1),{t:F}=Z(),W=v=>{let k=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`resetPassword.${v.code.toLowerCase()}`];for(let B of k){let j=F(B);if(j!==B)return j}return v.message||F("error.unknown")},_=v=>o?o instanceof URLSearchParams?o.get(v):o[v]||null:null;Qr(()=>{if(o){if(o){let v=_("fromCodeVerification"),k=_("email"),B=_("code");if(v==="true"&&k&&B){m(k),I(B),C(!0),O(!0),T(!1);return}let j=_("link");if(j)try{let Y=decodeURIComponent(j),[X,ce]=Y.split("/");if(X&&ce&&X.length===6){I(X),m(ce),C(!1),xe({email:ce,code:X});return}}catch{}if(k&&B){m(k),I(B),C(!1),xe({email:k,code:B});return}}g([F("resetPassword.invalidCode")]),T(!1),setTimeout(()=>e?.("forgotPassword"),3e3)}},[o,s,F,e]),Qr(()=>{s&&le&&!ne&&(ge(!0),(async(k,B)=>{try{let j=[{operation:"validatePasswordResetCode",data:{email:k,codePassword:B}}],Y=await s.transaction(j);if(Y.data&&Array.isArray(Y.data)){let X=Y.data[0];if(X&&X.response&&X.response.status==="OK"){O(!0);return}}if(Y.success)O(!0);else{let ce=G(Y).map(W);g(ce),setTimeout(()=>e?.("forgotPassword"),3e3)}}catch(j){let X=G(j).map(W);g(X),setTimeout(()=>e?.("forgotPassword"),3e3)}finally{T(!1),xe(null),ge(!1)}})(le.email,le.code))},[s,le,F,e]);let Re=v=>v.length<8?F("resetPassword.passwordTooShort"):null,R=async()=>{if(h||!s)return;g([]),d(null),p(null);let v=!1;if(!n)d(F("resetPassword.newPasswordRequired")),v=!0;else{let k=Re(n);k&&(d(k),v=!0)}if(l?n!==l&&(p(F("resetPassword.passwordsDoNotMatch")),v=!0):(p(F("resetPassword.confirmPasswordRequired")),v=!0),!v){u(!0);try{let k=[{operation:"validateAndResetPassword",data:{email:y,codePassword:P,newPassword:n}}],B=await s.transaction(k);if(B.success)g([]),setTimeout(()=>{t?.()},1e3);else{let Y=G(B).map(W);g(Y)}}catch(k){let j=G(k).map(W);g(j),r&&r(j.join(", "))}u(!1)}},q=()=>{V?e?.("checkCode",{email:y}):e?.("forgotPassword")};return f?H(fe,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:H(eo,{})}):A?De(dt,{children:[De(fe,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[De(fe,{sx:{mb:2},children:[H(Ke,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:F("resetPassword.title")}),H(Ke,{variant:"body2",sx:{color:"grey.600"},children:F("resetPassword.instructions")})]}),De(fe,{sx:{mb:1},children:[H(Ke,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:F("resetPassword.newPasswordLabel")}),H(Zr,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:n,disabled:h,onChange:v=>i(v.target.value),error:!!a,helperText:a,autoComplete:"new-password",placeholder:F("resetPassword.newPasswordPlaceholder"),required:!0})]}),De(fe,{sx:{mb:1},children:[H(Ke,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:F("resetPassword.confirmPasswordLabel")}),H(Zr,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:l,disabled:h,onChange:v=>c(v.target.value),error:!!w,helperText:w,autoComplete:"new-password",placeholder:F("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),H(at,{disabled:h,type:"button",onClick:R,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:h?H(eo,{size:20}):F("resetPassword.resetPasswordButton")}),H(fe,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:H(lt,{sx:{cursor:"pointer"},onClick:q,variant:"body2",color:"secondary",children:F("common.back")})})]}),H(fe,{children:b.length>0&&b.map((v,k)=>H(ro,{variant:"filled",sx:{mt:2},severity:"error",children:v},k))})]}):H(fe,{children:b.length>0&&b.map((v,k)=>H(ro,{variant:"filled",sx:{mt:2},severity:"error",children:v},k))})},oo=ct;import{useState as Ne,useEffect as to,useRef as ut}from"react";import{Typography as lr,TextField as gt,Button as mt,Box as ze,CircularProgress as pt,Alert as ft,Link as yt}from"@mui/material";import{Fragment as bt,jsx as se,jsxs as Ge}from"react/jsx-runtime";var ht=({onScreenChange:e,onError:r,searchParams:o})=>{let{crudify:t}=ie(),[s,n]=Ne(""),[i,l]=Ne(!1),[c,h]=Ne([]),[u,b]=Ne(null),[g,a]=Ne(""),d=ut(null),{t:w}=Z(),p=C=>o?o instanceof URLSearchParams?o.get(C):o[C]||null:null,y=C=>{let f=[`errors.auth.${C.code}`,`errors.data.${C.code}`,`errors.system.${C.code}`,`errors.${C.code}`,`checkCode.${C.code.toLowerCase()}`];for(let T of f){let A=w(T);if(A!==T)return A}return C.message||w("error.unknown")};to(()=>{let C=p("email");C?a(C):e?.("forgotPassword")},[o,e]),to(()=>{d.current&&d.current.focus()},[]);let m=async()=>{if(!(i||!t)){if(h([]),b(null),!s){b(w("checkCode.codeRequired"));return}if(s.length!==6){b(w("checkCode.codeRequired"));return}l(!0);try{let C=[{operation:"validatePasswordResetCode",data:{email:g,codePassword:s}}],f=await t.transaction(C);if(f.success)e?.("resetPassword",{email:g,code:s,fromCodeVerification:"true"});else{let A=G(f).map(y);h(A),l(!1)}}catch(C){let T=G(C).map(y);h(T),l(!1),r&&r(T.join(", "))}}},P=()=>{e?.("forgotPassword")},I=C=>{let f=C.target.value.replace(/\D/g,"").slice(0,6);n(f)};return Ge(bt,{children:[Ge(ze,{component:"form",noValidate:!0,onSubmit:C=>{C.preventDefault(),m()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Ge(ze,{sx:{mb:2},children:[se(lr,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:w("checkCode.title")}),se(lr,{variant:"body2",sx:{color:"grey.600"},children:w("checkCode.instructions")})]}),Ge(ze,{sx:{mb:1},children:[se(lr,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:w("checkCode.codeLabel")}),se(gt,{fullWidth:!0,id:"code",name:"code",type:"text",value:s,disabled:i,onChange:I,error:!!u,helperText:u,placeholder:w("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:d})]}),se(mt,{disabled:i||s.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:i?se(pt,{size:20}):w("checkCode.verifyButton")}),se(ze,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:se(yt,{sx:{cursor:"pointer"},onClick:P,variant:"body2",color:"secondary",children:w("common.back")})})]}),se(ze,{children:c.length>0&&c.map((C,f)=>se(ft,{sx:{mt:2},severity:"error",children:C},f))})]})},no=ht;import{Box as wt,CircularProgress as xt,Alert as io,Typography as cr}from"@mui/material";import{Fragment as Ct,jsx as Ae,jsxs as so}from"react/jsx-runtime";var ao=({children:e,fallback:r})=>{let{isLoading:o,error:t,isInitialized:s}=ie(),{t:n}=Z();return o?r||so(wt,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[Ae(xt,{}),Ae(cr,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):t?Ae(io,{severity:"error",sx:{mt:2},children:so(cr,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",t]})}):s?Ae(Ct,{children:e}):Ae(io,{severity:"warning",sx:{mt:2},children:Ae(cr,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as oe,jsxs as Rt}from"react/jsx-runtime";var Tt=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:s="/"})=>{let{t:n}=Z(),{state:i,setScreen:l}=$e(),{config:c}=me(),{showNotification:h}=Sr(),u=(g,a)=>{let d=a;g==="login"?d={}:g==="forgotPassword"&&!a&&(d={}),l(g,d),e?.(g,d)},b=()=>{let g={onScreenChange:u,onExternalNavigate:r,onError:t,redirectUrl:s};switch(i.currentScreen){case"forgotPassword":return oe(Jr,{...g});case"checkCode":return oe(no,{...g,searchParams:i.searchParams});case"resetPassword":return oe(oo,{...g,searchParams:i.searchParams,onResetSuccess:()=>{let a=n("resetPassword.successMessage");h(a,"success"),u("login")}});default:return oe(Gr,{...g,onLoginSuccess:o})}};return Rt(ao,{children:[oe(Pt,{sx:{display:"flex",justifyContent:"center",mb:3},children:oe("img",{src:c.logo||"https://logos.crudia.com/nocios-default.png",alt:n("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:g=>{let a=g.target;a.src="https://logos.crudia.com/nocios-default.png"}})}),!c.logo&&c.appName&&oe(vt,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:c.appName}),b()]})},Et=({translations:e,translationsUrl:r,language:o="en",initialScreen:t="login",autoReadFromCookies:s=!0,...n})=>{let{config:i}=me();return oe(Vr,{translations:e,translationsUrl:r,language:o,children:oe(Er,{config:i,children:oe(jr,{config:i,initialScreen:t,autoReadFromCookies:s,children:oe(Tt,{...n})})})})},Ms=Et;import{Box as Q,Card as lo,CardContent as co,Typography as te,Chip as Ye,Avatar as St,Divider as It,CircularProgress as kt,Alert as uo,List as Lt,ListItem as dr,ListItemText as ur,ListItemIcon as At,Collapse as Ft,IconButton as gr}from"@mui/material";import{Person as _t,Email as Ot,Badge as Bt,Security as Dt,Schedule as Nt,AccountCircle as zt,ExpandMore as Ut,ExpandLess as Mt,Info as Vt}from"@mui/icons-material";import{useState as Wt}from"react";import{Fragment as jt,jsx as E,jsxs as D}from"react/jsx-runtime";var Ht=({showExtendedData:e=!0,showProfileCard:r=!0,autoRefresh:o=!0})=>{let{userProfile:t,loading:s,error:n,extendedData:i,refreshProfile:l}=Ir({autoFetch:o,retryOnError:!0,maxRetries:3}),[c,h]=Wt(!1);if(s)return D(Q,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[E(kt,{}),E(te,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return D(uo,{severity:"error",action:E(gr,{color:"inherit",size:"small",onClick:l,children:E(te,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!t)return E(uo,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let u=i?.displayData||{},b=i?.totalFields||0,g=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}},a=(m,P)=>P==null?"No disponible":typeof P=="boolean"?P?"S\xED":"No":Array.isArray(P)?P.length>0?P.join(", "):"Ninguno":typeof P=="object"?JSON.stringify(P,null,2):String(P),d=[{key:"id",label:"ID",icon:E(Bt,{})},{key:"email",label:"Email",icon:E(Ot,{})},{key:"username",label:"Usuario",icon:E(_t,{})},{key:"fullName",label:"Nombre completo",icon:E(zt,{})},{key:"role",label:"Rol",icon:E(Dt,{})}],w=[{key:"firstName",label:"Nombre"},{key:"lastName",label:"Apellido"},{key:"isActive",label:"Activo"},{key:"lastLogin",label:"\xDAltimo login"},{key:"createdAt",label:"Creado"},{key:"updatedAt",label:"Actualizado"}],p=[...d.map(m=>m.key),...w.map(m=>m.key),"permissions"],y=Object.keys(u).filter(m=>!p.includes(m)).map(m=>({key:m,label:m}));return D(Q,{children:[r&&E(lo,{sx:{mb:2},children:D(co,{children:[D(Q,{display:"flex",alignItems:"center",mb:2,children:[E(St,{src:u.avatar,sx:{width:56,height:56,mr:2},children:u.fullName?.[0]||u.username?.[0]||u.email?.[0]}),D(Q,{children:[E(te,{variant:"h6",children:u.fullName||u.username||u.email}),E(te,{variant:"body2",color:"text.secondary",children:u.role||"Usuario"}),u.isActive!==void 0&&E(Ye,{label:u.isActive?"Activo":"Inactivo",color:u.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),E(Q,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:d.map(({key:m,label:P,icon:I})=>u[m]?D(Q,{display:"flex",alignItems:"center",children:[E(Q,{sx:{mr:1,color:"text.secondary"},children:I}),D(Q,{children:[E(te,{variant:"caption",color:"text.secondary",children:P}),E(te,{variant:"body2",children:a(m,u[m])})]})]},m):null)}),u.permissions&&Array.isArray(u.permissions)&&u.permissions.length>0&&D(Q,{mt:2,children:[E(te,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),D(Q,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[u.permissions.slice(0,5).map((m,P)=>E(Ye,{label:m,size:"small",variant:"outlined"},P)),u.permissions.length>5&&E(Ye,{label:`+${u.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&E(lo,{children:D(co,{children:[D(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[D(te,{variant:"h6",display:"flex",alignItems:"center",children:[E(Vt,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),E(Ye,{label:`${b} campos totales`,size:"small"})]}),D(Lt,{dense:!0,children:[w.map(({key:m,label:P})=>u[m]!==void 0&&D(dr,{divider:!0,children:[E(At,{children:E(Nt,{fontSize:"small"})}),E(ur,{primary:P,secondary:m.includes("At")||m.includes("Login")?g(u[m]):a(m,u[m])})]},m)),y.length>0&&D(jt,{children:[E(It,{sx:{my:1}}),E(dr,{children:E(ur,{primary:D(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[D(te,{variant:"subtitle2",children:["Campos Personalizados (",y.length,")"]}),E(gr,{size:"small",onClick:()=>h(!c),children:c?E(Mt,{}):E(Ut,{})})]})})}),E(Ft,{in:c,children:y.map(({key:m,label:P})=>E(dr,{sx:{pl:4},children:E(ur,{primary:P,secondary:a(m,u[m])})},m))})]})]}),D(Q,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[D(te,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",g(u.updatedAt)]}),E(gr,{size:"small",onClick:l,disabled:s,children:E(te,{variant:"caption",children:"Actualizar"})})]})]})})]})},qt=Ht;var go=["create","read","update","delete"],mo=["create","read","update","delete"];import{useRef as fn}from"react";import{useTranslation as yn}from"react-i18next";import{Box as Qe,Typography as xo,Button as hn,Stack as bn,Alert as Co,Divider as wn}from"@mui/material";import{Add as xn}from"@mui/icons-material";import{forwardRef as rn}from"react";import{useTranslation as on}from"react-i18next";import{Box as ve,FormControl as tn,InputLabel as nn,Select as sn,MenuItem as an,IconButton as ln,Typography as Fe,FormHelperText as cn,Stack as Je,Paper as wo,Divider as dn,Button as yr}from"@mui/material";import{Delete as un,SelectAll as gn,ClearAll as mn}from"@mui/icons-material";import{useState as po,useEffect as fo,useRef as yo}from"react";import{useTranslation as $t}from"react-i18next";import{Box as Xe,Typography as Ue,Button as ho,Stack as mr,FormControlLabel as Kt,FormHelperText as bo,Switch as Gt,ToggleButton as pr,ToggleButtonGroup as Yt}from"@mui/material";import{CheckCircle as Xt,Cancel as Jt,SelectAll as Qt,ClearAll as Zt}from"@mui/icons-material";import{jsx as z,jsxs as ye}from"react/jsx-runtime";var en=({value:e,onChange:r,availableFields:o,error:t,disabled:s=!1})=>{let{t:n}=$t(),[i,l]=po("custom"),[c,h]=po(!1),u=yo(null);fo(()=>{c&&u.current?.scrollIntoView({behavior:"smooth",block:"start"})},[c]);let b=yo(!1);fo(()=>{let p=e||{allow:[],owner_allow:[],deny:[]},y=new Set(o),m=(p.allow||[]).filter(C=>y.has(C)),P=(p.owner_allow||[]).filter(C=>y.has(C)),I=(p.deny||[]).filter(C=>y.has(C));o.forEach(C=>{!m.includes(C)&&!P.includes(C)&&!I.includes(C)&&I.push(C)});let V={allow:m,owner_allow:P,deny:I};JSON.stringify(V)!==JSON.stringify(p)&&r(V),m.length===o.length?l("all"):I.length===o.length?l("none"):l("custom")},[o,e]);let g=()=>{b.current=!0,r({allow:[...o],owner_allow:[],deny:[]}),l("all"),setTimeout(()=>{b.current=!1},0)},a=()=>{b.current=!0,r({allow:[],owner_allow:[],deny:[...o]}),l("none"),setTimeout(()=>{b.current=!1},0)},d=p=>e?.allow?.includes(p)?"allow":e?.owner_allow?.includes(p)?"owner_allow":"deny",w=(p,y)=>{b.current=!0;let m=new Set(e?.allow||[]),P=new Set(e?.owner_allow||[]),I=new Set(e?.deny||[]);m.delete(p),P.delete(p),I.delete(p),y==="allow"&&m.add(p),y==="owner_allow"&&P.add(p),y==="deny"&&I.add(p),r({allow:Array.from(m),owner_allow:Array.from(P),deny:Array.from(I)}),l("custom"),setTimeout(()=>{b.current=!1},0)};return o.length===0?ye(Xe,{children:[z(Ue,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("modules.form.publicPolicies.fields.conditions.label")}),z(Ue,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),t&&z(bo,{error:!0,sx:{mt:1},children:t})]}):ye(Xe,{children:[z(Ue,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.label")}),ye(mr,{direction:"row",spacing:1,alignItems:"center",sx:{mb:c?3:1},children:[z(ho,{variant:i==="all"?"contained":"outlined",startIcon:z(Qt,{}),onClick:g,disabled:s,size:"small",sx:{minWidth:120,...i==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("modules.form.publicPolicies.fields.conditions.allFields")}),z(ho,{variant:i==="none"?"contained":"outlined",startIcon:z(Zt,{}),onClick:a,disabled:s,size:"small",sx:{minWidth:120,...i==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("modules.form.publicPolicies.fields.conditions.noFields")}),z(Xe,{sx:{display:"flex",alignItems:"center",px:1.5,py:.35,borderRadius:"999px",backgroundColor:"#f3f4f6",border:"1px solid #d1d9e0"},children:z(Kt,{control:z(Gt,{size:"small",checked:c,onChange:()=>h(p=>!p),disabled:s,color:"primary",sx:{transform:"scale(1.15)",transformOrigin:"center",m:0}}),label:n("modules.form.publicPolicies.fields.conditions.customEdit"),labelPlacement:"end",sx:{ml:0,".MuiFormControlLabel-label":{fontSize:"0.75rem"}}})})]}),c&&ye(Xe,{ref:u,sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[z(Ue,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.help")}),z(mr,{spacing:1,children:o.map(p=>{let y=d(p);return ye(mr,{direction:"row",spacing:1,alignItems:"center",children:[z(Ue,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:p}),ye(Yt,{value:y,exclusive:!0,size:"small",children:[ye(pr,{value:"allow",onClick:()=>w(p,"allow"),disabled:s,sx:{px:2,color:y==="allow"?"#ffffff":"#6b7280",backgroundColor:y==="allow"?"#16a34a":"#f3f4f6",borderColor:y==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:y==="allow"?"#15803d":"#e5e7eb",borderColor:y==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[z(Xt,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.allow")]}),z(pr,{value:"owner_allow",onClick:()=>w(p,"owner_allow"),disabled:s,sx:{px:2,color:y==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:y==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:y==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:y==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:y==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),ye(pr,{value:"deny",onClick:()=>w(p,"deny"),disabled:s,sx:{px:2,color:y==="deny"?"#ffffff":"#6b7280",backgroundColor:y==="deny"?"#dc2626":"#f3f4f6",borderColor:y==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:y==="deny"?"#b91c1c":"#e5e7eb",borderColor:y==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[z(Jt,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},p)})})]}),t&&z(bo,{error:!0,sx:{mt:1},children:t})]})},fr=en;import{jsx as U,jsxs as $}from"react/jsx-runtime";var pn=rn(({policy:e,onChange:r,onRemove:o,availableFields:t,isSubmitting:s=!1,usedActions:n,error:i},l)=>{let{t:c}=on(),h=new Set(Array.from(n||[]));h.delete(e.action);let u=go.map(b=>({value:b,label:c(`modules.form.publicPolicies.fields.action.options.${b}`)}));return $(wo,{ref:l,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[$(ve,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[U(Fe,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:c("modules.form.publicPolicies.policyTitle")}),U(ln,{onClick:o,size:"small",disabled:s,"aria-label":c("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:U(un,{})})]}),$(Je,{spacing:1,children:[U(Je,{direction:{xs:"column",md:"row"},spacing:2,children:U(ve,{sx:{flex:1,minWidth:200},children:$(tn,{fullWidth:!0,children:[U(nn,{children:c("modules.form.publicPolicies.fields.action.label")}),U(sn,{value:e.action,label:c("modules.form.publicPolicies.fields.action.label"),disabled:s,onChange:b=>{let g=b.target.value,a={...e,action:g};g==="delete"?(a.permission="deny",delete a.fields):(a.fields={allow:[],owner_allow:[],deny:t},delete a.permission),r(a)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:u.map(b=>{let g=h.has(b.value);return U(an,{value:b.value,disabled:g,children:b.label},b.value)})}),i&&U(cn,{error:!0,children:i})]})})}),e.action==="delete"?$(ve,{children:[U(Fe,{variant:"body2",color:"text.secondary",sx:{mb:2},children:c("modules.form.publicPolicies.fields.conditions.label")}),$(Je,{direction:"row",spacing:1,sx:{mb:1},children:[U(yr,{variant:e.permission==="*"?"contained":"outlined",startIcon:U(gn,{}),onClick:()=>r({...e,permission:"*"}),disabled:s,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:c("modules.form.publicPolicies.fields.conditions.allFields")}),U(yr,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>r({...e,permission:"owner"}),disabled:s,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:c("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),U(yr,{variant:e.permission==="deny"?"contained":"outlined",startIcon:U(mn,{}),onClick:()=>r({...e,permission:"deny"}),disabled:s,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:c("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):U(fr,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:b=>r({...e,fields:b}),availableFields:t,disabled:s}),U(wo,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):$(Je,{spacing:.5,divider:U(dn,{sx:{borderColor:"#e5e7eb"}}),children:[$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:"#16a34a"},children:[c("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(e?.fields?.allow||[]).join(", ")||"-"]}),$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:"#0ea5e9"},children:[c("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(e?.fields?.owner_allow||[]).join(", ")||"-"]}),$(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(ve,{component:"span",sx:{color:"#dc2626"},children:[c("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(e?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),hr=pn;import{Fragment as vn,jsx as ae,jsxs as Ze}from"react/jsx-runtime";var Cn=()=>{let e=globalThis?.crypto;return e&&typeof e.randomUUID=="function"?e.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},Pn=({policies:e,onChange:r,availableFields:o,errors:t,isSubmitting:s=!1})=>{let{t:n}=yn(),i=fn({}),l=new Set((e||[]).map(d=>d.action).filter(Boolean)),c=mo.filter(d=>!l.has(d)),h=c.length>0,u=()=>{let d=c[0]||"create",w={id:Cn(),action:d};d==="delete"?w.permission="deny":w.fields={allow:[],owner_allow:[],deny:o};let p=[...e||[],w];r(p),setTimeout(()=>{let y=p.length-1,m=i.current[y];m&&m.scrollIntoView({behavior:"smooth",block:"center"})},100)},b=d=>{let w=[...e];w.splice(d,1),r(w)},g=(()=>{if(!t)return null;if(typeof t=="string")return t;let d=t._error;return typeof d=="string"?d:null})(),a=new Set((e||[]).map(d=>d.action));return Ze(vn,{children:[ae(wn,{sx:{borderColor:"#e0e4e7"}}),Ze(Qe,{children:[ae(Qe,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:Ze(Qe,{children:[ae(xo,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("modules.form.publicPolicies.title")}),ae(xo,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("modules.form.publicPolicies.description")})]})}),g&&ae(Co,{severity:"error",sx:{mb:3},children:g}),Ze(bn,{spacing:3,children:[(e||[]).length===0?ae(Co,{severity:"info",children:n("modules.form.publicPolicies.noPolicies")}):e.map((d,w)=>ae(hr,{ref:p=>{i.current[w]=p},policy:d,onChange:p=>{let y=[...e];y[w]=p,r(y)},onRemove:()=>b(w),availableFields:o,isSubmitting:s,usedActions:a,error:typeof t=="object"&&t&&d.id in t?t[d.id]:void 0},d.id)),h&&ae(Qe,{children:ae(hn,{type:"button",variant:"outlined",startIcon:ae(xn,{}),onClick:u,disabled:s,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("modules.form.publicPolicies.addPolicy")})})]})]})]})},Ta=Pn;import{useState as br}from"react";import{Button as er,TextField as Po,Box as _e,Alert as Me,Typography as he,CircularProgress as wr}from"@mui/material";import{jsx as N,jsxs as ue}from"react/jsx-runtime";function Aa(){let[e,r]=br(""),[o,t]=br(""),[s,n]=br(!1),{isAuthenticated:i,isLoading:l,error:c,login:h,logout:u,refreshTokens:b,clearError:g,isExpiringSoon:a,expiresIn:d}=me(),w=async m=>{if(m.preventDefault(),!e||!o)return;(await h(e,o)).success&&(r(""),t(""),n(!1))},p=async()=>{await u()},y=async()=>{await b()};return i?ue(_e,{sx:{maxWidth:600,mx:"auto",p:3},children:[N(he,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),N(Me,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),ue(_e,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[N(he,{variant:"h6",gutterBottom:!0,children:"Token Status"}),ue(he,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(d/1e3/60)," minutes"]}),a&&N(Me,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),ue(_e,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[N(er,{variant:"contained",onClick:y,disabled:l,startIcon:l?N(wr,{size:16}):null,children:"Refresh Tokens"}),N(er,{variant:"outlined",color:"error",onClick:p,disabled:l,children:"Logout"})]}),c&&N(Me,{severity:"error",sx:{mt:2},onClose:g,children:c})]}):ue(_e,{sx:{maxWidth:400,mx:"auto",p:3},children:[N(he,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),N(Me,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),s?ue("form",{onSubmit:w,children:[N(Po,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:m=>r(m.target.value),margin:"normal",required:!0,autoComplete:"email"}),N(Po,{fullWidth:!0,label:"Password",type:"password",value:o,onChange:m=>t(m.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),N(er,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:l,startIcon:l?N(wr,{size:16}):null,sx:{mt:3,mb:2},children:l?"Logging in...":"Login"})]}):N(er,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),c&&N(Me,{severity:"error",sx:{mt:2},onClose:g,children:c})]})}function Fa(){let{isAuthenticated:e,isLoading:r,isExpiringSoon:o,expiresIn:t}=me();return r?ue(_e,{sx:{display:"flex",alignItems:"center",gap:1},children:[N(wr,{size:16}),N(he,{variant:"caption",children:"Loading session..."})]}):e?ue(_e,{children:[N(he,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),o&&ue(he,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):N(he,{variant:"caption",color:"text.secondary",children:"Not logged in"})}import Tn from"@mui/material/TextField";import En from"@mui/material/CircularProgress";import vo from"@mui/material/InputAdornment";import Rn from"@mui/material/IconButton";import Sn from"@mui/icons-material/Refresh";import{jsx as be}from"react/jsx-runtime";var In=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),kn=({html:e})=>be("span",{dangerouslySetInnerHTML:{__html:In(e)}}),Va=({config:e,value:r,onChange:o,label:t,error:s=!1,helperText:n,readOnly:i=!1,disabled:l=!1})=>{let{value:c,loading:h,error:u,regenerate:b}=kr(e,{autoFetch:!r,onSuccess:y=>{o?.(y)}}),g=r||c,a=s||!!u,d=u||n,w=a&&d&&(d.toLowerCase().includes("duplicate")||d.toLowerCase().includes("duplicado")||d.toLowerCase().includes("duplicada")||d.toLowerCase().includes("unique")||d.toLowerCase().includes("\xFAnico")||d.toLowerCase().includes("unico")||d.toLowerCase().includes("\xFAnica")||d.toLowerCase().includes("unica")||d.toLowerCase().includes("already exists")||d.toLowerCase().includes("ya existe")||d.toLowerCase().includes("e11000"));return be(Tn,{label:t,fullWidth:!0,value:g,error:a,helperText:d?be(kn,{html:d}):" ",disabled:l,InputProps:{readOnly:!0,startAdornment:h?be(vo,{position:"start",children:be(En,{size:20})}):void 0,endAdornment:w&&!h?be(vo,{position:"end",children:be(Rn,{edge:"end",onClick:async()=>{!l&&!h&&await b()},disabled:l,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:be(Sn,{})})}):void 0}})};import To,{useCallback as Ve,useRef as Eo,useState as So}from"react";import Te from"@mui/material/Box";import Ee from"@mui/material/Typography";import Ro from"@mui/material/IconButton";import Ln from"@mui/material/LinearProgress";import xr from"@mui/material/CircularProgress";import An from"@mui/material/Chip";import Fn from"@mui/material/Paper";import _n from"@mui/material/List";import On from"@mui/material/ListItem";import Bn from"@mui/material/ListItemText";import Dn from"@mui/material/ListItemSecondaryAction";import Nn from"@mui/material/FormHelperText";import zn from"@mui/icons-material/CloudUpload";import Un from"@mui/icons-material/InsertDriveFile";import Mn from"@mui/icons-material/Image";import Vn from"@mui/icons-material/PictureAsPdf";import Wn from"@mui/icons-material/Delete";import Hn from"@mui/icons-material/Refresh";import qn from"@mui/icons-material/CheckCircle";import jn from"@mui/icons-material/Error";import gl from"@mui/icons-material/BrokenImage";import{jsx as S,jsxs as we}from"react/jsx-runtime";var Io=e=>{if(e===0)return"0 B";let r=1024,o=["B","KB","MB","GB"],t=Math.floor(Math.log(e)/Math.log(r));return`${parseFloat((e/Math.pow(r,t)).toFixed(1))} ${o[t]}`},$n=e=>e.startsWith("image/")?S(Mn,{color:"primary"}):e==="application/pdf"?S(Vn,{color:"error"}):S(Un,{color:"action"}),Kn=e=>{switch(e){case"completed":return S(qn,{color:"success",fontSize:"small"});case"error":return S(jn,{color:"error",fontSize:"small"});case"uploading":case"pending":return S(xr,{size:16});case"removing":return S(xr,{size:16,color:"error"});default:return null}},Gn=({file:e,baseUrl:r,disabled:o,onRemove:t,onRetry:s})=>{let[n,i]=So(!1),l=!o&&e.status!=="uploading"&&e.status!=="removing",c=!o&&e.status==="error"&&e.file,h=e.contentType.startsWith("image/"),u=e.visibility==="public"||e.filePath?.startsWith("public/")||e.filePath?.startsWith(r),g=!e.filePath||!u?null:e.filePath.startsWith("http://")||e.filePath.startsWith("https://")||e.filePath.startsWith(r)?e.filePath:`${r}${e.filePath}`,a=e.status==="completed"&&g,d=()=>h&&a&&!n?S(Te,{component:a?"a":"div",href:g||void 0,target:"_blank",rel:"noopener noreferrer",sx:{width:48,height:48,borderRadius:1,overflow:"hidden",display:"flex",alignItems:"center",justifyContent:"center",bgcolor:"grey.100",border:"1px solid",borderColor:"divider",cursor:a?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,"&:hover":a?{borderColor:"primary.main",transform:"scale(1.05)"}:{}},children:S("img",{src:g,alt:e.name,style:{width:"100%",height:"100%",objectFit:"cover"},onError:()=>i(!0)})}):S(Te,{component:a?"a":"div",href:g||void 0,target:"_blank",rel:"noopener noreferrer",sx:{width:48,height:48,borderRadius:1,display:"flex",alignItems:"center",justifyContent:"center",bgcolor:"grey.50",border:"1px solid",borderColor:"divider",cursor:a?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,textDecoration:"none","&:hover":a?{borderColor:"primary.main",bgcolor:"action.hover"}:{}},children:$n(e.contentType)});return we(On,{sx:{borderRadius:1,mb:.5,bgcolor:e.status==="error"?"error.lighter":"background.paper",border:"1px solid",borderColor:e.status==="error"?"error.light":"divider",gap:1.5},children:[d(),S(Bn,{primary:we(Te,{sx:{display:"flex",alignItems:"center",gap:1},children:[S(Ee,{variant:"body2",noWrap:!0,sx:{maxWidth:200,overflow:"hidden",textOverflow:"ellipsis"},children:e.name}),Kn(e.status)]}),secondary:we(Te,{children:[e.size>0&&S(Ee,{variant:"caption",color:"text.secondary",children:Io(e.size)}),e.status==="uploading"&&S(Ln,{variant:"determinate",value:e.progress,sx:{mt:.5,height:4,borderRadius:2}}),e.status==="error"&&e.errorMessage&&S(Ee,{variant:"caption",color:"error",display:"block",children:e.errorMessage}),a&&S(Ee,{variant:"caption",color:"primary",display:"block",children:h?"Click thumbnail to view":"Click to download"})]})}),we(Dn,{children:[c&&S(Ro,{edge:"end",size:"small",onClick:()=>s(e.id),color:"primary",title:"Retry",children:S(Hn,{fontSize:"small"})}),l&&S(Ro,{edge:"end",size:"small",onClick:()=>t(e.id),color:"error",title:"Delete",children:S(Wn,{fontSize:"small"})})]})]})};var pl=({label:e,accept:r,maxFileSize:o=10*1024*1024,multiple:t=!1,maxFiles:s,minFiles:n=0,required:i=!1,disabled:l=!1,error:c=!1,helperText:h,onChange:u,onValidation:b,initialFiles:g,placeholder:a,showFileList:d=!0,visibility:w="private",showPreview:p=!0,baseUrl:y})=>{let m=Eo(null),[P,I]=So(!1),V=t?s:1,C=i?Math.max(n,1):n,f={acceptedTypes:r,maxFileSize:o,maxFiles:V,minFiles:C,visibility:w,onFilesChange:L=>{let re=L.filter(Ce=>Ce.status==="completed"&&Ce.filePath).map(Ce=>{let Se=Ce.filePath;return Se.startsWith(y)||Se.startsWith("http://")||Se.startsWith("https://")?Se:y?`${y}${Se}`:Se});u?.(re)}},{files:T,isUploading:A,addFiles:O,removeFile:le,retryUpload:xe,isValid:ne,validationError:ge,initializeFiles:F,isTouched:W,markAsTouched:_,getPreviewUrl:Re}=Lr(f),R=Eo(!1);To.useEffect(()=>{g&&g.length>0&&!R.current&&(R.current=!0,F(g))},[g,F]),To.useEffect(()=>{b?.(ne,ge)},[ne,ge,b]);let q=Ve(L=>{_();let re=L.target.files;re&&re.length>0&&O(re),m.current&&(m.current.value="")},[O,_]),v=Ve(()=>{l||(_(),m.current?.click())},[l,_]),k=Ve(L=>{L.preventDefault(),L.stopPropagation(),l||I(!0)},[l]),B=Ve(L=>{L.preventDefault(),L.stopPropagation(),I(!1)},[]),j=Ve(L=>{if(L.preventDefault(),L.stopPropagation(),I(!1),l)return;_();let re=L.dataTransfer.files;re&&re.length>0&&O(re)},[l,O,_]),Y=r?.join(",")||"",X=!l&&(t||T.length===0),ce=c||W&&!ne,Pr=h||(W?ge:null);return we(Te,{sx:{width:"100%"},children:[e&&we(Ee,{variant:"body2",sx:{mb:1,fontWeight:500,color:ce?"error.main":"text.primary"},children:[e,i&&S("span",{style:{color:"red"},children:" *"})]}),S("input",{ref:m,type:"file",accept:Y,multiple:t,onChange:q,disabled:l,style:{display:"none"}}),X&&we(Fn,{variant:"outlined",onClick:v,onDragOver:k,onDragLeave:B,onDrop:j,sx:{p:3,textAlign:"center",cursor:l?"not-allowed":"pointer",borderStyle:"dashed",borderWidth:2,borderColor:P?"primary.main":ce?"error.main":"divider",bgcolor:P?"primary.lighter":l?"action.disabledBackground":"background.paper",transition:"all 0.2s ease","&:hover":l?{}:{borderColor:"primary.main",bgcolor:"action.hover"}},children:[S(zn,{sx:{fontSize:48,color:P?"primary.main":l?"action.disabled":"action.active",mb:1}}),S(Ee,{variant:"body2",color:l?"text.disabled":"text.secondary",children:(()=>{if(a)return a;let L=[];if(P)return"Drop file here";if(L.push("Drag files here or click to select"),r&&r.length>0){let re=r.map(Ce=>Ce.split("/")[1]?.toUpperCase()||Ce).join(", ");L.push(`Allowed types: ${re}`)}return o&&L.push(`Max ${Io(o)} per file`),V!==void 0&&t&&L.push(`Max ${V} files`),L[0]})()}),r&&r.length>0&&!P&&S(Te,{sx:{mt:1,display:"flex",gap:.5,justifyContent:"center",flexWrap:"wrap"},children:r.map(L=>S(An,{label:L.split("/")[1]?.toUpperCase()||L,size:"small",variant:"outlined",sx:{fontSize:"0.7rem"}},L))})]}),d&&T.length>0&&S(_n,{dense:!0,sx:{mt:1,p:0},children:T.map(L=>S(Gn,{file:L,baseUrl:y,disabled:l,onRemove:le,onRetry:xe},L.id))}),A&&we(Te,{sx:{display:"flex",alignItems:"center",gap:1,mt:1},children:[S(xr,{size:16}),S(Ee,{variant:"caption",color:"text.secondary",children:"Uploading files..."})]}),Pr&&S(Nn,{error:ce,sx:{mt:.5},children:Pr})]})};import{useCallback as Yn,useRef as Xn,useEffect as Jn}from"react";import ko from"@mui/material/Box";import Lo from"@mui/material/Typography";import Ao from"@mui/material/FormHelperText";import{MDXEditor as Qn,headingsPlugin as Zn,listsPlugin as ei,quotePlugin as ri,thematicBreakPlugin as oi,markdownShortcutPlugin as ti,linkPlugin as ni,linkDialogPlugin as ii,tablePlugin as si,toolbarPlugin as ai,UndoRedo as li,BoldItalicUnderlineToggles as ci,BlockTypeSelect as di,CreateLink as ui,InsertTable as gi,ListsToggle as mi,Separator as rr}from"@mdxeditor/editor";import"@mdxeditor/editor/style.css";import{Fragment as pi,jsx as K,jsxs as Cr}from"react/jsx-runtime";var Tl=({label:e,value:r="",onChange:o,required:t=!1,disabled:s=!1,error:n=!1,helperText:i,placeholder:l="Write here...",minHeight:c=200,maxHeight:h=500})=>{let u=Xn(null);Jn(()=>{u.current&&u.current.getMarkdown()!==r&&u.current.setMarkdown(r||"")},[r]);let b=Yn(g=>{o?.(g)},[o]);return Cr(ko,{sx:{width:"100%"},children:[e&&Cr(Lo,{component:"label",sx:{display:"block",mb:.5,fontSize:"0.875rem",fontWeight:500,color:n?"error.main":"text.primary"},children:[e,t&&K(Lo,{component:"span",color:"error.main",sx:{ml:.5},children:"*"})]}),K(ko,{sx:{border:1,borderColor:n?"error.main":"divider",borderRadius:1,overflow:"hidden",opacity:s?.6:1,pointerEvents:s?"none":"auto","& .mdxeditor":{minHeight:c,maxHeight:h,overflow:"auto"},"& .mdxeditor-toolbar":{borderBottom:1,borderColor:"divider",backgroundColor:"background.default"},"& .mdxeditor-root-contenteditable":{padding:2,minHeight:c-50}},children:K(Qn,{ref:u,markdown:r||"",onChange:b,placeholder:l,readOnly:s,plugins:[Zn(),ei(),ri(),oi(),ti(),ni(),ii(),si(),ai({toolbarContents:()=>Cr(pi,{children:[K(li,{}),K(rr,{}),K(ci,{}),K(rr,{}),K(di,{}),K(rr,{}),K(mi,{}),K(rr,{}),K(ui,{}),K(gi,{})]})})]})}),i&&K(Ao,{error:n,sx:{mx:0,mt:.5},children:i}),!i&&K(Ao,{sx:{mx:0,mt:.5},children:"\xA0"})]})};export{de as a,yi as b,hi as c,or as d,He as e,ki as f,Nr as g,Ms as h,qt as i,go as j,mo as k,Ta as l,Aa as m,Fa as n,Va as o,pl as p,Tl as q};
|
|
@@ -1 +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 _chunkAKTAAP5Ijs = require('./chunk-AKTAAP5I.js');var _chunk34FAL7YWjs = require('./chunk-34FAL7YW.js');var _react = require('react');var _crudifybrowser = require('@nocios/crudify-browser'); var _crudifybrowser2 = _interopRequireDefault(_crudifybrowser);var J=(S={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:m=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:u,tokens:p}=_chunkAKTAAP5Ijs.j.call(void 0, ),[R,d]=_react.useState.call(void 0, null),[y,A]=_react.useState.call(void 0, c&&T),[C,E]=_react.useState.call(void 0, null),l=_react.useRef.call(void 0, null),o=_react.useRef.call(void 0, !0),g=_react.useRef.call(void 0, 0),f=_react.useRef.call(void 0, 0),F=_react.useCallback.call(void 0, ()=>{if(!u)return null;let h=u["cognito:username"];return u.email||(typeof h=="string"?h:null)},[u]),P=_react.useCallback.call(void 0, ()=>{d(null),E(null),A(!1),f.current=0},[]),D=_react.useCallback.call(void 0, async()=>{let h=F();if(!h){o.current&&(E("No user email available from session data"),A(!1));return}if(!I){o.current&&(E("Session not initialized"),A(!1));return}l.current&&l.current.abort();let e=new AbortController;l.current=e;let i=++g.current;try{o.current&&(A(!0),E(null));let s=await _crudifybrowser2.default.readItems("users",{filter:{email:h},pagination:{limit:1}});if(i===g.current&&o.current&&!e.signal.aborted){let r=null;if(s.success){let t=s.data;if(Array.isArray(t)&&t.length>0)r=t[0];else if(t&&typeof t=="object"&&!Array.isArray(t)&&_optionalChain([t, 'access', _2 => _2.response, 'optionalAccess', _3 => _3.data]))try{let n=t.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e2){}else t&&typeof t=="object"&&!Array.isArray(t)&&t.items&&Array.isArray(t.items)&&t.items.length>0&&(r=t.items[0]);if(!r&&t&&typeof t=="object"&&!Array.isArray(t)&&_optionalChain([t, 'access', _4 => _4.data, 'optionalAccess', _5 => _5.response, 'optionalAccess', _6 => _6.data]))try{let n=t.data.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e3){}}r?(d(r),E(null),f.current=0):(E("User profile not found in database"),d(null))}}catch(s){if(i===g.current&&o.current){let r=s;if(r.name==="AbortError")return;N&&f.current<m&&(_optionalChain([r, 'access', _7 => _7.message, 'optionalAccess', _8 => _8.includes, 'call', _9 => _9("Network Error")])||_optionalChain([r, 'access', _10 => _10.message, 'optionalAccess', _11 => _11.includes, 'call', _12 => _12("Failed to fetch")]))?(f.current++,setTimeout(()=>{o.current&&D()},1e3*f.current)):(E("Failed to load user profile from database"),d(null))}}finally{i===g.current&&o.current&&A(!1),l.current===e&&(l.current=null)}},[I,F,N,m]);return _react.useEffect.call(void 0, ()=>{c&&T&&I?D():T||P()},[c,T,I,D,P]),_react.useEffect.call(void 0, ()=>(o.current=!0,()=>{o.current=!1,l.current&&(l.current.abort(),l.current=null)}),[]),{user:{session:u,data:R},loading:y,error:C,refreshProfile:D,clearProfile:P}};var te=()=>{let{isAuthenticated:S,isLoading:c,isInitialized:N,tokens:m,error:T,sessionData:I,login:u,logout:p,refreshTokens:R,clearError:d,getTokenInfo:y,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E}=_chunkAKTAAP5Ijs.j.call(void 0, ),l=_react.useCallback.call(void 0, g=>{g?_chunk34FAL7YWjs.a.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):p()},[p]),o=_optionalChain([m, 'optionalAccess', _13 => _13.expiresAt])?new Date(m.expiresAt):null;return{isAuthenticated:S,loading:c,error:T,token:_optionalChain([m, 'optionalAccess', _14 => _14.accessToken])||null,user:I,tokenExpiration:o,setToken:l,logout:p,refreshToken:R,login:u,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E,getTokenInfo:y,clearError:d}};var ae=()=>{let{isInitialized:S,isLoading:c,error:N,isAuthenticated:m,login:T}=_chunkAKTAAP5Ijs.j.call(void 0, ),I=_react.useCallback.call(void 0, ()=>S&&!c&&!N,[S,c,N]),u=_react.useCallback.call(void 0, async()=>new Promise((o,g)=>{let f=()=>{I()?o():N?g(new Error(N)):setTimeout(f,100)};f()}),[I,N]),p=_react.useCallback.call(void 0, async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),R=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.readItems(o,g||{},f)),[p]),d=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.readItem(o,g,f)),[p]),y=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.createItem(o,g,f)),[p]),A=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.updateItem(o,g,f)),[p]),C=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.deleteItem(o,g,f)),[p]),E=_react.useCallback.call(void 0, async(o,g)=>(await p(),await _crudifybrowser2.default.transaction(o,g)),[p]),l=_react.useCallback.call(void 0, async(o,g)=>{try{let f=await T(o,g);return f.success?{success:!0,data:f.tokens}:{success:!1,errors:f.error||"Login failed"}}catch(f){return{success:!1,errors:f instanceof Error?f.message:"Login failed"}}},[T]);return{readItems:R,readItem:d,createItem:y,updateItem:A,deleteItem:C,transaction:E,login:l,isInitialized:S,isInitializing:c,initializationError:N,isReady:I,waitForReady:u}};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"},de= exports.d =(S={})=>{let{showNotification:c}=_chunkAKTAAP5Ijs.h.call(void 0, ),{showSuccessNotifications:N=!1,showErrorNotifications:m=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:u=6e3,appStructure:p=[],translateFn:R=e=>e}=S,d=_react.useCallback.call(void 0, e=>{if(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||_optionalChain([e, 'access', _15 => _15.errors, 'access', _16 => _16._transaction, 'optionalAccess', _17 => _17.includes, 'call', _18 => _18("ONE_OR_MORE_OPERATIONS_FAILED")])||_optionalChain([e, 'access', _19 => _19.errors, 'access', _20 => _20._error, 'optionalAccess', _21 => _21.includes, 'call', _22 => _22("TOO_MANY_REQUESTS")])))return!1;let i=e.data;return!(!e.success&&_optionalChain([i, 'optionalAccess', _23 => _23.response, 'optionalAccess', _24 => _24.status])==="TOO_MANY_REQUESTS")},[]),y=_react.useCallback.call(void 0, (e,i)=>{let s=R(e);return s===e?i||R("error.unknown"):s},[R]),A=_react.useCallback.call(void 0, e=>["create","update","delete"].includes(e),[]),C=_react.useCallback.call(void 0, (e,i)=>N?A(e)&&i?!0:p.some(s=>s.key===e):!1,[N,p,A]),E=_react.useCallback.call(void 0, (e,i,s)=>{let r=_optionalChain([s, 'optionalAccess', _25 => _25.key])&&typeof s.key=="string"?s.key:e,t=`action.onSuccess.${r}`,n=y(t);if(n!==R("error.unknown")){if(A(r)&&i){let a=`action.${i}Singular`,O=y(a);if(O!==R("error.unknown"))return R(t,{item:O});{let L=`action.onSuccess.${r}WithoutItem`,x=y(L);return x!==R("error.unknown")?x:n}}return n}return R("success.transaction")},[y,R,A]),l=_react.useCallback.call(void 0, 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 s of i){let r=y(s);if(r!==R("error.unknown"))return r}}if(typeof e.data=="string"&&e.data.startsWith("errors.")){let i=y(e.data);if(i!==R("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 s=e.errors._transaction;if(_optionalChain([s, 'optionalAccess', _26 => _26.includes, 'call', _27 => _27("ONE_OR_MORE_OPERATIONS_FAILED")]))return"";if(Array.isArray(s)&&s.length>0){let r=s[0];if(typeof r=="string"&&r!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let t=JSON.parse(r);if(Array.isArray(t)&&t.length>0){let n=t[0];if(_optionalChain([n, 'optionalAccess', _28 => _28.response, 'optionalAccess', _29 => _29.errorCode])){let a=n.response.errorCode;if(M[a])return y(M[a]);let O=[`errors.auth.${a}`,`errors.data.${a}`,`errors.system.${a}`,`errors.${a}`];for(let L of O){let x=y(L);if(x!==y("error.unknown"))return x}}if(_optionalChain([n, 'optionalAccess', _30 => _30.response, 'optionalAccess', _31 => _31.data]))return n.response.data}if(_optionalChain([t, 'optionalAccess', _32 => _32.response, 'optionalAccess', _33 => _33.message])){let n=t.response.message.toLowerCase();return n.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t.response.message}}catch (e4){return r.toLowerCase().includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):r.toLowerCase().includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):r}}return y("error.transaction","Error en la operaci\xF3n")}if(i.length===1&&i[0]==="_error"){let s=e.errors._error;return Array.isArray(s)?s[0]:String(s)}return i.length===1&&i[0]==="_graphql"?y("errors.system.DATABASE_CONNECTION_ERROR"):`${y("errors.data.FIELD_ERROR")}: ${i.join(", ")}`}return I||R("error.unknown")},[T,I,R,y]),o=_react.useCallback.call(void 0, e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),g=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.createItem(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}else if(r.success){let t=_optionalChain([s, 'optionalAccess', _34 => _34.actionConfig]),n=_optionalChain([t, 'optionalAccess', _35 => _35.key])||"create",a=_optionalChain([t, 'optionalAccess', _36 => _36.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[m,C,c,l,o,E,u,d]),f=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.updateItem(e,i,s),t=_optionalChain([s, 'optionalAccess', _37 => _37.skipNotifications])===!0;if(!t&&!r.success&&m&&d(r)){let n=l(r),a=o(r);c(n,a,{autoHideDuration:u})}else if(!t&&r.success){let n=_optionalChain([s, 'optionalAccess', _38 => _38.actionConfig]),a=_optionalChain([n, 'optionalAccess', _39 => _39.key])||"update",O=_optionalChain([n, 'optionalAccess', _40 => _40.moduleKey])||e;if(C(a,O)){let L=E(a,O,n);c(L,"success",{autoHideDuration:u})}}return r},[m,C,c,l,o,E,u,d]),F=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.deleteItem(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}else if(r.success){let t=_optionalChain([s, 'optionalAccess', _41 => _41.actionConfig]),n=_optionalChain([t, 'optionalAccess', _42 => _42.key])||"delete",a=_optionalChain([t, 'optionalAccess', _43 => _43.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[m,C,c,l,o,E,u,d]),P=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.readItem(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}return r},[m,c,l,o,u,d]),D=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.readItems(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}return r},[m,c,l,o,u,d]),q=_react.useCallback.call(void 0, async(e,i)=>{let s=await _crudifybrowser2.default.transaction(e,i),r=_optionalChain([i, 'optionalAccess', _44 => _44.skipNotifications])===!0;if(!r&&!s.success&&m&&d(s)){let t=l(s),n=o(s);c(t,n,{autoHideDuration:u})}else if(!r&&s.success){let t="transaction",n,a=null;if(_optionalChain([i, 'optionalAccess', _45 => _45.actionConfig])?(a=i.actionConfig,t=a.key,n=a.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(t=e[0].operation,a=p.find(O=>O.key===t),a&&(n=a.moduleKey)),C(t,n)){let O=E(t,n,a);c(O,"success",{autoHideDuration:u})}}return s},[m,C,c,l,o,E,u,d,p]),h=_react.useCallback.call(void 0, (e,i)=>{if(!e.success&&m&&d(e)){let s=l(e),r=o(e);c(s,r,{autoHideDuration:u})}else e.success&&N&&i&&c(i,"success",{autoHideDuration:u});return e},[m,N,c,l,o,u,d,R]);return{createItem:g,updateItem:f,deleteItem:F,readItem:P,readItems:D,transaction:q,handleResponse:h,getErrorMessage:l,getErrorSeverity:o,shouldShowNotification:d}};exports.a = J; exports.b = te; exports.c = ae; exports.d = de;
|
|
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 _chunkE2B7CUHDjs = require('./chunk-E2B7CUHD.js');var _chunkDJ3T7VVSjs = require('./chunk-DJ3T7VVS.js');var _react = require('react');var _crudifybrowser = require('@nocios/crudify-browser'); var _crudifybrowser2 = _interopRequireDefault(_crudifybrowser);var J=(S={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:m=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:u,tokens:p}=_chunkE2B7CUHDjs.j.call(void 0, ),[R,d]=_react.useState.call(void 0, null),[y,A]=_react.useState.call(void 0, c&&T),[C,E]=_react.useState.call(void 0, null),l=_react.useRef.call(void 0, null),o=_react.useRef.call(void 0, !0),g=_react.useRef.call(void 0, 0),f=_react.useRef.call(void 0, 0),F=_react.useCallback.call(void 0, ()=>{if(!u)return null;let h=u["cognito:username"];return u.email||(typeof h=="string"?h:null)},[u]),P=_react.useCallback.call(void 0, ()=>{d(null),E(null),A(!1),f.current=0},[]),D=_react.useCallback.call(void 0, async()=>{let h=F();if(!h){o.current&&(E("No user email available from session data"),A(!1));return}if(!I){o.current&&(E("Session not initialized"),A(!1));return}l.current&&l.current.abort();let e=new AbortController;l.current=e;let i=++g.current;try{o.current&&(A(!0),E(null));let s=await _crudifybrowser2.default.readItems("users",{filter:{email:h},pagination:{limit:1}});if(i===g.current&&o.current&&!e.signal.aborted){let r=null;if(s.success){let t=s.data;if(Array.isArray(t)&&t.length>0)r=t[0];else if(t&&typeof t=="object"&&!Array.isArray(t)&&_optionalChain([t, 'access', _2 => _2.response, 'optionalAccess', _3 => _3.data]))try{let n=t.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e2){}else t&&typeof t=="object"&&!Array.isArray(t)&&t.items&&Array.isArray(t.items)&&t.items.length>0&&(r=t.items[0]);if(!r&&t&&typeof t=="object"&&!Array.isArray(t)&&_optionalChain([t, 'access', _4 => _4.data, 'optionalAccess', _5 => _5.response, 'optionalAccess', _6 => _6.data]))try{let n=t.data.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e3){}}r?(d(r),E(null),f.current=0):(E("User profile not found in database"),d(null))}}catch(s){if(i===g.current&&o.current){let r=s;if(r.name==="AbortError")return;N&&f.current<m&&(_optionalChain([r, 'access', _7 => _7.message, 'optionalAccess', _8 => _8.includes, 'call', _9 => _9("Network Error")])||_optionalChain([r, 'access', _10 => _10.message, 'optionalAccess', _11 => _11.includes, 'call', _12 => _12("Failed to fetch")]))?(f.current++,setTimeout(()=>{o.current&&D()},1e3*f.current)):(E("Failed to load user profile from database"),d(null))}}finally{i===g.current&&o.current&&A(!1),l.current===e&&(l.current=null)}},[I,F,N,m]);return _react.useEffect.call(void 0, ()=>{c&&T&&I?D():T||P()},[c,T,I,D,P]),_react.useEffect.call(void 0, ()=>(o.current=!0,()=>{o.current=!1,l.current&&(l.current.abort(),l.current=null)}),[]),{user:{session:u,data:R},loading:y,error:C,refreshProfile:D,clearProfile:P}};var te=()=>{let{isAuthenticated:S,isLoading:c,isInitialized:N,tokens:m,error:T,sessionData:I,login:u,logout:p,refreshTokens:R,clearError:d,getTokenInfo:y,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E}=_chunkE2B7CUHDjs.j.call(void 0, ),l=_react.useCallback.call(void 0, g=>{g?_chunkDJ3T7VVSjs.a.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):p()},[p]),o=_optionalChain([m, 'optionalAccess', _13 => _13.expiresAt])?new Date(m.expiresAt):null;return{isAuthenticated:S,loading:c,error:T,token:_optionalChain([m, 'optionalAccess', _14 => _14.accessToken])||null,user:I,tokenExpiration:o,setToken:l,logout:p,refreshToken:R,login:u,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E,getTokenInfo:y,clearError:d}};var ae=()=>{let{isInitialized:S,isLoading:c,error:N,isAuthenticated:m,login:T}=_chunkE2B7CUHDjs.j.call(void 0, ),I=_react.useCallback.call(void 0, ()=>S&&!c&&!N,[S,c,N]),u=_react.useCallback.call(void 0, async()=>new Promise((o,g)=>{let f=()=>{I()?o():N?g(new Error(N)):setTimeout(f,100)};f()}),[I,N]),p=_react.useCallback.call(void 0, async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),R=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.readItems(o,g||{},f)),[p]),d=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.readItem(o,g,f)),[p]),y=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.createItem(o,g,f)),[p]),A=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.updateItem(o,g,f)),[p]),C=_react.useCallback.call(void 0, async(o,g,f)=>(await p(),await _crudifybrowser2.default.deleteItem(o,g,f)),[p]),E=_react.useCallback.call(void 0, async(o,g)=>(await p(),await _crudifybrowser2.default.transaction(o,g)),[p]),l=_react.useCallback.call(void 0, async(o,g)=>{try{let f=await T(o,g);return f.success?{success:!0,data:f.tokens}:{success:!1,errors:f.error||"Login failed"}}catch(f){return{success:!1,errors:f instanceof Error?f.message:"Login failed"}}},[T]);return{readItems:R,readItem:d,createItem:y,updateItem:A,deleteItem:C,transaction:E,login:l,isInitialized:S,isInitializing:c,initializationError:N,isReady:I,waitForReady:u}};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"},de= exports.d =(S={})=>{let{showNotification:c}=_chunkE2B7CUHDjs.h.call(void 0, ),{showSuccessNotifications:N=!1,showErrorNotifications:m=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:u=6e3,appStructure:p=[],translateFn:R=e=>e}=S,d=_react.useCallback.call(void 0, e=>{if(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||_optionalChain([e, 'access', _15 => _15.errors, 'access', _16 => _16._transaction, 'optionalAccess', _17 => _17.includes, 'call', _18 => _18("ONE_OR_MORE_OPERATIONS_FAILED")])||_optionalChain([e, 'access', _19 => _19.errors, 'access', _20 => _20._error, 'optionalAccess', _21 => _21.includes, 'call', _22 => _22("TOO_MANY_REQUESTS")])))return!1;let i=e.data;return!(!e.success&&_optionalChain([i, 'optionalAccess', _23 => _23.response, 'optionalAccess', _24 => _24.status])==="TOO_MANY_REQUESTS")},[]),y=_react.useCallback.call(void 0, (e,i)=>{let s=R(e);return s===e?i||R("error.unknown"):s},[R]),A=_react.useCallback.call(void 0, e=>["create","update","delete"].includes(e),[]),C=_react.useCallback.call(void 0, (e,i)=>N?A(e)&&i?!0:p.some(s=>s.key===e):!1,[N,p,A]),E=_react.useCallback.call(void 0, (e,i,s)=>{let r=_optionalChain([s, 'optionalAccess', _25 => _25.key])&&typeof s.key=="string"?s.key:e,t=`action.onSuccess.${r}`,n=y(t);if(n!==R("error.unknown")){if(A(r)&&i){let a=`action.${i}Singular`,O=y(a);if(O!==R("error.unknown"))return R(t,{item:O});{let L=`action.onSuccess.${r}WithoutItem`,x=y(L);return x!==R("error.unknown")?x:n}}return n}return R("success.transaction")},[y,R,A]),l=_react.useCallback.call(void 0, 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 s of i){let r=y(s);if(r!==R("error.unknown"))return r}}if(typeof e.data=="string"&&e.data.startsWith("errors.")){let i=y(e.data);if(i!==R("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 s=e.errors._transaction;if(_optionalChain([s, 'optionalAccess', _26 => _26.includes, 'call', _27 => _27("ONE_OR_MORE_OPERATIONS_FAILED")]))return"";if(Array.isArray(s)&&s.length>0){let r=s[0];if(typeof r=="string"&&r!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let t=JSON.parse(r);if(Array.isArray(t)&&t.length>0){let n=t[0];if(_optionalChain([n, 'optionalAccess', _28 => _28.response, 'optionalAccess', _29 => _29.errorCode])){let a=n.response.errorCode;if(M[a])return y(M[a]);let O=[`errors.auth.${a}`,`errors.data.${a}`,`errors.system.${a}`,`errors.${a}`];for(let L of O){let x=y(L);if(x!==y("error.unknown"))return x}}if(_optionalChain([n, 'optionalAccess', _30 => _30.response, 'optionalAccess', _31 => _31.data]))return n.response.data}if(_optionalChain([t, 'optionalAccess', _32 => _32.response, 'optionalAccess', _33 => _33.message])){let n=t.response.message.toLowerCase();return n.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t.response.message}}catch (e4){return r.toLowerCase().includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):r.toLowerCase().includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):r}}return y("error.transaction","Error en la operaci\xF3n")}if(i.length===1&&i[0]==="_error"){let s=e.errors._error;return Array.isArray(s)?s[0]:String(s)}return i.length===1&&i[0]==="_graphql"?y("errors.system.DATABASE_CONNECTION_ERROR"):`${y("errors.data.FIELD_ERROR")}: ${i.join(", ")}`}return I||R("error.unknown")},[T,I,R,y]),o=_react.useCallback.call(void 0, e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),g=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.createItem(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}else if(r.success){let t=_optionalChain([s, 'optionalAccess', _34 => _34.actionConfig]),n=_optionalChain([t, 'optionalAccess', _35 => _35.key])||"create",a=_optionalChain([t, 'optionalAccess', _36 => _36.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[m,C,c,l,o,E,u,d]),f=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.updateItem(e,i,s),t=_optionalChain([s, 'optionalAccess', _37 => _37.skipNotifications])===!0;if(!t&&!r.success&&m&&d(r)){let n=l(r),a=o(r);c(n,a,{autoHideDuration:u})}else if(!t&&r.success){let n=_optionalChain([s, 'optionalAccess', _38 => _38.actionConfig]),a=_optionalChain([n, 'optionalAccess', _39 => _39.key])||"update",O=_optionalChain([n, 'optionalAccess', _40 => _40.moduleKey])||e;if(C(a,O)){let L=E(a,O,n);c(L,"success",{autoHideDuration:u})}}return r},[m,C,c,l,o,E,u,d]),F=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.deleteItem(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}else if(r.success){let t=_optionalChain([s, 'optionalAccess', _41 => _41.actionConfig]),n=_optionalChain([t, 'optionalAccess', _42 => _42.key])||"delete",a=_optionalChain([t, 'optionalAccess', _43 => _43.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[m,C,c,l,o,E,u,d]),P=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.readItem(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}return r},[m,c,l,o,u,d]),D=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifybrowser2.default.readItems(e,i,s);if(!r.success&&m&&d(r)){let t=l(r),n=o(r);c(t,n,{autoHideDuration:u})}return r},[m,c,l,o,u,d]),q=_react.useCallback.call(void 0, async(e,i)=>{let s=await _crudifybrowser2.default.transaction(e,i),r=_optionalChain([i, 'optionalAccess', _44 => _44.skipNotifications])===!0;if(!r&&!s.success&&m&&d(s)){let t=l(s),n=o(s);c(t,n,{autoHideDuration:u})}else if(!r&&s.success){let t="transaction",n,a=null;if(_optionalChain([i, 'optionalAccess', _45 => _45.actionConfig])?(a=i.actionConfig,t=a.key,n=a.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(t=e[0].operation,a=p.find(O=>O.key===t),a&&(n=a.moduleKey)),C(t,n)){let O=E(t,n,a);c(O,"success",{autoHideDuration:u})}}return s},[m,C,c,l,o,E,u,d,p]),h=_react.useCallback.call(void 0, (e,i)=>{if(!e.success&&m&&d(e)){let s=l(e),r=o(e);c(s,r,{autoHideDuration:u})}else e.success&&N&&i&&c(i,"success",{autoHideDuration:u});return e},[m,N,c,l,o,u,d,R]);return{createItem:g,updateItem:f,deleteItem:F,readItem:P,readItems:D,transaction:q,handleResponse:h,getErrorMessage:l,getErrorSeverity:o,shouldShowNotification:d}};exports.a = J; exports.b = te; exports.c = ae; exports.d = de;
|
|
@@ -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 T=[/password[^:]*[:=]\s*[^\s,}]+/gi,/token[^:]*[:=]\s*[^\s,}]+/gi,/key[^:]*[:=]\s*["']?[^\s,}"']+/gi,/secret[^:]*[:=]\s*[^\s,}]+/gi,/authorization[^:]*[:=]\s*[^\s,}]+/gi,/mongodb(\+srv)?:\/\/[^\s]+/gi,/postgres:\/\/[^\s]+/gi,/mysql:\/\/[^\s]+/gi];function w(n){if(typeof document>"u")return null;let e=document.cookie.match(new RegExp("(^|;)\\s*"+n+"=([^;]+)"));return e?e[2]:null}function S(){if(typeof window<"u"&&window.__CRUDIFY_ENV__)return window.__CRUDIFY_ENV__;let n=w("environment");return n&&["dev","stg","api","prod"].includes(n)?n:"prod"}var N=null,_="CrudifyUI",v=class{constructor(){this.explicitEnv=null;this.explicitEnv=N,this.prefix=_}getEffectiveEnv(){return this.explicitEnv!==null?this.explicitEnv:S()}sanitize(e){let t=e;for(let o of T)t=t.replace(o,"[REDACTED]");return t}sanitizeContext(e){let t={};for(let[o,r]of Object.entries(e))if(r!=null)if(o==="userId"&&typeof r=="string")t[o]=r.length>8?`${r.substring(0,8)}***`:r;else if(o==="email"&&typeof r=="string"){let[a,u]=r.split("@");t[o]=a&&u?`${a.substring(0,3)}***@${u}`:"[REDACTED]"}else typeof r=="string"?t[o]=this.sanitize(r):typeof r=="object"&&r!==null?t[o]=this.sanitizeContext(r):t[o]=r;return t}shouldLog(e){if(typeof window<"u"&&window.__CRUDIFY_DEBUG_MODE__)return!0;let t=this.getEffectiveEnv();return!((t==="prod"||t==="production"||t==="api")&&e!=="error")}log(e,t,o){if(!this.shouldLog(e))return;let r=this.sanitize(t),a=o?this.sanitizeContext(o):void 0,u={timestamp:new Date().toISOString(),level:e,environment:this.getEffectiveEnv(),service:this.prefix,message:r,...a&&Object.keys(a).length>0&&{context:a}},l=JSON.stringify(u);switch(e){case"error":console.error(l);break;case"warn":console.warn(l);break;case"info":console.info(l);break;case"debug":console.log(l);break}}error(e,t){let o;t instanceof Error?o={errorName:t.name,errorMessage:t.message,stack:t.stack}:o=t,this.log("error",e,o)}warn(e,t){this.log("warn",e,t)}info(e,t){this.log("info",e,t)}debug(e,t){this.log("debug",e,t)}getEnvironment(){return this.getEffectiveEnv()}setEnvironment(e){this.explicitEnv=e,N=e,typeof window<"u"&&(window.__CRUDIFY_ENV__=e)}isExplicitlyConfigured(){return this.explicitEnv!==null}},i= exports.a =new v;var f=n=>{let e=document.cookie.match(new RegExp("(^|;)\\s*"+n+"=([^;]+)"));return e?e[2]:null};function O(n={}){let{publicApiKey:e,env:t,appName:o,logo:r,loginActions:a,featureKeys:u,enableDebug:l=!1}=n;console.log("[CRUDIFY_DEBUG] resolveConfig called with:",{propsApiKey:e?`${e.substring(0,10)}...`:"undefined",propsEnv:t,enableDebug:l,documentCookie:typeof document<"u"?document.cookie:"N/A"});let s={configSource:"none"};l&&i.info("[ConfigResolver] Resolving configuration...",{propsApiKey:e?`${e.substring(0,10)}...`:void 0,propsEnv:t,hasPropsAppName:!!o,hasPropsLogo:!!r,propsLoginActions:a,propsFeatureKeys:u});let g=f("publicApiKey");if(console.log("[CRUDIFY_DEBUG] getCookie('publicApiKey'):",g?`${g.substring(0,10)}...`:"null"),l&&i.info("[ConfigResolver] Cookie check:",{hasCookieApiKey:!!g,cookieApiKey:g?`${g.substring(0,10)}...`:null,allCookies:typeof document<"u"?document.cookie:"N/A"}),g){let c=f("environment"),p=f("appName"),y=f("logo"),R=f("loginActions"),C=f("featureKeys"),A=f("theme");return s={publicApiKey:decodeURIComponent(g),env:c&&["dev","stg","api","prod"].includes(c)?c:"prod",appName:p?decodeURIComponent(p):void 0,logo:y?decodeURIComponent(y):void 0,loginActions:R?decodeURIComponent(R).split(",").map(E=>E.trim()).filter(Boolean):void 0,featureKeys:C?decodeURIComponent(C).split(",").map(E=>E.trim()).filter(Boolean):void 0,theme:A?(()=>{try{return JSON.parse(decodeURIComponent(A))}catch(E){l&&i.warn("[ConfigResolver] Failed to parse theme cookie",E instanceof Error?{errorMessage:E.message}:{message:String(E)});return}})():void 0,configSource:"cookies"},l&&(i.info("[ConfigResolver] \u2705 Using COOKIES configuration",{env:s.env,hasAppName:!!s.appName,hasLogo:!!s.logo,loginActionsCount:_optionalChain([s, 'access', _2 => _2.loginActions, 'optionalAccess', _3 => _3.length]),featureKeysCount:_optionalChain([s, 'access', _4 => _4.featureKeys, 'optionalAccess', _5 => _5.length])}),typeof window<"u"&&(window.__CRUDIFY_RESOLVED_CONFIG=s)),s}return e?(s={publicApiKey:e,env:t||"prod",appName:o,logo:r,loginActions:a,featureKeys:u,configSource:"props"},l&&(i.info("[ConfigResolver] \u2705 Using PROPS configuration (fallback - no cookies found)",{env:s.env,hasAppName:!!s.appName,hasLogo:!!s.logo,loginActionsCount:_optionalChain([s, 'access', _6 => _6.loginActions, 'optionalAccess', _7 => _7.length]),featureKeysCount:_optionalChain([s, 'access', _8 => _8.featureKeys, 'optionalAccess', _9 => _9.length])}),typeof window<"u"&&(window.__CRUDIFY_RESOLVED_CONFIG=s)),s):(l&&i.error("[ConfigResolver] \u274C No configuration found! Neither cookies nor props have publicApiKey",{hasCookies:!!g,hasProps:!!e}),s)}function M(n={}){return O(n)}var k=["errors.{category}.{code}","errors.{code}","login.{code}","error.{code}","messages.{code}","{code}"],D={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"},L={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 h(n,e){let{translateFn:t,currentLanguage:o,enableDebug:r}=e;r&&i.debug(`[ErrorTranslation] Translating error code: ${n} (lang: ${o||"unknown"})`);let a=n.toUpperCase(),u=D[a],l=k.map(c=>c.replace("{category}",u||"general").replace("{code}",a));r&&i.debug("[ErrorTranslation] Searching keys:",{translationKeys:l});for(let c of l){let p=t(c);if(r&&i.debug(`[ErrorTranslation] Checking key: "${c}" -> result: "${p}" (same as key: ${p===c})`),p&&p!==c)return r&&i.debug(`[ErrorTranslation] Found translation at key: ${c} = "${p}"`),p}let s=L[a];if(s)return r&&i.debug(`[ErrorTranslation] Using default message: "${s}"`),s;let g=a.replace(/_/g," ").toLowerCase().replace(/\b\w/g,c=>c.toUpperCase());return r&&i.debug(`[ErrorTranslation] No translation found, using friendly code: "${g}"`),g}function U(n,e){return n.map(t=>h(t,e))}function x(n,e){let{enableDebug:t}=e;t&&i.debug("[ErrorTranslation] Translating error:",{error:n});let o=h(n.code,e);return o!==n.code.toUpperCase()&&o!==n.code?(t&&i.debug(`[ErrorTranslation] Using hierarchical translation: "${o}"`),n.field?`${n.field}: ${o}`:o):n.message&&!n.message.includes("Error:")&&n.message.length>0&&n.message!==n.code?(t&&i.debug(`[ErrorTranslation] No hierarchical translation found, using API message: "${n.message}"`),n.message):(t&&i.debug(`[ErrorTranslation] Using final fallback: "${o}"`),n.field?`${n.field}: ${o}`:o)}function B(n,e={}){let t={translateFn:n,currentLanguage:e.currentLanguage,enableDebug:e.enableDebug||!1};return{translateErrorCode:o=>h(o,t),translateErrorCodes:o=>U(o,t),translateError:o=>x(o,t),translateApiError:o=>_optionalChain([o, 'optionalAccess', _10 => _10.data, 'optionalAccess', _11 => _11.response, 'optionalAccess', _12 => _12.status])?h(o.data.response.status,t):_optionalChain([o, 'optionalAccess', _13 => _13.status])?h(o.status,t):_optionalChain([o, 'optionalAccess', _14 => _14.code])?h(o.code,t):"Unknown error"}}var m=class n{constructor(){this.listeners=new Set;this.isHandlingAuthError=!1;this.lastErrorTime=0;this.lastEventType=null;this.DEBOUNCE_TIME=1e3}static getInstance(){return n.instance||(n.instance=new n),n.instance}emit(e,t){let o=Date.now();if(this.isHandlingAuthError&&this.lastEventType===e&&o-this.lastErrorTime<this.DEBOUNCE_TIME){i.debug(`AuthEventBus: Ignoring duplicate ${e} event (debounced)`);return}this.isHandlingAuthError=!0,this.lastErrorTime=o,this.lastEventType=e,i.debug(`AuthEventBus: Emitting ${e} event`,t?{details:t}:void 0);let r={type:e,details:t,timestamp:o};this.listeners.forEach(a=>{try{a(r)}catch(u){i.error("AuthEventBus: Error in listener",u instanceof Error?u:{message:String(u)})}}),setTimeout(()=>{this.isHandlingAuthError=!1,this.lastEventType=null},2e3)}subscribe(e){return this.listeners.add(e),()=>{this.listeners.delete(e)}}clear(){this.listeners.clear(),this.isHandlingAuthError=!1,this.lastEventType=null}isHandling(){return this.isHandlingAuthError}},J= exports.i =m.getInstance();var d=class d{constructor(){this.isPatched=!1;this.refCount=0;this.listeners=new Set;this.originalPushState=window.history.pushState,this.originalReplaceState=window.history.replaceState}static getInstance(){return d.instance||(d.instance=new d),d.instance}subscribe(e){return this.listeners.add(e),this.refCount++,this.isPatched||this.applyPatches(),()=>{this.unsubscribe(e)}}unsubscribe(e){this.listeners.delete(e),this.refCount--,this.refCount===0&&this.isPatched&&this.removePatches()}applyPatches(){let e=this;window.history.pushState=function(...t){let o=e.originalPushState.apply(this,t);return e.notifyListeners(),o},window.history.replaceState=function(...t){let o=e.originalReplaceState.apply(this,t);return e.notifyListeners(),o},this.isPatched=!0}removePatches(){window.history.pushState=this.originalPushState,window.history.replaceState=this.originalReplaceState,this.isPatched=!1}notifyListeners(){this.listeners.forEach(e=>{try{e()}catch(t){i.error("NavigationTracker: Error in navigation listener",t instanceof Error?t:{message:String(t)})}})}static reset(){_optionalChain([d, 'access', _15 => _15.instance, 'optionalAccess', _16 => _16.isPatched])&&d.instance.removePatches(),d.instance=null}getSubscriberCount(){return this.refCount}isActive(){return this.isPatched}};d.instance=null;var I=d;var b=n=>{try{let e=n.split(".");if(e.length!==3)return i.warn("Invalid JWT format: token must have 3 parts"),null;let t=e[1],o=t+"=".repeat((4-t.length%4)%4);return JSON.parse(atob(o))}catch(e){return i.warn("Failed to decode JWT token",e instanceof Error?{errorMessage:e.message}:{message:String(e)}),null}},j= exports.l =()=>{try{let n=null;if(n=sessionStorage.getItem("authToken"),n||(n=sessionStorage.getItem("token")),n||(n=localStorage.getItem("authToken")||localStorage.getItem("token")),!n)return null;let e=b(n);return e&&(e.email||e["cognito:username"])||null}catch(n){return i.warn("Failed to get current user email",n instanceof Error?{errorMessage:n.message}:{message:String(n)}),null}},q= exports.m =n=>{try{let e=b(n);if(!e||!e.exp)return!0;let t=Math.floor(Date.now()/1e3);return e.exp<t}catch (e2){return!0}};exports.a = i; exports.b = f; exports.c = O; exports.d = M; exports.e = h; exports.f = U; exports.g = x; exports.h = B; exports.i = J; exports.j = I; exports.k = b; exports.l = j; exports.m = q;
|