@nocios/crudify-ui 4.5.2 → 5.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/workflows/test.yml +7 -11
- package/.nvmrc +1 -0
- package/coverage/coverage-final.json +29 -28
- package/coverage/index.html +85 -85
- package/dist/{api-C_I7deA9.d.mts → api-slyZ8Gxc.d.mts} +17 -1
- package/dist/{api-C_I7deA9.d.ts → api-slyZ8Gxc.d.ts} +17 -1
- package/dist/chunk-3XZ3TEKQ.js +1 -0
- package/dist/chunk-5VOTRIDB.js +1 -0
- package/dist/chunk-6BQGRZYB.mjs +1 -0
- package/dist/{chunk-BJ6PIVZR.mjs → chunk-JAPL7EZJ.mjs} +1 -1
- package/dist/chunk-KQ2XC5PN.js +1 -0
- package/dist/chunk-LVSNJ4OM.js +1 -0
- package/dist/chunk-NSA6YDHY.mjs +1 -0
- package/dist/{chunk-YIIUEOXC.js → chunk-NSV6ECYO.js} +1 -1
- package/dist/chunk-NXTXGTU6.js +1 -0
- package/dist/chunk-OGAGYHG4.mjs +1 -0
- package/dist/chunk-PARX2RMU.mjs +1 -0
- package/dist/chunk-QPTL5FLE.mjs +1 -0
- package/dist/components.js +1 -1
- package/dist/components.mjs +1 -1
- package/dist/{errorTranslation-CXaKqIZY.d.mts → errorTranslation-BOha05J6.d.ts} +31 -8
- package/dist/{errorTranslation-nLCjcHIw.d.ts → errorTranslation-DTUst6nq.d.mts} +31 -8
- package/dist/hooks.d.mts +2 -2
- package/dist/hooks.d.ts +2 -2
- package/dist/hooks.js +1 -1
- package/dist/hooks.mjs +1 -1
- package/dist/{index-FpnmfpFM.d.mts → index-DD1mjOd6.d.mts} +68 -42
- package/dist/{index-DLlGvAEz.d.ts → index-Dr4eHdgn.d.ts} +68 -42
- package/dist/index.d.mts +10 -6
- package/dist/index.d.ts +10 -6
- package/dist/index.js +2 -2
- package/dist/index.mjs +2 -2
- package/dist/utils.d.mts +3 -3
- package/dist/utils.d.ts +3 -3
- package/dist/utils.js +1 -1
- package/dist/utils.mjs +1 -1
- package/package.json +7 -7
- package/dist/chunk-34FAL7YW.js +0 -1
- package/dist/chunk-AD5AA75O.mjs +0 -1
- package/dist/chunk-ARGPCO6I.js +0 -1
- package/dist/chunk-CKGV4C6A.js +0 -1
- package/dist/chunk-FRHTVRUM.mjs +0 -1
- package/dist/chunk-IRHFZZXY.mjs +0 -1
- package/dist/chunk-JCQC42XC.js +0 -1
- package/dist/chunk-SQPHAKLM.mjs +0 -1
- package/dist/chunk-SUWV767V.mjs +0 -1
- package/dist/chunk-VM6JVOLD.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{e as Hr,g as qr,h as me,j as he,l as jr,m as Kr,p as $r}from"./chunk-PARX2RMU.mjs";import{g as Y}from"./chunk-JAPL7EZJ.mjs";import{a as x,b as Mr,c as Vr,n as Wr}from"./chunk-6BQGRZYB.mjs";var ue={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","base.btn.back":"Volver","base.btn.cancel":"Cancelar","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","base.errors.errorUnknown":"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","base.loading.configInitial":"Cargando configuraci\xF3n inicial...","base.loading.pleaseWait":"Cargando, por favor espera...","base.loading.starting":"Iniciando aplicaci\xF3n...","base.loading.themeSetup":"Generando tema...","base.loading.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...","publicPolicies.fields.conditions.customEdit":"Edici\xF3n personalizada","base.file.clickToPreview":"Clic para ver imagen","base.file.clickToDownload":"Clic para descargar","base.file.privateFile":"Archivo privado","base.file.noPreview":"Sin vista previa","base.file.dropHere":"Suelta el archivo aqu\xED","base.file.dragOrClick":"Arrastra archivos aqu\xED o haz clic para seleccionar","base.file.uploading":"Subiendo archivos...","base.file.restore":"Restaurar","base.file.delete":"Eliminar","base.file.pendingDeletion":"Pendiente de eliminaci\xF3n","base.file.allowedTypes":"Tipos permitidos: {{types}}","base.file.maxSize":"M\xE1ximo {{size}} por archivo","base.file.maxFiles":"M\xE1ximo {{count}} archivos","base.file.validation.minFilesRequired":"Se requiere al menos un archivo","base.file.validation.minFilesRequiredPlural":"Se requieren al menos {{count}} archivos","base.file.validation.maxFilesExceeded":"M\xE1ximo {{count}} archivos permitidos","base.file.validation.filesWithErrors":"Algunos archivos tienen errores","base.file.confirmDelete.title":"Eliminar archivo","base.file.confirmDelete.message":"\xBFEst\xE1s seguro de que deseas eliminar este archivo? Esta acci\xF3n no se puede deshacer.","base.file.confirmDelete.confirm":"Eliminar","base.file.confirmDelete.cancel":"Cancelar","base.file.deleting":"Eliminando..."},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","base.btn.back":"Back","base.btn.cancel":"Cancel","error.app.config":"Configuration Error: {{message}}","error.app.initialization":"Error during final application initialization.","error.transaction":"Operation error","base.errors.errorUnknown":"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","base.loading.configInitial":"Loading initial configuration...","base.loading.pleaseWait":"Loading, please wait...","base.loading.starting":"Starting application...","base.loading.themeSetup":"Generating theme...","base.loading.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...","publicPolicies.fields.conditions.customEdit":"Custom Edit","base.file.clickToPreview":"Click to preview","base.file.clickToDownload":"Click to download","base.file.privateFile":"Private file","base.file.noPreview":"No preview","base.file.dropHere":"Drop file here","base.file.dragOrClick":"Drag files here or click to select","base.file.uploading":"Uploading files...","base.file.restore":"Restore","base.file.delete":"Delete","base.file.pendingDeletion":"Pending deletion","base.file.allowedTypes":"Allowed types: {{types}}","base.file.maxSize":"Max {{size}} per file","base.file.maxFiles":"Max {{count}} files","base.file.validation.minFilesRequired":"At least one file is required","base.file.validation.minFilesRequiredPlural":"At least {{count}} files are required","base.file.validation.maxFilesExceeded":"Maximum {{count}} files allowed","base.file.validation.filesWithErrors":"Some files have errors","base.file.confirmDelete.title":"Delete file","base.file.confirmDelete.message":"Are you sure you want to delete this file? This action cannot be undone.","base.file.confirmDelete.confirm":"Delete","base.file.deleting":"Deleting...","base.file.confirmDelete.cancel":"Cancel"}},Xi=()=>Object.keys(ue),Ji=e=>ue[e]||ue.es;import je from"@nocios/crudify-browser";var Gr="crudify_translations_",tt=3600*1e3;function Yr(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 sr=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=je.getTokenData();if(t&&t.endpoint){this.enableDebug&&x.debug("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}je.config(o);let i=await je.init(r,this.enableDebug?"debug":"none");if(i.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(i.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:i="stg",urlTranslations:n}=r;this.enableDebug&&x.debug("[TranslationService] fetchTranslations called with:",{apiKeyHash:Yr(o),crudifyEnv:i,featureKeys:t,hasUrlTranslations:!!n});let s=this.getFromCache(o),a=s?this.isCacheExpired(s):!0;if(s&&!a)return this.enableDebug&&x.debug("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(s.data.translations,n);try{await this.ensureCrudifyInitialized(o,i)}catch(u){return x.error("[TranslationService] Failed to initialize crudify",u instanceof Error?u:{message:String(u)}),s?(x.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(s.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 u=await this.fetchFromAPI(t);this.hasDataChanged(s,u)||!s?this.saveToCache(o,u):this.refreshCacheTimestamp(o);let g=this.mergeWithUrlTranslations(u.translations,n);return this.enableDebug&&x.debug("[TranslationService] Translations loaded:",{languages:Object.keys(g),keysCount:g[Object.keys(g)[0]]?Object.keys(g[Object.keys(g)[0]]).length:0}),g}catch(u){return x.error("[TranslationService] API fetch failed",u instanceof Error?u:{message:String(u)}),s?(x.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(s.data.translations,n)):(x.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(r){let o=await je.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(i=>{t[i]={...r[i],...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 i=0;i<o.length;i++){let n=o.charCodeAt(i);t=(t<<5)-t+n,t=t&t}return t.toString(36)}saveToCache(r,o){try{let t=this.getCacheKey(r),i={data:o,cachedAt:Date.now(),dataHash:this.hashData(o.translations)};localStorage.setItem(t,JSON.stringify(i)),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>tt}hasValidCache(r){let o=this.getFromCache(r);return o?!this.isCacheExpired(o):!1}getCacheKey(r){return`${Gr}${Yr(r)}`}getCriticalTranslationsOnly(){return ue}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(Gr));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)})}}},Ke=sr.getInstance();import{createContext as nt,useContext as it,useEffect as Qr,useState as Ie,useMemo as Xr,useCallback as at}from"react";import{Fragment as lt,jsx as Ge}from"react/jsx-runtime";var $e=null,lr=!1,Zr=nt(null);function Jr(e,r,o){return{...e,...r,...o||{}}}function st(e,r,o,t,i){Qr(()=>{if(!t||!e||!r)return;let n=o||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!n||!n.addResourceBundle){i&&x.debug("[TranslationsProvider] i18next not found, skipping auto-sync");return}i&&x.debug("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:r}),Object.keys(e).forEach(s=>{e[s]&&Object.keys(e[s]).length>0&&(n.addResourceBundle(s,"translation",e[s],!0,!0),i&&x.debug(`[TranslationsProvider] Synced ${Object.keys(e[s]).length} keys for language: ${s}`))}),n.language!==r&&n.changeLanguage&&(n.changeLanguage(r),i&&x.debug(`[TranslationsProvider] Changed i18next language to: ${r}`))},[e,r,o,t,i])}var ca=({children:e,apiKey:r,crudifyEnv:o="prod",featureKeys:t,language:i="es",devTranslations:n,translationUrl:s,enableDebug:a=!1,skipAutoInit:u=!0,autoSyncI18n:y=!0,i18nInstance:g,loadingFallback:b,waitForInitialLoad:l=!0})=>{let f=Xr(()=>Vr({publicApiKey:r,env:o,featureKeys:t,enableDebug:a}),[r,o,t,a]),c=f.publicApiKey||"",w=f.env||o||"prod",m=f.featureKeys||t,[p,h]=Ie({}),[P,S]=Ie(!0),[U,d]=Ie(!0),[C,I]=Ie(null),[A,q]=Ie(void 0),[re,oe]=Ie(!1),ce=at(async()=>{if(!c){a&&x.debug("[TranslationsProvider] No apiKey - skipping translation fetch"),S(!1),d(!1);return}if(re){a&&x.debug("[TranslationsProvider] Skipping reload - using fallback translations");return}if(Ke.hasValidCache(c)&&U&&(a&&x.debug("[TranslationsProvider] Valid cache found - not blocking initial render"),d(!1)),lr&&$e){a&&x.debug("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let R=await $e;h(R),S(!1);return}catch{a&&x.warn("[TranslationsProvider] Global fetch failed, retrying")}}lr=!0,S(!0),I(null);let B;if(s)try{a&&x.debug(`[TranslationsProvider] Fetching translations from URL: ${s}`);let R=await fetch(s);if(!R.ok)throw new Error(`Failed to fetch translations: ${R.statusText}`);B=await R.json(),q(B),a&&x.debug("[TranslationsProvider] URL translations loaded:",{keysCount:B?Object.keys(B).length:0})}catch(R){x.error("[TranslationsProvider] Failed to load URL translations",R instanceof Error?R:{message:String(R)}),B=void 0,q(void 0)}let de=(async()=>{try{Ke.setDebug(a);let R=await Ke.fetchTranslations({apiKey:c,crudifyEnv:w,featureKeys:m,urlTranslations:B}),V={};return Object.keys(R).forEach(v=>{let k=ue[v]||{},F=R[v]||{};V[v]=Jr(k,F,n)}),a&&x.debug("[TranslationsProvider] Loaded translations:",{languages:Object.keys(V),keysCount:Object.keys(V[i]||{}).length}),V}catch(R){x.error("[TranslationsProvider] Failed to load",R instanceof Error?R:{message:String(R)}),I(R instanceof Error?R.message:String(R)),oe(!0);let V={};return Object.keys(ue).forEach(v=>{let k=ue[v],F=B||A||{};V[v]=Jr(k,F,n)}),a&&x.debug("[TranslationsProvider] Using fallback translations (critical + URL)"),V}})();$e=de;try{let R=await de;h(R)}finally{S(!1),d(!1),lr=!1,setTimeout(()=>{$e=null},1e3)}},[c,w,m,s,n,a,i,re]);Qr(()=>{ce();let j=setInterval(ce,3600*1e3);return()=>clearInterval(j)},[ce]);let Re=Xr(()=>(j,B)=>{let R=(p[i]||{})[j];if(!R){let V=Object.keys(p);for(let v of V)if(p[v][j]){R=p[v][j];break}}return R||(a&&x.warn(`[TranslationsProvider] Missing translation: "${j}"`),R=j),B&&typeof R=="string"&&Object.entries(B).forEach(([V,v])=>{let k=new RegExp(`{{${V}}}`,"g");R=R.replace(k,String(v))}),R},[p,i,a]);st(p,i,g,y,a);let D={t:Re,language:i,availableLanguages:Object.keys(p),translations:p,isLoading:P,error:C,refreshTranslations:ce};return c?l&&U&&P?b||Ge("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:Ge("div",{children:"Loading translations..."})}):Ge(Zr.Provider,{value:D,children:e}):(a&&x.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),Ge(lt,{children:e}))},_e=()=>{let e=it(Zr);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};import{Box as $t,Typography as Gt}from"@mui/material";import{createContext as dt,useContext as ut,useMemo as dr}from"react";import{useState as cr,useEffect as ct}from"react";var eo=(e,r)=>{let[o,t]=cr({}),[i,n]=cr(!1),[s,a]=cr(null);return ct(()=>{if(r&&Object.keys(r).length>0){t(r),n(!1),a(null);return}if(!e){t({}),n(!1),a(null);return}let u=!1;return n(!0),a(null),fetch(e).then(y=>{if(!y.ok)throw new Error(`Failed to load translations: ${y.status}`);return y.json()}).then(y=>{u||(t(y),n(!1))}).catch(y=>{u||(x.error("[I18nProvider] Failed to load translations from URL",y instanceof Error?y:{message:String(y),url:e}),a(y instanceof Error?y.message:String(y)),t({}),n(!1))}),()=>{u=!0}},[e,r]),{translations:o,loading:i,error:s}};import{jsx as ro}from"react/jsx-runtime";var oo=dt(null),gt=()=>{try{return _e()}catch{return null}},ft=(e,r)=>{if(r.includes(".")){let o=r.split(".").reduce((t,i)=>t&&typeof t=="object"?t[i]:void 0,e);if(o!==void 0)return o}if(e&&e[r])return e[r]},to=({children:e,translations:r,translationsUrl:o,language:t="en"})=>{let n=gt()?.translations?.[t]||{},{translations:s,loading:a}=eo(o,r),u=dr(()=>({...n,...s,...r||{}}),[n,s,r]),y=dr(()=>(b,l)=>{let f=ft(u,b);return f==null&&(f=b),l&&typeof f=="string"&&Object.entries(l).forEach(([c,w])=>{f=f.replace(new RegExp(`{{${c}}}`,"g"),w)}),typeof f=="string"?f:b},[u]),g=dr(()=>({t:y,language:t}),[y,t]);return a?ro("div",{children:"Loading translations..."}):ro(oo.Provider,{value:g,children:e})},Z=()=>{let e=ut(oo);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};import{createContext as pt,useContext as mt,useReducer as ht,useEffect as no}from"react";import{jsx as bt}from"react/jsx-runtime";var io={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function yt(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),i=t.toString()?`?${t.toString()}`:window.location.pathname;try{window.history.replaceState({},"",i)}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,s)=>({...n,[s]: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:io.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 ao=pt(void 0),so=({children:e,initialScreen:r="login",config:o,autoReadFromCookies:t=!0})=>{let[i,n]=ht(yt,{...io,currentScreen:r});no(()=>{n({type:"INIT_CONFIG",payload:(()=>{let f={};if(t)try{let c=Mr("logo");if(c){let w=decodeURIComponent(c);w.startsWith("http")&&(f.logo=w)}}catch(c){x.error("Error reading configuration from cookies",c instanceof Error?c:{message:String(c)})}return{publicApiKey:o?.publicApiKey,env:o?.env,appName:o?.appName,logo:o?.logo||f.logo,loginActions:o?.loginActions}})()})},[o,t]),no(()=>{let l=new URLSearchParams(window.location.search),f={};l.forEach((c,w)=>{f[w]=c}),Object.keys(f).length>0&&n({type:"SET_SEARCH_PARAMS",payload:f}),r==="checkCode"&&f.email&&n({type:"UPDATE_FORM_DATA",payload:{email:f.email,code:f.code||""}}),r==="resetPassword"&&f.link&&n({type:"SET_SEARCH_PARAMS",payload:f})},[r]);let b={state:i,dispatch:n,setScreen:(l,f)=>{n({type:"SET_SCREEN",payload:{screen:l,params:f}})},updateFormData:l=>{n({type:"UPDATE_FORM_DATA",payload:l})},setFieldError:(l,f)=>{n({type:"SET_ERRORS",payload:{[l]:f}})},clearErrors:()=>{n({type:"CLEAR_ERRORS"})},setLoading:l=>{n({type:"SET_LOADING",payload:l})}};return bt(ao.Provider,{value:b,children:e})},Ye=()=>{let e=mt(ao);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};import{useEffect as wt,useRef as xt}from"react";import{Typography as ur,TextField as lo,Button as Ct,Box as Oe,CircularProgress as vt,Alert as Pt,Link as co}from"@mui/material";import{Fragment as Et,jsx as ee,jsxs as Be}from"react/jsx-runtime";var Tt=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:i="/"})=>{let{state:n,updateFormData:s,setFieldError:a,clearErrors:u,setLoading:y}=Ye(),{login:g}=he(),b=Z(),{t:l}=b,f="i18n"in b?b.i18n:void 0,c=xt(null),w=Wr(l,{currentLanguage:f?.language,enableDebug:!1}),m=()=>{if(n.searchParams.redirect)try{let d=decodeURIComponent(n.searchParams.redirect);if(d.startsWith("/")&&!d.startsWith("//"))return d}catch{}return i||"/"};wt(()=>{let d=setTimeout(()=>{c.current&&c.current.focus()},100);return()=>clearTimeout(d)},[]);let p=d=>w.translateError({code:d.code,message:d.message,field:d.field}),h=async()=>{if(!n.loading){if(!n.formData.username.trim()){a("username",l("login.usernameRequired"));return}if(!n.formData.password.trim()){a("password",l("login.passwordRequired"));return}u(),y(!0);try{let d=await g(n.formData.username,n.formData.password);if(y(!1),d.success){let C=m();o&&o(d.data,C)}else{let C=d.rawResponse||d;P(C)}}catch(d){y(!1);let I=Y(d).map(p);a("global",I),t&&t(I.join(", "))}}},P=d=>{let C=Y(d),I=[];C.forEach(A=>{A.field?a(A.field,p(A)):I.push(p(A))}),I.length>0&&a("global",I)};return Be(Et,{children:[Be(Oe,{component:"form",noValidate:!0,onSubmit:d=>{d.preventDefault(),h()},onKeyDown:d=>{d.key==="Enter"&&!n.loading&&(d.preventDefault(),h())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Be(Oe,{sx:{mb:1},children:[ee(ur,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:l("login.usernameOrEmailLabel")}),ee(lo,{fullWidth:!0,id:"email",name:"email",type:"email",value:n.formData.username,disabled:n.loading,onChange:d=>s({username:d.target.value}),error:!!n.errors.username,helperText:n.errors.username,autoComplete:"email",placeholder:l("login.usernameOrEmailPlaceholder"),inputRef:c,required:!0})]}),Be(Oe,{sx:{mb:1},children:[ee(ur,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:l("login.passwordLabel")}),ee(lo,{fullWidth:!0,id:"password",name:"password",type:"password",value:n.formData.password,disabled:n.loading,onChange:d=>s({password:d.target.value}),error:!!n.errors.password,helperText:n.errors.password,autoComplete:"current-password",placeholder:l("login.passwordPlaceholder"),required:!0})]}),n.config.loginActions?.includes("forgotPassword")&&ee(Oe,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:ee(co,{sx:{cursor:"pointer"},onClick:()=>{e?.("forgotPassword",n.searchParams)},variant:"body2",color:"secondary",children:l("login.forgotPasswordLink")})}),ee(Ct,{disabled:n.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:n.loading?ee(vt,{size:20}):l("login.loginButton")})]}),ee(Oe,{children:n.errors.global&&n.errors.global.length>0&&n.errors.global.map((d,C)=>ee(Pt,{variant:"filled",sx:{mt:2},severity:"error",children:ee("div",{children:d})},C))}),n.config.loginActions?.includes("createUser")&&Be(ur,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[l("login.noAccountPrompt")," ",ee(co,{sx:{cursor:"pointer"},onClick:()=>{let C=`/public/users/create${Object.keys(n.searchParams).length>0?`?${new URLSearchParams(n.searchParams).toString()}`:""}`;r?.(C)},fontWeight:"medium",color:"secondary",children:l("login.signUpLink")})]})]})},uo=Tt;import{useState as ke,useEffect as Rt,useRef as St}from"react";import{Typography as Le,TextField as It,Button as go,Box as ye,CircularProgress as kt,Alert as Lt,Link as gr}from"@mui/material";import{Fragment as fo,jsx as M,jsxs as Pe}from"react/jsx-runtime";var At=({onScreenChange:e,onError:r})=>{let{crudify:o}=me(),[t,i]=ke(""),[n,s]=ke(!1),[a,u]=ke([]),[y,g]=ke(null),[b,l]=ke(!1),[f,c]=ke(!1),w=St(null),{t:m}=Z();Rt(()=>{w.current&&!b&&!f&&w.current.focus()},[b,f]);let p=C=>{let I=[`errors.auth.${C.code}`,`errors.data.${C.code}`,`errors.system.${C.code}`,`errors.${C.code}`,`forgotPassword.${C.code.toLowerCase()}`];for(let A of I){let q=m(A);if(q!==A)return q}return C.message||m("base.errors.errorUnknown")},h=C=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(C),P=async()=>{if(!(n||!o)){if(u([]),g(null),!t){g(m("forgotPassword.emailRequired"));return}if(!h(t)){g(m("forgotPassword.invalidEmail"));return}s(!0);try{let C=[{operation:"requestPasswordReset",data:{email:t}}],I=await o.transaction(C);if(I.success)I.data&&I.data.existingCodeValid?c(!0):l(!0);else{let q=Y(I).map(p);u(q)}}catch(C){let A=Y(C).map(p);u(A),r&&r(A.join(", "))}finally{s(!1)}}},S=()=>{e?.("login")},U=()=>{if(b||f){e?.("checkCode",{email:t});return}if(!t){g(m("forgotPassword.emailRequired"));return}if(!h(t)){g(m("forgotPassword.invalidEmail"));return}e?.("checkCode",{email:t})};return b||f?M(fo,{children:Pe(ye,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[Pe(ye,{sx:{mb:2},children:[M(Le,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m(f?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),M(Le,{variant:"body2",sx:{color:f?"success.main":"grey.600"},children:m("forgotPassword.checkEmailInstructions")})]}),M(go,{type:"button",onClick:U,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:m("forgotPassword.enterCodeLink")}),M(ye,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:M(gr,{sx:{cursor:"pointer"},onClick:S,variant:"body2",color:"secondary",children:m("base.btn.back")})})]})}):Pe(fo,{children:[Pe(ye,{component:"form",noValidate:!0,onSubmit:C=>{C.preventDefault(),P()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Pe(ye,{sx:{mb:2},children:[M(Le,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m("forgotPassword.title")}),M(Le,{variant:"body2",sx:{color:"grey.600"},children:m("forgotPassword.instructions")})]}),Pe(ye,{sx:{mb:1},children:[M(Le,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:m("forgotPassword.emailLabel")}),M(It,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:n,onChange:C=>i(C.target.value),error:!!y,helperText:y,autoComplete:"email",placeholder:m("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:w})]}),M(go,{disabled:n,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?M(kt,{size:20}):m("forgotPassword.sendCodeButton")}),Pe(ye,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[M(gr,{sx:{cursor:"pointer"},onClick:S,variant:"body2",color:"secondary",children:m("base.btn.back")}),M(Le,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),M(gr,{sx:{cursor:"pointer"},onClick:U,variant:"body2",color:"secondary",children:m("login.alreadyHaveCodeLink")})]})]}),M(ye,{children:a.length>0&&a.map((C,I)=>M(Lt,{variant:"filled",sx:{mt:2},severity:"error",children:C},I))})]})},po=At;import{useState as J,useEffect as mo}from"react";import{Typography as Xe,TextField as ho,Button as Ft,Box as be,CircularProgress as yo,Alert as bo,Link as Dt}from"@mui/material";import{Fragment as Ot,jsx as H,jsxs as Ne}from"react/jsx-runtime";var _t=({onScreenChange:e,onError:r,searchParams:o,onResetSuccess:t})=>{let{crudify:i}=me(),[n,s]=J(""),[a,u]=J(""),[y,g]=J(!1),[b,l]=J([]),[f,c]=J(null),[w,m]=J(null),[p,h]=J(""),[P,S]=J(""),[U,d]=J(!1),[C,I]=J(!0),[A,q]=J(!1),[re,oe]=J(null),[ce,Re]=J(!1),{t:D}=Z(),j=v=>{let k=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`resetPassword.${v.code.toLowerCase()}`];for(let F of k){let W=D(F);if(W!==F)return W}return v.message||D("base.errors.errorUnknown")},B=v=>o?o instanceof URLSearchParams?o.get(v):o[v]||null:null;mo(()=>{if(o){if(o){let v=B("fromCodeVerification"),k=B("email"),F=B("code");if(v==="true"&&k&&F){h(k),S(F),d(!0),q(!0),I(!1);return}let W=B("link");if(W)try{let G=decodeURIComponent(W),[X,pe]=G.split("/");if(X&&pe&&X.length===6){S(X),h(pe),d(!1),oe({email:pe,code:X});return}}catch{}if(k&&F){h(k),S(F),d(!1),oe({email:k,code:F});return}}l([D("resetPassword.invalidCode")]),I(!1),setTimeout(()=>e?.("forgotPassword"),3e3)}},[o,i,D,e]),mo(()=>{i&&re&&!ce&&(Re(!0),(async(k,F)=>{try{let W=[{operation:"validatePasswordResetCode",data:{email:k,codePassword:F}}],G=await i.transaction(W);if(G.data&&Array.isArray(G.data)){let X=G.data[0];if(X&&X.response&&X.response.status==="OK"){q(!0);return}}if(G.success)q(!0);else{let pe=Y(G).map(j);l(pe),setTimeout(()=>e?.("forgotPassword"),3e3)}}catch(W){let X=Y(W).map(j);l(X),setTimeout(()=>e?.("forgotPassword"),3e3)}finally{I(!1),oe(null),Re(!1)}})(re.email,re.code))},[i,re,D,e]);let de=v=>v.length<8?D("resetPassword.passwordTooShort"):null,R=async()=>{if(y||!i)return;l([]),c(null),m(null);let v=!1;if(!n)c(D("resetPassword.newPasswordRequired")),v=!0;else{let k=de(n);k&&(c(k),v=!0)}if(a?n!==a&&(m(D("resetPassword.passwordsDoNotMatch")),v=!0):(m(D("resetPassword.confirmPasswordRequired")),v=!0),!v){g(!0);try{let k=[{operation:"validateAndResetPassword",data:{email:p,codePassword:P,newPassword:n}}],F=await i.transaction(k);if(F.success)l([]),setTimeout(()=>{t?.()},1e3);else{let G=Y(F).map(j);l(G)}}catch(k){let W=Y(k).map(j);l(W),r&&r(W.join(", "))}g(!1)}},V=()=>{U?e?.("checkCode",{email:p}):e?.("forgotPassword")};return C?H(be,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:H(yo,{})}):A?Ne(Ot,{children:[Ne(be,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Ne(be,{sx:{mb:2},children:[H(Xe,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:D("resetPassword.title")}),H(Xe,{variant:"body2",sx:{color:"grey.600"},children:D("resetPassword.instructions")})]}),Ne(be,{sx:{mb:1},children:[H(Xe,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:D("resetPassword.newPasswordLabel")}),H(ho,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:n,disabled:y,onChange:v=>s(v.target.value),error:!!f,helperText:f,autoComplete:"new-password",placeholder:D("resetPassword.newPasswordPlaceholder"),required:!0})]}),Ne(be,{sx:{mb:1},children:[H(Xe,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:D("resetPassword.confirmPasswordLabel")}),H(ho,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:a,disabled:y,onChange:v=>u(v.target.value),error:!!w,helperText:w,autoComplete:"new-password",placeholder:D("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),H(Ft,{disabled:y,type:"button",onClick:R,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:y?H(yo,{size:20}):D("resetPassword.resetPasswordButton")}),H(be,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:H(Dt,{sx:{cursor:"pointer"},onClick:V,variant:"body2",color:"secondary",children:D("base.btn.back")})})]}),H(be,{children:b.length>0&&b.map((v,k)=>H(bo,{variant:"filled",sx:{mt:2},severity:"error",children:v},k))})]}):H(be,{children:b.length>0&&b.map((v,k)=>H(bo,{variant:"filled",sx:{mt:2},severity:"error",children:v},k))})},wo=_t;import{useState as ze,useEffect as xo,useRef as Bt}from"react";import{Typography as fr,TextField as Nt,Button as zt,Box as Ue,CircularProgress as Ut,Alert as Mt,Link as Vt}from"@mui/material";import{Fragment as Ht,jsx as ae,jsxs as Je}from"react/jsx-runtime";var Wt=({onScreenChange:e,onError:r,searchParams:o})=>{let{crudify:t}=me(),[i,n]=ze(""),[s,a]=ze(!1),[u,y]=ze([]),[g,b]=ze(null),[l,f]=ze(""),c=Bt(null),{t:w}=Z(),m=d=>o?o instanceof URLSearchParams?o.get(d):o[d]||null:null,p=d=>{let C=[`errors.auth.${d.code}`,`errors.data.${d.code}`,`errors.system.${d.code}`,`errors.${d.code}`,`checkCode.${d.code.toLowerCase()}`];for(let I of C){let A=w(I);if(A!==I)return A}return d.message||w("base.errors.errorUnknown")};xo(()=>{let d=m("email");d?f(d):e?.("forgotPassword")},[o,e]),xo(()=>{c.current&&c.current.focus()},[]);let h=async()=>{if(!(s||!t)){if(y([]),b(null),!i){b(w("checkCode.codeRequired"));return}if(i.length!==6){b(w("checkCode.codeRequired"));return}a(!0);try{let d=[{operation:"validatePasswordResetCode",data:{email:l,codePassword:i}}],C=await t.transaction(d);if(C.success)e?.("resetPassword",{email:l,code:i,fromCodeVerification:"true"});else{let A=Y(C).map(p);y(A),a(!1)}}catch(d){let I=Y(d).map(p);y(I),a(!1),r&&r(I.join(", "))}}},P=()=>{e?.("forgotPassword")},S=d=>{let C=d.target.value.replace(/\D/g,"").slice(0,6);n(C)};return Je(Ht,{children:[Je(Ue,{component:"form",noValidate:!0,onSubmit:d=>{d.preventDefault(),h()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Je(Ue,{sx:{mb:2},children:[ae(fr,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:w("checkCode.title")}),ae(fr,{variant:"body2",sx:{color:"grey.600"},children:w("checkCode.instructions")})]}),Je(Ue,{sx:{mb:1},children:[ae(fr,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:w("checkCode.codeLabel")}),ae(Nt,{fullWidth:!0,id:"code",name:"code",type:"text",value:i,disabled:s,onChange:S,error:!!g,helperText:g,placeholder:w("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:c})]}),ae(zt,{disabled:s||i.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:s?ae(Ut,{size:20}):w("checkCode.verifyButton")}),ae(Ue,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:ae(Vt,{sx:{cursor:"pointer"},onClick:P,variant:"body2",color:"secondary",children:w("base.btn.back")})})]}),ae(Ue,{children:u.length>0&&u.map((d,C)=>ae(Mt,{sx:{mt:2},severity:"error",children:d},C))})]})},Co=Wt;import{Box as qt,CircularProgress as jt,Alert as vo,Typography as pr}from"@mui/material";import{Fragment as Kt,jsx as Ae,jsxs as Po}from"react/jsx-runtime";var To=({children:e,fallback:r})=>{let{isLoading:o,error:t,isInitialized:i}=me(),{t:n}=Z();return o?r||Po(qt,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[Ae(jt,{}),Ae(pr,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):t?Ae(vo,{severity:"error",sx:{mt:2},children:Po(pr,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",t]})}):i?Ae(Kt,{children:e}):Ae(vo,{severity:"warning",sx:{mt:2},children:Ae(pr,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as te,jsxs as Jt}from"react/jsx-runtime";var Yt=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:i="/"})=>{let{t:n}=Z(),{state:s,setScreen:a}=Ye(),{config:u}=he(),{showNotification:y}=Hr(),g=(l,f)=>{let c=f;l==="login"?c={}:l==="forgotPassword"&&!f&&(c={}),a(l,c),e?.(l,c)},b=()=>{let l={onScreenChange:g,onExternalNavigate:r,onError:t,redirectUrl:i};switch(s.currentScreen){case"forgotPassword":return te(po,{...l});case"checkCode":return te(Co,{...l,searchParams:s.searchParams});case"resetPassword":return te(wo,{...l,searchParams:s.searchParams,onResetSuccess:()=>{let f=n("resetPassword.successMessage");y(f,"success"),g("login")}});default:return te(uo,{...l,onLoginSuccess:o})}};return Jt(To,{children:[te($t,{sx:{display:"flex",justifyContent:"center",mb:3},children:te("img",{src:u.logo||"https://logos.crudia.com/nocios-default.png",alt:n("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:l=>{let f=l.target;f.src="https://logos.crudia.com/nocios-default.png"}})}),!u.logo&&u.appName&&te(Gt,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:u.appName}),b()]})},Xt=({translations:e,translationsUrl:r,language:o="en",initialScreen:t="login",autoReadFromCookies:i=!0,...n})=>{let{config:s}=he();return te(to,{translations:e,translationsUrl:r,language:o,children:te(qr,{config:s,children:te(so,{config:s,initialScreen:t,autoReadFromCookies:i,children:te(Yt,{...n})})})})},ws=Xt;import{Box as Q,Card as Eo,CardContent as Ro,Typography as ne,Chip as Qe,Avatar as Qt,Divider as Zt,CircularProgress as en,Alert as So,List as rn,ListItem as mr,ListItemText as hr,ListItemIcon as on,Collapse as tn,IconButton as yr}from"@mui/material";import{Person as nn,Email as an,Badge as sn,Security as ln,Schedule as cn,AccountCircle as dn,ExpandMore as un,ExpandLess as gn,Info as fn}from"@mui/icons-material";import{useState as pn}from"react";import{Fragment as yn,jsx as E,jsxs as _}from"react/jsx-runtime";var mn=({showExtendedData:e=!0,showProfileCard:r=!0,autoRefresh:o=!0})=>{let{userProfile:t,loading:i,error:n,extendedData:s,refreshProfile:a}=jr({autoFetch:o,retryOnError:!0,maxRetries:3}),[u,y]=pn(!1);if(i)return _(Q,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[E(en,{}),E(ne,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return _(So,{severity:"error",action:E(yr,{color:"inherit",size:"small",onClick:a,children:E(ne,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!t)return E(So,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let g=s?.displayData||{},b=s?.totalFields||0,l=h=>{if(!h)return"No disponible";try{return new Date(h).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return h}},f=(h,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),c=[{key:"id",label:"ID",icon:E(sn,{})},{key:"email",label:"Email",icon:E(an,{})},{key:"username",label:"Usuario",icon:E(nn,{})},{key:"fullName",label:"Nombre completo",icon:E(dn,{})},{key:"role",label:"Rol",icon:E(ln,{})}],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"}],m=[...c.map(h=>h.key),...w.map(h=>h.key),"permissions"],p=Object.keys(g).filter(h=>!m.includes(h)).map(h=>({key:h,label:h}));return _(Q,{children:[r&&E(Eo,{sx:{mb:2},children:_(Ro,{children:[_(Q,{display:"flex",alignItems:"center",mb:2,children:[E(Qt,{src:g.avatar,sx:{width:56,height:56,mr:2},children:g.fullName?.[0]||g.username?.[0]||g.email?.[0]}),_(Q,{children:[E(ne,{variant:"h6",children:g.fullName||g.username||g.email}),E(ne,{variant:"body2",color:"text.secondary",children:g.role||"Usuario"}),g.isActive!==void 0&&E(Qe,{label:g.isActive?"Activo":"Inactivo",color:g.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),E(Q,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:c.map(({key:h,label:P,icon:S})=>g[h]?_(Q,{display:"flex",alignItems:"center",children:[E(Q,{sx:{mr:1,color:"text.secondary"},children:S}),_(Q,{children:[E(ne,{variant:"caption",color:"text.secondary",children:P}),E(ne,{variant:"body2",children:f(h,g[h])})]})]},h):null)}),g.permissions&&Array.isArray(g.permissions)&&g.permissions.length>0&&_(Q,{mt:2,children:[E(ne,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),_(Q,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[g.permissions.slice(0,5).map((h,P)=>E(Qe,{label:h,size:"small",variant:"outlined"},P)),g.permissions.length>5&&E(Qe,{label:`+${g.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&E(Eo,{children:_(Ro,{children:[_(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[_(ne,{variant:"h6",display:"flex",alignItems:"center",children:[E(fn,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),E(Qe,{label:`${b} campos totales`,size:"small"})]}),_(rn,{dense:!0,children:[w.map(({key:h,label:P})=>g[h]!==void 0&&_(mr,{divider:!0,children:[E(on,{children:E(cn,{fontSize:"small"})}),E(hr,{primary:P,secondary:h.includes("At")||h.includes("Login")?l(g[h]):f(h,g[h])})]},h)),p.length>0&&_(yn,{children:[E(Zt,{sx:{my:1}}),E(mr,{children:E(hr,{primary:_(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[_(ne,{variant:"subtitle2",children:["Campos Personalizados (",p.length,")"]}),E(yr,{size:"small",onClick:()=>y(!u),children:u?E(gn,{}):E(un,{})})]})})}),E(tn,{in:u,children:p.map(({key:h,label:P})=>E(mr,{sx:{pl:4},children:E(hr,{primary:P,secondary:f(h,g[h])})},h))})]})]}),_(Q,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[_(ne,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",l(g.updatedAt)]}),E(yr,{size:"small",onClick:a,disabled:i,children:E(ne,{variant:"caption",children:"Actualizar"})})]})]})})]})},hn=mn;var Io=["create","read","update","delete"],ko=["create","read","update","delete"];import{useRef as Mn}from"react";import{useTranslation as Vn}from"react-i18next";import{Box as rr,Typography as Bo,Button as Wn,Stack as Hn,Alert as No,Divider as qn}from"@mui/material";import{Add as jn}from"@mui/icons-material";import{forwardRef as Sn}from"react";import{useTranslation as In}from"react-i18next";import{Box as Te,FormControl as kn,InputLabel as Ln,Select as An,MenuItem as Fn,IconButton as Dn,Typography as Fe,FormHelperText as _n,Stack as er,Paper as Oo,Divider as On,Button as Cr}from"@mui/material";import{Delete as Bn,SelectAll as Nn,ClearAll as zn}from"@mui/icons-material";import{useState as Lo,useEffect as Ao,useRef as Fo}from"react";import{useTranslation as bn}from"react-i18next";import{Box as Ze,Typography as Me,Button as Do,Stack as br,FormControlLabel as wn,FormHelperText as _o,Switch as xn,ToggleButton as wr,ToggleButtonGroup as Cn}from"@mui/material";import{CheckCircle as vn,Cancel as Pn,SelectAll as Tn,ClearAll as En}from"@mui/icons-material";import{jsx as N,jsxs as we}from"react/jsx-runtime";var Rn=({value:e,onChange:r,availableFields:o,error:t,disabled:i=!1})=>{let{t:n}=bn(),[s,a]=Lo("custom"),[u,y]=Lo(!1),g=Fo(null);Ao(()=>{u&&g.current?.scrollIntoView({behavior:"smooth",block:"start"})},[u]);let b=Fo(!1);Ao(()=>{let m=e||{allow:[],owner_allow:[],deny:[]},p=new Set(o),h=(m.allow||[]).filter(d=>p.has(d)),P=(m.owner_allow||[]).filter(d=>p.has(d)),S=(m.deny||[]).filter(d=>p.has(d));o.forEach(d=>{!h.includes(d)&&!P.includes(d)&&!S.includes(d)&&S.push(d)});let U={allow:h,owner_allow:P,deny:S};JSON.stringify(U)!==JSON.stringify(m)&&r(U),h.length===o.length?a("all"):S.length===o.length?a("none"):a("custom")},[o,e]);let l=()=>{b.current=!0,r({allow:[...o],owner_allow:[],deny:[]}),a("all"),setTimeout(()=>{b.current=!1},0)},f=()=>{b.current=!0,r({allow:[],owner_allow:[],deny:[...o]}),a("none"),setTimeout(()=>{b.current=!1},0)},c=m=>e?.allow?.includes(m)?"allow":e?.owner_allow?.includes(m)?"owner_allow":"deny",w=(m,p)=>{b.current=!0;let h=new Set(e?.allow||[]),P=new Set(e?.owner_allow||[]),S=new Set(e?.deny||[]);h.delete(m),P.delete(m),S.delete(m),p==="allow"&&h.add(m),p==="owner_allow"&&P.add(m),p==="deny"&&S.add(m),r({allow:Array.from(h),owner_allow:Array.from(P),deny:Array.from(S)}),a("custom"),setTimeout(()=>{b.current=!1},0)};return o.length===0?we(Ze,{children:[N(Me,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("publicPolicies.fields.conditions.label")}),N(Me,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("publicPolicies.fields.conditions.noFieldsAvailable")}),t&&N(_o,{error:!0,sx:{mt:1},children:t})]}):we(Ze,{children:[N(Me,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("publicPolicies.fields.conditions.label")}),we(br,{direction:"row",spacing:1,alignItems:"center",sx:{mb:u?3:1},children:[N(Do,{variant:s==="all"?"contained":"outlined",startIcon:N(Tn,{}),onClick:l,disabled:i,size:"small",sx:{minWidth:120,...s==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("publicPolicies.fields.conditions.allFields")}),N(Do,{variant:s==="none"?"contained":"outlined",startIcon:N(En,{}),onClick:f,disabled:i,size:"small",sx:{minWidth:120,...s==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("publicPolicies.fields.conditions.noFields")}),N(Ze,{sx:{display:"flex",alignItems:"center",px:1.5,py:.35,borderRadius:"999px",backgroundColor:"#f3f4f6",border:"1px solid #d1d9e0"},children:N(wn,{control:N(xn,{size:"small",checked:u,onChange:()=>y(m=>!m),disabled:i,color:"primary",sx:{transform:"scale(1.15)",transformOrigin:"center",m:0}}),label:n("publicPolicies.fields.conditions.customEdit"),labelPlacement:"end",sx:{ml:0,".MuiFormControlLabel-label":{fontSize:"0.75rem"}}})})]}),u&&we(Ze,{ref:g,sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[N(Me,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("publicPolicies.fields.conditions.help")}),N(br,{spacing:1,children:o.map(m=>{let p=c(m);return we(br,{direction:"row",spacing:1,alignItems:"center",children:[N(Me,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:m}),we(Cn,{value:p,exclusive:!0,size:"small",children:[we(wr,{value:"allow",onClick:()=>w(m,"allow"),disabled:i,sx:{px:2,color:p==="allow"?"#ffffff":"#6b7280",backgroundColor:p==="allow"?"#16a34a":"#f3f4f6",borderColor:p==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:p==="allow"?"#15803d":"#e5e7eb",borderColor:p==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[N(vn,{sx:{fontSize:16,mr:.5}}),n("publicPolicies.fields.conditions.states.allow")]}),N(wr,{value:"owner_allow",onClick:()=>w(m,"owner_allow"),disabled:i,sx:{px:2,color:p==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:p==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:p==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:p==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:p==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("publicPolicies.fields.conditions.states.ownerAllow")}),we(wr,{value:"deny",onClick:()=>w(m,"deny"),disabled:i,sx:{px:2,color:p==="deny"?"#ffffff":"#6b7280",backgroundColor:p==="deny"?"#dc2626":"#f3f4f6",borderColor:p==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:p==="deny"?"#b91c1c":"#e5e7eb",borderColor:p==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[N(Pn,{sx:{fontSize:16,mr:.5}}),n("publicPolicies.fields.conditions.states.deny")]})]})]},m)})})]}),t&&N(_o,{error:!0,sx:{mt:1},children:t})]})},xr=Rn;import{jsx as z,jsxs as K}from"react/jsx-runtime";var Un=Sn(({policy:e,onChange:r,onRemove:o,availableFields:t,isSubmitting:i=!1,usedActions:n,error:s},a)=>{let{t:u}=In(),y=new Set(Array.from(n||[]));y.delete(e.action);let g=Io.map(b=>({value:b,label:u(`publicPolicies.fields.action.options.${b}`)}));return K(Oo,{ref:a,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[K(Te,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[z(Fe,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:u("publicPolicies.policyTitle")}),z(Dn,{onClick:o,size:"small",disabled:i,"aria-label":u("publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:z(Bn,{})})]}),K(er,{spacing:1,children:[z(er,{direction:{xs:"column",md:"row"},spacing:2,children:z(Te,{sx:{flex:1,minWidth:200},children:K(kn,{fullWidth:!0,children:[z(Ln,{children:u("publicPolicies.fields.action.label")}),z(An,{value:e.action,label:u("publicPolicies.fields.action.label"),disabled:i,onChange:b=>{let l=b.target.value,f={...e,action:l};l==="delete"?(f.permission="deny",delete f.fields):(f.fields={allow:[],owner_allow:[],deny:t},delete f.permission),r(f)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:g.map(b=>{let l=y.has(b.value);return z(Fn,{value:b.value,disabled:l,children:b.label},b.value)})}),s&&z(_n,{error:!0,children:s})]})})}),e.action==="delete"?K(Te,{children:[z(Fe,{variant:"body2",color:"text.secondary",sx:{mb:2},children:u("publicPolicies.fields.conditions.label")}),K(er,{direction:"row",spacing:1,sx:{mb:1},children:[z(Cr,{variant:e.permission==="*"?"contained":"outlined",startIcon:z(Nn,{}),onClick:()=>r({...e,permission:"*"}),disabled:i,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:u("publicPolicies.fields.conditions.allFields")}),z(Cr,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>r({...e,permission:"owner"}),disabled:i,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:u("publicPolicies.fields.conditions.states.ownerAllow")}),z(Cr,{variant:e.permission==="deny"?"contained":"outlined",startIcon:z(zn,{}),onClick:()=>r({...e,permission:"deny"}),disabled:i,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:u("publicPolicies.fields.conditions.noFields")})]})]}):z(xr,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:b=>r({...e,fields:b}),availableFields:t,disabled:i}),z(Oo,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?K(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[K(Te,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[u("publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):K(er,{spacing:.5,divider:z(On,{sx:{borderColor:"#e5e7eb"}}),children:[K(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[K(Te,{component:"span",sx:{color:"#16a34a"},children:[u("publicPolicies.fields.conditions.states.allow"),":"]})," ",(e?.fields?.allow||[]).join(", ")||"-"]}),K(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[K(Te,{component:"span",sx:{color:"#0ea5e9"},children:[u("publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(e?.fields?.owner_allow||[]).join(", ")||"-"]}),K(Fe,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[K(Te,{component:"span",sx:{color:"#dc2626"},children:[u("publicPolicies.fields.conditions.states.deny"),":"]})," ",(e?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),vr=Un;import{Fragment as Gn,jsx as se,jsxs as or}from"react/jsx-runtime";var Kn=()=>typeof globalThis<"u"&&globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`,$n=({policies:e,onChange:r,availableFields:o,errors:t,isSubmitting:i=!1})=>{let{t:n}=Vn(),s=Mn({}),a=new Set((e||[]).map(c=>c.action).filter(Boolean)),u=ko.filter(c=>!a.has(c)),y=u.length>0,g=()=>{let c=u[0]||"create",w={id:Kn(),action:c};c==="delete"?w.permission="deny":w.fields={allow:[],owner_allow:[],deny:o};let m=[...e||[],w];r(m),setTimeout(()=>{let p=m.length-1,h=s.current[p];h&&h.scrollIntoView({behavior:"smooth",block:"center"})},100)},b=c=>{let w=[...e];w.splice(c,1),r(w)},l=(()=>{if(!t)return null;if(typeof t=="string")return t;let c=t._error;return typeof c=="string"?c:null})(),f=new Set((e||[]).map(c=>c.action));return or(Gn,{children:[se(qn,{sx:{borderColor:"#e0e4e7"}}),or(rr,{children:[se(rr,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:or(rr,{children:[se(Bo,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("publicPolicies.title")}),se(Bo,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("publicPolicies.description")})]})}),l&&se(No,{severity:"error",sx:{mb:3},children:l}),or(Hn,{spacing:3,children:[(e||[]).length===0?se(No,{severity:"info",children:n("publicPolicies.noPolicies")}):e.map((c,w)=>se(vr,{ref:m=>{s.current[w]=m},policy:c,onChange:m=>{let p=[...e];p[w]=m,r(p)},onRemove:()=>b(w),availableFields:o,isSubmitting:i,usedActions:f,error:typeof t=="object"&&t!==null&&!("_error"in t)&&c.id in t?t[c.id]:void 0},c.id)),y&&se(rr,{children:se(Wn,{type:"button",variant:"outlined",startIcon:se(jn,{}),onClick:g,disabled:i,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("publicPolicies.addPolicy")})})]})]})]})},tl=$n;import{useState as Pr}from"react";import{Button as tr,TextField as zo,Box as De,Alert as Ve,Typography as xe,CircularProgress as Tr}from"@mui/material";import{jsx as O,jsxs as ge}from"react/jsx-runtime";function dl(){let[e,r]=Pr(""),[o,t]=Pr(""),[i,n]=Pr(!1),{isAuthenticated:s,isLoading:a,error:u,login:y,logout:g,refreshTokens:b,clearError:l,isExpiringSoon:f,expiresIn:c}=he(),w=async h=>{if(h.preventDefault(),!e||!o)return;(await y(e,o)).success&&(r(""),t(""),n(!1))},m=async()=>{await g()},p=async()=>{await b()};return s?ge(De,{sx:{maxWidth:600,mx:"auto",p:3},children:[O(xe,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),O(Ve,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),ge(De,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[O(xe,{variant:"h6",gutterBottom:!0,children:"Token Status"}),ge(xe,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(c/1e3/60)," minutes"]}),f&&O(Ve,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),ge(De,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[O(tr,{variant:"contained",onClick:p,disabled:a,startIcon:a?O(Tr,{size:16}):null,children:"Refresh Tokens"}),O(tr,{variant:"outlined",color:"error",onClick:m,disabled:a,children:"Logout"})]}),u&&O(Ve,{severity:"error",sx:{mt:2},onClose:l,children:u})]}):ge(De,{sx:{maxWidth:400,mx:"auto",p:3},children:[O(xe,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),O(Ve,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),i?ge("form",{onSubmit:w,children:[O(zo,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:h=>r(h.target.value),margin:"normal",required:!0,autoComplete:"email"}),O(zo,{fullWidth:!0,label:"Password",type:"password",value:o,onChange:h=>t(h.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),O(tr,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:a,startIcon:a?O(Tr,{size:16}):null,sx:{mt:3,mb:2},children:a?"Logging in...":"Login"})]}):O(tr,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),u&&O(Ve,{severity:"error",sx:{mt:2},onClose:l,children:u})]})}function ul(){let{isAuthenticated:e,isLoading:r,isExpiringSoon:o,expiresIn:t}=he();return r?ge(De,{sx:{display:"flex",alignItems:"center",gap:1},children:[O(Tr,{size:16}),O(xe,{variant:"caption",children:"Loading session..."})]}):e?ge(De,{children:[O(xe,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),o&&ge(xe,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):O(xe,{variant:"caption",color:"text.secondary",children:"Not logged in"})}import Yn from"@mui/material/TextField";import Xn from"@mui/material/CircularProgress";import Uo from"@mui/material/InputAdornment";import Jn from"@mui/material/IconButton";import Qn from"@mui/icons-material/Refresh";import{jsx as Ce}from"react/jsx-runtime";var Zn=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),ei=({html:e})=>Ce("span",{dangerouslySetInnerHTML:{__html:Zn(e)}}),xl=({config:e,value:r,onChange:o,label:t,error:i=!1,helperText:n,readOnly:s=!1,disabled:a=!1})=>{let{value:u,loading:y,error:g,regenerate:b}=Kr(e,{autoFetch:!r,onSuccess:p=>{o?.(p)}}),l=r||u,f=i||!!g,c=g||n,w=f&&c&&(c.toLowerCase().includes("duplicate")||c.toLowerCase().includes("duplicado")||c.toLowerCase().includes("duplicada")||c.toLowerCase().includes("unique")||c.toLowerCase().includes("\xFAnico")||c.toLowerCase().includes("unico")||c.toLowerCase().includes("\xFAnica")||c.toLowerCase().includes("unica")||c.toLowerCase().includes("already exists")||c.toLowerCase().includes("ya existe")||c.toLowerCase().includes("e11000"));return Ce(Yn,{label:t,fullWidth:!0,value:l,error:f,helperText:c?Ce(ei,{html:c}):" ",disabled:a,InputProps:{readOnly:!0,startAdornment:y?Ce(Uo,{position:"start",children:Ce(Xn,{size:20})}):void 0,endAdornment:w&&!y?Ce(Uo,{position:"end",children:Ce(Jn,{edge:"end",onClick:async()=>{!a&&!y&&await b()},disabled:a,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:Ce(Qn,{})})}):void 0}})};import Er,{useCallback as fe,useRef as Mo,useState as We}from"react";import Ee from"@mui/material/Box";import ve from"@mui/material/Typography";import Rr from"@mui/material/IconButton";import ri from"@mui/material/LinearProgress";import nr from"@mui/material/CircularProgress";import Wo from"@mui/material/Chip";import oi from"@mui/material/Paper";import ti from"@mui/material/List";import ni from"@mui/material/ListItem";import ii from"@mui/material/ListItemText";import ai from"@mui/material/ListItemSecondaryAction";import si from"@mui/material/FormHelperText";import li from"@mui/material/Dialog";import ci from"@mui/material/DialogTitle";import di from"@mui/material/DialogContent";import ui from"@mui/material/DialogActions";import Vo from"@mui/material/Button";import gi from"@mui/icons-material/CloudUpload";import fi from"@mui/icons-material/InsertDriveFile";import pi from"@mui/icons-material/Image";import mi from"@mui/icons-material/PictureAsPdf";import hi from"@mui/icons-material/Delete";import yi from"@mui/icons-material/Refresh";import bi from"@mui/icons-material/Restore";import wi from"@mui/icons-material/CheckCircle";import xi from"@mui/icons-material/Error";import Ql from"@mui/icons-material/BrokenImage";import{jsx as T,jsxs as le}from"react/jsx-runtime";var Ci=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),vi=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]}`},Pi=e=>e.startsWith("image/")?T(pi,{color:"primary"}):e==="application/pdf"?T(mi,{color:"error"}):T(fi,{color:"action"}),Ti=(e,r)=>{switch(e){case"completed":return T(wi,{color:"success",fontSize:"small"});case"error":return T(xi,{color:"error",fontSize:"small"});case"uploading":case"pending":return T(nr,{size:16});case"removing":return T(nr,{size:16,color:"error"});case"pendingDeletion":return T(Wo,{label:r("base.file.pendingDeletion"),size:"small",color:"warning",variant:"outlined",sx:{fontSize:"0.65rem",height:20}});default:return null}},Ei=({file:e,baseUrl:r,disabled:o,onRemove:t,onRestore:i,onRetry:n})=>{let{t:s}=_e(),[a,u]=We(!1),y=e.status==="pendingDeletion",g=!o&&e.status!=="uploading"&&e.status!=="removing"&&!y,b=!o&&y,l=!o&&e.status==="error"&&e.file,f=e.contentType.startsWith("image/"),c=e.visibility==="public"||e.filePath?.startsWith("public/")||e.filePath?.startsWith(r),m=!e.filePath||!c?null:e.filePath.startsWith("http://")||e.filePath.startsWith("https://")||e.filePath.startsWith(r)?e.filePath:`${r}${e.filePath}`,p=e.status==="completed"&&m,h=()=>f&&p&&!a?T(Ee,{component:p?"a":"div",href:m||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:p?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,"&:hover":p?{borderColor:"primary.main",transform:"scale(1.05)"}:{}},children:T("img",{src:m,alt:e.name,style:{width:"100%",height:"100%",objectFit:"cover"},onError:()=>u(!0)})}):T(Ee,{component:p?"a":"div",href:m||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:p?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,textDecoration:"none","&:hover":p?{borderColor:"primary.main",bgcolor:"action.hover"}:{}},children:Pi(e.contentType)});return le(ni,{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:[h(),T(ii,{primary:le(Ee,{sx:{display:"flex",alignItems:"center",gap:1},children:[T(ve,{variant:"body2",noWrap:!0,sx:{maxWidth:200,overflow:"hidden",textOverflow:"ellipsis",textDecoration:y?"line-through":"none",opacity:y?.6:1},children:e.name}),Ti(e.status,s)]}),secondary:le(Ee,{sx:{opacity:y?.6:1},children:[e.size>0&&T(ve,{variant:"caption",color:"text.secondary",children:vi(e.size)}),e.status==="uploading"&&T(ri,{variant:"determinate",value:e.progress,sx:{mt:.5,height:4,borderRadius:2}}),e.status==="error"&&e.errorMessage&&T(ve,{variant:"caption",color:"error",display:"block",children:e.errorMessage}),p&&T(ve,{variant:"caption",color:"primary",display:"block",component:"a",href:m||void 0,target:"_blank",rel:"noopener noreferrer",sx:{cursor:"pointer",textDecoration:"underline","&:hover":{textDecoration:"none"}},children:s(f?"base.file.clickToPreview":"base.file.clickToDownload")})]})}),le(ai,{children:[l&&T(Rr,{edge:"end",size:"small",onClick:()=>n(e.id),color:"primary",title:s("base.file.restore"),children:T(yi,{fontSize:"small"})}),b&&T(Rr,{edge:"end",size:"small",onClick:()=>i(e.id),color:"primary",title:s("base.file.restore"),children:T(bi,{fontSize:"small"})}),g&&T(Rr,{edge:"end",size:"small",onClick:()=>t(e.id),color:"error",title:s("base.file.delete"),children:T(hi,{fontSize:"small"})})]})]})};var rc=({label:e,accept:r,maxFileSize:o=10*1024*1024,multiple:t=!1,maxFiles:i,minFiles:n=0,required:s=!1,disabled:a=!1,error:u=!1,helperText:y,onChange:g,onValidation:b,initialFiles:l,placeholder:f,showFileList:c=!0,visibility:w="private",showPreview:m=!0,baseUrl:p,onDeletionHandlersReady:h,mode:P="create"})=>{let{t:S}=_e(),U=Mo(null),[d,C]=We(!1),[I,A]=We(!1),[q,re]=We(null),[oe,ce]=We(!1),Re=t?i:1,D=s?Math.max(n,1):n,j={acceptedTypes:r,maxFileSize:o,maxFiles:Re,minFiles:D,visibility:w,mode:P,onFilesChange:L=>{let ie=L.filter(qe=>qe.status==="completed"&&qe.filePath).map(qe=>{let Se=qe.filePath;return Se.startsWith(p)||Se.startsWith("http://")||Se.startsWith("https://")?Se:p?`${p}${Se}`:Se});g?.(ie)}},{files:B,isUploading:de,addFiles:R,removeFile:V,restoreFile:v,retryUpload:k,isValid:F,validationError:W,validationErrorKey:G,validationErrorParams:X,initializeFiles:pe,isTouched:Ki,markAsTouched:He,isSubmitted:Ko,markAsSubmitted:Ir,getPreviewUrl:$i,commitDeletions:kr,restorePendingDeletions:Lr,hasPendingDeletions:Ar,deleteFileImmediately:Fr,activeFiles:Gi,activeFileCount:$o,waitForUploads:Dr,completedFilePaths:_r}=$r(j),Or=fe(()=>_r,[_r]),Br=Mo(!1);Er.useEffect(()=>{l&&l.length>0&&!Br.current&&(Br.current=!0,pe(l,p))},[l,pe,p]),Er.useEffect(()=>{b?.(F,W)},[F,W,b]),Er.useEffect(()=>{h?.({commitDeletions:kr,restorePendingDeletions:Lr,hasPendingDeletions:Ar,markAsSubmitted:Ir,isValid:F,isUploading:de,waitForUploads:Dr,getCompletedFilePaths:Or})},[h,kr,Lr,Ar,Ir,F,de,Dr,Or]);let Go=fe(L=>{He();let ie=L.target.files;ie&&ie.length>0&&R(ie),U.current&&(U.current.value="")},[R,He]),Yo=fe(()=>{a||U.current?.click()},[a]),Xo=fe(L=>{L.preventDefault(),L.stopPropagation(),a||C(!0)},[a]),Jo=fe(L=>{L.preventDefault(),L.stopPropagation(),C(!1)},[]),Qo=fe(L=>{if(L.preventDefault(),L.stopPropagation(),C(!1),a)return;He();let ie=L.dataTransfer.files;ie&&ie.length>0&&R(ie)},[a,R,He]),Zo=fe(async L=>{(await V(L)).needsConfirmation&&(re(L),A(!0))},[V]),et=fe(async()=>{if(q){ce(!0);try{let L=await Fr(q);L.success||x.error("Error deleting file",{error:L.error})}finally{ce(!1),A(!1),re(null)}}},[q,Fr]),Nr=fe(()=>{A(!1),re(null)},[]),rt=r?.join(",")||"",ot=!a&&(t||$o===0),zr=Ko&&!F,ar=u||zr,Ur=y||(zr&&G?S(G,X):null);return le(Ee,{sx:{width:"100%"},children:[e&&le(ve,{variant:"body2",sx:{mb:1,fontWeight:500,color:ar?"error.main":"text.primary"},children:[e,s&&T("span",{style:{color:"red"},children:" *"})]}),T("input",{ref:U,type:"file",accept:rt,multiple:t,onChange:Go,disabled:a,style:{display:"none"}}),ot&&le(oi,{variant:"outlined",onClick:Yo,onDragOver:Xo,onDragLeave:Jo,onDrop:Qo,sx:{p:3,textAlign:"center",cursor:a?"not-allowed":"pointer",borderStyle:"dashed",borderWidth:2,borderColor:d?"primary.main":ar?"error.main":"divider",bgcolor:d?"primary.lighter":a?"action.disabledBackground":"background.paper",transition:"all 0.2s ease","&:hover":a?{}:{borderColor:"primary.main",bgcolor:"action.hover"}},children:[T(gi,{sx:{fontSize:48,color:d?"primary.main":a?"action.disabled":"action.active",mb:1}}),T(ve,{variant:"body2",color:a?"text.disabled":"text.secondary",children:f||S(d?"base.file.dropHere":"base.file.dragOrClick")}),r&&r.length>0&&!d&&T(Ee,{sx:{mt:1,display:"flex",gap:.5,justifyContent:"center",flexWrap:"wrap"},children:r.map(L=>T(Wo,{label:L.split("/")[1]?.toUpperCase()||L,size:"small",variant:"outlined",sx:{fontSize:"0.7rem"}},L))})]}),c&&B.length>0&&T(ti,{dense:!0,sx:{mt:1,p:0},children:B.map(L=>T(Ei,{file:L,baseUrl:p,disabled:a,onRemove:Zo,onRestore:v,onRetry:k},L.id))}),de&&le(Ee,{sx:{display:"flex",alignItems:"center",gap:1,mt:1},children:[T(nr,{size:16}),T(ve,{variant:"caption",color:"text.secondary",children:S("base.file.uploading")})]}),Ur&&T(si,{error:ar,sx:{mt:.5},dangerouslySetInnerHTML:{__html:Ci(Ur)}}),le(li,{open:I,onClose:oe?void 0:Nr,children:[T(ci,{children:S("base.file.confirmDelete.title")}),T(di,{children:T(ve,{children:S("base.file.confirmDelete.message")})}),le(ui,{children:[T(Vo,{onClick:Nr,disabled:oe,children:S("base.file.confirmDelete.cancel")}),T(Vo,{onClick:et,color:"error",variant:"contained",disabled:oe,startIcon:oe?T(nr,{size:16,color:"inherit"}):void 0,children:S(oe?"base.file.deleting":"base.file.confirmDelete.confirm")})]})]})]})};import{useCallback as Ri,useRef as Si,useEffect as Ii}from"react";import Ho from"@mui/material/Box";import qo from"@mui/material/Typography";import jo from"@mui/material/FormHelperText";import{MDXEditor as ki,headingsPlugin as Li,listsPlugin as Ai,quotePlugin as Fi,thematicBreakPlugin as Di,markdownShortcutPlugin as _i,linkPlugin as Oi,linkDialogPlugin as Bi,tablePlugin as Ni,toolbarPlugin as zi,UndoRedo as Ui,BoldItalicUnderlineToggles as Mi,BlockTypeSelect as Vi,CreateLink as Wi,InsertTable as Hi,ListsToggle as qi,Separator as ir}from"@mdxeditor/editor";import"@mdxeditor/editor/style.css";import{Fragment as ji,jsx as $,jsxs as Sr}from"react/jsx-runtime";var uc=({label:e,value:r="",onChange:o,required:t=!1,disabled:i=!1,error:n=!1,helperText:s,placeholder:a="Write here...",minHeight:u=200,maxHeight:y=500})=>{let g=Si(null);Ii(()=>{g.current&&g.current.getMarkdown()!==r&&g.current.setMarkdown(r||"")},[r]);let b=Ri(l=>{o?.(l)},[o]);return Sr(Ho,{sx:{width:"100%"},children:[e&&Sr(qo,{component:"label",sx:{display:"block",mb:.5,fontSize:"0.875rem",fontWeight:500,color:n?"error.main":"text.primary"},children:[e,t&&$(qo,{component:"span",color:"error.main",sx:{ml:.5},children:"*"})]}),$(Ho,{sx:{border:1,borderColor:n?"error.main":"divider",borderRadius:1,overflow:"hidden",opacity:i?.6:1,pointerEvents:i?"none":"auto","& .mdxeditor":{minHeight:u,maxHeight:y,overflow:"auto"},"& .mdxeditor-toolbar":{borderBottom:1,borderColor:"divider",backgroundColor:"background.default"},"& .mdxeditor-root-contenteditable":{padding:2,minHeight:u-50}},children:$(ki,{ref:g,markdown:r||"",onChange:b,placeholder:a,readOnly:i,plugins:[Li(),Ai(),Fi(),Di(),_i(),Oi(),Bi(),Ni(),zi({toolbarContents:()=>Sr(ji,{children:[$(Ui,{}),$(ir,{}),$(Mi,{}),$(ir,{}),$(Vi,{}),$(ir,{}),$(qi,{}),$(ir,{}),$(Wi,{}),$(Hi,{})]})})]})}),s&&$(jo,{error:n,sx:{mx:0,mt:.5},children:s}),!s&&$(jo,{sx:{mx:0,mt:.5},children:"\xA0"})]})};export{ue as a,Xi as b,Ji as c,sr as d,Ke as e,ca as f,_e as g,ws as h,hn as i,Io as j,ko as k,tl as l,dl as m,ul as n,xl as o,rc as p,uc as q};
|
|
@@ -1 +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 r={INVALID_CREDENTIALS:"INVALID_CREDENTIALS",UNAUTHORIZED:"UNAUTHORIZED",INVALID_API_KEY:"INVALID_API_KEY",USER_NOT_FOUND:"USER_NOT_FOUND",USER_NOT_ACTIVE:"USER_NOT_ACTIVE",NO_PERMISSION:"NO_PERMISSION",ITEM_NOT_FOUND:"ITEM_NOT_FOUND",NOT_FOUND:"NOT_FOUND",IN_USE:"IN_USE",FIELD_ERROR:"FIELD_ERROR",BAD_REQUEST:"BAD_REQUEST",INVALID_EMAIL:"INVALID_EMAIL",INVALID_CODE:"INVALID_CODE",INTERNAL_SERVER_ERROR:"INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"INVALID_CONFIGURATION",UNKNOWN_OPERATION:"UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"TOO_MANY_REQUESTS",NETWORK_ERROR:"NETWORK_ERROR",TIMEOUT_ERROR:"TIMEOUT_ERROR"},O= exports.b ={[r.INVALID_CREDENTIALS]:"warning",[r.UNAUTHORIZED]:"warning",[r.INVALID_API_KEY]:"error",[r.USER_NOT_FOUND]:"warning",[r.USER_NOT_ACTIVE]:"warning",[r.NO_PERMISSION]:"warning",[r.ITEM_NOT_FOUND]:"info",[r.NOT_FOUND]:"info",[r.IN_USE]:"warning",[r.FIELD_ERROR]:"warning",[r.BAD_REQUEST]:"warning",[r.INVALID_EMAIL]:"warning",[r.INVALID_CODE]:"warning",[r.INTERNAL_SERVER_ERROR]:"error",[r.DATABASE_CONNECTION_ERROR]:"error",[r.INVALID_CONFIGURATION]:"error",[r.UNKNOWN_OPERATION]:"error",[r.TOO_MANY_REQUESTS]:"warning",[r.NETWORK_ERROR]:"error",[r.TIMEOUT_ERROR]:"error"};function _(e){let o=[];try{let
|
|
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 r={INVALID_CREDENTIALS:"INVALID_CREDENTIALS",UNAUTHORIZED:"UNAUTHORIZED",INVALID_API_KEY:"INVALID_API_KEY",USER_NOT_FOUND:"USER_NOT_FOUND",USER_NOT_ACTIVE:"USER_NOT_ACTIVE",NO_PERMISSION:"NO_PERMISSION",ITEM_NOT_FOUND:"ITEM_NOT_FOUND",NOT_FOUND:"NOT_FOUND",IN_USE:"IN_USE",FIELD_ERROR:"FIELD_ERROR",BAD_REQUEST:"BAD_REQUEST",INVALID_EMAIL:"INVALID_EMAIL",INVALID_CODE:"INVALID_CODE",INTERNAL_SERVER_ERROR:"INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"INVALID_CONFIGURATION",UNKNOWN_OPERATION:"UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"TOO_MANY_REQUESTS",NETWORK_ERROR:"NETWORK_ERROR",TIMEOUT_ERROR:"TIMEOUT_ERROR"},O= exports.b ={[r.INVALID_CREDENTIALS]:"warning",[r.UNAUTHORIZED]:"warning",[r.INVALID_API_KEY]:"error",[r.USER_NOT_FOUND]:"warning",[r.USER_NOT_ACTIVE]:"warning",[r.NO_PERMISSION]:"warning",[r.ITEM_NOT_FOUND]:"info",[r.NOT_FOUND]:"info",[r.IN_USE]:"warning",[r.FIELD_ERROR]:"warning",[r.BAD_REQUEST]:"warning",[r.INVALID_EMAIL]:"warning",[r.INVALID_CODE]:"warning",[r.INTERNAL_SERVER_ERROR]:"error",[r.DATABASE_CONNECTION_ERROR]:"error",[r.INVALID_CONFIGURATION]:"error",[r.UNKNOWN_OPERATION]:"error",[r.TOO_MANY_REQUESTS]:"warning",[r.NETWORK_ERROR]:"error",[r.TIMEOUT_ERROR]:"error"};function _(e){let o=[];try{let s=e;if(s.data&&typeof s.data=="object"){let a=s.data;if(a.response){let{status:t,fieldsWarning:R}=a.response;if(R&&typeof R=="object"&&Object.entries(R).forEach(([n,E])=>{Array.isArray(E)&&E.length>0&&o.push({code:r.FIELD_ERROR,message:E[0],severity:"warning",field:n})}),t&&typeof t=="string"){let n=t;O[n]&&o.push({code:n,message:i(n),severity:O[n]})}}}if(s.errors){if(typeof s.errors=="string")o.push({code:r.BAD_REQUEST,message:s.errors,severity:"warning"});else if(typeof s.errors=="object"){let a=s.errors;Object.entries(a).forEach(([t,R])=>{Array.isArray(R)&&R.length>0&&(t==="_error"?R.forEach(n=>{let E=typeof n=="string"&&N(n)?n:r.BAD_REQUEST;o.push({code:E,message:typeof n=="string"?n:i(E),severity:O[E]||"warning"})}):t==="_graphql"?R.forEach(n=>{if(typeof n=="string"){let E=N(n)?n:r.BAD_REQUEST;o.push({code:E,message:i(E),severity:O[E]||"warning"})}}):o.push({code:r.FIELD_ERROR,message:typeof R[0]=="string"?R[0]:"Validation error",severity:"warning",field:t}))})}}o.length===0&&s.success===!1&&o.push({code:r.BAD_REQUEST,message:"Request failed",severity:"warning"})}catch(s){o.push({code:r.INTERNAL_SERVER_ERROR,message:"Failed to parse error response",severity:"error",details:{originalError:s}})}return o.length>0?o:[{code:r.INTERNAL_SERVER_ERROR,message:"Unknown error occurred",severity:"error"}]}function I(e){try{let o=e;if(o.data&&Array.isArray(o.data)){let s=[];return o.data.forEach((a,t)=>{_optionalChain([a, 'access', _2 => _2.response, 'optionalAccess', _3 => _3.status])==="TOO_MANY_REQUESTS"?s.push({code:r.TOO_MANY_REQUESTS,message:i(r.TOO_MANY_REQUESTS),severity:"warning",details:{transactionIndex:t}}):(!a.response||a.response.status!=="OK")&&s.push({code:r.BAD_REQUEST,message:"Transaction failed",severity:"warning",details:{transactionIndex:t,response:a.response}})}),s}return _(e)}catch(o){return[{code:r.INTERNAL_SERVER_ERROR,message:"Failed to parse transaction error",severity:"error",details:{originalError:o}}]}}function N(e){return Object.values(r).includes(e)}function i(e){return{[r.INVALID_CREDENTIALS]:"Invalid email or password",[r.UNAUTHORIZED]:"You are not authorized to perform this action",[r.INVALID_API_KEY]:"Invalid API key",[r.USER_NOT_FOUND]:"User not found",[r.USER_NOT_ACTIVE]:"User account is not active",[r.NO_PERMISSION]:"You do not have permission to perform this action",[r.ITEM_NOT_FOUND]:"Item not found",[r.NOT_FOUND]:"Resource not found",[r.IN_USE]:"Resource is currently in use",[r.FIELD_ERROR]:"Validation error",[r.BAD_REQUEST]:"Invalid request",[r.INVALID_EMAIL]:"Please enter a valid email address",[r.INVALID_CODE]:"Invalid or expired code",[r.INTERNAL_SERVER_ERROR]:"Internal server error",[r.DATABASE_CONNECTION_ERROR]:"Database connection error",[r.INVALID_CONFIGURATION]:"Invalid configuration",[r.UNKNOWN_OPERATION]:"Unknown operation",[r.TOO_MANY_REQUESTS]:"Too many requests. Please try again later.",[r.NETWORK_ERROR]:"Network error. Please check your connection.",[r.TIMEOUT_ERROR]:"Request timed out. Please try again."}[e]||"An unknown error occurred"}function c(e){return e instanceof Error?e.name==="AbortError"?{code:r.TIMEOUT_ERROR,message:"Request was cancelled",severity:"info"}:e.message.includes("NetworkError")||e.message.includes("Failed to fetch")?{code:r.NETWORK_ERROR,message:i(r.NETWORK_ERROR),severity:"error"}:{code:r.INTERNAL_SERVER_ERROR,message:e.message||"An unexpected error occurred",severity:"error",details:{originalError:e}}:{code:r.INTERNAL_SERVER_ERROR,message:"An unknown error occurred",severity:"error",details:{originalError:e}}}function d(e){if(e instanceof Error)return[c(e)];if(typeof e=="object"&&e!==null){let o=e;return o.data&&Array.isArray(o.data)?I(e):_(e)}return[{code:r.INTERNAL_SERVER_ERROR,message:"An unknown error occurred",severity:"error",details:{originalError:e}}]}exports.a = r; exports.b = O; exports.c = _; exports.d = I; exports.e = i; exports.f = c; exports.g = d;
|
|
@@ -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 _=[/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 O(n){if(typeof document>"u")return null;let e=document.cookie.match(new RegExp("(^|;)\\s*"+n+"=([^;]+)"));return e?e[2]:null}function k(){if(typeof window<"u"&&window.__CRUDIFY_ENV__)return window.__CRUDIFY_ENV__;let n=O("environment");return n&&["dev","stg","api","prod"].includes(n)?n:"prod"}var b=null,L="CrudifyUI",y=class{constructor(){this.explicitEnv=null;this.explicitEnv=b,this.prefix=L}getEffectiveEnv(){return this.explicitEnv!==null?this.explicitEnv:k()}sanitize(e){let t=e;for(let r of _)t=t.replace(r,"[REDACTED]");return t}sanitizeContext(e){let t={};for(let[r,o]of Object.entries(e))if(o!=null)if(r==="userId"&&typeof o=="string")t[r]=o.length>8?`${o.substring(0,8)}***`:o;else if(r==="email"&&typeof o=="string"){let[a,c]=o.split("@");t[r]=a&&c?`${a.substring(0,3)}***@${c}`:"[REDACTED]"}else typeof o=="string"?t[r]=this.sanitize(o):typeof o=="object"&&o!==null?t[r]=this.sanitizeContext(o):t[r]=o;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,r){if(!this.shouldLog(e))return;let o=this.sanitize(t),a=r?this.sanitizeContext(r):void 0,c={timestamp:new Date().toISOString(),level:e,environment:this.getEffectiveEnv(),service:this.prefix,message:o,...a&&Object.keys(a).length>0&&{context:a}},l=JSON.stringify(c);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 r;t instanceof Error?r={errorName:t.name,errorMessage:t.message,stack:t.stack}:r=t,this.log("error",e,r)}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){if(this.explicitEnv=e,b=e,typeof window<"u"){let t=["dev","stg","api","prod"];window.__CRUDIFY_ENV__=t.includes(e)?e:void 0}}isExplicitlyConfigured(){return this.explicitEnv!==null}},i= exports.a =new y;var f=n=>{let e=document.cookie.match(new RegExp("(^|;)\\s*"+n+"=([^;]+)"));return e?e[2]:null};function D(n={}){let{publicApiKey:e,env:t,appName:r,logo:o,loginActions:a,featureKeys:c,enableDebug:l=!1}=n,s={configSource:"none"};l&&i.info("[ConfigResolver] Resolving configuration...",{propsApiKey:e?`${e.substring(0,10)}...`:void 0,propsEnv:t,hasPropsAppName:!!r,hasPropsLogo:!!o,propsLoginActions:a,propsFeatureKeys:c});let g=f("publicApiKey");if(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 u=f("environment"),p=f("appName"),C=f("logo"),I=f("loginActions"),N=f("featureKeys"),T=f("theme");return s={publicApiKey:decodeURIComponent(g),env:u&&["dev","stg","api","prod"].includes(u)?u:"prod",appName:p?decodeURIComponent(p):void 0,logo:C?decodeURIComponent(C):void 0,loginActions:I?decodeURIComponent(I).split(",").map(E=>E.trim()).filter(Boolean):void 0,featureKeys:N?decodeURIComponent(N).split(",").map(E=>E.trim()).filter(Boolean):void 0,theme:T?(()=>{try{return JSON.parse(decodeURIComponent(T))}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:r,logo:o,loginActions:a,featureKeys:c,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 Y(n={}){return D(n)}var x=["errors.{category}.{code}","errors.{code}","login.{code}","error.{code}","messages.{code}","{code}"],U={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"},P={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:r,enableDebug:o}=e;o&&i.debug(`[ErrorTranslation] Translating error code: ${n} (lang: ${r||"unknown"})`);let a=n.toUpperCase(),c=U[a],l=x.map(u=>u.replace("{category}",c||"general").replace("{code}",a));o&&i.debug("[ErrorTranslation] Searching keys:",{translationKeys:l});for(let u of l){let p=t(u);if(o&&i.debug(`[ErrorTranslation] Checking key: "${u}" -> result: "${p}" (same as key: ${p===u})`),p&&p!==u)return o&&i.debug(`[ErrorTranslation] Found translation at key: ${u} = "${p}"`),p}let s=P[a];if(s)return o&&i.debug(`[ErrorTranslation] Using default message: "${s}"`),s;let g=a.replace(/_/g," ").toLowerCase().replace(/\b\w/g,u=>u.toUpperCase());return o&&i.debug(`[ErrorTranslation] No translation found, using friendly code: "${g}"`),g}function K(n,e){return n.map(t=>h(t,e))}function F(n,e){let{enableDebug:t}=e;t&&i.debug("[ErrorTranslation] Translating error:",{error:n});let r=h(n.code,e);return r!==n.code.toUpperCase()&&r!==n.code?(t&&i.debug(`[ErrorTranslation] Using hierarchical translation: "${r}"`),n.field?`${n.field}: ${r}`:r):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: "${r}"`),n.field?`${n.field}: ${r}`:r)}function J(n,e={}){let t={translateFn:n,currentLanguage:e.currentLanguage,enableDebug:e.enableDebug||!1};return{translateErrorCode:r=>h(r,t),translateErrorCodes:r=>K(r,t),translateError:r=>F(r,t),translateApiError:r=>_optionalChain([r, 'optionalAccess', _10 => _10.data, 'optionalAccess', _11 => _11.response, 'optionalAccess', _12 => _12.status])?h(r.data.response.status,t):_optionalChain([r, 'optionalAccess', _13 => _13.status])?h(r.status,t):_optionalChain([r, 'optionalAccess', _14 => _14.code])?h(r.code,t):"Unknown error"}}var v=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 r=Date.now();if(this.isHandlingAuthError&&this.lastEventType===e&&r-this.lastErrorTime<this.DEBOUNCE_TIME){i.debug(`AuthEventBus: Ignoring duplicate ${e} event (debounced)`);return}this.isHandlingAuthError=!0,this.lastErrorTime=r,this.lastEventType=e,i.debug(`AuthEventBus: Emitting ${e} event`,t?{details:t}:void 0);let o={type:e,details:t,timestamp:r};this.listeners.forEach(a=>{try{a(o)}catch(c){i.error("AuthEventBus: Error in listener",c instanceof Error?c:{message:String(c)})}}),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.o =v.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 r=e.originalPushState.apply(this,t);return e.notifyListeners(),r},window.history.replaceState=function(...t){let r=e.originalReplaceState.apply(this,t);return e.notifyListeners(),r},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 w=d;var S=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],r=t+"=".repeat((4-t.length%4)%4);return JSON.parse(atob(r))}catch(e){return i.warn("Failed to decode JWT token",e instanceof Error?{errorMessage:e.message}:{message:String(e)}),null}},te= exports.r =()=>{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=S(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}},ne= exports.s =n=>{try{let e=S(n);if(!e||!e.exp)return!0;let t=Math.floor(Date.now()/1e3);return e.exp<t}catch (e2){return!0}};var A="AES-GCM";async function oe(n){let t=new TextEncoder().encode(n),r=await crypto.subtle.digest("SHA-256",t);return Array.from(new Uint8Array(r)).map(a=>a.toString(16).padStart(2,"0")).join("")}async function B(n,e){let t=new TextEncoder,r=await crypto.subtle.importKey("raw",t.encode(n),"PBKDF2",!1,["deriveKey"]);return crypto.subtle.deriveKey({name:"PBKDF2",salt:e.buffer,iterations:1e5,hash:"SHA-256"},r,{name:A,length:256},!1,["encrypt","decrypt"])}async function ie(n,e,t){let r=new TextEncoder,o=crypto.getRandomValues(new Uint8Array(12)),a=await crypto.subtle.encrypt({name:A,iv:o},e,r.encode(n)),c=m(o),l=m(t),s=m(new Uint8Array(a));return`v2:${c}:${l}:${s}`}async function se(n,e){if(!n.startsWith("v2:"))return null;try{let t=n.slice(3).split(":");if(t.length!==3)return null;let[r,o,a]=t,c=R(r),l=R(o),s=R(a),g=await B(e,l),u=await crypto.subtle.decrypt({name:A,iv:c.buffer},g,s.buffer);return new TextDecoder().decode(u)}catch (e3){return null}}function ae(){return crypto.getRandomValues(new Uint8Array(16))}function le(n){return n.startsWith("v2:")}function m(n){let e="";for(let t=0;t<n.length;t++)e+=String.fromCharCode(n[t]);return btoa(e)}function R(n){let e=atob(n),t=new Uint8Array(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}exports.a = i; exports.b = f; exports.c = D; exports.d = Y; exports.e = oe; exports.f = B; exports.g = ie; exports.h = se; exports.i = ae; exports.j = le; exports.k = h; exports.l = K; exports.m = F; exports.n = J; exports.o = j; exports.p = w; exports.q = S; exports.r = te; exports.s = ne;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as n,e as h,f as m,g as p,h as u,i as y,j as l}from"./chunk-6BQGRZYB.mjs";var c="crudify_login_storage_version",d=2,g="crudify_login_encryption_salt",a=class{constructor(t="sessionStorage"){this.encryptionKey=null;this.salt=null;this.initPromise=null;this.initialized=!1;this.storage=t==="localStorage"?window.localStorage:window.sessionStorage}async ensureInitialized(){if(!(this.initialized&&this.encryptionKey)){if(this.initPromise){await this.initPromise;return}this.initPromise=this.initialize(),await this.initPromise}}async initialize(){try{parseInt(this.storage.getItem(c)||"1")<d&&(this.clearLegacyData(),this.storage.setItem(c,d.toString()));let e=this.storage.getItem(g);e&&l(`v2:x:${e}:x`)?this.salt=this.base64ToUint8Array(e):(this.salt=y(),this.storage.setItem(g,this.uint8ArrayToBase64(this.salt)));let i=await this.generateFingerprint();this.encryptionKey=await m(i,this.salt),this.initialized=!0}catch(t){n.error("SecureStorage initialization failed",t instanceof Error?t:{message:String(t)}),this.initialized=!1}}async generateFingerprint(){let t=[navigator.userAgent,navigator.language,new Date().getTimezoneOffset().toString(),screen.colorDepth.toString(),screen.width.toString(),screen.height.toString(),"crudify-login"].join("|");return h(t)}clearLegacyData(){let t=[];for(let e=0;e<this.storage.length;e++){let i=this.storage.key(e);i&&!i.startsWith(c)&&!i.startsWith(g)&&t.push(i)}t.forEach(e=>this.storage.removeItem(e))}async setItem(t,e,i){try{if(await this.ensureInitialized(),!this.encryptionKey||!this.salt){n.error("SecureStorage not properly initialized");return}let r=await p(e,this.encryptionKey,this.salt);if(this.storage.setItem(t,r),i){let o=Date.now()+i*60*1e3;this.storage.setItem(`${t}_expiry`,o.toString())}}catch(r){n.error("Failed to encrypt and store data",r instanceof Error?r:{message:String(r)})}}async getItem(t){try{await this.ensureInitialized();let e=`${t}_expiry`,i=this.storage.getItem(e);if(i){let f=parseInt(i,10);if(Date.now()>f)return this.removeItem(t),null}let r=this.storage.getItem(t);if(!r)return null;if(!l(r))return this.removeItem(t),null;let o=await this.generateFingerprint(),s=await u(r,o);return s||(n.warn("Failed to decrypt stored data - may be corrupted"),this.removeItem(t),null)}catch(e){return n.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`)}clear(){this.storage.clear()}async setToken(t){try{let e=t.split(".");if(e.length===3){let i=JSON.parse(atob(e[1]));if(i.exp){let r=i.exp*1e3,o=Date.now(),s=Math.floor((r-o)/(60*1e3));if(s>0){await this.setItem("authToken",t,s);return}}}}catch{n.warn("Failed to parse token expiry, using default expiry")}await this.setItem("authToken",t,1440)}async getToken(){let t=await this.getItem("authToken");if(t)try{let e=t.split(".");if(e.length===3){let i=JSON.parse(atob(e[1]));if(i.exp){let r=Math.floor(Date.now()/1e3);if(i.exp<r)return this.removeItem("authToken"),null}}}catch{return n.warn("Failed to validate token expiry"),this.removeItem("authToken"),null}return t}async hasValidToken(){return await this.getToken()!==null}async migrateFromLocalStorage(t){let e=window.localStorage.getItem(t);e&&(window.localStorage.removeItem(t),t==="authToken"?await this.setToken(e):await this.setItem(t,e))}uint8ArrayToBase64(t){let e="";for(let i=0;i<t.length;i++)e+=String.fromCharCode(t[i]);return btoa(e)}base64ToUint8Array(t){let e=atob(t),i=new Uint8Array(e.length);for(let r=0;r<e.length;r++)i[r]=e.charCodeAt(r);return i}},I=new a("sessionStorage"),T=new a("localStorage");export{I as a,T as b};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as g,c as de,e as ve,f as Te,g as be,h as Ae,i as Ie,j as ke,k as Se,o as _,p as we,q as xe,r as Pe}from"./chunk-6BQGRZYB.mjs";var Ne="crudify_storage_version",Re=2,a=class a{static setStorageType(i){a.storageType=i}static async initialize(){if(!(a.encryptionKey&&a.salt))return a.initPromise||(a.initPromise=(async()=>{try{a.checkStorageVersion(),a.salt=a.getOrCreateSalt(),a.fingerprint=await a.generateFingerprint(),a.encryptionKey=await Te(a.fingerprint,a.salt)}catch(i){throw g.error("Crudify: Failed to initialize encryption",i instanceof Error?i:{message:String(i)}),i}})()),a.initPromise}static checkStorageVersion(){try{if(parseInt(localStorage.getItem(Ne)||"1",10)<Re){let e=a.getStorage();e&&e.removeItem(a.TOKEN_KEY),localStorage.removeItem(a.ENCRYPTION_KEY_STORAGE),localStorage.removeItem(a.SALT_KEY),localStorage.setItem(Ne,Re.toString()),g.info("Crudify: Storage upgraded to v2, tokens cleared for security")}}catch{}}static getOrCreateSalt(){try{let e=localStorage.getItem(a.SALT_KEY);if(e){let t=atob(e),n=new Uint8Array(t.length);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return n}}catch{}let i=Ie();try{let e="";for(let t=0;t<i.length;t++)e+=String.fromCharCode(i[t]);localStorage.setItem(a.SALT_KEY,btoa(e))}catch{g.warn("Crudify: Cannot persist salt, encryption may not persist across sessions")}return i}static async generateFingerprint(){let i=new Uint8Array(16);crypto.getRandomValues(i);let e=Array.from(i,o=>o.toString(16).padStart(2,"0")).join(""),t=[navigator.userAgent,navigator.language,navigator.platform,screen.width,screen.height,e].join("|");try{let o=localStorage.getItem(a.ENCRYPTION_KEY_STORAGE);if(o&&o.length>=32)return o}catch{}let n=await ve(t);try{localStorage.setItem(a.ENCRYPTION_KEY_STORAGE,n)}catch{g.warn("Crudify: Cannot persist encryption key hash")}return n}static isStorageAvailable(i){try{let e=window[i],t="__storage_test__";return e.setItem(t,"test"),e.removeItem(t),!0}catch{return!1}}static getStorage(){return a.storageType==="none"?null:a.isStorageAvailable(a.storageType)?window[a.storageType]:(g.warn(`Crudify: ${a.storageType} not available, tokens won't persist`),null)}static async encryptData(i){if(await a.initialize(),!a.encryptionKey||!a.salt)throw new Error("Encryption not initialized");return be(i,a.encryptionKey,a.salt)}static async decryptData(i){if(await a.initialize(),!a.fingerprint)throw new Error("Encryption not initialized");return ke(i)?Ae(i,a.fingerprint):(g.warn("Crudify: Legacy encrypted data detected, cannot decrypt"),null)}static async saveTokens(i){let e=a.getStorage();if(e)try{let t={accessToken:i.accessToken,refreshToken:i.refreshToken,expiresAt:i.expiresAt,refreshExpiresAt:i.refreshExpiresAt,savedAt:Date.now()},n=await a.encryptData(JSON.stringify(t));e.setItem(a.TOKEN_KEY,n),g.debug("Crudify: Tokens saved successfully")}catch(t){g.error("Crudify: Failed to save tokens",t instanceof Error?t:{message:String(t)})}}static async getTokens(){let i=a.getStorage();if(!i)return null;try{let e=i.getItem(a.TOKEN_KEY);if(!e)return null;let t=await a.decryptData(e);if(!t)return g.warn("Crudify: Failed to decrypt tokens, clearing storage"),await a.clearTokens(),null;let n=JSON.parse(t);return!n.accessToken||!n.refreshToken||!n.expiresAt||!n.refreshExpiresAt?(g.warn("Crudify: Incomplete token data found, clearing storage"),await a.clearTokens(),null):Date.now()>=n.refreshExpiresAt?(g.info("Crudify: Refresh token expired, clearing storage"),await a.clearTokens(),null):{accessToken:n.accessToken,refreshToken:n.refreshToken,expiresAt:n.expiresAt,refreshExpiresAt:n.refreshExpiresAt}}catch(e){return g.error("Crudify: Failed to retrieve tokens",e instanceof Error?e:{message:String(e)}),await a.clearTokens(),null}}static async clearTokens(){let i=a.getStorage();if(i)try{i.removeItem(a.TOKEN_KEY),g.debug("Crudify: Tokens cleared from storage")}catch(e){g.error("Crudify: Failed to clear tokens",e instanceof Error?e:{message:String(e)})}}static async rotateEncryptionKey(){try{await a.clearTokens(),a.encryptionKey=null,a.salt=null,a.fingerprint=null,a.initPromise=null;try{localStorage.removeItem(a.ENCRYPTION_KEY_STORAGE),localStorage.removeItem(a.SALT_KEY)}catch{}g.info("Crudify: Encryption key rotated successfully")}catch(i){g.error("Crudify: Failed to rotate encryption key",i instanceof Error?i:{message:String(i)})}}static async hasValidTokens(){return await a.getTokens()!==null}static async getExpirationInfo(){let i=await a.getTokens();if(!i)return null;let e=Date.now();return{accessExpired:e>=i.expiresAt,refreshExpired:e>=i.refreshExpiresAt,accessExpiresIn:Math.max(0,i.expiresAt-e),refreshExpiresIn:Math.max(0,i.refreshExpiresAt-e)}}static async updateAccessToken(i,e){let t=await a.getTokens();if(!t){g.warn("Crudify: Cannot update access token, no existing tokens found");return}await a.saveTokens({...t,accessToken:i,expiresAt:e})}static createSyncEvent(i,e,t){return{type:i,tokens:e,hadPreviousTokens:t}}static subscribeToChanges(i){let e=async t=>{if(t.key!==a.TOKEN_KEY)return;let n=t.oldValue!==null&&t.oldValue!=="";if(t.newValue===null){g.debug("Crudify: Tokens removed in another tab"),i(null,a.SYNC_EVENTS.TOKENS_CLEARED,n);return}if(t.newValue){g.debug("Crudify: Tokens updated in another tab");let o=await a.getTokens();i(o,a.SYNC_EVENTS.TOKENS_UPDATED,n)}};return window.addEventListener("storage",e),()=>{window.removeEventListener("storage",e)}}};a.TOKEN_KEY="crudify_tokens",a.ENCRYPTION_KEY_STORAGE="crudify_enc_key",a.SALT_KEY="crudify_enc_salt",a.encryptionKey=null,a.salt=null,a.fingerprint=null,a.storageType="localStorage",a.initPromise=null,a.SYNC_EVENTS={TOKENS_CLEARED:"TOKENS_CLEARED",TOKENS_UPDATED:"TOKENS_UPDATED"};var b=a;import F from"@nocios/crudify-browser";var ee=class r{constructor(){this.config={};this.initialized=!1;this.crudifyInitialized=!1;this.lastActivityTime=0;this.isRefreshingLocally=!1;this.refreshPromise=null}static getInstance(){return r.instance||(r.instance=new r),r.instance}async initialize(i={}){if(!this.initialized){if(this.config={storageType:"localStorage",autoRestore:!0,enableLogging:!1,env:"stg",...i},b.setStorageType(this.config.storageType||"localStorage"),this.config.publicApiKey&&!this.crudifyInitialized&&await this.ensureCrudifyInitialized(),F.setTokenInvalidationCallback(()=>{this.log("Tokens invalidated by crudify-core"),_.emit("SESSION_EXPIRED",{message:"Your session has expired. Please log in again.",source:"crudify-core.clearTokensAndRefreshState"})}),this.config.apiEndpointAdmin&&this.config.apiKeyEndpointAdmin){let e=await b.getTokens();e?await b.saveTokens({...e,apiEndpointAdmin:this.config.apiEndpointAdmin,apiKeyEndpointAdmin:this.config.apiKeyEndpointAdmin}):await b.saveTokens({accessToken:"",refreshToken:"",expiresAt:0,refreshExpiresAt:0,apiEndpointAdmin:this.config.apiEndpointAdmin,apiKeyEndpointAdmin:this.config.apiKeyEndpointAdmin})}this.config.autoRestore&&await this.restoreSession(),this.initialized=!0}}async login(i,e){try{let t=await F.login(i,e);if(!t.success)return{success:!1,error:this.formatError(t.errors),rawResponse:t};let n=await b.getTokens(),o=t.data,m={accessToken:o.token,refreshToken:o.refreshToken,expiresAt:o.expiresAt,refreshExpiresAt:o.refreshExpiresAt,apiEndpointAdmin:n?.apiEndpointAdmin||this.config.apiEndpointAdmin,apiKeyEndpointAdmin:n?.apiKeyEndpointAdmin||this.config.apiKeyEndpointAdmin};return await b.saveTokens(m),this.lastActivityTime=Date.now(),this.config.onLoginSuccess?.(m),{success:!0,tokens:m,data:o}}catch(t){return g.error("[SessionManager] Login error",t instanceof Error?t:{message:String(t)}),{success:!1,error:t instanceof Error?t.message:"Unknown error"}}}async logout(){try{this.log("Logging out..."),await F.logout(),await b.clearTokens(),this.log("Logout successful"),this.config.onLogout?.()}catch(i){this.log("Logout error",{error:i instanceof Error?i.message:String(i)}),await b.clearTokens()}}async restoreSession(){try{this.log("Attempting to restore session...");let i=await b.getTokens();if(!i)return this.log("No valid tokens found in storage"),!1;if(Date.now()>=i.refreshExpiresAt)return this.log("Refresh token expired, clearing storage"),await b.clearTokens(),!1;if(F.setTokens({accessToken:i.accessToken,refreshToken:i.refreshToken,expiresAt:i.expiresAt,refreshExpiresAt:i.refreshExpiresAt}),F.getTokenData().isValid===!1){if(this.log("Restored access token is invalid or expired"),Date.now()<i.refreshExpiresAt&&(this.log("Access token expired but refresh is valid, attempting refresh..."),await this.refreshTokens())){this.log("Session restored successfully via token refresh");let n=await b.getTokens();return n&&this.config.onSessionRestored?.(n),!0}return await b.clearTokens(),await F.logout(),!1}return this.log("Session restored successfully"),this.lastActivityTime=Date.now(),this.config.onSessionRestored?.(i),!0}catch(i){return this.log("Session restore error",{error:i instanceof Error?i.message:String(i)}),await b.clearTokens(),await F.logout(),!1}}async isAuthenticated(){return F.isLogin()||await b.hasValidTokens()}async getTokenInfo(){let i=F.getTokenData(),e=await b.getExpirationInfo(),t=await b.getTokens();return{isLoggedIn:await this.isAuthenticated(),crudifyTokens:i,storageInfo:e,hasValidTokens:await b.hasValidTokens(),apiEndpointAdmin:t?.apiEndpointAdmin,apiKeyEndpointAdmin:t?.apiKeyEndpointAdmin}}async refreshTokens(){if(this.isRefreshingLocally&&this.refreshPromise)return this.log("Refresh already in progress, waiting for existing promise..."),this.refreshPromise;this.isRefreshingLocally=!0,this.refreshPromise=this._performRefresh();try{return await this.refreshPromise}finally{this.isRefreshingLocally=!1,this.refreshPromise=null}}async _performRefresh(){try{this.log("Starting token refresh...");let i=await F.refreshAccessToken();if(!i.success)return this.log("Token refresh failed",{errors:i.errors}),await b.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),!1;let e=i.data,t={accessToken:e.token,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt};return await b.saveTokens(t),this.log("Tokens refreshed and saved successfully"),this.lastActivityTime=Date.now(),!0}catch(i){return this.log("Token refresh error",{error:i instanceof Error?i.message:String(i)}),await b.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),!1}}isRefreshing(){return this.isRefreshingLocally}setupResponseInterceptor(){F.setResponseInterceptor(async i=>{this.updateLastActivity();let e=this.detectAuthorizationError(i);if(e.isAuthError){if(this.log("\u{1F6A8} Authorization error detected:",{errorType:e.errorType,shouldLogout:e.shouldTriggerLogout}),e.isRefreshTokenInvalid||e.isTokenRefreshFailed)return this.log("Refresh token invalid, emitting TOKEN_REFRESH_FAILED event"),_.emit("TOKEN_REFRESH_FAILED",{message:e.userFriendlyMessage,error:e.errorDetails,source:"SessionManager.setupResponseInterceptor"}),i;e.shouldTriggerLogout&&(await b.hasValidTokens()&&!e.isIrrecoverable?(this.log("Access token expired, emitting TOKEN_EXPIRED event"),_.emit("TOKEN_EXPIRED",{message:"Access token expired, refresh needed",error:e.errorDetails,source:"SessionManager.setupResponseInterceptor"})):(this.log("No valid tokens or irrecoverable error, emitting SESSION_EXPIRED event"),_.emit("SESSION_EXPIRED",{message:e.userFriendlyMessage,error:e.errorDetails,source:"SessionManager.setupResponseInterceptor"})))}return i}),this.log("Response interceptor configured (non-blocking mode)")}async ensureCrudifyInitialized(){if(!this.crudifyInitialized)try{this.log("Initializing crudify SDK...");let i=F.getTokenData();if(i&&i.endpoint){this.log("Crudify already initialized by another service"),this.crudifyInitialized=!0;return}let e=this.config.env||"stg";F.config(e);let t=this.config.publicApiKey,n=this.config.enableLogging?"debug":"none",o=await F.init(t,n);if(o&&o.success===!1&&o.errors)throw new Error(`Failed to initialize crudify: ${JSON.stringify(o.errors)}`);this.crudifyInitialized=!0,this.log("Crudify SDK initialized successfully")}catch(i){throw g.error("[SessionManager] Failed to initialize crudify",i instanceof Error?i:{message:String(i)}),i}}detectAuthorizationError(i){let e={isAuthError:!1,isRefreshTokenInvalid:!1,isTokenRefreshFailed:!1,isTokenExpired:!1,isUnauthorized:!1,isIrrecoverable:!1,shouldTriggerLogout:!1,errorType:"",errorDetails:null,userFriendlyMessage:""};if(i.errors&&Array.isArray(i.errors)){let t=i.errors.find(n=>n.errorType==="Unauthorized"||n.message?.includes("Unauthorized")||n.message?.includes("Not Authorized")||n.message?.includes("NOT_AUTHORIZED")||n.message?.includes("Token")||n.message?.includes("TOKEN")||n.message?.includes("Authentication")||n.message?.includes("UNAUTHENTICATED")||n.extensions?.code==="UNAUTHENTICATED"||n.extensions?.code==="FORBIDDEN");t&&(e.isAuthError=!0,e.errorType="GraphQL Array",e.errorDetails=t,e.shouldTriggerLogout=!0,e.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.",(t.message?.includes("TOKEN")||t.message?.includes("Token"))&&(e.isTokenExpired=!0),t.extensions?.code==="UNAUTHENTICATED"&&(e.isUnauthorized=!0))}if(!e.isAuthError&&i.errors&&typeof i.errors=="object"&&!Array.isArray(i.errors)){let n=Object.values(i.errors).flat().find(o=>typeof o=="string"&&(o.includes("NOT_AUTHORIZED")||o.includes("TOKEN_REFRESH_FAILED")||o.includes("TOKEN_HAS_EXPIRED")||o.includes("PLEASE_LOGIN")||o.includes("Unauthorized")||o.includes("UNAUTHENTICATED")||o.includes("SESSION_EXPIRED")||o.includes("INVALID_TOKEN")));n&&typeof n=="string"&&(e.isAuthError=!0,e.errorType="GraphQL Object",e.errorDetails=i.errors,e.shouldTriggerLogout=!0,n.includes("TOKEN_REFRESH_FAILED")?(e.isTokenRefreshFailed=!0,e.isRefreshTokenInvalid=!0,e.isIrrecoverable=!0,e.userFriendlyMessage="Tu sesi\xF3n ha caducado. Por favor, inicia sesi\xF3n nuevamente."):n.includes("TOKEN_HAS_EXPIRED")||n.includes("SESSION_EXPIRED")?(e.isTokenExpired=!0,e.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."):n.includes("INVALID_TOKEN")?(e.isTokenExpired=!0,e.isIrrecoverable=!0,e.userFriendlyMessage="Token inv\xE1lido. Por favor, inicia sesi\xF3n nuevamente."):e.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.")}if(!e.isAuthError&&i.data?.response?.status){let t=i.data.response.status.toUpperCase();(t==="UNAUTHORIZED"||t==="UNAUTHENTICATED")&&(e.isAuthError=!0,e.errorType="Status",e.errorDetails=i.data.response,e.isUnauthorized=!0,e.shouldTriggerLogout=!0,e.isIrrecoverable=!0,e.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.")}if(!e.isAuthError&&i.data?.response?.data)try{let t=typeof i.data.response.data=="string"?JSON.parse(i.data.response.data):i.data.response.data;(t.error==="REFRESH_TOKEN_INVALID"||t.error==="TOKEN_EXPIRED"||t.error==="INVALID_TOKEN")&&(e.isAuthError=!0,e.errorType="Parsed Data",e.errorDetails=t,e.shouldTriggerLogout=!0,e.isIrrecoverable=!0,t.error==="REFRESH_TOKEN_INVALID"?(e.isRefreshTokenInvalid=!0,e.isTokenRefreshFailed=!0,e.userFriendlyMessage="Tu sesi\xF3n ha caducado. Por favor, inicia sesi\xF3n nuevamente."):(e.isTokenExpired=!0,e.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."))}catch{}if(!e.isAuthError&&i.errorCode){let t=String(i.errorCode).toUpperCase();(t==="UNAUTHORIZED"||t==="UNAUTHENTICATED"||t==="TOKEN_EXPIRED"||t==="INVALID_TOKEN")&&(e.isAuthError=!0,e.errorType="Error Code",e.errorDetails={errorCode:t},e.shouldTriggerLogout=!0,t==="TOKEN_EXPIRED"?e.isTokenExpired=!0:e.isUnauthorized=!0,e.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.")}return e}updateLastActivity(){this.lastActivityTime=Date.now(),this.log("Last activity updated")}getTimeSinceLastActivity(){return this.lastActivityTime===0?0:Date.now()-this.lastActivityTime}checkInactivity(){let i=this.getTimeSinceLastActivity();if(this.lastActivityTime===0)return"none";let e=1800*1e3;return i>e?(this.log(`Inactivity timeout: ${Math.floor(i/6e4)} minutes since last activity`),"logout"):"none"}async clearSession(){await b.clearTokens(),await F.logout(),this.lastActivityTime=0,this.log("Session cleared completely")}getSessionExpiredMessage(){return this.config.translateFn?Se("SESSION_EXPIRED",{translateFn:this.config.translateFn,enableDebug:this.config.enableLogging}):"Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."}log(i,e){this.config.enableLogging&&g.debug(`[SessionManager] ${i}`,e)}formatError(i){return i?typeof i=="string"?i:typeof i=="object"?Object.values(i).flat().map(String).join(", "):"Authentication failed":"Unknown error"}};import{useState as fi,useEffect as ie,useCallback as W}from"react";function Ce(r={}){let[i,e]=fi({isAuthenticated:!1,isLoading:!0,isInitialized:!1,tokens:null,error:null}),t=ee.getInstance(),n=W(async()=>{try{e(s=>({...s,isLoading:!0,error:null}));let u={autoRestore:r.autoRestore??!0,enableLogging:r.enableLogging??!1,showNotification:r.showNotification,translateFn:r.translateFn,apiEndpointAdmin:r.apiEndpointAdmin,apiKeyEndpointAdmin:r.apiKeyEndpointAdmin,publicApiKey:r.publicApiKey,env:r.env||"stg",onSessionExpired:()=>{e(s=>({...s,isAuthenticated:!1,tokens:null,error:"Session expired"})),r.onSessionExpired?.()},onSessionRestored:s=>{e(E=>({...E,isAuthenticated:!0,tokens:s,error:null})),r.onSessionRestored?.(s)},onLoginSuccess:s=>{e(E=>({...E,isAuthenticated:!0,tokens:s,error:null}))},onLogout:()=>{e(s=>({...s,isAuthenticated:!1,tokens:null,error:null}))}};await t.initialize(u),t.setupResponseInterceptor();let l=await t.isAuthenticated(),f=await t.getTokenInfo();e(s=>({...s,isAuthenticated:l,isInitialized:!0,isLoading:!1,tokens:f.crudifyTokens.accessToken?{accessToken:f.crudifyTokens.accessToken,refreshToken:f.crudifyTokens.refreshToken,expiresAt:f.crudifyTokens.expiresAt,refreshExpiresAt:f.crudifyTokens.refreshExpiresAt}:null}))}catch(u){let l=u instanceof Error?u.message:"Initialization failed";g.error("[useSession] Initialize failed",u instanceof Error?u:{message:l}),e(f=>({...f,isLoading:!1,isInitialized:!0,error:l}))}},[r.autoRestore,r.enableLogging,r.onSessionExpired,r.onSessionRestored]),o=W(async(u,l)=>{e(f=>({...f,isLoading:!0,error:null}));try{let f=await t.login(u,l);return f.success&&f.tokens?e(s=>({...s,isAuthenticated:!0,tokens:f.tokens,isLoading:!1,error:null})):e(s=>({...s,isAuthenticated:!1,tokens:null,isLoading:!1,error:null})),f}catch(f){let s=f instanceof Error?f.message:"Login failed";g.error("[useSession] Login error",f instanceof Error?f:{message:s});let E=s.includes("INVALID_CREDENTIALS")||s.includes("Invalid email")||s.includes("Invalid password")||s.includes("credentials");return e(k=>({...k,isAuthenticated:!1,tokens:null,isLoading:!1,error:E?null:s})),{success:!1,error:s}}},[t]),m=W(async()=>{e(u=>({...u,isLoading:!0}));try{await t.logout(),e(u=>({...u,isAuthenticated:!1,tokens:null,isLoading:!1,error:null}))}catch(u){e(l=>({...l,isAuthenticated:!1,tokens:null,isLoading:!1,error:u instanceof Error?u.message:"Logout error"}))}},[t]),T=W(async()=>{try{let u=await t.refreshTokens();if(u){let l=await t.getTokenInfo();e(f=>({...f,tokens:l.crudifyTokens.accessToken?{accessToken:l.crudifyTokens.accessToken,refreshToken:l.crudifyTokens.refreshToken,expiresAt:l.crudifyTokens.expiresAt,refreshExpiresAt:l.crudifyTokens.refreshExpiresAt}:null,error:null}))}else e(l=>({...l,isAuthenticated:!1,tokens:null,error:"Token refresh failed"}));return u}catch(u){return e(l=>({...l,isAuthenticated:!1,tokens:null,error:u instanceof Error?u.message:"Token refresh failed"})),!1}},[t]),x=W(()=>{e(u=>({...u,error:null}))},[]),A=W(async()=>t.getTokenInfo(),[t]);ie(()=>{n()},[n]),ie(()=>{if(!i.isAuthenticated||!i.tokens)return;let u=we.getInstance(),l=()=>{t.updateLastActivity()},f=u.subscribe(l);window.addEventListener("popstate",l);let s=async()=>{let R=(await t.getTokenInfo()).crudifyTokens.expiresIn||0;return R<300*1e3?30*1e3:R<1800*1e3?60*1e3:120*1e3},E,k=async()=>{let S=await s();E=setTimeout(async()=>{if(t.isRefreshing()){k();return}let R=await t.getTokenInfo(),w=R.crudifyTokens.expiresIn||0,C=((R.crudifyTokens.expiresAt||0)-(Date.now()-w))*.5;if(w>0&&w<=C)if(e(K=>({...K,isLoading:!0})),await t.refreshTokens()){let K=await t.getTokenInfo();e(ce=>({...ce,isLoading:!1,tokens:K.crudifyTokens.accessToken?{accessToken:K.crudifyTokens.accessToken,refreshToken:K.crudifyTokens.refreshToken,expiresAt:K.crudifyTokens.expiresAt,refreshExpiresAt:K.crudifyTokens.refreshExpiresAt}:null}))}else e(K=>({...K,isLoading:!1,isAuthenticated:!1,tokens:null}));let v=t.getTimeSinceLastActivity(),X=1800*1e3;v>X?await m():k()},S)};return k(),()=>{clearTimeout(E),window.removeEventListener("popstate",l),f()}},[i.isAuthenticated,i.tokens,t,r.enableLogging,m]),ie(()=>{let u=_.subscribe(async l=>{if(l.type==="TOKEN_EXPIRED"){if(t.isRefreshing())return;e(f=>({...f,isLoading:!0}));try{if(await t.refreshTokens()){let s=await t.getTokenInfo();e(E=>({...E,isLoading:!1,tokens:s.crudifyTokens.accessToken?{accessToken:s.crudifyTokens.accessToken,refreshToken:s.crudifyTokens.refreshToken,expiresAt:s.crudifyTokens.expiresAt,refreshExpiresAt:s.crudifyTokens.refreshExpiresAt}:null}))}else _.emit("SESSION_EXPIRED",{message:"Failed to refresh token after detecting expiration",source:"useSession.TOKEN_EXPIRED handler"})}catch(f){_.emit("SESSION_EXPIRED",{message:f instanceof Error?f.message:"Unknown error during refresh",source:"useSession.TOKEN_EXPIRED handler (error)"})}}(l.type==="SESSION_EXPIRED"||l.type==="TOKEN_REFRESH_FAILED")&&(e(f=>({...f,isAuthenticated:!1,tokens:null,isLoading:!1,error:l.details?.message||"Session expired"})),r.onSessionExpired?.())});return()=>u()},[r.onSessionExpired,t]),ie(()=>{let u=b.subscribeToChanges((l,f,s)=>{f===b.SYNC_EVENTS.TOKENS_CLEARED?s&&i.isAuthenticated?(g.debug("[useSession] Cross-tab logout detected"),e(E=>({...E,isAuthenticated:!1,tokens:null})),r.onSessionExpired?.()):s&&e(E=>({...E,isAuthenticated:!1,tokens:null})):f===b.SYNC_EVENTS.TOKENS_UPDATED&&l&&(g.debug("[useSession] Cross-tab login/refresh detected"),e(E=>({...E,tokens:l,isAuthenticated:!0,error:null})))});return()=>u()},[i.isAuthenticated,r.onSessionExpired]);let L=W(()=>{t.updateLastActivity()},[t]);return{...i,login:o,logout:m,refreshTokens:T,clearError:x,getTokenInfo:A,updateActivity:L,isExpiringSoon:i.tokens?i.tokens.expiresAt-Date.now()<300*1e3:!1,expiresIn:i.tokens?Math.max(0,i.tokens.expiresAt-Date.now()):0,refreshExpiresIn:i.tokens?Math.max(0,i.tokens.refreshExpiresAt-Date.now()):0}}import{useState as De,createContext as gi,useContext as pi,useCallback as te,useEffect as mi}from"react";import{Snackbar as yi,Alert as hi,Box as Ei,Portal as vi}from"@mui/material";import{v4 as Ti}from"uuid";import bi from"dompurify";import{jsx as B,jsxs as ki}from"react/jsx-runtime";var Fe=gi(null),Ai=r=>bi.sanitize(r,{ALLOWED_TAGS:["b","i","em","strong","br","span"],ALLOWED_ATTR:["class"],FORBID_TAGS:["script","iframe","object","embed"],FORBID_ATTR:["onload","onerror","onclick","onmouseover","onfocus","onblur"],WHOLE_DOCUMENT:!1,RETURN_DOM:!1,RETURN_DOM_FRAGMENT:!1,RETURN_TRUSTED_TYPE:!1}),fe=({children:r,maxNotifications:i=5,defaultAutoHideDuration:e=6e3,position:t={vertical:"top",horizontal:"right"},enabled:n=!1,allowHtml:o=!1})=>{let[m,T]=De([]),x=te((l,f="info",s)=>{if(!n)return"";if(!l||typeof l!="string")return g.warn("GlobalNotificationProvider: Invalid message provided"),"";l.length>1e3&&(g.warn("GlobalNotificationProvider: Message too long, truncating"),l=l.substring(0,1e3)+"...");let E=Ti(),k={id:E,message:l,severity:f,autoHideDuration:s?.autoHideDuration??e,persistent:s?.persistent??!1,allowHtml:s?.allowHtml??o};return T(S=>[...S.length>=i?S.slice(-(i-1)):S,k]),E},[i,e,n,o]),A=te(l=>{T(f=>f.filter(s=>s.id!==l))},[]),L=te(()=>{T([])},[]),u={showNotification:x,hideNotification:A,clearAllNotifications:L};return ki(Fe.Provider,{value:u,children:[r,n&&B(vi,{children:B(Ei,{sx:{position:"fixed",zIndex:9999,[t.vertical]:(t.vertical==="top",24),[t.horizontal]:t.horizontal==="right"||t.horizontal==="left"?24:"50%",...t.horizontal==="center"&&{transform:"translateX(-50%)"},display:"flex",flexDirection:t.vertical==="top"?"column":"column-reverse",gap:1,maxWidth:"400px",width:"auto"},children:m.map(l=>B(Ii,{notification:l,onClose:()=>A(l.id)},l.id))})})]})},Ii=({notification:r,onClose:i})=>{let[e,t]=De(!0),n=te((o,m)=>{m!=="clickaway"&&(t(!1),setTimeout(i,300))},[i]);return mi(()=>{if(!r.persistent&&r.autoHideDuration){let o=setTimeout(()=>{n()},r.autoHideDuration);return()=>clearTimeout(o)}},[r.autoHideDuration,r.persistent,n]),B(yi,{open:e,onClose:n,sx:{position:"relative","& .MuiSnackbarContent-root":{minWidth:"auto"}},TransitionProps:{enter:!0,exit:!0},children:B(hi,{variant:"filled",severity:r.severity,onClose:n,sx:{width:"100%",minWidth:"280px",maxWidth:"400px",wordBreak:"break-word"},children:r.allowHtml?B("span",{dangerouslySetInnerHTML:{__html:Ai(r.message)}}):B("span",{children:r.message})})})},Le=()=>{let r=pi(Fe);if(!r)throw new Error("useGlobalNotification debe ser usado dentro de un GlobalNotificationProvider");return r};import{createContext as Si,useContext as wi,useEffect as xi,useState as j}from"react";import J from"@nocios/crudify-browser";var ge=class r{constructor(){this.listeners=[];this.credentials=null;this.isReady=!1}static getInstance(){return r.instance||(r.instance=new r),r.instance}notifyCredentialsReady(i){this.credentials=i,this.isReady=!0,this.listeners.forEach(e=>{try{e(i)}catch(t){g.error("[CredentialsEventBus] Error in listener",t instanceof Error?t:{message:String(t)})}}),this.listeners=[]}waitForCredentials(){return this.isReady&&this.credentials?Promise.resolve(this.credentials):new Promise(i=>{this.listeners.push(i)})}reset(){this.credentials=null,this.isReady=!1,this.listeners=[]}areCredentialsReady(){return this.isReady&&this.credentials!==null}},re=ge.getInstance();import{jsx as Pi}from"react/jsx-runtime";var ze=Si(void 0),Ke=({config:r,children:i})=>{let[e,t]=j(!0),[n,o]=j(null),[m,T]=j(!1),[x,A]=j(""),[L,u]=j();xi(()=>{if(!r.publicApiKey){o("No publicApiKey provided"),t(!1),T(!1);return}let f=`${r.publicApiKey}-${r.env}`;if(f===x&&m){t(!1);return}(async()=>{t(!0),o(null),T(!1);try{J.config(r.env||"prod");let E=await J.init(r.publicApiKey,"none");if(u(E),typeof J.transaction=="function"&&typeof J.login=="function")T(!0),A(f),E.apiEndpointAdmin&&E.apiKeyEndpointAdmin&&re.notifyCredentialsReady({apiUrl:E.apiEndpointAdmin,apiKey:E.apiKeyEndpointAdmin});else throw new Error("Crudify methods not properly initialized")}catch(E){let k=E instanceof Error?E.message:"Failed to initialize Crudify";g.error("[CrudifyProvider] Initialization error",E instanceof Error?E:{message:String(E)}),o(k),T(!1)}finally{t(!1)}})()},[r.publicApiKey,r.env,x,m]);let l={crudify:m?J:null,isLoading:e,error:n,isInitialized:m,adminCredentials:L};return Pi(ze.Provider,{value:l,children:i})},Ue=()=>{let r=wi(ze);if(r===void 0)throw new Error("useCrudify must be used within a CrudifyProvider");return r};import Ni,{createContext as Ri,useContext as Ci,useMemo as pe}from"react";import{Fragment as Fi,jsx as D,jsxs as M}from"react/jsx-runtime";var He=Ri(void 0);function Oe({children:r,options:i={},config:e,showNotifications:t=!1,notificationOptions:n={}}){let o;try{let{showNotification:s}=Le();o=s}catch{}let m={};try{let s=Ue();s.isInitialized&&s.adminCredentials&&(m=s.adminCredentials)}catch{}let T=pe(()=>{let s=de({publicApiKey:e?.publicApiKey,env:e?.env,enableDebug:i?.enableLogging});return{publicApiKey:s.publicApiKey,env:s.env||"prod"}},[e,i?.enableLogging]),x=Ni.useMemo(()=>({...i,showNotification:o,apiEndpointAdmin:m.apiEndpointAdmin,apiKeyEndpointAdmin:m.apiKeyEndpointAdmin,publicApiKey:T.publicApiKey,env:T.env,onSessionExpired:()=>{i.onSessionExpired?.()}}),[i,o,m.apiEndpointAdmin,m.apiKeyEndpointAdmin,T]),A=Ce(x),L=pe(()=>{let s=de({publicApiKey:e?.publicApiKey,env:e?.env,appName:e?.appName,logo:e?.logo,loginActions:e?.loginActions,enableDebug:i?.enableLogging});return{publicApiKey:s.publicApiKey,env:s.env,appName:s.appName,loginActions:s.loginActions,logo:s.logo}},[e,i?.enableLogging]),u=pe(()=>{if(!A.tokens?.accessToken||!A.isAuthenticated)return null;try{let s=xe(A.tokens.accessToken);if(s&&s.sub&&s.email&&s.subscriber){let E={_id:s.sub,email:s.email,subscriberKey:s.subscriber};return Object.keys(s).forEach(k=>{["sub","email","subscriber"].includes(k)||(E[k]=s[k])}),E}}catch(s){g.error("Error decoding JWT token for sessionData",s instanceof Error?s:{message:String(s)})}return null},[A.tokens?.accessToken,A.isAuthenticated]),l={...A,sessionData:u,config:L},f={enabled:t,maxNotifications:n.maxNotifications||5,defaultAutoHideDuration:n.defaultAutoHideDuration||6e3,position:n.position||{vertical:"top",horizontal:"right"}};return D(He.Provider,{value:l,children:r})}function Lt(r){let i={enabled:r.showNotifications,maxNotifications:r.notificationOptions?.maxNotifications||5,defaultAutoHideDuration:r.notificationOptions?.defaultAutoHideDuration||6e3,position:r.notificationOptions?.position||{vertical:"top",horizontal:"right"},allowHtml:r.notificationOptions?.allowHtml||!1};return r.config?.publicApiKey?D(Ke,{config:{publicApiKey:r.config.publicApiKey,env:r.config.env||"prod",appName:r.config.appName,loginActions:r.config.loginActions,logo:r.config.logo},children:D(fe,{...i,children:D(Oe,{...r})})}):D(fe,{...i,children:D(Oe,{...r})})}function Di(){let r=Ci(He);if(r===void 0)throw new Error("useSessionContext must be used within a SessionProvider");return r}function zt(){let r=Di();return r.isInitialized?M("div",{style:{padding:"10px",margin:"10px",border:"1px solid #ccc",borderRadius:"4px",fontSize:"12px",fontFamily:"monospace"},children:[D("h4",{children:"Session Debug Info"}),M("div",{children:[D("strong",{children:"Authenticated:"})," ",r.isAuthenticated?"Yes":"No"]}),M("div",{children:[D("strong",{children:"Loading:"})," ",r.isLoading?"Yes":"No"]}),M("div",{children:[D("strong",{children:"Error:"})," ",r.error||"None"]}),r.tokens&&M(Fi,{children:[M("div",{children:[D("strong",{children:"Access Token:"})," ",r.tokens.accessToken.substring(0,20),"..."]}),M("div",{children:[D("strong",{children:"Refresh Token:"})," ",r.tokens.refreshToken.substring(0,20),"..."]}),M("div",{children:[D("strong",{children:"Access Expires In:"})," ",Math.round(r.expiresIn/1e3/60)," minutes"]}),M("div",{children:[D("strong",{children:"Refresh Expires In:"})," ",Math.round(r.refreshExpiresIn/1e3/60/60)," hours"]}),M("div",{children:[D("strong",{children:"Expiring Soon:"})," ",r.isExpiringSoon?"Yes":"No"]})]})]}):D("div",{children:"Session not initialized"})}import{useState as ne,useEffect as Me,useCallback as Ge,useRef as se}from"react";import Li from"@nocios/crudify-browser";var Gt=(r={})=>{let{autoFetch:i=!0,retryOnError:e=!1,maxRetries:t=3}=r,[n,o]=ne(null),[m,T]=ne(!1),[x,A]=ne(null),[L,u]=ne({}),l=se(null),f=se(!0),s=se(0),E=se(0),k=Ge(()=>{o(null),A(null),T(!1),u({})},[]),S=Ge(async()=>{let R=Pe();if(!R){f.current&&(A("No user email available"),T(!1));return}l.current&&l.current.abort();let w=new AbortController;l.current=w;let z=++s.current;try{f.current&&(T(!0),A(null));let U=await Li.readItems("users",{filter:{email:R},pagination:{limit:1}});if(z===s.current&&f.current&&!w.signal.aborted){let C=U.data;if(U.success&&C&&C.length>0){let v=C[0];o(v);let X={fullProfile:v,totalFields:Object.keys(v).length,displayData:{id:v.id,email:v.email,username:v.username,firstName:v.firstName,lastName:v.lastName,fullName:v.fullName||`${v.firstName||""} ${v.lastName||""}`.trim(),role:v.role,permissions:v.permissions||[],isActive:v.isActive,lastLogin:v.lastLogin,createdAt:v.createdAt,updatedAt:v.updatedAt,...Object.keys(v).filter(G=>!["id","email","username","firstName","lastName","fullName","role","permissions","isActive","lastLogin","createdAt","updatedAt"].includes(G)).reduce((G,K)=>({...G,[K]:v[K]}),{})}};u(X),A(null),E.current=0}else A("User profile not found"),o(null),u({})}}catch(U){if(z===s.current&&f.current){let C=U;if(C.name==="AbortError")return;e&&E.current<t&&(C.message?.includes("Network Error")||C.message?.includes("Failed to fetch"))?(E.current++,setTimeout(()=>{f.current&&S()},1e3*E.current)):(A("Failed to load user profile"),o(null),u({}))}}finally{z===s.current&&f.current&&T(!1),l.current===w&&(l.current=null)}},[e,t]);return Me(()=>{i&&S()},[i,S]),Me(()=>(f.current=!0,()=>{f.current=!1,l.current&&(l.current.abort(),l.current=null)}),[]),{userProfile:n,loading:m,error:x,extendedData:L,refreshProfile:S,clearProfile:k}};import{useState as me,useEffect as zi,useCallback as oe,useRef as Ki}from"react";import Ui from"@nocios/crudify-browser";var $t=(r,i={})=>{let{autoFetch:e=!0,onSuccess:t,onError:n}=i,{prefix:o,padding:m=0,separator:T=""}=r,[x,A]=me(""),[L,u]=me(!1),[l,f]=me(null),s=Ki(!1),E=oe(w=>{let z=String(w).padStart(m,"0");return`${o}${T}${z}`},[o,m,T]),k=oe(async()=>{u(!0),f(null);try{let w=await Ui.getNextSequence(o),z=w.data;if(w.success&&z?.value){let U=E(z.value);A(U),t?.(U)}else{let U=w.errors?._error?.[0]||"Failed to generate code";f(U),n?.(U)}}catch(w){let z=w instanceof Error?w.message:"Unknown error";f(z),n?.(z)}finally{u(!1)}},[o,E,t,n]),S=oe(async()=>{await k()},[k]),R=oe(()=>{f(null)},[]);return zi(()=>{e&&!x&&!s.current&&(s.current=!0,k())},[e,x,k]),{value:x,loading:L,error:l,regenerate:S,clearError:R}};import ye from"@nocios/crudify-browser";var he=class r{constructor(){this.state={status:"UNINITIALIZED",priority:null,publicApiKey:null,env:null,error:null,initializedBy:null};this.initializationPromise=null;this.highPriorityInitializerPresent=!1;this.waitingForHighPriority=new Set;this.HIGH_PRIORITY_WAIT_TIMEOUT=100}static getInstance(){return r.instance||(r.instance=new r),r.instance}registerHighPriorityInitializer(){this.highPriorityInitializerPresent=!0}isHighPriorityInitializerPresent(){return this.highPriorityInitializerPresent}getState(){return{...this.state}}async initialize(i){let{priority:e,publicApiKey:t,env:n,enableLogging:o,requestedBy:m}=i;if(this.state.status==="INITIALIZED"){this.state.publicApiKey!==t&&g.warn(`[CrudifyInitialization] ${m} attempted to initialize with different key. Already initialized with key: ${this.state.publicApiKey?.slice(0,10)}... by ${this.state.initializedBy}`);return}if(this.initializationPromise)return o&&g.debug(`[CrudifyInitialization] ${m} waiting for ongoing initialization...`),this.initializationPromise;if(e==="LOW"&&this.highPriorityInitializerPresent&&this.state.status==="UNINITIALIZED"){if(o&&g.debug(`[CrudifyInitialization] ${m} (LOW priority) waiting for HIGH priority initializer...`),this.waitingForHighPriority.add(m),await this.waitForHighPriorityOrTimeout(o),this.waitingForHighPriority.delete(m),this.getState().status==="INITIALIZED"){o&&g.debug(`[CrudifyInitialization] ${m} found initialization completed by HIGH priority`);return}o&&g.warn(`[CrudifyInitialization] ${m} timeout waiting for HIGH priority, initializing with LOW priority`)}e==="HIGH"&&this.state.status==="INITIALIZING"&&this.state.priority==="LOW"&&(g.warn(`[CrudifyInitialization] HIGH priority request from ${m} interrupting LOW priority initialization by ${this.state.initializedBy}`),this.state.status="UNINITIALIZED",this.initializationPromise=null),o&&g.debug(`[CrudifyInitialization] ${m} starting initialization (${e} priority)...`),this.state.status="INITIALIZING",this.state.priority=e,this.state.initializedBy=m,this.initializationPromise=this.performInitialization(t,n,o);try{await this.initializationPromise,this.state.status="INITIALIZED",this.state.publicApiKey=t,this.state.env=n,this.state.error=null,o&&g.info(`[CrudifyInitialization] Successfully initialized by ${m} (${e} priority)`)}catch(T){throw this.state.status="ERROR",this.state.error=T instanceof Error?T:new Error(String(T)),this.initializationPromise=null,g.error(`[CrudifyInitialization] Initialization failed for ${m}`,T instanceof Error?T:{message:String(T)}),T}}async waitForHighPriorityOrTimeout(i){return new Promise(e=>{let n=0,o=setInterval(()=>{if(n+=10,this.state.status==="INITIALIZED"&&this.state.priority==="HIGH"){clearInterval(o),e();return}if(this.state.status==="INITIALIZING"&&this.state.priority==="HIGH"){n=0;return}n>=this.HIGH_PRIORITY_WAIT_TIMEOUT&&(clearInterval(o),i&&g.debug(`[CrudifyInitialization] Timeout waiting for HIGH priority (${this.HIGH_PRIORITY_WAIT_TIMEOUT}ms)`),e())},10)})}async performInitialization(i,e,t){let n=ye.getTokenData();if(n&&n.endpoint){t&&g.debug("[CrudifyInitialization] SDK already initialized externally");return}ye.config(e);let o=t?"debug":"none",m=await ye.init(i,o);if(m.success===!1)throw new Error(`Crudify initialization failed: ${JSON.stringify(m.errors||"Unknown error")}`);m.apiEndpointAdmin&&m.apiKeyEndpointAdmin&&re.notifyCredentialsReady({apiUrl:m.apiEndpointAdmin,apiKey:m.apiKeyEndpointAdmin})}reset(){this.state={status:"UNINITIALIZED",priority:null,publicApiKey:null,env:null,error:null,initializedBy:null},this.initializationPromise=null,this.highPriorityInitializerPresent=!1,this.waitingForHighPriority.clear()}isInitialized(){return this.state.status==="INITIALIZED"}getDiagnostics(){return{...this.state,waitingCount:this.waitingForHighPriority.size,waitingComponents:Array.from(this.waitingForHighPriority),hasActivePromise:this.initializationPromise!==null}}},Q=he.getInstance();import{useState as ae,useCallback as N,useRef as Oi,useMemo as q}from"react";import le from"@nocios/crudify-browser";var _e=r=>{let i=new Uint8Array(r);return crypto.getRandomValues(i),Array.from(i,e=>e.toString(36).padStart(2,"0")).join("").substring(0,r)},Ve=()=>`file_${Date.now()}_${_e(7)}`,Hi=r=>{let i=r.lastIndexOf("."),e=i>0?r.substring(i):"",t=Date.now(),n=_e(6);return`${t}_${n}${e}`},Ee=(r,i)=>{if(r.startsWith("http://")||r.startsWith("https://"))try{let e=new URL(r);return e.pathname.startsWith("/")?e.pathname.substring(1):e.pathname}catch{if(i&&r.startsWith(i))return r.substring(i.length)}return i&&r.startsWith(i)?r.substring(i.length):r},ir=(r={})=>{let{acceptedTypes:i,maxFileSize:e=10*1024*1024,maxFiles:t,minFiles:n=0,visibility:o="private",onUploadComplete:m,onUploadError:T,onFileRemoved:x,onFilesChange:A,mode:L="edit"}=r,[u,l]=ae([]),[f,s]=ae(!1),[E,k]=ae(!1),[S,R]=ae([]),w=Oi(new Map),z=N(()=>{s(!0)},[]),U=N(()=>{k(!0),s(!0)},[]),C=N((c,p)=>{l(d=>d.map(h=>h.id===c?{...h,...p}:h))},[]),v=N(c=>{A?.(c)},[A]),X=N(c=>i&&i.length>0&&!i.includes(c.type)?{valid:!1,error:`File type not allowed: ${c.type}`}:c.size>e?{valid:!1,error:`File exceeds maximum size of ${(e/1048576).toFixed(1)}MB`}:{valid:!0},[i,e]),G=N(async(c,p)=>{try{if(!Q.isInitialized())throw new Error("Crudify is not initialized. Please wait for the application to finish loading.");let d=Hi(p.name),y=await le.generateSignedUrl({fileName:d,contentType:p.type,visibility:o});if(!y.success||!y.data)throw new Error("Failed to get upload URL");let h=y.data,{uploadUrl:P,s3Key:I,publicUrl:H}=h;if(!P||!I)throw new Error("Incomplete signed URL response");let Y=I.indexOf("/"),ci=Y>0?I.substring(Y+1):I;C(c.id,{status:"uploading",progress:0}),await new Promise((ue,$)=>{let O=new XMLHttpRequest;O.upload.addEventListener("progress",V=>{if(V.lengthComputable){let di=Math.round(V.loaded/V.total*100);C(c.id,{progress:di})}}),O.addEventListener("load",()=>{O.status>=200&&O.status<300?ue():$(new Error(`Upload failed with status ${O.status}`))}),O.addEventListener("error",()=>{$(new Error("Network error during upload"))}),O.addEventListener("abort",()=>{$(new Error("Upload cancelled"))}),O.open("PUT",P),O.setRequestHeader("Content-Type",p.type),O.send(p)});let ui={status:"completed",progress:100,filePath:ci,visibility:o,publicUrl:o==="public"?H:void 0,file:void 0};l(ue=>{let $=ue.map(V=>V.id===c.id?{...V,...ui}:V);v($);let O=$.find(V=>V.id===c.id);return O&&m?.(O),$})}catch(d){let y=d instanceof Error?d.message:"Unknown error";C(c.id,{status:"error",progress:0,errorMessage:y}),l(h=>{let P=h.find(I=>I.id===c.id);return P&&T?.(P,y),h})}},[C,m,T,o]),K=N(async c=>{let p=Array.from(c),d=[];l(y=>{if(t!==void 0){let I=y.filter(Y=>Y.status!=="pendingDeletion"&&Y.status!=="error").length,H=t-I;if(H<=0)return g.warn(`File limit of ${t} already reached`),y;p.length>H&&(p=p.slice(0,H),g.warn(`Only ${H} files will be added to not exceed limit`))}let h=[];for(let I of p){let H=X(I),Y={id:Ve(),name:I.name,size:I.size,contentType:I.type,status:H.valid?"pending":"error",progress:0,createdAt:Date.now(),file:H.valid?I:void 0,errorMessage:H.error,isExisting:!1};h.push(Y)}d=h;let P=[...y,...h];return v(P),P}),setTimeout(()=>{let y=d.filter(h=>h.status==="pending"&&h.file);for(let h of y)if(h.file){let P=G(h,h.file);w.current.set(h.id,P),P.finally(()=>{w.current.delete(h.id)})}},0)},[t,X,G,v]),ce=N(async c=>{let p=u.find(y=>y.id===c);if(!p)return{needsConfirmation:!1,isExisting:!1};let d=p.isExisting===!0;return L==="create"||!d?{needsConfirmation:!0,isExisting:d}:(R(y=>[...y,c]),l(y=>{let h=y.map(I=>I.id===c?{...I,status:"pendingDeletion"}:I),P=h.filter(I=>I.status!=="pendingDeletion");return v(P),h}),{needsConfirmation:!1,isExisting:d})},[u,L,v]),Ye=N(async c=>{let p=u.find(d=>d.id===c);if(!p)return{success:!1,error:"File not found"};if(!p.filePath)return l(d=>{let y=d.filter(h=>h.id!==c);return v(y),y}),{success:!0};try{if(!Q.isInitialized())return{success:!1,error:"Crudify not initialized"};let d=Ee(p.filePath);return(await le.disableFile({filePath:d})).success?(l(h=>{let P=h.filter(I=>I.id!==c);return v(P),P}),x?.(p),{success:!0}):{success:!1,error:"Failed to delete file"}}catch(d){return{success:!1,error:d instanceof Error?d.message:"Unknown error"}}},[u,v,x]),$e=N(c=>{let p=u.find(d=>d.id===c);return!p||!p.isExisting?!1:(R(d=>d.filter(y=>y!==c)),l(d=>{let y=d.map(h=>h.id===c?{...h,status:"completed"}:h);return v(y),y}),!0)},[u,v]),We=N(()=>{S.length!==0&&(l(c=>{let p=c.map(d=>S.includes(d.id)?{...d,status:"completed"}:d);return v(p),p}),R([]))},[S,v]),Be=N(async()=>{if(S.length===0)return{success:!0,errors:[]};let c=[],p=[];if(!Q.isInitialized())return{success:!1,errors:["Crudify is not initialized. Please wait for the application to finish loading."]};for(let d of S){let y=u.find(h=>h.id===d);if(!y?.filePath){p.push(d);continue}try{let h=Ee(y.filePath);(await le.disableFile({filePath:h})).success?(p.push(d),x?.(y)):c.push(`Failed to delete ${y.name}`)}catch(h){c.push(`Error deleting ${y.name}: ${h instanceof Error?h.message:"Unknown error"}`)}}return p.length>0&&(l(d=>d.filter(h=>!p.includes(h.id))),R(d=>d.filter(y=>!p.includes(y)))),{success:c.length===0,errors:c}},[u,S,x]),Xe=N(()=>{l([]),v([])},[v]),Ze=N(async c=>{let p=u.find(y=>y.id===c);if(!p||p.status!=="error"||!p.file){g.warn("Cannot retry: file not found or no original file");return}C(c,{status:"pending",progress:0,errorMessage:void 0});let d=G(p,p.file);w.current.set(c,d),d.finally(()=>{w.current.delete(c)})},[u,C,G]),qe=N(async()=>{let c=Array.from(w.current.values());return c.length>0&&await Promise.allSettled(c),new Promise(p=>{setTimeout(()=>{l(d=>{let y=d.filter(h=>h.status==="completed"&&h.filePath).map(h=>h.filePath);return p(y),d})},0)})},[]),je=c=>{let p=c.split(".").pop()?.toLowerCase()||"";return{jpg:"image/jpeg",jpeg:"image/jpeg",png:"image/png",gif:"image/gif",webp:"image/webp",svg:"image/svg+xml",bmp:"image/bmp",ico:"image/x-icon",pdf:"application/pdf",doc:"application/msword",docx:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",xls:"application/vnd.ms-excel",xlsx:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",ppt:"application/vnd.ms-powerpoint",pptx:"application/vnd.openxmlformats-officedocument.presentationml.presentation",txt:"text/plain",csv:"text/csv",mp3:"audio/mpeg",wav:"audio/wav",mp4:"video/mp4",webm:"video/webm",zip:"application/zip",rar:"application/x-rar-compressed",json:"application/json",xml:"application/xml"}[p]||"application/octet-stream"},Je=N((c,p)=>{let d=c.map(y=>{let h=Ee(y.filePath,p),P=h.includes("/public/")||h.startsWith("public/")?"public":"private",I=y.contentType||je(y.name);return{id:Ve(),name:y.name,size:y.size||0,contentType:I,status:"completed",progress:100,filePath:h,visibility:P,createdAt:Date.now(),isExisting:!0}});l(d),v(d)},[v]),Qe=N(async c=>{let p=u.find(d=>d.id===c);if(!p||!p.filePath)return null;if(p.visibility==="public"&&p.publicUrl)return p.publicUrl;try{if(!Q.isInitialized())return null;let d=await le.getFileUrl({filePath:p.filePath,expiresIn:3600}),y=d.data;return d.success&&y?.url?y.url:null}catch{return null}},[u]),ei=q(()=>u.some(c=>c.status==="uploading"||c.status==="pending"),[u]),ii=q(()=>u.filter(c=>c.status==="uploading"||c.status==="pending").length,[u]),ti=q(()=>u.filter(c=>c.status==="completed"&&c.filePath).map(c=>c.filePath),[u]),Z=q(()=>u.filter(c=>c.status!=="pendingDeletion"),[u]),ri=q(()=>Z.filter(c=>c.status==="completed"||c.status==="pending"||c.status==="uploading").length,[Z]),{isValid:ni,validationError:si,validationErrorKey:oi,validationErrorParams:ai}=q(()=>{let c=Z.filter(d=>d.status==="completed").length;if(c<n){let d=n===1?"file.validation.minFilesRequired":"file.validation.minFilesRequiredPlural";return{isValid:!1,validationError:d,validationErrorKey:d,validationErrorParams:{count:n}}}return t!==void 0&&c>t?{isValid:!1,validationError:"file.validation.maxFilesExceeded",validationErrorKey:"file.validation.maxFilesExceeded",validationErrorParams:{count:t}}:Z.some(d=>d.status==="error")?{isValid:!1,validationError:"file.validation.filesWithErrors",validationErrorKey:"file.validation.filesWithErrors",validationErrorParams:{}}:{isValid:!0,validationError:null,validationErrorKey:null,validationErrorParams:{}}},[Z,n,t]),li=S.length>0;return{files:u,activeFiles:Z,activeFileCount:ri,isUploading:ei,pendingCount:ii,addFiles:K,removeFile:ce,deleteFileImmediately:Ye,restoreFile:$e,clearFiles:Xe,retryUpload:Ze,isValid:ni,validationError:si,validationErrorKey:oi,validationErrorParams:ai,waitForUploads:qe,completedFilePaths:ti,initializeFiles:Je,isTouched:f,markAsTouched:z,isSubmitted:E,markAsSubmitted:U,getPreviewUrl:Qe,pendingDeletions:S,hasPendingDeletions:li,commitDeletions:Be,restorePendingDeletions:We}};export{b as a,ee as b,Ce as c,fe as d,Le as e,re as f,Ke as g,Ue as h,Lt as i,Di as j,zt as k,Gt as l,$t as m,he as n,Q as o,ir as p};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{e as $,j as k}from"./chunk-PARX2RMU.mjs";import{a as V}from"./chunk-6BQGRZYB.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as v}from"react";import Q from"@nocios/crudify-browser";var J=(w={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:g=3}=w,{isAuthenticated:T,isInitialized:I,sessionData:u,tokens:m}=k(),[R,d]=K(null),[p,A]=K(c&&T),[C,E]=K(null),f=v(null),o=v(!0),y=v(0),l=v(0),F=j(()=>{if(!u)return null;let h=u["cognito:username"];return u.email||(typeof h=="string"?h:null)},[u]),L=j(()=>{d(null),E(null),A(!1),l.current=0},[]),U=j(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}f.current&&f.current.abort();let e=new AbortController;f.current=e;let i=++y.current;try{o.current&&(A(!0),E(null));let s=await Q.readItems("users",{filter:{email:h},pagination:{limit:1}});if(i===y.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)&&t.response?.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{}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)&&t.data?.response?.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{}}r?(d(r),E(null),l.current=0):(E("User profile not found in database"),d(null))}}catch(s){if(i===y.current&&o.current){let r=s;if(r.name==="AbortError")return;N&&l.current<g&&(r.message?.includes("Network Error")||r.message?.includes("Failed to fetch"))?(l.current++,setTimeout(()=>{o.current&&U()},1e3*l.current)):(E("Failed to load user profile from database"),d(null))}}finally{i===y.current&&o.current&&A(!1),f.current===e&&(f.current=null)}},[I,F,N,g]);return z(()=>{c&&T&&I?U():T||L()},[c,T,I,U,L]),z(()=>(o.current=!0,()=>{o.current=!1,f.current&&(f.current.abort(),f.current=null)}),[]),{user:{session:u,data:R},loading:p,error:C,refreshProfile:U,clearProfile:L}};import{useCallback as W}from"react";var te=()=>{let{isAuthenticated:w,isLoading:c,isInitialized:N,tokens:g,error:T,sessionData:I,login:u,logout:m,refreshTokens:R,clearError:d,getTokenInfo:p,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E}=k(),f=W(y=>{y?V.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):m()},[m]),o=g?.expiresAt?new Date(g.expiresAt):null;return{isAuthenticated:w,loading:c,error:T,token:g?.accessToken||null,user:I,tokenExpiration:o,setToken:f,logout:m,refreshToken:R,login:u,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E,getTokenInfo:p,clearError:d}};import{useCallback as S}from"react";import b from"@nocios/crudify-browser";var ae=()=>{let{isInitialized:w,isLoading:c,error:N,isAuthenticated:g,login:T}=k(),I=S(()=>w&&!c&&!N,[w,c,N]),u=S(async()=>new Promise((o,y)=>{let l=()=>{I()?o():N?y(new Error(N)):setTimeout(l,100)};l()}),[I,N]),m=S(async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),R=S(async(o,y,l)=>(await m(),await b.readItems(o,y||{},l)),[m]),d=S(async(o,y,l)=>(await m(),await b.readItem(o,y,l)),[m]),p=S(async(o,y,l)=>(await m(),await b.createItem(o,y,l)),[m]),A=S(async(o,y,l)=>(await m(),await b.updateItem(o,y,l)),[m]),C=S(async(o,y,l)=>(await m(),await b.deleteItem(o,y,l)),[m]),E=S(async(o,y)=>(await m(),await b.transaction(o,y)),[m]),f=S(async(o,y)=>{try{let l=await T(o,y);return l.success?{success:!0,data:l.tokens}:{success:!1,errors:l.error||"Login failed"}}catch(l){return{success:!1,errors:l instanceof Error?l.message:"Login failed"}}},[T]);return{readItems:R,readItem:d,createItem:p,updateItem:A,deleteItem:C,transaction:E,login:f,isInitialized:w,isInitializing:c,initializationError:N,isReady:I,waitForReady:u}};import{useCallback as _}from"react";import P from"@nocios/crudify-browser";var Y={INVALID_CREDENTIALS:"warning",UNAUTHORIZED:"warning",INVALID_API_KEY:"error",USER_NOT_FOUND:"warning",USER_NOT_ACTIVE:"warning",NO_PERMISSION:"warning",ITEM_NOT_FOUND:"info",NOT_FOUND:"info",IN_USE:"warning",FIELD_ERROR:"warning",BAD_REQUEST:"warning",INTERNAL_SERVER_ERROR:"error",DATABASE_CONNECTION_ERROR:"error",INVALID_CONFIGURATION:"error",UNKNOWN_OPERATION:"error",TOO_MANY_REQUESTS:"warning"},M={INVALID_CREDENTIALS:"errors.auth.INVALID_CREDENTIALS",UNAUTHORIZED:"errors.auth.UNAUTHORIZED",INVALID_API_KEY:"errors.auth.INVALID_API_KEY",USER_NOT_FOUND:"errors.auth.USER_NOT_FOUND",USER_NOT_ACTIVE:"errors.auth.USER_NOT_ACTIVE",NO_PERMISSION:"errors.auth.NO_PERMISSION",ITEM_NOT_FOUND:"errors.data.ITEM_NOT_FOUND",NOT_FOUND:"errors.data.NOT_FOUND",IN_USE:"errors.data.IN_USE",FIELD_ERROR:"errors.data.FIELD_ERROR",BAD_REQUEST:"errors.data.BAD_REQUEST",INTERNAL_SERVER_ERROR:"errors.system.INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"errors.system.DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"errors.system.INVALID_CONFIGURATION",UNKNOWN_OPERATION:"errors.system.UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"errors.system.TOO_MANY_REQUESTS"},de=(w={})=>{let{showNotification:c}=$(),{showSuccessNotifications:N=!1,showErrorNotifications:g=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:u=6e3,appStructure:m=[],translateFn:R=e=>e}=w,d=_(e=>{if(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||e.errors._transaction?.includes("ONE_OR_MORE_OPERATIONS_FAILED")||e.errors._error?.includes("TOO_MANY_REQUESTS")))return!1;let i=e.data;return!(!e.success&&i?.response?.status==="TOO_MANY_REQUESTS")},[]),p=_((e,i)=>{let s=R(e);return s===e?i||R("error.unknown"):s},[R]),A=_(e=>["create","update","delete"].includes(e),[]),C=_((e,i)=>N?A(e)&&i?!0:m.some(s=>s.key===e):!1,[N,m,A]),E=_((e,i,s)=>{let r=s?.key&&typeof s.key=="string"?s.key:e,t=`action.onSuccess.${r}`,n=p(t);if(n!==R("error.unknown")){if(A(r)&&i){let a=`action.${i}Singular`,O=p(a);if(O!==R("error.unknown"))return R(t,{item:O});{let D=`action.onSuccess.${r}WithoutItem`,x=p(D);return x!==R("error.unknown")?x:n}}return n}return R("base.success.transaction")},[p,R,A]),f=_(e=>{if(e.errorCode&&T[e.errorCode])return T[e.errorCode];if(e.errorCode&&M[e.errorCode])return p(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=p(s);if(r!==R("error.unknown"))return r}}if(typeof e.data=="string"&&e.data.startsWith("errors.")){let i=p(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(s?.includes("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(n?.response?.errorCode){let a=n.response.errorCode;if(M[a])return p(M[a]);let O=[`errors.auth.${a}`,`errors.data.${a}`,`errors.system.${a}`,`errors.${a}`];for(let D of O){let x=p(D);if(x!==p("error.unknown"))return x}}if(n?.response?.data)return n.response.data}if(t?.response?.message){let n=t.response.message.toLowerCase();return n.includes("expired")?p("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?p("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t.response.message}}catch{return r.toLowerCase().includes("expired")?p("resetPassword.linkExpired","El enlace ha expirado"):r.toLowerCase().includes("invalid")?p("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):r}}return p("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"?p("errors.system.DATABASE_CONNECTION_ERROR"):`${p("errors.data.FIELD_ERROR")}: ${i.join(", ")}`}return I||R("error.unknown")},[T,I,R,p]),o=_(e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),y=_(async(e,i,s)=>{let r=await P.createItem(e,i,s);if(!r.success&&g&&d(r)){let t=f(r),n=o(r);c(t,n,{autoHideDuration:u})}else if(r.success){let t=s?.actionConfig,n=t?.key||"create",a=t?.moduleKey||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),l=_(async(e,i,s)=>{let r=await P.updateItem(e,i,s),t=s?.skipNotifications===!0;if(!t&&!r.success&&g&&d(r)){let n=f(r),a=o(r);c(n,a,{autoHideDuration:u})}else if(!t&&r.success){let n=s?.actionConfig,a=n?.key||"update",O=n?.moduleKey||e;if(C(a,O)){let D=E(a,O,n);c(D,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),F=_(async(e,i,s)=>{let r=await P.deleteItem(e,i,s);if(!r.success&&g&&d(r)){let t=f(r),n=o(r);c(t,n,{autoHideDuration:u})}else if(r.success){let t=s?.actionConfig,n=t?.key||"delete",a=t?.moduleKey||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),L=_(async(e,i,s)=>{let r=await P.readItem(e,i,s);if(!r.success&&g&&d(r)){let t=f(r),n=o(r);c(t,n,{autoHideDuration:u})}return r},[g,c,f,o,u,d]),U=_(async(e,i,s)=>{let r=await P.readItems(e,i,s);if(!r.success&&g&&d(r)){let t=f(r),n=o(r);c(t,n,{autoHideDuration:u})}return r},[g,c,f,o,u,d]),q=_(async(e,i)=>{let s=await P.transaction(e,i),r=i?.skipNotifications===!0;if(!r&&!s.success&&g&&d(s)){let t=f(s),n=o(s);c(t,n,{autoHideDuration:u})}else if(!r&&s.success){let t="transaction",n,a=null;if(i?.actionConfig)a=i.actionConfig,t=a.key,n=a.moduleKey;else if(Array.isArray(e)&&e.length>0&&"operation"in e[0]&&e[0].operation){t=e[0].operation;let O=m.find(D=>D.key===t);O&&(a=O,n=O.moduleKey)}if(C(t,n)){let O=E(t,n,a??void 0);c(O,"success",{autoHideDuration:u})}}return s},[g,C,c,f,o,E,u,d,m]),h=_((e,i)=>{if(!e.success&&g&&d(e)){let s=f(e),r=o(e);c(s,r,{autoHideDuration:u})}else e.success&&N&&i&&c(i,"success",{autoHideDuration:u});return e},[g,N,c,f,o,u,d,R]);return{createItem:y,updateItem:l,deleteItem:F,readItem:L,readItems:U,transaction:q,handleResponse:h,getErrorMessage:f,getErrorSeverity:o,shouldShowNotification:d}};export{J as a,te as b,ae as c,de as d};
|
package/dist/components.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunk5VOTRIDBjs = require('./chunk-5VOTRIDB.js');var _chunk3XZ3TEKQjs = require('./chunk-3XZ3TEKQ.js');require('./chunk-NSV6ECYO.js');require('./chunk-NXTXGTU6.js');var _react = require('react');var _jsxruntime = require('react/jsx-runtime');function z({showBelowMinutes:f=5,position:m="bottom-right",colorNormal:c="#ed6c02",colorCritical:x="#d32f2f",style:u,className:g}={}){let{isAuthenticated:o,tokens:t}=_chunk3XZ3TEKQjs.c.call(void 0, ),[i,y]=_react.useState.call(void 0, 0),[h,C]=_react.useState.call(void 0, 100);if(_react.useEffect.call(void 0, ()=>{if(!o||!t)return;let v=setInterval(()=>{let P=Date.now(),p=t.expiresAt-P,w=900*1e3;y(Math.max(0,p)),C(Math.max(0,p/w*100))},1e3);return()=>clearInterval(v)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),S=Math.floor(i%6e4/1e3);if(e>=f)return null;let s=e<2,a=s?x:c,b={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[m];return _jsxruntime.jsxs.call(void 0, "div",{className:g,style:{position:"fixed",...b,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...u},children:[_jsxruntime.jsxs.call(void 0, "div",{style:{marginBottom:"8px"},children:[_jsxruntime.jsx.call(void 0, "div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),_jsxruntime.jsxs.call(void 0, "div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",S.toString().padStart(2,"0")]})]}),_jsxruntime.jsx.call(void 0, "div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:_jsxruntime.jsx.call(void 0, "div",{style:{width:`${h}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}exports.CrudiaAutoGenerate = _chunk5VOTRIDBjs.o; exports.CrudiaFileField = _chunk5VOTRIDBjs.p; exports.CrudiaMarkdownField = _chunk5VOTRIDBjs.q; exports.CrudifyLogin = _chunk5VOTRIDBjs.h; exports.GlobalNotificationProvider = _chunk3XZ3TEKQjs.d; exports.LoginComponent = _chunk5VOTRIDBjs.m; exports.Policies = _chunk5VOTRIDBjs.l; exports.SessionStatus = _chunk5VOTRIDBjs.n; exports.SessionTimeIndicator = z; exports.UserProfileDisplay = _chunk5VOTRIDBjs.i; exports.useGlobalNotification = _chunk3XZ3TEKQjs.e;
|
package/dist/components.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{h as N,i as T,l as M,m as k,n as G,o as L,p as A,q as R}from"./chunk-
|
|
1
|
+
import{h as N,i as T,l as M,m as k,n as G,o as L,p as A,q as R}from"./chunk-NSA6YDHY.mjs";import{c as d,d as F,e as I}from"./chunk-PARX2RMU.mjs";import"./chunk-JAPL7EZJ.mjs";import"./chunk-6BQGRZYB.mjs";import{useEffect as B,useState as l}from"react";import{jsx as r,jsxs as n}from"react/jsx-runtime";function z({showBelowMinutes:f=5,position:m="bottom-right",colorNormal:c="#ed6c02",colorCritical:x="#d32f2f",style:u,className:g}={}){let{isAuthenticated:o,tokens:t}=d(),[i,y]=l(0),[h,C]=l(100);if(B(()=>{if(!o||!t)return;let v=setInterval(()=>{let P=Date.now(),p=t.expiresAt-P,w=900*1e3;y(Math.max(0,p)),C(Math.max(0,p/w*100))},1e3);return()=>clearInterval(v)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),S=Math.floor(i%6e4/1e3);if(e>=f)return null;let s=e<2,a=s?x:c,b={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[m];return n("div",{className:g,style:{position:"fixed",...b,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...u},children:[n("div",{style:{marginBottom:"8px"},children:[r("div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),n("div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",S.toString().padStart(2,"0")]})]}),r("div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:r("div",{style:{width:`${h}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}export{L as CrudiaAutoGenerate,A as CrudiaFileField,R as CrudiaMarkdownField,N as CrudifyLogin,F as GlobalNotificationProvider,k as LoginComponent,M as Policies,G as SessionStatus,z as SessionTimeIndicator,T as UserProfileDisplay,I as useGlobalNotification};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { J as JwtPayload } from './api-
|
|
1
|
+
import { J as JwtPayload } from './api-slyZ8Gxc.js';
|
|
2
2
|
|
|
3
3
|
interface JWTPayload extends JwtPayload {
|
|
4
4
|
"cognito:username"?: string;
|
|
@@ -10,15 +10,30 @@ declare const isTokenExpired: (token: string) => boolean;
|
|
|
10
10
|
declare const getCookie: (name: string) => string | null;
|
|
11
11
|
|
|
12
12
|
declare class SecureStorage {
|
|
13
|
-
private readonly encryptionKey;
|
|
14
13
|
private readonly storage;
|
|
14
|
+
private encryptionKey;
|
|
15
|
+
private salt;
|
|
16
|
+
private initPromise;
|
|
17
|
+
private initialized;
|
|
15
18
|
constructor(storageType?: "localStorage" | "sessionStorage");
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
+
/**
|
|
20
|
+
* Initialize encryption key asynchronously
|
|
21
|
+
* Must be called before using encryption methods
|
|
22
|
+
*/
|
|
23
|
+
private ensureInitialized;
|
|
24
|
+
private initialize;
|
|
25
|
+
private generateFingerprint;
|
|
26
|
+
private clearLegacyData;
|
|
27
|
+
setItem(key: string, value: string, expiryMinutes?: number): Promise<void>;
|
|
28
|
+
getItem(key: string): Promise<string | null>;
|
|
19
29
|
removeItem(key: string): void;
|
|
20
|
-
|
|
21
|
-
|
|
30
|
+
clear(): void;
|
|
31
|
+
setToken(token: string): Promise<void>;
|
|
32
|
+
getToken(): Promise<string | null>;
|
|
33
|
+
hasValidToken(): Promise<boolean>;
|
|
34
|
+
migrateFromLocalStorage(key: string): Promise<void>;
|
|
35
|
+
private uint8ArrayToBase64;
|
|
36
|
+
private base64ToUint8Array;
|
|
22
37
|
}
|
|
23
38
|
declare const secureSessionStorage: SecureStorage;
|
|
24
39
|
declare const secureLocalStorage: SecureStorage;
|
|
@@ -114,7 +129,15 @@ declare function createErrorTranslator(translateFn: (key: string) => string, opt
|
|
|
114
129
|
message?: string;
|
|
115
130
|
field?: string;
|
|
116
131
|
}) => string;
|
|
117
|
-
translateApiError: (apiResponse:
|
|
132
|
+
translateApiError: (apiResponse: {
|
|
133
|
+
data?: {
|
|
134
|
+
response?: {
|
|
135
|
+
status?: string;
|
|
136
|
+
};
|
|
137
|
+
};
|
|
138
|
+
status?: string;
|
|
139
|
+
code?: string;
|
|
140
|
+
} | null | undefined) => string;
|
|
118
141
|
};
|
|
119
142
|
|
|
120
143
|
export { ERROR_CODES as E, type ParsedError as P, getCookie as a, secureLocalStorage as b, parseTransactionError as c, decodeJwtSafely as d, parseJavaScriptError as e, getErrorMessage as f, getCurrentUserEmail as g, handleCrudifyError as h, isTokenExpired as i, ERROR_SEVERITY_MAP as j, translateErrorCodes as k, translateError as l, createErrorTranslator as m, type ErrorCode as n, type ErrorSeverity as o, parseApiError as p, type ErrorTranslationConfig as q, secureSessionStorage as s, translateErrorCode as t };
|