@nocios/crudify-components 2.0.6 → 2.0.8
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/coverage/coverage-final.json +8 -7
- package/coverage/index.html +24 -24
- package/dist/chunk-2MPTNZJB.js +1 -0
- package/dist/chunk-3U5GG5M4.mjs +1 -0
- package/dist/chunk-4KHK3A5S.mjs +1 -0
- package/dist/{chunk-XZ6OGRJR.mjs → chunk-HRV256AI.mjs} +1 -1
- package/dist/{chunk-RORGWKHP.js → chunk-IKTVS5DX.js} +1 -1
- package/dist/chunk-QM34W6EU.js +1 -0
- package/dist/components.js +1 -1
- package/dist/components.mjs +1 -1
- package/dist/hooks.js +1 -1
- package/dist/hooks.mjs +1 -1
- package/dist/index.js +2 -2
- package/dist/index.mjs +2 -2
- package/package.json +1 -1
- package/dist/chunk-7ORHVSWL.mjs +0 -1
- package/dist/chunk-AOPB3KXB.js +0 -1
- package/dist/chunk-GT7B57S5.mjs +0 -1
- package/dist/chunk-LK6QVSG4.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{g as Xr,i as Jr,j as ye,l as be,n as Qr,o as Zr,r as eo}from"./chunk-4KHK3A5S.mjs";import{g as X}from"./chunk-JAPL7EZJ.mjs";import{a as w,b as jr,d as Kr,f as Gr,p as Yr}from"./chunk-4ILUXVPW.mjs";var ge={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...","resetPassword.passwordRequirementsNotMet":"La contrase\xF1a no cumple con todos los requisitos","passwordRequirements.minLength":"M\xEDnimo 8 caracteres","passwordRequirements.uppercase":"Una letra may\xFAscula","passwordRequirements.lowercase":"Una letra min\xFAscula","passwordRequirements.number":"Un n\xFAmero","passwordRequirements.special":"Un car\xE1cter especial (!@#$%...)","base.btn.showPassword":"Mostrar contrase\xF1a","base.btn.hidePassword":"Ocultar contrase\xF1a","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...","resetPassword.passwordRequirementsNotMet":"Password does not meet all requirements","passwordRequirements.minLength":"Minimum 8 characters","passwordRequirements.uppercase":"One uppercase letter","passwordRequirements.lowercase":"One lowercase letter","passwordRequirements.number":"One number","passwordRequirements.special":"One special character (!@#$%...)","base.btn.showPassword":"Show password","base.btn.hidePassword":"Hide password","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"}},Es=()=>Object.keys(ge),Rs=e=>ge[e]||ge.es;import Qe from"@nocios/crudify-sdk";var ro="crudify_translations_",wt=3600*1e3;function oo(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 mr=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&&w.debug("[TranslationService] Waiting for crudify initialization..."),this.initializationPromise):(this.enableDebug&&w.debug("[TranslationService] Initializing crudify SDK..."),this.initializationPromise=(async()=>{try{let t=Qe.getTokenData();if(t&&t.endpoint){this.enableDebug&&w.debug("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}Qe.config(o);let i=await Qe.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&&w.debug("[TranslationService] Crudify SDK initialized successfully")}catch(t){throw w.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&&w.debug("[TranslationService] fetchTranslations called with:",{apiKeyHash:oo(o),crudifyEnv:i,featureKeys:t,hasUrlTranslations:!!n});let l=this.getFromCache(o),a=l?this.isCacheExpired(l):!0;if(l&&!a)return this.enableDebug&&w.debug("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(l.data.translations,n);try{await this.ensureCrudifyInitialized(o,i)}catch(u){return w.error("[TranslationService] Failed to initialize crudify",u instanceof Error?u:{message:String(u)}),l?(w.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(l.data.translations,n)):(w.warn("[TranslationService] Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&w.debug("[TranslationService] Fetching from API via crudify SDK");let u=await this.fetchFromAPI(t);this.hasDataChanged(l,u)||!l?this.saveToCache(o,u):this.refreshCacheTimestamp(o);let d=this.mergeWithUrlTranslations(u.translations,n);return this.enableDebug&&w.debug("[TranslationService] Translations loaded:",{languages:Object.keys(d),keysCount:d[Object.keys(d)[0]]?Object.keys(d[Object.keys(d)[0]]).length:0}),d}catch(u){return w.error("[TranslationService] API fetch failed",u instanceof Error?u:{message:String(u)}),l?(w.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(l.data.translations,n)):(w.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(r){let o=await Qe.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&&w.debug("[TranslationService] Saved to cache:",{cacheKey:t})}catch(t){w.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 w.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){w.error("[TranslationService] Failed to refresh cache timestamp",o instanceof Error?o:{message:String(o)})}}isCacheExpired(r){return Date.now()-r.cachedAt>wt}hasValidCache(r){let o=this.getFromCache(r);return o?!this.isCacheExpired(o):!1}getCacheKey(r){return`${ro}${oo(r)}`}getCriticalTranslationsOnly(){return ge}invalidateCache(r){let o=this.getCacheKey(r);localStorage.removeItem(o),this.enableDebug&&w.debug("[TranslationService] Cache invalidated:",{cacheKey:o})}async prefetchTranslations(r){try{await this.fetchTranslations(r),this.enableDebug&&w.debug("[TranslationService] Prefetch completed")}catch(o){w.error("[TranslationService] Prefetch failed",o instanceof Error?o:{message:String(o)})}}clearAllCaches(){try{let o=Object.keys(localStorage).filter(t=>t.startsWith(ro));o.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&w.debug(`[TranslationService] Cleared ${o.length} cache entries`)}catch(r){w.error("[TranslationService] Failed to clear caches",r instanceof Error?r:{message:String(r)})}}},Ze=mr.getInstance();import{createContext as xt,useContext as Pt,useEffect as io,useState as Fe,useMemo as to,useCallback as Ct}from"react";import{Fragment as Tt,jsx as rr}from"react/jsx-runtime";var er=null,fr=!1,so=xt(null);function no(e,r,o){return{...e,...r,...o||{}}}function vt(e,r,o,t,i){io(()=>{if(!t||!e||!r)return;let n=o||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!n||!n.addResourceBundle){i&&w.debug("[TranslationsProvider] i18next not found, skipping auto-sync");return}i&&w.debug("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:r}),Object.keys(e).forEach(l=>{e[l]&&Object.keys(e[l]).length>0&&(n.addResourceBundle(l,"translation",e[l],!0,!0),i&&w.debug(`[TranslationsProvider] Synced ${Object.keys(e[l]).length} keys for language: ${l}`))}),n.language!==r&&n.changeLanguage&&(n.changeLanguage(r),i&&w.debug(`[TranslationsProvider] Changed i18next language to: ${r}`))},[e,r,o,t,i])}var zs=({children:e,apiKey:r,crudifyEnv:o="prod",featureKeys:t,language:i="es",devTranslations:n,translationUrl:l,enableDebug:a=!1,skipAutoInit:u=!0,autoSyncI18n:y=!0,i18nInstance:d,loadingFallback:b,waitForInitialLoad:x=!0})=>{let c=to(()=>Kr({publicApiKey:r,env:o,featureKeys:t,enableDebug:a}),[r,o,t,a]),s=c.publicApiKey||"",h=c.env||o||"prod",m=c.featureKeys||t,[p,f]=Fe({}),[C,S]=Fe(!0),[B,g]=Fe(!0),[P,k]=Fe(null),[A,J]=Fe(void 0),[le,Z]=Fe(!1),ne=Ct(async()=>{if(!s){a&&w.debug("[TranslationsProvider] No apiKey - skipping translation fetch"),S(!1),g(!1);return}if(le){a&&w.debug("[TranslationsProvider] Skipping reload - using fallback translations");return}if(Ze.hasValidCache(s)&&B&&(a&&w.debug("[TranslationsProvider] Valid cache found - not blocking initial render"),g(!1)),fr&&er){a&&w.debug("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let E=await er;f(E),S(!1);return}catch{a&&w.warn("[TranslationsProvider] Global fetch failed, retrying")}}fr=!0,S(!0),k(null);let W;if(l)try{a&&w.debug(`[TranslationsProvider] Fetching translations from URL: ${l}`);let E=await fetch(l);if(!E.ok)throw new Error(`Failed to fetch translations: ${E.statusText}`);W=await E.json(),J(W),a&&w.debug("[TranslationsProvider] URL translations loaded:",{keysCount:W?Object.keys(W).length:0})}catch(E){w.error("[TranslationsProvider] Failed to load URL translations",E instanceof Error?E:{message:String(E)}),W=void 0,J(void 0)}let ee=(async()=>{try{Ze.setDebug(a);let E=await Ze.fetchTranslations({apiKey:s,crudifyEnv:h,featureKeys:m,urlTranslations:W}),R={};return Object.keys(E).forEach(q=>{let ie=ge[q]||{},re=E[q]||{};R[q]=no(ie,re,n)}),a&&w.debug("[TranslationsProvider] Loaded translations:",{languages:Object.keys(R),keysCount:Object.keys(R[i]||{}).length}),R}catch(E){w.error("[TranslationsProvider] Failed to load",E instanceof Error?E:{message:String(E)}),k(E instanceof Error?E.message:String(E)),Z(!0);let R={};return Object.keys(ge).forEach(q=>{let ie=ge[q],re=W||A||{};R[q]=no(ie,re,n)}),a&&w.debug("[TranslationsProvider] Using fallback translations (critical + URL)"),R}})();er=ee;try{let E=await ee;f(E)}finally{S(!1),g(!1),fr=!1,setTimeout(()=>{er=null},1e3)}},[s,h,m,l,n,a,i,le]);io(()=>{ne();let V=setInterval(ne,3600*1e3);return()=>clearInterval(V)},[ne]);let ze=to(()=>(V,W)=>{let E=(p[i]||{})[V];if(!E){let R=Object.keys(p);for(let q of R)if(p[q][V]){E=p[q][V];break}}return E||(a&&w.warn(`[TranslationsProvider] Missing translation: "${V}"`),E=V),W&&typeof E=="string"&&Object.entries(W).forEach(([R,q])=>{let ie=new RegExp(`{{${R}}}`,"g");E=E.replace(ie,String(q))}),E},[p,i,a]);vt(p,i,d,y,a);let ke={t:ze,language:i,availableLanguages:Object.keys(p),translations:p,isLoading:C,error:P,refreshTranslations:ne};return s?x&&B&&C?b||rr("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:rr("div",{children:"Loading translations..."})}):rr(so.Provider,{value:ke,children:e}):(a&&w.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),rr(Tt,{children:e}))},Me=()=>{let e=Pt(so);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};var Et=/^[a-zA-Z0-9\-_./\?=&%#]+$/,Rt=[/^https?:\/\//i,/^ftp:\/\//i,/^\/\//,/javascript:/i,/data:/i,/vbscript:/i,/about:/i,/\.\.\//,/\.\.\\/,/%2e%2e%2f/i,/%2e%2e%5c/i,/%2f%2f/i,/%5c%5c/i,/[\x00-\x1f\x7f-\x9f]/,/\\/],ao=(e,r="/")=>{if(!e||typeof e!="string")return r;let o=e.trim();if(!o)return r;if(!o.startsWith("/"))return w.warn("Open redirect blocked (relative path)",{path:e}),r;if(!Et.test(o))return w.warn("Open redirect blocked (invalid characters)",{path:e}),r;let t=o.toLowerCase();for(let n of Rt)if(n.test(t))return w.warn("Open redirect blocked (dangerous pattern)",{path:e}),r;let i=o.split("?")[0].split("/").filter(Boolean);if(i.length===0)return o;for(let n of i)if(n===".."||n.includes(":")||n.length>100)return w.warn("Open redirect blocked (suspicious path part)",{part:n}),r;return o},St=[/^files\.nocios\.link$/,/^files\.crudia\.com$/,/^[a-z0-9][a-z0-9-]*\.nocios\.link$/,/^[a-z0-9][a-z0-9-]*\.crudia\.com$/],lo=(e,r="/")=>{if(!e||typeof e!="string")return r;let o=e.trim();if(!o)return r;if(o.startsWith("/"))return ao(o,r);try{if(o.includes("..")||o.includes("//",8))return w.warn("Redirect blocked (dangerous path pattern)",{url:o}),r;let t=new URL(o);if(t.protocol!=="https:")return w.warn("Redirect blocked (non-HTTPS protocol)",{url:o}),r;let i=t.hostname.toLowerCase();return St.some(l=>l.test(i))?o:(w.warn("Redirect blocked (untrusted domain)",{url:o,hostname:i}),r)}catch{return w.warn("Redirect blocked (invalid URL)",{url:o}),r}},Vs=(e,r="/")=>{try{let t=(typeof e=="string"?new URLSearchParams(e):e).get("redirect");if(!t)return r;let i=decodeURIComponent(t);return ao(i,r)}catch(o){return w.warn("Error parsing redirect parameter",o instanceof Error?{errorMessage:o.message}:{message:String(o)}),r}};import{Box as co,Typography as It}from"@mui/material";import kt from"@mui/icons-material/CheckCircle";import At from"@mui/icons-material/RadioButtonUnchecked";import{jsx as qe,jsxs as _t}from"react/jsx-runtime";var Lt=({message:e,valid:r})=>_t(co,{sx:{display:"flex",alignItems:"center",gap:.5,py:.25},children:[r?qe(kt,{sx:{fontSize:16,color:"success.main"}}):qe(At,{sx:{fontSize:16,color:"text.disabled"}}),qe(It,{variant:"caption",sx:{color:r?"success.main":"text.secondary",transition:"color 0.2s ease"},children:e})]}),Ft=({requirements:e,show:r=!0})=>!r||e.length===0?null:qe(co,{sx:{mt:.5,mb:1,px:.5},children:e.map((o,t)=>qe(Lt,{message:o.message,valid:o.valid},t))}),uo=Ft;var Dt=/[A-Z]/,Ot=/[a-z]/,Bt=/[0-9]/,Nt=/[!@#$%^&*()_+\-=\[\]{}|;:,.<>?]/,zt=/^[A-Za-z0-9]+$/;function po(e,r){return r.map(o=>{let t=!0;switch(o.type){case"minLength":t=e.length>=Number(o.value??0);break;case"alphanumeric":t=e.length>0&&zt.test(e);break;case"uppercase":t=Dt.test(e);break;case"lowercase":t=Ot.test(e);break;case"number":t=Bt.test(e);break;case"special":t=Nt.test(e);break;default:t=!0}return{message:o.message,valid:t,enforce:!!o.enforce}})}function go(e){return e.filter(r=>r.enforce).every(r=>r.valid)}var mo=[{type:"minLength",value:8,message:"passwordRequirements.minLength",enforce:!0},{type:"uppercase",message:"passwordRequirements.uppercase",enforce:!0},{type:"lowercase",message:"passwordRequirements.lowercase",enforce:!0},{type:"number",message:"passwordRequirements.number",enforce:!0},{type:"special",message:"passwordRequirements.special",enforce:!0}];import{Box as En,Typography as Rn}from"@mui/material";import{createContext as Mt,useContext as qt,useMemo as yr}from"react";import{useState as hr,useEffect as Ut}from"react";var fo=(e,r)=>{let[o,t]=hr({}),[i,n]=hr(!1),[l,a]=hr(null);return Ut(()=>{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||(w.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:l}};import{jsx as ho}from"react/jsx-runtime";var yo=Mt(null),Vt=()=>{try{return Me()}catch{return null}},Wt=(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]},bo=({children:e,translations:r,translationsUrl:o,language:t="en"})=>{let n=Vt()?.translations?.[t]||{},{translations:l,loading:a}=fo(o,r),u=yr(()=>({...n,...l,...r||{}}),[n,l,r]),y=yr(()=>(b,x)=>{let c=Wt(u,b);return c==null&&(c=b),x&&typeof c=="string"&&Object.entries(x).forEach(([s,h])=>{c=c.replace(new RegExp(`{{${s}}}`,"g"),h)}),typeof c=="string"?c:b},[u]),d=yr(()=>({t:y,language:t}),[y,t]);return a?ho("div",{children:"Loading translations..."}):ho(yo.Provider,{value:d,children:e})},oe=()=>{let e=qt(yo);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};import{createContext as Ht,useContext as $t,useReducer as jt,useEffect as br,useCallback as Kt}from"react";import{jsx as Yt}from"react/jsx-runtime";var wo={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function Gt(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"CLEAR_SEARCH_PARAMS":return{...e,searchParams:{}};case"UPDATE_FORM_DATA":return{...e,formData:{...e.formData,...r.payload},errors:{...e.errors,...Object.keys(r.payload).reduce((n,l)=>({...n,[l]: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:wo.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 xo=Ht(void 0),Po=({children:e,initialScreen:r="login",config:o,autoReadFromCookies:t=!0})=>{let[i,n]=jt(Gt,{...wo,currentScreen:r});br(()=>{n({type:"INIT_CONFIG",payload:(()=>{let s={};if(t)try{let h=jr();h.configSource!=="none"&&h.logo&&(s.logo=h.logo)}catch(h){w.error("Error reading configuration",h instanceof Error?h:{message:String(h)})}return{publicApiKey:o?.publicApiKey,env:o?.env,appName:o?.appName,logo:o?.logo||s.logo,loginActions:o?.loginActions}})()})},[o,t]),br(()=>{let c=new URLSearchParams(window.location.search),s={};c.forEach((h,m)=>{s[m]=h}),Object.keys(s).length>0&&n({type:"SET_SEARCH_PARAMS",payload:s}),r==="checkCode"&&s.email&&n({type:"UPDATE_FORM_DATA",payload:{email:s.email,code:s.code||""}}),r==="resetPassword"&&s.link&&n({type:"SET_SEARCH_PARAMS",payload:s})},[r]),br(()=>{let c=Gr.subscribe(s=>{(s.type==="LOGOUT"||s.type==="SESSION_EXPIRED")&&(w.debug("LoginStateProvider: Clearing state due to auth event",{type:s.type}),n({type:"CLEAR_SEARCH_PARAMS"}),n({type:"RESET_FORM"}))});return()=>c()},[]);let l=(c,s)=>{n({type:"SET_SCREEN",payload:{screen:c,params:s}})},a=c=>{n({type:"UPDATE_FORM_DATA",payload:c})},u=(c,s)=>{n({type:"SET_ERRORS",payload:{[c]:s}})},y=()=>{n({type:"CLEAR_ERRORS"})},d=c=>{n({type:"SET_LOADING",payload:c})},b=Kt(()=>{n({type:"CLEAR_SEARCH_PARAMS"})},[]),x={state:i,dispatch:n,setScreen:l,updateFormData:a,setFieldError:u,clearErrors:y,setLoading:d,clearSearchParams:b};return Yt(xo.Provider,{value:x,children:e})},or=()=>{let e=$t(xo);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};import{useEffect as Xt,useRef as Jt}from"react";import{Typography as wr,TextField as Co,Button as Qt,Box as Ve,CircularProgress as Zt,Alert as en,Link as vo}from"@mui/material";import{Fragment as on,jsx as te,jsxs as We}from"react/jsx-runtime";var rn=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:i="/"})=>{let{state:n,updateFormData:l,setFieldError:a,clearErrors:u,setLoading:y}=or(),{login:d}=be(),b=oe(),{t:x}=b,c="i18n"in b?b.i18n:void 0,s=Jt(null),h=Yr(x,{currentLanguage:c?.language,enableDebug:!1}),m=()=>{if(n.searchParams.redirect)try{let g=decodeURIComponent(n.searchParams.redirect);return lo(g,i||"/")}catch{}return i||"/"};Xt(()=>{let g=setTimeout(()=>{s.current&&s.current.focus()},100);return()=>clearTimeout(g)},[]);let p=g=>h.translateError({code:g.code,message:g.message,field:g.field}),f=async()=>{if(!n.loading){if(!n.formData.username.trim()){a("username",x("login.usernameRequired"));return}if(!n.formData.password.trim()){a("password",x("login.passwordRequired"));return}u(),y(!0);try{let g=await d(n.formData.username,n.formData.password);if(y(!1),g.success){let P=m();o&&o(g.data,P)}else{let P=g.rawResponse||g;C(P)}}catch(g){y(!1);let k=X(g).map(p);a("global",k),t&&t(k.join(", "))}}},C=g=>{let P=X(g),k=[];P.forEach(A=>{A.field?a(A.field,p(A)):k.push(p(A))}),k.length>0&&a("global",k)};return We(on,{children:[We(Ve,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),f()},onKeyDown:g=>{g.key==="Enter"&&!n.loading&&(g.preventDefault(),f())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[We(Ve,{sx:{mb:1},children:[te(wr,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:x("login.usernameOrEmailLabel")}),te(Co,{fullWidth:!0,id:"email",name:"email",type:"email",value:n.formData.username,disabled:n.loading,onChange:g=>l({username:g.target.value}),error:!!n.errors.username,helperText:n.errors.username,autoComplete:"email",placeholder:x("login.usernameOrEmailPlaceholder"),inputRef:s,required:!0})]}),We(Ve,{sx:{mb:1},children:[te(wr,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:x("login.passwordLabel")}),te(Co,{fullWidth:!0,id:"password",name:"password",type:"password",value:n.formData.password,disabled:n.loading,onChange:g=>l({password:g.target.value}),error:!!n.errors.password,helperText:n.errors.password,autoComplete:"current-password",placeholder:x("login.passwordPlaceholder"),required:!0})]}),n.config.loginActions?.includes("forgotPassword")&&te(Ve,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:te(vo,{sx:{cursor:"pointer"},onClick:()=>{e?.("forgotPassword",n.searchParams)},variant:"body2",color:"secondary",children:x("login.forgotPasswordLink")})}),te(Qt,{disabled:n.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:n.loading?te(Zt,{size:20}):x("login.loginButton")})]}),te(Ve,{children:n.errors.global&&n.errors.global.length>0&&n.errors.global.map((g,P)=>te(en,{variant:"filled",sx:{mt:2},severity:"error",children:te("div",{children:g})},P))}),n.config.loginActions?.includes("createUser")&&We(wr,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[x("login.noAccountPrompt")," ",te(vo,{sx:{cursor:"pointer"},onClick:()=>{let P=`/public/users/create${Object.keys(n.searchParams).length>0?`?${new URLSearchParams(n.searchParams).toString()}`:""}`;r?.(P)},fontWeight:"medium",color:"secondary",children:x("login.signUpLink")})]})]})},To=rn;import{useState as _e,useEffect as tn,useRef as nn}from"react";import{Typography as De,TextField as sn,Button as Eo,Box as we,CircularProgress as an,Alert as ln,Link as xr}from"@mui/material";import{Fragment as Ro,jsx as M,jsxs as Re}from"react/jsx-runtime";var cn=({onScreenChange:e,onError:r})=>{let{crudify:o}=ye(),[t,i]=_e(""),[n,l]=_e(!1),[a,u]=_e([]),[y,d]=_e(null),[b,x]=_e(!1),[c,s]=_e(!1),h=nn(null),{t:m}=oe();tn(()=>{h.current&&!b&&!c&&h.current.focus()},[b,c]);let p=P=>{let k=[`errors.auth.${P.code}`,`errors.data.${P.code}`,`errors.system.${P.code}`,`errors.${P.code}`,`forgotPassword.${P.code.toLowerCase()}`];for(let A of k){let J=m(A);if(J!==A)return J}return P.message||m("base.errors.errorUnknown")},f=P=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(P),C=async()=>{if(!(n||!o)){if(u([]),d(null),!t){d(m("forgotPassword.emailRequired"));return}if(!f(t)){d(m("forgotPassword.invalidEmail"));return}l(!0);try{let P=[{operation:"requestPasswordReset",data:{email:t}}],k=await o.transaction(P);if(k.success)k.data&&k.data.existingCodeValid?s(!0):x(!0);else{let J=X(k).map(p);u(J)}}catch(P){let A=X(P).map(p);u(A),r&&r(A.join(", "))}finally{l(!1)}}},S=()=>{e?.("login")},B=()=>{if(b||c){e?.("checkCode",{email:t});return}if(!t){d(m("forgotPassword.emailRequired"));return}if(!f(t)){d(m("forgotPassword.invalidEmail"));return}e?.("checkCode",{email:t})};return b||c?M(Ro,{children:Re(we,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[Re(we,{sx:{mb:2},children:[M(De,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m(c?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),M(De,{variant:"body2",sx:{color:c?"success.main":"grey.600"},children:m("forgotPassword.checkEmailInstructions")})]}),M(Eo,{type:"button",onClick:B,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:m("forgotPassword.enterCodeLink")}),M(we,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:M(xr,{sx:{cursor:"pointer"},onClick:S,variant:"body2",color:"secondary",children:m("base.btn.back")})})]})}):Re(Ro,{children:[Re(we,{component:"form",noValidate:!0,onSubmit:P=>{P.preventDefault(),C()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Re(we,{sx:{mb:2},children:[M(De,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m("forgotPassword.title")}),M(De,{variant:"body2",sx:{color:"grey.600"},children:m("forgotPassword.instructions")})]}),Re(we,{sx:{mb:1},children:[M(De,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:m("forgotPassword.emailLabel")}),M(sn,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:n,onChange:P=>i(P.target.value),error:!!y,helperText:y,autoComplete:"email",placeholder:m("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:h})]}),M(Eo,{disabled:n,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?M(an,{size:20}):m("forgotPassword.sendCodeButton")}),Re(we,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[M(xr,{sx:{cursor:"pointer"},onClick:S,variant:"body2",color:"secondary",children:m("base.btn.back")}),M(De,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),M(xr,{sx:{cursor:"pointer"},onClick:B,variant:"body2",color:"secondary",children:m("login.alreadyHaveCodeLink")})]})]}),M(we,{children:a.length>0&&a.map((P,k)=>M(ln,{variant:"filled",sx:{mt:2},severity:"error",children:P},k))})]})},So=cn;import{useState as H,useEffect as Io,useMemo as Pr}from"react";import{Typography as tr,TextField as ko,Button as dn,Box as xe,CircularProgress as Ao,Alert as Lo,Link as un,IconButton as Fo,InputAdornment as _o}from"@mui/material";import Do from"@mui/icons-material/Visibility";import Oo from"@mui/icons-material/VisibilityOff";import{Fragment as gn,jsx as F,jsxs as He}from"react/jsx-runtime";var pn=({onScreenChange:e,onError:r,searchParams:o,onResetSuccess:t,passwordRules:i})=>{let{crudify:n}=ye(),[l,a]=H(""),[u,y]=H(""),[d,b]=H(!1),[x,c]=H([]),[s,h]=H(null),[m,p]=H(null),[f,C]=H(""),[S,B]=H(""),[g,P]=H(!1),[k,A]=H(!0),[J,le]=H(!1),[Z,ne]=H(null),[ze,ke]=H(!1),[V,W]=H(!1),[ee,E]=H(!1),{t:R}=oe(),q=Pr(()=>(i||mo).map(_=>({..._,message:R(_.message)})),[i,R]),ie=Pr(()=>po(l,q),[l,q]),re=Pr(()=>go(ie),[ie]),Ue=l===u,Ee=I=>{let _=[`errors.auth.${I.code}`,`errors.data.${I.code}`,`errors.system.${I.code}`,`errors.${I.code}`,`resetPassword.${I.code.toLowerCase()}`];for(let U of _){let K=R(U);if(K!==U)return K}return I.message||R("base.errors.errorUnknown")},Ae=I=>o?o instanceof URLSearchParams?o.get(I):o[I]||null:null;Io(()=>{if(o){if(o){let I=Ae("fromCodeVerification"),_=Ae("email"),U=Ae("code");if(I==="true"&&_&&U){C(_),B(U),P(!0),le(!0),A(!1);return}let K=Ae("link");if(K)try{let G=decodeURIComponent(K),[Y,he]=G.split("/");if(Y&&he&&Y.length===6){B(Y),C(he),P(!1),ne({email:he,code:Y});return}}catch{}if(_&&U){C(_),B(U),P(!1),ne({email:_,code:U});return}}c([R("resetPassword.invalidCode")]),A(!1),setTimeout(()=>e?.("forgotPassword"),3e3)}},[o,n,R,e]),Io(()=>{n&&Z&&!ze&&(ke(!0),(async(_,U)=>{try{let K=[{operation:"validatePasswordResetCode",data:{email:_,codePassword:U}}],G=await n.transaction(K);if(G.data&&Array.isArray(G.data)){let Y=G.data[0];if(Y&&Y.response&&Y.response.status==="OK"){le(!0);return}}if(G.success)le(!0);else{let he=X(G).map(Ee);c(he),setTimeout(()=>e?.("forgotPassword"),3e3)}}catch(K){let Y=X(K).map(Ee);c(Y),setTimeout(()=>e?.("forgotPassword"),3e3)}finally{A(!1),ne(null),ke(!1)}})(Z.email,Z.code))},[n,Z,R,e]);let Xe=async()=>{if(d||!n)return;c([]),h(null),p(null);let I=!1;if(l?re||(h(R("resetPassword.passwordRequirementsNotMet")),I=!0):(h(R("resetPassword.newPasswordRequired")),I=!0),u?Ue||(p(R("resetPassword.passwordsDoNotMatch")),I=!0):(p(R("resetPassword.confirmPasswordRequired")),I=!0),!I){b(!0);try{let _=[{operation:"validateAndResetPassword",data:{email:f,codePassword:S,newPassword:l}}],U=await n.transaction(_);if(U.success)c([]),setTimeout(()=>{t?.()},1e3);else{let G=X(U).map(Ee);c(G)}}catch(_){let K=X(_).map(Ee);c(K),r&&r(K.join(", "))}b(!1)}},Nr=()=>{g?e?.("checkCode",{email:f}):e?.("forgotPassword")};return k?F(xe,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:F(Ao,{})}):J?He(gn,{children:[He(xe,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[He(xe,{sx:{mb:2},children:[F(tr,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:R("resetPassword.title")}),F(tr,{variant:"body2",sx:{color:"grey.600"},children:R("resetPassword.instructions")})]}),He(xe,{sx:{mb:1},children:[F(tr,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:R("resetPassword.newPasswordLabel")}),F(ko,{fullWidth:!0,id:"newPassword",name:"newPassword",type:V?"text":"password",value:l,disabled:d,onChange:I=>a(I.target.value),error:!!s,helperText:s,autoComplete:"new-password",placeholder:R("resetPassword.newPasswordPlaceholder"),required:!0,InputProps:{endAdornment:F(_o,{position:"end",children:F(Fo,{"aria-label":R(V?"base.btn.hidePassword":"base.btn.showPassword"),onClick:()=>W(!V),edge:"end",size:"small",disabled:d,children:V?F(Oo,{}):F(Do,{})})})}}),F(uo,{requirements:ie,show:l.length>0})]}),He(xe,{sx:{mb:1},children:[F(tr,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:R("resetPassword.confirmPasswordLabel")}),F(ko,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:ee?"text":"password",value:u,disabled:d,onChange:I=>y(I.target.value),error:!!m,helperText:m,autoComplete:"new-password",placeholder:R("resetPassword.confirmPasswordPlaceholder"),required:!0,InputProps:{endAdornment:F(_o,{position:"end",children:F(Fo,{"aria-label":R(ee?"base.btn.hidePassword":"base.btn.showPassword"),onClick:()=>E(!ee),edge:"end",size:"small",disabled:d,children:ee?F(Oo,{}):F(Do,{})})})}})]}),F(dn,{disabled:d||!re||!Ue||!l||!u,type:"button",onClick:Xe,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:d?F(Ao,{size:20}):R("resetPassword.resetPasswordButton")}),F(xe,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:F(un,{sx:{cursor:"pointer"},onClick:Nr,variant:"body2",color:"secondary",children:R("base.btn.back")})})]}),F(xe,{children:x.length>0&&x.map((I,_)=>F(Lo,{variant:"filled",sx:{mt:2},severity:"error",children:I},_))})]}):F(xe,{children:x.length>0&&x.map((I,_)=>F(Lo,{variant:"filled",sx:{mt:2},severity:"error",children:I},_))})},Bo=pn;import{useState as $e,useEffect as No,useRef as mn}from"react";import{Typography as Cr,TextField as fn,Button as hn,Box as je,CircularProgress as yn,Alert as bn,Link as wn}from"@mui/material";import{Fragment as Pn,jsx as de,jsxs as nr}from"react/jsx-runtime";var xn=({onScreenChange:e,onError:r,searchParams:o})=>{let{crudify:t}=ye(),[i,n]=$e(""),[l,a]=$e(!1),[u,y]=$e([]),[d,b]=$e(null),[x,c]=$e(""),s=mn(null),{t:h}=oe(),m=g=>o?o instanceof URLSearchParams?o.get(g):o[g]||null:null,p=g=>{let P=[`errors.auth.${g.code}`,`errors.data.${g.code}`,`errors.system.${g.code}`,`errors.${g.code}`,`checkCode.${g.code.toLowerCase()}`];for(let k of P){let A=h(k);if(A!==k)return A}return g.message||h("base.errors.errorUnknown")};No(()=>{let g=m("email");g?c(g):e?.("forgotPassword")},[o,e]),No(()=>{s.current&&s.current.focus()},[]);let f=async()=>{if(!(l||!t)){if(y([]),b(null),!i){b(h("checkCode.codeRequired"));return}if(i.length!==6){b(h("checkCode.codeRequired"));return}a(!0);try{let g=[{operation:"validatePasswordResetCode",data:{email:x,codePassword:i}}],P=await t.transaction(g);if(P.success)e?.("resetPassword",{email:x,code:i,fromCodeVerification:"true"});else{let A=X(P).map(p);y(A),a(!1)}}catch(g){let k=X(g).map(p);y(k),a(!1),r&&r(k.join(", "))}}},C=()=>{e?.("forgotPassword")},S=g=>{let P=g.target.value.replace(/\D/g,"").slice(0,6);n(P)};return nr(Pn,{children:[nr(je,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),f()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[nr(je,{sx:{mb:2},children:[de(Cr,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:h("checkCode.title")}),de(Cr,{variant:"body2",sx:{color:"grey.600"},children:h("checkCode.instructions")})]}),nr(je,{sx:{mb:1},children:[de(Cr,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:h("checkCode.codeLabel")}),de(fn,{fullWidth:!0,id:"code",name:"code",type:"text",value:i,disabled:l,onChange:S,error:!!d,helperText:d,placeholder:h("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:s})]}),de(hn,{disabled:l||i.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:l?de(yn,{size:20}):h("checkCode.verifyButton")}),de(je,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:de(wn,{sx:{cursor:"pointer"},onClick:C,variant:"body2",color:"secondary",children:h("base.btn.back")})})]}),de(je,{children:u.length>0&&u.map((g,P)=>de(bn,{sx:{mt:2},severity:"error",children:g},P))})]})},zo=xn;import{Box as Cn,CircularProgress as vn,Alert as Uo,Typography as vr}from"@mui/material";import{Fragment as Tn,jsx as Oe,jsxs as Mo}from"react/jsx-runtime";var qo=({children:e,fallback:r})=>{let{isLoading:o,error:t,isInitialized:i}=ye(),{t:n}=oe();return o?r||Mo(Cn,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[Oe(vn,{}),Oe(vr,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):t?Oe(Uo,{severity:"error",sx:{mt:2},children:Mo(vr,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",t]})}):i?Oe(Tn,{children:e}):Oe(Uo,{severity:"warning",sx:{mt:2},children:Oe(vr,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as se,jsxs as kn}from"react/jsx-runtime";var Sn=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:i="/",passwordRules:n})=>{let{t:l}=oe(),{state:a,setScreen:u}=or(),{config:y}=be(),{showNotification:d}=Xr(),b=(c,s)=>{let h=s;c==="login"?h={}:c==="forgotPassword"&&!s&&(h={}),u(c,h),e?.(c,h)},x=()=>{let c={onScreenChange:b,onExternalNavigate:r,onError:t,redirectUrl:i};switch(a.currentScreen){case"forgotPassword":return se(So,{...c});case"checkCode":return se(zo,{...c,searchParams:a.searchParams});case"resetPassword":return se(Bo,{...c,searchParams:a.searchParams,passwordRules:n,onResetSuccess:()=>{let s=l("resetPassword.successMessage");d(s,"success"),b("login")}});default:return se(To,{...c,onLoginSuccess:o})}};return kn(qo,{children:[se(En,{sx:{display:"flex",justifyContent:"center",mb:3},children:se("img",{src:y.logo||"https://logos.crudia.com/nocios-default.png",alt:l("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:c=>{let s=c.target;s.src="https://logos.crudia.com/nocios-default.png"}})}),!y.logo&&y.appName&&se(Rn,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:y.appName}),x()]})},In=({translations:e,translationsUrl:r,language:o="en",initialScreen:t="login",autoReadFromCookies:i=!0,...n})=>{let{config:l}=be();return se(bo,{translations:e,translationsUrl:r,language:o,children:se(Jr,{config:l,children:se(Po,{config:l,initialScreen:t,autoReadFromCookies:i,children:se(Sn,{...n})})})})},ul=In;import{Box as Q,Card as Vo,CardContent as Wo,Typography as ae,Chip as ir,Avatar as An,Divider as Ln,CircularProgress as Fn,Alert as Ho,List as _n,ListItem as Tr,ListItemText as Er,ListItemIcon as Dn,Collapse as On,IconButton as Rr}from"@mui/material";import{Person as Bn,Email as Nn,Badge as zn,Security as Un,Schedule as Mn,AccountCircle as qn,ExpandMore as Vn,ExpandLess as Wn,Info as Hn}from"@mui/icons-material";import{useState as $n}from"react";import{Fragment as Gn,jsx as T,jsxs as D}from"react/jsx-runtime";var jn=({showExtendedData:e=!0,showProfileCard:r=!0,autoRefresh:o=!0})=>{let{userProfile:t,loading:i,error:n,extendedData:l,refreshProfile:a}=Qr({autoFetch:o,retryOnError:!0,maxRetries:3}),[u,y]=$n(!1);if(i)return D(Q,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[T(Fn,{}),T(ae,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return D(Ho,{severity:"error",action:T(Rr,{color:"inherit",size:"small",onClick:a,children:T(ae,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!t)return T(Ho,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let d=l?.displayData||{},b=l?.totalFields||0,x=f=>{if(!f)return"No disponible";try{return new Date(f).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return f}},c=(f,C)=>C==null?"No disponible":typeof C=="boolean"?C?"S\xED":"No":Array.isArray(C)?C.length>0?C.join(", "):"Ninguno":typeof C=="object"?JSON.stringify(C,null,2):String(C),s=[{key:"id",label:"ID",icon:T(zn,{})},{key:"email",label:"Email",icon:T(Nn,{})},{key:"username",label:"Usuario",icon:T(Bn,{})},{key:"fullName",label:"Nombre completo",icon:T(qn,{})},{key:"role",label:"Rol",icon:T(Un,{})}],h=[{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=[...s.map(f=>f.key),...h.map(f=>f.key),"permissions"],p=Object.keys(d).filter(f=>!m.includes(f)).map(f=>({key:f,label:f}));return D(Q,{children:[r&&T(Vo,{sx:{mb:2},children:D(Wo,{children:[D(Q,{display:"flex",alignItems:"center",mb:2,children:[T(An,{src:d.avatar,sx:{width:56,height:56,mr:2},children:d.fullName?.[0]||d.username?.[0]||d.email?.[0]}),D(Q,{children:[T(ae,{variant:"h6",children:d.fullName||d.username||d.email}),T(ae,{variant:"body2",color:"text.secondary",children:d.role||"Usuario"}),d.isActive!==void 0&&T(ir,{label:d.isActive?"Activo":"Inactivo",color:d.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),T(Q,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:s.map(({key:f,label:C,icon:S})=>d[f]?D(Q,{display:"flex",alignItems:"center",children:[T(Q,{sx:{mr:1,color:"text.secondary"},children:S}),D(Q,{children:[T(ae,{variant:"caption",color:"text.secondary",children:C}),T(ae,{variant:"body2",children:c(f,d[f])})]})]},f):null)}),d.permissions&&Array.isArray(d.permissions)&&d.permissions.length>0&&D(Q,{mt:2,children:[T(ae,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),D(Q,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[d.permissions.slice(0,5).map((f,C)=>T(ir,{label:f,size:"small",variant:"outlined"},C)),d.permissions.length>5&&T(ir,{label:`+${d.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&T(Vo,{children:D(Wo,{children:[D(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[D(ae,{variant:"h6",display:"flex",alignItems:"center",children:[T(Hn,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),T(ir,{label:`${b} campos totales`,size:"small"})]}),D(_n,{dense:!0,children:[h.map(({key:f,label:C})=>d[f]!==void 0&&D(Tr,{divider:!0,children:[T(Dn,{children:T(Mn,{fontSize:"small"})}),T(Er,{primary:C,secondary:f.includes("At")||f.includes("Login")?x(d[f]):c(f,d[f])})]},f)),p.length>0&&D(Gn,{children:[T(Ln,{sx:{my:1}}),T(Tr,{children:T(Er,{primary:D(Q,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[D(ae,{variant:"subtitle2",children:["Campos Personalizados (",p.length,")"]}),T(Rr,{size:"small",onClick:()=>y(!u),children:u?T(Wn,{}):T(Vn,{})})]})})}),T(On,{in:u,children:p.map(({key:f,label:C})=>T(Tr,{sx:{pl:4},children:T(Er,{primary:C,secondary:c(f,d[f])})},f))})]})]}),D(Q,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[D(ae,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",x(d.updatedAt)]}),T(Rr,{size:"small",onClick:a,disabled:i,children:T(ae,{variant:"caption",children:"Actualizar"})})]})]})})]})},Kn=jn;var $o=["create","read","update","delete"],jo=["create","read","update","delete"];import{useRef as yi}from"react";import{useTranslation as bi}from"react-i18next";import{Box as lr,Typography as Zo,Button as wi,Stack as xi,Alert as et,Divider as Pi}from"@mui/material";import{Add as Ci}from"@mui/icons-material";import{forwardRef as ni}from"react";import{useTranslation as ii}from"react-i18next";import{Box as Se,FormControl as si,InputLabel as ai,Select as li,MenuItem as ci,IconButton as di,Typography as Be,FormHelperText as ui,Stack as ar,Paper as Qo,Divider as pi,Button as Ar}from"@mui/material";import{Delete as gi,SelectAll as mi,ClearAll as fi}from"@mui/icons-material";import{useState as Ko,useEffect as Go,useRef as Yo}from"react";import{useTranslation as Yn}from"react-i18next";import{Box as sr,Typography as Ke,Button as Xo,Stack as Sr,FormControlLabel as Xn,FormHelperText as Jo,Switch as Jn,ToggleButton as Ir,ToggleButtonGroup as Qn}from"@mui/material";import{CheckCircle as Zn,Cancel as ei,SelectAll as ri,ClearAll as oi}from"@mui/icons-material";import{jsx as N,jsxs as Pe}from"react/jsx-runtime";var ti=({value:e,onChange:r,availableFields:o,error:t,disabled:i=!1})=>{let{t:n}=Yn(),[l,a]=Ko("custom"),[u,y]=Ko(!1),d=Yo(null);Go(()=>{u&&d.current?.scrollIntoView({behavior:"smooth",block:"start"})},[u]);let b=Yo(!1);Go(()=>{let m=e||{allow:[],owner_allow:[],deny:[]},p=new Set(o),f=(m.allow||[]).filter(g=>p.has(g)),C=(m.owner_allow||[]).filter(g=>p.has(g)),S=(m.deny||[]).filter(g=>p.has(g));o.forEach(g=>{!f.includes(g)&&!C.includes(g)&&!S.includes(g)&&S.push(g)});let B={allow:f,owner_allow:C,deny:S};JSON.stringify(B)!==JSON.stringify(m)&&r(B),f.length===o.length?a("all"):S.length===o.length?a("none"):a("custom")},[o,e]);let x=()=>{b.current=!0,r({allow:[...o],owner_allow:[],deny:[]}),a("all"),setTimeout(()=>{b.current=!1},0)},c=()=>{b.current=!0,r({allow:[],owner_allow:[],deny:[...o]}),a("none"),setTimeout(()=>{b.current=!1},0)},s=m=>e?.allow?.includes(m)?"allow":e?.owner_allow?.includes(m)?"owner_allow":"deny",h=(m,p)=>{b.current=!0;let f=new Set(e?.allow||[]),C=new Set(e?.owner_allow||[]),S=new Set(e?.deny||[]);f.delete(m),C.delete(m),S.delete(m),p==="allow"&&f.add(m),p==="owner_allow"&&C.add(m),p==="deny"&&S.add(m),r({allow:Array.from(f),owner_allow:Array.from(C),deny:Array.from(S)}),a("custom"),setTimeout(()=>{b.current=!1},0)};return o.length===0?Pe(sr,{children:[N(Ke,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("publicPolicies.fields.conditions.label")}),N(Ke,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("publicPolicies.fields.conditions.noFieldsAvailable")}),t&&N(Jo,{error:!0,sx:{mt:1},children:t})]}):Pe(sr,{children:[N(Ke,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("publicPolicies.fields.conditions.label")}),Pe(Sr,{direction:"row",spacing:1,alignItems:"center",sx:{mb:u?3:1},children:[N(Xo,{variant:l==="all"?"contained":"outlined",startIcon:N(ri,{}),onClick:x,disabled:i,size:"small",sx:{minWidth:120,...l==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("publicPolicies.fields.conditions.allFields")}),N(Xo,{variant:l==="none"?"contained":"outlined",startIcon:N(oi,{}),onClick:c,disabled:i,size:"small",sx:{minWidth:120,...l==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("publicPolicies.fields.conditions.noFields")}),N(sr,{sx:{display:"flex",alignItems:"center",px:1.5,py:.35,borderRadius:"999px",backgroundColor:"#f3f4f6",border:"1px solid #d1d9e0"},children:N(Xn,{control:N(Jn,{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&&Pe(sr,{ref:d,sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[N(Ke,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("publicPolicies.fields.conditions.help")}),N(Sr,{spacing:1,children:o.map(m=>{let p=s(m);return Pe(Sr,{direction:"row",spacing:1,alignItems:"center",children:[N(Ke,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:m}),Pe(Qn,{value:p,exclusive:!0,size:"small",children:[Pe(Ir,{value:"allow",onClick:()=>h(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(Zn,{sx:{fontSize:16,mr:.5}}),n("publicPolicies.fields.conditions.states.allow")]}),N(Ir,{value:"owner_allow",onClick:()=>h(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")}),Pe(Ir,{value:"deny",onClick:()=>h(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(ei,{sx:{fontSize:16,mr:.5}}),n("publicPolicies.fields.conditions.states.deny")]})]})]},m)})})]}),t&&N(Jo,{error:!0,sx:{mt:1},children:t})]})},kr=ti;import{jsx as z,jsxs as $}from"react/jsx-runtime";var hi=ni(({policy:e,onChange:r,onRemove:o,availableFields:t,isSubmitting:i=!1,usedActions:n,error:l},a)=>{let{t:u}=ii(),y=new Set(Array.from(n||[]));y.delete(e.action);let d=$o.map(b=>({value:b,label:u(`publicPolicies.fields.action.options.${b}`)}));return $(Qo,{ref:a,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[$(Se,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[z(Be,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:u("publicPolicies.policyTitle")}),z(di,{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(gi,{})})]}),$(ar,{spacing:1,children:[z(ar,{direction:{xs:"column",md:"row"},spacing:2,children:z(Se,{sx:{flex:1,minWidth:200},children:$(si,{fullWidth:!0,children:[z(ai,{children:u("publicPolicies.fields.action.label")}),z(li,{value:e.action,label:u("publicPolicies.fields.action.label"),disabled:i,onChange:b=>{let x=b.target.value,c={...e,action:x};x==="delete"?(c.permission="deny",delete c.fields):(c.fields={allow:[],owner_allow:[],deny:t},delete c.permission),r(c)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:d.map(b=>{let x=y.has(b.value);return z(ci,{value:b.value,disabled:x,children:b.label},b.value)})}),l&&z(ui,{error:!0,children:l})]})})}),e.action==="delete"?$(Se,{children:[z(Be,{variant:"body2",color:"text.secondary",sx:{mb:2},children:u("publicPolicies.fields.conditions.label")}),$(ar,{direction:"row",spacing:1,sx:{mb:1},children:[z(Ar,{variant:e.permission==="*"?"contained":"outlined",startIcon:z(mi,{}),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(Ar,{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(Ar,{variant:e.permission==="deny"?"contained":"outlined",startIcon:z(fi,{}),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(kr,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:b=>r({...e,fields:b}),availableFields:t,disabled:i}),z(Qo,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?$(Be,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(Se,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[u("publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):$(ar,{spacing:.5,divider:z(pi,{sx:{borderColor:"#e5e7eb"}}),children:[$(Be,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(Se,{component:"span",sx:{color:"#16a34a"},children:[u("publicPolicies.fields.conditions.states.allow"),":"]})," ",(e?.fields?.allow||[]).join(", ")||"-"]}),$(Be,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(Se,{component:"span",sx:{color:"#0ea5e9"},children:[u("publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(e?.fields?.owner_allow||[]).join(", ")||"-"]}),$(Be,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[$(Se,{component:"span",sx:{color:"#dc2626"},children:[u("publicPolicies.fields.conditions.states.deny"),":"]})," ",(e?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),Lr=hi;import{Fragment as Ei,jsx as ue,jsxs as cr}from"react/jsx-runtime";var vi=()=>typeof globalThis<"u"&&globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`,Ti=({policies:e,onChange:r,availableFields:o,errors:t,isSubmitting:i=!1})=>{let{t:n}=bi(),l=yi({}),a=new Set((e||[]).map(s=>s.action).filter(Boolean)),u=jo.filter(s=>!a.has(s)),y=u.length>0,d=()=>{let s=u[0]||"create",h={id:vi(),action:s};s==="delete"?h.permission="deny":h.fields={allow:[],owner_allow:[],deny:o};let m=[...e||[],h];r(m),setTimeout(()=>{let p=m.length-1,f=l.current[p];f&&f.scrollIntoView({behavior:"smooth",block:"center"})},100)},b=s=>{let h=[...e];h.splice(s,1),r(h)},x=(()=>{if(!t)return null;if(typeof t=="string")return t;let s=t._error;return typeof s=="string"?s:null})(),c=new Set((e||[]).map(s=>s.action));return cr(Ei,{children:[ue(Pi,{sx:{borderColor:"#e0e4e7"}}),cr(lr,{children:[ue(lr,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:cr(lr,{children:[ue(Zo,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("publicPolicies.title")}),ue(Zo,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("publicPolicies.description")})]})}),x&&ue(et,{severity:"error",sx:{mb:3},children:x}),cr(xi,{spacing:3,children:[(e||[]).length===0?ue(et,{severity:"info",children:n("publicPolicies.noPolicies")}):e.map((s,h)=>ue(Lr,{ref:m=>{l.current[h]=m},policy:s,onChange:m=>{let p=[...e];p[h]=m,r(p)},onRemove:()=>b(h),availableFields:o,isSubmitting:i,usedActions:c,error:typeof t=="object"&&t!==null&&!("_error"in t)&&s.id in t?t[s.id]:void 0},s.id)),y&&ue(lr,{children:ue(wi,{type:"button",variant:"outlined",startIcon:ue(Ci,{}),onClick:d,disabled:i,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("publicPolicies.addPolicy")})})]})]})]})},Yl=Ti;import{useState as Fr}from"react";import{Button as dr,TextField as rt,Box as Ne,Alert as Ge,Typography as Ce,CircularProgress as _r}from"@mui/material";import{jsx as O,jsxs as me}from"react/jsx-runtime";function oc(){let[e,r]=Fr(""),[o,t]=Fr(""),[i,n]=Fr(!1),{isAuthenticated:l,isLoading:a,error:u,login:y,logout:d,refreshTokens:b,clearError:x,isExpiringSoon:c,expiresIn:s}=be(),h=async f=>{if(f.preventDefault(),!e||!o)return;(await y(e,o)).success&&(r(""),t(""),n(!1))},m=async()=>{await d()},p=async()=>{await b()};return l?me(Ne,{sx:{maxWidth:600,mx:"auto",p:3},children:[O(Ce,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),O(Ge,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),me(Ne,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[O(Ce,{variant:"h6",gutterBottom:!0,children:"Token Status"}),me(Ce,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(s/1e3/60)," minutes"]}),c&&O(Ge,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),me(Ne,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[O(dr,{variant:"contained",onClick:p,disabled:a,startIcon:a?O(_r,{size:16}):null,children:"Refresh Tokens"}),O(dr,{variant:"outlined",color:"error",onClick:m,disabled:a,children:"Logout"})]}),u&&O(Ge,{severity:"error",sx:{mt:2},onClose:x,children:u})]}):me(Ne,{sx:{maxWidth:400,mx:"auto",p:3},children:[O(Ce,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),O(Ge,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),i?me("form",{onSubmit:h,children:[O(rt,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:f=>r(f.target.value),margin:"normal",required:!0,autoComplete:"email"}),O(rt,{fullWidth:!0,label:"Password",type:"password",value:o,onChange:f=>t(f.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),O(dr,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:a,startIcon:a?O(_r,{size:16}):null,sx:{mt:3,mb:2},children:a?"Logging in...":"Login"})]}):O(dr,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),u&&O(Ge,{severity:"error",sx:{mt:2},onClose:x,children:u})]})}function tc(){let{isAuthenticated:e,isLoading:r,isExpiringSoon:o,expiresIn:t}=be();return r?me(Ne,{sx:{display:"flex",alignItems:"center",gap:1},children:[O(_r,{size:16}),O(Ce,{variant:"caption",children:"Loading session..."})]}):e?me(Ne,{children:[O(Ce,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),o&&me(Ce,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):O(Ce,{variant:"caption",color:"text.secondary",children:"Not logged in"})}import Ri from"@mui/material/TextField";import Si from"@mui/material/CircularProgress";import ot from"@mui/material/InputAdornment";import Ii from"@mui/material/IconButton";import ki from"@mui/icons-material/Refresh";import{jsx as ve}from"react/jsx-runtime";var Ai=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),Li=({html:e})=>ve("span",{dangerouslySetInnerHTML:{__html:Ai(e)}}),pc=({config:e,value:r,onChange:o,label:t,error:i=!1,helperText:n,readOnly:l=!1,disabled:a=!1})=>{let{value:u,loading:y,error:d,regenerate:b}=Zr(e,{autoFetch:!r,onSuccess:p=>{o?.(p)}}),x=r||u,c=i||!!d,s=d||n,h=c&&s&&(s.toLowerCase().includes("duplicate")||s.toLowerCase().includes("duplicado")||s.toLowerCase().includes("duplicada")||s.toLowerCase().includes("unique")||s.toLowerCase().includes("\xFAnico")||s.toLowerCase().includes("unico")||s.toLowerCase().includes("\xFAnica")||s.toLowerCase().includes("unica")||s.toLowerCase().includes("already exists")||s.toLowerCase().includes("ya existe")||s.toLowerCase().includes("e11000"));return ve(Ri,{label:t,fullWidth:!0,value:x,error:c,helperText:s?ve(Li,{html:s}):" ",disabled:a,InputProps:{readOnly:!0,startAdornment:y?ve(ot,{position:"start",children:ve(Si,{size:20})}):void 0,endAdornment:h&&!y?ve(ot,{position:"end",children:ve(Ii,{edge:"end",onClick:async()=>{!a&&!y&&await b()},disabled:a,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:ve(ki,{})})}):void 0}})};import Dr,{useCallback as fe,useRef as tt,useState as Ye}from"react";import Ie from"@mui/material/Box";import Te from"@mui/material/Typography";import Or from"@mui/material/IconButton";import Fi from"@mui/material/LinearProgress";import ur from"@mui/material/CircularProgress";import it from"@mui/material/Chip";import _i from"@mui/material/Paper";import Di from"@mui/material/List";import Oi from"@mui/material/ListItem";import Bi from"@mui/material/ListItemText";import Ni from"@mui/material/ListItemSecondaryAction";import zi from"@mui/material/FormHelperText";import Ui from"@mui/material/Dialog";import Mi from"@mui/material/DialogTitle";import qi from"@mui/material/DialogContent";import Vi from"@mui/material/DialogActions";import nt from"@mui/material/Button";import Wi from"@mui/icons-material/CloudUpload";import Hi from"@mui/icons-material/InsertDriveFile";import $i from"@mui/icons-material/Image";import ji from"@mui/icons-material/PictureAsPdf";import Ki from"@mui/icons-material/Delete";import Gi from"@mui/icons-material/Refresh";import Yi from"@mui/icons-material/Restore";import Xi from"@mui/icons-material/CheckCircle";import Ji from"@mui/icons-material/Error";import Hc from"@mui/icons-material/BrokenImage";import{jsx as v,jsxs as pe}from"react/jsx-runtime";var Qi=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),Zi=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]}`},es=e=>e.startsWith("image/")?v($i,{color:"primary"}):e==="application/pdf"?v(ji,{color:"error"}):v(Hi,{color:"action"}),rs=(e,r)=>{switch(e){case"completed":return v(Xi,{color:"success",fontSize:"small"});case"error":return v(Ji,{color:"error",fontSize:"small"});case"uploading":case"pending":return v(ur,{size:16});case"removing":return v(ur,{size:16,color:"error"});case"pendingDeletion":return v(it,{label:r("base.file.pendingDeletion"),size:"small",color:"warning",variant:"outlined",sx:{fontSize:"0.65rem",height:20}});default:return null}},os=({file:e,baseUrl:r,disabled:o,onRemove:t,onRestore:i,onRetry:n})=>{let{t:l}=Me(),[a,u]=Ye(!1),y=e.status==="pendingDeletion",d=!o&&e.status!=="uploading"&&e.status!=="removing"&&!y,b=!o&&y,x=!o&&e.status==="error"&&e.file,c=e.contentType.startsWith("image/"),s=e.visibility==="public"||e.filePath?.startsWith("public/")||e.filePath?.startsWith(r),m=!e.filePath||!s?null:e.filePath.startsWith("http://")||e.filePath.startsWith("https://")||e.filePath.startsWith(r)?e.filePath:`${r}${e.filePath}`,p=e.status==="completed"&&m,f=()=>c&&p&&!a?v(Ie,{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:v("img",{src:m,alt:e.name,style:{width:"100%",height:"100%",objectFit:"cover"},onError:()=>u(!0)})}):v(Ie,{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:es(e.contentType)});return pe(Oi,{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:[f(),v(Bi,{primary:pe(Ie,{sx:{display:"flex",alignItems:"center",gap:1},children:[v(Te,{variant:"body2",noWrap:!0,sx:{maxWidth:200,overflow:"hidden",textOverflow:"ellipsis",textDecoration:y?"line-through":"none",opacity:y?.6:1},children:e.name}),rs(e.status,l)]}),secondary:pe(Ie,{sx:{opacity:y?.6:1},children:[e.size>0&&v(Te,{variant:"caption",color:"text.secondary",children:Zi(e.size)}),e.status==="uploading"&&v(Fi,{variant:"determinate",value:e.progress,sx:{mt:.5,height:4,borderRadius:2}}),e.status==="error"&&e.errorMessage&&v(Te,{variant:"caption",color:"error",display:"block",children:e.errorMessage}),p&&v(Te,{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:l(c?"base.file.clickToPreview":"base.file.clickToDownload")})]})}),pe(Ni,{children:[x&&v(Or,{edge:"end",size:"small",onClick:()=>n(e.id),color:"primary",title:l("base.file.restore"),children:v(Gi,{fontSize:"small"})}),b&&v(Or,{edge:"end",size:"small",onClick:()=>i(e.id),color:"primary",title:l("base.file.restore"),children:v(Yi,{fontSize:"small"})}),d&&v(Or,{edge:"end",size:"small",onClick:()=>t(e.id),color:"error",title:l("base.file.delete"),children:v(Ki,{fontSize:"small"})})]})]})};var Kc=({label:e,accept:r,maxFileSize:o=10*1024*1024,multiple:t=!1,maxFiles:i,minFiles:n=0,required:l=!1,disabled:a=!1,error:u=!1,helperText:y,onChange:d,onValidation:b,initialFiles:x,placeholder:c,showFileList:s=!0,visibility:h="private",showPreview:m=!0,baseUrl:p,onDeletionHandlersReady:f,mode:C="create"})=>{let{t:S}=Me(),B=tt(null),[g,P]=Ye(!1),[k,A]=Ye(!1),[J,le]=Ye(null),[Z,ne]=Ye(!1),ze=t?i:1,ke=l?Math.max(n,1):n,V={acceptedTypes:r,maxFileSize:o,maxFiles:ze,minFiles:ke,visibility:h,mode:C,onFilesChange:L=>{let ce=L.filter(Je=>Je.status==="completed"&&Je.filePath).map(Je=>{let Le=Je.filePath;return Le.startsWith(p)||Le.startsWith("http://")||Le.startsWith("https://")?Le:p?`${p}${Le}`:Le});d?.(ce)}},{files:W,isUploading:ee,addFiles:E,removeFile:R,restoreFile:q,retryUpload:ie,isValid:re,validationError:Ue,validationErrorKey:Ee,validationErrorParams:Ae,initializeFiles:Xe,isTouched:Nr,markAsTouched:I,isSubmitted:_,markAsSubmitted:U,getPreviewUrl:K,commitDeletions:G,restorePendingDeletions:Y,hasPendingDeletions:he,deleteFileImmediately:zr,activeFiles:vs,activeFileCount:ct,waitForUploads:Ur,completedFilePaths:Mr}=eo(V),qr=fe(()=>Mr,[Mr]),Vr=tt(!1);Dr.useEffect(()=>{x&&x.length>0&&!Vr.current&&(Vr.current=!0,Xe(x,p))},[x,Xe,p]),Dr.useEffect(()=>{b?.(re,Ue)},[re,Ue,b]),Dr.useEffect(()=>{f?.({commitDeletions:G,restorePendingDeletions:Y,hasPendingDeletions:he,markAsSubmitted:U,isValid:re,isUploading:ee,waitForUploads:Ur,getCompletedFilePaths:qr})},[f,G,Y,he,U,re,ee,Ur,qr]);let dt=fe(L=>{I();let ce=L.target.files;ce&&ce.length>0&&E(ce),B.current&&(B.current.value="")},[E,I]),ut=fe(()=>{a||B.current?.click()},[a]),pt=fe(L=>{L.preventDefault(),L.stopPropagation(),a||P(!0)},[a]),gt=fe(L=>{L.preventDefault(),L.stopPropagation(),P(!1)},[]),mt=fe(L=>{if(L.preventDefault(),L.stopPropagation(),P(!1),a)return;I();let ce=L.dataTransfer.files;ce&&ce.length>0&&E(ce)},[a,E,I]),ft=fe(async L=>{(await R(L)).needsConfirmation&&(le(L),A(!0))},[R]),ht=fe(async()=>{if(J){ne(!0);try{let L=await zr(J);L.success||w.error("Error deleting file",{error:L.error})}finally{ne(!1),A(!1),le(null)}}},[J,zr]),Wr=fe(()=>{A(!1),le(null)},[]),yt=r?.join(",")||"",bt=!a&&(t||ct===0),Hr=_&&!re,gr=u||Hr,$r=y||(Hr&&Ee?S(Ee,Ae):null);return pe(Ie,{sx:{width:"100%"},children:[e&&pe(Te,{variant:"body2",sx:{mb:1,fontWeight:500,color:gr?"error.main":"text.primary"},children:[e,l&&v("span",{style:{color:"red"},children:" *"})]}),v("input",{ref:B,type:"file",accept:yt,multiple:t,onChange:dt,disabled:a,style:{display:"none"}}),bt&&pe(_i,{variant:"outlined",onClick:ut,onDragOver:pt,onDragLeave:gt,onDrop:mt,sx:{p:3,textAlign:"center",cursor:a?"not-allowed":"pointer",borderStyle:"dashed",borderWidth:2,borderColor:g?"primary.main":gr?"error.main":"divider",bgcolor:g?"primary.lighter":a?"action.disabledBackground":"background.paper",transition:"all 0.2s ease","&:hover":a?{}:{borderColor:"primary.main",bgcolor:"action.hover"}},children:[v(Wi,{sx:{fontSize:48,color:g?"primary.main":a?"action.disabled":"action.active",mb:1}}),v(Te,{variant:"body2",color:a?"text.disabled":"text.secondary",children:c||S(g?"base.file.dropHere":"base.file.dragOrClick")}),r&&r.length>0&&!g&&v(Ie,{sx:{mt:1,display:"flex",gap:.5,justifyContent:"center",flexWrap:"wrap"},children:r.map(L=>v(it,{label:L.split("/")[1]?.toUpperCase()||L,size:"small",variant:"outlined",sx:{fontSize:"0.7rem"}},L))})]}),s&&W.length>0&&v(Di,{dense:!0,sx:{mt:1,p:0},children:W.map(L=>v(os,{file:L,baseUrl:p,disabled:a,onRemove:ft,onRestore:q,onRetry:ie},L.id))}),ee&&pe(Ie,{sx:{display:"flex",alignItems:"center",gap:1,mt:1},children:[v(ur,{size:16}),v(Te,{variant:"caption",color:"text.secondary",children:S("base.file.uploading")})]}),$r&&v(zi,{error:gr,sx:{mt:.5},dangerouslySetInnerHTML:{__html:Qi($r)}}),pe(Ui,{open:k,onClose:Z?void 0:Wr,children:[v(Mi,{children:S("base.file.confirmDelete.title")}),v(qi,{children:v(Te,{children:S("base.file.confirmDelete.message")})}),pe(Vi,{children:[v(nt,{onClick:Wr,disabled:Z,children:S("base.file.confirmDelete.cancel")}),v(nt,{onClick:ht,color:"error",variant:"contained",disabled:Z,startIcon:Z?v(ur,{size:16,color:"inherit"}):void 0,children:S(Z?"base.file.deleting":"base.file.confirmDelete.confirm")})]})]})]})};import{useCallback as ts,useRef as ns,useEffect as is}from"react";import st from"@mui/material/Box";import at from"@mui/material/Typography";import lt from"@mui/material/FormHelperText";import{MDXEditor as ss,headingsPlugin as as,listsPlugin as ls,quotePlugin as cs,thematicBreakPlugin as ds,markdownShortcutPlugin as us,linkPlugin as ps,linkDialogPlugin as gs,tablePlugin as ms,toolbarPlugin as fs,UndoRedo as hs,BoldItalicUnderlineToggles as ys,BlockTypeSelect as bs,CreateLink as ws,InsertTable as xs,ListsToggle as Ps,Separator as pr}from"@mdxeditor/editor";import"@mdxeditor/editor/style.css";import{Fragment as Cs,jsx as j,jsxs as Br}from"react/jsx-runtime";var td=({label:e,value:r="",onChange:o,required:t=!1,disabled:i=!1,error:n=!1,helperText:l,placeholder:a="Write here...",minHeight:u=200,maxHeight:y=500})=>{let d=ns(null);is(()=>{d.current&&d.current.getMarkdown()!==r&&d.current.setMarkdown(r||"")},[r]);let b=ts(x=>{o?.(x)},[o]);return Br(st,{sx:{width:"100%"},children:[e&&Br(at,{component:"label",sx:{display:"block",mb:.5,fontSize:"0.875rem",fontWeight:500,color:n?"error.main":"text.primary"},children:[e,t&&j(at,{component:"span",color:"error.main",sx:{ml:.5},children:"*"})]}),j(st,{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:j(ss,{ref:d,markdown:r||"",onChange:b,placeholder:a,readOnly:i,plugins:[as(),ls(),cs(),ds(),us(),ps(),gs(),ms(),fs({toolbarContents:()=>Br(Cs,{children:[j(hs,{}),j(pr,{}),j(ys,{}),j(pr,{}),j(bs,{}),j(pr,{}),j(Ps,{}),j(pr,{}),j(ws,{}),j(xs,{})]})})]})}),l&&j(lt,{error:n,sx:{mx:0,mt:.5},children:l}),!l&&j(lt,{sx:{mx:0,mt:.5},children:"\xA0"})]})};export{ge as a,Es as b,Rs as c,mr as d,Ze as e,zs as f,Me as g,ao as h,Vs as i,uo as j,po as k,go as l,mo as m,ul as n,Kn as o,$o as p,jo as q,Yl as r,oc as s,tc as t,pc as u,Kc as v,td as w};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as c,d as he,f as H,g as Re,h as Ne,i as Pe,j as De,k as Le,l as Oe,m as Fe,q as ze,r as Ue,s as Ke}from"./chunk-4ILUXVPW.mjs";var Me="crudify_storage_version",He=2,a=class a{static setStorageType(e){a.storageType=e}static async initialize(){if(!(a.encryptionKey&&a.salt))return a.initPromise||(a.initPromise=(async()=>{let t=null;for(let i=1;i<=3;i++)try{a.checkStorageVersion(),a.salt=a.getOrCreateSalt(),a.fingerprint=await a.generateFingerprint(),a.encryptionKey=await Ne(a.fingerprint,a.salt);return}catch(n){t=n instanceof Error?n:new Error(String(n)),i<3&&await new Promise(o=>setTimeout(o,100*i))}throw c.error("Crudify: Failed to initialize encryption after retries",t??{message:"Unknown error"}),t})()),a.initPromise}static checkStorageVersion(){try{if(parseInt(localStorage.getItem(Me)||"1",10)<He){let t=a.getStorage();t&&t.removeItem(a.TOKEN_KEY),localStorage.removeItem(a.ENCRYPTION_KEY_STORAGE),localStorage.removeItem(a.SALT_KEY),localStorage.setItem(Me,He.toString()),c.info("Crudify: Storage upgraded to v2, tokens cleared for security")}}catch{}}static getOrCreateSalt(){try{let t=localStorage.getItem(a.SALT_KEY);if(t){let i=atob(t),n=new Uint8Array(i.length);for(let o=0;o<i.length;o++)n[o]=i.charCodeAt(o);return n}}catch{}let e=Le();try{let t="";for(let i=0;i<e.length;i++)t+=String.fromCharCode(e[i]);localStorage.setItem(a.SALT_KEY,btoa(t))}catch{c.warn("Crudify: Cannot persist salt, encryption may not persist across sessions")}return e}static async generateFingerprint(){try{let n=localStorage.getItem(a.ENCRYPTION_KEY_STORAGE);if(n&&n.length>=32)return n}catch{}let t=[navigator.userAgent,navigator.language,navigator.platform||"unknown",String(screen.width),String(screen.height),String(screen.colorDepth||24),String(new Date().getTimezoneOffset()),"crudify-session-v3"].join("|"),i=await Re(t);try{localStorage.setItem(a.ENCRYPTION_KEY_STORAGE,i)}catch{c.warn("Crudify: Cannot persist encryption key hash, session may not survive page reload")}return i}static isStorageAvailable(e){try{let t=window[e],i="__storage_test__";return t.setItem(i,"test"),t.removeItem(i),!0}catch{return!1}}static getStorage(){return a.storageType==="none"?null:a.isStorageAvailable(a.storageType)?window[a.storageType]:(c.warn(`Crudify: ${a.storageType} not available, tokens won't persist`),null)}static async encryptData(e){if(await a.initialize(),!a.encryptionKey||!a.salt)throw new Error("Encryption not initialized");return Pe(e,a.encryptionKey,a.salt)}static async decryptData(e){if(await a.initialize(),!a.fingerprint)throw new Error("Encryption not initialized");return Oe(e)?De(e,a.fingerprint):(c.warn("Crudify: Legacy encrypted data detected, cannot decrypt"),null)}static async saveTokens(e){let t=a.getStorage();if(t)try{let i={accessToken:e.accessToken,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt,savedAt:Date.now()},n=await a.encryptData(JSON.stringify(i));t.setItem(a.TOKEN_KEY,n),c.debug("Crudify: Tokens saved successfully")}catch(i){c.error("Crudify: Failed to save tokens",i instanceof Error?i:{message:String(i)})}}static async getTokens(){let e=a.getStorage();if(!e)return null;try{let t=e.getItem(a.TOKEN_KEY);if(!t)return null;let i=await a.decryptData(t);if(!i)return c.warn("Crudify: Failed to decrypt tokens, clearing storage"),await a.clearTokens(),null;let n=JSON.parse(i);return!n.accessToken||!n.refreshToken||!n.expiresAt||!n.refreshExpiresAt?(c.warn("Crudify: Incomplete token data found, clearing storage"),await a.clearTokens(),null):Date.now()>=n.refreshExpiresAt?(c.info("Crudify: Refresh token expired, clearing storage"),await a.clearTokens(),null):{accessToken:n.accessToken,refreshToken:n.refreshToken,expiresAt:n.expiresAt,refreshExpiresAt:n.refreshExpiresAt}}catch(t){return c.error("Crudify: Failed to retrieve tokens",t instanceof Error?t:{message:String(t)}),await a.clearTokens(),null}}static async clearTokens(){let e=a.getStorage();if(e)try{e.removeItem(a.TOKEN_KEY),c.debug("Crudify: Tokens cleared from storage")}catch(t){c.error("Crudify: Failed to clear tokens",t instanceof Error?t:{message:String(t)})}}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{}c.info("Crudify: Encryption key rotated successfully")}catch(e){c.error("Crudify: Failed to rotate encryption key",e instanceof Error?e:{message:String(e)})}}static async hasValidTokens(){return await a.getTokens()!==null}static async ensureInitialized(){await a.initialize()}static async getExpirationInfo(){let e=await a.getTokens();if(!e)return null;let t=Date.now();return{accessExpired:t>=e.expiresAt,refreshExpired:t>=e.refreshExpiresAt,accessExpiresIn:Math.max(0,e.expiresAt-t),refreshExpiresIn:Math.max(0,e.refreshExpiresAt-t)}}static async updateAccessToken(e,t){let i=await a.getTokens();if(!i){c.warn("Crudify: Cannot update access token, no existing tokens found");return}await a.saveTokens({...i,accessToken:e,expiresAt:t})}static createSyncEvent(e,t,i){return{type:e,tokens:t,hadPreviousTokens:i}}static markLocalChange(){a.ignoreNextStorageEvent=!0,a.ignoreStorageEventTimeout&&clearTimeout(a.ignoreStorageEventTimeout),a.ignoreStorageEventTimeout=setTimeout(()=>{a.ignoreNextStorageEvent=!1},100)}static markSuccessfulLogin(){a.lastSuccessfulLoginTime=Date.now()}static isWithinLoginGracePeriod(){return a.lastSuccessfulLoginTime===0?!1:Date.now()-a.lastSuccessfulLoginTime<a.LOGIN_GRACE_PERIOD_MS}static subscribeToChanges(e){let t=async i=>{if(i.key!==a.TOKEN_KEY)return;if(a.ignoreNextStorageEvent){a.ignoreNextStorageEvent=!1;return}if(i.newValue===null&&a.isWithinLoginGracePeriod())return;if(i.newValue===null){let l=a.getStorage()?.getItem(a.TOKEN_KEY);if(l!==null&&l!=="")return}let n=i.oldValue!==null&&i.oldValue!=="";if(i.newValue===null){c.debug("Crudify: Tokens removed in another tab"),e(null,a.SYNC_EVENTS.TOKENS_CLEARED,n);return}if(i.newValue){c.debug("Crudify: Tokens updated in another tab");let o=await a.getTokens();e(o,a.SYNC_EVENTS.TOKENS_UPDATED,n)}};return window.addEventListener("storage",t),()=>{window.removeEventListener("storage",t)}}};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.lastSuccessfulLoginTime=0,a.LOGIN_GRACE_PERIOD_MS=5e3,a.SYNC_EVENTS={TOKENS_CLEARED:"TOKENS_CLEARED",TOKENS_UPDATED:"TOKENS_UPDATED"},a.ignoreNextStorageEvent=!1,a.ignoreStorageEventTimeout=null;var v=a;var K=class K{constructor(){this.broadcastChannel=null;this.CHANNEL_NAME="crudify-session-sync";this.listeners=new Set;this.isInitialized=!1;this.tabId=K.generateTabId(),this.initialize()}static generateTabId(){let e=Date.now().toString(36),t=Math.random().toString(36).substring(2,9);return`tab_${e}_${t}`}static getInstance(){return K.instance||(K.instance=new K),K.instance}static resetInstance(){K.instance&&(K.instance.destroy(),K.instance=null)}initialize(){if(!this.isInitialized)try{typeof BroadcastChannel<"u"?(this.broadcastChannel=new BroadcastChannel(this.CHANNEL_NAME),this.broadcastChannel.onmessage=e=>{this.handleMessage(e.data)},this.broadcastChannel.onmessageerror=()=>{c.warn("Crudify: CrossTabSync message error")},c.debug("Crudify: CrossTabSync initialized with BroadcastChannel")):c.debug("Crudify: BroadcastChannel not available, using localStorage fallback"),this.isInitialized=!0}catch(e){c.warn("Crudify: Failed to initialize CrossTabSync",{message:e instanceof Error?e.message:String(e)})}}destroy(){this.broadcastChannel&&(this.broadcastChannel.close(),this.broadcastChannel=null),this.listeners.clear(),this.isInitialized=!1}getTabId(){return this.tabId}subscribe(e){return this.listeners.add(e),()=>{this.listeners.delete(e)}}notifyLogin(){this.broadcast({type:"SESSION_STARTED",tabId:this.tabId,timestamp:Date.now()})}notifyLogout(){this.broadcast({type:"SESSION_ENDED",tabId:this.tabId,timestamp:Date.now()})}notifyTokenRefreshed(){this.broadcast({type:"TOKEN_REFRESHED",tabId:this.tabId,timestamp:Date.now()})}ping(){this.broadcast({type:"SESSION_PING",tabId:this.tabId,timestamp:Date.now()})}broadcast(e){this.isInitialized||this.initialize();try{this.broadcastChannel&&(this.broadcastChannel.postMessage(e),c.debug(`Crudify: CrossTab broadcast ${e.type}`))}catch(t){c.warn("Crudify: Failed to broadcast cross-tab message",{message:t instanceof Error?t.message:String(t)})}}handleMessage(e){e.tabId!==this.tabId&&(c.debug(`Crudify: CrossTab received ${e.type} from ${e.tabId}`),e.type==="SESSION_PING"&&this.broadcast({type:"SESSION_PONG",tabId:this.tabId,timestamp:Date.now(),payload:{respondingTo:e.tabId}}),this.listeners.forEach(t=>{try{t(e)}catch(i){c.error("Crudify: CrossTab listener error",{message:i instanceof Error?i.message:String(i)})}}))}};K.instance=null;var Ee=K,B=Ee.getInstance();import L from"@nocios/crudify-sdk";var oe="crudify_auth",Se=r=>{if(r==="dev"||typeof window>"u"||!window.location)return"";if(!r){let e=window.location.hostname;return e?e.endsWith(".nocios.link")||e==="nocios.link"?".nocios.link":e.endsWith(".crudia.com")||e==="crudia.com"?".crudia.com":"":""}return r==="prod"||r==="api"?".crudia.com":".nocios.link"},Ot=(r,e,t)=>{if(typeof document>"u"){c.debug("[CookieSync] No document available (SSR), skipping cookie set");return}if(!r){c.warn("[CookieSync] Attempted to set cookie with empty token");return}try{let i=Se(t),n=Date.now(),o=Math.max(0,Math.floor((e-n)/1e3)),l=[`${oe}=${encodeURIComponent(r)}`,"path=/","SameSite=Lax",`max-age=${o}`];typeof window<"u"&&window.location.protocol==="https:"&&l.push("Secure"),i&&l.push(`domain=${i}`),document.cookie=l.join("; "),c.debug("[CookieSync] Cookie set successfully",{domain:i||"(current host)",maxAgeSeconds:o,tokenLength:r.length})}catch(i){c.error("[CookieSync] Failed to set cookie",i instanceof Error?i:{message:String(i)})}},Ft=r=>{if(typeof document>"u"){c.debug("[CookieSync] No document available (SSR), skipping cookie clear");return}try{let e=Se(r),t=[`${oe}=`,"path=/","max-age=0","expires=Thu, 01 Jan 1970 00:00:00 GMT"];e&&t.push(`domain=${e}`),document.cookie=t.join("; "),document.cookie=`${oe}=; path=/; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT`,c.debug("[CookieSync] Cookie cleared successfully",{domain:e||"(current host)"})}catch(e){c.error("[CookieSync] Failed to clear cookie",e instanceof Error?e:{message:String(e)})}},zt=()=>{if(typeof document>"u")return null;try{let e=document.cookie.split(";").map(i=>i.trim()).find(i=>i.startsWith(`${oe}=`));if(!e)return null;let t=e.split("=")[1];return t?decodeURIComponent(t):null}catch(r){return c.error("[CookieSync] Failed to read cookie",r instanceof Error?r:{message:String(r)}),null}},Q={setCrossSubdomainCookie:Ot,clearCrossSubdomainCookie:Ft,getCrossSubdomainCookie:zt,getCookieDomain:Se};var se=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(e={}){if(!this.initialized){if(this.config={storageType:"localStorage",autoRestore:!0,enableLogging:!1,env:"stg",...e},v.setStorageType(this.config.storageType||"localStorage"),this.config.publicApiKey&&!this.crudifyInitialized&&await this.ensureCrudifyInitialized(),L.setTokenInvalidationCallback(()=>{this.log("Tokens invalidated by crudify-core"),H.emit("SESSION_EXPIRED",{message:"Your session has expired. Please log in again.",source:"crudify-core.clearTokensAndRefreshState"})}),this.config.apiEndpointAdmin&&this.config.apiKeyEndpointAdmin){let t=await v.getTokens();t?await v.saveTokens({...t,apiEndpointAdmin:this.config.apiEndpointAdmin,apiKeyEndpointAdmin:this.config.apiKeyEndpointAdmin}):await v.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(e,t){try{let i=await L.login(e,t);if(!i.success)return{success:!1,error:this.formatError(i.errors),rawResponse:i};let n=await v.getTokens(),o=i.data,l={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 v.saveTokens(l),v.markSuccessfulLogin(),this.lastActivityTime=Date.now(),Q.setCrossSubdomainCookie(l.accessToken,l.expiresAt,this.config.env),B.notifyLogin(),this.config.onLoginSuccess?.(l),{success:!0,tokens:l,data:o}}catch(i){return c.error("[SessionManager] Login error",i instanceof Error?i:{message:String(i)}),{success:!1,error:i instanceof Error?i.message:"Unknown error"}}}async logout(){try{this.log("Logging out..."),H.emit("LOGOUT",{message:"User logged out",source:"SessionManager.logout"}),Q.clearCrossSubdomainCookie(this.config.env),await L.logout(),await v.clearTokens(),B.notifyLogout(),this.log("Logout successful"),this.config.onLogout?.()}catch(e){this.log("Logout error",{error:e instanceof Error?e.message:String(e)}),await v.clearTokens(),B.notifyLogout()}}async restoreSession(){try{this.log("Attempting to restore session...");let e=await v.getTokens();if(!e)return this.log("No valid tokens found in storage"),!1;if(Date.now()>=e.refreshExpiresAt)return this.log("Refresh token expired, clearing storage"),await v.clearTokens(),!1;if(L.setTokens({accessToken:e.accessToken,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt}),L.getTokenData().isValid===!1){if(this.log("Restored access token is invalid or expired"),Date.now()<e.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 v.getTokens();return n&&this.config.onSessionRestored?.(n),!0}return await v.clearTokens(),await L.logout(),!1}return this.log("Session restored successfully"),this.lastActivityTime=Date.now(),this.config.onSessionRestored?.(e),!0}catch(e){return this.log("Session restore error",{error:e instanceof Error?e.message:String(e)}),await v.clearTokens(),await L.logout(),!1}}async isAuthenticated(){return L.isLogin()||await v.hasValidTokens()}async getTokenInfo(){let e=L.getTokenData(),t=await v.getExpirationInfo(),i=await v.getTokens();return{isLoggedIn:await this.isAuthenticated(),crudifyTokens:e,storageInfo:t,hasValidTokens:await v.hasValidTokens(),apiEndpointAdmin:i?.apiEndpointAdmin,apiKeyEndpointAdmin:i?.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 e=await L.refreshAccessToken();if(!e.success)return this.log("Token refresh failed",{errors:e.errors}),await v.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),!1;let t=e.data,i={accessToken:t.token,refreshToken:t.refreshToken,expiresAt:t.expiresAt,refreshExpiresAt:t.refreshExpiresAt};return await v.saveTokens(i),this.log("Tokens refreshed and saved successfully"),Q.setCrossSubdomainCookie(i.accessToken,i.expiresAt,this.config.env),this.lastActivityTime=Date.now(),B.notifyTokenRefreshed(),!0}catch(e){return this.log("Token refresh error",{error:e instanceof Error?e.message:String(e)}),await v.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),!1}}isRefreshing(){return this.isRefreshingLocally}setupResponseInterceptor(){L.setResponseInterceptor(async e=>{this.updateLastActivity();let t=this.detectAuthorizationError(e);if(t.isAuthError){if(this.log("\u{1F6A8} Authorization error detected:",{errorType:t.errorType,shouldLogout:t.shouldTriggerLogout}),t.isRefreshTokenInvalid||t.isTokenRefreshFailed)return this.log("Refresh token invalid, emitting TOKEN_REFRESH_FAILED event"),H.emit("TOKEN_REFRESH_FAILED",{message:t.userFriendlyMessage,error:t.errorDetails,source:"SessionManager.setupResponseInterceptor"}),e;t.shouldTriggerLogout&&(await v.hasValidTokens()&&!t.isIrrecoverable?(this.log("Access token expired, emitting TOKEN_EXPIRED event"),H.emit("TOKEN_EXPIRED",{message:"Access token expired, refresh needed",error:t.errorDetails,source:"SessionManager.setupResponseInterceptor"})):(this.log("No valid tokens or irrecoverable error, emitting SESSION_EXPIRED event"),H.emit("SESSION_EXPIRED",{message:t.userFriendlyMessage,error:t.errorDetails,source:"SessionManager.setupResponseInterceptor"})))}return e}),this.log("Response interceptor configured (non-blocking mode)")}async ensureCrudifyInitialized(){if(!this.crudifyInitialized)try{this.log("Initializing crudify SDK...");let e=L.getTokenData();if(e&&e.endpoint){this.log("Crudify already initialized by another service"),this.crudifyInitialized=!0;return}let t=this.config.env||"stg";L.config(t);let i=this.config.publicApiKey,n=this.config.enableLogging?"debug":"none",o=await L.init(i,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(e){throw c.error("[SessionManager] Failed to initialize crudify",e instanceof Error?e:{message:String(e)}),e}}detectAuthorizationError(e){let t={isAuthError:!1,isRefreshTokenInvalid:!1,isTokenRefreshFailed:!1,isTokenExpired:!1,isUnauthorized:!1,isIrrecoverable:!1,shouldTriggerLogout:!1,errorType:"",errorDetails:null,userFriendlyMessage:""};if(e.errors&&Array.isArray(e.errors)){let i=e.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");i&&(t.isAuthError=!0,t.errorType="GraphQL Array",t.errorDetails=i,t.shouldTriggerLogout=!0,t.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.",(i.message?.includes("TOKEN")||i.message?.includes("Token"))&&(t.isTokenExpired=!0),i.extensions?.code==="UNAUTHENTICATED"&&(t.isUnauthorized=!0))}if(!t.isAuthError&&e.errors&&typeof e.errors=="object"&&!Array.isArray(e.errors)){let n=Object.values(e.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"&&(t.isAuthError=!0,t.errorType="GraphQL Object",t.errorDetails=e.errors,t.shouldTriggerLogout=!0,n.includes("TOKEN_REFRESH_FAILED")?(t.isTokenRefreshFailed=!0,t.isRefreshTokenInvalid=!0,t.isIrrecoverable=!0,t.userFriendlyMessage="Tu sesi\xF3n ha caducado. Por favor, inicia sesi\xF3n nuevamente."):n.includes("TOKEN_HAS_EXPIRED")||n.includes("SESSION_EXPIRED")?(t.isTokenExpired=!0,t.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."):n.includes("INVALID_TOKEN")?(t.isTokenExpired=!0,t.isIrrecoverable=!0,t.userFriendlyMessage="Token inv\xE1lido. Por favor, inicia sesi\xF3n nuevamente."):t.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.")}if(!t.isAuthError&&e.data?.response?.status){let i=e.data.response.status.toUpperCase();(i==="UNAUTHORIZED"||i==="UNAUTHENTICATED")&&(t.isAuthError=!0,t.errorType="Status",t.errorDetails=e.data.response,t.isUnauthorized=!0,t.shouldTriggerLogout=!0,t.isIrrecoverable=!0,t.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.")}if(!t.isAuthError&&e.data?.response?.data)try{let i=typeof e.data.response.data=="string"?JSON.parse(e.data.response.data):e.data.response.data;(i.error==="REFRESH_TOKEN_INVALID"||i.error==="TOKEN_EXPIRED"||i.error==="INVALID_TOKEN")&&(t.isAuthError=!0,t.errorType="Parsed Data",t.errorDetails=i,t.shouldTriggerLogout=!0,t.isIrrecoverable=!0,i.error==="REFRESH_TOKEN_INVALID"?(t.isRefreshTokenInvalid=!0,t.isTokenRefreshFailed=!0,t.userFriendlyMessage="Tu sesi\xF3n ha caducado. Por favor, inicia sesi\xF3n nuevamente."):(t.isTokenExpired=!0,t.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."))}catch{}if(!t.isAuthError&&e.errorCode){let i=String(e.errorCode).toUpperCase();(i==="UNAUTHORIZED"||i==="UNAUTHENTICATED"||i==="TOKEN_EXPIRED"||i==="INVALID_TOKEN")&&(t.isAuthError=!0,t.errorType="Error Code",t.errorDetails={errorCode:i},t.shouldTriggerLogout=!0,i==="TOKEN_EXPIRED"?t.isTokenExpired=!0:t.isUnauthorized=!0,t.userFriendlyMessage="Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente.")}return t}updateLastActivity(){this.lastActivityTime=Date.now(),this.log("Last activity updated")}getTimeSinceLastActivity(){return this.lastActivityTime===0?0:Date.now()-this.lastActivityTime}checkInactivity(){let e=this.getTimeSinceLastActivity();if(this.lastActivityTime===0)return"none";let t=1800*1e3;return e>t?(this.log(`Inactivity timeout: ${Math.floor(e/6e4)} minutes since last activity`),"logout"):"none"}async clearSession(){Q.clearCrossSubdomainCookie(this.config.env),await v.clearTokens(),await L.logout(),this.lastActivityTime=0,this.log("Session cleared completely")}getSessionExpiredMessage(){return this.config.translateFn?Fe("SESSION_EXPIRED",{translateFn:this.config.translateFn,enableDebug:this.config.enableLogging}):"Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."}log(e,t){this.config.enableLogging&&c.debug(`[SessionManager] ${e}`,t)}formatError(e){return e?typeof e=="string"?e:typeof e=="object"?Object.values(e).flat().map(String).join(", "):"Authentication failed":"Unknown error"}};import{useEffect as $t,useCallback as j}from"react";import{useState as Ut,useCallback as ee}from"react";var Ge={isAuthenticated:!1,isLoading:!0,isLoggingOut:!1,isInitialized:!1,tokens:null,error:null};function _e(){let[r,e]=Ut(Ge),t=ee(s=>{e(f=>({...f,isLoading:s}))},[]),i=ee((s,f)=>{e(E=>({...E,isAuthenticated:s,tokens:f,error:s?null:E.error}))},[]),n=ee(s=>{e(f=>({...f,isLoggingOut:s}))},[]),o=ee(s=>{e(f=>({...f,error:s}))},[]),l=ee(s=>{e(f=>({...f,isInitialized:s}))},[]);return{state:r,setState:e,setLoading:t,setAuthenticated:i,setLoggingOut:n,setError:o,setInitialized:l}}import{useCallback as le}from"react";var ae={AGGRESSIVE:3e4,MODERATE:6e4,RELAXED:12e4},Te={AGGRESSIVE:300*1e3,MODERATE:1800*1e3},Ve=.5;function $e(r){return r?r.expiresAt-Date.now()<3e5:!1}function Ye(r){return r?Math.max(0,r.expiresAt-Date.now()):0}function We(r){return r?Math.max(0,r.refreshExpiresAt-Date.now()):0}function $(r){return r.crudifyTokens.accessToken?{accessToken:r.crudifyTokens.accessToken,refreshToken:r.crudifyTokens.refreshToken||"",expiresAt:r.crudifyTokens.expiresAt,refreshExpiresAt:r.crudifyTokens.refreshExpiresAt}:null}function Be(r){let{sessionManager:e,stateManager:t}=r,i=le(async(s,f)=>{t.setState(E=>({...E,isLoading:!0,isLoggingOut:!1,error:null}));try{let E=await e.login(s,f);return E.success&&E.tokens?t.setState(b=>({...b,isAuthenticated:!0,tokens:E.tokens,isLoading:!1,isLoggingOut:!1,error:null})):t.setState(b=>({...b,isAuthenticated:!1,tokens:null,isLoading:!1,isLoggingOut:!1,error:null})),E}catch(E){let b=E instanceof Error?E.message:"Login failed";c.error("[useSession] Login error",E instanceof Error?E:{message:b});let S=b.includes("INVALID_CREDENTIALS")||b.includes("Invalid email")||b.includes("Invalid password")||b.includes("credentials");return t.setState(m=>({...m,isAuthenticated:!1,tokens:null,isLoading:!1,isLoggingOut:!1,error:S?null:b})),{success:!1,error:b}}},[e,t]),n=le(async()=>{t.setState(s=>({...s,isLoading:!0,isLoggingOut:!0}));try{await e.logout(),t.setState(s=>({...s,isAuthenticated:!1,tokens:null,isLoading:!1,error:null}))}catch(s){t.setState(f=>({...f,isAuthenticated:!1,tokens:null,isLoading:!1,error:s instanceof Error?s.message:"Logout error"}))}},[e,t]),o=le(async()=>{try{let s=await e.refreshTokens();if(s){let f=await e.getTokenInfo();t.setState(E=>({...E,tokens:$(f),error:null}))}else t.setState(f=>({...f,isAuthenticated:!1,tokens:null,error:"Token refresh failed"}));return s}catch(s){return t.setState(f=>({...f,isAuthenticated:!1,tokens:null,error:s instanceof Error?s.message:"Token refresh failed"})),!1}},[e,t]),l=le(()=>{t.setError(null)},[t]);return{login:i,logout:n,refreshTokens:o,clearError:l}}import{useEffect as Ht,useCallback as Gt}from"react";function _t(r){return r<Te.AGGRESSIVE?ae.AGGRESSIVE:r<Te.MODERATE?ae.MODERATE:ae.RELAXED}function Xe(r){let{isAuthenticated:e,tokens:t,sessionManager:i,onTokensRefreshed:n,onSessionExpired:o,onSetLoading:l,logout:s}=r,f=Gt(()=>{i.updateLastActivity()},[i]);Ht(()=>{if(!e||!t)return;let b=ze.getInstance().subscribe(f);window.addEventListener("popstate",f);let S,m=!0,I=async()=>{if(!m)return;let k=(await i.getTokenInfo()).crudifyTokens.expiresIn||0,R=_t(k);S=setTimeout(async()=>{if(!m)return;if(i.isRefreshing()){I();return}let x=await i.getTokenInfo(),O=x.crudifyTokens.expiresIn||0,z=((x.crudifyTokens.expiresAt||0)-(Date.now()-O))*Ve;if(O>0&&O<=z)if(l(!0),await i.refreshTokens()){let Z=await i.getTokenInfo();n($(Z)),l(!1)}else n(null),o(),l(!1);i.getTimeSinceLastActivity()>18e5?await s():m&&I()},R)};return I(),()=>{m=!1,clearTimeout(S),window.removeEventListener("popstate",f),b()}},[e,t,i,f,n,o,l,s])}import{useEffect as Vt}from"react";function Ze(r){let{sessionManager:e,onTokensUpdated:t,onSessionExpired:i,onSetLoading:n,onSetError:o}=r;Vt(()=>{let l=H.subscribe(async s=>{if(s.type==="TOKEN_EXPIRED"){if(e.isRefreshing())return;n(!0);try{if(await e.refreshTokens()){let E=await e.getTokenInfo();t($(E)),n(!1)}else H.emit("SESSION_EXPIRED",{message:"Failed to refresh token after detecting expiration",source:"useSession.TOKEN_EXPIRED handler"})}catch(f){H.emit("SESSION_EXPIRED",{message:f instanceof Error?f.message:"Unknown error during refresh",source:"useSession.TOKEN_EXPIRED handler (error)"})}}(s.type==="SESSION_EXPIRED"||s.type==="TOKEN_REFRESH_FAILED")&&(t(null),n(!1),o(s.details?.message?.toString()||"Session expired"),i())});return()=>l()},[e,t,i,n,o])}import{useEffect as qe}from"react";function je(r){let{isAuthenticated:e,onTokensUpdated:t,onSessionExpired:i}=r;qe(()=>{let n=async l=>{switch(l.type){case"SESSION_STARTED":case"TOKEN_REFRESHED":try{await v.ensureInitialized();let s=await v.getTokens();s&&(c.debug(`[useCrossTabSync] Syncing ${l.type} from tab ${l.tabId}`),t(s))}catch(s){c.warn("[useCrossTabSync] Failed to read tokens after cross-tab event",{error:s instanceof Error?s.message:String(s)})}break;case"SESSION_ENDED":try{await v.hasValidTokens()||(c.debug(`[useCrossTabSync] Syncing SESSION_ENDED from tab ${l.tabId}`),t(null),e&&i())}catch(s){c.warn("[useCrossTabSync] Failed to verify tokens after logout event",{error:s instanceof Error?s.message:String(s)})}break;case"SESSION_PING":case"SESSION_PONG":break}},o=B.subscribe(n);return()=>o()},[e,t,i]),qe(()=>{let n=v.subscribeToChanges(async(o,l,s)=>{if(l===v.SYNC_EVENTS.TOKENS_CLEARED){if(await v.hasValidTokens())return;s&&e?(t(null),i()):s&&t(null)}else l===v.SYNC_EVENTS.TOKENS_UPDATED&&o&&t(o)});return()=>n()},[e,t,i])}async function Je(r){let{sessionManager:e,options:t,stateActions:i}=r;try{i.setState(s=>({...s,isLoading:!0,error:null}));let n={autoRestore:t.autoRestore??!0,enableLogging:t.enableLogging??!1,showNotification:t.showNotification,translateFn:t.translateFn,apiEndpointAdmin:t.apiEndpointAdmin,apiKeyEndpointAdmin:t.apiKeyEndpointAdmin,publicApiKey:t.publicApiKey,env:t.env||"stg",onSessionExpired:()=>{i.setState(s=>({...s,isAuthenticated:!1,tokens:null,error:"Session expired"})),t.onSessionExpired?.()},onSessionRestored:s=>{i.setState(f=>({...f,isAuthenticated:!0,tokens:s,error:null})),t.onSessionRestored?.(s)},onLoginSuccess:s=>{i.setState(f=>({...f,isAuthenticated:!0,tokens:s,error:null}))},onLogout:()=>{i.setState(s=>({...s,isAuthenticated:!1,tokens:null,error:null}))}};await e.initialize(n),e.setupResponseInterceptor();let o=await e.isAuthenticated(),l=await e.getTokenInfo();i.setState(s=>({...s,isAuthenticated:o,isInitialized:!0,isLoading:!1,isLoggingOut:!1,tokens:$(l)}))}catch(n){let o=n instanceof Error?n.message:"Initialization failed";c.error("[useSession] Initialize failed",n instanceof Error?n:{message:o}),i.setState(l=>({...l,isLoading:!1,isInitialized:!0,isLoggingOut:!1,error:o}))}}function ve(r={}){let e=se.getInstance(),t=_e(),{state:i}=t,{login:n,logout:o,refreshTokens:l,clearError:s}=Be({sessionManager:e,stateManager:t}),f=j(g=>{t.setAuthenticated(!!g,g)},[t]),E=j(()=>{t.setAuthenticated(!1,null),r.onSessionExpired?.()},[t,r.onSessionExpired]),b=j(g=>{t.setLoading(g)},[t]),S=j(g=>{t.setError(g)},[t]);$t(()=>{Je({sessionManager:e,options:r,stateActions:t})},[]),Xe({isAuthenticated:i.isAuthenticated,tokens:i.tokens,sessionManager:e,onTokensRefreshed:f,onSessionExpired:E,onSetLoading:b,logout:o}),Ze({sessionManager:e,onTokensUpdated:f,onSessionExpired:E,onSetLoading:b,onSetError:S}),je({isAuthenticated:i.isAuthenticated,onTokensUpdated:f,onSessionExpired:E});let m=j(()=>{e.updateLastActivity()},[e]),I=j(async()=>e.getTokenInfo(),[e]);return{...i,login:n,logout:o,refreshTokens:l,clearError:s,getTokenInfo:I,updateActivity:m,isExpiringSoon:$e(i.tokens),expiresIn:Ye(i.tokens),refreshExpiresIn:We(i.tokens)}}import{useState as Qe,createContext as Yt,useContext as Wt,useCallback as ce,useEffect as Bt}from"react";import{Snackbar as Xt,Alert as Zt,Box as qt,Portal as jt}from"@mui/material";import{v4 as Jt}from"uuid";import Qt from"dompurify";import{jsx as X,jsxs as ii}from"react/jsx-runtime";var et=Yt(null),ei=r=>Qt.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}),be=({children:r,maxNotifications:e=5,defaultAutoHideDuration:t=6e3,position:i={vertical:"top",horizontal:"right"},enabled:n=!1,allowHtml:o=!1})=>{let[l,s]=Qe([]),f=ce((m,I="info",g)=>{if(!n)return"";if(!m||typeof m!="string")return c.warn("GlobalNotificationProvider: Invalid message provided"),"";m.length>1e3&&(c.warn("GlobalNotificationProvider: Message too long, truncating"),m=m.substring(0,1e3)+"...");let k=Jt(),R={id:k,message:m,severity:I,autoHideDuration:g?.autoHideDuration??t,persistent:g?.persistent??!1,allowHtml:g?.allowHtml??o};return s(x=>[...x.length>=e?x.slice(-(e-1)):x,R]),k},[e,t,n,o]),E=ce(m=>{s(I=>I.filter(g=>g.id!==m))},[]),b=ce(()=>{s([])},[]),S={showNotification:f,hideNotification:E,clearAllNotifications:b};return ii(et.Provider,{value:S,children:[r,n&&X(jt,{children:X(qt,{sx:{position:"fixed",zIndex:9999,[i.vertical]:(i.vertical==="top",24),[i.horizontal]:i.horizontal==="right"||i.horizontal==="left"?24:"50%",...i.horizontal==="center"&&{transform:"translateX(-50%)"},display:"flex",flexDirection:i.vertical==="top"?"column":"column-reverse",gap:1,maxWidth:"400px",width:"auto"},children:l.map(m=>X(ti,{notification:m,onClose:()=>E(m.id)},m.id))})})]})},ti=({notification:r,onClose:e})=>{let[t,i]=Qe(!0),n=ce((o,l)=>{l!=="clickaway"&&(i(!1),setTimeout(e,300))},[e]);return Bt(()=>{if(!r.persistent&&r.autoHideDuration){let o=setTimeout(()=>{n()},r.autoHideDuration);return()=>clearTimeout(o)}},[r.autoHideDuration,r.persistent,n]),X(Xt,{open:t,onClose:n,sx:{position:"relative","& .MuiSnackbarContent-root":{minWidth:"auto"}},TransitionProps:{enter:!0,exit:!0},children:X(Zt,{variant:"filled",severity:r.severity,onClose:n,sx:{width:"100%",minWidth:"280px",maxWidth:"400px",wordBreak:"break-word"},children:r.allowHtml?X("span",{dangerouslySetInnerHTML:{__html:ei(r.message)}}):X("span",{children:r.message})})})},tt=()=>{let r=Wt(et);if(!r)throw new Error("useGlobalNotification debe ser usado dentro de un GlobalNotificationProvider");return r};import{createContext as ri,useContext as ni,useEffect as oi,useState as te}from"react";import ie from"@nocios/crudify-sdk";var Ie=class r{constructor(){this.listeners=[];this.credentials=null;this.isReady=!1}static getInstance(){return r.instance||(r.instance=new r),r.instance}notifyCredentialsReady(e){this.credentials=e,this.isReady=!0,this.listeners.forEach(t=>{try{t(e)}catch(i){c.error("[CredentialsEventBus] Error in listener",i instanceof Error?i:{message:String(i)})}}),this.listeners=[]}waitForCredentials(){return this.isReady&&this.credentials?Promise.resolve(this.credentials):new Promise(e=>{this.listeners.push(e)})}reset(){this.credentials=null,this.isReady=!1,this.listeners=[]}areCredentialsReady(){return this.isReady&&this.credentials!==null}},ue=Ie.getInstance();import{jsx as si}from"react/jsx-runtime";var it=ri(void 0),rt=({config:r,children:e})=>{let[t,i]=te(!0),[n,o]=te(null),[l,s]=te(!1),[f,E]=te(""),[b,S]=te();oi(()=>{if(!r.publicApiKey){o("No publicApiKey provided"),i(!1),s(!1);return}let I=`${r.publicApiKey}-${r.env}`;if(I===f&&l){i(!1);return}(async()=>{i(!0),o(null),s(!1);try{ie.config(r.env||"prod");let k=await ie.init(r.publicApiKey,"none");if(S(k),typeof ie.transaction=="function"&&typeof ie.login=="function")s(!0),E(I),k.apiEndpointAdmin&&k.apiKeyEndpointAdmin&&ue.notifyCredentialsReady({apiUrl:k.apiEndpointAdmin,apiKey:k.apiKeyEndpointAdmin});else throw new Error("Crudify methods not properly initialized")}catch(k){let R=k instanceof Error?k.message:"Failed to initialize Crudify";c.error("[CrudifyProvider] Initialization error",k instanceof Error?k:{message:String(k)}),o(R),s(!1)}finally{i(!1)}})()},[r.publicApiKey,r.env,f,l]);let m={crudify:l?ie:null,isLoading:t,error:n,isInitialized:l,adminCredentials:b};return si(it.Provider,{value:m,children:e})},nt=()=>{let r=ni(it);if(r===void 0)throw new Error("useCrudify must be used within a CrudifyProvider");return r};import ai,{createContext as li,useContext as ci,useMemo as ke}from"react";import{Fragment as di,jsx as P,jsxs as G}from"react/jsx-runtime";var st=li(void 0);function ot({children:r,options:e={},config:t,showNotifications:i=!1,notificationOptions:n={}}){let o;try{let{showNotification:g}=tt();o=g}catch{}let l={};try{let g=nt();g.isInitialized&&g.adminCredentials&&(l=g.adminCredentials)}catch{}let s=ke(()=>{let g=he({publicApiKey:t?.publicApiKey,env:t?.env,enableDebug:e?.enableLogging});return{publicApiKey:g.publicApiKey,env:g.env||"prod"}},[t,e?.enableLogging]),f=ai.useMemo(()=>({...e,showNotification:o,apiEndpointAdmin:l.apiEndpointAdmin,apiKeyEndpointAdmin:l.apiKeyEndpointAdmin,publicApiKey:s.publicApiKey,env:s.env,onSessionExpired:()=>{e.onSessionExpired?.()}}),[e,o,l.apiEndpointAdmin,l.apiKeyEndpointAdmin,s]),E=ve(f),b=ke(()=>{let g=he({publicApiKey:t?.publicApiKey,env:t?.env,appName:t?.appName,logo:t?.logo,loginActions:t?.loginActions,enableDebug:e?.enableLogging});return{publicApiKey:g.publicApiKey,env:g.env,appName:g.appName,loginActions:g.loginActions,logo:g.logo}},[t,e?.enableLogging]),S=ke(()=>{if(!E.tokens?.accessToken||!E.isAuthenticated)return null;try{let g=Ue(E.tokens.accessToken);if(g&&g.sub&&g.email&&g.subscriber){let k={_id:g.sub,email:g.email,subscriberKey:g.subscriber};return Object.keys(g).forEach(R=>{["sub","email","subscriber"].includes(R)||(k[R]=g[R])}),k}}catch(g){c.error("Error decoding JWT token for sessionData",g instanceof Error?g:{message:String(g)})}return null},[E.tokens?.accessToken,E.isAuthenticated]),m={...E,sessionData:S,config:b},I={enabled:i,maxNotifications:n.maxNotifications||5,defaultAutoHideDuration:n.defaultAutoHideDuration||6e3,position:n.position||{vertical:"top",horizontal:"right"}};return P(st.Provider,{value:m,children:r})}function Jr(r){let e={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?P(rt,{config:{publicApiKey:r.config.publicApiKey,env:r.config.env||"prod",appName:r.config.appName,loginActions:r.config.loginActions,logo:r.config.logo},children:P(be,{...e,children:P(ot,{...r})})}):P(be,{...e,children:P(ot,{...r})})}function ui(){let r=ci(st);if(r===void 0)throw new Error("useSessionContext must be used within a SessionProvider");return r}function Qr(){let r=ui();return r.isInitialized?G("div",{style:{padding:"10px",margin:"10px",border:"1px solid #ccc",borderRadius:"4px",fontSize:"12px",fontFamily:"monospace"},children:[P("h4",{children:"Session Debug Info"}),G("div",{children:[P("strong",{children:"Authenticated:"})," ",r.isAuthenticated?"Yes":"No"]}),G("div",{children:[P("strong",{children:"Loading:"})," ",r.isLoading?"Yes":"No"]}),G("div",{children:[P("strong",{children:"Error:"})," ",r.error||"None"]}),r.tokens&&G(di,{children:[G("div",{children:[P("strong",{children:"Access Token:"})," ",r.tokens.accessToken.substring(0,20),"..."]}),G("div",{children:[P("strong",{children:"Refresh Token:"})," ",r.tokens.refreshToken.substring(0,20),"..."]}),G("div",{children:[P("strong",{children:"Access Expires In:"})," ",Math.round(r.expiresIn/1e3/60)," minutes"]}),G("div",{children:[P("strong",{children:"Refresh Expires In:"})," ",Math.round(r.refreshExpiresIn/1e3/60/60)," hours"]}),G("div",{children:[P("strong",{children:"Expiring Soon:"})," ",r.isExpiringSoon?"Yes":"No"]})]})]}):P("div",{children:"Session not initialized"})}import{useState as de,useEffect as at,useCallback as lt,useRef as fe}from"react";import fi from"@nocios/crudify-sdk";var sn=(r={})=>{let{autoFetch:e=!0,retryOnError:t=!1,maxRetries:i=3}=r,[n,o]=de(null),[l,s]=de(!1),[f,E]=de(null),[b,S]=de({}),m=fe(null),I=fe(!0),g=fe(0),k=fe(0),R=lt(()=>{o(null),E(null),s(!1),S({})},[]),x=lt(async()=>{let O=Ke();if(!O){I.current&&(E("No user email available"),s(!1));return}m.current&&m.current.abort();let w=new AbortController;m.current=w;let F=++g.current;try{I.current&&(s(!0),E(null));let z=await fi.readItems("users",{filter:{email:O},pagination:{limit:1}});if(F===g.current&&I.current&&!w.signal.aborted){let D=z.data;if(z.success&&D&&D.length>0){let T=D[0];o(T);let Z={fullProfile:T,totalFields:Object.keys(T).length,displayData:{id:T.id,email:T.email,username:T.username,firstName:T.firstName,lastName:T.lastName,fullName:T.fullName||`${T.firstName||""} ${T.lastName||""}`.trim(),role:T.role,permissions:T.permissions||[],isActive:T.isActive,lastLogin:T.lastLogin,createdAt:T.createdAt,updatedAt:T.updatedAt,...Object.keys(T).filter(V=>!["id","email","username","firstName","lastName","fullName","role","permissions","isActive","lastLogin","createdAt","updatedAt"].includes(V)).reduce((V,ne)=>({...V,[ne]:T[ne]}),{})}};S(Z),E(null),k.current=0}else E("User profile not found"),o(null),S({})}}catch(z){if(F===g.current&&I.current){let D=z;if(D.name==="AbortError")return;t&&k.current<i&&(D.message?.includes("Network Error")||D.message?.includes("Failed to fetch"))?(k.current++,setTimeout(()=>{I.current&&x()},1e3*k.current)):(E("Failed to load user profile"),o(null),S({}))}}finally{F===g.current&&I.current&&s(!1),m.current===w&&(m.current=null)}},[t,i]);return at(()=>{e&&x()},[e,x]),at(()=>(I.current=!0,()=>{I.current=!1,m.current&&(m.current.abort(),m.current=null)}),[]),{userProfile:n,loading:l,error:f,extendedData:b,refreshProfile:x,clearProfile:R}};import{useState as Ae,useEffect as gi,useCallback as ge,useRef as pi}from"react";import mi from"@nocios/crudify-sdk";var un=(r,e={})=>{let{autoFetch:t=!0,onSuccess:i,onError:n}=e,{prefix:o,padding:l=0,separator:s=""}=r,[f,E]=Ae(""),[b,S]=Ae(!1),[m,I]=Ae(null),g=pi(!1),k=ge(w=>{let F=String(w).padStart(l,"0");return`${o}${s}${F}`},[o,l,s]),R=ge(async()=>{S(!0),I(null);try{let w=await mi.getNextSequence(o),F=w.data;if(w.success&&F?.value){let z=k(F.value);E(z),i?.(z)}else{let z=w.errors?._error?.[0]||"Failed to generate code";I(z),n?.(z)}}catch(w){let F=w instanceof Error?w.message:"Unknown error";I(F),n?.(F)}finally{S(!1)}},[o,k,i,n]),x=ge(async()=>{await R()},[R]),O=ge(()=>{I(null)},[]);return gi(()=>{t&&!f&&!g.current&&(g.current=!0,R())},[t,f,R]),{value:f,loading:b,error:m,regenerate:x,clearError:O}};import xe from"@nocios/crudify-sdk";var we=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(e){let{priority:t,publicApiKey:i,env:n,enableLogging:o,requestedBy:l}=e;if(this.state.status==="INITIALIZED"){this.state.publicApiKey!==i&&c.warn(`[CrudifyInitialization] ${l} 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&&c.debug(`[CrudifyInitialization] ${l} waiting for ongoing initialization...`),this.initializationPromise;if(t==="LOW"&&this.highPriorityInitializerPresent&&this.state.status==="UNINITIALIZED"){if(o&&c.debug(`[CrudifyInitialization] ${l} (LOW priority) waiting for HIGH priority initializer...`),this.waitingForHighPriority.add(l),await this.waitForHighPriorityOrTimeout(o),this.waitingForHighPriority.delete(l),this.getState().status==="INITIALIZED"){o&&c.debug(`[CrudifyInitialization] ${l} found initialization completed by HIGH priority`);return}o&&c.warn(`[CrudifyInitialization] ${l} timeout waiting for HIGH priority, initializing with LOW priority`)}t==="HIGH"&&this.state.status==="INITIALIZING"&&this.state.priority==="LOW"&&(c.warn(`[CrudifyInitialization] HIGH priority request from ${l} interrupting LOW priority initialization by ${this.state.initializedBy}`),this.state.status="UNINITIALIZED",this.initializationPromise=null),o&&c.debug(`[CrudifyInitialization] ${l} starting initialization (${t} priority)...`),this.state.status="INITIALIZING",this.state.priority=t,this.state.initializedBy=l,this.initializationPromise=this.performInitialization(i,n,o);try{await this.initializationPromise,this.state.status="INITIALIZED",this.state.publicApiKey=i,this.state.env=n,this.state.error=null,o&&c.info(`[CrudifyInitialization] Successfully initialized by ${l} (${t} priority)`)}catch(s){throw this.state.status="ERROR",this.state.error=s instanceof Error?s:new Error(String(s)),this.initializationPromise=null,c.error(`[CrudifyInitialization] Initialization failed for ${l}`,s instanceof Error?s:{message:String(s)}),s}}async waitForHighPriorityOrTimeout(e){return new Promise(t=>{let n=0,o=setInterval(()=>{if(n+=10,this.state.status==="INITIALIZED"&&this.state.priority==="HIGH"){clearInterval(o),t();return}if(this.state.status==="INITIALIZING"&&this.state.priority==="HIGH"){n=0;return}n>=this.HIGH_PRIORITY_WAIT_TIMEOUT&&(clearInterval(o),e&&c.debug(`[CrudifyInitialization] Timeout waiting for HIGH priority (${this.HIGH_PRIORITY_WAIT_TIMEOUT}ms)`),t())},10)})}async performInitialization(e,t,i){let n=xe.getTokenData();if(n&&n.endpoint){i&&c.debug("[CrudifyInitialization] SDK already initialized externally");return}xe.config(t);let o=i?"debug":"none",l=await xe.init(e,o);if(l.success===!1)throw new Error(`Crudify initialization failed: ${JSON.stringify(l.errors||"Unknown error")}`);l.apiEndpointAdmin&&l.apiKeyEndpointAdmin&&ue.notifyCredentialsReady({apiUrl:l.apiEndpointAdmin,apiKey:l.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}}},re=we.getInstance();import{useState as pe,useCallback as N,useRef as yi,useMemo as J}from"react";import me from"@nocios/crudify-sdk";var ut=r=>{let e=new Uint8Array(r);return crypto.getRandomValues(e),Array.from(e,t=>t.toString(36).padStart(2,"0")).join("").substring(0,r)},ct=()=>`file_${Date.now()}_${ut(7)}`,hi=r=>{let e=r.lastIndexOf("."),t=e>0?r.substring(e):"",i=Date.now(),n=ut(6);return`${i}_${n}${t}`},Ce=(r,e)=>{if(r.startsWith("http://")||r.startsWith("https://"))try{let t=new URL(r);return t.pathname.startsWith("/")?t.pathname.substring(1):t.pathname}catch{if(e&&r.startsWith(e))return r.substring(e.length)}return e&&r.startsWith(e)?r.substring(e.length):r},Tn=(r={})=>{let{acceptedTypes:e,maxFileSize:t=10*1024*1024,maxFiles:i,minFiles:n=0,visibility:o="private",onUploadComplete:l,onUploadError:s,onFileRemoved:f,onFilesChange:E,mode:b="edit"}=r,[S,m]=pe([]),[I,g]=pe(!1),[k,R]=pe(!1),[x,O]=pe([]),w=yi(new Map),F=N(()=>{g(!0)},[]),z=N(()=>{R(!0),g(!0)},[]),D=N((u,p)=>{m(d=>d.map(h=>h.id===u?{...h,...p}:h))},[]),T=N(u=>{E?.(u)},[E]),Z=N(u=>e&&e.length>0&&!e.includes(u.type)?{valid:!1,error:`File type not allowed: ${u.type}`}:u.size>t?{valid:!1,error:`File exceeds maximum size of ${(t/1048576).toFixed(1)}MB`}:{valid:!0},[e,t]),V=N(async(u,p)=>{try{if(!re.isInitialized())throw new Error("Crudify is not initialized. Please wait for the application to finish loading.");let d=hi(p.name),y=await me.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:C,s3Key:A,publicUrl:M}=h;if(!C||!A)throw new Error("Incomplete signed URL response");let Y=A.indexOf("/"),Pt=Y>0?A.substring(Y+1):A;D(u.id,{status:"uploading",progress:0}),await new Promise((ye,W)=>{let U=new XMLHttpRequest;U.upload.addEventListener("progress",_=>{if(_.lengthComputable){let Lt=Math.round(_.loaded/_.total*100);D(u.id,{progress:Lt})}}),U.addEventListener("load",()=>{U.status>=200&&U.status<300?ye():W(new Error(`Upload failed with status ${U.status}`))}),U.addEventListener("error",()=>{W(new Error("Network error during upload"))}),U.addEventListener("abort",()=>{W(new Error("Upload cancelled"))}),U.open("PUT",C),U.setRequestHeader("Content-Type",p.type),U.send(p)});let Dt={status:"completed",progress:100,filePath:Pt,visibility:o,publicUrl:o==="public"?M:void 0,file:void 0};m(ye=>{let W=ye.map(_=>_.id===u.id?{..._,...Dt}:_);T(W);let U=W.find(_=>_.id===u.id);return U&&l?.(U),W})}catch(d){let y=d instanceof Error?d.message:"Unknown error";D(u.id,{status:"error",progress:0,errorMessage:y}),m(h=>{let C=h.find(A=>A.id===u.id);return C&&s?.(C,y),h})}},[D,l,s,o]),ne=N(async u=>{let p=Array.from(u),d=[];m(y=>{if(i!==void 0){let A=y.filter(Y=>Y.status!=="pendingDeletion"&&Y.status!=="error").length,M=i-A;if(M<=0)return c.warn(`File limit of ${i} already reached`),y;p.length>M&&(p=p.slice(0,M),c.warn(`Only ${M} files will be added to not exceed limit`))}let h=[];for(let A of p){let M=Z(A),Y={id:ct(),name:A.name,size:A.size,contentType:A.type,status:M.valid?"pending":"error",progress:0,createdAt:Date.now(),file:M.valid?A:void 0,errorMessage:M.error,isExisting:!1};h.push(Y)}d=h;let C=[...y,...h];return T(C),C}),setTimeout(()=>{let y=d.filter(h=>h.status==="pending"&&h.file);for(let h of y)if(h.file){let C=V(h,h.file);w.current.set(h.id,C),C.finally(()=>{w.current.delete(h.id)})}},0)},[i,Z,V,T]),dt=N(async u=>{let p=S.find(y=>y.id===u);if(!p)return{needsConfirmation:!1,isExisting:!1};let d=p.isExisting===!0;return b==="create"||!d?{needsConfirmation:!0,isExisting:d}:(O(y=>[...y,u]),m(y=>{let h=y.map(A=>A.id===u?{...A,status:"pendingDeletion"}:A),C=h.filter(A=>A.status!=="pendingDeletion");return T(C),h}),{needsConfirmation:!1,isExisting:d})},[S,b,T]),ft=N(async u=>{let p=S.find(d=>d.id===u);if(!p)return{success:!1,error:"File not found"};if(!p.filePath)return m(d=>{let y=d.filter(h=>h.id!==u);return T(y),y}),{success:!0};try{if(!re.isInitialized())return{success:!1,error:"Crudify not initialized"};let d=Ce(p.filePath);return(await me.disableFile({filePath:d})).success?(m(h=>{let C=h.filter(A=>A.id!==u);return T(C),C}),f?.(p),{success:!0}):{success:!1,error:"Failed to delete file"}}catch(d){return{success:!1,error:d instanceof Error?d.message:"Unknown error"}}},[S,T,f]),gt=N(u=>{let p=S.find(d=>d.id===u);return!p||!p.isExisting?!1:(O(d=>d.filter(y=>y!==u)),m(d=>{let y=d.map(h=>h.id===u?{...h,status:"completed"}:h);return T(y),y}),!0)},[S,T]),pt=N(()=>{x.length!==0&&(m(u=>{let p=u.map(d=>x.includes(d.id)?{...d,status:"completed"}:d);return T(p),p}),O([]))},[x,T]),mt=N(async()=>{if(x.length===0)return{success:!0,errors:[]};let u=[],p=[];if(!re.isInitialized())return{success:!1,errors:["Crudify is not initialized. Please wait for the application to finish loading."]};for(let d of x){let y=S.find(h=>h.id===d);if(!y?.filePath){p.push(d);continue}try{let h=Ce(y.filePath);(await me.disableFile({filePath:h})).success?(p.push(d),f?.(y)):u.push(`Failed to delete ${y.name}`)}catch(h){u.push(`Error deleting ${y.name}: ${h instanceof Error?h.message:"Unknown error"}`)}}return p.length>0&&(m(d=>d.filter(h=>!p.includes(h.id))),O(d=>d.filter(y=>!p.includes(y)))),{success:u.length===0,errors:u}},[S,x,f]),yt=N(()=>{m([]),T([])},[T]),ht=N(async u=>{let p=S.find(y=>y.id===u);if(!p||p.status!=="error"||!p.file){c.warn("Cannot retry: file not found or no original file");return}D(u,{status:"pending",progress:0,errorMessage:void 0});let d=V(p,p.file);w.current.set(u,d),d.finally(()=>{w.current.delete(u)})},[S,D,V]),Et=N(async()=>{let u=Array.from(w.current.values());return u.length>0&&await Promise.allSettled(u),new Promise(p=>{setTimeout(()=>{m(d=>{let y=d.filter(h=>h.status==="completed"&&h.filePath).map(h=>h.filePath);return p(y),d})},0)})},[]),St=u=>{let p=u.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"},Tt=N((u,p)=>{let d=u.map(y=>{let h=Ce(y.filePath,p),C=h.includes("/public/")||h.startsWith("public/")?"public":"private",A=y.contentType||St(y.name);return{id:ct(),name:y.name,size:y.size||0,contentType:A,status:"completed",progress:100,filePath:h,visibility:C,createdAt:Date.now(),isExisting:!0}});m(d),T(d)},[T]),vt=N(async u=>{let p=S.find(d=>d.id===u);if(!p||!p.filePath)return null;if(p.visibility==="public"&&p.publicUrl)return p.publicUrl;try{if(!re.isInitialized())return null;let d=await me.getFileUrl({filePath:p.filePath,expiresIn:3600}),y=d.data;return d.success&&y?.url?y.url:null}catch{return null}},[S]),bt=J(()=>S.some(u=>u.status==="uploading"||u.status==="pending"),[S]),It=J(()=>S.filter(u=>u.status==="uploading"||u.status==="pending").length,[S]),kt=J(()=>S.filter(u=>u.status==="completed"&&u.filePath).map(u=>u.filePath),[S]),q=J(()=>S.filter(u=>u.status!=="pendingDeletion"),[S]),At=J(()=>q.filter(u=>u.status==="completed"||u.status==="pending"||u.status==="uploading").length,[q]),{isValid:xt,validationError:wt,validationErrorKey:Ct,validationErrorParams:Rt}=J(()=>{let u=q.filter(d=>d.status==="completed").length;if(u<n){let d=n===1?"file.validation.minFilesRequired":"file.validation.minFilesRequiredPlural";return{isValid:!1,validationError:d,validationErrorKey:d,validationErrorParams:{count:n}}}return i!==void 0&&u>i?{isValid:!1,validationError:"file.validation.maxFilesExceeded",validationErrorKey:"file.validation.maxFilesExceeded",validationErrorParams:{count:i}}:q.some(d=>d.status==="error")?{isValid:!1,validationError:"file.validation.filesWithErrors",validationErrorKey:"file.validation.filesWithErrors",validationErrorParams:{}}:{isValid:!0,validationError:null,validationErrorKey:null,validationErrorParams:{}}},[q,n,i]),Nt=x.length>0;return{files:S,activeFiles:q,activeFileCount:At,isUploading:bt,pendingCount:It,addFiles:ne,removeFile:dt,deleteFileImmediately:ft,restoreFile:gt,clearFiles:yt,retryUpload:ht,isValid:xt,validationError:wt,validationErrorKey:Ct,validationErrorParams:Rt,waitForUploads:Et,completedFilePaths:kt,initializeFiles:Tt,isTouched:I,markAsTouched:F,isSubmitted:k,markAsSubmitted:z,getPreviewUrl:vt,pendingDeletions:x,hasPendingDeletions:Nt,commitDeletions:mt,restorePendingDeletions:pt}};export{v as a,Ee as b,B as c,se as d,ve as e,be as f,tt as g,ue as h,rt as i,nt as j,Jr as k,ui as l,Qr as m,sn as n,un as o,we as p,re as q,Tn as r};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{g as $,l as k}from"./chunk-GT7B57S5.mjs";import{a as V}from"./chunk-4ILUXVPW.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as v}from"react";import Q from"@nocios/crudify-sdk";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-sdk";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-sdk";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};
|
|
1
|
+
import{g as $,l as k}from"./chunk-4KHK3A5S.mjs";import{a as V}from"./chunk-4ILUXVPW.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as v}from"react";import Q from"@nocios/crudify-sdk";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-sdk";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-sdk";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};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } 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 _chunkLK6QVSG4js = require('./chunk-LK6QVSG4.js');var _chunkCR5KJUSTjs = require('./chunk-CR5KJUST.js');var _react = require('react');var _crudifysdk = require('@nocios/crudify-sdk'); var _crudifysdk2 = _interopRequireDefault(_crudifysdk);var J=(w={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:g=3}=w,{isAuthenticated:T,isInitialized:I,sessionData:u,tokens:m}=_chunkLK6QVSG4js.l.call(void 0, ),[R,d]=_react.useState.call(void 0, null),[p,A]=_react.useState.call(void 0, c&&T),[C,E]=_react.useState.call(void 0, null),f=_react.useRef.call(void 0, null),o=_react.useRef.call(void 0, !0),y=_react.useRef.call(void 0, 0),l=_react.useRef.call(void 0, 0),F=_react.useCallback.call(void 0, ()=>{if(!u)return null;let h=u["cognito:username"];return u.email||(typeof h=="string"?h:null)},[u]),L=_react.useCallback.call(void 0, ()=>{d(null),E(null),A(!1),l.current=0},[]),U=_react.useCallback.call(void 0, async()=>{let h=F();if(!h){o.current&&(E("No user email available from session data"),A(!1));return}if(!I){o.current&&(E("Session not initialized"),A(!1));return}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 _crudifysdk2.default.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)&&_optionalChain([t, 'access', _2 => _2.response, 'optionalAccess', _3 => _3.data]))try{let n=t.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e2){}else t&&typeof t=="object"&&!Array.isArray(t)&&t.items&&Array.isArray(t.items)&&t.items.length>0&&(r=t.items[0]);if(!r&&t&&typeof t=="object"&&!Array.isArray(t)&&_optionalChain([t, 'access', _4 => _4.data, 'optionalAccess', _5 => _5.response, 'optionalAccess', _6 => _6.data]))try{let n=t.data.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e3){}}r?(d(r),E(null),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&&(_optionalChain([r, 'access', _7 => _7.message, 'optionalAccess', _8 => _8.includes, 'call', _9 => _9("Network Error")])||_optionalChain([r, 'access', _10 => _10.message, 'optionalAccess', _11 => _11.includes, 'call', _12 => _12("Failed to fetch")]))?(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 _react.useEffect.call(void 0, ()=>{c&&T&&I?U():T||L()},[c,T,I,U,L]),_react.useEffect.call(void 0, ()=>(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}};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}=_chunkLK6QVSG4js.l.call(void 0, ),f=_react.useCallback.call(void 0, y=>{y?_chunkCR5KJUSTjs.a.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):m()},[m]),o=_optionalChain([g, 'optionalAccess', _13 => _13.expiresAt])?new Date(g.expiresAt):null;return{isAuthenticated:w,loading:c,error:T,token:_optionalChain([g, 'optionalAccess', _14 => _14.accessToken])||null,user:I,tokenExpiration:o,setToken:f,logout:m,refreshToken:R,login:u,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E,getTokenInfo:p,clearError:d}};var ae=()=>{let{isInitialized:w,isLoading:c,error:N,isAuthenticated:g,login:T}=_chunkLK6QVSG4js.l.call(void 0, ),I=_react.useCallback.call(void 0, ()=>w&&!c&&!N,[w,c,N]),u=_react.useCallback.call(void 0, async()=>new Promise((o,y)=>{let l=()=>{I()?o():N?y(new Error(N)):setTimeout(l,100)};l()}),[I,N]),m=_react.useCallback.call(void 0, async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),R=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.readItems(o,y||{},l)),[m]),d=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.readItem(o,y,l)),[m]),p=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.createItem(o,y,l)),[m]),A=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.updateItem(o,y,l)),[m]),C=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.deleteItem(o,y,l)),[m]),E=_react.useCallback.call(void 0, async(o,y)=>(await m(),await _crudifysdk2.default.transaction(o,y)),[m]),f=_react.useCallback.call(void 0, 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}};var Y={INVALID_CREDENTIALS:"warning",UNAUTHORIZED:"warning",INVALID_API_KEY:"error",USER_NOT_FOUND:"warning",USER_NOT_ACTIVE:"warning",NO_PERMISSION:"warning",ITEM_NOT_FOUND:"info",NOT_FOUND:"info",IN_USE:"warning",FIELD_ERROR:"warning",BAD_REQUEST:"warning",INTERNAL_SERVER_ERROR:"error",DATABASE_CONNECTION_ERROR:"error",INVALID_CONFIGURATION:"error",UNKNOWN_OPERATION:"error",TOO_MANY_REQUESTS:"warning"},M={INVALID_CREDENTIALS:"errors.auth.INVALID_CREDENTIALS",UNAUTHORIZED:"errors.auth.UNAUTHORIZED",INVALID_API_KEY:"errors.auth.INVALID_API_KEY",USER_NOT_FOUND:"errors.auth.USER_NOT_FOUND",USER_NOT_ACTIVE:"errors.auth.USER_NOT_ACTIVE",NO_PERMISSION:"errors.auth.NO_PERMISSION",ITEM_NOT_FOUND:"errors.data.ITEM_NOT_FOUND",NOT_FOUND:"errors.data.NOT_FOUND",IN_USE:"errors.data.IN_USE",FIELD_ERROR:"errors.data.FIELD_ERROR",BAD_REQUEST:"errors.data.BAD_REQUEST",INTERNAL_SERVER_ERROR:"errors.system.INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"errors.system.DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"errors.system.INVALID_CONFIGURATION",UNKNOWN_OPERATION:"errors.system.UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"errors.system.TOO_MANY_REQUESTS"},de= exports.d =(w={})=>{let{showNotification:c}=_chunkLK6QVSG4js.g.call(void 0, ),{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=_react.useCallback.call(void 0, e=>{if(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||_optionalChain([e, 'access', _15 => _15.errors, 'access', _16 => _16._transaction, 'optionalAccess', _17 => _17.includes, 'call', _18 => _18("ONE_OR_MORE_OPERATIONS_FAILED")])||_optionalChain([e, 'access', _19 => _19.errors, 'access', _20 => _20._error, 'optionalAccess', _21 => _21.includes, 'call', _22 => _22("TOO_MANY_REQUESTS")])))return!1;let i=e.data;return!(!e.success&&_optionalChain([i, 'optionalAccess', _23 => _23.response, 'optionalAccess', _24 => _24.status])==="TOO_MANY_REQUESTS")},[]),p=_react.useCallback.call(void 0, (e,i)=>{let s=R(e);return s===e?i||R("error.unknown"):s},[R]),A=_react.useCallback.call(void 0, e=>["create","update","delete"].includes(e),[]),C=_react.useCallback.call(void 0, (e,i)=>N?A(e)&&i?!0:m.some(s=>s.key===e):!1,[N,m,A]),E=_react.useCallback.call(void 0, (e,i,s)=>{let r=_optionalChain([s, 'optionalAccess', _25 => _25.key])&&typeof s.key=="string"?s.key:e,t=`action.onSuccess.${r}`,n=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=_react.useCallback.call(void 0, 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(_optionalChain([s, 'optionalAccess', _26 => _26.includes, 'call', _27 => _27("ONE_OR_MORE_OPERATIONS_FAILED")]))return"";if(Array.isArray(s)&&s.length>0){let r=s[0];if(typeof r=="string"&&r!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let t=JSON.parse(r);if(Array.isArray(t)&&t.length>0){let n=t[0];if(_optionalChain([n, 'optionalAccess', _28 => _28.response, 'optionalAccess', _29 => _29.errorCode])){let a=n.response.errorCode;if(M[a])return 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(_optionalChain([n, 'optionalAccess', _30 => _30.response, 'optionalAccess', _31 => _31.data]))return n.response.data}if(_optionalChain([t, 'optionalAccess', _32 => _32.response, 'optionalAccess', _33 => _33.message])){let n=t.response.message.toLowerCase();return n.includes("expired")?p("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?p("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t.response.message}}catch (e4){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=_react.useCallback.call(void 0, e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),y=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_optionalChain([s, 'optionalAccess', _34 => _34.actionConfig]),n=_optionalChain([t, 'optionalAccess', _35 => _35.key])||"create",a=_optionalChain([t, 'optionalAccess', _36 => _36.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),l=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.updateItem(e,i,s),t=_optionalChain([s, 'optionalAccess', _37 => _37.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=_optionalChain([s, 'optionalAccess', _38 => _38.actionConfig]),a=_optionalChain([n, 'optionalAccess', _39 => _39.key])||"update",O=_optionalChain([n, 'optionalAccess', _40 => _40.moduleKey])||e;if(C(a,O)){let D=E(a,O,n);c(D,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),F=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_optionalChain([s, 'optionalAccess', _41 => _41.actionConfig]),n=_optionalChain([t, 'optionalAccess', _42 => _42.key])||"delete",a=_optionalChain([t, 'optionalAccess', _43 => _43.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),L=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_react.useCallback.call(void 0, async(e,i)=>{let s=await _crudifysdk2.default.transaction(e,i),r=_optionalChain([i, 'optionalAccess', _44 => _44.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(_optionalChain([i, 'optionalAccess', _45 => _45.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,_nullishCoalesce(a, () => (void 0)));c(O,"success",{autoHideDuration:u})}}return s},[g,C,c,f,o,E,u,d,m]),h=_react.useCallback.call(void 0, (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}};exports.a = J; exports.b = te; exports.c = ae; exports.d = de;
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } 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 _chunkQM34W6EUjs = require('./chunk-QM34W6EU.js');var _chunkCR5KJUSTjs = require('./chunk-CR5KJUST.js');var _react = require('react');var _crudifysdk = require('@nocios/crudify-sdk'); var _crudifysdk2 = _interopRequireDefault(_crudifysdk);var J=(w={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:g=3}=w,{isAuthenticated:T,isInitialized:I,sessionData:u,tokens:m}=_chunkQM34W6EUjs.l.call(void 0, ),[R,d]=_react.useState.call(void 0, null),[p,A]=_react.useState.call(void 0, c&&T),[C,E]=_react.useState.call(void 0, null),f=_react.useRef.call(void 0, null),o=_react.useRef.call(void 0, !0),y=_react.useRef.call(void 0, 0),l=_react.useRef.call(void 0, 0),F=_react.useCallback.call(void 0, ()=>{if(!u)return null;let h=u["cognito:username"];return u.email||(typeof h=="string"?h:null)},[u]),L=_react.useCallback.call(void 0, ()=>{d(null),E(null),A(!1),l.current=0},[]),U=_react.useCallback.call(void 0, async()=>{let h=F();if(!h){o.current&&(E("No user email available from session data"),A(!1));return}if(!I){o.current&&(E("Session not initialized"),A(!1));return}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 _crudifysdk2.default.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)&&_optionalChain([t, 'access', _2 => _2.response, 'optionalAccess', _3 => _3.data]))try{let n=t.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e2){}else t&&typeof t=="object"&&!Array.isArray(t)&&t.items&&Array.isArray(t.items)&&t.items.length>0&&(r=t.items[0]);if(!r&&t&&typeof t=="object"&&!Array.isArray(t)&&_optionalChain([t, 'access', _4 => _4.data, 'optionalAccess', _5 => _5.response, 'optionalAccess', _6 => _6.data]))try{let n=t.data.response.data,a=typeof n=="string"?JSON.parse(n):n;a&&a.items&&Array.isArray(a.items)&&a.items.length>0&&(r=a.items[0])}catch (e3){}}r?(d(r),E(null),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&&(_optionalChain([r, 'access', _7 => _7.message, 'optionalAccess', _8 => _8.includes, 'call', _9 => _9("Network Error")])||_optionalChain([r, 'access', _10 => _10.message, 'optionalAccess', _11 => _11.includes, 'call', _12 => _12("Failed to fetch")]))?(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 _react.useEffect.call(void 0, ()=>{c&&T&&I?U():T||L()},[c,T,I,U,L]),_react.useEffect.call(void 0, ()=>(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}};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}=_chunkQM34W6EUjs.l.call(void 0, ),f=_react.useCallback.call(void 0, y=>{y?_chunkCR5KJUSTjs.a.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):m()},[m]),o=_optionalChain([g, 'optionalAccess', _13 => _13.expiresAt])?new Date(g.expiresAt):null;return{isAuthenticated:w,loading:c,error:T,token:_optionalChain([g, 'optionalAccess', _14 => _14.accessToken])||null,user:I,tokenExpiration:o,setToken:f,logout:m,refreshToken:R,login:u,isExpiringSoon:A,expiresIn:C,refreshExpiresIn:E,getTokenInfo:p,clearError:d}};var ae=()=>{let{isInitialized:w,isLoading:c,error:N,isAuthenticated:g,login:T}=_chunkQM34W6EUjs.l.call(void 0, ),I=_react.useCallback.call(void 0, ()=>w&&!c&&!N,[w,c,N]),u=_react.useCallback.call(void 0, async()=>new Promise((o,y)=>{let l=()=>{I()?o():N?y(new Error(N)):setTimeout(l,100)};l()}),[I,N]),m=_react.useCallback.call(void 0, async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),R=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.readItems(o,y||{},l)),[m]),d=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.readItem(o,y,l)),[m]),p=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.createItem(o,y,l)),[m]),A=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.updateItem(o,y,l)),[m]),C=_react.useCallback.call(void 0, async(o,y,l)=>(await m(),await _crudifysdk2.default.deleteItem(o,y,l)),[m]),E=_react.useCallback.call(void 0, async(o,y)=>(await m(),await _crudifysdk2.default.transaction(o,y)),[m]),f=_react.useCallback.call(void 0, 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}};var Y={INVALID_CREDENTIALS:"warning",UNAUTHORIZED:"warning",INVALID_API_KEY:"error",USER_NOT_FOUND:"warning",USER_NOT_ACTIVE:"warning",NO_PERMISSION:"warning",ITEM_NOT_FOUND:"info",NOT_FOUND:"info",IN_USE:"warning",FIELD_ERROR:"warning",BAD_REQUEST:"warning",INTERNAL_SERVER_ERROR:"error",DATABASE_CONNECTION_ERROR:"error",INVALID_CONFIGURATION:"error",UNKNOWN_OPERATION:"error",TOO_MANY_REQUESTS:"warning"},M={INVALID_CREDENTIALS:"errors.auth.INVALID_CREDENTIALS",UNAUTHORIZED:"errors.auth.UNAUTHORIZED",INVALID_API_KEY:"errors.auth.INVALID_API_KEY",USER_NOT_FOUND:"errors.auth.USER_NOT_FOUND",USER_NOT_ACTIVE:"errors.auth.USER_NOT_ACTIVE",NO_PERMISSION:"errors.auth.NO_PERMISSION",ITEM_NOT_FOUND:"errors.data.ITEM_NOT_FOUND",NOT_FOUND:"errors.data.NOT_FOUND",IN_USE:"errors.data.IN_USE",FIELD_ERROR:"errors.data.FIELD_ERROR",BAD_REQUEST:"errors.data.BAD_REQUEST",INTERNAL_SERVER_ERROR:"errors.system.INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"errors.system.DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"errors.system.INVALID_CONFIGURATION",UNKNOWN_OPERATION:"errors.system.UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"errors.system.TOO_MANY_REQUESTS"},de= exports.d =(w={})=>{let{showNotification:c}=_chunkQM34W6EUjs.g.call(void 0, ),{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=_react.useCallback.call(void 0, e=>{if(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||_optionalChain([e, 'access', _15 => _15.errors, 'access', _16 => _16._transaction, 'optionalAccess', _17 => _17.includes, 'call', _18 => _18("ONE_OR_MORE_OPERATIONS_FAILED")])||_optionalChain([e, 'access', _19 => _19.errors, 'access', _20 => _20._error, 'optionalAccess', _21 => _21.includes, 'call', _22 => _22("TOO_MANY_REQUESTS")])))return!1;let i=e.data;return!(!e.success&&_optionalChain([i, 'optionalAccess', _23 => _23.response, 'optionalAccess', _24 => _24.status])==="TOO_MANY_REQUESTS")},[]),p=_react.useCallback.call(void 0, (e,i)=>{let s=R(e);return s===e?i||R("error.unknown"):s},[R]),A=_react.useCallback.call(void 0, e=>["create","update","delete"].includes(e),[]),C=_react.useCallback.call(void 0, (e,i)=>N?A(e)&&i?!0:m.some(s=>s.key===e):!1,[N,m,A]),E=_react.useCallback.call(void 0, (e,i,s)=>{let r=_optionalChain([s, 'optionalAccess', _25 => _25.key])&&typeof s.key=="string"?s.key:e,t=`action.onSuccess.${r}`,n=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=_react.useCallback.call(void 0, 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(_optionalChain([s, 'optionalAccess', _26 => _26.includes, 'call', _27 => _27("ONE_OR_MORE_OPERATIONS_FAILED")]))return"";if(Array.isArray(s)&&s.length>0){let r=s[0];if(typeof r=="string"&&r!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let t=JSON.parse(r);if(Array.isArray(t)&&t.length>0){let n=t[0];if(_optionalChain([n, 'optionalAccess', _28 => _28.response, 'optionalAccess', _29 => _29.errorCode])){let a=n.response.errorCode;if(M[a])return 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(_optionalChain([n, 'optionalAccess', _30 => _30.response, 'optionalAccess', _31 => _31.data]))return n.response.data}if(_optionalChain([t, 'optionalAccess', _32 => _32.response, 'optionalAccess', _33 => _33.message])){let n=t.response.message.toLowerCase();return n.includes("expired")?p("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?p("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t.response.message}}catch (e4){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=_react.useCallback.call(void 0, e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),y=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_optionalChain([s, 'optionalAccess', _34 => _34.actionConfig]),n=_optionalChain([t, 'optionalAccess', _35 => _35.key])||"create",a=_optionalChain([t, 'optionalAccess', _36 => _36.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),l=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.updateItem(e,i,s),t=_optionalChain([s, 'optionalAccess', _37 => _37.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=_optionalChain([s, 'optionalAccess', _38 => _38.actionConfig]),a=_optionalChain([n, 'optionalAccess', _39 => _39.key])||"update",O=_optionalChain([n, 'optionalAccess', _40 => _40.moduleKey])||e;if(C(a,O)){let D=E(a,O,n);c(D,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),F=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_optionalChain([s, 'optionalAccess', _41 => _41.actionConfig]),n=_optionalChain([t, 'optionalAccess', _42 => _42.key])||"delete",a=_optionalChain([t, 'optionalAccess', _43 => _43.moduleKey])||e;if(C(n,a)){let O=E(n,a,t);c(O,"success",{autoHideDuration:u})}}return r},[g,C,c,f,o,E,u,d]),L=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_react.useCallback.call(void 0, async(e,i,s)=>{let r=await _crudifysdk2.default.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=_react.useCallback.call(void 0, async(e,i)=>{let s=await _crudifysdk2.default.transaction(e,i),r=_optionalChain([i, 'optionalAccess', _44 => _44.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(_optionalChain([i, 'optionalAccess', _45 => _45.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,_nullishCoalesce(a, () => (void 0)));c(O,"success",{autoHideDuration:u})}}return s},[g,C,c,f,o,E,u,d,m]),h=_react.useCallback.call(void 0, (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}};exports.a = J; exports.b = te; exports.c = ae; exports.d = de;
|