@nocios/crudify-ui 4.0.8 → 4.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/GlobalNotificationProvider-C3iWgM1z.d.mts +35 -0
- package/dist/GlobalNotificationProvider-C3iWgM1z.d.ts +35 -0
- package/dist/api-Djqihi4n.d.mts +82 -0
- package/dist/api-Djqihi4n.d.ts +82 -0
- package/dist/chunk-6EBMA4HZ.js +1 -0
- package/dist/chunk-BJ6PIVZR.mjs +1 -0
- package/dist/chunk-D3OQLCQW.mjs +1 -0
- package/dist/chunk-FBT222LR.mjs +1 -0
- package/dist/chunk-JZVX4CN3.mjs +1 -0
- package/dist/chunk-NNY4A73V.js +1 -0
- package/dist/chunk-OGQX5FM5.js +1 -0
- package/dist/chunk-T2CPA46I.mjs +1 -0
- package/dist/chunk-TAEX76JC.js +1 -0
- package/dist/chunk-YICJIX2K.js +1 -0
- package/dist/chunk-YIIUEOXC.js +1 -0
- package/dist/chunk-YS3C7YG5.mjs +1 -0
- package/dist/components.d.mts +4 -0
- package/dist/components.d.ts +4 -0
- package/dist/components.js +1 -0
- package/dist/components.mjs +1 -0
- package/dist/hooks.d.mts +5 -0
- package/dist/hooks.d.ts +5 -0
- package/dist/hooks.js +1 -0
- package/dist/hooks.mjs +1 -0
- package/dist/index-CY6Qkw3q.d.mts +78 -0
- package/dist/index-CjC4JwH9.d.ts +427 -0
- package/dist/index-DxFMT2hN.d.ts +78 -0
- package/dist/index-FiBZQvXG.d.mts +427 -0
- package/dist/index.d.mts +8 -732
- package/dist/index.d.ts +8 -732
- package/dist/index.js +1 -4906
- package/dist/index.mjs +1 -4890
- package/dist/utils.d.mts +124 -0
- package/dist/utils.d.ts +124 -0
- package/dist/utils.js +1 -0
- package/dist/utils.mjs +1 -0
- package/package.json +24 -14
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
type NotificationSeverity = "error" | "info" | "success" | "warning";
|
|
4
|
+
interface Notification {
|
|
5
|
+
id: string;
|
|
6
|
+
message: string;
|
|
7
|
+
severity: NotificationSeverity;
|
|
8
|
+
autoHideDuration?: number;
|
|
9
|
+
persistent?: boolean;
|
|
10
|
+
allowHtml?: boolean;
|
|
11
|
+
}
|
|
12
|
+
interface GlobalNotificationContextValue {
|
|
13
|
+
showNotification: (message: string, severity?: NotificationSeverity, options?: {
|
|
14
|
+
autoHideDuration?: number;
|
|
15
|
+
persistent?: boolean;
|
|
16
|
+
allowHtml?: boolean;
|
|
17
|
+
}) => string;
|
|
18
|
+
hideNotification: (id: string) => void;
|
|
19
|
+
clearAllNotifications: () => void;
|
|
20
|
+
}
|
|
21
|
+
interface GlobalNotificationProviderProps {
|
|
22
|
+
children: React.ReactNode;
|
|
23
|
+
maxNotifications?: number;
|
|
24
|
+
defaultAutoHideDuration?: number;
|
|
25
|
+
position?: {
|
|
26
|
+
vertical: "top" | "bottom";
|
|
27
|
+
horizontal: "left" | "center" | "right";
|
|
28
|
+
};
|
|
29
|
+
enabled?: boolean;
|
|
30
|
+
allowHtml?: boolean;
|
|
31
|
+
}
|
|
32
|
+
declare const GlobalNotificationProvider: React.FC<GlobalNotificationProviderProps>;
|
|
33
|
+
declare const useGlobalNotification: () => GlobalNotificationContextValue;
|
|
34
|
+
|
|
35
|
+
export { GlobalNotificationProvider as G, type Notification as N, type GlobalNotificationProviderProps as a, type NotificationSeverity as b, useGlobalNotification as u };
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
type NotificationSeverity = "error" | "info" | "success" | "warning";
|
|
4
|
+
interface Notification {
|
|
5
|
+
id: string;
|
|
6
|
+
message: string;
|
|
7
|
+
severity: NotificationSeverity;
|
|
8
|
+
autoHideDuration?: number;
|
|
9
|
+
persistent?: boolean;
|
|
10
|
+
allowHtml?: boolean;
|
|
11
|
+
}
|
|
12
|
+
interface GlobalNotificationContextValue {
|
|
13
|
+
showNotification: (message: string, severity?: NotificationSeverity, options?: {
|
|
14
|
+
autoHideDuration?: number;
|
|
15
|
+
persistent?: boolean;
|
|
16
|
+
allowHtml?: boolean;
|
|
17
|
+
}) => string;
|
|
18
|
+
hideNotification: (id: string) => void;
|
|
19
|
+
clearAllNotifications: () => void;
|
|
20
|
+
}
|
|
21
|
+
interface GlobalNotificationProviderProps {
|
|
22
|
+
children: React.ReactNode;
|
|
23
|
+
maxNotifications?: number;
|
|
24
|
+
defaultAutoHideDuration?: number;
|
|
25
|
+
position?: {
|
|
26
|
+
vertical: "top" | "bottom";
|
|
27
|
+
horizontal: "left" | "center" | "right";
|
|
28
|
+
};
|
|
29
|
+
enabled?: boolean;
|
|
30
|
+
allowHtml?: boolean;
|
|
31
|
+
}
|
|
32
|
+
declare const GlobalNotificationProvider: React.FC<GlobalNotificationProviderProps>;
|
|
33
|
+
declare const useGlobalNotification: () => GlobalNotificationContextValue;
|
|
34
|
+
|
|
35
|
+
export { GlobalNotificationProvider as G, type Notification as N, type GlobalNotificationProviderProps as a, type NotificationSeverity as b, useGlobalNotification as u };
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
interface CrudifyApiResponse<T = unknown> {
|
|
2
|
+
success: boolean;
|
|
3
|
+
data?: T;
|
|
4
|
+
errors?: string | Record<string, string[]> | string[];
|
|
5
|
+
errorCode?: string;
|
|
6
|
+
fieldsWarning?: Record<string, string[]>;
|
|
7
|
+
}
|
|
8
|
+
interface CrudifyTransactionResponse {
|
|
9
|
+
success: boolean;
|
|
10
|
+
data?: TransactionResponseData[];
|
|
11
|
+
errors?: string | Record<string, string[]>;
|
|
12
|
+
errorCode?: string;
|
|
13
|
+
}
|
|
14
|
+
interface TransactionResponseData {
|
|
15
|
+
response?: {
|
|
16
|
+
status: string;
|
|
17
|
+
data?: unknown;
|
|
18
|
+
message?: string;
|
|
19
|
+
};
|
|
20
|
+
errors?: string | Record<string, string[]>;
|
|
21
|
+
}
|
|
22
|
+
interface UserProfile {
|
|
23
|
+
id: string | number;
|
|
24
|
+
email: string;
|
|
25
|
+
username?: string;
|
|
26
|
+
firstName?: string;
|
|
27
|
+
lastName?: string;
|
|
28
|
+
fullName?: string;
|
|
29
|
+
avatar?: string;
|
|
30
|
+
role?: string;
|
|
31
|
+
permissions?: string[];
|
|
32
|
+
lastLogin?: string;
|
|
33
|
+
isActive?: boolean;
|
|
34
|
+
createdAt?: string;
|
|
35
|
+
updatedAt?: string;
|
|
36
|
+
[key: string]: unknown;
|
|
37
|
+
}
|
|
38
|
+
interface LoginResponse {
|
|
39
|
+
token: string;
|
|
40
|
+
user?: UserProfile;
|
|
41
|
+
expiresIn?: number;
|
|
42
|
+
refreshToken?: string;
|
|
43
|
+
}
|
|
44
|
+
interface LoginRequest {
|
|
45
|
+
identifier: string;
|
|
46
|
+
password: string;
|
|
47
|
+
}
|
|
48
|
+
interface ForgotPasswordRequest {
|
|
49
|
+
email: string;
|
|
50
|
+
}
|
|
51
|
+
interface ResetPasswordRequest {
|
|
52
|
+
email: string;
|
|
53
|
+
code: string;
|
|
54
|
+
newPassword: string;
|
|
55
|
+
}
|
|
56
|
+
interface ValidateCodeRequest {
|
|
57
|
+
email: string;
|
|
58
|
+
codePassword: string;
|
|
59
|
+
}
|
|
60
|
+
interface JwtPayload {
|
|
61
|
+
sub?: string;
|
|
62
|
+
email?: string;
|
|
63
|
+
username?: string;
|
|
64
|
+
iat?: number;
|
|
65
|
+
exp?: number;
|
|
66
|
+
iss?: string;
|
|
67
|
+
aud?: string;
|
|
68
|
+
[key: string]: unknown;
|
|
69
|
+
}
|
|
70
|
+
interface ApiError {
|
|
71
|
+
code: string;
|
|
72
|
+
message: string;
|
|
73
|
+
field?: string;
|
|
74
|
+
details?: Record<string, unknown>;
|
|
75
|
+
}
|
|
76
|
+
interface ValidationError {
|
|
77
|
+
field: string;
|
|
78
|
+
message: string;
|
|
79
|
+
code: string;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export type { ApiError as A, CrudifyApiResponse as C, ForgotPasswordRequest as F, JwtPayload as J, LoginResponse as L, ResetPasswordRequest as R, TransactionResponseData as T, UserProfile as U, ValidateCodeRequest as V, CrudifyTransactionResponse as a, LoginRequest as b, ValidationError as c };
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
interface CrudifyApiResponse<T = unknown> {
|
|
2
|
+
success: boolean;
|
|
3
|
+
data?: T;
|
|
4
|
+
errors?: string | Record<string, string[]> | string[];
|
|
5
|
+
errorCode?: string;
|
|
6
|
+
fieldsWarning?: Record<string, string[]>;
|
|
7
|
+
}
|
|
8
|
+
interface CrudifyTransactionResponse {
|
|
9
|
+
success: boolean;
|
|
10
|
+
data?: TransactionResponseData[];
|
|
11
|
+
errors?: string | Record<string, string[]>;
|
|
12
|
+
errorCode?: string;
|
|
13
|
+
}
|
|
14
|
+
interface TransactionResponseData {
|
|
15
|
+
response?: {
|
|
16
|
+
status: string;
|
|
17
|
+
data?: unknown;
|
|
18
|
+
message?: string;
|
|
19
|
+
};
|
|
20
|
+
errors?: string | Record<string, string[]>;
|
|
21
|
+
}
|
|
22
|
+
interface UserProfile {
|
|
23
|
+
id: string | number;
|
|
24
|
+
email: string;
|
|
25
|
+
username?: string;
|
|
26
|
+
firstName?: string;
|
|
27
|
+
lastName?: string;
|
|
28
|
+
fullName?: string;
|
|
29
|
+
avatar?: string;
|
|
30
|
+
role?: string;
|
|
31
|
+
permissions?: string[];
|
|
32
|
+
lastLogin?: string;
|
|
33
|
+
isActive?: boolean;
|
|
34
|
+
createdAt?: string;
|
|
35
|
+
updatedAt?: string;
|
|
36
|
+
[key: string]: unknown;
|
|
37
|
+
}
|
|
38
|
+
interface LoginResponse {
|
|
39
|
+
token: string;
|
|
40
|
+
user?: UserProfile;
|
|
41
|
+
expiresIn?: number;
|
|
42
|
+
refreshToken?: string;
|
|
43
|
+
}
|
|
44
|
+
interface LoginRequest {
|
|
45
|
+
identifier: string;
|
|
46
|
+
password: string;
|
|
47
|
+
}
|
|
48
|
+
interface ForgotPasswordRequest {
|
|
49
|
+
email: string;
|
|
50
|
+
}
|
|
51
|
+
interface ResetPasswordRequest {
|
|
52
|
+
email: string;
|
|
53
|
+
code: string;
|
|
54
|
+
newPassword: string;
|
|
55
|
+
}
|
|
56
|
+
interface ValidateCodeRequest {
|
|
57
|
+
email: string;
|
|
58
|
+
codePassword: string;
|
|
59
|
+
}
|
|
60
|
+
interface JwtPayload {
|
|
61
|
+
sub?: string;
|
|
62
|
+
email?: string;
|
|
63
|
+
username?: string;
|
|
64
|
+
iat?: number;
|
|
65
|
+
exp?: number;
|
|
66
|
+
iss?: string;
|
|
67
|
+
aud?: string;
|
|
68
|
+
[key: string]: unknown;
|
|
69
|
+
}
|
|
70
|
+
interface ApiError {
|
|
71
|
+
code: string;
|
|
72
|
+
message: string;
|
|
73
|
+
field?: string;
|
|
74
|
+
details?: Record<string, unknown>;
|
|
75
|
+
}
|
|
76
|
+
interface ValidationError {
|
|
77
|
+
field: string;
|
|
78
|
+
message: string;
|
|
79
|
+
code: string;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export type { ApiError as A, CrudifyApiResponse as C, ForgotPasswordRequest as F, JwtPayload as J, LoginResponse as L, ResetPasswordRequest as R, TransactionResponseData as T, UserProfile as U, ValidateCodeRequest as V, CrudifyTransactionResponse as a, LoginRequest as b, ValidationError as c };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var m=e=>{let n=document.cookie.match(new RegExp("(^|;)\\s*"+e+"=([^;]+)"));return n?n[2]:null};var R=["errors.{category}.{code}","errors.{code}","login.{code}","error.{code}","messages.{code}","{code}"],T={INVALID_CREDENTIALS:"auth",UNAUTHORIZED:"auth",INVALID_API_KEY:"auth",USER_NOT_FOUND:"auth",USER_NOT_ACTIVE:"auth",NO_PERMISSION:"auth",SESSION_EXPIRED:"auth",ITEM_NOT_FOUND:"data",NOT_FOUND:"data",IN_USE:"data",DUPLICATE_ENTRY:"data",FIELD_ERROR:"validation",BAD_REQUEST:"validation",INVALID_EMAIL:"validation",INVALID_CODE:"validation",REQUIRED_FIELD:"validation",INTERNAL_SERVER_ERROR:"system",DATABASE_CONNECTION_ERROR:"system",INVALID_CONFIGURATION:"system",UNKNOWN_OPERATION:"system",TIMEOUT_ERROR:"system",NETWORK_ERROR:"system",TOO_MANY_REQUESTS:"rate_limit"},f={INVALID_CREDENTIALS:"Invalid username or password",UNAUTHORIZED:"You are not authorized to perform this action",SESSION_EXPIRED:"Your session has expired. Please log in again.",USER_NOT_FOUND:"User not found",ITEM_NOT_FOUND:"Item not found",FIELD_ERROR:"Invalid field value",INTERNAL_SERVER_ERROR:"An internal error occurred",NETWORK_ERROR:"Network connection error",TIMEOUT_ERROR:"Request timeout",UNKNOWN_OPERATION:"Unknown operation",INVALID_EMAIL:"Invalid email format",INVALID_CODE:"Invalid code",TOO_MANY_REQUESTS:"Too many requests, please try again later"};function l(e,n){let{translateFn:r,currentLanguage:t,enableDebug:a}=n;a&&console.log(`\u{1F50D} [ErrorTranslation] Translating error code: ${e} (lang: ${t||"unknown"})`);let i=e.toUpperCase(),d=T[i],c=R.map(o=>o.replace("{category}",d||"general").replace("{code}",i));a&&console.log("\u{1F511} [ErrorTranslation] Searching keys:",c);for(let o of c){let s=r(o);if(a&&console.log(`\u{1F50D} [ErrorTranslation] Checking key: "${o}" -> result: "${s}" (same as key: ${s===o})`),s&&s!==o)return a&&console.log(`\u2705 [ErrorTranslation] Found translation at key: ${o} = "${s}"`),s}let g=f[i];if(g)return a&&console.log(`\u{1F504} [ErrorTranslation] Using default message: "${g}"`),g;let u=i.replace(/_/g," ").toLowerCase().replace(/\b\w/g,o=>o.toUpperCase());return a&&console.log(`\u26A0\uFE0F [ErrorTranslation] No translation found, using friendly code: "${u}"`),u}function I(e,n){return e.map(r=>l(r,n))}function N(e,n){let{enableDebug:r}=n;r&&console.log("\u{1F50D} [ErrorTranslation] Translating error:",e);let t=l(e.code,n);return t!==e.code.toUpperCase()&&t!==e.code?(r&&console.log(`\u2705 [ErrorTranslation] Using hierarchical translation: "${t}"`),e.field?`${e.field}: ${t}`:t):e.message&&!e.message.includes("Error:")&&e.message.length>0&&e.message!==e.code?(r&&console.log(`\u{1F504} [ErrorTranslation] No hierarchical translation found, using API message: "${e.message}"`),e.message):(r&&console.log(`\u26A0\uFE0F [ErrorTranslation] Using final fallback: "${t}"`),e.field?`${e.field}: ${t}`:t)}function O(e,n={}){let r={translateFn:e,currentLanguage:n.currentLanguage,enableDebug:n.enableDebug||!1};return{translateErrorCode:t=>l(t,r),translateErrorCodes:t=>I(t,r),translateError:t=>N(t,r),translateApiError:t=>_optionalChain([t, 'optionalAccess', _ => _.data, 'optionalAccess', _2 => _2.response, 'optionalAccess', _3 => _3.status])?l(t.data.response.status,r):_optionalChain([t, 'optionalAccess', _4 => _4.status])?l(t.status,r):_optionalChain([t, 'optionalAccess', _5 => _5.code])?l(t.code,r):"Unknown error"}}var E=e=>{try{let n=e.split(".");if(n.length!==3)return console.warn("Invalid JWT format: token must have 3 parts"),null;let r=n[1],t=r+"=".repeat((4-r.length%4)%4);return JSON.parse(atob(t))}catch(n){return console.warn("Failed to decode JWT token:",n),null}},y= exports.g =()=>{try{let e=null;if(e=sessionStorage.getItem("authToken"),console.log("\u{1F50D} getCurrentUserEmail - authToken:",e?`${e.substring(0,20)}...`:null),e||(e=sessionStorage.getItem("token"),console.log("\u{1F50D} getCurrentUserEmail - token:",e?`${e.substring(0,20)}...`:null)),e||(e=localStorage.getItem("authToken")||localStorage.getItem("token"),console.log("\u{1F50D} getCurrentUserEmail - localStorage:",e?`${e.substring(0,20)}...`:null)),!e)return console.warn("\u{1F50D} getCurrentUserEmail - No token found in any storage"),null;let n=E(e);if(!n)return console.warn("\u{1F50D} getCurrentUserEmail - Failed to decode token"),null;let r=n.email||n["cognito:username"]||null;return console.log("\u{1F50D} getCurrentUserEmail - Extracted email:",r),r}catch(e){return console.warn("Failed to get current user email:",e),null}},A= exports.h =e=>{try{let n=E(e);if(!n||!n.exp)return!0;let r=Math.floor(Date.now()/1e3);return n.exp<r}catch (e2){return!0}};exports.a = m; exports.b = l; exports.c = I; exports.d = N; exports.e = O; exports.f = E; exports.g = y; exports.h = A;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var r={INVALID_CREDENTIALS:"INVALID_CREDENTIALS",UNAUTHORIZED:"UNAUTHORIZED",INVALID_API_KEY:"INVALID_API_KEY",USER_NOT_FOUND:"USER_NOT_FOUND",USER_NOT_ACTIVE:"USER_NOT_ACTIVE",NO_PERMISSION:"NO_PERMISSION",ITEM_NOT_FOUND:"ITEM_NOT_FOUND",NOT_FOUND:"NOT_FOUND",IN_USE:"IN_USE",FIELD_ERROR:"FIELD_ERROR",BAD_REQUEST:"BAD_REQUEST",INVALID_EMAIL:"INVALID_EMAIL",INVALID_CODE:"INVALID_CODE",INTERNAL_SERVER_ERROR:"INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"INVALID_CONFIGURATION",UNKNOWN_OPERATION:"UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"TOO_MANY_REQUESTS",NETWORK_ERROR:"NETWORK_ERROR",TIMEOUT_ERROR:"TIMEOUT_ERROR"},O={[r.INVALID_CREDENTIALS]:"warning",[r.UNAUTHORIZED]:"warning",[r.INVALID_API_KEY]:"error",[r.USER_NOT_FOUND]:"warning",[r.USER_NOT_ACTIVE]:"warning",[r.NO_PERMISSION]:"warning",[r.ITEM_NOT_FOUND]:"info",[r.NOT_FOUND]:"info",[r.IN_USE]:"warning",[r.FIELD_ERROR]:"warning",[r.BAD_REQUEST]:"warning",[r.INVALID_EMAIL]:"warning",[r.INVALID_CODE]:"warning",[r.INTERNAL_SERVER_ERROR]:"error",[r.DATABASE_CONNECTION_ERROR]:"error",[r.INVALID_CONFIGURATION]:"error",[r.UNKNOWN_OPERATION]:"error",[r.TOO_MANY_REQUESTS]:"warning",[r.NETWORK_ERROR]:"error",[r.TIMEOUT_ERROR]:"error"};function _(e){let o=[];try{let E=e;if(E.data&&typeof E.data=="object"){let a=E.data;if(a.response){let{status:R,fieldsWarning:t}=a.response;if(t&&typeof t=="object"&&Object.entries(t).forEach(([n,s])=>{Array.isArray(s)&&s.length>0&&o.push({code:r.FIELD_ERROR,message:s[0],severity:"warning",field:n})}),R&&typeof R=="string"){let n=R;O[n]&&o.push({code:n,message:i(n),severity:O[n]})}}}if(E.errors){if(typeof E.errors=="string")o.push({code:r.BAD_REQUEST,message:E.errors,severity:"warning"});else if(typeof E.errors=="object"){let a=E.errors;Object.entries(a).forEach(([R,t])=>{Array.isArray(t)&&t.length>0&&(R==="_error"?t.forEach(n=>{let s=typeof n=="string"&&N(n)?n:r.BAD_REQUEST;o.push({code:s,message:typeof n=="string"?n:i(s),severity:O[s]||"warning"})}):R==="_graphql"?t.forEach(n=>{if(typeof n=="string"){let s=N(n)?n:r.BAD_REQUEST;o.push({code:s,message:i(s),severity:O[s]||"warning"})}}):o.push({code:r.FIELD_ERROR,message:typeof t[0]=="string"?t[0]:"Validation error",severity:"warning",field:R}))})}}o.length===0&&E.success===!1&&o.push({code:r.BAD_REQUEST,message:"Request failed",severity:"warning"})}catch(E){o.push({code:r.INTERNAL_SERVER_ERROR,message:"Failed to parse error response",severity:"error",details:{originalError:E}})}return o.length>0?o:[{code:r.INTERNAL_SERVER_ERROR,message:"Unknown error occurred",severity:"error"}]}function I(e){try{let o=e;if(o.data&&Array.isArray(o.data)){let E=[];return o.data.forEach((a,R)=>{a.response?.status==="TOO_MANY_REQUESTS"?E.push({code:r.TOO_MANY_REQUESTS,message:i(r.TOO_MANY_REQUESTS),severity:"warning",details:{transactionIndex:R}}):(!a.response||a.response.status!=="OK")&&E.push({code:r.BAD_REQUEST,message:"Transaction failed",severity:"warning",details:{transactionIndex:R,response:a.response}})}),E}return _(e)}catch(o){return[{code:r.INTERNAL_SERVER_ERROR,message:"Failed to parse transaction error",severity:"error",details:{originalError:o}}]}}function N(e){return Object.values(r).includes(e)}function i(e){return{[r.INVALID_CREDENTIALS]:"Invalid email or password",[r.UNAUTHORIZED]:"You are not authorized to perform this action",[r.INVALID_API_KEY]:"Invalid API key",[r.USER_NOT_FOUND]:"User not found",[r.USER_NOT_ACTIVE]:"User account is not active",[r.NO_PERMISSION]:"You do not have permission to perform this action",[r.ITEM_NOT_FOUND]:"Item not found",[r.NOT_FOUND]:"Resource not found",[r.IN_USE]:"Resource is currently in use",[r.FIELD_ERROR]:"Validation error",[r.BAD_REQUEST]:"Invalid request",[r.INVALID_EMAIL]:"Please enter a valid email address",[r.INVALID_CODE]:"Invalid or expired code",[r.INTERNAL_SERVER_ERROR]:"Internal server error",[r.DATABASE_CONNECTION_ERROR]:"Database connection error",[r.INVALID_CONFIGURATION]:"Invalid configuration",[r.UNKNOWN_OPERATION]:"Unknown operation",[r.TOO_MANY_REQUESTS]:"Too many requests. Please try again later.",[r.NETWORK_ERROR]:"Network error. Please check your connection.",[r.TIMEOUT_ERROR]:"Request timed out. Please try again."}[e]||"An unknown error occurred"}function c(e){return e instanceof Error?e.name==="AbortError"?{code:r.TIMEOUT_ERROR,message:"Request was cancelled",severity:"info"}:e.message.includes("NetworkError")||e.message.includes("Failed to fetch")?{code:r.NETWORK_ERROR,message:i(r.NETWORK_ERROR),severity:"error"}:{code:r.INTERNAL_SERVER_ERROR,message:e.message||"An unexpected error occurred",severity:"error",details:{originalError:e}}:{code:r.INTERNAL_SERVER_ERROR,message:"An unknown error occurred",severity:"error",details:{originalError:e}}}function A(e){if(e instanceof Error)return[c(e)];if(typeof e=="object"&&e!==null){let o=e;return o.data&&Array.isArray(o.data)?I(e):_(e)}return[{code:r.INTERNAL_SERVER_ERROR,message:"An unknown error occurred",severity:"error",details:{originalError:e}}]}export{r as a,O as b,_ as c,I as d,i as e,c as f,A as g};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{e as $,g as D}from"./chunk-FBT222LR.mjs";import{useState as K,useEffect as z,useCallback as j,useRef as F}from"react";import Q from"@nocios/crudify-browser";var G=(S={})=>{let{autoFetch:c=!0,retryOnError:N=!1,maxRetries:g=3}=S,{isAuthenticated:T,isInitialized:I,sessionData:a,tokens:R}=D(),[E,d]=K(null),[y,O]=K(!1),[A,p]=K(null),u=F(null),o=F(!0),m=F(0),l=F(0),L=j(()=>a&&(a.email||a["cognito:username"])||null,[a]),P=j(()=>{d(null),p(null),O(!1),l.current=0},[]),w=j(async()=>{let x=L();if(!x){o.current&&(p("No user email available from session data"),O(!1));return}if(!I){o.current&&(p("Session not initialized"),O(!1));return}u.current&&u.current.abort();let e=new AbortController;u.current=e;let i=++m.current;try{o.current&&(O(!0),p(null));let r=await Q.readItems("users",{filter:{email:x},pagination:{limit:1}});if(i===m.current&&o.current&&!e.signal.aborted){let t=null;if(r.success){if(Array.isArray(r.data)&&r.data.length>0)t=r.data[0];else if(r.data?.response?.data)try{let s=r.data.response.data,n=typeof s=="string"?JSON.parse(s):s;n&&n.items&&Array.isArray(n.items)&&n.items.length>0&&(t=n.items[0])}catch{}else if(r.data&&typeof r.data=="object")r.data.items&&Array.isArray(r.data.items)&&r.data.items.length>0&&(t=r.data.items[0]);else if(r.data?.data?.response?.data)try{let s=r.data.data.response.data,n=typeof s=="string"?JSON.parse(s):s;n&&n.items&&Array.isArray(n.items)&&n.items.length>0&&(t=n.items[0])}catch{}}t?(d(t),p(null),l.current=0):(p("User profile not found in database"),d(null))}}catch(r){if(i===m.current&&o.current){let t=r;if(t.name==="AbortError")return;N&&l.current<g&&(t.message?.includes("Network Error")||t.message?.includes("Failed to fetch"))?(l.current++,setTimeout(()=>{o.current&&w()},1e3*l.current)):(p("Failed to load user profile from database"),d(null))}}finally{i===m.current&&o.current&&O(!1),u.current===e&&(u.current=null)}},[I,L,N,g]);return z(()=>{c&&T&&I?w():T||P()},[c,T,I,w,P]),z(()=>(o.current=!0,()=>{o.current=!1,u.current&&(u.current.abort(),u.current=null)}),[]),{user:{session:a,data:E},loading:y,error:A,refreshProfile:w,clearProfile:P}};import{useCallback as W}from"react";var ee=()=>{let{isAuthenticated:S,isLoading:c,isInitialized:N,tokens:g,error:T,sessionData:I,login:a,logout:R,refreshTokens:E,clearError:d,getTokenInfo:y,isExpiringSoon:O,expiresIn:A,refreshExpiresIn:p}=D(),u=W(m=>{m?console.warn("useAuth.setToken() is deprecated. Use login() method instead for better security."):R()},[R]),o=g?.expiresAt?new Date(g.expiresAt):null;return{isAuthenticated:S,loading:c,error:T,token:g?.accessToken||null,user:I,tokenExpiration:o,setToken:u,logout:R,refreshToken:E,login:a,isExpiringSoon:O,expiresIn:A,refreshExpiresIn:p,getTokenInfo:y,clearError:d}};import{useCallback as h}from"react";import U from"@nocios/crudify-browser";var oe=()=>{let{isInitialized:S,isLoading:c,error:N,isAuthenticated:g,login:T}=D(),I=h(()=>S&&!c&&!N,[S,c,N]),a=h(async()=>new Promise((o,m)=>{let l=()=>{I()?o():N?m(new Error(N)):setTimeout(l,100)};l()}),[I,N]),R=h(async()=>{if(!I())throw new Error("System not ready. Check isInitialized, isLoading, and error states.")},[I]),E=h(async(o,m,l)=>(await R(),await U.readItems(o,m||{},l)),[R]),d=h(async(o,m,l)=>(await R(),await U.readItem(o,m,l)),[R]),y=h(async(o,m,l)=>(await R(),await U.createItem(o,m,l)),[R]),O=h(async(o,m,l)=>(await R(),await U.updateItem(o,m,l)),[R]),A=h(async(o,m,l)=>(await R(),await U.deleteItem(o,m,l)),[R]),p=h(async(o,m)=>(await R(),await U.transaction(o,m)),[R]),u=h(async(o,m)=>{try{let l=await T(o,m);return l.success?{success:!0,data:l.tokens}:{success:!1,errors:l.error||"Login failed"}}catch(l){return{success:!1,errors:l instanceof Error?l.message:"Login failed"}}},[T]);return{readItems:E,readItem:d,createItem:y,updateItem:O,deleteItem:A,transaction:p,login:u,isInitialized:S,isInitializing:c,initializationError:N,isReady:I,waitForReady:a}};import{useCallback as C}from"react";import b from"@nocios/crudify-browser";var Y={INVALID_CREDENTIALS:"warning",UNAUTHORIZED:"warning",INVALID_API_KEY:"error",USER_NOT_FOUND:"warning",USER_NOT_ACTIVE:"warning",NO_PERMISSION:"warning",ITEM_NOT_FOUND:"info",NOT_FOUND:"info",IN_USE:"warning",FIELD_ERROR:"warning",BAD_REQUEST:"warning",INTERNAL_SERVER_ERROR:"error",DATABASE_CONNECTION_ERROR:"error",INVALID_CONFIGURATION:"error",UNKNOWN_OPERATION:"error",TOO_MANY_REQUESTS:"warning"},v={INVALID_CREDENTIALS:"errors.auth.INVALID_CREDENTIALS",UNAUTHORIZED:"errors.auth.UNAUTHORIZED",INVALID_API_KEY:"errors.auth.INVALID_API_KEY",USER_NOT_FOUND:"errors.auth.USER_NOT_FOUND",USER_NOT_ACTIVE:"errors.auth.USER_NOT_ACTIVE",NO_PERMISSION:"errors.auth.NO_PERMISSION",ITEM_NOT_FOUND:"errors.data.ITEM_NOT_FOUND",NOT_FOUND:"errors.data.NOT_FOUND",IN_USE:"errors.data.IN_USE",FIELD_ERROR:"errors.data.FIELD_ERROR",BAD_REQUEST:"errors.data.BAD_REQUEST",INTERNAL_SERVER_ERROR:"errors.system.INTERNAL_SERVER_ERROR",DATABASE_CONNECTION_ERROR:"errors.system.DATABASE_CONNECTION_ERROR",INVALID_CONFIGURATION:"errors.system.INVALID_CONFIGURATION",UNKNOWN_OPERATION:"errors.system.UNKNOWN_OPERATION",TOO_MANY_REQUESTS:"errors.system.TOO_MANY_REQUESTS"},le=(S={})=>{let{showNotification:c}=$(),{showSuccessNotifications:N=!1,showErrorNotifications:g=!0,customErrorMessages:T={},defaultErrorMessage:I="Ha ocurrido un error inesperado",autoHideDuration:a=6e3,appStructure:R=[],translateFn:E=e=>e}=S,d=C(e=>!(!e.success&&e.errors&&(Object.keys(e.errors).some(r=>r!=="_error"&&r!=="_graphql"&&r!=="_transaction")||e.errors._transaction?.includes("ONE_OR_MORE_OPERATIONS_FAILED")||e.errors._error?.includes("TOO_MANY_REQUESTS"))||!e.success&&e.data?.response?.status==="TOO_MANY_REQUESTS"),[]),y=C((e,i)=>{let r=E(e);return r===e?i||E("error.unknown"):r},[E]),O=C(e=>["create","update","delete"].includes(e),[]),A=C((e,i)=>N?O(e)&&i?!0:R.some(r=>r.key===e):!1,[N,R,O]),p=C((e,i,r)=>{let t=r?.key&&typeof r.key=="string"?r.key:e,s=`action.onSuccess.${t}`,n=y(s);if(n!==E("error.unknown")){if(O(t)&&i){let f=`action.${i}Singular`,_=y(f);if(_!==E("error.unknown"))return E(s,{item:_});{let M=`action.onSuccess.${t}WithoutItem`,k=y(M);return k!==E("error.unknown")?k:n}}return n}return E("success.transaction")},[y,E,O]),u=C(e=>{if(e.errorCode&&T[e.errorCode])return T[e.errorCode];if(e.errorCode&&v[e.errorCode])return y(v[e.errorCode]);if(e.errorCode){let i=[`errors.auth.${e.errorCode}`,`errors.data.${e.errorCode}`,`errors.system.${e.errorCode}`,`errors.${e.errorCode}`];for(let r of i){let t=y(r);if(t!==E("error.unknown"))return t}}if(typeof e.data=="string"&&e.data.startsWith("errors.")){let i=y(e.data);if(i!==E("error.unknown"))return i}if(e.errors&&Object.keys(e.errors).length>0){let i=Object.keys(e.errors);if(i.length===1&&i[0]==="_transaction"){let r=e.errors._transaction;if(r?.includes("ONE_OR_MORE_OPERATIONS_FAILED"))return"";if(Array.isArray(r)&&r.length>0){let t=r[0];if(typeof t=="string"&&t!=="ONE_OR_MORE_OPERATIONS_FAILED")try{let s=JSON.parse(t);if(Array.isArray(s)&&s.length>0){let n=s[0];if(n?.response?.errorCode){let f=n.response.errorCode;if(v[f])return y(v[f]);let _=[`errors.auth.${f}`,`errors.data.${f}`,`errors.system.${f}`,`errors.${f}`];for(let M of _){let k=y(M);if(k!==y("error.unknown"))return k}}if(n?.response?.data)return n.response.data}if(s?.response?.message){let n=s.response.message.toLowerCase();return n.includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):n.includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):s.response.message}}catch{return t.toLowerCase().includes("expired")?y("resetPassword.linkExpired","El enlace ha expirado"):t.toLowerCase().includes("invalid")?y("resetPassword.invalidCode","C\xF3digo inv\xE1lido"):t}}return y("error.transaction","Error en la operaci\xF3n")}if(i.length===1&&i[0]==="_error"){let r=e.errors._error;return Array.isArray(r)?r[0]:String(r)}return i.length===1&&i[0]==="_graphql"?y("errors.system.DATABASE_CONNECTION_ERROR"):`${y("errors.data.FIELD_ERROR")}: ${i.join(", ")}`}return I||E("error.unknown")},[T,I,E,y]),o=C(e=>e.errorCode&&Y[e.errorCode]?Y[e.errorCode]:"error",[]),m=C(async(e,i,r)=>{let t=await b.createItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"create",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),l=C(async(e,i,r)=>{let t=await b.updateItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"update",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),L=C(async(e,i,r)=>{let t=await b.deleteItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}else if(t.success){let s=r?.actionConfig,n=s?.key||"delete",f=s?.moduleKey||e;if(A(n,f)){let _=p(n,f,s);c(_,"success",{autoHideDuration:a})}}return t},[g,A,c,u,o,p,a,d]),P=C(async(e,i,r)=>{let t=await b.readItem(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}return t},[g,c,u,o,a,d]),w=C(async(e,i,r)=>{let t=await b.readItems(e,i,r);if(!t.success&&g&&d(t)){let s=u(t),n=o(t);c(s,n,{autoHideDuration:a})}return t},[g,c,u,o,a,d]),V=C(async(e,i)=>{let r=await b.transaction(e,i),t=i?.skipNotifications===!0;if(!t&&!r.success&&g&&d(r)){let s=u(r),n=o(r);c(s,n,{autoHideDuration:a})}else if(!t&&r.success){let s="transaction",n,f=null;if(i?.actionConfig?(f=i.actionConfig,s=f.key,n=f.moduleKey):Array.isArray(e)&&e.length>0&&e[0].operation&&(s=e[0].operation,f=R.find(_=>_.key===s),f&&(n=f.moduleKey)),A(s,n)){let _=p(s,n,f);c(_,"success",{autoHideDuration:a})}}return r},[g,A,c,u,o,p,a,d,R]),x=C((e,i)=>{if(!e.success&&g&&d(e)){let r=u(e),t=o(e);c(r,t,{autoHideDuration:a})}else e.success&&N&&i&&c(i,"success",{autoHideDuration:a});return e},[g,N,c,u,o,a,d,E]);return{createItem:m,updateItem:l,deleteItem:L,readItem:P,readItems:w,transaction:V,handleResponse:x,getErrorMessage:u,getErrorSeverity:o,shouldShowNotification:d}};export{G as a,ee as b,oe as c,le as d};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as w,b as M,f as G,g as Y}from"./chunk-YS3C7YG5.mjs";import P from"crypto-js";var s=class s{static setStorageType(e){s.storageType=e}static generateEncryptionKey(){let e=[navigator.userAgent,navigator.language,navigator.platform,screen.width,screen.height,Date.now().toString(),Math.random().toString(36)].join("|");return P.SHA256(e).toString()}static getEncryptionKey(){if(s.encryptionKey)return s.encryptionKey;let e=window.localStorage;if(!e)return s.encryptionKey=s.generateEncryptionKey(),s.encryptionKey;try{let t=e.getItem(s.ENCRYPTION_KEY_STORAGE);return(!t||t.length<32)&&(t=s.generateEncryptionKey(),e.setItem(s.ENCRYPTION_KEY_STORAGE,t)),s.encryptionKey=t,t}catch{return console.warn("Crudify: Cannot persist encryption key, using temporary key"),s.encryptionKey=s.generateEncryptionKey(),s.encryptionKey}}static isStorageAvailable(e){try{let t=window[e],r="__storage_test__";return t.setItem(r,"test"),t.removeItem(r),!0}catch{return!1}}static getStorage(){return s.storageType==="none"?null:s.isStorageAvailable(s.storageType)?window[s.storageType]:(console.warn(`Crudify: ${s.storageType} not available, tokens won't persist`),null)}static encrypt(e){try{let t=s.getEncryptionKey();return P.AES.encrypt(e,t).toString()}catch(t){return console.error("Crudify: Encryption failed",t),e}}static decrypt(e){try{let t=s.getEncryptionKey();return P.AES.decrypt(e,t).toString(P.enc.Utf8)||e}catch(t){return console.error("Crudify: Decryption failed",t),e}}static saveTokens(e){let t=s.getStorage();if(t)try{let r={accessToken:e.accessToken,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt,savedAt:Date.now()},i=s.encrypt(JSON.stringify(r));t.setItem(s.TOKEN_KEY,i),console.debug("Crudify: Tokens saved successfully")}catch(r){console.error("Crudify: Failed to save tokens",r)}}static getTokens(){let e=s.getStorage();if(!e)return null;try{let t=e.getItem(s.TOKEN_KEY);if(!t)return null;let r=s.decrypt(t),i=JSON.parse(r);return!i.accessToken||!i.refreshToken||!i.expiresAt||!i.refreshExpiresAt?(console.warn("Crudify: Incomplete token data found, clearing storage"),s.clearTokens(),null):Date.now()>=i.refreshExpiresAt?(console.info("Crudify: Refresh token expired, clearing storage"),s.clearTokens(),null):{accessToken:i.accessToken,refreshToken:i.refreshToken,expiresAt:i.expiresAt,refreshExpiresAt:i.refreshExpiresAt}}catch(t){return console.error("Crudify: Failed to retrieve tokens",t),s.clearTokens(),null}}static clearTokens(){let e=s.getStorage();if(e)try{e.removeItem(s.TOKEN_KEY),console.debug("Crudify: Tokens cleared from storage")}catch(t){console.error("Crudify: Failed to clear tokens",t)}}static rotateEncryptionKey(){try{s.clearTokens(),s.encryptionKey=null;let e=window.localStorage;e&&e.removeItem(s.ENCRYPTION_KEY_STORAGE),console.info("Crudify: Encryption key rotated successfully")}catch(e){console.error("Crudify: Failed to rotate encryption key",e)}}static hasValidTokens(){return s.getTokens()!==null}static getExpirationInfo(){let e=s.getTokens();if(!e)return null;let t=Date.now();return{accessExpired:t>=e.expiresAt,refreshExpired:t>=e.refreshExpiresAt,accessExpiresIn:Math.max(0,e.expiresAt-t),refreshExpiresIn:Math.max(0,e.refreshExpiresAt-t)}}static updateAccessToken(e,t){let r=s.getTokens();if(!r){console.warn("Crudify: Cannot update access token, no existing tokens found");return}s.saveTokens({...r,accessToken:e,expiresAt:t})}};s.TOKEN_KEY="crudify_tokens",s.ENCRYPTION_KEY_STORAGE="crudify_enc_key",s.encryptionKey=null,s.storageType="localStorage";var g=s;import A from"@nocios/crudify-browser";var L=class n{constructor(){this.config={};this.initialized=!1}static getInstance(){return n.instance||(n.instance=new n),n.instance}async initialize(e={}){if(this.initialized){console.warn("SessionManager: Already initialized");return}this.config={storageType:"localStorage",autoRestore:!0,enableLogging:!1,...e},g.setStorageType(this.config.storageType||"localStorage"),this.config.enableLogging,this.config.autoRestore&&await this.restoreSession(),this.initialized=!0,this.log("SessionManager initialized successfully")}async login(e,t){try{this.log("Attempting login...");let r=await A.login(e,t);if(!r.success)return this.log("Login failed:",r.errors),{success:!1,error:this.formatError(r.errors),rawResponse:r};let i={accessToken:r.data.token,refreshToken:r.data.refreshToken,expiresAt:r.data.expiresAt,refreshExpiresAt:r.data.refreshExpiresAt};return g.saveTokens(i),this.log("Login successful, tokens saved"),this.config.onLoginSuccess?.(i),{success:!0,tokens:i,data:r.data}}catch(r){return this.log("Login error:",r),{success:!1,error:r instanceof Error?r.message:"Unknown error"}}}async logout(){try{this.log("Logging out..."),await A.logout(),g.clearTokens(),this.log("Logout successful"),this.config.onLogout?.()}catch(e){this.log("Logout error:",e),g.clearTokens()}}async restoreSession(){try{this.log("Attempting to restore session...");let e=g.getTokens();if(!e)return this.log("No valid tokens found in storage"),!1;A.setTokens({accessToken:e.accessToken,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt});try{if(!A.isLogin())return this.log("Restored tokens are invalid, clearing storage"),g.clearTokens(),!1}catch(t){return this.log("Token validation failed:",t),g.clearTokens(),!1}return this.log("Session restored successfully"),this.config.onSessionRestored?.(e),!0}catch(e){return this.log("Session restore error:",e),g.clearTokens(),!1}}isAuthenticated(){return A.isLogin()||g.hasValidTokens()}getTokenInfo(){let e=A.getTokenData(),t=g.getExpirationInfo();return{isLoggedIn:this.isAuthenticated(),crudifyTokens:e,storageInfo:t,hasValidTokens:g.hasValidTokens()}}async refreshTokens(){try{this.log("Manually refreshing tokens...");let e=await A.refreshAccessToken();if(!e.success)return this.log("Token refresh failed:",e.errors),g.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),!1;let t={accessToken:e.data.token,refreshToken:e.data.refreshToken,expiresAt:e.data.expiresAt,refreshExpiresAt:e.data.refreshExpiresAt};return g.saveTokens(t),this.log("Tokens refreshed and saved successfully"),!0}catch(e){return this.log("Token refresh error:",e),g.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),!1}}setupResponseInterceptor(){A.setResponseInterceptor(async e=>{let t=this.detectAuthorizationError(e);if(t.isAuthError){if(console.warn("\u{1F6A8} SessionManager - Authorization error detected:",{errorType:t.errorType,errorDetails:t.errorDetails,fullResponse:e}),t.isRefreshTokenInvalid||t.isTokenRefreshFailed)return this.log("Refresh token invalid or refresh already failed, clearing session"),g.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.(),e;g.hasValidTokens()&&!t.isIrrecoverable?(this.log("Auth error detected, attempting token refresh..."),await this.refreshTokens()||(this.log("Token refresh failed, triggering session expired"),this.config.onSessionExpired?.())):(this.log("Auth error with no valid tokens or irrecoverable error, triggering session expired"),g.clearTokens(),this.config.showNotification?.(this.getSessionExpiredMessage(),"warning"),this.config.onSessionExpired?.())}return e}),this.log("Response interceptor configured")}detectAuthorizationError(e){let t={isAuthError:!1,isRefreshTokenInvalid:!1,isTokenRefreshFailed:!1,isIrrecoverable:!1,errorType:"",errorDetails:null};if(e.errors){if(Array.isArray(e.errors))e.errors.some(i=>i.errorType==="Unauthorized"||i.message?.includes("Unauthorized")||i.message?.includes("Not Authorized")||i.message?.includes("Token")||i.extensions?.code==="UNAUTHENTICATED"||i.message?.includes("NOT_AUTHORIZED"))&&(t.isAuthError=!0,t.errorType="GraphQL Array Format",t.errorDetails=e.errors);else if(typeof e.errors=="object"){let r=Object.values(e.errors).flat();r.some(l=>typeof l=="string"&&(l.includes("NOT_AUTHORIZED")||l.includes("TOKEN_REFRESH_FAILED")||l.includes("PLEASE_LOGIN")||l.includes("Unauthorized")||l.includes("UNAUTHENTICATED")||l.includes("Token")))&&(t.isAuthError=!0,t.errorType="GraphQL Object Format",t.errorDetails=e.errors,t.isTokenRefreshFailed=r.some(l=>typeof l=="string"&&l.includes("TOKEN_REFRESH_FAILED")))}}if(!t.isAuthError&&e.data?.response?.status==="UNAUTHORIZED"&&(t.isAuthError=!0,t.errorType="Status UNAUTHORIZED",t.errorDetails=e.data.response,t.isIrrecoverable=!0),!t.isAuthError&&e.data?.response?.data)try{let r=JSON.parse(e.data.response.data);(r.error==="REFRESH_TOKEN_INVALID"||r.error==="TOKEN_EXPIRED")&&(t.isAuthError=!0,t.errorType="Parsed Data Format",t.errorDetails=r,t.isRefreshTokenInvalid=!0,t.isIrrecoverable=!0)}catch{}if(!t.isAuthError&&e.errorCode){let r=e.errorCode;(r==="UNAUTHORIZED"||r==="UNAUTHENTICATED"||r==="TOKEN_EXPIRED")&&(t.isAuthError=!0,t.errorType="Error Code Format",t.errorDetails={errorCode:r})}return t}clearSession(){g.clearTokens(),A.logout(),this.log("Session cleared completely")}getSessionExpiredMessage(){return this.config.translateFn?M("SESSION_EXPIRED",{translateFn:this.config.translateFn,enableDebug:this.config.enableLogging}):"Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."}log(e,...t){this.config.enableLogging&&console.log(`[SessionManager] ${e}`,...t)}formatError(e){return e?typeof e=="string"?e:typeof e=="object"?Object.values(e).flat().join(", "):"Authentication failed":"Unknown error"}};import{useState as _,useEffect as ee,useCallback as D}from"react";function V(n={}){let[e,t]=_({isAuthenticated:!1,isLoading:!0,isInitialized:!1,tokens:null,error:null}),r=L.getInstance(),i=D(async()=>{try{t(a=>({...a,isLoading:!0,error:null}));let c={autoRestore:n.autoRestore??!0,enableLogging:n.enableLogging??!1,showNotification:n.showNotification,translateFn:n.translateFn,onSessionExpired:()=>{t(a=>({...a,isAuthenticated:!1,tokens:null,error:"Session expired"})),n.onSessionExpired?.()},onSessionRestored:a=>{t(d=>({...d,isAuthenticated:!0,tokens:a,error:null})),n.onSessionRestored?.(a)},onLoginSuccess:a=>{t(d=>({...d,isAuthenticated:!0,tokens:a,error:null}))},onLogout:()=>{t(a=>({...a,isAuthenticated:!1,tokens:null,error:null}))}};await r.initialize(c),r.setupResponseInterceptor();let f=r.isAuthenticated(),o=r.getTokenInfo();t(a=>({...a,isAuthenticated:f,isInitialized:!0,isLoading:!1,tokens:o.crudifyTokens.accessToken?{accessToken:o.crudifyTokens.accessToken,refreshToken:o.crudifyTokens.refreshToken,expiresAt:o.crudifyTokens.expiresAt,refreshExpiresAt:o.crudifyTokens.refreshExpiresAt}:null}))}catch(c){let f=c instanceof Error?c.message:"Initialization failed";t(o=>({...o,isLoading:!1,isInitialized:!0,error:f}))}},[n.autoRestore,n.enableLogging,n.onSessionExpired,n.onSessionRestored]),l=D(async(c,f)=>{t(o=>({...o,isLoading:!0,error:null}));try{let o=await r.login(c,f);return o.success&&o.tokens?t(a=>({...a,isAuthenticated:!0,tokens:o.tokens,isLoading:!1,error:null})):t(a=>({...a,isAuthenticated:!1,tokens:null,isLoading:!1,error:null})),o}catch(o){let a=o instanceof Error?o.message:"Login failed",d=a.includes("INVALID_CREDENTIALS")||a.includes("Invalid email")||a.includes("Invalid password")||a.includes("credentials");return t(k=>({...k,isAuthenticated:!1,tokens:null,isLoading:!1,error:d?null:a})),{success:!1,error:a}}},[r]),E=D(async()=>{t(c=>({...c,isLoading:!0}));try{await r.logout(),t(c=>({...c,isAuthenticated:!1,tokens:null,isLoading:!1,error:null}))}catch(c){t(f=>({...f,isAuthenticated:!1,tokens:null,isLoading:!1,error:c instanceof Error?c.message:"Logout error"}))}},[r]),p=D(async()=>{try{let c=await r.refreshTokens();if(c){let f=r.getTokenInfo();t(o=>({...o,tokens:f.crudifyTokens.accessToken?{accessToken:f.crudifyTokens.accessToken,refreshToken:f.crudifyTokens.refreshToken,expiresAt:f.crudifyTokens.expiresAt,refreshExpiresAt:f.crudifyTokens.refreshExpiresAt}:null,error:null}))}else t(f=>({...f,isAuthenticated:!1,tokens:null,error:"Token refresh failed"}));return c}catch(c){return t(f=>({...f,isAuthenticated:!1,tokens:null,error:c instanceof Error?c.message:"Token refresh failed"})),!1}},[r]),b=D(()=>{t(c=>({...c,error:null}))},[]),y=D(()=>r.getTokenInfo(),[r]);return ee(()=>{i()},[i]),{...e,login:l,logout:E,refreshTokens:p,clearError:b,getTokenInfo:y,isExpiringSoon:e.tokens?e.tokens.expiresAt-Date.now()<300*1e3:!1,expiresIn:e.tokens?Math.max(0,e.tokens.expiresAt-Date.now()):0,refreshExpiresIn:e.tokens?Math.max(0,e.tokens.refreshExpiresAt-Date.now()):0}}import{useState as j,createContext as te,useContext as re,useCallback as O,useEffect as oe}from"react";import{Snackbar as ne,Alert as ie,Box as se,Portal as ae}from"@mui/material";import{v4 as le}from"uuid";import ce from"dompurify";import{jsx as N,jsxs as de}from"react/jsx-runtime";var W=te(null),ue=n=>ce.sanitize(n,{ALLOWED_TAGS:["b","i","em","strong","br","span"],ALLOWED_ATTR:["class"],FORBID_TAGS:["script","iframe","object","embed"],FORBID_ATTR:["onload","onerror","onclick","onmouseover","onfocus","onblur"],WHOLE_DOCUMENT:!1,RETURN_DOM:!1,RETURN_DOM_FRAGMENT:!1,RETURN_TRUSTED_TYPE:!1}),B=({children:n,maxNotifications:e=5,defaultAutoHideDuration:t=6e3,position:r={vertical:"top",horizontal:"right"},enabled:i=!1,allowHtml:l=!1})=>{let[E,p]=j([]),b=O((o,a="info",d)=>{if(!i)return"";if(!o||typeof o!="string")return console.warn("\u26A0\uFE0F GlobalNotificationProvider: Invalid message provided"),"";o.length>1e3&&(console.warn("\u26A0\uFE0F GlobalNotificationProvider: Message too long, truncating"),o=o.substring(0,1e3)+"...");let k=le(),x={id:k,message:o,severity:a,autoHideDuration:d?.autoHideDuration??t,persistent:d?.persistent??!1,allowHtml:d?.allowHtml??l};return p(T=>[...T.length>=e?T.slice(-(e-1)):T,x]),k},[e,t,i,l]),y=O(o=>{p(a=>a.filter(d=>d.id!==o))},[]),c=O(()=>{p([])},[]),f={showNotification:b,hideNotification:y,clearAllNotifications:c};return de(W.Provider,{value:f,children:[n,i&&N(ae,{children:N(se,{sx:{position:"fixed",zIndex:9999,[r.vertical]:(r.vertical==="top",24),[r.horizontal]:r.horizontal==="right"||r.horizontal==="left"?24:"50%",...r.horizontal==="center"&&{transform:"translateX(-50%)"},display:"flex",flexDirection:r.vertical==="top"?"column":"column-reverse",gap:1,maxWidth:"400px",width:"auto"},children:E.map(o=>N(fe,{notification:o,onClose:()=>y(o.id)},o.id))})})]})},fe=({notification:n,onClose:e})=>{let[t,r]=j(!0),i=O((l,E)=>{E!=="clickaway"&&(r(!1),setTimeout(e,300))},[e]);return oe(()=>{if(!n.persistent&&n.autoHideDuration){let l=setTimeout(()=>{i()},n.autoHideDuration);return()=>clearTimeout(l)}},[n.autoHideDuration,n.persistent,i]),N(ne,{open:t,onClose:i,sx:{position:"relative","& .MuiSnackbarContent-root":{minWidth:"auto"}},TransitionProps:{enter:!0,exit:!0},children:N(ie,{variant:"filled",severity:n.severity,onClose:i,sx:{width:"100%",minWidth:"280px",maxWidth:"400px",wordBreak:"break-word"},children:n.allowHtml?N("span",{dangerouslySetInnerHTML:{__html:ue(n.message)}}):N("span",{children:n.message})})})},J=()=>{let n=re(W);if(!n)throw new Error("useGlobalNotification debe ser usado dentro de un GlobalNotificationProvider");return n};import ge,{createContext as pe,useContext as he,useMemo as Z}from"react";import{Fragment as H,jsx as h,jsxs as m}from"react/jsx-runtime";var X=pe(void 0);function ye({children:n,options:e={},config:t,showNotifications:r=!1,notificationOptions:i={}}){let l;try{let{showNotification:o}=J();l=o}catch{}let E=ge.useMemo(()=>({...e,showNotification:l,onSessionExpired:()=>{e.onSessionExpired?.()}}),[e,l]),p=V(E),b=Z(()=>{let o,a,d,k,x,T="unknown";if(t?.publicApiKey&&(o=t.publicApiKey,T="props"),t?.env&&(a=t.env),t?.appName&&(d=t.appName),t?.loginActions&&(k=t.loginActions),t?.logo&&(x=t.logo),!o){let R=w("publicApiKey"),S=w("environment"),I=w("appName"),v=w("loginActions"),u=w("logo");R&&(o=R,T="cookies"),S&&["dev","stg","prod"].includes(S)&&(a=S),I&&(d=decodeURIComponent(I)),v&&(k=decodeURIComponent(v).split(",").map(C=>C.trim()).filter(Boolean)),u&&(x=decodeURIComponent(u))}return{publicApiKey:o,env:a,appName:d,loginActions:k,logo:x}},[t]),y=Z(()=>{if(!p.tokens?.accessToken||!p.isAuthenticated)return null;try{let o=G(p.tokens.accessToken);if(o&&o.sub&&o.email&&o.subscriber){let a={_id:o.sub,email:o.email,subscriberKey:o.subscriber};return Object.keys(o).forEach(d=>{["sub","email","subscriber"].includes(d)||(a[d]=o[d])}),a}}catch(o){console.error("Error decoding JWT token for sessionData:",o)}return null},[p.tokens?.accessToken,p.isAuthenticated]),c={...p,sessionData:y,config:b},f={enabled:r,maxNotifications:i.maxNotifications||5,defaultAutoHideDuration:i.defaultAutoHideDuration||6e3,position:i.position||{vertical:"top",horizontal:"right"}};return h(X.Provider,{value:c,children:n})}function Be(n){let e={enabled:n.showNotifications,maxNotifications:n.notificationOptions?.maxNotifications||5,defaultAutoHideDuration:n.notificationOptions?.defaultAutoHideDuration||6e3,position:n.notificationOptions?.position||{vertical:"top",horizontal:"right"},allowHtml:n.notificationOptions?.allowHtml||!1};return h(B,{...e,children:h(ye,{...n})})}function $(){let n=he(X);if(n===void 0)throw new Error("useSessionContext must be used within a SessionProvider");return n}function Je({children:n,fallback:e=h("div",{children:"Please log in to access this content"}),redirectTo:t}){let{isAuthenticated:r,isLoading:i,isInitialized:l}=$();return!l||i?h("div",{children:"Loading..."}):r?h(H,{children:n}):t?(t(),null):h(H,{children:e})}function Ze(){let n=$();return n.isInitialized?m("div",{style:{padding:"10px",margin:"10px",border:"1px solid #ccc",borderRadius:"4px",fontSize:"12px",fontFamily:"monospace"},children:[h("h4",{children:"Session Debug Info"}),m("div",{children:[h("strong",{children:"Authenticated:"})," ",n.isAuthenticated?"Yes":"No"]}),m("div",{children:[h("strong",{children:"Loading:"})," ",n.isLoading?"Yes":"No"]}),m("div",{children:[h("strong",{children:"Error:"})," ",n.error||"None"]}),n.tokens&&m(H,{children:[m("div",{children:[h("strong",{children:"Access Token:"})," ",n.tokens.accessToken.substring(0,20),"..."]}),m("div",{children:[h("strong",{children:"Refresh Token:"})," ",n.tokens.refreshToken.substring(0,20),"..."]}),m("div",{children:[h("strong",{children:"Access Expires In:"})," ",Math.round(n.expiresIn/1e3/60)," minutes"]}),m("div",{children:[h("strong",{children:"Refresh Expires In:"})," ",Math.round(n.refreshExpiresIn/1e3/60/60)," hours"]}),m("div",{children:[h("strong",{children:"Expiring Soon:"})," ",n.isExpiringSoon?"Yes":"No"]})]})]}):h("div",{children:"Session not initialized"})}import{useState as U,useEffect as q,useCallback as Q,useRef as K}from"react";import ke from"@nocios/crudify-browser";var et=(n={})=>{let{autoFetch:e=!0,retryOnError:t=!1,maxRetries:r=3}=n,[i,l]=U(null),[E,p]=U(!1),[b,y]=U(null),[c,f]=U({}),o=K(null),a=K(!0),d=K(0),k=K(0),x=Q(()=>{l(null),y(null),p(!1),f({})},[]),T=Q(async()=>{let R=Y();if(!R){a.current&&(y("No user email available"),p(!1));return}o.current&&o.current.abort();let S=new AbortController;o.current=S;let I=++d.current;try{a.current&&(p(!0),y(null));let v=await ke.readItems("users",{filter:{email:R},pagination:{limit:1}});if(I===d.current&&a.current&&!S.signal.aborted)if(v.success&&v.data&&v.data.length>0){let u=v.data[0];l(u);let z={fullProfile:u,totalFields:Object.keys(u).length,displayData:{id:u.id,email:u.email,username:u.username,firstName:u.firstName,lastName:u.lastName,fullName:u.fullName||`${u.firstName||""} ${u.lastName||""}`.trim(),role:u.role,permissions:u.permissions||[],isActive:u.isActive,lastLogin:u.lastLogin,createdAt:u.createdAt,updatedAt:u.updatedAt,...Object.keys(u).filter(C=>!["id","email","username","firstName","lastName","fullName","role","permissions","isActive","lastLogin","createdAt","updatedAt"].includes(C)).reduce((C,F)=>({...C,[F]:u[F]}),{})}};f(z),y(null),k.current=0}else y("User profile not found"),l(null),f({})}catch(v){if(I===d.current&&a.current){let u=v;if(u.name==="AbortError")return;t&&k.current<r&&(u.message?.includes("Network Error")||u.message?.includes("Failed to fetch"))?(k.current++,setTimeout(()=>{a.current&&T()},1e3*k.current)):(y("Failed to load user profile"),l(null),f({}))}}finally{I===d.current&&a.current&&p(!1),o.current===S&&(o.current=null)}},[t,r]);return q(()=>{e&&T()},[e,T]),q(()=>(a.current=!0,()=>{a.current=!1,o.current&&(o.current.abort(),o.current=null)}),[]),{userProfile:i,loading:E,error:b,extendedData:c,refreshProfile:T,clearProfile:x}};export{g as a,L as b,V as c,B as d,J as e,Be as f,$ as g,Je as h,Ze as i,et as j};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{e as Qe,g as Q,j as Ze}from"./chunk-FBT222LR.mjs";import{g as z}from"./chunk-BJ6PIVZR.mjs";import{a as Je,e as Xe}from"./chunk-YS3C7YG5.mjs";import{Box as kr,Typography as Lr}from"@mui/material";import{createContext as $o,useContext as Ho,useMemo as oo}from"react";import{useState as Fe,useEffect as Mo}from"react";var eo=(e,t)=>{let[s,a]=Fe({}),[m,n]=Fe(!1),[i,p]=Fe(null);return Mo(()=>{if(console.log("\u{1F527} [I18nProvider] Hybrid translation loading:",{hasProvidedTranslations:!!t&&Object.keys(t).length>0,hasUrl:!!e,providedKeys:t?Object.keys(t).length:0}),t&&Object.keys(t).length>0){console.log("\u2705 [I18nProvider] Using provided translations (highest priority)"),a(t),n(!1),p(null);return}if(!e){console.log("\u26A0\uFE0F [I18nProvider] No translations provided, using empty object (keys will show as-is)"),a({}),n(!1),p(null);return}console.log("\u{1F310} [I18nProvider] Loading translations from URL:",e);let l=!1;return n(!0),p(null),fetch(e).then(y=>{if(!y.ok)throw new Error(`Failed to load translations: ${y.status}`);return y.json()}).then(y=>{l||(console.log("\u2705 [I18nProvider] Translations loaded successfully from URL:",{url:e,keysLoaded:Object.keys(y).length}),a(y),n(!1))}).catch(y=>{l||(console.error("\u274C [I18nProvider] Failed to load translations from URL:",e,y),p(y.message),console.log("\u{1F504} [I18nProvider] Falling back to empty translations (keys will show as-is)"),a({}),n(!1))}),()=>{l=!0}},[e,t]),{translations:s,loading:m,error:i}};import{jsx as ro}from"react/jsx-runtime";var to=$o(null),Ko=(e,t)=>e&&e[t]?e[t]:t.split(".").reduce((s,a)=>s&&typeof s=="object"?s[a]:void 0,e),no=({children:e,translations:t,translationsUrl:s,language:a="en"})=>{let{translations:m,loading:n}=eo(s,t),i=oo(()=>(l,y)=>{let c=Ko(m,l);return c==null&&(console.log(`\u{1F50D} [I18nProvider] Translation not found for key: "${l}" - showing key as-is`),c=l),y&&typeof c=="string"&&Object.entries(y).forEach(([x,d])=>{c=c.replace(new RegExp(`{{${x}}}`,"g"),d)}),typeof c=="string"?c:l},[m]),p=oo(()=>({t:i,language:a}),[i,a]);return n?ro("div",{children:"Loading translations..."}):ro(to.Provider,{value:p,children:e})},U=()=>{let e=Ho(to);if(!e)throw new Error("useTranslation must be used within I18nProvider");return e};import{createContext as jo,useContext as qo,useEffect as Go,useState as ve}from"react";import fe from"@nocios/crudify-browser";import{jsx as Yo}from"react/jsx-runtime";var io=jo(void 0),so=({config:e,children:t})=>{let[s,a]=ve(!0),[m,n]=ve(null),[i,p]=ve(!1),[l,y]=ve("");console.log("\u{1F50D} CrudifyProvider - Received config:",e),Go(()=>{if(console.log("\u{1F50D} CrudifyProvider - useEffect - config.publicApiKey:",e.publicApiKey),console.log("\u{1F50D} CrudifyProvider - useEffect - full config:",e),!e.publicApiKey){console.log("\u274C CrudifyProvider - No publicApiKey provided, setting error"),n("No publicApiKey provided"),a(!1),p(!1);return}console.log("\u2705 CrudifyProvider - publicApiKey found, proceeding with initialization");let x=`${e.publicApiKey}-${e.env}`;if(x===l&&i){a(!1);return}(async()=>{a(!0),n(null),p(!1);try{if(fe.config(e.env||"prod"),await fe.init(e.publicApiKey,"none"),typeof fe.transaction=="function"&&typeof fe.login=="function")p(!0),y(x);else throw new Error("Crudify methods not properly initialized")}catch(o){let r=o instanceof Error?o.message:"Failed to initialize Crudify";n(r),p(!1)}finally{a(!1)}})()},[e.publicApiKey,e.env,l,i]);let c={crudify:i?fe:null,isLoading:s,error:m,isInitialized:i};return Yo(io.Provider,{value:c,children:t})},q=()=>{let e=qo(io);if(e===void 0)throw new Error("useCrudify must be used within a CrudifyProvider");return e};import{createContext as Jo,useContext as Xo,useReducer as Qo,useEffect as ao}from"react";import{jsx as er}from"react/jsx-runtime";var lo={currentScreen:"login",searchParams:{},formData:{username:"",password:"",email:"",code:"",newPassword:"",confirmPassword:""},loading:!1,errors:{global:[]},emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1,config:{}};function Zo(e,t){switch(t.type){case"SET_SCREEN":let s={...e,currentScreen:t.payload.screen,searchParams:t.payload.params||e.searchParams,errors:{global:[]}},a=new URLSearchParams(s.searchParams),m=a.toString()?`?${a.toString()}`:window.location.pathname;try{window.history.replaceState({},"",m)}catch{}return s;case"SET_SEARCH_PARAMS":return{...e,searchParams:t.payload};case"UPDATE_FORM_DATA":return{...e,formData:{...e.formData,...t.payload},errors:{...e.errors,...Object.keys(t.payload).reduce((n,i)=>({...n,[i]:void 0}),{})}};case"SET_LOADING":return{...e,loading:t.payload};case"SET_ERRORS":return{...e,errors:{...e.errors,...t.payload}};case"CLEAR_ERRORS":return{...e,errors:{global:[]}};case"SET_EMAIL_SENT":return{...e,emailSent:t.payload};case"SET_CODE_ALREADY_EXISTS":return{...e,codeAlreadyExists:t.payload};case"SET_CODE_VALIDATED":return{...e,codeValidated:t.payload};case"SET_FROM_CODE_VERIFICATION":return{...e,fromCodeVerification:t.payload};case"RESET_FORM":return{...e,formData:lo.formData,errors:{global:[]},loading:!1,emailSent:!1,codeAlreadyExists:!1,codeValidated:!1,fromCodeVerification:!1};case"INIT_CONFIG":return{...e,config:t.payload};default:return e}}var co=Jo(void 0),uo=({children:e,initialScreen:t="login",config:s,autoReadFromCookies:a=!0})=>{let[m,n]=Qo(Zo,{...lo,currentScreen:t});ao(()=>{n({type:"INIT_CONFIG",payload:(()=>{let o={};if(a)try{let r=Je("logo");if(r){let u=decodeURIComponent(r);u.startsWith("http")&&(o.logo=u)}}catch(r){console.error("Error reading configuration from cookies:",r)}return{publicApiKey:s?.publicApiKey,env:s?.env,appName:s?.appName,logo:s?.logo||o.logo,loginActions:s?.loginActions}})()})},[s,a]),ao(()=>{let d=new URLSearchParams(window.location.search),o={};d.forEach((r,u)=>{o[u]=r}),Object.keys(o).length>0&&n({type:"SET_SEARCH_PARAMS",payload:o}),t==="checkCode"&&o.email&&n({type:"UPDATE_FORM_DATA",payload:{email:o.email,code:o.code||""}}),t==="resetPassword"&&o.link&&n({type:"SET_SEARCH_PARAMS",payload:o})},[t]);let x={state:m,dispatch:n,setScreen:(d,o)=>{n({type:"SET_SCREEN",payload:{screen:d,params:o}})},updateFormData:d=>{n({type:"UPDATE_FORM_DATA",payload:d})},setFieldError:(d,o)=>{n({type:"SET_ERRORS",payload:{[d]:o}})},clearErrors:()=>{n({type:"CLEAR_ERRORS"})},setLoading:d=>{n({type:"SET_LOADING",payload:d})}};return er(co.Provider,{value:x,children:e})},Te=()=>{let e=Xo(co);if(e===void 0)throw new Error("useLoginState must be used within a LoginStateProvider");return e};import{useEffect as or,useRef as rr}from"react";import{Typography as De,TextField as fo,Button as tr,Box as me,CircularProgress as nr,Alert as ir,Link as mo}from"@mui/material";import{Fragment as ar,jsx as M,jsxs as pe}from"react/jsx-runtime";var sr=({onScreenChange:e,onExternalNavigate:t,onLoginSuccess:s,onError:a,redirectUrl:m="/"})=>{let{crudify:n}=q(),{state:i,updateFormData:p,setFieldError:l,clearErrors:y,setLoading:c}=Te(),{login:x}=Q(),d=U(),{t:o}=d,r=d.i18n,u=rr(null),C=Xe(o,{currentLanguage:r?.language,enableDebug:!1}),P=()=>{if(i.searchParams.redirect)try{let g=decodeURIComponent(i.searchParams.redirect);if(g.startsWith("/")&&!g.startsWith("//"))return g}catch{}return m||"/"};or(()=>{let g=setTimeout(()=>{u.current&&u.current.focus()},100);return()=>clearTimeout(g)},[]);let f=g=>{console.log("\u{1F50D} [LoginForm] Translating parsed error:",g);let S=C.translateError({code:g.code,message:g.message,field:g.field});return console.log("\u{1F50D} [LoginForm] Translation result:",S),S},h=async()=>{if(!i.loading){if(!i.formData.username.trim()){l("username",o("login.usernameRequired"));return}if(!i.formData.password.trim()){l("password",o("login.passwordRequired"));return}y(),c(!0);try{let g=await x(i.formData.username,i.formData.password);if(c(!1),g.success){console.log("\u{1F510} LoginForm - Login successful via SessionProvider, calling onLoginSuccess");let S=P();s&&s(g.data,S)}else{let S=g.rawResponse||g;w(S)}}catch(g){c(!1);let J=z(g).map(f);l("global",J),a&&a(J.join(", "))}}},w=g=>{z(g).forEach(J=>{if(J.field)l(J.field,f(J));else{let de=i.errors.global||[];l("global",[...de,f(J)])}})};return pe(ar,{children:[pe(me,{component:"form",noValidate:!0,onSubmit:g=>{g.preventDefault(),h()},onKeyDown:g=>{g.key==="Enter"&&!i.loading&&(g.preventDefault(),h())},sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[pe(me,{sx:{mb:1},children:[M(De,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:o("login.usernameOrEmailLabel")}),M(fo,{fullWidth:!0,id:"email",name:"email",type:"email",value:i.formData.username,disabled:i.loading,onChange:g=>p({username:g.target.value}),error:!!i.errors.username,helperText:i.errors.username,autoComplete:"email",placeholder:o("login.usernameOrEmailPlaceholder"),inputRef:u,required:!0})]}),pe(me,{sx:{mb:1},children:[M(De,{variant:"body2",component:"label",htmlFor:"password",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:o("login.passwordLabel")}),M(fo,{fullWidth:!0,id:"password",name:"password",type:"password",value:i.formData.password,disabled:i.loading,onChange:g=>p({password:g.target.value}),error:!!i.errors.password,helperText:i.errors.password,autoComplete:"current-password",placeholder:o("login.passwordPlaceholder"),required:!0})]}),i.config.loginActions?.includes("forgotPassword")&&M(me,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center"},children:M(mo,{sx:{cursor:"pointer"},onClick:()=>{e?.("forgotPassword",i.searchParams)},variant:"body2",color:"secondary",children:o("login.forgotPasswordLink")})}),M(tr,{disabled:i.loading,type:"submit",fullWidth:!0,variant:"contained",color:"primary",sx:{mt:1,mb:2},children:i.loading?M(nr,{size:20}):o("login.loginButton")})]}),M(me,{children:i.errors.global&&i.errors.global.length>0&&i.errors.global.map((g,S)=>M(ir,{variant:"filled",sx:{mt:2},severity:"error",children:M("div",{children:g})},S))}),i.config.loginActions?.includes("createUser")&&pe(De,{variant:"body2",align:"center",sx:{color:"text.secondary",mt:3},children:[o("login.noAccountPrompt")," ",M(mo,{sx:{cursor:"pointer"},onClick:()=>{let S=`/public/users/create${Object.keys(i.searchParams).length>0?`?${new URLSearchParams(i.searchParams).toString()}`:""}`;t?.(S)},fontWeight:"medium",color:"secondary",children:o("login.signUpLink")})]})]})},po=sr;import{useState as ie}from"react";import{Typography as se,TextField as lr,Button as go,Box as Z,CircularProgress as cr,Alert as dr,Link as _e}from"@mui/material";import{Fragment as yo,jsx as B,jsxs as te}from"react/jsx-runtime";var ur=({onScreenChange:e,onError:t})=>{let{crudify:s}=q(),[a,m]=ie(""),[n,i]=ie(!1),[p,l]=ie([]),[y,c]=ie(null),[x,d]=ie(!1),[o,r]=ie(!1),{t:u}=U(),C=v=>{let E=[`errors.auth.${v.code}`,`errors.data.${v.code}`,`errors.system.${v.code}`,`errors.${v.code}`,`forgotPassword.${v.code.toLowerCase()}`];for(let g of E){let S=u(g);if(S!==g)return S}return v.message||u("error.unknown")},P=v=>/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(v),f=async()=>{if(!(n||!s)){if(l([]),c(null),!a){c(u("forgotPassword.emailRequired"));return}if(!P(a)){c(u("forgotPassword.invalidEmail"));return}i(!0);try{let v=[{operation:"requestPasswordReset",data:{email:a}}],E=await s.transaction(v);if(E.success)E.data&&E.data.existingCodeValid?r(!0):d(!0);else{let S=z(E).map(C);l(S)}}catch(v){let g=z(v).map(C);l(g),t&&t(g.join(", "))}finally{i(!1)}}},h=()=>{e?.("login")},w=()=>{if(x||o){e?.("checkCode",{email:a});return}if(!a){c(u("forgotPassword.emailRequired"));return}if(!P(a)){c(u("forgotPassword.invalidEmail"));return}e?.("checkCode",{email:a})};return x||o?B(yo,{children:te(Z,{sx:{width:"100%",display:"flex",flexDirection:"column",gap:2,textAlign:"center"},children:[te(Z,{sx:{mb:2},children:[B(se,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:u(o?"forgotPassword.codeAlreadyExistsMessage":"forgotPassword.emailSentMessage")}),B(se,{variant:"body2",sx:{color:o?"success.main":"grey.600"},children:u("forgotPassword.checkEmailInstructions")})]}),B(go,{type:"button",onClick:w,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:u("forgotPassword.enterCodeLink")}),B(Z,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:B(_e,{sx:{cursor:"pointer"},onClick:h,variant:"body2",color:"secondary",children:u("common.back")})})]})}):te(yo,{children:[te(Z,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[te(Z,{sx:{mb:2},children:[B(se,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:u("forgotPassword.title")}),B(se,{variant:"body2",sx:{color:"grey.600"},children:u("forgotPassword.instructions")})]}),te(Z,{sx:{mb:1},children:[B(se,{variant:"body2",component:"label",htmlFor:"email",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:u("forgotPassword.emailLabel")}),B(lr,{fullWidth:!0,id:"email",name:"email",type:"email",value:a,disabled:n,onChange:v=>m(v.target.value),error:!!y,helperText:y,autoComplete:"email",placeholder:u("forgotPassword.emailPlaceholder"),required:!0})]}),B(go,{disabled:n,type:"button",onClick:f,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:n?B(cr,{size:20}):u("forgotPassword.sendCodeButton")}),te(Z,{sx:{display:"flex",justifyContent:"center",alignItems:"center",gap:2},children:[B(_e,{sx:{cursor:"pointer"},onClick:h,variant:"body2",color:"secondary",children:u("common.back")}),B(se,{variant:"body2",sx:{color:"grey.400"},children:"\u2022"}),B(_e,{sx:{cursor:"pointer"},onClick:w,variant:"body2",color:"secondary",children:u("login.alreadyHaveCodeLink")})]})]}),B(Z,{children:p.length>0&&p.map((v,E)=>B(dr,{variant:"filled",sx:{mt:2},severity:"error",children:v},E))})]})},xo=ur;import{useState as V,useEffect as ho}from"react";import{Typography as Ee,TextField as bo,Button as fr,Box as ee,CircularProgress as wo,Alert as Co,Link as mr}from"@mui/material";import{Fragment as gr,jsx as F,jsxs as ge}from"react/jsx-runtime";var pr=({onScreenChange:e,onError:t,searchParams:s,onResetSuccess:a})=>{let{crudify:m}=q(),[n,i]=V(""),[p,l]=V(""),[y,c]=V(!1),[x,d]=V([]),[o,r]=V(null),[u,C]=V(null),[P,f]=V(""),[h,w]=V(""),[v,E]=V(!1),[g,S]=V(!0),[J,de]=V(!1),[we,Be]=V(null),[No,Ye]=V(!1),{t:I}=U(),Ce=T=>{let k=[`errors.auth.${T.code}`,`errors.data.${T.code}`,`errors.system.${T.code}`,`errors.${T.code}`,`resetPassword.${T.code.toLowerCase()}`];for(let O of k){let N=I(O);if(N!==O)return N}return T.message||I("error.unknown")},Pe=T=>s?s instanceof URLSearchParams?s.get(T):s[T]||null:null;ho(()=>{if(s){if(s){let T=Pe("fromCodeVerification"),k=Pe("email"),O=Pe("code");if(T==="true"&&k&&O){f(k),w(O),E(!0),de(!0),S(!1);return}let N=Pe("link");if(N)try{let $=decodeURIComponent(N),[H,ue]=$.split("/");if(H&&ue&&H.length===6){w(H),f(ue),E(!1),Be({email:ue,code:H});return}}catch{}if(k&&O){f(k),w(O),E(!1),Be({email:k,code:O});return}}d([I("resetPassword.invalidCode")]),S(!1),setTimeout(()=>e?.("forgotPassword"),3e3)}},[s,m,I,e]),ho(()=>{m&&we&&!No&&(Ye(!0),(async(k,O)=>{try{let N=[{operation:"validatePasswordResetCode",data:{email:k,codePassword:O}}],$=await m.transaction(N);if($.data&&Array.isArray($.data)){let H=$.data[0];if(H&&H.response&&H.response.status==="OK"){de(!0);return}}if($.success)de(!0);else{let ue=z($).map(Ce);d(ue),setTimeout(()=>e?.("forgotPassword"),3e3)}}catch(N){let H=z(N).map(Ce);d(H),setTimeout(()=>e?.("forgotPassword"),3e3)}finally{S(!1),Be(null),Ye(!1)}})(we.email,we.code))},[m,we,I,e]);let Vo=T=>T.length<8?I("resetPassword.passwordTooShort"):null,Wo=async()=>{if(y||!m)return;d([]),r(null),C(null);let T=!1;if(!n)r(I("resetPassword.newPasswordRequired")),T=!0;else{let k=Vo(n);k&&(r(k),T=!0)}if(p?n!==p&&(C(I("resetPassword.passwordsDoNotMatch")),T=!0):(C(I("resetPassword.confirmPasswordRequired")),T=!0),!T){c(!0);try{let k=[{operation:"validateAndResetPassword",data:{email:P,codePassword:h,newPassword:n}}],O=await m.transaction(k);if(O.success)d([]),setTimeout(()=>{a?.()},1e3);else{let $=z(O).map(Ce);d($)}}catch(k){let N=z(k).map(Ce);d(N),t&&t(N.join(", "))}c(!1)}},Uo=()=>{v?e?.("checkCode",{email:P}):e?.("forgotPassword")};return g?F(ee,{sx:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"300px"},children:F(wo,{})}):J?ge(gr,{children:[ge(ee,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[ge(ee,{sx:{mb:2},children:[F(Ee,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:I("resetPassword.title")}),F(Ee,{variant:"body2",sx:{color:"grey.600"},children:I("resetPassword.instructions")})]}),ge(ee,{sx:{mb:1},children:[F(Ee,{variant:"body2",component:"label",htmlFor:"newPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:I("resetPassword.newPasswordLabel")}),F(bo,{fullWidth:!0,id:"newPassword",name:"newPassword",type:"password",value:n,disabled:y,onChange:T=>i(T.target.value),error:!!o,helperText:o,autoComplete:"new-password",placeholder:I("resetPassword.newPasswordPlaceholder"),required:!0})]}),ge(ee,{sx:{mb:1},children:[F(Ee,{variant:"body2",component:"label",htmlFor:"confirmPassword",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:I("resetPassword.confirmPasswordLabel")}),F(bo,{fullWidth:!0,id:"confirmPassword",name:"confirmPassword",type:"password",value:p,disabled:y,onChange:T=>l(T.target.value),error:!!u,helperText:u,autoComplete:"new-password",placeholder:I("resetPassword.confirmPasswordPlaceholder"),required:!0})]}),F(fr,{disabled:y,type:"button",onClick:Wo,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:y?F(wo,{size:20}):I("resetPassword.resetPasswordButton")}),F(ee,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:F(mr,{sx:{cursor:"pointer"},onClick:Uo,variant:"body2",color:"secondary",children:I("common.back")})})]}),F(ee,{children:x.length>0&&x.map((T,k)=>F(Co,{variant:"filled",sx:{mt:2},severity:"error",children:T},k))})]}):F(ee,{children:x.length>0&&x.map((T,k)=>F(Co,{variant:"filled",sx:{mt:2},severity:"error",children:T},k))})},Po=pr;import{useState as ye,useEffect as yr}from"react";import{Typography as Oe,TextField as xr,Button as hr,Box as xe,CircularProgress as br,Alert as wr,Link as Cr}from"@mui/material";import{Fragment as vr,jsx as G,jsxs as Se}from"react/jsx-runtime";var Pr=({onScreenChange:e,onError:t,searchParams:s})=>{let{crudify:a}=q(),[m,n]=ye(""),[i,p]=ye(!1),[l,y]=ye([]),[c,x]=ye(null),[d,o]=ye(""),{t:r}=U(),u=w=>s?s instanceof URLSearchParams?s.get(w):s[w]||null:null,C=w=>{let v=[`errors.auth.${w.code}`,`errors.data.${w.code}`,`errors.system.${w.code}`,`errors.${w.code}`,`checkCode.${w.code.toLowerCase()}`];for(let E of v){let g=r(E);if(g!==E)return g}return w.message||r("error.unknown")};yr(()=>{let w=u("email");w?o(w):e?.("forgotPassword")},[s,e]);let P=async()=>{if(!(i||!a)){if(y([]),x(null),!m){x(r("checkCode.codeRequired"));return}if(m.length!==6){x(r("checkCode.codeRequired"));return}p(!0);try{let w=[{operation:"validatePasswordResetCode",data:{email:d,codePassword:m}}],v=await a.transaction(w);if(v.success)e?.("resetPassword",{email:d,code:m,fromCodeVerification:"true"});else{let g=z(v).map(C);y(g),p(!1)}}catch(w){let E=z(w).map(C);y(E),p(!1),t&&t(E.join(", "))}}},f=()=>{e?.("forgotPassword")},h=w=>{let v=w.target.value.replace(/\D/g,"").slice(0,6);n(v)};return Se(vr,{children:[Se(xe,{component:"form",noValidate:!0,sx:{width:"100%",display:"flex",flexDirection:"column",gap:2},children:[Se(xe,{sx:{mb:2},children:[G(Oe,{variant:"h5",component:"h1",sx:{mb:1,fontWeight:600},children:r("checkCode.title")}),G(Oe,{variant:"body2",sx:{color:"grey.600"},children:r("checkCode.instructions")})]}),Se(xe,{sx:{mb:1},children:[G(Oe,{variant:"body2",component:"label",htmlFor:"code",sx:{display:"block",fontWeight:500,color:"grey.700",mb:.5},children:r("checkCode.codeLabel")}),G(xr,{fullWidth:!0,id:"code",name:"code",type:"text",value:m,disabled:i,onChange:h,error:!!c,helperText:c,placeholder:r("checkCode.codePlaceholder"),inputProps:{maxLength:6,style:{textAlign:"center",fontSize:"1.5rem",letterSpacing:"0.4rem"}},required:!0})]}),G(hr,{disabled:i||m.length!==6,type:"button",onClick:P,fullWidth:!0,variant:"contained",color:"primary",sx:{mt:2,mb:2},children:i?G(br,{size:20}):r("checkCode.verifyButton")}),G(xe,{sx:{display:"flex",justifyContent:"center",alignItems:"center"},children:G(Cr,{sx:{cursor:"pointer"},onClick:f,variant:"body2",color:"secondary",children:r("common.back")})})]}),G(xe,{children:l.length>0&&l.map((w,v)=>G(wr,{sx:{mt:2},severity:"error",children:w},v))})]})},vo=Pr;import{Box as Tr,CircularProgress as Er,Alert as To,Typography as ze}from"@mui/material";import{Fragment as Sr,jsx as ae,jsxs as Eo}from"react/jsx-runtime";var So=({children:e,fallback:t})=>{let{isLoading:s,error:a,isInitialized:m}=q(),{t:n}=U();return s?t||Eo(Tr,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"200px",gap:2},children:[ae(Er,{}),ae(ze,{variant:"body2",color:"text.secondary",children:n("login.initializing")!=="login.initializing"?n("login.initializing"):"Initializing..."})]}):a?ae(To,{severity:"error",sx:{mt:2},children:Eo(ze,{variant:"body2",children:[n("login.initializationError")!=="login.initializationError"?n("login.initializationError"):"Initialization error",":"," ",a]})}):m?ae(Sr,{children:e}):ae(To,{severity:"warning",sx:{mt:2},children:ae(ze,{variant:"body2",children:n("login.notInitialized")!=="login.notInitialized"?n("login.notInitialized"):"System not initialized"})})};import{jsx as K,jsxs as Ir}from"react/jsx-runtime";var Rr=({onScreenChange:e,onExternalNavigate:t,onLoginSuccess:s,onError:a,redirectUrl:m="/"})=>{let{t:n}=U(),{state:i,setScreen:p}=Te(),{config:l}=Q(),{showNotification:y}=Qe(),c=(d,o)=>{let r=o;d==="login"?r={}:d==="forgotPassword"&&!o&&(r={}),p(d,r),e?.(d,r)},x=()=>{let d={onScreenChange:c,onExternalNavigate:t,onError:a,redirectUrl:m};switch(i.currentScreen){case"forgotPassword":return K(xo,{...d});case"checkCode":return K(vo,{...d,searchParams:i.searchParams});case"resetPassword":return K(Po,{...d,searchParams:i.searchParams,onResetSuccess:()=>{let o=n("resetPassword.successMessage");y(o,"success"),c("login")}});default:return K(po,{...d,onLoginSuccess:s})}};return Ir(So,{children:[K(kr,{sx:{display:"flex",justifyContent:"center",mb:3},children:K("img",{src:l.logo||"/nocios-default.png",alt:n("login.logoAlt"),style:{width:"100%",maxWidth:"150px",height:"auto"},onError:d=>{let o=d.target;o.src="/nocios-default.png"}})}),!l.logo&&l.appName&&K(Lr,{variant:"h6",component:"h1",sx:{textAlign:"center",mb:2},children:l.appName}),x()]})},Ar=({translations:e,translationsUrl:t,language:s="en",initialScreen:a="login",autoReadFromCookies:m=!0,...n})=>{let{config:i}=Q();return K(no,{translations:e,translationsUrl:t,language:s,children:K(so,{config:i,children:K(uo,{config:i,initialScreen:a,autoReadFromCookies:m,children:K(Rr,{...n})})})})},Wn=Ar;import{Box as W,Card as ko,CardContent as Lo,Typography as j,Chip as ke,Avatar as Br,Divider as Fr,CircularProgress as Dr,Alert as Ro,List as _r,ListItem as Ne,ListItemText as Ve,ListItemIcon as Or,Collapse as zr,IconButton as We}from"@mui/material";import{Person as Nr,Email as Vr,Badge as Wr,Security as Ur,Schedule as Mr,AccountCircle as $r,ExpandMore as Hr,ExpandLess as Kr,Info as jr}from"@mui/icons-material";import{useState as qr}from"react";import{Fragment as Jr,jsx as b,jsxs as L}from"react/jsx-runtime";var Gr=({showExtendedData:e=!0,showProfileCard:t=!0,autoRefresh:s=!0})=>{let{userProfile:a,loading:m,error:n,extendedData:i,refreshProfile:p}=Ze({autoFetch:s,retryOnError:!0,maxRetries:3}),[l,y]=qr(!1);if(m)return L(W,{display:"flex",justifyContent:"center",alignItems:"center",p:3,children:[b(Dr,{}),b(j,{variant:"body2",sx:{ml:2},children:"Cargando perfil de usuario..."})]});if(n)return L(Ro,{severity:"error",action:b(We,{color:"inherit",size:"small",onClick:p,children:b(j,{variant:"caption",children:"Reintentar"})}),children:["Error al cargar el perfil: ",n]});if(!a)return b(Ro,{severity:"warning",children:"No se encontr\xF3 informaci\xF3n del usuario"});let c=i?.displayData||{},x=i?.totalFields||0,d=f=>{if(!f)return"No disponible";try{return new Date(f).toLocaleString("es-ES",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return f}},o=(f,h)=>h==null?"No disponible":typeof h=="boolean"?h?"S\xED":"No":Array.isArray(h)?h.length>0?h.join(", "):"Ninguno":typeof h=="object"?JSON.stringify(h,null,2):String(h),r=[{key:"id",label:"ID",icon:b(Wr,{})},{key:"email",label:"Email",icon:b(Vr,{})},{key:"username",label:"Usuario",icon:b(Nr,{})},{key:"fullName",label:"Nombre completo",icon:b($r,{})},{key:"role",label:"Rol",icon:b(Ur,{})}],u=[{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"}],C=[...r.map(f=>f.key),...u.map(f=>f.key),"permissions"],P=Object.keys(c).filter(f=>!C.includes(f)).map(f=>({key:f,label:f}));return L(W,{children:[t&&b(ko,{sx:{mb:2},children:L(Lo,{children:[L(W,{display:"flex",alignItems:"center",mb:2,children:[b(Br,{src:c.avatar,sx:{width:56,height:56,mr:2},children:c.fullName?.[0]||c.username?.[0]||c.email?.[0]}),L(W,{children:[b(j,{variant:"h6",children:c.fullName||c.username||c.email}),b(j,{variant:"body2",color:"text.secondary",children:c.role||"Usuario"}),c.isActive!==void 0&&b(ke,{label:c.isActive?"Activo":"Inactivo",color:c.isActive?"success":"error",size:"small",sx:{mt:.5}})]})]}),b(W,{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(250px, 1fr))",gap:2,children:r.map(({key:f,label:h,icon:w})=>c[f]?L(W,{display:"flex",alignItems:"center",children:[b(W,{sx:{mr:1,color:"text.secondary"},children:w}),L(W,{children:[b(j,{variant:"caption",color:"text.secondary",children:h}),b(j,{variant:"body2",children:o(f,c[f])})]})]},f):null)}),c.permissions&&Array.isArray(c.permissions)&&c.permissions.length>0&&L(W,{mt:2,children:[b(j,{variant:"caption",color:"text.secondary",display:"block",children:"Permisos"}),L(W,{display:"flex",flexWrap:"wrap",gap:.5,mt:.5,children:[c.permissions.slice(0,5).map((f,h)=>b(ke,{label:f,size:"small",variant:"outlined"},h)),c.permissions.length>5&&b(ke,{label:`+${c.permissions.length-5} m\xE1s`,size:"small"})]})]})]})}),e&&b(ko,{children:L(Lo,{children:[L(W,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[L(j,{variant:"h6",display:"flex",alignItems:"center",children:[b(jr,{sx:{mr:1}}),"Informaci\xF3n Detallada"]}),b(ke,{label:`${x} campos totales`,size:"small"})]}),L(_r,{dense:!0,children:[u.map(({key:f,label:h})=>c[f]!==void 0&&L(Ne,{divider:!0,children:[b(Or,{children:b(Mr,{fontSize:"small"})}),b(Ve,{primary:h,secondary:f.includes("At")||f.includes("Login")?d(c[f]):o(f,c[f])})]},f)),P.length>0&&L(Jr,{children:[b(Fr,{sx:{my:1}}),b(Ne,{children:b(Ve,{primary:L(W,{display:"flex",justifyContent:"space-between",alignItems:"center",children:[L(j,{variant:"subtitle2",children:["Campos Personalizados (",P.length,")"]}),b(We,{size:"small",onClick:()=>y(!l),children:l?b(Kr,{}):b(Hr,{})})]})})}),b(zr,{in:l,children:P.map(({key:f,label:h})=>b(Ne,{sx:{pl:4},children:b(Ve,{primary:h,secondary:o(f,c[f])})},f))})]})]}),L(W,{mt:2,display:"flex",justifyContent:"space-between",alignItems:"center",children:[L(j,{variant:"caption",color:"text.secondary",children:["\xDAltima actualizaci\xF3n: ",d(c.updatedAt)]}),b(We,{size:"small",onClick:p,disabled:m,children:b(j,{variant:"caption",children:"Actualizar"})})]})]})})]})},Yr=Gr;var Ao=["create","read","update","delete"],Io=["create","read","update","delete"];import{useRef as wt}from"react";import{useTranslation as Ct}from"react-i18next";import{Box as Re,Typography as _o,Button as Pt,Stack as vt,Alert as Oo,Divider as Tt}from"@mui/material";import{Add as Et}from"@mui/icons-material";import{forwardRef as at}from"react";import{useTranslation as lt}from"react-i18next";import{Box as ne,FormControl as ct,InputLabel as dt,Select as ut,MenuItem as ft,IconButton as mt,Typography as le,FormHelperText as pt,Stack as Le,Paper as Do,Divider as gt,Button as Ke}from"@mui/material";import{Delete as yt,SelectAll as xt,ClearAll as ht}from"@mui/icons-material";import{useState as Xr,useEffect as Qr,useRef as Zr}from"react";import{useTranslation as et}from"react-i18next";import{Box as Ue,Typography as he,Button as Bo,Stack as Me,FormHelperText as Fo,ToggleButton as $e,ToggleButtonGroup as ot}from"@mui/material";import{CheckCircle as rt,Cancel as tt,SelectAll as nt,ClearAll as it}from"@mui/icons-material";import{jsx as D,jsxs as oe}from"react/jsx-runtime";var st=({value:e,onChange:t,availableFields:s,error:a,disabled:m=!1})=>{let{t:n}=et(),[i,p]=Xr("custom"),l=Zr(!1);Qr(()=>{let o=e||{allow:[],owner_allow:[],deny:[]},r=new Set(s),u=(o.allow||[]).filter(h=>r.has(h)),C=(o.owner_allow||[]).filter(h=>r.has(h)),P=(o.deny||[]).filter(h=>r.has(h));s.forEach(h=>{!u.includes(h)&&!C.includes(h)&&!P.includes(h)&&P.push(h)});let f={allow:u,owner_allow:C,deny:P};JSON.stringify(f)!==JSON.stringify(o)&&t(f),u.length===s.length?p("all"):P.length===s.length?p("none"):p("custom")},[s,e]);let y=()=>{l.current=!0,t({allow:[...s],owner_allow:[],deny:[]}),p("all"),setTimeout(()=>{l.current=!1},0)},c=()=>{l.current=!0,t({allow:[],owner_allow:[],deny:[...s]}),p("none"),setTimeout(()=>{l.current=!1},0)},x=o=>e?.allow?.includes(o)?"allow":e?.owner_allow?.includes(o)?"owner_allow":"deny",d=(o,r)=>{l.current=!0;let u=new Set(e?.allow||[]),C=new Set(e?.owner_allow||[]),P=new Set(e?.deny||[]);u.delete(o),C.delete(o),P.delete(o),r==="allow"&&u.add(o),r==="owner_allow"&&C.add(o),r==="deny"&&P.add(o),t({allow:Array.from(u),owner_allow:Array.from(C),deny:Array.from(P)}),p("custom"),setTimeout(()=>{l.current=!1},0)};return s.length===0?oe(Ue,{children:[D(he,{variant:"body2",color:"text.secondary",sx:{mb:1},children:n("modules.form.publicPolicies.fields.conditions.label")}),D(he,{variant:"body2",color:"text.secondary",sx:{fontStyle:"italic"},children:n("modules.form.publicPolicies.fields.conditions.noFieldsAvailable")}),a&&D(Fo,{error:!0,sx:{mt:1},children:a})]}):oe(Ue,{children:[D(he,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.label")}),oe(Me,{direction:"row",spacing:1,sx:{mb:3},children:[D(Bo,{variant:i==="all"?"contained":"outlined",startIcon:D(nt,{}),onClick:y,disabled:m,size:"small",sx:{minWidth:120,...i==="all"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:n("modules.form.publicPolicies.fields.conditions.allFields")}),D(Bo,{variant:i==="none"?"contained":"outlined",startIcon:D(it,{}),onClick:c,disabled:m,size:"small",sx:{minWidth:120,...i==="none"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:n("modules.form.publicPolicies.fields.conditions.noFields")})]}),oe(Ue,{sx:{p:2,border:"1px solid #d1d9e0",borderRadius:1,backgroundColor:"#f6f8fa"},children:[D(he,{variant:"body2",color:"text.secondary",sx:{mb:2},children:n("modules.form.publicPolicies.fields.conditions.help")}),D(Me,{spacing:1,children:s.map(o=>{let r=x(o);return oe(Me,{direction:"row",spacing:1,alignItems:"center",children:[D(he,{variant:"body2",sx:{minWidth:100,fontFamily:"monospace"},children:o}),oe(ot,{value:r,exclusive:!0,size:"small",children:[oe($e,{value:"allow",onClick:()=>d(o,"allow"),disabled:m,sx:{px:2,color:r==="allow"?"#ffffff":"#6b7280",backgroundColor:r==="allow"?"#16a34a":"#f3f4f6",borderColor:r==="allow"?"#16a34a":"#d1d5db","&:hover":{backgroundColor:r==="allow"?"#15803d":"#e5e7eb",borderColor:r==="allow"?"#15803d":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#16a34a",color:"#ffffff","&:hover":{backgroundColor:"#15803d"}}},children:[D(rt,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.allow")]}),D($e,{value:"owner_allow",onClick:()=>d(o,"owner_allow"),disabled:m,sx:{px:2,color:r==="owner_allow"?"#ffffff":"#6b7280",backgroundColor:r==="owner_allow"?"#0ea5e9":"#f3f4f6",borderColor:r==="owner_allow"?"#0ea5e9":"#d1d5db","&:hover":{backgroundColor:r==="owner_allow"?"#0284c7":"#e5e7eb",borderColor:r==="owner_allow"?"#0284c7":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#0ea5e9",color:"#ffffff","&:hover":{backgroundColor:"#0284c7"}}},children:n("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),oe($e,{value:"deny",onClick:()=>d(o,"deny"),disabled:m,sx:{px:2,color:r==="deny"?"#ffffff":"#6b7280",backgroundColor:r==="deny"?"#dc2626":"#f3f4f6",borderColor:r==="deny"?"#dc2626":"#d1d5db","&:hover":{backgroundColor:r==="deny"?"#b91c1c":"#e5e7eb",borderColor:r==="deny"?"#b91c1c":"#9ca3af"},"&.Mui-selected":{backgroundColor:"#dc2626",color:"#ffffff","&:hover":{backgroundColor:"#b91c1c"}}},children:[D(tt,{sx:{fontSize:16,mr:.5}}),n("modules.form.publicPolicies.fields.conditions.states.deny")]})]})]},o)})})]}),a&&D(Fo,{error:!0,sx:{mt:1},children:a})]})},He=st;import{jsx as A,jsxs as _}from"react/jsx-runtime";var bt=at(({policy:e,onChange:t,onRemove:s,availableFields:a,isSubmitting:m=!1,usedActions:n,error:i},p)=>{let{t:l}=lt(),y=new Set(Array.from(n||[]));y.delete(e.action);let c=Ao.map(x=>({value:x,label:l(`modules.form.publicPolicies.fields.action.options.${x}`)}));return _(Do,{ref:p,sx:{p:3,border:"1px solid #d1d9e0",borderRadius:2,position:"relative",backgroundColor:"#ffffff"},children:[_(ne,{sx:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",mb:3},children:[A(le,{variant:"subtitle1",sx:{fontWeight:600,color:"#111418",fontSize:"1rem"},children:l("modules.form.publicPolicies.policyTitle")}),A(mt,{onClick:s,size:"small",disabled:m,"aria-label":l("modules.form.publicPolicies.removePolicy"),sx:{color:"#656d76","&:hover":{color:"#cf222e",backgroundColor:"rgba(207, 34, 46, 0.1)"}},children:A(yt,{})})]}),_(Le,{spacing:3,children:[A(Le,{direction:{xs:"column",md:"row"},spacing:2,children:A(ne,{sx:{flex:1,minWidth:200},children:_(ct,{fullWidth:!0,children:[A(dt,{children:l("modules.form.publicPolicies.fields.action.label")}),A(ut,{value:e.action,label:l("modules.form.publicPolicies.fields.action.label"),disabled:m,onChange:x=>{let d=x.target.value,o={...e,action:d};d==="delete"?(o.permission="deny",delete o.fields):(o.fields={allow:[],owner_allow:[],deny:a},delete o.permission),t(o)},sx:{backgroundColor:"#ffffff","&:hover .MuiOutlinedInput-notchedOutline":{borderColor:"#8c959f"},"&.Mui-focused .MuiOutlinedInput-notchedOutline":{borderColor:"#0969da",borderWidth:2}},children:c.map(x=>{let d=y.has(x.value);return A(ft,{value:x.value,disabled:d,children:x.label},x.value)})}),i&&A(pt,{error:!0,children:i})]})})}),e.action==="delete"?_(ne,{children:[A(le,{variant:"body2",color:"text.secondary",sx:{mb:2},children:l("modules.form.publicPolicies.fields.conditions.label")}),_(Le,{direction:"row",spacing:1,sx:{mb:3},children:[A(Ke,{variant:e.permission==="*"?"contained":"outlined",startIcon:A(xt,{}),onClick:()=>t({...e,permission:"*"}),disabled:m,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="*"&&{backgroundColor:"#16a34a","&:hover":{backgroundColor:"#15803d"}}},children:l("modules.form.publicPolicies.fields.conditions.allFields")}),A(Ke,{variant:e.permission==="owner"?"contained":"outlined",onClick:()=>t({...e,permission:"owner"}),disabled:m,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="owner"&&{backgroundColor:"#0ea5e9","&:hover":{backgroundColor:"#0284c7"}}},children:l("modules.form.publicPolicies.fields.conditions.states.ownerAllow")}),A(Ke,{variant:e.permission==="deny"?"contained":"outlined",startIcon:A(ht,{}),onClick:()=>t({...e,permission:"deny"}),disabled:m,size:"small",sx:{minWidth:140,whiteSpace:"nowrap",...e.permission==="deny"&&{backgroundColor:"#cf222e","&:hover":{backgroundColor:"#bc1f2c"}}},children:l("modules.form.publicPolicies.fields.conditions.noFields")})]})]}):A(He,{value:e.fields||{allow:[],owner_allow:[],deny:[]},onChange:x=>t({...e,fields:x}),availableFields:a,disabled:m}),A(Do,{variant:"outlined",sx:{p:2,backgroundColor:"#f9fafb"},children:e.action==="delete"?_(le,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(ne,{component:"span",sx:{color:e.permission==="*"?"#16a34a":e.permission==="owner"?"#0ea5e9":"#dc2626"},children:[l("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",e.permission||"-"]}):_(Le,{spacing:.5,divider:A(gt,{sx:{borderColor:"#e5e7eb"}}),children:[_(le,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(ne,{component:"span",sx:{color:"#16a34a"},children:[l("modules.form.publicPolicies.fields.conditions.states.allow"),":"]})," ",(e?.fields?.allow||[]).join(", ")||"-"]}),_(le,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(ne,{component:"span",sx:{color:"#0ea5e9"},children:[l("modules.form.publicPolicies.fields.conditions.states.ownerAllow"),":"]})," ",(e?.fields?.owner_allow||[]).join(", ")||"-"]}),_(le,{variant:"body2",sx:{fontFamily:"monospace",color:"text.secondary"},children:[_(ne,{component:"span",sx:{color:"#dc2626"},children:[l("modules.form.publicPolicies.fields.conditions.states.deny"),":"]})," ",(e?.fields?.deny||[]).join(", ")||"-"]})]})})]})]})}),je=bt;import{Fragment as Lt,jsx as Y,jsxs as Ae}from"react/jsx-runtime";var St=()=>{let e=globalThis?.crypto;return e&&typeof e.randomUUID=="function"?e.randomUUID():`${Date.now()}-${Math.random().toString(16).slice(2)}`},kt=({policies:e,onChange:t,availableFields:s,errors:a,isSubmitting:m=!1})=>{let{t:n}=Ct(),i=wt({}),p=new Set((e||[]).map(r=>r.action).filter(Boolean)),l=Io.filter(r=>!p.has(r)),y=l.length>0,c=()=>{let r=l[0]||"create",u={id:St(),action:r};r==="delete"?u.permission="deny":u.fields={allow:[],owner_allow:[],deny:s};let C=[...e||[],u];t(C),setTimeout(()=>{let P=C.length-1,f=i.current[P];f&&f.scrollIntoView({behavior:"smooth",block:"center"})},100)},x=r=>{let u=[...e];u.splice(r,1),t(u)},d=(()=>{if(!a)return null;if(typeof a=="string")return a;let r=a._error;return typeof r=="string"?r:null})(),o=new Set((e||[]).map(r=>r.action));return Ae(Lt,{children:[Y(Tt,{sx:{borderColor:"#e0e4e7"}}),Ae(Re,{children:[Y(Re,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:3,children:Ae(Re,{children:[Y(_o,{variant:"h6",sx:{fontWeight:600,color:"#111418",mb:1},children:n("modules.form.publicPolicies.title")}),Y(_o,{variant:"body2",color:"text.secondary",sx:{fontSize:"0.875rem"},children:n("modules.form.publicPolicies.description")})]})}),d&&Y(Oo,{severity:"error",sx:{mb:3},children:d}),Ae(vt,{spacing:3,children:[(e||[]).length===0?Y(Oo,{severity:"info",children:n("modules.form.publicPolicies.noPolicies")}):e.map((r,u)=>Y(je,{ref:C=>{i.current[u]=C},policy:r,onChange:C=>{let P=[...e];P[u]=C,t(P)},onRemove:()=>x(u),availableFields:s,isSubmitting:m,usedActions:o,error:typeof a=="object"&&a&&r.id in a?a[r.id]:void 0},r.id)),y&&Y(Re,{children:Y(Pt,{type:"button",variant:"outlined",startIcon:Y(Et,{}),onClick:c,disabled:m,sx:{borderColor:"#d0d7de",color:"#656d76","&:hover":{borderColor:"#8c959f",backgroundColor:"transparent"}},children:n("modules.form.publicPolicies.addPolicy")})})]})]})]})},Ti=kt;import{useState as qe}from"react";import{Button as Ie,TextField as zo,Box as ce,Alert as be,Typography as re,CircularProgress as Ge}from"@mui/material";import{jsx as R,jsxs as X}from"react/jsx-runtime";function Ii(){let[e,t]=qe(""),[s,a]=qe(""),[m,n]=qe(!1),{isAuthenticated:i,isLoading:p,error:l,login:y,logout:c,refreshTokens:x,clearError:d,isExpiringSoon:o,expiresIn:r}=Q(),u=async f=>{if(f.preventDefault(),!e||!s)return;(await y(e,s)).success&&(t(""),a(""),n(!1))},C=async()=>{await c()},P=async()=>{await x()};return i?X(ce,{sx:{maxWidth:600,mx:"auto",p:3},children:[R(re,{variant:"h4",gutterBottom:!0,children:"Welcome! \u{1F389}"}),R(be,{severity:"success",sx:{mb:3},children:"You are successfully logged in with Refresh Token Pattern enabled"}),X(ce,{sx:{mb:3,p:2,bgcolor:"background.paper",border:1,borderColor:"divider",borderRadius:1},children:[R(re,{variant:"h6",gutterBottom:!0,children:"Token Status"}),X(re,{variant:"body2",color:"text.secondary",children:["Access Token expires in: ",Math.round(r/1e3/60)," minutes"]}),o&&R(be,{severity:"warning",sx:{mt:1},children:"Token expires soon - automatic refresh will happen"})]}),X(ce,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[R(Ie,{variant:"contained",onClick:P,disabled:p,startIcon:p?R(Ge,{size:16}):null,children:"Refresh Tokens"}),R(Ie,{variant:"outlined",color:"error",onClick:C,disabled:p,children:"Logout"})]}),l&&R(be,{severity:"error",sx:{mt:2},onClose:d,children:l})]}):X(ce,{sx:{maxWidth:400,mx:"auto",p:3},children:[R(re,{variant:"h4",gutterBottom:!0,align:"center",children:"Login with Refresh Tokens"}),R(be,{severity:"info",sx:{mb:3},children:"This demo shows the new Refresh Token Pattern with automatic session management"}),m?X("form",{onSubmit:u,children:[R(zo,{fullWidth:!0,label:"Email",type:"email",value:e,onChange:f=>t(f.target.value),margin:"normal",required:!0,autoComplete:"email"}),R(zo,{fullWidth:!0,label:"Password",type:"password",value:s,onChange:f=>a(f.target.value),margin:"normal",required:!0,autoComplete:"current-password"}),R(Ie,{type:"submit",fullWidth:!0,variant:"contained",size:"large",disabled:p,startIcon:p?R(Ge,{size:16}):null,sx:{mt:3,mb:2},children:p?"Logging in...":"Login"})]}):R(Ie,{fullWidth:!0,variant:"contained",size:"large",onClick:()=>n(!0),sx:{mt:2},children:"Show Login Form"}),l&&R(be,{severity:"error",sx:{mt:2},onClose:d,children:l})]})}function Bi(){let{isAuthenticated:e,isLoading:t,isExpiringSoon:s,expiresIn:a}=Q();return t?X(ce,{sx:{display:"flex",alignItems:"center",gap:1},children:[R(Ge,{size:16}),R(re,{variant:"caption",children:"Loading session..."})]}):e?X(ce,{children:[R(re,{variant:"caption",color:"success.main",children:"\u2713 Authenticated"}),s&&X(re,{variant:"caption",color:"warning.main",display:"block",children:["\u26A0 Token expires in ",Math.round(a/1e3/60)," min"]})]}):R(re,{variant:"caption",color:"text.secondary",children:"Not logged in"})}export{Wn as a,Yr as b,Ao as c,Io as d,Ti as e,Ii as f,Bi as g};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _cryptojs = require('crypto-js'); var _cryptojs2 = _interopRequireDefault(_cryptojs);var a=class{constructor(e="sessionStorage"){this.encryptionKey=this.generateEncryptionKey(),this.storage=e==="localStorage"?window.localStorage:window.sessionStorage}generateEncryptionKey(){let e=[navigator.userAgent,navigator.language,new Date().getTimezoneOffset(),screen.colorDepth,screen.width,screen.height,"crudify-login"].join("|");return _cryptojs2.default.SHA256(e).toString()}setItem(e,t,r){try{let o=_cryptojs2.default.AES.encrypt(t,this.encryptionKey).toString();if(this.storage.setItem(e,o),r){let s=new Date().getTime()+r*60*1e3;this.storage.setItem(`${e}_expiry`,s.toString())}}catch(o){console.error("Failed to encrypt and store data:",o)}}getItem(e){try{let t=`${e}_expiry`,r=this.storage.getItem(t);if(r){let c=parseInt(r,10);if(new Date().getTime()>c)return this.removeItem(e),null}let o=this.storage.getItem(e);if(!o)return null;let n=_cryptojs2.default.AES.decrypt(o,this.encryptionKey).toString(_cryptojs2.default.enc.Utf8);return n||(console.warn("Failed to decrypt stored data - may be corrupted"),this.removeItem(e),null)}catch(t){return console.error("Failed to decrypt data:",t),this.removeItem(e),null}}removeItem(e){this.storage.removeItem(e),this.storage.removeItem(`${e}_expiry`)}setToken(e){try{let t=e.split(".");if(t.length===3){let r=JSON.parse(atob(t[1]));if(r.exp){let o=r.exp*1e3,s=new Date().getTime(),n=Math.floor((o-s)/(60*1e3));if(n>0){this.setItem("authToken",e,n);return}}}}catch (e2){console.warn("Failed to parse token expiry, using default expiry")}this.setItem("authToken",e,1440)}getToken(){let e=this.getItem("authToken");if(e)try{let t=e.split(".");if(t.length===3){let r=JSON.parse(atob(t[1]));if(r.exp){let o=Math.floor(Date.now()/1e3);if(r.exp<o)return this.removeItem("authToken"),null}}}catch (e3){return console.warn("Failed to validate token expiry"),this.removeItem("authToken"),null}return e}},p= exports.a =new a("sessionStorage"),y= exports.b =new a("localStorage");exports.a = p; exports.b = y;
|
|
@@ -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 _chunk6EBMA4HZjs = require('./chunk-6EBMA4HZ.js');var _cryptojs = require('crypto-js'); var _cryptojs2 = _interopRequireDefault(_cryptojs);var s=class s{static setStorageType(e){s.storageType=e}static generateEncryptionKey(){let e=[navigator.userAgent,navigator.language,navigator.platform,screen.width,screen.height,Date.now().toString(),Math.random().toString(36)].join("|");return _cryptojs2.default.SHA256(e).toString()}static getEncryptionKey(){if(s.encryptionKey)return s.encryptionKey;let e=window.localStorage;if(!e)return s.encryptionKey=s.generateEncryptionKey(),s.encryptionKey;try{let t=e.getItem(s.ENCRYPTION_KEY_STORAGE);return(!t||t.length<32)&&(t=s.generateEncryptionKey(),e.setItem(s.ENCRYPTION_KEY_STORAGE,t)),s.encryptionKey=t,t}catch (e2){return console.warn("Crudify: Cannot persist encryption key, using temporary key"),s.encryptionKey=s.generateEncryptionKey(),s.encryptionKey}}static isStorageAvailable(e){try{let t=window[e],r="__storage_test__";return t.setItem(r,"test"),t.removeItem(r),!0}catch (e3){return!1}}static getStorage(){return s.storageType==="none"?null:s.isStorageAvailable(s.storageType)?window[s.storageType]:(console.warn(`Crudify: ${s.storageType} not available, tokens won't persist`),null)}static encrypt(e){try{let t=s.getEncryptionKey();return _cryptojs2.default.AES.encrypt(e,t).toString()}catch(t){return console.error("Crudify: Encryption failed",t),e}}static decrypt(e){try{let t=s.getEncryptionKey();return _cryptojs2.default.AES.decrypt(e,t).toString(_cryptojs2.default.enc.Utf8)||e}catch(t){return console.error("Crudify: Decryption failed",t),e}}static saveTokens(e){let t=s.getStorage();if(t)try{let r={accessToken:e.accessToken,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt,savedAt:Date.now()},i=s.encrypt(JSON.stringify(r));t.setItem(s.TOKEN_KEY,i),console.debug("Crudify: Tokens saved successfully")}catch(r){console.error("Crudify: Failed to save tokens",r)}}static getTokens(){let e=s.getStorage();if(!e)return null;try{let t=e.getItem(s.TOKEN_KEY);if(!t)return null;let r=s.decrypt(t),i=JSON.parse(r);return!i.accessToken||!i.refreshToken||!i.expiresAt||!i.refreshExpiresAt?(console.warn("Crudify: Incomplete token data found, clearing storage"),s.clearTokens(),null):Date.now()>=i.refreshExpiresAt?(console.info("Crudify: Refresh token expired, clearing storage"),s.clearTokens(),null):{accessToken:i.accessToken,refreshToken:i.refreshToken,expiresAt:i.expiresAt,refreshExpiresAt:i.refreshExpiresAt}}catch(t){return console.error("Crudify: Failed to retrieve tokens",t),s.clearTokens(),null}}static clearTokens(){let e=s.getStorage();if(e)try{e.removeItem(s.TOKEN_KEY),console.debug("Crudify: Tokens cleared from storage")}catch(t){console.error("Crudify: Failed to clear tokens",t)}}static rotateEncryptionKey(){try{s.clearTokens(),s.encryptionKey=null;let e=window.localStorage;e&&e.removeItem(s.ENCRYPTION_KEY_STORAGE),console.info("Crudify: Encryption key rotated successfully")}catch(e){console.error("Crudify: Failed to rotate encryption key",e)}}static hasValidTokens(){return s.getTokens()!==null}static getExpirationInfo(){let e=s.getTokens();if(!e)return null;let t=Date.now();return{accessExpired:t>=e.expiresAt,refreshExpired:t>=e.refreshExpiresAt,accessExpiresIn:Math.max(0,e.expiresAt-t),refreshExpiresIn:Math.max(0,e.refreshExpiresAt-t)}}static updateAccessToken(e,t){let r=s.getTokens();if(!r){console.warn("Crudify: Cannot update access token, no existing tokens found");return}s.saveTokens({...r,accessToken:e,expiresAt:t})}};s.TOKEN_KEY="crudify_tokens",s.ENCRYPTION_KEY_STORAGE="crudify_enc_key",s.encryptionKey=null,s.storageType="localStorage";var g=s;var _crudifybrowser = require('@nocios/crudify-browser'); var _crudifybrowser2 = _interopRequireDefault(_crudifybrowser);var L=class n{constructor(){this.config={};this.initialized=!1}static getInstance(){return n.instance||(n.instance=new n),n.instance}async initialize(e={}){if(this.initialized){console.warn("SessionManager: Already initialized");return}this.config={storageType:"localStorage",autoRestore:!0,enableLogging:!1,...e},g.setStorageType(this.config.storageType||"localStorage"),this.config.enableLogging,this.config.autoRestore&&await this.restoreSession(),this.initialized=!0,this.log("SessionManager initialized successfully")}async login(e,t){try{this.log("Attempting login...");let r=await _crudifybrowser2.default.login(e,t);if(!r.success)return this.log("Login failed:",r.errors),{success:!1,error:this.formatError(r.errors),rawResponse:r};let i={accessToken:r.data.token,refreshToken:r.data.refreshToken,expiresAt:r.data.expiresAt,refreshExpiresAt:r.data.refreshExpiresAt};return g.saveTokens(i),this.log("Login successful, tokens saved"),_optionalChain([this, 'access', _2 => _2.config, 'access', _3 => _3.onLoginSuccess, 'optionalCall', _4 => _4(i)]),{success:!0,tokens:i,data:r.data}}catch(r){return this.log("Login error:",r),{success:!1,error:r instanceof Error?r.message:"Unknown error"}}}async logout(){try{this.log("Logging out..."),await _crudifybrowser2.default.logout(),g.clearTokens(),this.log("Logout successful"),_optionalChain([this, 'access', _5 => _5.config, 'access', _6 => _6.onLogout, 'optionalCall', _7 => _7()])}catch(e){this.log("Logout error:",e),g.clearTokens()}}async restoreSession(){try{this.log("Attempting to restore session...");let e=g.getTokens();if(!e)return this.log("No valid tokens found in storage"),!1;_crudifybrowser2.default.setTokens({accessToken:e.accessToken,refreshToken:e.refreshToken,expiresAt:e.expiresAt,refreshExpiresAt:e.refreshExpiresAt});try{if(!_crudifybrowser2.default.isLogin())return this.log("Restored tokens are invalid, clearing storage"),g.clearTokens(),!1}catch(t){return this.log("Token validation failed:",t),g.clearTokens(),!1}return this.log("Session restored successfully"),_optionalChain([this, 'access', _8 => _8.config, 'access', _9 => _9.onSessionRestored, 'optionalCall', _10 => _10(e)]),!0}catch(e){return this.log("Session restore error:",e),g.clearTokens(),!1}}isAuthenticated(){return _crudifybrowser2.default.isLogin()||g.hasValidTokens()}getTokenInfo(){let e=_crudifybrowser2.default.getTokenData(),t=g.getExpirationInfo();return{isLoggedIn:this.isAuthenticated(),crudifyTokens:e,storageInfo:t,hasValidTokens:g.hasValidTokens()}}async refreshTokens(){try{this.log("Manually refreshing tokens...");let e=await _crudifybrowser2.default.refreshAccessToken();if(!e.success)return this.log("Token refresh failed:",e.errors),g.clearTokens(),_optionalChain([this, 'access', _11 => _11.config, 'access', _12 => _12.showNotification, 'optionalCall', _13 => _13(this.getSessionExpiredMessage(),"warning")]),_optionalChain([this, 'access', _14 => _14.config, 'access', _15 => _15.onSessionExpired, 'optionalCall', _16 => _16()]),!1;let t={accessToken:e.data.token,refreshToken:e.data.refreshToken,expiresAt:e.data.expiresAt,refreshExpiresAt:e.data.refreshExpiresAt};return g.saveTokens(t),this.log("Tokens refreshed and saved successfully"),!0}catch(e){return this.log("Token refresh error:",e),g.clearTokens(),_optionalChain([this, 'access', _17 => _17.config, 'access', _18 => _18.showNotification, 'optionalCall', _19 => _19(this.getSessionExpiredMessage(),"warning")]),_optionalChain([this, 'access', _20 => _20.config, 'access', _21 => _21.onSessionExpired, 'optionalCall', _22 => _22()]),!1}}setupResponseInterceptor(){_crudifybrowser2.default.setResponseInterceptor(async e=>{let t=this.detectAuthorizationError(e);if(t.isAuthError){if(console.warn("\u{1F6A8} SessionManager - Authorization error detected:",{errorType:t.errorType,errorDetails:t.errorDetails,fullResponse:e}),t.isRefreshTokenInvalid||t.isTokenRefreshFailed)return this.log("Refresh token invalid or refresh already failed, clearing session"),g.clearTokens(),_optionalChain([this, 'access', _23 => _23.config, 'access', _24 => _24.showNotification, 'optionalCall', _25 => _25(this.getSessionExpiredMessage(),"warning")]),_optionalChain([this, 'access', _26 => _26.config, 'access', _27 => _27.onSessionExpired, 'optionalCall', _28 => _28()]),e;g.hasValidTokens()&&!t.isIrrecoverable?(this.log("Auth error detected, attempting token refresh..."),await this.refreshTokens()||(this.log("Token refresh failed, triggering session expired"),_optionalChain([this, 'access', _29 => _29.config, 'access', _30 => _30.onSessionExpired, 'optionalCall', _31 => _31()]))):(this.log("Auth error with no valid tokens or irrecoverable error, triggering session expired"),g.clearTokens(),_optionalChain([this, 'access', _32 => _32.config, 'access', _33 => _33.showNotification, 'optionalCall', _34 => _34(this.getSessionExpiredMessage(),"warning")]),_optionalChain([this, 'access', _35 => _35.config, 'access', _36 => _36.onSessionExpired, 'optionalCall', _37 => _37()]))}return e}),this.log("Response interceptor configured")}detectAuthorizationError(e){let t={isAuthError:!1,isRefreshTokenInvalid:!1,isTokenRefreshFailed:!1,isIrrecoverable:!1,errorType:"",errorDetails:null};if(e.errors){if(Array.isArray(e.errors))e.errors.some(i=>i.errorType==="Unauthorized"||_optionalChain([i, 'access', _38 => _38.message, 'optionalAccess', _39 => _39.includes, 'call', _40 => _40("Unauthorized")])||_optionalChain([i, 'access', _41 => _41.message, 'optionalAccess', _42 => _42.includes, 'call', _43 => _43("Not Authorized")])||_optionalChain([i, 'access', _44 => _44.message, 'optionalAccess', _45 => _45.includes, 'call', _46 => _46("Token")])||_optionalChain([i, 'access', _47 => _47.extensions, 'optionalAccess', _48 => _48.code])==="UNAUTHENTICATED"||_optionalChain([i, 'access', _49 => _49.message, 'optionalAccess', _50 => _50.includes, 'call', _51 => _51("NOT_AUTHORIZED")]))&&(t.isAuthError=!0,t.errorType="GraphQL Array Format",t.errorDetails=e.errors);else if(typeof e.errors=="object"){let r=Object.values(e.errors).flat();r.some(l=>typeof l=="string"&&(l.includes("NOT_AUTHORIZED")||l.includes("TOKEN_REFRESH_FAILED")||l.includes("PLEASE_LOGIN")||l.includes("Unauthorized")||l.includes("UNAUTHENTICATED")||l.includes("Token")))&&(t.isAuthError=!0,t.errorType="GraphQL Object Format",t.errorDetails=e.errors,t.isTokenRefreshFailed=r.some(l=>typeof l=="string"&&l.includes("TOKEN_REFRESH_FAILED")))}}if(!t.isAuthError&&_optionalChain([e, 'access', _52 => _52.data, 'optionalAccess', _53 => _53.response, 'optionalAccess', _54 => _54.status])==="UNAUTHORIZED"&&(t.isAuthError=!0,t.errorType="Status UNAUTHORIZED",t.errorDetails=e.data.response,t.isIrrecoverable=!0),!t.isAuthError&&_optionalChain([e, 'access', _55 => _55.data, 'optionalAccess', _56 => _56.response, 'optionalAccess', _57 => _57.data]))try{let r=JSON.parse(e.data.response.data);(r.error==="REFRESH_TOKEN_INVALID"||r.error==="TOKEN_EXPIRED")&&(t.isAuthError=!0,t.errorType="Parsed Data Format",t.errorDetails=r,t.isRefreshTokenInvalid=!0,t.isIrrecoverable=!0)}catch (e4){}if(!t.isAuthError&&e.errorCode){let r=e.errorCode;(r==="UNAUTHORIZED"||r==="UNAUTHENTICATED"||r==="TOKEN_EXPIRED")&&(t.isAuthError=!0,t.errorType="Error Code Format",t.errorDetails={errorCode:r})}return t}clearSession(){g.clearTokens(),_crudifybrowser2.default.logout(),this.log("Session cleared completely")}getSessionExpiredMessage(){return this.config.translateFn?_chunk6EBMA4HZjs.b.call(void 0, "SESSION_EXPIRED",{translateFn:this.config.translateFn,enableDebug:this.config.enableLogging}):"Tu sesi\xF3n ha expirado. Por favor, inicia sesi\xF3n nuevamente."}log(e,...t){this.config.enableLogging&&console.log(`[SessionManager] ${e}`,...t)}formatError(e){return e?typeof e=="string"?e:typeof e=="object"?Object.values(e).flat().join(", "):"Authentication failed":"Unknown error"}};var _react = require('react'); var _react2 = _interopRequireDefault(_react);function V(n={}){let[e,t]=_react.useState.call(void 0, {isAuthenticated:!1,isLoading:!0,isInitialized:!1,tokens:null,error:null}),r=L.getInstance(),i=_react.useCallback.call(void 0, async()=>{try{t(a=>({...a,isLoading:!0,error:null}));let c={autoRestore:_nullishCoalesce(n.autoRestore, () => (!0)),enableLogging:_nullishCoalesce(n.enableLogging, () => (!1)),showNotification:n.showNotification,translateFn:n.translateFn,onSessionExpired:()=>{t(a=>({...a,isAuthenticated:!1,tokens:null,error:"Session expired"})),_optionalChain([n, 'access', _58 => _58.onSessionExpired, 'optionalCall', _59 => _59()])},onSessionRestored:a=>{t(d=>({...d,isAuthenticated:!0,tokens:a,error:null})),_optionalChain([n, 'access', _60 => _60.onSessionRestored, 'optionalCall', _61 => _61(a)])},onLoginSuccess:a=>{t(d=>({...d,isAuthenticated:!0,tokens:a,error:null}))},onLogout:()=>{t(a=>({...a,isAuthenticated:!1,tokens:null,error:null}))}};await r.initialize(c),r.setupResponseInterceptor();let f=r.isAuthenticated(),o=r.getTokenInfo();t(a=>({...a,isAuthenticated:f,isInitialized:!0,isLoading:!1,tokens:o.crudifyTokens.accessToken?{accessToken:o.crudifyTokens.accessToken,refreshToken:o.crudifyTokens.refreshToken,expiresAt:o.crudifyTokens.expiresAt,refreshExpiresAt:o.crudifyTokens.refreshExpiresAt}:null}))}catch(c){let f=c instanceof Error?c.message:"Initialization failed";t(o=>({...o,isLoading:!1,isInitialized:!0,error:f}))}},[n.autoRestore,n.enableLogging,n.onSessionExpired,n.onSessionRestored]),l=_react.useCallback.call(void 0, async(c,f)=>{t(o=>({...o,isLoading:!0,error:null}));try{let o=await r.login(c,f);return o.success&&o.tokens?t(a=>({...a,isAuthenticated:!0,tokens:o.tokens,isLoading:!1,error:null})):t(a=>({...a,isAuthenticated:!1,tokens:null,isLoading:!1,error:null})),o}catch(o){let a=o instanceof Error?o.message:"Login failed",d=a.includes("INVALID_CREDENTIALS")||a.includes("Invalid email")||a.includes("Invalid password")||a.includes("credentials");return t(k=>({...k,isAuthenticated:!1,tokens:null,isLoading:!1,error:d?null:a})),{success:!1,error:a}}},[r]),E=_react.useCallback.call(void 0, async()=>{t(c=>({...c,isLoading:!0}));try{await r.logout(),t(c=>({...c,isAuthenticated:!1,tokens:null,isLoading:!1,error:null}))}catch(c){t(f=>({...f,isAuthenticated:!1,tokens:null,isLoading:!1,error:c instanceof Error?c.message:"Logout error"}))}},[r]),p=_react.useCallback.call(void 0, async()=>{try{let c=await r.refreshTokens();if(c){let f=r.getTokenInfo();t(o=>({...o,tokens:f.crudifyTokens.accessToken?{accessToken:f.crudifyTokens.accessToken,refreshToken:f.crudifyTokens.refreshToken,expiresAt:f.crudifyTokens.expiresAt,refreshExpiresAt:f.crudifyTokens.refreshExpiresAt}:null,error:null}))}else t(f=>({...f,isAuthenticated:!1,tokens:null,error:"Token refresh failed"}));return c}catch(c){return t(f=>({...f,isAuthenticated:!1,tokens:null,error:c instanceof Error?c.message:"Token refresh failed"})),!1}},[r]),b=_react.useCallback.call(void 0, ()=>{t(c=>({...c,error:null}))},[]),y=_react.useCallback.call(void 0, ()=>r.getTokenInfo(),[r]);return _react.useEffect.call(void 0, ()=>{i()},[i]),{...e,login:l,logout:E,refreshTokens:p,clearError:b,getTokenInfo:y,isExpiringSoon:e.tokens?e.tokens.expiresAt-Date.now()<300*1e3:!1,expiresIn:e.tokens?Math.max(0,e.tokens.expiresAt-Date.now()):0,refreshExpiresIn:e.tokens?Math.max(0,e.tokens.refreshExpiresAt-Date.now()):0}}var _material = require('@mui/material');var _uuid = require('uuid');var _dompurify = require('dompurify'); var _dompurify2 = _interopRequireDefault(_dompurify);var _jsxruntime = require('react/jsx-runtime');var W=_react.createContext.call(void 0, null),ue=n=>_dompurify2.default.sanitize(n,{ALLOWED_TAGS:["b","i","em","strong","br","span"],ALLOWED_ATTR:["class"],FORBID_TAGS:["script","iframe","object","embed"],FORBID_ATTR:["onload","onerror","onclick","onmouseover","onfocus","onblur"],WHOLE_DOCUMENT:!1,RETURN_DOM:!1,RETURN_DOM_FRAGMENT:!1,RETURN_TRUSTED_TYPE:!1}),B= exports.d =({children:n,maxNotifications:e=5,defaultAutoHideDuration:t=6e3,position:r={vertical:"top",horizontal:"right"},enabled:i=!1,allowHtml:l=!1})=>{let[E,p]=_react.useState.call(void 0, []),b=_react.useCallback.call(void 0, (o,a="info",d)=>{if(!i)return"";if(!o||typeof o!="string")return console.warn("\u26A0\uFE0F GlobalNotificationProvider: Invalid message provided"),"";o.length>1e3&&(console.warn("\u26A0\uFE0F GlobalNotificationProvider: Message too long, truncating"),o=o.substring(0,1e3)+"...");let k=_uuid.v4.call(void 0, ),x={id:k,message:o,severity:a,autoHideDuration:_nullishCoalesce(_optionalChain([d, 'optionalAccess', _62 => _62.autoHideDuration]), () => (t)),persistent:_nullishCoalesce(_optionalChain([d, 'optionalAccess', _63 => _63.persistent]), () => (!1)),allowHtml:_nullishCoalesce(_optionalChain([d, 'optionalAccess', _64 => _64.allowHtml]), () => (l))};return p(T=>[...T.length>=e?T.slice(-(e-1)):T,x]),k},[e,t,i,l]),y=_react.useCallback.call(void 0, o=>{p(a=>a.filter(d=>d.id!==o))},[]),c=_react.useCallback.call(void 0, ()=>{p([])},[]),f={showNotification:b,hideNotification:y,clearAllNotifications:c};return _jsxruntime.jsxs.call(void 0, W.Provider,{value:f,children:[n,i&&_jsxruntime.jsx.call(void 0, _material.Portal,{children:_jsxruntime.jsx.call(void 0, _material.Box,{sx:{position:"fixed",zIndex:9999,[r.vertical]:(r.vertical==="top",24),[r.horizontal]:r.horizontal==="right"||r.horizontal==="left"?24:"50%",...r.horizontal==="center"&&{transform:"translateX(-50%)"},display:"flex",flexDirection:r.vertical==="top"?"column":"column-reverse",gap:1,maxWidth:"400px",width:"auto"},children:E.map(o=>_jsxruntime.jsx.call(void 0, fe,{notification:o,onClose:()=>y(o.id)},o.id))})})]})},fe=({notification:n,onClose:e})=>{let[t,r]=_react.useState.call(void 0, !0),i=_react.useCallback.call(void 0, (l,E)=>{E!=="clickaway"&&(r(!1),setTimeout(e,300))},[e]);return _react.useEffect.call(void 0, ()=>{if(!n.persistent&&n.autoHideDuration){let l=setTimeout(()=>{i()},n.autoHideDuration);return()=>clearTimeout(l)}},[n.autoHideDuration,n.persistent,i]),_jsxruntime.jsx.call(void 0, _material.Snackbar,{open:t,onClose:i,sx:{position:"relative","& .MuiSnackbarContent-root":{minWidth:"auto"}},TransitionProps:{enter:!0,exit:!0},children:_jsxruntime.jsx.call(void 0, _material.Alert,{variant:"filled",severity:n.severity,onClose:i,sx:{width:"100%",minWidth:"280px",maxWidth:"400px",wordBreak:"break-word"},children:n.allowHtml?_jsxruntime.jsx.call(void 0, "span",{dangerouslySetInnerHTML:{__html:ue(n.message)}}):_jsxruntime.jsx.call(void 0, "span",{children:n.message})})})},J= exports.e =()=>{let n=_react.useContext.call(void 0, W);if(!n)throw new Error("useGlobalNotification debe ser usado dentro de un GlobalNotificationProvider");return n};var X=_react.createContext.call(void 0, void 0);function ye({children:n,options:e={},config:t,showNotifications:r=!1,notificationOptions:i={}}){let l;try{let{showNotification:o}=J();l=o}catch (e5){}let E=_react2.default.useMemo(()=>({...e,showNotification:l,onSessionExpired:()=>{_optionalChain([e, 'access', _65 => _65.onSessionExpired, 'optionalCall', _66 => _66()])}}),[e,l]),p=V(E),b=_react.useMemo.call(void 0, ()=>{let o,a,d,k,x,T="unknown";if(_optionalChain([t, 'optionalAccess', _67 => _67.publicApiKey])&&(o=t.publicApiKey,T="props"),_optionalChain([t, 'optionalAccess', _68 => _68.env])&&(a=t.env),_optionalChain([t, 'optionalAccess', _69 => _69.appName])&&(d=t.appName),_optionalChain([t, 'optionalAccess', _70 => _70.loginActions])&&(k=t.loginActions),_optionalChain([t, 'optionalAccess', _71 => _71.logo])&&(x=t.logo),!o){let R=_chunk6EBMA4HZjs.a.call(void 0, "publicApiKey"),S=_chunk6EBMA4HZjs.a.call(void 0, "environment"),I=_chunk6EBMA4HZjs.a.call(void 0, "appName"),v=_chunk6EBMA4HZjs.a.call(void 0, "loginActions"),u=_chunk6EBMA4HZjs.a.call(void 0, "logo");R&&(o=R,T="cookies"),S&&["dev","stg","prod"].includes(S)&&(a=S),I&&(d=decodeURIComponent(I)),v&&(k=decodeURIComponent(v).split(",").map(C=>C.trim()).filter(Boolean)),u&&(x=decodeURIComponent(u))}return{publicApiKey:o,env:a,appName:d,loginActions:k,logo:x}},[t]),y=_react.useMemo.call(void 0, ()=>{if(!_optionalChain([p, 'access', _72 => _72.tokens, 'optionalAccess', _73 => _73.accessToken])||!p.isAuthenticated)return null;try{let o=_chunk6EBMA4HZjs.f.call(void 0, p.tokens.accessToken);if(o&&o.sub&&o.email&&o.subscriber){let a={_id:o.sub,email:o.email,subscriberKey:o.subscriber};return Object.keys(o).forEach(d=>{["sub","email","subscriber"].includes(d)||(a[d]=o[d])}),a}}catch(o){console.error("Error decoding JWT token for sessionData:",o)}return null},[_optionalChain([p, 'access', _74 => _74.tokens, 'optionalAccess', _75 => _75.accessToken]),p.isAuthenticated]),c={...p,sessionData:y,config:b},f={enabled:r,maxNotifications:i.maxNotifications||5,defaultAutoHideDuration:i.defaultAutoHideDuration||6e3,position:i.position||{vertical:"top",horizontal:"right"}};return _jsxruntime.jsx.call(void 0, X.Provider,{value:c,children:n})}function Be(n){let e={enabled:n.showNotifications,maxNotifications:_optionalChain([n, 'access', _76 => _76.notificationOptions, 'optionalAccess', _77 => _77.maxNotifications])||5,defaultAutoHideDuration:_optionalChain([n, 'access', _78 => _78.notificationOptions, 'optionalAccess', _79 => _79.defaultAutoHideDuration])||6e3,position:_optionalChain([n, 'access', _80 => _80.notificationOptions, 'optionalAccess', _81 => _81.position])||{vertical:"top",horizontal:"right"},allowHtml:_optionalChain([n, 'access', _82 => _82.notificationOptions, 'optionalAccess', _83 => _83.allowHtml])||!1};return _jsxruntime.jsx.call(void 0, B,{...e,children:_jsxruntime.jsx.call(void 0, ye,{...n})})}function $(){let n=_react.useContext.call(void 0, X);if(n===void 0)throw new Error("useSessionContext must be used within a SessionProvider");return n}function Je({children:n,fallback:e=_jsxruntime.jsx.call(void 0, "div",{children:"Please log in to access this content"}),redirectTo:t}){let{isAuthenticated:r,isLoading:i,isInitialized:l}=$();return!l||i?_jsxruntime.jsx.call(void 0, "div",{children:"Loading..."}):r?_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:n}):t?(t(),null):_jsxruntime.jsx.call(void 0, _jsxruntime.Fragment,{children:e})}function Ze(){let n=$();return n.isInitialized?_jsxruntime.jsxs.call(void 0, "div",{style:{padding:"10px",margin:"10px",border:"1px solid #ccc",borderRadius:"4px",fontSize:"12px",fontFamily:"monospace"},children:[_jsxruntime.jsx.call(void 0, "h4",{children:"Session Debug Info"}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Authenticated:"})," ",n.isAuthenticated?"Yes":"No"]}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Loading:"})," ",n.isLoading?"Yes":"No"]}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Error:"})," ",n.error||"None"]}),n.tokens&&_jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment,{children:[_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Access Token:"})," ",n.tokens.accessToken.substring(0,20),"..."]}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Refresh Token:"})," ",n.tokens.refreshToken.substring(0,20),"..."]}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Access Expires In:"})," ",Math.round(n.expiresIn/1e3/60)," minutes"]}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Refresh Expires In:"})," ",Math.round(n.refreshExpiresIn/1e3/60/60)," hours"]}),_jsxruntime.jsxs.call(void 0, "div",{children:[_jsxruntime.jsx.call(void 0, "strong",{children:"Expiring Soon:"})," ",n.isExpiringSoon?"Yes":"No"]})]})]}):_jsxruntime.jsx.call(void 0, "div",{children:"Session not initialized"})}var et=(n={})=>{let{autoFetch:e=!0,retryOnError:t=!1,maxRetries:r=3}=n,[i,l]=_react.useState.call(void 0, null),[E,p]=_react.useState.call(void 0, !1),[b,y]=_react.useState.call(void 0, null),[c,f]=_react.useState.call(void 0, {}),o=_react.useRef.call(void 0, null),a=_react.useRef.call(void 0, !0),d=_react.useRef.call(void 0, 0),k=_react.useRef.call(void 0, 0),x=_react.useCallback.call(void 0, ()=>{l(null),y(null),p(!1),f({})},[]),T=_react.useCallback.call(void 0, async()=>{let R=_chunk6EBMA4HZjs.g.call(void 0, );if(!R){a.current&&(y("No user email available"),p(!1));return}o.current&&o.current.abort();let S=new AbortController;o.current=S;let I=++d.current;try{a.current&&(p(!0),y(null));let v=await _crudifybrowser2.default.readItems("users",{filter:{email:R},pagination:{limit:1}});if(I===d.current&&a.current&&!S.signal.aborted)if(v.success&&v.data&&v.data.length>0){let u=v.data[0];l(u);let z={fullProfile:u,totalFields:Object.keys(u).length,displayData:{id:u.id,email:u.email,username:u.username,firstName:u.firstName,lastName:u.lastName,fullName:u.fullName||`${u.firstName||""} ${u.lastName||""}`.trim(),role:u.role,permissions:u.permissions||[],isActive:u.isActive,lastLogin:u.lastLogin,createdAt:u.createdAt,updatedAt:u.updatedAt,...Object.keys(u).filter(C=>!["id","email","username","firstName","lastName","fullName","role","permissions","isActive","lastLogin","createdAt","updatedAt"].includes(C)).reduce((C,F)=>({...C,[F]:u[F]}),{})}};f(z),y(null),k.current=0}else y("User profile not found"),l(null),f({})}catch(v){if(I===d.current&&a.current){let u=v;if(u.name==="AbortError")return;t&&k.current<r&&(_optionalChain([u, 'access', _84 => _84.message, 'optionalAccess', _85 => _85.includes, 'call', _86 => _86("Network Error")])||_optionalChain([u, 'access', _87 => _87.message, 'optionalAccess', _88 => _88.includes, 'call', _89 => _89("Failed to fetch")]))?(k.current++,setTimeout(()=>{a.current&&T()},1e3*k.current)):(y("Failed to load user profile"),l(null),f({}))}}finally{I===d.current&&a.current&&p(!1),o.current===S&&(o.current=null)}},[t,r]);return _react.useEffect.call(void 0, ()=>{e&&T()},[e,T]),_react.useEffect.call(void 0, ()=>(a.current=!0,()=>{a.current=!1,o.current&&(o.current.abort(),o.current=null)}),[]),{userProfile:i,loading:E,error:b,extendedData:c,refreshProfile:T,clearProfile:x}};exports.a = g; exports.b = L; exports.c = V; exports.d = B; exports.e = J; exports.f = Be; exports.g = $; exports.h = Je; exports.i = Ze; exports.j = et;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import i from"crypto-js";var a=class{constructor(e="sessionStorage"){this.encryptionKey=this.generateEncryptionKey(),this.storage=e==="localStorage"?window.localStorage:window.sessionStorage}generateEncryptionKey(){let e=[navigator.userAgent,navigator.language,new Date().getTimezoneOffset(),screen.colorDepth,screen.width,screen.height,"crudify-login"].join("|");return i.SHA256(e).toString()}setItem(e,t,r){try{let o=i.AES.encrypt(t,this.encryptionKey).toString();if(this.storage.setItem(e,o),r){let s=new Date().getTime()+r*60*1e3;this.storage.setItem(`${e}_expiry`,s.toString())}}catch(o){console.error("Failed to encrypt and store data:",o)}}getItem(e){try{let t=`${e}_expiry`,r=this.storage.getItem(t);if(r){let c=parseInt(r,10);if(new Date().getTime()>c)return this.removeItem(e),null}let o=this.storage.getItem(e);if(!o)return null;let n=i.AES.decrypt(o,this.encryptionKey).toString(i.enc.Utf8);return n||(console.warn("Failed to decrypt stored data - may be corrupted"),this.removeItem(e),null)}catch(t){return console.error("Failed to decrypt data:",t),this.removeItem(e),null}}removeItem(e){this.storage.removeItem(e),this.storage.removeItem(`${e}_expiry`)}setToken(e){try{let t=e.split(".");if(t.length===3){let r=JSON.parse(atob(t[1]));if(r.exp){let o=r.exp*1e3,s=new Date().getTime(),n=Math.floor((o-s)/(60*1e3));if(n>0){this.setItem("authToken",e,n);return}}}}catch{console.warn("Failed to parse token expiry, using default expiry")}this.setItem("authToken",e,1440)}getToken(){let e=this.getItem("authToken");if(e)try{let t=e.split(".");if(t.length===3){let r=JSON.parse(atob(t[1]));if(r.exp){let o=Math.floor(Date.now()/1e3);if(r.exp<o)return this.removeItem("authToken"),null}}}catch{return console.warn("Failed to validate token expiry"),this.removeItem("authToken"),null}return e}},p=new a("sessionStorage"),y=new a("localStorage");export{p as a,y as b};
|