@nocios/crudify-components 2.0.32 → 2.0.38
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/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/components/CrudiaAutoGenerate.tsx.html +583 -0
- package/coverage/components/CrudiaFileField/CrudiaFileField.tsx.html +1276 -0
- package/coverage/components/CrudiaFileField/components/DeleteConfirmationDialog.tsx.html +355 -0
- package/coverage/components/CrudiaFileField/components/DropZone.tsx.html +433 -0
- package/coverage/components/CrudiaFileField/components/FileItemRow.tsx.html +751 -0
- package/coverage/components/CrudiaFileField/components/FileThumbnail.tsx.html +1195 -0
- package/coverage/components/CrudiaFileField/components/index.html +176 -0
- package/coverage/components/CrudiaFileField/components/index.ts.html +115 -0
- package/coverage/components/CrudiaFileField/hooks/index.html +146 -0
- package/coverage/components/CrudiaFileField/hooks/index.ts.html +112 -0
- package/coverage/components/CrudiaFileField/hooks/useDeleteConfirmation.ts.html +421 -0
- package/coverage/components/CrudiaFileField/hooks/useDragDrop.ts.html +403 -0
- package/coverage/components/CrudiaFileField/index.html +131 -0
- package/coverage/components/CrudiaFileField/index.ts.html +112 -0
- package/coverage/components/CrudiaFileField/utils/formatters.ts.html +163 -0
- package/coverage/components/CrudiaFileField/utils/icons.tsx.html +253 -0
- package/coverage/components/CrudiaFileField/utils/index.html +131 -0
- package/coverage/components/CrudiaMarkdownField.tsx.html +619 -0
- package/coverage/components/CrudifyLogin/Forms/CheckCodeForm.tsx.html +586 -0
- package/coverage/components/CrudifyLogin/Forms/ForgotPasswordForm.tsx.html +694 -0
- package/coverage/components/CrudifyLogin/Forms/LoginForm.tsx.html +835 -0
- package/coverage/components/CrudifyLogin/Forms/ResetPasswordForm.tsx.html +1180 -0
- package/coverage/components/CrudifyLogin/Forms/components/CodeInput.tsx.html +283 -0
- package/coverage/components/CrudifyLogin/Forms/components/FormAlert.tsx.html +202 -0
- package/coverage/components/CrudifyLogin/Forms/components/PasswordInput.tsx.html +340 -0
- package/coverage/components/CrudifyLogin/Forms/components/index.html +161 -0
- package/coverage/components/CrudifyLogin/Forms/components/index.ts.html +106 -0
- package/coverage/components/CrudifyLogin/Forms/index.html +161 -0
- package/coverage/components/CrudifyLogin/Forms/utils/errorTranslation.ts.html +268 -0
- package/coverage/components/CrudifyLogin/Forms/utils/index.html +161 -0
- package/coverage/components/CrudifyLogin/Forms/utils/index.ts.html +106 -0
- package/coverage/components/CrudifyLogin/Forms/utils/paramUtils.ts.html +478 -0
- package/coverage/components/CrudifyLogin/Forms/utils/validation.ts.html +289 -0
- package/coverage/components/CrudifyLogin/components/CrudifyInitializer.tsx.html +262 -0
- package/coverage/components/CrudifyLogin/components/index.html +116 -0
- package/coverage/components/CrudifyLogin/context/CrudifyProvider.tsx.html +382 -0
- package/coverage/components/CrudifyLogin/context/I18nProvider.tsx.html +397 -0
- package/coverage/components/CrudifyLogin/context/LoginStateProvider.tsx.html +1249 -0
- package/coverage/components/CrudifyLogin/context/index.html +146 -0
- package/coverage/components/CrudifyLogin/hooks/index.html +116 -0
- package/coverage/components/CrudifyLogin/hooks/useTranslationsFromUrl.ts.html +292 -0
- package/coverage/components/CrudifyLogin/index.html +116 -0
- package/coverage/components/CrudifyLogin/index.tsx.html +475 -0
- package/coverage/components/GlobalNotificationProvider.tsx.html +781 -0
- package/coverage/components/LoginComponent.tsx.html +727 -0
- package/coverage/components/PasswordRequirements/index.html +116 -0
- package/coverage/components/PasswordRequirements/index.tsx.html +226 -0
- package/coverage/components/PublicPolicies/FieldSelector/FieldSelector.tsx.html +982 -0
- package/coverage/components/PublicPolicies/FieldSelector/index.html +131 -0
- package/coverage/components/PublicPolicies/FieldSelector/index.ts.html +85 -0
- package/coverage/components/PublicPolicies/Policies.tsx.html +610 -0
- package/coverage/components/PublicPolicies/PolicyItem/PolicyItem.tsx.html +856 -0
- package/coverage/components/PublicPolicies/PolicyItem/index.html +131 -0
- package/coverage/components/PublicPolicies/PolicyItem/index.ts.html +85 -0
- package/coverage/components/PublicPolicies/constants.ts.html +127 -0
- package/coverage/components/PublicPolicies/index.html +131 -0
- package/coverage/components/SessionTimeIndicator/index.html +116 -0
- package/coverage/components/SessionTimeIndicator/index.tsx.html +505 -0
- package/coverage/components/UserProfile/UserProfileDisplay.tsx.html +826 -0
- package/coverage/components/UserProfile/index.html +131 -0
- package/coverage/components/UserProfile/index.ts.html +85 -0
- package/coverage/components/index.html +176 -0
- package/coverage/components/index.ts.html +160 -0
- package/coverage/core/CrossTabSyncManager.ts.html +814 -0
- package/coverage/core/CrudifyInitializationManager.ts.html +1132 -0
- package/coverage/core/SessionManager.ts.html +2764 -0
- package/coverage/core/index.html +146 -0
- package/coverage/coverage-final.json +87 -0
- package/coverage/favicon.png +0 -0
- package/coverage/hooks/index.html +131 -0
- package/coverage/hooks/useAutoGenerate.ts.html +562 -0
- package/coverage/hooks/useFileUpload/index.html +131 -0
- package/coverage/hooks/useFileUpload/index.ts.html +112 -0
- package/coverage/hooks/useFileUpload/services/index.html +116 -0
- package/coverage/hooks/useFileUpload/services/uploadService.ts.html +610 -0
- package/coverage/hooks/useFileUpload/useFileUpload.ts.html +1870 -0
- package/coverage/hooks/useFileUpload/utils/fileUtils.ts.html +271 -0
- package/coverage/hooks/useFileUpload/utils/index.html +146 -0
- package/coverage/hooks/useFileUpload/utils/mimeTypes.ts.html +235 -0
- package/coverage/hooks/useFileUpload/utils/validation.ts.html +379 -0
- package/coverage/hooks/useSession/constants.ts.html +217 -0
- package/coverage/hooks/useSession/hooks/index.html +176 -0
- package/coverage/hooks/useSession/hooks/useAuthEventSubscriber.ts.html +331 -0
- package/coverage/hooks/useSession/hooks/useCrossTabSync.ts.html +433 -0
- package/coverage/hooks/useSession/hooks/useSessionActions.ts.html +664 -0
- package/coverage/hooks/useSession/hooks/useSessionState.ts.html +295 -0
- package/coverage/hooks/useSession/hooks/useTokenRefreshScheduler.ts.html +490 -0
- package/coverage/hooks/useSession/index.html +161 -0
- package/coverage/hooks/useSession/index.ts.html +127 -0
- package/coverage/hooks/useSession/types.ts.html +427 -0
- package/coverage/hooks/useSession/useSession.ts.html +526 -0
- package/coverage/hooks/useSession/utils/index.html +131 -0
- package/coverage/hooks/useSession/utils/initializeSession.ts.html +424 -0
- package/coverage/hooks/useSession/utils/tokenUtils.ts.html +280 -0
- package/coverage/hooks/useUserProfile.ts.html +658 -0
- package/coverage/index.html +566 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/providers/SessionProvider.tsx.html +1150 -0
- package/coverage/providers/TranslationsProvider.tsx.html +1450 -0
- package/coverage/providers/index.html +131 -0
- package/coverage/services/credentialsEventBus.ts.html +310 -0
- package/coverage/services/index.html +131 -0
- package/coverage/services/translationService.ts.html +1318 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +210 -0
- package/coverage/translations/critical.ts.html +1195 -0
- package/coverage/translations/index.html +116 -0
- package/coverage/types/index.html +116 -0
- package/coverage/types/password.ts.html +178 -0
- package/coverage/utils/authEventBus.ts.html +454 -0
- package/coverage/utils/configResolver.ts.html +460 -0
- package/coverage/utils/cookieSync.ts.html +580 -0
- package/coverage/utils/errorHandler.ts.html +1264 -0
- package/coverage/utils/errorTranslation.ts.html +862 -0
- package/coverage/utils/index.html +296 -0
- package/coverage/utils/jwtUtils.ts.html +301 -0
- package/coverage/utils/logger.ts.html +901 -0
- package/coverage/utils/navigationTracker.ts.html +565 -0
- package/coverage/utils/passwordValidation.ts.html +259 -0
- package/coverage/utils/redirectSecurity.ts.html +715 -0
- package/coverage/utils/tenantConfig.ts.html +700 -0
- package/coverage/utils/tokenStorage.ts.html +1768 -0
- package/coverage/utils/webCrypto.ts.html +472 -0
- package/dist/{CrudiaMarkdownField-C54-A_J3.d.mts → CrudiaMarkdownField-BvJn2GL8.d.mts} +17 -7
- package/dist/{CrudiaMarkdownField-C8HQh7s5.d.ts → CrudiaMarkdownField-CggOpcBM.d.ts} +17 -7
- package/dist/chunk-44VU4TSP.mjs +1 -0
- package/dist/chunk-4LMFQECS.js +1 -0
- package/dist/chunk-77UKXG5L.mjs +1 -0
- package/dist/{chunk-4VN5YRYZ.js → chunk-BXFEQ6KP.js} +1 -1
- package/dist/{chunk-6ONAT4QU.js → chunk-H6XXWDUT.js} +1 -1
- package/dist/chunk-NIRLP2TC.js +1 -0
- package/dist/chunk-O4FUHIQG.mjs +1 -0
- package/dist/chunk-SYHNHKFA.mjs +1 -0
- package/dist/chunk-W4ZYKPOK.js +1 -0
- package/dist/{chunk-RJBX4MWF.mjs → chunk-WMLIOPUC.mjs} +1 -1
- package/dist/components.d.mts +1 -1
- package/dist/components.d.ts +1 -1
- package/dist/components.js +1 -1
- package/dist/components.mjs +1 -1
- package/dist/errorTranslation-D-Y7uNN_.d.mts +141 -0
- package/dist/errorTranslation-DDlAXpMl.d.ts +141 -0
- package/dist/hooks.d.mts +2 -2
- package/dist/hooks.d.ts +2 -2
- package/dist/hooks.js +1 -1
- package/dist/hooks.mjs +1 -1
- package/dist/{index-DY90WVQQ.d.mts → index-U--xRr8A.d.mts} +225 -191
- package/dist/{index-d1vE803G.d.ts → index-dXVRVcEB.d.ts} +225 -191
- package/dist/index.d.mts +179 -6
- package/dist/index.d.ts +179 -6
- package/dist/index.js +2 -2
- package/dist/index.mjs +1 -1
- package/dist/{errorTranslation-By5Av0tL.d.ts → tenantConfig-DqJqQkoR.d.mts} +116 -139
- package/dist/{errorTranslation-DeeDj7Vt.d.mts → tenantConfig-DqJqQkoR.d.ts} +116 -139
- package/dist/utils.d.mts +2 -2
- package/dist/utils.d.ts +2 -2
- package/dist/utils.js +1 -1
- package/dist/utils.mjs +1 -1
- package/package.json +1 -1
- package/coverage/.tmp/coverage-102.json +0 -1
- package/coverage/.tmp/coverage-103.json +0 -1
- package/coverage/.tmp/coverage-104.json +0 -1
- package/coverage/.tmp/coverage-105.json +0 -1
- package/coverage/.tmp/coverage-106.json +0 -1
- package/coverage/.tmp/coverage-107.json +0 -1
- package/dist/api-B4uXiHF0.d.mts +0 -118
- package/dist/api-B4uXiHF0.d.ts +0 -118
- package/dist/chunk-4ILUXVPW.mjs +0 -1
- package/dist/chunk-5XBTRBE5.js +0 -1
- package/dist/chunk-CR5KJUST.js +0 -1
- package/dist/chunk-H5M2Q6PB.mjs +0 -1
- package/dist/chunk-JAPL7EZJ.mjs +0 -1
- package/dist/chunk-L7GKP6XY.mjs +0 -1
- package/dist/chunk-NSV6ECYO.js +0 -1
- package/dist/chunk-PTUSZGL4.mjs +0 -1
- package/dist/chunk-T6R65ROU.js +0 -1
|
@@ -0,0 +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 _chunkH6XXWDUTjs = require('./chunk-H6XXWDUT.js');var _chunk4LMFQECSjs = require('./chunk-4LMFQECS.js');var de={es:{"base.actions.create":"Nuevo","base.actions.delete":"Eliminar","base.actions.read":"Ver","base.actions.refresh":"Refrescar","base.actions.update":"Editar","base.btn.back":"Volver","base.btn.cancel":"Cancelar","base.btn.hidePassword":"Ocultar contrase\xF1a","base.btn.showPassword":"Mostrar contrase\xF1a","base.errors.errorUnknown":"Ocurri\xF3 un error desconocido.","base.fields.actions":"Acciones","base.fields.confirmPassword":"Confirmar contrase\xF1a","base.fields.createdAt":"Creado el","base.fields.email":"Correo electr\xF3nico","base.fields.lastName":"Apellido","base.fields.name":"Nombre","base.fields.password":"Contrase\xF1a","base.fields.profile":"Perfil","base.fields.updatedAt":"Actualizado el","base.file.allowedTypes":"Tipos permitidos: {{types}}","base.file.clickToDownload":"Clic para descargar","base.file.clickToPreview":"Clic para ver imagen","base.file.confirmDelete.cancel":"Cancelar","base.file.confirmDelete.confirm":"Eliminar","base.file.confirmDelete.message":"\xBFEst\xE1s seguro de que deseas eliminar este archivo? Esta acci\xF3n no se puede deshacer.","base.file.confirmDelete.title":"Eliminar archivo","base.file.delete":"Eliminar","base.file.deleting":"Eliminando...","base.file.dragOrClick":"Arrastra archivos aqu\xED o haz clic para seleccionar","base.file.dropHere":"Suelta el archivo aqu\xED","base.file.maxFiles":"M\xE1ximo {{count}} archivos","base.file.maxSize":"M\xE1ximo {{size}} por archivo","base.file.noPreview":"Sin vista previa","base.file.pendingDeletion":"Pendiente de eliminaci\xF3n","base.file.privateFile":"Archivo privado","base.file.restore":"Restaurar","base.file.uploading":"Subiendo archivos...","base.file.validation.filesWithErrors":"Algunos archivos tienen errores","base.file.validation.maxFilesExceeded":"M\xE1ximo {{count}} archivos permitidos","base.file.validation.minFilesRequired":"Se requiere al menos un archivo","base.file.validation.minFilesRequiredPlural":"Se requieren al menos {{count}} archivos","base.lastUpdated":"\xDAltima actualizaci\xF3n a las {{formattedLastUpdated}}","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...","base.titles.create":"Nuevo {{moduleName}}","base.titles.read":"Ver {{moduleName}}","base.titles.update":"Editar {{moduleName}}","base.success.transaction":"La operaci\xF3n se ha completado con \xE9xito.","base.loading.executing":"Ejecutando operaci\xF3n...","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","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","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","login.alreadyHaveCodeLink":"\xBFYa tienes un c\xF3digo?","login.forgotPasswordLink":"\xBFOlvidaste tu contrase\xF1a?","login.initializationError":"Error de inicializaci\xF3n","login.initializing":"Inicializando...","login.loginButton":"Iniciar sesi\xF3n","login.logoAlt":"Logotipo","login.noAccountPrompt":"\xBFNo tienes una cuenta?","login.notInitialized":"Sistema no inicializado","login.passwordLabel":"Contrase\xF1a","login.passwordPlaceholder":"Ingresa tu contrase\xF1a","login.passwordRequired":"Contrase\xF1a es obligatoria","login.signUpLink":"Reg\xEDstrate","login.usernameOrEmailLabel":"Usuario o correo electr\xF3nico","login.usernameOrEmailPlaceholder":"Ingresa tu correo electr\xF3nico","login.usernameRequired":"El usuario es requerido","passwordRequirements.lowercase":"Una letra min\xFAscula","passwordRequirements.minLength":"M\xEDnimo 8 caracteres","passwordRequirements.number":"Un n\xFAmero","passwordRequirements.special":"Un car\xE1cter especial (!@#$%...)","passwordRequirements.uppercase":"Una letra may\xFAscula","profiles.actions.assignProfiles":"Asignar perfiles","profiles.moduleName":"Perfiles","profiles.moduleSingular":"Perfil","publicPolicies.fields.conditions.customEdit":"Edici\xF3n personalizada","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.passwordRequirementsNotMet":"La contrase\xF1a no cumple con todos los requisitos","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...","translations.fields.lang":"Idioma","translations.moduleName":"Traducciones","translations.moduleSingular":"Traducci\xF3n","users.fields.currentPassword":"Contrase\xF1a actual","users.fields.newPassword":"Nueva Contrase\xF1a","users.fields.repeatNewPassword":"Repetir Nueva Contrase\xF1a","users.moduleName":"Usuarios","users.moduleSingular":"Usuario"},en:{"base.actions.create":"New","base.actions.delete":"Delete","base.actions.read":"View","base.actions.refresh":"Refresh","base.actions.update":"Edit","base.btn.back":"Back","base.btn.cancel":"Cancel","base.btn.hidePassword":"Hide password","base.btn.showPassword":"Show password","base.errors.errorUnknown":"An unknown error occurred.","base.fields.actions":"Actions","base.fields.confirmPassword":"Confirm password","base.fields.createdAt":"Created at","base.fields.email":"Email","base.fields.lastName":"Last name","base.fields.name":"Name","base.fields.password":"Password","base.fields.profile":"Profile","base.fields.updatedAt":"Updated at","base.file.allowedTypes":"Allowed types: {{types}}","base.file.clickToDownload":"Click to download","base.file.clickToPreview":"Click to preview image","base.file.confirmDelete.cancel":"Cancel","base.file.confirmDelete.confirm":"Delete","base.file.confirmDelete.message":"Are you sure you want to delete this file? This action cannot be undone.","base.file.confirmDelete.title":"Delete file","base.file.delete":"Delete","base.file.deleting":"Deleting...","base.file.dragOrClick":"Drag files here or click to select","base.file.dropHere":"Drop file here","base.file.maxFiles":"Maximum {{count}} files","base.file.maxSize":"Maximum {{size}} per file","base.file.noPreview":"No preview","base.file.pendingDeletion":"Pending deletion","base.file.privateFile":"Private file","base.file.restore":"Restore","base.file.uploading":"Uploading files...","base.file.validation.filesWithErrors":"Some files have errors","base.file.validation.maxFilesExceeded":"Maximum {{count}} files allowed","base.file.validation.minFilesRequired":"At least one file is required","base.file.validation.minFilesRequiredPlural":"At least {{count}} files are required","base.lastUpdated":"Last updated at {{formattedLastUpdated}}","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...","base.titles.create":"New {{moduleName}}","base.titles.read":"View {{moduleName}}","base.titles.update":"Edit {{moduleName}}","base.success.transaction":"The operation has been completed successfully.","base.loading.executing":"Processing\u2026","checkCode.codeLabel":"Verification Code","checkCode.codePlaceholder":"Enter the 6-digit code","checkCode.codeRequired":"Code is required","checkCode.emailLabel":"Email","checkCode.emailPlaceholder":"Enter your email","checkCode.emailRequired":"Email is required","checkCode.instructions":"Enter the 6-digit code we sent to your email.","checkCode.invalidEmail":"Enter a valid email address","checkCode.resendCodeLink":"Resend code","checkCode.title":"Verify Code","checkCode.verifyButton":"Verify Code","error.app.config":"Configuration Error: {{message}}","error.app.initialization":"Error during final application initialization.","error.transaction":"Operation error","errors.DUPLICATE":"The <b>{{field}}</b> field must be unique.","errors.FOREIGN_KEY_NOT_FOUND":"The <b>{{field}}</b> field must reference an existing item.","errors.INVALID_EMAIL":"The <b>{{field}}</b> field must be a valid email address.","errors.INVALID_OBJECT_ID":"The <b>{{field}}</b> field must be a valid value.","errors.IN_USE":"The item is in use and cannot be deleted.","errors.MAX_LENGTH":"The <b>{{field}}</b> field must not exceed <b>{{length}}</b> characters.","errors.MIN_LENGTH":"The <b>{{field}}</b> field must be at least <b>{{length}}</b> characters.","errors.MUST_NOT_BE_EMAIL":"The <b>{{field}}</b> field must not be an email.","errors.NO_PERMISSION":"You don't have permission to perform this action.","errors.NO_SPACES":"The <b>{{field}}</b> field must not contain spaces.","errors.ONE_OR_MORE_OPERATIONS_FAILED":"Operation error","errors.REQUIRED":"The <b>{{field}}</b> field is required.","errors.TOKEN_HAS_EXPIRED":"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":"Invalid username and/or password","errors.auth.NO_PERMISSION":"You don't have sufficient 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 not active","errors.auth.USER_NOT_FOUND":"User not found","errors.data.BAD_REQUEST":"Invalid request","errors.data.FIELD_ERROR":"Error in submitted 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":"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 has already been sent and is still valid","forgotPassword.emailLabel":"Email","forgotPassword.emailPlaceholder":"Enter your email","forgotPassword.emailRequired":"Email is required","forgotPassword.emailSentMessage":"Code sent successfully","forgotPassword.enterCodeLink":"Enter Code","forgotPassword.instructions":"Enter your email and we'll send you a code to reset your password.","forgotPassword.invalidEmail":"Enter a valid email address","forgotPassword.sendCodeButton":"Send Code","forgotPassword.title":"Recover Password","login.alreadyHaveCodeLink":"Already have a code?","login.forgotPasswordLink":"Forgot your 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 email","login.usernameRequired":"Username is required","passwordRequirements.lowercase":"One lowercase letter","passwordRequirements.minLength":"Minimum 8 characters","passwordRequirements.number":"One number","passwordRequirements.special":"One special character (!@#$%...)","passwordRequirements.uppercase":"One uppercase letter","profiles.actions.assignProfiles":"Assign profiles","profiles.moduleName":"Profiles","profiles.moduleSingular":"Profile","publicPolicies.fields.conditions.customEdit":"Custom edit","resetPassword.codeExpiredOrInvalid":"The code has expired or is 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.passwordRequirementsNotMet":"Password does not meet all requirements","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...","translations.fields.lang":"Language","translations.moduleName":"Translations","translations.moduleSingular":"Translation","users.fields.currentPassword":"Current password","users.fields.newPassword":"New Password","users.fields.repeatNewPassword":"Repeat New Password","users.moduleName":"Users","users.moduleSingular":"User"}},ni= exports.b =()=>Object.keys(de),ai= exports.c =e=>de[e]||de.es;var _crudifysdk = require('@nocios/crudify-sdk'); var _crudifysdk2 = _interopRequireDefault(_crudifysdk);var xo="crudify_translations_",_t=3600*1e3;function Co(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 Pr=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&&_chunk4LMFQECSjs.a.debug("[TranslationService] Waiting for crudify initialization..."),this.initializationPromise):(this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Initializing crudify SDK..."),this.initializationPromise=(async()=>{try{let t=_crudifysdk2.default.getTokenData();if(t&&t.endpoint){this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Crudify already initialized"),this.isInitialized=!0;return}_crudifysdk2.default.config(o);let a=await _crudifysdk2.default.init(r,this.enableDebug?"debug":"none");if(a.success===!1)throw new Error(`Failed to initialize crudify: ${JSON.stringify(a.errors||"Unknown error")}`);this.isInitialized=!0,this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Crudify SDK initialized successfully")}catch(t){throw _chunk4LMFQECSjs.a.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:a="stg",urlTranslations:n}=r;this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] fetchTranslations called with:",{apiKeyHash:Co(o),crudifyEnv:a,featureKeys:t,hasUrlTranslations:!!n});let s=this.getFromCache(o),l=s?this.isCacheExpired(s):!0;if(s&&!l)return this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Using cached translations"),this.mergeWithUrlTranslations(s.data.translations,n);try{await this.ensureCrudifyInitialized(o,a)}catch(i){return _chunk4LMFQECSjs.a.error("[TranslationService] Failed to initialize crudify",i instanceof Error?i:{message:String(i)}),s?(_chunk4LMFQECSjs.a.warn("[TranslationService] Using expired cache (init failed)"),this.mergeWithUrlTranslations(s.data.translations,n)):(_chunk4LMFQECSjs.a.warn("[TranslationService] Using critical bundle (init failed)"),this.getCriticalTranslationsOnly())}try{this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Fetching from API via crudify SDK");let i=await this.fetchFromAPI(t);this.hasDataChanged(s,i)||!s?this.saveToCache(o,i):this.refreshCacheTimestamp(o);let d=this.mergeWithUrlTranslations(i.translations,n);return this.enableDebug&&_chunk4LMFQECSjs.a.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(i){return _chunk4LMFQECSjs.a.error("[TranslationService] API fetch failed",i instanceof Error?i:{message:String(i)}),s?(_chunk4LMFQECSjs.a.warn("[TranslationService] Using expired cache as fallback"),this.mergeWithUrlTranslations(s.data.translations,n)):(_chunk4LMFQECSjs.a.warn("[TranslationService] Using critical bundle translations"),this.getCriticalTranslationsOnly())}}async fetchFromAPI(r){let o=await _crudifysdk2.default.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(a=>{t[a]={...r[a],...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 a=0;a<o.length;a++){let n=o.charCodeAt(a);t=(t<<5)-t+n,t=t&t}return t.toString(36)}saveToCache(r,o){try{let t=this.getCacheKey(r),a={data:o,cachedAt:Date.now(),dataHash:this.hashData(o.translations)};localStorage.setItem(t,JSON.stringify(a)),this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Saved to cache:",{cacheKey:t})}catch(t){_chunk4LMFQECSjs.a.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 _chunk4LMFQECSjs.a.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){_chunk4LMFQECSjs.a.error("[TranslationService] Failed to refresh cache timestamp",o instanceof Error?o:{message:String(o)})}}isCacheExpired(r){return Date.now()-r.cachedAt>_t}hasValidCache(r){let o=this.getFromCache(r);return o?!this.isCacheExpired(o):!1}getCacheKey(r){return`${xo}${Co(r)}`}getCriticalTranslationsOnly(){return de}invalidateCache(r){let o=this.getCacheKey(r);localStorage.removeItem(o),this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Cache invalidated:",{cacheKey:o})}async prefetchTranslations(r){try{await this.fetchTranslations(r),this.enableDebug&&_chunk4LMFQECSjs.a.debug("[TranslationService] Prefetch completed")}catch(o){_chunk4LMFQECSjs.a.error("[TranslationService] Prefetch failed",o instanceof Error?o:{message:String(o)})}}clearAllCaches(){try{let o=Object.keys(localStorage).filter(t=>t.startsWith(xo));o.forEach(t=>localStorage.removeItem(t)),this.enableDebug&&_chunk4LMFQECSjs.a.debug(`[TranslationService] Cleared ${o.length} cache entries`)}catch(r){_chunk4LMFQECSjs.a.error("[TranslationService] Failed to clear caches",r instanceof Error?r:{message:String(r)})}}},Ze= exports.e =Pr.getInstance();var _react = require('react'); var _react2 = _interopRequireDefault(_react);var _jsxruntime = require('react/jsx-runtime');var Je=null,vr=!1,To=_react.createContext.call(void 0, null);function vo(e,r,o){return{...e,...r,...o||{}}}function Ut(e,r,o,t,a){_react.useEffect.call(void 0, ()=>{if(!t||!e||!r)return;let n=o||typeof window<"u"&&window.i18next||typeof window<"u"&&window.i18n;if(!n||!n.addResourceBundle){a&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] i18next not found, skipping auto-sync");return}a&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] Auto-syncing translations with i18next",{languages:Object.keys(e),currentLanguage:r}),Object.keys(e).forEach(s=>{e[s]&&Object.keys(e[s]).length>0&&(n.addResourceBundle(s,"translation",e[s],!0,!0),a&&_chunk4LMFQECSjs.a.debug(`[TranslationsProvider] Synced ${Object.keys(e[s]).length} keys for language: ${s}`))}),n.language!==r&&n.changeLanguage&&(n.changeLanguage(r),a&&_chunk4LMFQECSjs.a.debug(`[TranslationsProvider] Changed i18next language to: ${r}`))},[e,r,o,t,a])}var yi=({children:e,apiKey:r,crudifyEnv:o="prod",featureKeys:t,language:a="es",devTranslations:n,translationUrl:s,enableDebug:l=!1,skipAutoInit:i=!0,autoSyncI18n:f=!0,i18nInstance:d,loadingFallback:y,waitForInitialLoad:x=!0})=>{let c=_react.useMemo.call(void 0, ()=>_chunk4LMFQECSjs.d.call(void 0, {publicApiKey:r,env:o,featureKeys:t,enableDebug:l}),[r,o,t,l]),u=c.publicApiKey||"",p=c.env||o||"prod",m=c.featureKeys||t,[g,h]=_react.useState.call(void 0, {}),[C,S]=_react.useState.call(void 0, !0),[T,b]=_react.useState.call(void 0, !0),[R,A]=_react.useState.call(void 0, null),[W,ve]=_react.useState.call(void 0, void 0),[ne,ae]=_react.useState.call(void 0, !1),ee=_react.useCallback.call(void 0, async()=>{if(!u){l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] No apiKey - skipping translation fetch"),S(!1),b(!1);return}if(ne){l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] Skipping reload - using fallback translations");return}if(Ze.hasValidCache(u)&&T&&(l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] Valid cache found - not blocking initial render"),b(!1)),vr&&Je){l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] Fetch already in progress, waiting for existing promise");try{let E=await Je;h(E),S(!1);return}catch (e2){l&&_chunk4LMFQECSjs.a.warn("[TranslationsProvider] Global fetch failed, retrying")}}vr=!0,S(!0),A(null);let I;if(s)try{l&&_chunk4LMFQECSjs.a.debug(`[TranslationsProvider] Fetching translations from URL: ${s}`);let E=await fetch(s);if(!E.ok)throw new Error(`Failed to fetch translations: ${E.statusText}`);I=await E.json(),ve(I),l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] URL translations loaded:",{keysCount:I?Object.keys(I).length:0})}catch(E){_chunk4LMFQECSjs.a.error("[TranslationsProvider] Failed to load URL translations",E instanceof Error?E:{message:String(E)}),I=void 0,ve(void 0)}let Y=(async()=>{try{Ze.setDebug(l);let E=await Ze.fetchTranslations({apiKey:u,crudifyEnv:p,featureKeys:m,urlTranslations:I}),F={};return Object.keys(E).forEach(M=>{let X=de[M]||{},re=E[M]||{};F[M]=vo(X,re,n)}),l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] Loaded translations:",{languages:Object.keys(F),keysCount:Object.keys(F[a]||{}).length}),F}catch(E){_chunk4LMFQECSjs.a.error("[TranslationsProvider] Failed to load",E instanceof Error?E:{message:String(E)}),A(E instanceof Error?E.message:String(E)),ae(!0);let F={};return Object.keys(de).forEach(M=>{let X=de[M],re=I||W||{};F[M]=vo(X,re,n)}),l&&_chunk4LMFQECSjs.a.debug("[TranslationsProvider] Using fallback translations (critical + URL)"),F}})();Je=Y;try{let E=await Y;h(E)}finally{S(!1),b(!1),vr=!1,setTimeout(()=>{Je=null},1e3)}},[u,p,m,s,n,l,a,ne]);_react.useEffect.call(void 0, ()=>{ee();let v=setInterval(ee,3600*1e3);return()=>clearInterval(v)},[ee]);let ke=_react.useMemo.call(void 0, ()=>(v,I)=>{let E=(g[a]||{})[v];if(!E){let F=Object.keys(g);for(let M of F)if(g[M][v]){E=g[M][v];break}}return E||(l&&_chunk4LMFQECSjs.a.warn(`[TranslationsProvider] Missing translation: "${v}"`),E=v),I&&typeof E=="string"&&Object.entries(I).forEach(([F,M])=>{let X=new RegExp(`{{${F}}}`,"g");E=E.replace(X,String(M))}),E},[g,a,l]);Ut(g,a,d,f,l);let Le={t:ke,language:a,availableLanguages:Object.keys(g),translations:g,isLoading:C,error:R,refreshTranslations:ee};return u?x&&T&&C?y||_jsxruntime.jsx.call(void 0, "div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"},children:_jsxruntime.jsx.call(void 0, "div",{children:"Loading translations..."})}):_jsxruntime.jsx.call(void 0, To.Provider,{value:Le,children:e}):(l&&_chunk4LMFQECSjs.a.warn("[TranslationsProvider] No API key available. Skipping translations. Provide apiKey via props or ensure cookies are set by Lambda."),_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e}))},Ee= exports.g =()=>{let e=_react.useContext.call(void 0, To);if(!e)throw new Error("useTranslations must be used within TranslationsProvider");return e};var Mt=/^[a-zA-Z0-9\-_./\?=&%#]+$/,Vt=[/^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]/,/\\/],Ro= exports.h =(e,r="/")=>{if(!e||typeof e!="string")return r;let o=e.trim();if(!o)return r;if(!o.startsWith("/"))return _chunk4LMFQECSjs.a.warn("Open redirect blocked (relative path)",{path:e}),r;if(!Mt.test(o))return _chunk4LMFQECSjs.a.warn("Open redirect blocked (invalid characters)",{path:e}),r;let t=o.toLowerCase();for(let n of Vt)if(n.test(t))return _chunk4LMFQECSjs.a.warn("Open redirect blocked (dangerous pattern)",{path:e}),r;let a=o.split("?")[0].split("/").filter(Boolean);if(a.length===0)return o;for(let n of a)if(n===".."||n.includes(":")||n.length>100)return _chunk4LMFQECSjs.a.warn("Open redirect blocked (suspicious path part)",{part:n}),r;return o},qt=[/^files\.nocios\.link$/,/^files\.crudia\.com$/,/^[a-z0-9][a-z0-9-]*\.nocios\.link$/,/^[a-z0-9][a-z0-9-]*\.crudia\.com$/],So= exports.i =(e,r="/")=>{if(!e||typeof e!="string")return r;let o=e.trim();if(!o)return r;if(o.startsWith("/"))return Ro(o,r);try{if(o.includes("..")||o.includes("//",8))return _chunk4LMFQECSjs.a.warn("Redirect blocked (dangerous path pattern)",{url:o}),r;let t=new URL(o);if(t.protocol!=="https:")return _chunk4LMFQECSjs.a.warn("Redirect blocked (non-HTTPS protocol)",{url:o}),r;let a=t.hostname.toLowerCase();return qt.some(s=>s.test(a))?o:(_chunk4LMFQECSjs.a.warn("Redirect blocked (untrusted domain)",{url:o,hostname:a}),r)}catch (e3){return _chunk4LMFQECSjs.a.warn("Redirect blocked (invalid URL)",{url:o}),r}},Ci= exports.j =(e,r="/")=>{try{let t=(typeof e=="string"?new URLSearchParams(e):e).get("redirect");if(!t)return r;let a=decodeURIComponent(t);return Ro(a,r)}catch(o){return _chunk4LMFQECSjs.a.warn("Error parsing redirect parameter",o instanceof Error?{errorMessage:o.message}:{message:String(o)}),r}};var _material = require('@mui/material');var _CheckCircle = require('@mui/icons-material/CheckCircle'); var _CheckCircle2 = _interopRequireDefault(_CheckCircle);var _RadioButtonUnchecked = require('@mui/icons-material/RadioButtonUnchecked'); var _RadioButtonUnchecked2 = _interopRequireDefault(_RadioButtonUnchecked);var $t=({message:e,valid:r})=>_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",alignItems:"center",gap:.5,py:.25},children:[r?_jsxruntime.jsx.call(void 0, _CheckCircle2.default,{sx:{fontSize:16,color:"success.main"}}):_jsxruntime.jsx.call(void 0, _RadioButtonUnchecked2.default,{sx:{fontSize:16,color:"text.disabled"}}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",sx:{color:r?"success.main":"text.secondary",transition:"color 0.2s ease"},children:e})]}),jt=({requirements:e,show:r=!0})=>!r||e.length===0?null:_jsxruntime.jsx.call(void 0, _material.Box,{sx:{mt:.5,mb:1,px:.5},children:e.map((o,t)=>_jsxruntime.jsx.call(void 0, $t,{message:o.message,valid:o.valid},t))}),ko= exports.k =jt;var Yt=/[A-Z]/,Xt=/[a-z]/,Zt=/[0-9]/,Jt=/[!@#$%^&*()_+\-=\[\]{}|;:,.<>?]/,Qt=/^[A-Za-z0-9]+$/;function Lo(e,r){return r.map(o=>{let t=!0;switch(o.type){case"minLength":t=e.length>=Number(_nullishCoalesce(o.value, () => (0)));break;case"alphanumeric":t=e.length>0&&Qt.test(e);break;case"uppercase":t=Yt.test(e);break;case"lowercase":t=Xt.test(e);break;case"number":t=Zt.test(e);break;case"special":t=Jt.test(e);break;default:t=!0}return{message:o.message,valid:t,enforce:!!o.enforce}})}function Ao(e){return e.filter(r=>r.enforce).every(r=>r.valid)}var Do=[{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}];var Fo=(e,r)=>{let[o,t]=_react.useState.call(void 0, {}),[a,n]=_react.useState.call(void 0, !1),[s,l]=_react.useState.call(void 0, null);return _react.useEffect.call(void 0, ()=>{if(r&&Object.keys(r).length>0){t(r),n(!1),l(null);return}if(!e){t({}),n(!1),l(null);return}let i=!1;return n(!0),l(null),fetch(e).then(f=>{if(!f.ok)throw new Error(`Failed to load translations: ${f.status}`);return f.json()}).then(f=>{i||(t(f),n(!1))}).catch(f=>{i||(_chunk4LMFQECSjs.a.error("[I18nProvider] Failed to load translations from URL",f instanceof Error?f:{message:String(f),url:e}),l(f instanceof Error?f.message:String(f)),t({}),n(!1))}),()=>{i=!0}},[e,r]),{translations:o,loading:a,error:s}};var Oo=_react.createContext.call(void 0, null),tn=()=>{try{return Ee()}catch (e4){return null}},nn=(e,r)=>{if(r.includes(".")){let o=r.split(".").reduce((t,a)=>t&&typeof t=="object"?t[a]:void 0,e);if(o!==void 0)return o}if(e&&e[r])return e[r]},No=({children:e,translations:r,translationsUrl:o,language:t="en"})=>{let n=_optionalChain([tn, 'call', _2 => _2(), 'optionalAccess', _3 => _3.translations, 'optionalAccess', _4 => _4[t]])||{},{translations:s,loading:l}=Fo(o,r),i=_react.useMemo.call(void 0, ()=>({...n,...s,...r||{}}),[n,s,r]),f=_react.useMemo.call(void 0, ()=>(y,x)=>{let c=nn(i,y);return c==null&&(c=y),x&&typeof c=="string"&&Object.entries(x).forEach(([u,p])=>{c=c.replace(new RegExp(`{{${u}}}`,"g"),p)}),typeof c=="string"?c:y},[i]),d=_react.useMemo.call(void 0, ()=>({t:f,language:t}),[f,t]);return l?_jsxruntime.jsx.call(void 0, "div",{children:"Loading translations..."}):_jsxruntime.jsx.call(void 0, Oo.Provider,{value:d,children:e})},J=()=>{let e=_react.useContext.call(void 0, Oo);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};var Bo={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function dn(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),a=t.toString()?`?${t.toString()}`:window.location.pathname;try{window.history.replaceState({},"",a)}catch (e5){}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,s)=>({...n,[s]:void 0}),{})}};case"SET_LOADING":return{...e,loading:r.payload};case"SET_ERRORS":return{...e,errors:{...e.errors,...r.payload}};case"CLEAR_ERRORS":return{...e,errors:{global:[]}};case"SET_EMAIL_SENT":return{...e,emailSent:r.payload};case"SET_CODE_ALREADY_EXISTS":return{...e,codeAlreadyExists:r.payload};case"SET_CODE_VALIDATED":return{...e,codeValidated:r.payload};case"SET_FROM_CODE_VERIFICATION":return{...e,fromCodeVerification:r.payload};case"RESET_FORM":return{...e,formData:Bo.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 Uo=_react.createContext.call(void 0, void 0),zo=({children:e,initialScreen:r="login",config:o,autoReadFromCookies:t=!0})=>{let[a,n]=_react.useReducer.call(void 0, dn,{...Bo,currentScreen:r});_react.useEffect.call(void 0, ()=>{n({type:"INIT_CONFIG",payload:(()=>{let u={};if(t)try{let p=_chunk4LMFQECSjs.b.call(void 0, );p.configSource!=="none"&&p.logo&&(u.logo=p.logo)}catch(p){_chunk4LMFQECSjs.a.error("Error reading configuration",p instanceof Error?p:{message:String(p)})}return{publicApiKey:_optionalChain([o, 'optionalAccess', _5 => _5.publicApiKey]),env:_optionalChain([o, 'optionalAccess', _6 => _6.env]),appName:_optionalChain([o, 'optionalAccess', _7 => _7.appName]),logo:_optionalChain([o, 'optionalAccess', _8 => _8.logo])||u.logo,loginActions:_optionalChain([o, 'optionalAccess', _9 => _9.loginActions])}})()})},[o,t]),_react.useEffect.call(void 0, ()=>{let c=new URLSearchParams(window.location.search),u={};c.forEach((p,m)=>{u[m]=p}),Object.keys(u).length>0&&n({type:"SET_SEARCH_PARAMS",payload:u}),r==="checkCode"&&u.email&&n({type:"UPDATE_FORM_DATA",payload:{email:u.email,code:u.code||""}}),r==="resetPassword"&&u.link&&n({type:"SET_SEARCH_PARAMS",payload:u})},[r]),_react.useEffect.call(void 0, ()=>{let c=_chunk4LMFQECSjs.f.subscribe(u=>{(u.type==="LOGOUT"||u.type==="SESSION_EXPIRED")&&(_chunk4LMFQECSjs.a.debug("LoginStateProvider: Clearing state due to auth event",{type:u.type}),n({type:"CLEAR_SEARCH_PARAMS"}),n({type:"RESET_FORM"}))});return()=>c()},[]);let s=(c,u)=>{n({type:"SET_SCREEN",payload:{screen:c,params:u}})},l=c=>{n({type:"UPDATE_FORM_DATA",payload:c})},i=(c,u)=>{n({type:"SET_ERRORS",payload:{[c]:u}})},f=()=>{n({type:"CLEAR_ERRORS"})},d=c=>{n({type:"SET_LOADING",payload:c})},y=_react.useCallback.call(void 0, ()=>{n({type:"CLEAR_SEARCH_PARAMS"})},[]),x={state:a,dispatch:n,setScreen:s,updateFormData:l,setFieldError:i,clearErrors:f,setLoading:d,clearSearchParams:y};return _jsxruntime.jsx.call(void 0, Uo.Provider,{value:x,children:e})},er=()=>{let e=_react.useContext.call(void 0, Uo);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};var yn=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:a="/"})=>{let{state:n,updateFormData:s,setFieldError:l,clearErrors:i,setLoading:f}=er(),{login:d}=_chunkH6XXWDUTjs.l.call(void 0, ),y=J(),{t:x}=y,c="i18n"in y?y.i18n:void 0,u=_react.useRef.call(void 0, null),p=_chunk4LMFQECSjs.p.call(void 0, x,{currentLanguage:_optionalChain([c, 'optionalAccess', _10 => _10.language]),enableDebug:!1}),m=()=>{if(n.searchParams.redirect)try{let b=decodeURIComponent(n.searchParams.redirect);return So(b,a||"/")}catch (e6){}return a||"/"};_react.useEffect.call(void 0, ()=>{let b=setTimeout(()=>{u.current&&u.current.focus()},100);return()=>clearTimeout(b)},[]);let g=b=>p.translateError({code:b.code,message:b.message,field:b.field}),h=async()=>{if(!n.loading){if(!n.formData.username.trim()){l("username",x("login.usernameRequired"));return}if(!n.formData.password.trim()){l("password",x("login.passwordRequired"));return}i(),f(!0);try{let b=await d(n.formData.username,n.formData.password);if(f(!1),b.success){let R=m();o&&o(b.data,R)}else{let R=b.rawResponse||b;C(R)}}catch(b){f(!1);let A=_chunk4LMFQECSjs.A.call(void 0, b).map(g);l("global",A),t&&t(A.join(", "))}}},C=b=>{let R=_chunk4LMFQECSjs.A.call(void 0, b),A=[];R.forEach(W=>{W.field?l(W.field,g(W)):A.push(g(W))}),A.length>0&&l("global",A)};return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,onSubmit:b=>{b.preventDefault(),h()},onKeyDown:b=>{b.key==="Enter"&&!n.loading&&(b.preventDefault(),h())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:x("login.usernameOrEmailLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"email",name:"email",type:"email",value:n.formData.username,disabled:n.loading,onChange:b=>s({username:b.target.value}),error:!!n.errors.username,helperText:n.errors.username,autoComplete:"email",placeholder:x("login.usernameOrEmailPlaceholder"),inputRef:u,required:!0})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:x("login.passwordLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"password",name:"password",type:"password",value:n.formData.password,disabled:n.loading,onChange:b=>s({password:b.target.value}),error:!!n.errors.password,helperText:n.errors.password,autoComplete:"current-password",placeholder:x("login.passwordPlaceholder"),required:!0})]}),_optionalChain([n, 'access', _11 => _11.config, 'access', _12 => _12.loginActions, 'optionalAccess', _13 => _13.includes, 'call', _14 => _14("forgotPassword")])&&_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:()=>{_optionalChain([e, 'optionalCall', _15 => _15("forgotPassword",n.searchParams)])},variant:"body2",color:"secondary",children:x("login.forgotPasswordLink")})}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:n.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:n.loading?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):x("login.loginButton")})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:n.errors.global&&n.errors.global.length>0&&n.errors.global.map((b,R)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",sx:{mt:2},severity:"error",children:_jsxruntime.jsx.call(void 0, "div",{children:b})},R))}),_optionalChain([n, 'access', _16 => _16.config, 'access', _17 => _17.loginActions, 'optionalAccess', _18 => _18.includes, 'call', _19 => _19("createUser")])&&_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[x("login.noAccountPrompt")," ",_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:()=>{let R=`/public/users/create${Object.keys(n.searchParams).length>0?`?${new URLSearchParams(n.searchParams).toString()}`:""}`;_optionalChain([r, 'optionalCall', _20 => _20(R)])},fontWeight:"medium",color:"secondary",children:x("login.signUpLink")})]})]})},qo=yn;var Te=(e,r)=>o=>{let t=[`errors.auth.${o.code}`,`errors.data.${o.code}`,`errors.system.${o.code}`,`errors.${o.code}`,`${r}.${o.code.toLowerCase()}`];for(let a of t){let n=e(a);if(n!==a)return n}return o.message||e("base.errors.errorUnknown")};var ye=(e,r)=>e?e instanceof URLSearchParams?e.get(r):e[r]||null:null;var wn=/^[^\s@]+@[^\s@]+\.[^\s@]+$/,rr=e=>!e||typeof e!="string"?!1:wn.test(e.trim());var or=e=>!e||typeof e!="string"?"":e.replace(/\D/g,"").slice(0,6);var Tn=({onScreenChange:e,onError:r})=>{let{crudify:o}=_chunkH6XXWDUTjs.j.call(void 0, ),[t,a]=_react.useState.call(void 0, ""),[n,s]=_react.useState.call(void 0, !1),[l,i]=_react.useState.call(void 0, []),[f,d]=_react.useState.call(void 0, null),[y,x]=_react.useState.call(void 0, !1),[c,u]=_react.useState.call(void 0, !1),p=_react.useRef.call(void 0, null),{t:m}=J(),g=Te(m,"forgotPassword");_react.useEffect.call(void 0, ()=>{p.current&&!y&&!c&&p.current.focus()},[y,c]);let h=async()=>{if(!(n||!o)){if(i([]),d(null),!t){d(m("forgotPassword.emailRequired"));return}if(!rr(t)){d(m("forgotPassword.invalidEmail"));return}s(!0);try{let b=[{operation:"requestPasswordReset",data:{email:t}}],R=await o.transaction(b);if(R.success)R.data&&R.data.existingCodeValid?u(!0):x(!0);else{let W=_chunk4LMFQECSjs.A.call(void 0, R).map(g);i(W)}}catch(b){let A=_chunk4LMFQECSjs.A.call(void 0, b).map(g);i(A),r&&r(A.join(", "))}finally{s(!1)}}},C=()=>{_optionalChain([e, 'optionalCall', _21 => _21("login")])},S=()=>{if(y||c){_optionalChain([e, 'optionalCall', _22 => _22("checkCode",{email:t})]);return}if(!t){d(m("forgotPassword.emailRequired"));return}if(!rr(t)){d(m("forgotPassword.invalidEmail"));return}_optionalChain([e, 'optionalCall', _23 => _23("checkCode",{email:t})])};return y||c?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m(c?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:c?"success.main":"grey.600"},children:m("forgotPassword.checkEmailInstructions")})]}),_jsxruntime.jsx.call(void 0, _material.Button,{type:"button",onClick:S,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:m("forgotPassword.enterCodeLink")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:C,variant:"body2",color:"secondary",children:m("base.btn.back")})})]})}):_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,onSubmit:b=>{b.preventDefault(),h()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:m("forgotPassword.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.600"},children:m("forgotPassword.instructions")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:m("forgotPassword.emailLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"email",name:"email",type:"email",value:t,disabled:n,onChange:b=>a(b.target.value),error:!!f,helperText:f,autoComplete:"email",placeholder:m("forgotPassword.emailPlaceholder"),required:!0,autoFocus:!0,inputRef:p})]}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:n,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):m("forgotPassword.sendCodeButton")}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:C,variant:"body2",color:"secondary",children:m("base.btn.back")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:S,variant:"body2",color:"secondary",children:m("login.alreadyHaveCodeLink")})]})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:l.length>0&&l.map((b,R)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",sx:{mt:2},severity:"error",children:b},R))})]})},Ko=Tn;var _Visibility = require('@mui/icons-material/Visibility'); var _Visibility2 = _interopRequireDefault(_Visibility);var _VisibilityOff = require('@mui/icons-material/VisibilityOff'); var _VisibilityOff2 = _interopRequireDefault(_VisibilityOff);var Dn=({id:e,name:r,value:o,onChange:t,disabled:a=!1,error:n=!1,helperText:s,label:l,placeholder:i,autoComplete:f="current-password",showPasswordLabel:d="Show password",hidePasswordLabel:y="Hide password"})=>{let[x,c]=_react.useState.call(void 0, !1);return _jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:e,name:r,type:x?"text":"password",value:o,disabled:a,onChange:t,error:n,helperText:s,autoComplete:f,placeholder:i,label:l,required:!0,InputProps:{endAdornment:_jsxruntime.jsx.call(void 0, _material.InputAdornment,{position:"end",children:_jsxruntime.jsx.call(void 0, _material.IconButton,{"aria-label":x?y:d,onClick:()=>{c(p=>!p)},edge:"end",size:"small",disabled:a,children:x?_jsxruntime.jsx.call(void 0, _VisibilityOff2.default,{}):_jsxruntime.jsx.call(void 0, _Visibility2.default,{})})})}})},tr=Dn;var On=({errors:e,severity:r="error",variant:o="filled"})=>!e||e.length===0?null:_jsxruntime.jsx.call(void 0, _material.Box,{children:e.map((t,a)=>_jsxruntime.jsx.call(void 0, _material.Alert,{variant:o,severity:r,sx:{mt:2},children:t},a))}),nr=On;var Mn=({onScreenChange:e,onError:r,searchParams:o,onResetSuccess:t,passwordRules:a})=>{let{crudify:n}=_chunkH6XXWDUTjs.j.call(void 0, ),[s,l]=_react.useState.call(void 0, ""),[i,f]=_react.useState.call(void 0, ""),[d,y]=_react.useState.call(void 0, !1),[x,c]=_react.useState.call(void 0, []),[u,p]=_react.useState.call(void 0, null),[m,g]=_react.useState.call(void 0, null),[h,C]=_react.useState.call(void 0, ""),[S,T]=_react.useState.call(void 0, ""),[b,R]=_react.useState.call(void 0, !1),[A,W]=_react.useState.call(void 0, !0),[ve,ne]=_react.useState.call(void 0, !1),[ae,ee]=_react.useState.call(void 0, null),[ke,Le]=_react.useState.call(void 0, !1),{t:v}=J(),I=_react.useRef.call(void 0, null);_react.useEffect.call(void 0, ()=>()=>{I.current&&clearTimeout(I.current)},[]);let Y=_react.useCallback.call(void 0, (_,D=3e3)=>{I.current&&clearTimeout(I.current),I.current=setTimeout(()=>_optionalChain([e, 'optionalCall', _24 => _24(_)]),D)},[e]),E=_react.useMemo.call(void 0, ()=>(a||Do).map(D=>({...D,message:v(D.message)})),[a,v]),F=_react.useMemo.call(void 0, ()=>Lo(s,E),[s,E]),M=_react.useMemo.call(void 0, ()=>Ao(F),[F]),X=s===i,re=Te(v,"resetPassword");_react.useEffect.call(void 0, ()=>{if(!o)return;let _=ye(o,"fromCodeVerification"),D=ye(o,"email"),H=ye(o,"code");if(_==="true"&&D&&H){C(D),T(H),R(!0),ne(!0),W(!1);return}let Z=ye(o,"link");if(Z)try{let $=decodeURIComponent(Z),[se,me]=$.split("/");if(se&&me&&se.length===6){T(se),C(me),R(!1),ee({email:me,code:se});return}}catch($){console.warn("Failed to parse reset password link:",$)}if(D&&H){C(D),T(H),R(!1),ee({email:D,code:H});return}c([v("resetPassword.invalidCode")]),W(!1),Y("forgotPassword")},[o,v,Y]),_react.useEffect.call(void 0, ()=>{n&&ae&&!ke&&(Le(!0),(async(D,H)=>{try{let Z=[{operation:"validatePasswordResetCode",data:{email:D,codePassword:H}}],$=await n.transaction(Z);if($.data&&Array.isArray($.data)&&_optionalChain([$, 'access', _25 => _25.data, 'access', _26 => _26[0], 'optionalAccess', _27 => _27.response, 'optionalAccess', _28 => _28.status])==="OK"){ne(!0);return}if($.success)ne(!0);else{let me=_chunk4LMFQECSjs.A.call(void 0, $).map(re);c(me),Y("forgotPassword")}}catch(Z){let se=_chunk4LMFQECSjs.A.call(void 0, Z).map(re);c(se),Y("forgotPassword")}finally{W(!1),ee(null),Le(!1)}})(ae.email,ae.code))},[n,ae,ke,v,re,Y]);let Ge=async()=>{if(d||!n)return;c([]),p(null),g(null);let _=!1;if(s?M||(p(v("resetPassword.passwordRequirementsNotMet")),_=!0):(p(v("resetPassword.newPasswordRequired")),_=!0),i?X||(g(v("resetPassword.passwordsDoNotMatch")),_=!0):(g(v("resetPassword.confirmPasswordRequired")),_=!0),!_){y(!0);try{let D=[{operation:"validateAndResetPassword",data:{email:h,codePassword:S,newPassword:s}}],H=await n.transaction(D);if(H.success)c([]),I.current&&clearTimeout(I.current),I.current=setTimeout(()=>{_optionalChain([t, 'optionalCall', _29 => _29()])},1e3);else{let $=_chunk4LMFQECSjs.A.call(void 0, H).map(re);c($)}}catch(D){let Z=_chunk4LMFQECSjs.A.call(void 0, D).map(re);c(Z),r&&r(Z.join(", "))}y(!1)}},to=()=>{b?_optionalChain([e, 'optionalCall', _30 => _30("checkCode",{email:h})]):_optionalChain([e, 'optionalCall', _31 => _31("forgotPassword")])};return A?_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:_jsxruntime.jsx.call(void 0, _material.CircularProgress,{})}):ve?_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:v("resetPassword.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.600"},children:v("resetPassword.instructions")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:v("resetPassword.newPasswordLabel")}),_jsxruntime.jsx.call(void 0, tr,{id:"newPassword",name:"newPassword",value:s,disabled:d,onChange:_=>l(_.target.value),error:!!u,helperText:_nullishCoalesce(u, () => (void 0)),autoComplete:"new-password",placeholder:v("resetPassword.newPasswordPlaceholder"),showPasswordLabel:v("base.btn.showPassword"),hidePasswordLabel:v("base.btn.hidePassword")}),_jsxruntime.jsx.call(void 0, ko,{requirements:F,show:s.length>0})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:v("resetPassword.confirmPasswordLabel")}),_jsxruntime.jsx.call(void 0, tr,{id:"confirmPassword",name:"confirmPassword",value:i,disabled:d,onChange:_=>f(_.target.value),error:!!m,helperText:_nullishCoalesce(m, () => (void 0)),autoComplete:"new-password",placeholder:v("resetPassword.confirmPasswordPlaceholder"),showPasswordLabel:v("base.btn.showPassword"),hidePasswordLabel:v("base.btn.hidePassword")})]}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:d||!M||!X||!s||!i,type:"button",onClick:Ge,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:d?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):v("resetPassword.resetPasswordButton")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:to,variant:"body2",color:"secondary",children:v("base.btn.back")})})]}),_jsxruntime.jsx.call(void 0, nr,{errors:x})]}):_jsxruntime.jsx.call(void 0, _material.Box,{children:_jsxruntime.jsx.call(void 0, nr,{errors:x})})},Go=Mn;var Gn=({onScreenChange:e,onError:r,searchParams:o})=>{let{crudify:t}=_chunkH6XXWDUTjs.j.call(void 0, ),[a,n]=_react.useState.call(void 0, ""),[s,l]=_react.useState.call(void 0, !1),[i,f]=_react.useState.call(void 0, []),[d,y]=_react.useState.call(void 0, null),[x,c]=_react.useState.call(void 0, ""),u=_react.useRef.call(void 0, null),{t:p}=J(),m=Te(p,"checkCode");_react.useEffect.call(void 0, ()=>{let T=ye(o,"email");T?c(T):_optionalChain([e, 'optionalCall', _32 => _32("forgotPassword")])},[o,e]),_react.useEffect.call(void 0, ()=>{u.current&&u.current.focus()},[]);let g=async()=>{if(!(s||!t)){if(f([]),y(null),!a){y(p("checkCode.codeRequired"));return}if(a.length!==6){y(p("checkCode.codeRequired"));return}l(!0);try{let T=[{operation:"validatePasswordResetCode",data:{email:x,codePassword:a}}],b=await t.transaction(T);if(b.success)_optionalChain([e, 'optionalCall', _33 => _33("resetPassword",{email:x,code:a,fromCodeVerification:"true"})]);else{let A=_chunk4LMFQECSjs.A.call(void 0, b).map(m);f(A),l(!1)}}catch(T){let R=_chunk4LMFQECSjs.A.call(void 0, T).map(m);f(R),l(!1),r&&r(R.join(", "))}}},h=()=>{_optionalChain([e, 'optionalCall', _34 => _34("forgotPassword")])},C=T=>{n(or(T.target.value))};return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"form",noValidate:!0,onSubmit:T=>{T.preventDefault(),g()},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:2},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:p("checkCode.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{color:"grey.600"},children:p("checkCode.instructions")})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:p("checkCode.codeLabel")}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,id:"code",name:"code",type:"text",value:a,disabled:s,onChange:C,error:!!d,helperText:d,placeholder:p("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0,autoFocus:!0,inputRef:u})]}),_jsxruntime.jsx.call(void 0, _material.Button,{disabled:s||a.length!==6,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:s?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:20}):p("checkCode.verifyButton")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:_jsxruntime.jsx.call(void 0, _material.Link,{sx:{cursor:"pointer"},onClick:h,variant:"body2",color:"secondary",children:p("base.btn.back")})})]}),_jsxruntime.jsx.call(void 0, _material.Box,{children:i.length>0&&i.map((T,b)=>_jsxruntime.jsx.call(void 0, _material.Alert,{sx:{mt:2},severity:"error",children:T},b))})]})},Xo=Gn;var Qo=({children:e,fallback:r})=>{let{isLoading:o,error:t,isInitialized:a}=_chunkH6XXWDUTjs.j.call(void 0, ),{t:n}=J();return o?r||_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[_jsxruntime.jsx.call(void 0, _material.CircularProgress,{}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):t?_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mt:2},children:_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",t]})}):a?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e}):_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"warning",sx:{mt:2},children:_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};var ra=({onScreenChange:e,onExternalNavigate:r,onLoginSuccess:o,onError:t,redirectUrl:a="/",passwordRules:n})=>{let{t:s}=J(),{state:l,setScreen:i}=er(),{config:f}=_chunkH6XXWDUTjs.l.call(void 0, ),{showNotification:d}=_chunkH6XXWDUTjs.g.call(void 0, ),y=(c,u)=>{let p=u;c==="login"?p={}:c==="forgotPassword"&&!u&&(p={}),i(c,p),_optionalChain([e, 'optionalCall', _35 => _35(c,p)])},x=()=>{let c={onScreenChange:y,onExternalNavigate:r,onError:t,redirectUrl:a};switch(l.currentScreen){case"forgotPassword":return _jsxruntime.jsx.call(void 0, Ko,{...c});case"checkCode":return _jsxruntime.jsx.call(void 0, Xo,{...c,searchParams:l.searchParams});case"resetPassword":return _jsxruntime.jsx.call(void 0, Go,{...c,searchParams:l.searchParams,passwordRules:n,onResetSuccess:()=>{let u=s("resetPassword.successMessage");d(u,"success"),y("login")}});default:return _jsxruntime.jsx.call(void 0, qo,{...c,onLoginSuccess:o})}};return _jsxruntime.jsxs.call(void 0, Qo,{children:[_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"center",mb:3},children:_jsxruntime.jsx.call(void 0, "img",{src:f.logo||"https://logos.crudia.com/nocios-default.png",alt:s("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:c=>{let u=c.target;u.src="https://logos.crudia.com/nocios-default.png"}})}),!f.logo&&f.appName&&_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:f.appName}),x()]})},oa=({translations:e,translationsUrl:r,language:o="en",initialScreen:t="login",autoReadFromCookies:a=!0,...n})=>{let{config:s}=_chunkH6XXWDUTjs.l.call(void 0, );return _jsxruntime.jsx.call(void 0, No,{translations:e,translationsUrl:r,language:o,children:_jsxruntime.jsx.call(void 0, _chunkH6XXWDUTjs.i,{config:s,children:_jsxruntime.jsx.call(void 0, zo,{config:s,initialScreen:t,autoReadFromCookies:a,children:_jsxruntime.jsx.call(void 0, ra,{...n})})})})},Tc= exports.o =oa;var _iconsmaterial = require('@mui/icons-material');var xa=({showExtendedData:e=!0,showProfileCard:r=!0,autoRefresh:o=!0})=>{let{userProfile:t,loading:a,error:n,extendedData:s,refreshProfile:l}=_chunkH6XXWDUTjs.n.call(void 0, {autoFetch:o,retryOnError:!0,maxRetries:3}),[i,f]=_react.useState.call(void 0, !1);if(a)return _jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[_jsxruntime.jsx.call(void 0, _material.CircularProgress,{}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return _jsxruntime.jsxs.call(void 0, _material.Alert,{severity:"error",action:_jsxruntime.jsx.call(void 0, _material.IconButton,{color:"inherit",size:"small",onClick:l,children:_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!t)return _jsxruntime.jsx.call(void 0, _material.Alert,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let d=_optionalChain([s, 'optionalAccess', _36 => _36.displayData])||{},y=_optionalChain([s, 'optionalAccess', _37 => _37.totalFields])||0,x=h=>{if(!h)return"No disponible";try{return new Date(h).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch (e7){return h}},c=(h,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),u=[{key:"id",label:"ID",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Badge,{})},{key:"email",label:"Email",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Email,{})},{key:"username",label:"Usuario",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Person,{})},{key:"fullName",label:"Nombre completo",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.AccountCircle,{})},{key:"role",label:"Rol",icon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Security,{})}],p=[{key:"firstName",label:"Nombre"},{key:"lastName",label:"Apellido"},{key:"isActive",label:"Activo"},{key:"lastLogin",label:"\xDAltimo login"},{key:"createdAt",label:"Creado"},{key:"updatedAt",label:"Actualizado"}],m=[...u.map(h=>h.key),...p.map(h=>h.key),"permissions"],g=Object.keys(d).filter(h=>!m.includes(h)).map(h=>({key:h,label:h}));return _jsxruntime.jsxs.call(void 0, _material.Box,{children:[r&&_jsxruntime.jsx.call(void 0, _material.Card,{sx:{mb:2},children:_jsxruntime.jsxs.call(void 0, _material.CardContent,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",alignItems:"center",mb:2,children:[_jsxruntime.jsx.call(void 0, _material.Avatar,{src:d.avatar,sx:{width:56,height:56,mr:2},children:_optionalChain([d, 'access', _38 => _38.fullName, 'optionalAccess', _39 => _39[0]])||_optionalChain([d, 'access', _40 => _40.username, 'optionalAccess', _41 => _41[0]])||_optionalChain([d, 'access', _42 => _42.email, 'optionalAccess', _43 => _43[0]])}),_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",children:d.fullName||d.username||d.email}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",children:d.role||"Usuario"}),d.isActive!==void 0&&_jsxruntime.jsx.call(void 0, _material.Chip,{label:d.isActive?"Activo":"Inactivo",color:d.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),_jsxruntime.jsx.call(void 0, _material.Box,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:u.map(({key:h,label:C,icon:S})=>d[h]?_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",alignItems:"center",children:[_jsxruntime.jsx.call(void 0, _material.Box,{sx:{mr:1,color:"text.secondary"},children:S}),_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",children:C}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",children:c(h,d[h])})]})]},h):null)}),d.permissions&&Array.isArray(d.permissions)&&d.permissions.length>0&&_jsxruntime.jsxs.call(void 0, _material.Box,{mt:2,children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[d.permissions.slice(0,5).map((h,C)=>_jsxruntime.jsx.call(void 0, _material.Chip,{label:h,size:"small",variant:"outlined"},C)),d.permissions.length>5&&_jsxruntime.jsx.call(void 0, _material.Chip,{label:`+${d.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&_jsxruntime.jsx.call(void 0, _material.Card,{children:_jsxruntime.jsxs.call(void 0, _material.CardContent,{children:[_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"h6",display:"flex",alignItems:"center",children:[_jsxruntime.jsx.call(void 0, _iconsmaterial.Info,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),_jsxruntime.jsx.call(void 0, _material.Chip,{label:`${y} campos totales`,size:"small"})]}),_jsxruntime.jsxs.call(void 0, _material.List,{dense:!0,children:[p.map(({key:h,label:C})=>d[h]!==void 0&&_jsxruntime.jsxs.call(void 0, _material.ListItem,{divider:!0,children:[_jsxruntime.jsx.call(void 0, _material.ListItemIcon,{children:_jsxruntime.jsx.call(void 0, _iconsmaterial.Schedule,{fontSize:"small"})}),_jsxruntime.jsx.call(void 0, _material.ListItemText,{primary:C,secondary:h.includes("At")||h.includes("Login")?x(d[h]):c(h,d[h])})]},h)),g.length>0&&_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, _material.Divider,{sx:{my:1}}),_jsxruntime.jsx.call(void 0, _material.ListItem,{children:_jsxruntime.jsx.call(void 0, _material.ListItemText,{primary:_jsxruntime.jsxs.call(void 0, _material.Box,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"subtitle2",children:["Campos Personalizados (",g.length,")"]}),_jsxruntime.jsx.call(void 0, _material.IconButton,{size:"small",onClick:()=>f(!i),children:i?_jsxruntime.jsx.call(void 0, _iconsmaterial.ExpandLess,{}):_jsxruntime.jsx.call(void 0, _iconsmaterial.ExpandMore,{})})]})})}),_jsxruntime.jsx.call(void 0, _material.Collapse,{in:i,children:g.map(({key:h,label:C})=>_jsxruntime.jsx.call(void 0, _material.ListItem,{sx:{pl:4},children:_jsxruntime.jsx.call(void 0, _material.ListItemText,{primary:C,secondary:c(h,d[h])})},h))})]})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",x(d.updatedAt)]}),_jsxruntime.jsx.call(void 0, _material.IconButton,{size:"small",onClick:l,disabled:a,children:_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",children:"Actualizar"})})]})]})})]})},Ca= exports.p =xa;var tt=["create","read","update","delete"],nt= exports.r =["create","read","update","delete"];var _reacti18next = require('react-i18next');var Aa=({value:e,onChange:r,availableFields:o,error:t,disabled:a=!1})=>{let{t:n}=_reacti18next.useTranslation.call(void 0, ),[s,l]=_react.useState.call(void 0, "custom"),[i,f]=_react.useState.call(void 0, !1),d=_react.useRef.call(void 0, null);_react.useEffect.call(void 0, ()=>{i&&_optionalChain([d, 'access', _44 => _44.current, 'optionalAccess', _45 => _45.scrollIntoView, 'call', _46 => _46({behavior:"smooth",block:"start"})])},[i]);let y=_react.useRef.call(void 0, !1);_react.useEffect.call(void 0, ()=>{let m=e||{allow:[],owner_allow:[],deny:[]},g=new Set(o),h=(m.allow||[]).filter(b=>g.has(b)),C=(m.owner_allow||[]).filter(b=>g.has(b)),S=(m.deny||[]).filter(b=>g.has(b));o.forEach(b=>{!h.includes(b)&&!C.includes(b)&&!S.includes(b)&&S.push(b)});let T={allow:h,owner_allow:C,deny:S};JSON.stringify(T)!==JSON.stringify(m)&&r(T),h.length===o.length?l("all"):S.length===o.length?l("none"):l("custom")},[o,e]);let x=()=>{y.current=!0,r({allow:[...o],owner_allow:[],deny:[]}),l("all"),setTimeout(()=>{y.current=!1},0)},c=()=>{y.current=!0,r({allow:[],owner_allow:[],deny:[...o]}),l("none"),setTimeout(()=>{y.current=!1},0)},u=m=>_optionalChain([e, 'optionalAccess', _47 => _47.allow, 'optionalAccess', _48 => _48.includes, 'call', _49 => _49(m)])?"allow":_optionalChain([e, 'optionalAccess', _50 => _50.owner_allow, 'optionalAccess', _51 => _51.includes, 'call', _52 => _52(m)])?"owner_allow":"deny",p=(m,g)=>{y.current=!0;let h=new Set(_optionalChain([e, 'optionalAccess', _53 => _53.allow])||[]),C=new Set(_optionalChain([e, 'optionalAccess', _54 => _54.owner_allow])||[]),S=new Set(_optionalChain([e, 'optionalAccess', _55 => _55.deny])||[]);h.delete(m),C.delete(m),S.delete(m),g==="allow"&&h.add(m),g==="owner_allow"&&C.add(m),g==="deny"&&S.add(m),r({allow:Array.from(h),owner_allow:Array.from(C),deny:Array.from(S)}),l("custom"),setTimeout(()=>{y.current=!1},0)};return o.length===0?_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("publicPolicies.fields.conditions.label")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("publicPolicies.fields.conditions.noFieldsAvailable")}),t&&_jsxruntime.jsx.call(void 0, _material.FormHelperText,{error:!0,sx:{mt:1},children:t})]}):_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("publicPolicies.fields.conditions.label")}),_jsxruntime.jsxs.call(void 0, _material.Stack,{direction:"row",spacing:1,alignItems:"center",sx:{mb:i?3:1},children:[_jsxruntime.jsx.call(void 0, _material.Button,{variant:s==="all"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.SelectAll,{}),onClick:x,disabled:a,size:"small",sx:{minWidth:120,...s==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("publicPolicies.fields.conditions.allFields")}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:s==="none"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.ClearAll,{}),onClick:c,disabled:a,size:"small",sx:{minWidth:120,...s==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("publicPolicies.fields.conditions.noFields")}),_jsxruntime.jsx.call(void 0, _material.Box,{sx:{display:"flex",alignItems:"center",px:1.5,py:.35,borderRadius:"999px",backgroundColor:"#f3f4f6",border:"1px solid #d1d9e0"},children:_jsxruntime.jsx.call(void 0, _material.FormControlLabel,{control:_jsxruntime.jsx.call(void 0, _material.Switch,{size:"small",checked:i,onChange:()=>f(m=>!m),disabled:a,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"}}})})]}),i&&_jsxruntime.jsxs.call(void 0, _material.Box,{ref:d,sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("publicPolicies.fields.conditions.help")}),_jsxruntime.jsx.call(void 0, _material.Stack,{spacing:1,children:o.map(m=>{let g=u(m);return _jsxruntime.jsxs.call(void 0, _material.Stack,{direction:"row",spacing:1,alignItems:"center",children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:m}),_jsxruntime.jsxs.call(void 0, _material.ToggleButtonGroup,{value:g,exclusive:!0,size:"small",children:[_jsxruntime.jsxs.call(void 0, _material.ToggleButton,{value:"allow",onClick:()=>p(m,"allow"),disabled:a,sx:{px:2,color:g==="allow"?"#ffffff":"#6b7280",backgroundColor:g==="allow"?"#16a34a":"#f3f4f6",borderColor:g==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:g==="allow"?"#15803d":"#e5e7eb",borderColor:g==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[_jsxruntime.jsx.call(void 0, _iconsmaterial.CheckCircle,{sx:{fontSize:16,mr:.5}}),n("publicPolicies.fields.conditions.states.allow")]}),_jsxruntime.jsx.call(void 0, _material.ToggleButton,{value:"owner_allow",onClick:()=>p(m,"owner_allow"),disabled:a,sx:{px:2,color:g==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:g==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:g==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:g==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:g==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("publicPolicies.fields.conditions.states.ownerAllow")}),_jsxruntime.jsxs.call(void 0, _material.ToggleButton,{value:"deny",onClick:()=>p(m,"deny"),disabled:a,sx:{px:2,color:g==="deny"?"#ffffff":"#6b7280",backgroundColor:g==="deny"?"#dc2626":"#f3f4f6",borderColor:g==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:g==="deny"?"#b91c1c":"#e5e7eb",borderColor:g==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[_jsxruntime.jsx.call(void 0, _iconsmaterial.Cancel,{sx:{fontSize:16,mr:.5}}),n("publicPolicies.fields.conditions.states.deny")]})]})]},m)})})]}),t&&_jsxruntime.jsx.call(void 0, _material.FormHelperText,{error:!0,sx:{mt:1},children:t})]})},Ur=Aa;var Ha=_react.forwardRef.call(void 0, ({policy:e,onChange:r,onRemove:o,availableFields:t,isSubmitting:a=!1,usedActions:n,error:s},l)=>{let{t:i}=_reacti18next.useTranslation.call(void 0, ),f=new Set(Array.from(n||[]));f.delete(e.action);let d=tt.map(y=>({value:y,label:i(`publicPolicies.fields.action.options.${y}`)}));return _jsxruntime.jsxs.call(void 0, _material.Paper,{ref:l,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:i("publicPolicies.policyTitle")}),_jsxruntime.jsx.call(void 0, _material.IconButton,{onClick:o,size:"small",disabled:a,"aria-label":i("publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:_jsxruntime.jsx.call(void 0, _iconsmaterial.Delete,{})})]}),_jsxruntime.jsxs.call(void 0, _material.Stack,{spacing:1,children:[_jsxruntime.jsx.call(void 0, _material.Stack,{direction:{xs:"column",md:"row"},spacing:2,children:_jsxruntime.jsx.call(void 0, _material.Box,{sx:{flex:1,minWidth:200},children:_jsxruntime.jsxs.call(void 0, _material.FormControl,{fullWidth:!0,children:[_jsxruntime.jsx.call(void 0, _material.InputLabel,{children:i("publicPolicies.fields.action.label")}),_jsxruntime.jsx.call(void 0, _material.Select,{value:e.action,label:i("publicPolicies.fields.action.label"),disabled:a,onChange:y=>{let x=y.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(y=>{let x=f.has(y.value);return _jsxruntime.jsx.call(void 0, _material.MenuItem,{value:y.value,disabled:x,children:y.label},y.value)})}),s&&_jsxruntime.jsx.call(void 0, _material.FormHelperText,{error:!0,children:s})]})})}),e.action==="delete"?_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{mb:2},children:i("publicPolicies.fields.conditions.label")}),_jsxruntime.jsxs.call(void 0, _material.Stack,{direction:"row",spacing:1,sx:{mb:1},children:[_jsxruntime.jsx.call(void 0, _material.Button,{variant:e.permission==="*"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.SelectAll,{}),onClick:()=>r({...e,permission:"*"}),disabled:a,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:i("publicPolicies.fields.conditions.allFields")}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>r({...e,permission:"owner"}),disabled:a,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:i("publicPolicies.fields.conditions.states.ownerAllow")}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:e.permission==="deny"?"contained":"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.ClearAll,{}),onClick:()=>r({...e,permission:"deny"}),disabled:a,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:i("publicPolicies.fields.conditions.noFields")})]})]}):_jsxruntime.jsx.call(void 0, Ur,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:y=>r({...e,fields:y}),availableFields:t,disabled:a}),_jsxruntime.jsx.call(void 0, _material.Paper,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[i("publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):_jsxruntime.jsxs.call(void 0, _material.Stack,{spacing:.5,divider:_jsxruntime.jsx.call(void 0, _material.Divider,{sx:{borderColor:"#e5e7eb"}}),children:[_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:"#16a34a"},children:[i("publicPolicies.fields.conditions.states.allow"),":"]})," ",(_optionalChain([e, 'optionalAccess', _56 => _56.fields, 'optionalAccess', _57 => _57.allow])||[]).join(", ")||"-"]}),_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:"#0ea5e9"},children:[i("publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(_optionalChain([e, 'optionalAccess', _58 => _58.fields, 'optionalAccess', _59 => _59.owner_allow])||[]).join(", ")||"-"]}),_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_jsxruntime.jsxs.call(void 0, _material.Box,{component:"span",sx:{color:"#dc2626"},children:[i("publicPolicies.fields.conditions.states.deny"),":"]})," ",(_optionalChain([e, 'optionalAccess', _60 => _60.fields, 'optionalAccess', _61 => _61.deny])||[]).join(", ")||"-"]})]})})]})]})}),Mr=Ha;var Za=()=>typeof globalThis<"u"&&_optionalChain([globalThis, 'access', _62 => _62.crypto, 'optionalAccess', _63 => _63.randomUUID])?globalThis.crypto.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`,Ja=({policies:e,onChange:r,availableFields:o,errors:t,isSubmitting:a=!1})=>{let{t:n}=_reacti18next.useTranslation.call(void 0, ),s=_react.useRef.call(void 0, {}),l=new Set((e||[]).map(u=>u.action).filter(Boolean)),i=nt.filter(u=>!l.has(u)),f=i.length>0,d=()=>{let u=i[0]||"create",p={id:Za(),action:u};u==="delete"?p.permission="deny":p.fields={allow:[],owner_allow:[],deny:o};let m=[...e||[],p];r(m),setTimeout(()=>{let g=m.length-1,h=s.current[g];h&&h.scrollIntoView({behavior:"smooth",block:"center"})},100)},y=u=>{let p=[...e];p.splice(u,1),r(p)},x=(()=>{if(!t)return null;if(typeof t=="string")return t;let u=t._error;return typeof u=="string"?u:null})(),c=new Set((e||[]).map(u=>u.action));return _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, _material.Divider,{sx:{borderColor:"#e0e4e7"}}),_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Box,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("publicPolicies.title")}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("publicPolicies.description")})]})}),x&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mb:3},children:x}),_jsxruntime.jsxs.call(void 0, _material.Stack,{spacing:3,children:[(e||[]).length===0?_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"info",children:n("publicPolicies.noPolicies")}):e.map((u,p)=>_jsxruntime.jsx.call(void 0, Mr,{ref:m=>{s.current[p]=m},policy:u,onChange:m=>{let g=[...e];g[p]=m,r(g)},onRemove:()=>y(p),availableFields:o,isSubmitting:a,usedActions:c,error:typeof t=="object"&&t!==null&&!("_error"in t)&&u.id in t?t[u.id]:void 0},u.id)),f&&_jsxruntime.jsx.call(void 0, _material.Box,{children:_jsxruntime.jsx.call(void 0, _material.Button,{type:"button",variant:"outlined",startIcon:_jsxruntime.jsx.call(void 0, _iconsmaterial.Add,{}),onClick:d,disabled:a,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("publicPolicies.addPolicy")})})]})]})]})},cd= exports.s =Ja;function hd(){let[e,r]=_react.useState.call(void 0, ""),[o,t]=_react.useState.call(void 0, ""),[a,n]=_react.useState.call(void 0, !1),{isAuthenticated:s,isLoading:l,error:i,login:f,logout:d,refreshTokens:y,clearError:x,isExpiringSoon:c,expiresIn:u}=_chunkH6XXWDUTjs.l.call(void 0, ),p=async h=>{if(h.preventDefault(),!e||!o)return;(await f(e,o)).success&&(r(""),t(""),n(!1))},m=async()=>{await d()},g=async()=>{await y()};return s?_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{maxWidth:600,mx:"auto",p:3},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h6",gutterBottom:!0,children:"Token Status"}),_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(u/1e3/60)," minutes"]}),c&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[_jsxruntime.jsx.call(void 0, _material.Button,{variant:"contained",onClick:g,disabled:l,startIcon:l?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:16}):null,children:"Refresh Tokens"}),_jsxruntime.jsx.call(void 0, _material.Button,{variant:"outlined",color:"error",onClick:m,disabled:l,children:"Logout"})]}),i&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mt:2},onClose:x,children:i})]}):_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{maxWidth:400,mx:"auto",p:3},children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),a?_jsxruntime.jsxs.call(void 0, "form",{onSubmit:p,children:[_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:h=>r(h.target.value),margin:"normal",required:!0,autoComplete:"email"}),_jsxruntime.jsx.call(void 0, _material.TextField,{fullWidth:!0,label:"Password",type:"password",value:o,onChange:h=>t(h.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),_jsxruntime.jsx.call(void 0, _material.Button,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:l,startIcon:l?_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:16}):null,sx:{mt:3,mb:2},children:l?"Logging in...":"Login"})]}):_jsxruntime.jsx.call(void 0, _material.Button,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),i&&_jsxruntime.jsx.call(void 0, _material.Alert,{severity:"error",sx:{mt:2},onClose:x,children:i})]})}function yd(){let{isAuthenticated:e,isLoading:r,isExpiringSoon:o,expiresIn:t}=_chunkH6XXWDUTjs.l.call(void 0, );return r?_jsxruntime.jsxs.call(void 0, _material.Box,{sx:{display:"flex",alignItems:"center",gap:1},children:[_jsxruntime.jsx.call(void 0, _material.CircularProgress,{size:16}),_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",children:"Loading session..."})]}):e?_jsxruntime.jsxs.call(void 0, _material.Box,{children:[_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),o&&_jsxruntime.jsxs.call(void 0, _material.Typography,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(t/1e3/60)," min"]})]}):_jsxruntime.jsx.call(void 0, _material.Typography,{variant:"caption",color:"text.secondary",children:"Not logged in"})}var _TextField = require('@mui/material/TextField'); var _TextField2 = _interopRequireDefault(_TextField);var _CircularProgress = require('@mui/material/CircularProgress'); var _CircularProgress2 = _interopRequireDefault(_CircularProgress);var _InputAdornment = require('@mui/material/InputAdornment'); var _InputAdornment2 = _interopRequireDefault(_InputAdornment);var _IconButton = require('@mui/material/IconButton'); var _IconButton2 = _interopRequireDefault(_IconButton);var _Refresh = require('@mui/icons-material/Refresh'); var _Refresh2 = _interopRequireDefault(_Refresh);var ns=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),as=({html:e})=>_jsxruntime.jsx.call(void 0, "span",{dangerouslySetInnerHTML:{__html:ns(e)}}),Rd= exports.v =({config:e,value:r,onChange:o,label:t,error:a=!1,helperText:n,readOnly:s=!1,disabled:l=!1,name:i})=>{let{value:f,loading:d,error:y,regenerate:x}=_chunkH6XXWDUTjs.o.call(void 0, e,{autoFetch:!r,onSuccess:h=>{_optionalChain([o, 'optionalCall', _64 => _64(h)])}}),c=r||f,u=a||!!y,p=y||n,m=u&&p&&(p.toLowerCase().includes("duplicate")||p.toLowerCase().includes("duplicado")||p.toLowerCase().includes("duplicada")||p.toLowerCase().includes("unique")||p.toLowerCase().includes("\xFAnico")||p.toLowerCase().includes("unico")||p.toLowerCase().includes("\xFAnica")||p.toLowerCase().includes("unica")||p.toLowerCase().includes("already exists")||p.toLowerCase().includes("ya existe")||p.toLowerCase().includes("e11000"));return _jsxruntime.jsx.call(void 0, _TextField2.default,{name:i,label:t,fullWidth:!0,value:c,error:u,helperText:p?_jsxruntime.jsx.call(void 0, as,{html:p}):" ",disabled:l,InputProps:{readOnly:!0,startAdornment:d?_jsxruntime.jsx.call(void 0, _InputAdornment2.default,{position:"start",children:_jsxruntime.jsx.call(void 0, _CircularProgress2.default,{size:20})}):void 0,endAdornment:m&&!d?_jsxruntime.jsx.call(void 0, _InputAdornment2.default,{position:"end",children:_jsxruntime.jsx.call(void 0, _IconButton2.default,{edge:"end",onClick:async()=>{!l&&!d&&await x()},disabled:l,size:"small",color:"error","aria-label":"regenerar c\xF3digo",title:"Regenerar c\xF3digo",children:_jsxruntime.jsx.call(void 0, _Refresh2.default,{})})}):void 0}})};var _Box = require('@mui/material/Box'); var _Box2 = _interopRequireDefault(_Box);var _Typography = require('@mui/material/Typography'); var _Typography2 = _interopRequireDefault(_Typography);var _List = require('@mui/material/List'); var _List2 = _interopRequireDefault(_List);var _FormHelperText = require('@mui/material/FormHelperText'); var _FormHelperText2 = _interopRequireDefault(_FormHelperText);var gt=e=>e.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,"").replace(/javascript:/gi,"").replace(/on\w+\s*=/gi,"").replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,""),ht=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]}`};var Hr=({disabled:e,onFilesDropped:r,onInteraction:o})=>{let[t,a]=_react.useState.call(void 0, !1),n=_react.useCallback.call(void 0, i=>{i.preventDefault(),i.stopPropagation(),e||a(!0)},[e]),s=_react.useCallback.call(void 0, i=>{i.preventDefault(),i.stopPropagation(),a(!1)},[]),l=_react.useCallback.call(void 0, i=>{if(i.preventDefault(),i.stopPropagation(),a(!1),e)return;_optionalChain([o, 'optionalCall', _65 => _65()]);let f=i.dataTransfer.files;f&&f.length>0&&r(f)},[e,r,o]);return{isDragging:t,handleDragOver:n,handleDragLeave:s,handleDrop:l}};var jr=({deleteFileImmediately:e})=>{let[r,o]=_react.useState.call(void 0, !1),[t,a]=_react.useState.call(void 0, null),[n,s]=_react.useState.call(void 0, !1),l=_react.useCallback.call(void 0, d=>{a(d),o(!0)},[]),i=_react.useCallback.call(void 0, async()=>{if(t){s(!0);try{let d=await e(t);d.success||_chunk4LMFQECSjs.a.error("Error deleting file",{error:d.error})}finally{s(!1),o(!1),a(null)}}},[t,e]),f=_react.useCallback.call(void 0, ()=>{o(!1),a(null)},[]);return{isOpen:r,isDeleting:n,fileToDelete:t,openConfirmation:l,handleConfirm:i,handleCancel:f}};var _LinearProgress = require('@mui/material/LinearProgress'); var _LinearProgress2 = _interopRequireDefault(_LinearProgress);var _ListItem = require('@mui/material/ListItem'); var _ListItem2 = _interopRequireDefault(_ListItem);var _ListItemText = require('@mui/material/ListItemText'); var _ListItemText2 = _interopRequireDefault(_ListItemText);var _ListItemSecondaryAction = require('@mui/material/ListItemSecondaryAction'); var _ListItemSecondaryAction2 = _interopRequireDefault(_ListItemSecondaryAction);var _Delete = require('@mui/icons-material/Delete'); var _Delete2 = _interopRequireDefault(_Delete);var _Restore = require('@mui/icons-material/Restore'); var _Restore2 = _interopRequireDefault(_Restore);var _Chip = require('@mui/material/Chip'); var _Chip2 = _interopRequireDefault(_Chip);var _InsertDriveFile = require('@mui/icons-material/InsertDriveFile'); var _InsertDriveFile2 = _interopRequireDefault(_InsertDriveFile);var _Image = require('@mui/icons-material/Image'); var _Image2 = _interopRequireDefault(_Image);var _PictureAsPdf = require('@mui/icons-material/PictureAsPdf'); var _PictureAsPdf2 = _interopRequireDefault(_PictureAsPdf);var _Error = require('@mui/icons-material/Error'); var _Error2 = _interopRequireDefault(_Error);var Gr=e=>e.startsWith("image/")?_jsxruntime.jsx.call(void 0, _Image2.default,{color:"primary"}):e==="application/pdf"?_jsxruntime.jsx.call(void 0, _PictureAsPdf2.default,{color:"error"}):_jsxruntime.jsx.call(void 0, _InsertDriveFile2.default,{color:"action"}),bt=(e,r)=>{switch(e){case"completed":return _jsxruntime.jsx.call(void 0, _CheckCircle2.default,{color:"success",fontSize:"small"});case"error":return _jsxruntime.jsx.call(void 0, _Error2.default,{color:"error",fontSize:"small"});case"uploading":case"pending":return _jsxruntime.jsx.call(void 0, _CircularProgress2.default,{size:16});case"removing":return _jsxruntime.jsx.call(void 0, _CircularProgress2.default,{size:16,color:"error"});case"pendingDeletion":return _jsxruntime.jsx.call(void 0, _Chip2.default,{label:r("base.file.pendingDeletion"),size:"small",color:"warning",variant:"outlined",sx:{fontSize:"0.65rem",height:20}});default:return null}};var Xr=({file:e,baseUrl:r,disabled:o,onRemove:t,onRestore:a,onRetry:n})=>{let{t:s}=Ee(),[l,i]=_react.useState.call(void 0, !1),f=e.status==="pendingDeletion",d=!o&&e.status!=="uploading"&&e.status!=="removing"&&!f,y=!o&&f,x=!o&&e.status==="error"&&e.file,c=e.contentType.startsWith("image/"),u=e.visibility==="public"||_optionalChain([e, 'access', _66 => _66.filePath, 'optionalAccess', _67 => _67.startsWith, 'call', _68 => _68("public/")])||_optionalChain([e, 'access', _69 => _69.filePath, 'optionalAccess', _70 => _70.startsWith, 'call', _71 => _71(r)]),m=!e.filePath||!u?null:e.filePath.startsWith("http://")||e.filePath.startsWith("https://")||e.filePath.startsWith(r)?e.filePath:`${r}${e.filePath}`,g=e.status==="completed"&&m,h=()=>c&&g&&!l?_jsxruntime.jsx.call(void 0, _Box2.default,{component:g?"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:g?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,"&:hover":g?{borderColor:"primary.main",transform:"scale(1.05)"}:{}},children:_jsxruntime.jsx.call(void 0, "img",{src:m,alt:e.name,style:{width:"100%",height:"100%",objectFit:"cover"},onError:()=>i(!0)})}):_jsxruntime.jsx.call(void 0, _Box2.default,{component:g?"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:g?"pointer":"default",transition:"all 0.2s ease",flexShrink:0,textDecoration:"none","&:hover":g?{borderColor:"primary.main",bgcolor:"action.hover"}:{}},children:Gr(e.contentType)});return _jsxruntime.jsxs.call(void 0, _ListItem2.default,{sx:{borderRadius:1,mb:.5,bgcolor:e.status==="error"?"error.lighter":"background.paper",border:"1px solid",borderColor:e.status==="error"?"error.light":"divider",gap:1.5},children:[h(),_jsxruntime.jsx.call(void 0, _ListItemText2.default,{primary:_jsxruntime.jsxs.call(void 0, _Box2.default,{sx:{display:"flex",alignItems:"center",gap:1},children:[_jsxruntime.jsx.call(void 0, _Typography2.default,{variant:"body2",noWrap:!0,sx:{maxWidth:200,overflow:"hidden",textOverflow:"ellipsis",textDecoration:f?"line-through":"none",opacity:f?.6:1},children:e.name}),bt(e.status,s)]}),secondary:_jsxruntime.jsxs.call(void 0, _Box2.default,{sx:{opacity:f?.6:1},children:[e.size>0&&_jsxruntime.jsx.call(void 0, _Typography2.default,{variant:"caption",color:"text.secondary",children:ht(e.size)}),e.status==="uploading"&&_jsxruntime.jsx.call(void 0, _LinearProgress2.default,{variant:"determinate",value:e.progress,sx:{mt:.5,height:4,borderRadius:2}}),e.status==="error"&&e.errorMessage&&_jsxruntime.jsx.call(void 0, _Typography2.default,{variant:"caption",color:"error",display:"block",children:e.errorMessage}),g&&_jsxruntime.jsx.call(void 0, _Typography2.default,{variant:"caption",color:"primary",display:"block",component:"a",href:m||void 0,target:"_blank",rel:"noopener noreferrer",sx:{cursor:"pointer",textDecoration:"underline","&:hover":{textDecoration:"none"}},children:s(c?"base.file.clickToPreview":"base.file.clickToDownload")})]})}),_jsxruntime.jsxs.call(void 0, _ListItemSecondaryAction2.default,{children:[x&&_jsxruntime.jsx.call(void 0, _IconButton2.default,{edge:"end",size:"small",onClick:()=>n(e.id),color:"primary",title:s("base.file.restore"),children:_jsxruntime.jsx.call(void 0, _Refresh2.default,{fontSize:"small"})}),y&&_jsxruntime.jsx.call(void 0, _IconButton2.default,{edge:"end",size:"small",onClick:()=>a(e.id),color:"primary",title:s("base.file.restore"),children:_jsxruntime.jsx.call(void 0, _Restore2.default,{fontSize:"small"})}),d&&_jsxruntime.jsx.call(void 0, _IconButton2.default,{edge:"end",size:"small",onClick:()=>t(e.id),color:"error",title:s("base.file.delete"),children:_jsxruntime.jsx.call(void 0, _Delete2.default,{fontSize:"small"})})]})]})};var _BrokenImage = require('@mui/icons-material/BrokenImage'); var _BrokenImage2 = _interopRequireDefault(_BrokenImage);var _Paper = require('@mui/material/Paper'); var _Paper2 = _interopRequireDefault(_Paper);var _CloudUpload = require('@mui/icons-material/CloudUpload'); var _CloudUpload2 = _interopRequireDefault(_CloudUpload);var Zr=({isDragging:e,disabled:r,hasError:o,placeholder:t,accept:a,onClick:n,onDragOver:s,onDragLeave:l,onDrop:i})=>_jsxruntime.jsxs.call(void 0, _Paper2.default,{variant:"outlined",onClick:n,onDragOver:s,onDragLeave:l,onDrop:i,sx:{p:3,textAlign:"center",cursor:r?"not-allowed":"pointer",borderStyle:"dashed",borderWidth:2,borderColor:e?"primary.main":o?"error.main":"divider",bgcolor:e?"primary.lighter":r?"action.disabledBackground":"background.paper",transition:"all 0.2s ease","&:hover":r?{}:{borderColor:"primary.main",bgcolor:"action.hover"}},children:[_jsxruntime.jsx.call(void 0, _CloudUpload2.default,{sx:{fontSize:48,color:e?"primary.main":r?"action.disabled":"action.active",mb:1}}),_jsxruntime.jsx.call(void 0, _Typography2.default,{variant:"body2",color:r?"text.disabled":"text.secondary",children:t}),a&&a.length>0&&!e&&_jsxruntime.jsx.call(void 0, _Box2.default,{sx:{mt:1,display:"flex",gap:.5,justifyContent:"center",flexWrap:"wrap"},children:a.map(f=>_jsxruntime.jsx.call(void 0, _Chip2.default,{label:_optionalChain([f, 'access', _72 => _72.split, 'call', _73 => _73("/"), 'access', _74 => _74[1], 'optionalAccess', _75 => _75.toUpperCase, 'call', _76 => _76()])||f,size:"small",variant:"outlined",sx:{fontSize:"0.7rem"}},f))})]});var _Dialog = require('@mui/material/Dialog'); var _Dialog2 = _interopRequireDefault(_Dialog);var _DialogTitle = require('@mui/material/DialogTitle'); var _DialogTitle2 = _interopRequireDefault(_DialogTitle);var _DialogContent = require('@mui/material/DialogContent'); var _DialogContent2 = _interopRequireDefault(_DialogContent);var _DialogActions = require('@mui/material/DialogActions'); var _DialogActions2 = _interopRequireDefault(_DialogActions);var _Button = require('@mui/material/Button'); var _Button2 = _interopRequireDefault(_Button);var Jr=({open:e,isDeleting:r,onConfirm:o,onCancel:t,title:a,message:n,cancelText:s,confirmText:l,deletingText:i})=>_jsxruntime.jsxs.call(void 0, _Dialog2.default,{open:e,onClose:r?void 0:t,children:[_jsxruntime.jsx.call(void 0, _DialogTitle2.default,{children:a}),_jsxruntime.jsx.call(void 0, _DialogContent2.default,{children:_jsxruntime.jsx.call(void 0, _Typography2.default,{children:n})}),_jsxruntime.jsxs.call(void 0, _DialogActions2.default,{children:[_jsxruntime.jsx.call(void 0, _Button2.default,{onClick:t,disabled:r,children:s}),_jsxruntime.jsx.call(void 0, _Button2.default,{onClick:o,color:"error",variant:"contained",disabled:r,startIcon:r?_jsxruntime.jsx.call(void 0, _CircularProgress2.default,{size:16,color:"inherit"}):void 0,children:r?i:l})]})]});var Ns=({label:e,accept:r,maxFileSize:o=10*1024*1024,multiple:t=!1,maxFiles:a,minFiles:n=0,required:s=!1,disabled:l=!1,error:i=!1,helperText:f,onChange:d,onValidation:y,initialFiles:x,placeholder:c,showFileList:u=!0,visibility:p="private",showPreview:m=!0,baseUrl:g,onDeletionHandlersReady:h,mode:C="create",name:S})=>{let{t:T}=Ee(),b=_react.useRef.call(void 0, null),R=t?a:1,A=s?Math.max(n,1):n,W={acceptedTypes:r,maxFileSize:o,maxFiles:R,minFiles:A,visibility:p,mode:C,onFilesChange:ie=>{let fe=ie.filter(Ye=>Ye.status==="completed"&&Ye.filePath).map(Ye=>{let Cr=Ye.filePath;return Cr.startsWith("/")?Cr:`/${Cr}`});_optionalChain([d, 'optionalCall', _77 => _77(fe)])}},{files:ve,isUploading:ne,addFiles:ae,removeFile:ee,restoreFile:ke,retryUpload:Le,isValid:v,validationError:I,validationErrorKey:Y,validationErrorParams:E,initializeFiles:F,isTouched:M,markAsTouched:X,isSubmitted:re,markAsSubmitted:Ge,getPreviewUrl:to,commitDeletions:_,restorePendingDeletions:D,hasPendingDeletions:H,deleteFileImmediately:Z,activeFiles:$,activeFileCount:se,waitForUploads:me,completedFilePaths:no}=_chunkH6XXWDUTjs.r.call(void 0, W),ao=_react.useCallback.call(void 0, ()=>no,[no]),so=_react.useRef.call(void 0, !1),wr=_react.useRef.call(void 0, !1);_react2.default.useEffect(()=>{x&&x.length>0&&!so.current&&!wr.current&&(wr.current=!0,(async()=>{try{await F(x,g),so.current=!0}catch(fe){_chunk4LMFQECSjs.a.error("Failed to initialize files",{error:fe})}finally{wr.current=!1}})())},[x,F,g]),_react2.default.useEffect(()=>{_optionalChain([y, 'optionalCall', _78 => _78(v,I)])},[v,I,y]),_react2.default.useEffect(()=>{h&&h({commitDeletions:_,restorePendingDeletions:D,hasPendingDeletions:H,markAsSubmitted:Ge,isValid:v,isUploading:ne,waitForUploads:me,getCompletedFilePaths:ao})},[h,_,D,H,Ge,v,ne,me,ao]);let{isDragging:io,handleDragOver:Rt,handleDragLeave:St,handleDrop:It}=Hr({disabled:l,onFilesDropped:ae,onInteraction:X}),Ae=jr({deleteFileImmediately:Z}),kt=_react.useCallback.call(void 0, ie=>{X();let fe=ie.target.files;fe&&fe.length>0&&ae(fe),b.current&&(b.current.value="")},[ae,X]),Lt=_react.useCallback.call(void 0, ()=>{l||_optionalChain([b, 'access', _79 => _79.current, 'optionalAccess', _80 => _80.click, 'call', _81 => _81()])},[l]),At=_react.useCallback.call(void 0, async ie=>{(await ee(ie)).needsConfirmation&&Ae.openConfirmation(ie)},[ee,Ae]),Dt=_optionalChain([r, 'optionalAccess', _82 => _82.join, 'call', _83 => _83(",")])||"",Ft=!l&&(t||se===0),lo=re&&!v,xr=i||lo,co=f||(lo&&Y?T(Y,E):null);return _jsxruntime.jsxs.call(void 0, _Box2.default,{sx:{width:"100%"},children:[e&&_jsxruntime.jsxs.call(void 0, _Typography2.default,{variant:"body2",sx:{mb:1,fontWeight:500,color:xr?"error.main":"text.primary"},children:[e,s&&_jsxruntime.jsx.call(void 0, "span",{style:{color:"red"},children:" *"})]}),_jsxruntime.jsx.call(void 0, "input",{ref:b,type:"file",name:S,accept:Dt,multiple:t,onChange:kt,disabled:l,style:{display:"none"}}),Ft&&_jsxruntime.jsx.call(void 0, Zr,{isDragging:io,disabled:l,hasError:xr,placeholder:c||T(io?"base.file.dropHere":"base.file.dragOrClick"),accept:r,onClick:Lt,onDragOver:Rt,onDragLeave:St,onDrop:It}),u&&ve.length>0&&_jsxruntime.jsx.call(void 0, _List2.default,{dense:!0,sx:{mt:1,p:0},children:ve.map(ie=>_jsxruntime.jsx.call(void 0, Xr,{file:ie,baseUrl:g,disabled:l,onRemove:At,onRestore:ke,onRetry:Le},ie.id))}),ne&&_jsxruntime.jsxs.call(void 0, _Box2.default,{sx:{display:"flex",alignItems:"center",gap:1,mt:1},children:[_jsxruntime.jsx.call(void 0, _CircularProgress2.default,{size:16}),_jsxruntime.jsx.call(void 0, _Typography2.default,{variant:"caption",color:"text.secondary",children:T("base.file.uploading")})]}),co&&_jsxruntime.jsx.call(void 0, _FormHelperText2.default,{error:xr,sx:{mt:.5},dangerouslySetInnerHTML:{__html:gt(co)}}),_jsxruntime.jsx.call(void 0, Jr,{open:Ae.isOpen,isDeleting:Ae.isDeleting,onConfirm:Ae.handleConfirm,onCancel:Ae.handleCancel,title:T("base.file.confirmDelete.title"),message:T("base.file.confirmDelete.message"),cancelText:T("base.file.confirmDelete.cancel"),confirmText:T("base.file.confirmDelete.confirm"),deletingText:T("base.file.deleting")})]})};var _editor = require('@mdxeditor/editor');require('@mdxeditor/editor/style.css');var kp=({label:e,value:r="",onChange:o,required:t=!1,disabled:a=!1,error:n=!1,helperText:s,placeholder:l="Write here...",minHeight:i=200,maxHeight:f=500,name:d})=>{let y=_react.useRef.call(void 0, null);_react.useEffect.call(void 0, ()=>{y.current&&y.current.getMarkdown()!==r&&y.current.setMarkdown(r||"")},[r]);let x=_react.useCallback.call(void 0, c=>{_optionalChain([o, 'optionalCall', _84 => _84(c)])},[o]);return _jsxruntime.jsxs.call(void 0, _Box2.default,{sx:{width:"100%"},children:[e&&_jsxruntime.jsxs.call(void 0, _Typography2.default,{component:"label",sx:{display:"block",mb:.5,fontSize:"0.875rem",fontWeight:500,color:n?"error.main":"text.primary"},children:[e,t&&_jsxruntime.jsx.call(void 0, _Typography2.default,{component:"span",color:"error.main",sx:{ml:.5},children:"*"})]}),d&&_jsxruntime.jsx.call(void 0, "input",{type:"hidden",name:d,value:r,readOnly:!0}),_jsxruntime.jsx.call(void 0, _Box2.default,{sx:{border:1,borderColor:n?"error.main":"divider",borderRadius:1,overflow:"hidden",opacity:a?.6:1,pointerEvents:a?"none":"auto","& .mdxeditor":{minHeight:i,maxHeight:f,overflow:"auto"},"& .mdxeditor-toolbar":{borderBottom:1,borderColor:"divider",backgroundColor:"background.default"},"& .mdxeditor-root-contenteditable":{padding:2,minHeight:i-50}},children:_jsxruntime.jsx.call(void 0, _editor.MDXEditor,{ref:y,markdown:r||"",onChange:x,placeholder:l,readOnly:a,plugins:[_editor.headingsPlugin.call(void 0, ),_editor.listsPlugin.call(void 0, ),_editor.quotePlugin.call(void 0, ),_editor.thematicBreakPlugin.call(void 0, ),_editor.markdownShortcutPlugin.call(void 0, ),_editor.linkPlugin.call(void 0, ),_editor.linkDialogPlugin.call(void 0, ),_editor.tablePlugin.call(void 0, ),_editor.toolbarPlugin.call(void 0, {toolbarContents:()=>_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsx.call(void 0, _editor.UndoRedo,{}),_jsxruntime.jsx.call(void 0, _editor.Separator,{}),_jsxruntime.jsx.call(void 0, _editor.BoldItalicUnderlineToggles,{}),_jsxruntime.jsx.call(void 0, _editor.Separator,{}),_jsxruntime.jsx.call(void 0, _editor.BlockTypeSelect,{}),_jsxruntime.jsx.call(void 0, _editor.Separator,{}),_jsxruntime.jsx.call(void 0, _editor.ListsToggle,{}),_jsxruntime.jsx.call(void 0, _editor.Separator,{}),_jsxruntime.jsx.call(void 0, _editor.CreateLink,{}),_jsxruntime.jsx.call(void 0, _editor.InsertTable,{})]})})]})}),s&&_jsxruntime.jsx.call(void 0, _FormHelperText2.default,{error:n,sx:{mx:0,mt:.5},children:s}),!s&&_jsxruntime.jsx.call(void 0, _FormHelperText2.default,{sx:{mx:0,mt:.5},children:"\xA0"})]})};exports.a = de; exports.b = ni; exports.c = ai; exports.d = Pr; exports.e = Ze; exports.f = yi; exports.g = Ee; exports.h = Ro; exports.i = So; exports.j = Ci; exports.k = ko; exports.l = Lo; exports.m = Ao; exports.n = Do; exports.o = Tc; exports.p = Ca; exports.q = tt; exports.r = nt; exports.s = cd; exports.t = hd; exports.u = yd; exports.v = Rd; exports.w = Ns; exports.x = kp;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as n,g as h,h as m,i as p,j as u,k as y,l}from"./chunk-
|
|
1
|
+
import{a as n,g as h,h as m,i as p,j as u,k as y,l}from"./chunk-44VU4TSP.mjs";var c="crudify_login_storage_version",d=2,g="crudify_login_encryption_salt",a=class{constructor(t="sessionStorage"){this.encryptionKey=null;this.salt=null;this.initPromise=null;this.initialized=!1;this.storage=t==="localStorage"?window.localStorage:window.sessionStorage}async ensureInitialized(){if(!(this.initialized&&this.encryptionKey)){if(this.initPromise){await this.initPromise;return}this.initPromise=this.initialize(),await this.initPromise}}async initialize(){try{parseInt(this.storage.getItem(c)||"1")<d&&(this.clearLegacyData(),this.storage.setItem(c,d.toString()));let e=this.storage.getItem(g);e&&l(`v2:x:${e}:x`)?this.salt=this.base64ToUint8Array(e):(this.salt=y(),this.storage.setItem(g,this.uint8ArrayToBase64(this.salt)));let i=await this.generateFingerprint();this.encryptionKey=await m(i,this.salt),this.initialized=!0}catch(t){n.error("SecureStorage initialization failed",t instanceof Error?t:{message:String(t)}),this.initialized=!1}}async generateFingerprint(){let t=[navigator.userAgent,navigator.language,new Date().getTimezoneOffset().toString(),screen.colorDepth.toString(),screen.width.toString(),screen.height.toString(),"crudify-login"].join("|");return h(t)}clearLegacyData(){let t=[];for(let e=0;e<this.storage.length;e++){let i=this.storage.key(e);i&&!i.startsWith(c)&&!i.startsWith(g)&&t.push(i)}t.forEach(e=>this.storage.removeItem(e))}async setItem(t,e,i){try{if(await this.ensureInitialized(),!this.encryptionKey||!this.salt){n.error("SecureStorage not properly initialized");return}let r=await p(e,this.encryptionKey,this.salt);if(this.storage.setItem(t,r),i){let o=Date.now()+i*60*1e3;this.storage.setItem(`${t}_expiry`,o.toString())}}catch(r){n.error("Failed to encrypt and store data",r instanceof Error?r:{message:String(r)})}}async getItem(t){try{await this.ensureInitialized();let e=`${t}_expiry`,i=this.storage.getItem(e);if(i){let f=parseInt(i,10);if(Date.now()>f)return this.removeItem(t),null}let r=this.storage.getItem(t);if(!r)return null;if(!l(r))return this.removeItem(t),null;let o=await this.generateFingerprint(),s=await u(r,o);return s||(n.warn("Failed to decrypt stored data - may be corrupted"),this.removeItem(t),null)}catch(e){return n.error("Failed to decrypt data",e instanceof Error?e:{message:String(e)}),this.removeItem(t),null}}removeItem(t){this.storage.removeItem(t),this.storage.removeItem(`${t}_expiry`)}clear(){this.storage.clear()}async setToken(t){try{let e=t.split(".");if(e.length===3){let i=JSON.parse(atob(e[1]));if(i.exp){let r=i.exp*1e3,o=Date.now(),s=Math.floor((r-o)/(60*1e3));if(s>0){await this.setItem("authToken",t,s);return}}}}catch{n.warn("Failed to parse token expiry, using default expiry")}await this.setItem("authToken",t,1440)}async getToken(){let t=await this.getItem("authToken");if(t)try{let e=t.split(".");if(e.length===3){let i=JSON.parse(atob(e[1]));if(i.exp){let r=Math.floor(Date.now()/1e3);if(i.exp<r)return this.removeItem("authToken"),null}}}catch{return n.warn("Failed to validate token expiry"),this.removeItem("authToken"),null}return t}async hasValidToken(){return await this.getToken()!==null}async migrateFromLocalStorage(t){let e=window.localStorage.getItem(t);e&&(window.localStorage.removeItem(t),t==="authToken"?await this.setToken(e):await this.setItem(t,e))}uint8ArrayToBase64(t){let e="";for(let i=0;i<t.length;i++)e+=String.fromCharCode(t[i]);return btoa(e)}base64ToUint8Array(t){let e=atob(t),i=new Uint8Array(e.length);for(let r=0;r<e.length;r++)i[r]=e.charCodeAt(r);return i}},I=new a("sessionStorage"),T=new a("localStorage");export{I as a,T as b};
|
package/dist/components.d.mts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { B as BoxScreenType, a as CrudiaAutoGenerate, i as CrudiaAutoGenerateProps, b as CrudiaFileField, j as CrudiaFileFieldProps, c as CrudiaMarkdownField, k as CrudiaMarkdownFieldProps, C as CrudifyLogin, d as CrudifyLoginConfig, e as CrudifyLoginProps, f as CrudifyLoginTranslations, L as LoginComponent, P as Policies, h as PolicyAction, S as SessionStatus, g as UserLoginData, U as UserProfileDisplay } from './CrudiaMarkdownField-
|
|
1
|
+
export { B as BoxScreenType, a as CrudiaAutoGenerate, i as CrudiaAutoGenerateProps, b as CrudiaFileField, j as CrudiaFileFieldProps, c as CrudiaMarkdownField, k as CrudiaMarkdownFieldProps, C as CrudifyLogin, d as CrudifyLoginConfig, e as CrudifyLoginProps, f as CrudifyLoginTranslations, L as LoginComponent, P as Policies, h as PolicyAction, S as SessionStatus, g as UserLoginData, U as UserProfileDisplay } from './CrudiaMarkdownField-BvJn2GL8.mjs';
|
|
2
2
|
export { G as GlobalNotificationProvider, a as GlobalNotificationProviderProps, N as Notification, b as NotificationSeverity, u as useGlobalNotification } from './GlobalNotificationProvider-Zq18OkpI.mjs';
|
|
3
3
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
4
|
import 'react';
|
package/dist/components.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { B as BoxScreenType, a as CrudiaAutoGenerate, i as CrudiaAutoGenerateProps, b as CrudiaFileField, j as CrudiaFileFieldProps, c as CrudiaMarkdownField, k as CrudiaMarkdownFieldProps, C as CrudifyLogin, d as CrudifyLoginConfig, e as CrudifyLoginProps, f as CrudifyLoginTranslations, L as LoginComponent, P as Policies, h as PolicyAction, S as SessionStatus, g as UserLoginData, U as UserProfileDisplay } from './CrudiaMarkdownField-
|
|
1
|
+
export { B as BoxScreenType, a as CrudiaAutoGenerate, i as CrudiaAutoGenerateProps, b as CrudiaFileField, j as CrudiaFileFieldProps, c as CrudiaMarkdownField, k as CrudiaMarkdownFieldProps, C as CrudifyLogin, d as CrudifyLoginConfig, e as CrudifyLoginProps, f as CrudifyLoginTranslations, L as LoginComponent, P as Policies, h as PolicyAction, S as SessionStatus, g as UserLoginData, U as UserProfileDisplay } from './CrudiaMarkdownField-CggOpcBM.js';
|
|
2
2
|
export { G as GlobalNotificationProvider, a as GlobalNotificationProviderProps, N as Notification, b as NotificationSeverity, u as useGlobalNotification } from './GlobalNotificationProvider-Zq18OkpI.js';
|
|
3
3
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
4
|
import 'react';
|
package/dist/components.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkW4ZYKPOKjs = require('./chunk-W4ZYKPOK.js');var _chunkH6XXWDUTjs = require('./chunk-H6XXWDUT.js');require('./chunk-4LMFQECS.js');var _react = require('react');var _jsxruntime = require('react/jsx-runtime');function z({showBelowMinutes:f=5,position:m="bottom-right",colorNormal:c="#ed6c02",colorCritical:x="#d32f2f",style:u,className:g}={}){let{isAuthenticated:o,tokens:t}=_chunkH6XXWDUTjs.e.call(void 0, ),[i,y]=_react.useState.call(void 0, 0),[h,C]=_react.useState.call(void 0, 100);if(_react.useEffect.call(void 0, ()=>{if(!o||!t)return;let v=setInterval(()=>{let P=Date.now(),p=t.expiresAt-P,w=900*1e3;y(Math.max(0,p)),C(Math.max(0,p/w*100))},1e3);return()=>clearInterval(v)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),S=Math.floor(i%6e4/1e3);if(e>=f)return null;let s=e<2,a=s?x:c,b={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[m];return _jsxruntime.jsxs.call(void 0, "div",{className:g,style:{position:"fixed",...b,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...u},children:[_jsxruntime.jsxs.call(void 0, "div",{style:{marginBottom:"8px"},children:[_jsxruntime.jsx.call(void 0, "div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),_jsxruntime.jsxs.call(void 0, "div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",S.toString().padStart(2,"0")]})]}),_jsxruntime.jsx.call(void 0, "div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:_jsxruntime.jsx.call(void 0, "div",{style:{width:`${h}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}exports.CrudiaAutoGenerate = _chunkW4ZYKPOKjs.v; exports.CrudiaFileField = _chunkW4ZYKPOKjs.w; exports.CrudiaMarkdownField = _chunkW4ZYKPOKjs.x; exports.CrudifyLogin = _chunkW4ZYKPOKjs.o; exports.GlobalNotificationProvider = _chunkH6XXWDUTjs.f; exports.LoginComponent = _chunkW4ZYKPOKjs.t; exports.Policies = _chunkW4ZYKPOKjs.s; exports.SessionStatus = _chunkW4ZYKPOKjs.u; exports.SessionTimeIndicator = z; exports.UserProfileDisplay = _chunkW4ZYKPOKjs.p; exports.useGlobalNotification = _chunkH6XXWDUTjs.g;
|
package/dist/components.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{o as N,p as T,s as M,t as k,u as G,v as L,w as A,x as R}from"./chunk-
|
|
1
|
+
import{o as N,p as T,s as M,t as k,u as G,v as L,w as A,x as R}from"./chunk-SYHNHKFA.mjs";import{e as d,f as F,g as I}from"./chunk-O4FUHIQG.mjs";import"./chunk-44VU4TSP.mjs";import{useEffect as B,useState as l}from"react";import{jsx as r,jsxs as n}from"react/jsx-runtime";function z({showBelowMinutes:f=5,position:m="bottom-right",colorNormal:c="#ed6c02",colorCritical:x="#d32f2f",style:u,className:g}={}){let{isAuthenticated:o,tokens:t}=d(),[i,y]=l(0),[h,C]=l(100);if(B(()=>{if(!o||!t)return;let v=setInterval(()=>{let P=Date.now(),p=t.expiresAt-P,w=900*1e3;y(Math.max(0,p)),C(Math.max(0,p/w*100))},1e3);return()=>clearInterval(v)},[o,t]),!o||i<=0)return null;let e=Math.floor(i/6e4),S=Math.floor(i%6e4/1e3);if(e>=f)return null;let s=e<2,a=s?x:c,b={"top-left":{top:"16px",left:"16px"},"top-right":{top:"16px",right:"16px"},"bottom-left":{bottom:"16px",left:"16px"},"bottom-right":{bottom:"16px",right:"16px"}}[m];return n("div",{className:g,style:{position:"fixed",...b,padding:"12px 16px",backgroundColor:"white",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0, 0, 0, 0.15)",minWidth:"200px",zIndex:9999,fontFamily:"system-ui, -apple-system, sans-serif",...u},children:[n("div",{style:{marginBottom:"8px"},children:[r("div",{style:{fontSize:"12px",fontWeight:600,color:a,marginBottom:"4px"},children:s?"\u26A0\uFE0F Sesi\xF3n expirando":"\u23F0 Sesi\xF3n por expirar"}),n("div",{style:{fontSize:"14px",color:"#333",fontWeight:500},children:[e,":",S.toString().padStart(2,"0")]})]}),r("div",{style:{width:"100%",height:"6px",backgroundColor:"#e0e0e0",borderRadius:"3px",overflow:"hidden"},children:r("div",{style:{width:`${h}%`,height:"100%",backgroundColor:a,transition:"width 1s linear"}})})]})}export{L as CrudiaAutoGenerate,A as CrudiaFileField,R as CrudiaMarkdownField,N as CrudifyLogin,F as GlobalNotificationProvider,k as LoginComponent,M as Policies,G as SessionStatus,z as SessionTimeIndicator,T as UserProfileDisplay,I as useGlobalNotification};
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { J as JwtPayload } from './tenantConfig-DqJqQkoR.mjs';
|
|
2
|
+
|
|
3
|
+
interface JWTPayload extends JwtPayload {
|
|
4
|
+
"cognito:username"?: string;
|
|
5
|
+
}
|
|
6
|
+
declare const decodeJwtSafely: (token: string) => JWTPayload | null;
|
|
7
|
+
declare const getCurrentUserEmail: () => string | null;
|
|
8
|
+
declare const isTokenExpired: (token: string) => boolean;
|
|
9
|
+
|
|
10
|
+
declare class SecureStorage {
|
|
11
|
+
private readonly storage;
|
|
12
|
+
private encryptionKey;
|
|
13
|
+
private salt;
|
|
14
|
+
private initPromise;
|
|
15
|
+
private initialized;
|
|
16
|
+
constructor(storageType?: "localStorage" | "sessionStorage");
|
|
17
|
+
/**
|
|
18
|
+
* Initialize encryption key asynchronously
|
|
19
|
+
* Must be called before using encryption methods
|
|
20
|
+
*/
|
|
21
|
+
private ensureInitialized;
|
|
22
|
+
private initialize;
|
|
23
|
+
private generateFingerprint;
|
|
24
|
+
private clearLegacyData;
|
|
25
|
+
setItem(key: string, value: string, expiryMinutes?: number): Promise<void>;
|
|
26
|
+
getItem(key: string): Promise<string | null>;
|
|
27
|
+
removeItem(key: string): void;
|
|
28
|
+
clear(): void;
|
|
29
|
+
setToken(token: string): Promise<void>;
|
|
30
|
+
getToken(): Promise<string | null>;
|
|
31
|
+
hasValidToken(): Promise<boolean>;
|
|
32
|
+
migrateFromLocalStorage(key: string): Promise<void>;
|
|
33
|
+
private uint8ArrayToBase64;
|
|
34
|
+
private base64ToUint8Array;
|
|
35
|
+
}
|
|
36
|
+
declare const secureSessionStorage: SecureStorage;
|
|
37
|
+
declare const secureLocalStorage: SecureStorage;
|
|
38
|
+
|
|
39
|
+
declare const ERROR_CODES: {
|
|
40
|
+
readonly INVALID_CREDENTIALS: "INVALID_CREDENTIALS";
|
|
41
|
+
readonly UNAUTHORIZED: "UNAUTHORIZED";
|
|
42
|
+
readonly INVALID_API_KEY: "INVALID_API_KEY";
|
|
43
|
+
readonly USER_NOT_FOUND: "USER_NOT_FOUND";
|
|
44
|
+
readonly USER_NOT_ACTIVE: "USER_NOT_ACTIVE";
|
|
45
|
+
readonly NO_PERMISSION: "NO_PERMISSION";
|
|
46
|
+
readonly ITEM_NOT_FOUND: "ITEM_NOT_FOUND";
|
|
47
|
+
readonly NOT_FOUND: "NOT_FOUND";
|
|
48
|
+
readonly IN_USE: "IN_USE";
|
|
49
|
+
readonly FIELD_ERROR: "FIELD_ERROR";
|
|
50
|
+
readonly BAD_REQUEST: "BAD_REQUEST";
|
|
51
|
+
readonly INVALID_EMAIL: "INVALID_EMAIL";
|
|
52
|
+
readonly INVALID_CODE: "INVALID_CODE";
|
|
53
|
+
readonly INTERNAL_SERVER_ERROR: "INTERNAL_SERVER_ERROR";
|
|
54
|
+
readonly DATABASE_CONNECTION_ERROR: "DATABASE_CONNECTION_ERROR";
|
|
55
|
+
readonly INVALID_CONFIGURATION: "INVALID_CONFIGURATION";
|
|
56
|
+
readonly UNKNOWN_OPERATION: "UNKNOWN_OPERATION";
|
|
57
|
+
readonly TOO_MANY_REQUESTS: "TOO_MANY_REQUESTS";
|
|
58
|
+
readonly NETWORK_ERROR: "NETWORK_ERROR";
|
|
59
|
+
readonly TIMEOUT_ERROR: "TIMEOUT_ERROR";
|
|
60
|
+
};
|
|
61
|
+
type ErrorCode = (typeof ERROR_CODES)[keyof typeof ERROR_CODES];
|
|
62
|
+
type ErrorSeverity = "info" | "warning" | "error" | "critical";
|
|
63
|
+
declare const ERROR_SEVERITY_MAP: Record<ErrorCode, ErrorSeverity>;
|
|
64
|
+
interface ParsedError {
|
|
65
|
+
code: ErrorCode;
|
|
66
|
+
message: string;
|
|
67
|
+
severity: ErrorSeverity;
|
|
68
|
+
field?: string;
|
|
69
|
+
details?: Record<string, unknown>;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Parse a Crudify API response and extract standardized error information
|
|
73
|
+
*/
|
|
74
|
+
declare function parseApiError(response: unknown): ParsedError[];
|
|
75
|
+
/**
|
|
76
|
+
* Parse transaction response errors
|
|
77
|
+
*/
|
|
78
|
+
declare function parseTransactionError(response: unknown): ParsedError[];
|
|
79
|
+
/**
|
|
80
|
+
* Get a human-readable error message for an error code
|
|
81
|
+
*/
|
|
82
|
+
declare function getErrorMessage(code: ErrorCode): string;
|
|
83
|
+
/**
|
|
84
|
+
* Handle JavaScript/Network errors and convert to ParsedError
|
|
85
|
+
*/
|
|
86
|
+
declare function parseJavaScriptError(error: unknown): ParsedError;
|
|
87
|
+
/**
|
|
88
|
+
* Universal error handler that can process any type of error from Crudify APIs
|
|
89
|
+
*/
|
|
90
|
+
declare function handleCrudifyError(error: unknown): ParsedError[];
|
|
91
|
+
|
|
92
|
+
interface ErrorTranslationConfig {
|
|
93
|
+
/** Función de traducción de i18next */
|
|
94
|
+
translateFn: (key: string) => string;
|
|
95
|
+
/** Idioma actual (opcional, para logging) */
|
|
96
|
+
currentLanguage?: string;
|
|
97
|
+
/** Habilitar logs de debug */
|
|
98
|
+
enableDebug?: boolean;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Traduce un código de error usando jerarquía de fallbacks
|
|
102
|
+
*/
|
|
103
|
+
declare function translateErrorCode(errorCode: string, config: ErrorTranslationConfig): string;
|
|
104
|
+
/**
|
|
105
|
+
* Traduce múltiples códigos de error
|
|
106
|
+
*/
|
|
107
|
+
declare function translateErrorCodes(errorCodes: string[], config: ErrorTranslationConfig): string[];
|
|
108
|
+
/**
|
|
109
|
+
* Traduce un error completo (código + mensaje personalizado)
|
|
110
|
+
*/
|
|
111
|
+
declare function translateError(error: {
|
|
112
|
+
code: string;
|
|
113
|
+
message?: string;
|
|
114
|
+
field?: string;
|
|
115
|
+
}, config: ErrorTranslationConfig): string;
|
|
116
|
+
/**
|
|
117
|
+
* Hook para usar en componentes React con i18next
|
|
118
|
+
*/
|
|
119
|
+
declare function createErrorTranslator(translateFn: (key: string) => string, options?: {
|
|
120
|
+
currentLanguage?: string;
|
|
121
|
+
enableDebug?: boolean;
|
|
122
|
+
}): {
|
|
123
|
+
translateErrorCode: (code: string) => string;
|
|
124
|
+
translateErrorCodes: (codes: string[]) => string[];
|
|
125
|
+
translateError: (error: {
|
|
126
|
+
code: string;
|
|
127
|
+
message?: string;
|
|
128
|
+
field?: string;
|
|
129
|
+
}) => string;
|
|
130
|
+
translateApiError: (apiResponse: {
|
|
131
|
+
data?: {
|
|
132
|
+
response?: {
|
|
133
|
+
status?: string;
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
status?: string;
|
|
137
|
+
code?: string;
|
|
138
|
+
} | null | undefined) => string;
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
export { ERROR_CODES as E, type ParsedError as P, secureLocalStorage as a, parseTransactionError as b, parseJavaScriptError as c, decodeJwtSafely as d, getErrorMessage as e, ERROR_SEVERITY_MAP as f, getCurrentUserEmail as g, handleCrudifyError as h, isTokenExpired as i, translateErrorCodes as j, translateError as k, createErrorTranslator as l, type ErrorCode as m, type ErrorSeverity as n, type ErrorTranslationConfig as o, parseApiError as p, secureSessionStorage as s, translateErrorCode as t };
|