analytica-frontend-lib 1.0.91 → 1.0.93

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.
Files changed (298) hide show
  1. package/dist/Accordation/index.d.mts +12 -0
  2. package/dist/Accordation/index.d.ts +12 -1
  3. package/dist/Accordation/index.js +1 -0
  4. package/dist/Accordation/index.js.map +1 -0
  5. package/dist/Accordation/index.mjs +1 -0
  6. package/dist/Accordation/index.mjs.map +1 -0
  7. package/dist/Alert/index.d.mts +13 -0
  8. package/dist/Alert/index.d.ts +13 -1
  9. package/dist/Alert/index.js +1 -0
  10. package/dist/Alert/index.js.map +1 -0
  11. package/dist/Alert/index.mjs +1 -0
  12. package/dist/Alert/index.mjs.map +1 -0
  13. package/dist/AlertDialog/index.d.mts +36 -0
  14. package/dist/AlertDialog/index.d.ts +36 -1
  15. package/dist/AlertDialog/index.js +1 -0
  16. package/dist/AlertDialog/index.js.map +1 -0
  17. package/dist/AlertDialog/index.mjs +1 -0
  18. package/dist/AlertDialog/index.mjs.map +1 -0
  19. package/dist/Alternative/index.d.mts +81 -0
  20. package/dist/Alternative/index.d.ts +81 -1
  21. package/dist/Alternative/index.js +1 -0
  22. package/dist/Alternative/index.js.map +1 -0
  23. package/dist/Alternative/index.mjs +1 -0
  24. package/dist/Alternative/index.mjs.map +1 -0
  25. package/dist/Auth/AuthProvider/index.d.mts +3 -0
  26. package/dist/Auth/AuthProvider/index.d.ts +3 -1
  27. package/dist/Auth/AuthProvider/index.js +1 -0
  28. package/dist/Auth/AuthProvider/index.js.map +1 -0
  29. package/dist/Auth/AuthProvider/index.mjs +1 -0
  30. package/dist/Auth/AuthProvider/index.mjs.map +1 -0
  31. package/dist/Auth/ProtectedRoute/index.d.mts +3 -0
  32. package/dist/Auth/ProtectedRoute/index.d.ts +3 -1
  33. package/dist/Auth/ProtectedRoute/index.js +1 -0
  34. package/dist/Auth/ProtectedRoute/index.js.map +1 -0
  35. package/dist/Auth/ProtectedRoute/index.mjs +1 -0
  36. package/dist/Auth/ProtectedRoute/index.mjs.map +1 -0
  37. package/dist/Auth/PublicRoute/index.d.mts +3 -0
  38. package/dist/Auth/PublicRoute/index.d.ts +3 -1
  39. package/dist/Auth/PublicRoute/index.js +1 -0
  40. package/dist/Auth/PublicRoute/index.js.map +1 -0
  41. package/dist/Auth/PublicRoute/index.mjs +1 -0
  42. package/dist/Auth/PublicRoute/index.mjs.map +1 -0
  43. package/dist/Auth/getRootDomain/index.d.mts +3 -0
  44. package/dist/Auth/getRootDomain/index.d.ts +3 -1
  45. package/dist/Auth/getRootDomain/index.js +1 -0
  46. package/dist/Auth/getRootDomain/index.js.map +1 -0
  47. package/dist/Auth/getRootDomain/index.mjs +1 -0
  48. package/dist/Auth/getRootDomain/index.mjs.map +1 -0
  49. package/dist/Auth/index.d.mts +312 -0
  50. package/dist/Auth/index.d.ts +312 -1
  51. package/dist/Auth/index.js +1 -0
  52. package/dist/Auth/index.js.map +1 -0
  53. package/dist/Auth/index.mjs +1 -0
  54. package/dist/Auth/index.mjs.map +1 -0
  55. package/dist/Auth/useApiConfig/index.d.mts +43 -0
  56. package/dist/Auth/useApiConfig/index.d.ts +43 -1
  57. package/dist/Auth/useApiConfig/index.js +1 -0
  58. package/dist/Auth/useApiConfig/index.js.map +1 -0
  59. package/dist/Auth/useApiConfig/index.mjs +1 -0
  60. package/dist/Auth/useApiConfig/index.mjs.map +1 -0
  61. package/dist/Auth/useAuth/index.d.mts +3 -0
  62. package/dist/Auth/useAuth/index.d.ts +3 -1
  63. package/dist/Auth/useAuth/index.js +1 -0
  64. package/dist/Auth/useAuth/index.js.map +1 -0
  65. package/dist/Auth/useAuth/index.mjs +1 -0
  66. package/dist/Auth/useAuth/index.mjs.map +1 -0
  67. package/dist/Auth/useAuthGuard/index.d.mts +3 -0
  68. package/dist/Auth/useAuthGuard/index.d.ts +3 -1
  69. package/dist/Auth/useAuthGuard/index.js +1 -0
  70. package/dist/Auth/useAuthGuard/index.js.map +1 -0
  71. package/dist/Auth/useAuthGuard/index.mjs +1 -0
  72. package/dist/Auth/useAuthGuard/index.mjs.map +1 -0
  73. package/dist/Auth/useRouteAuth/index.d.mts +3 -0
  74. package/dist/Auth/useRouteAuth/index.d.ts +3 -1
  75. package/dist/Auth/useRouteAuth/index.js +1 -0
  76. package/dist/Auth/useRouteAuth/index.js.map +1 -0
  77. package/dist/Auth/useRouteAuth/index.mjs +1 -0
  78. package/dist/Auth/useRouteAuth/index.mjs.map +1 -0
  79. package/dist/Auth/useUrlAuthentication/index.d.mts +58 -0
  80. package/dist/Auth/useUrlAuthentication/index.d.ts +58 -1
  81. package/dist/Auth/useUrlAuthentication/index.js +1 -0
  82. package/dist/Auth/useUrlAuthentication/index.js.map +1 -0
  83. package/dist/Auth/useUrlAuthentication/index.mjs +1 -0
  84. package/dist/Auth/useUrlAuthentication/index.mjs.map +1 -0
  85. package/dist/Auth/withAuth/index.d.mts +3 -0
  86. package/dist/Auth/withAuth/index.d.ts +3 -1
  87. package/dist/Auth/withAuth/index.js +1 -0
  88. package/dist/Auth/withAuth/index.js.map +1 -0
  89. package/dist/Auth/withAuth/index.mjs +1 -0
  90. package/dist/Auth/withAuth/index.mjs.map +1 -0
  91. package/dist/Auth/zustandAuthAdapter/index.d.mts +75 -0
  92. package/dist/Auth/zustandAuthAdapter/index.d.ts +75 -1
  93. package/dist/Auth/zustandAuthAdapter/index.js +1 -0
  94. package/dist/Auth/zustandAuthAdapter/index.js.map +1 -0
  95. package/dist/Auth/zustandAuthAdapter/index.mjs +1 -0
  96. package/dist/Auth/zustandAuthAdapter/index.mjs.map +1 -0
  97. package/dist/Badge/index.d.mts +46 -0
  98. package/dist/Badge/index.d.ts +46 -1
  99. package/dist/Badge/index.js +1 -0
  100. package/dist/Badge/index.js.map +1 -0
  101. package/dist/Badge/index.mjs +1 -0
  102. package/dist/Badge/index.mjs.map +1 -0
  103. package/dist/Button/index.d.mts +45 -0
  104. package/dist/Button/index.d.ts +45 -1
  105. package/dist/Button/index.js +1 -0
  106. package/dist/Button/index.js.map +1 -0
  107. package/dist/Button/index.mjs +1 -0
  108. package/dist/Button/index.mjs.map +1 -0
  109. package/dist/Calendar/index.d.mts +60 -0
  110. package/dist/Calendar/index.d.ts +60 -1
  111. package/dist/Calendar/index.js +1 -0
  112. package/dist/Calendar/index.js.map +1 -0
  113. package/dist/Calendar/index.mjs +1 -0
  114. package/dist/Calendar/index.mjs.map +1 -0
  115. package/dist/Card/index.d.mts +150 -0
  116. package/dist/Card/index.d.ts +150 -1
  117. package/dist/Card/index.js +1 -0
  118. package/dist/Card/index.js.map +1 -0
  119. package/dist/Card/index.mjs +1 -0
  120. package/dist/Card/index.mjs.map +1 -0
  121. package/dist/CheckBox/index.d.mts +74 -0
  122. package/dist/CheckBox/index.d.ts +74 -1
  123. package/dist/CheckBox/index.js +1 -0
  124. package/dist/CheckBox/index.js.map +1 -0
  125. package/dist/CheckBox/index.mjs +1 -0
  126. package/dist/CheckBox/index.mjs.map +1 -0
  127. package/dist/Chips/index.d.mts +41 -0
  128. package/dist/Chips/index.d.ts +41 -1
  129. package/dist/Chips/index.js +1 -0
  130. package/dist/Chips/index.js.map +1 -0
  131. package/dist/Chips/index.mjs +1 -0
  132. package/dist/Chips/index.mjs.map +1 -0
  133. package/dist/Divider/index.d.mts +32 -0
  134. package/dist/Divider/index.d.ts +32 -1
  135. package/dist/Divider/index.js +1 -0
  136. package/dist/Divider/index.js.map +1 -0
  137. package/dist/Divider/index.mjs +1 -0
  138. package/dist/Divider/index.mjs.map +1 -0
  139. package/dist/DropdownMenu/index.d.mts +68 -0
  140. package/dist/DropdownMenu/index.d.ts +68 -1
  141. package/dist/DropdownMenu/index.js +1 -0
  142. package/dist/DropdownMenu/index.js.map +1 -0
  143. package/dist/DropdownMenu/index.mjs +1 -0
  144. package/dist/DropdownMenu/index.mjs.map +1 -0
  145. package/dist/IconButton/index.d.mts +76 -0
  146. package/dist/IconButton/index.d.ts +76 -1
  147. package/dist/IconButton/index.js +1 -0
  148. package/dist/IconButton/index.js.map +1 -0
  149. package/dist/IconButton/index.mjs +1 -0
  150. package/dist/IconButton/index.mjs.map +1 -0
  151. package/dist/IconRoundedButton/index.d.mts +34 -0
  152. package/dist/IconRoundedButton/index.d.ts +34 -1
  153. package/dist/IconRoundedButton/index.js +1 -0
  154. package/dist/IconRoundedButton/index.js.map +1 -0
  155. package/dist/IconRoundedButton/index.mjs +1 -0
  156. package/dist/IconRoundedButton/index.mjs.map +1 -0
  157. package/dist/Input/index.d.mts +27 -0
  158. package/dist/Input/index.d.ts +27 -1
  159. package/dist/Input/index.js +1 -0
  160. package/dist/Input/index.js.map +1 -0
  161. package/dist/Input/index.mjs +1 -0
  162. package/dist/Input/index.mjs.map +1 -0
  163. package/dist/Menu/index.d.mts +48 -0
  164. package/dist/Menu/index.d.ts +48 -1
  165. package/dist/Menu/index.js +1 -0
  166. package/dist/Menu/index.js.map +1 -0
  167. package/dist/Menu/index.mjs +1 -0
  168. package/dist/Menu/index.mjs.map +1 -0
  169. package/dist/Modal/index.d.mts +66 -0
  170. package/dist/Modal/index.d.ts +66 -1
  171. package/dist/Modal/index.js +1 -0
  172. package/dist/Modal/index.js.map +1 -0
  173. package/dist/Modal/index.mjs +1 -0
  174. package/dist/Modal/index.mjs.map +1 -0
  175. package/dist/MultipleChoice/index.d.mts +20 -0
  176. package/dist/MultipleChoice/index.d.ts +20 -1
  177. package/dist/MultipleChoice/index.js +1 -0
  178. package/dist/MultipleChoice/index.js.map +1 -0
  179. package/dist/MultipleChoice/index.mjs +1 -0
  180. package/dist/MultipleChoice/index.mjs.map +1 -0
  181. package/dist/NavButton/index.d.mts +57 -0
  182. package/dist/NavButton/index.d.ts +57 -1
  183. package/dist/NavButton/index.js +1 -0
  184. package/dist/NavButton/index.js.map +1 -0
  185. package/dist/NavButton/index.mjs +1 -0
  186. package/dist/NavButton/index.mjs.map +1 -0
  187. package/dist/NotFound/index.d.mts +58 -0
  188. package/dist/NotFound/index.d.ts +58 -1
  189. package/dist/NotFound/index.js +1 -0
  190. package/dist/NotFound/index.js.map +1 -0
  191. package/dist/NotFound/index.mjs +1 -0
  192. package/dist/NotFound/index.mjs.map +1 -0
  193. package/dist/ProgressBar/index.d.mts +95 -0
  194. package/dist/ProgressBar/index.d.ts +95 -1
  195. package/dist/ProgressBar/index.js +1 -0
  196. package/dist/ProgressBar/index.js.map +1 -0
  197. package/dist/ProgressBar/index.mjs +1 -0
  198. package/dist/ProgressBar/index.mjs.map +1 -0
  199. package/dist/ProgressCircle/index.d.mts +60 -0
  200. package/dist/ProgressCircle/index.d.ts +60 -1
  201. package/dist/ProgressCircle/index.js +1 -0
  202. package/dist/ProgressCircle/index.js.map +1 -0
  203. package/dist/ProgressCircle/index.mjs +1 -0
  204. package/dist/ProgressCircle/index.mjs.map +1 -0
  205. package/dist/Quiz/index.d.mts +57 -0
  206. package/dist/Quiz/index.d.ts +57 -1
  207. package/dist/Quiz/index.js +3 -2
  208. package/dist/Quiz/index.js.map +1 -0
  209. package/dist/Quiz/index.mjs +3 -2
  210. package/dist/Quiz/index.mjs.map +1 -0
  211. package/dist/Quiz/useQuizStore/index.d.mts +139 -0
  212. package/dist/Quiz/useQuizStore/index.d.ts +139 -1
  213. package/dist/Quiz/useQuizStore/index.js +1 -0
  214. package/dist/Quiz/useQuizStore/index.js.map +1 -0
  215. package/dist/Quiz/useQuizStore/index.mjs +1 -0
  216. package/dist/Quiz/useQuizStore/index.mjs.map +1 -0
  217. package/dist/Radio/index.d.mts +203 -0
  218. package/dist/Radio/index.d.ts +203 -1
  219. package/dist/Radio/index.js +1 -0
  220. package/dist/Radio/index.js.map +1 -0
  221. package/dist/Radio/index.mjs +1 -0
  222. package/dist/Radio/index.mjs.map +1 -0
  223. package/dist/Select/index.d.mts +58 -0
  224. package/dist/Select/index.d.ts +58 -1
  225. package/dist/Select/index.js +1 -0
  226. package/dist/Select/index.js.map +1 -0
  227. package/dist/Select/index.mjs +1 -0
  228. package/dist/Select/index.mjs.map +1 -0
  229. package/dist/SelectionButton/index.d.mts +57 -0
  230. package/dist/SelectionButton/index.d.ts +57 -1
  231. package/dist/SelectionButton/index.js +1 -0
  232. package/dist/SelectionButton/index.js.map +1 -0
  233. package/dist/SelectionButton/index.mjs +1 -0
  234. package/dist/SelectionButton/index.mjs.map +1 -0
  235. package/dist/Skeleton/index.d.mts +40 -0
  236. package/dist/Skeleton/index.d.ts +40 -1
  237. package/dist/Skeleton/index.js +1 -0
  238. package/dist/Skeleton/index.js.map +1 -0
  239. package/dist/Skeleton/index.mjs +1 -0
  240. package/dist/Skeleton/index.mjs.map +1 -0
  241. package/dist/Stepper/index.d.mts +169 -0
  242. package/dist/Stepper/index.d.ts +169 -1
  243. package/dist/Stepper/index.js +1 -0
  244. package/dist/Stepper/index.js.map +1 -0
  245. package/dist/Stepper/index.mjs +1 -0
  246. package/dist/Stepper/index.mjs.map +1 -0
  247. package/dist/Table/index.d.mts +17 -0
  248. package/dist/Table/index.d.ts +17 -1
  249. package/dist/Table/index.js +1 -0
  250. package/dist/Table/index.js.map +1 -0
  251. package/dist/Table/index.mjs +1 -0
  252. package/dist/Table/index.mjs.map +1 -0
  253. package/dist/Text/index.d.mts +58 -0
  254. package/dist/Text/index.d.ts +58 -1
  255. package/dist/Text/index.js +1 -0
  256. package/dist/Text/index.js.map +1 -0
  257. package/dist/Text/index.mjs +1 -0
  258. package/dist/Text/index.mjs.map +1 -0
  259. package/dist/TextArea/index.d.mts +70 -0
  260. package/dist/TextArea/index.d.ts +70 -1
  261. package/dist/TextArea/index.js +1 -0
  262. package/dist/TextArea/index.js.map +1 -0
  263. package/dist/TextArea/index.mjs +1 -0
  264. package/dist/TextArea/index.mjs.map +1 -0
  265. package/dist/Toast/ToastStore/index.d.mts +19 -0
  266. package/dist/Toast/ToastStore/index.d.ts +19 -1
  267. package/dist/Toast/ToastStore/index.js +1 -0
  268. package/dist/Toast/ToastStore/index.js.map +1 -0
  269. package/dist/Toast/ToastStore/index.mjs +1 -0
  270. package/dist/Toast/ToastStore/index.mjs.map +1 -0
  271. package/dist/Toast/Toaster/index.d.mts +16 -0
  272. package/dist/Toast/Toaster/index.d.ts +16 -1
  273. package/dist/Toast/Toaster/index.js +1 -0
  274. package/dist/Toast/Toaster/index.js.map +1 -0
  275. package/dist/Toast/Toaster/index.mjs +1 -0
  276. package/dist/Toast/Toaster/index.mjs.map +1 -0
  277. package/dist/Toast/index.d.mts +17 -0
  278. package/dist/Toast/index.d.ts +17 -1
  279. package/dist/Toast/index.js +1 -0
  280. package/dist/Toast/index.js.map +1 -0
  281. package/dist/Toast/index.mjs +1 -0
  282. package/dist/Toast/index.mjs.map +1 -0
  283. package/dist/index.css +5 -4
  284. package/dist/index.css.map +1 -0
  285. package/dist/index.d.mts +42 -2142
  286. package/dist/index.d.ts +42 -2142
  287. package/dist/index.js +3 -23
  288. package/dist/index.js.map +1 -0
  289. package/dist/index.mjs +3 -20
  290. package/dist/index.mjs.map +1 -0
  291. package/dist/styles.css +5 -4
  292. package/dist/styles.css.map +1 -0
  293. package/dist/styles.d.mts +2 -0
  294. package/dist/styles.d.ts +2 -0
  295. package/package.json +4 -5
  296. package/dist/CheckBox/CheckboxList/index.d.ts +0 -1
  297. package/dist/CheckBox/CheckboxList/index.js +0 -429
  298. package/dist/CheckBox/CheckboxList/index.mjs +0 -415
@@ -0,0 +1,312 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { ReactNode, ComponentType } from 'react';
3
+
4
+ /**
5
+ * Interface for basic authentication tokens
6
+ *
7
+ * @interface AuthTokens
8
+ * @property {string} token - Main authentication token
9
+ * @property {string} refreshToken - Token used to refresh the main token
10
+ * @property {unknown} [key] - Additional properties that can be included
11
+ */
12
+ interface AuthTokens {
13
+ token: string;
14
+ refreshToken: string;
15
+ [key: string]: unknown;
16
+ }
17
+ /**
18
+ * Interface for basic user information
19
+ *
20
+ * @interface AuthUser
21
+ * @property {string} id - Unique user identifier
22
+ * @property {string} [name] - Optional user name
23
+ * @property {string} [email] - Optional user email
24
+ * @property {unknown} [key] - Additional user properties
25
+ */
26
+ interface AuthUser {
27
+ id: string;
28
+ name?: string;
29
+ email?: string;
30
+ [key: string]: unknown;
31
+ }
32
+ /**
33
+ * Interface for basic session information
34
+ *
35
+ * @interface SessionInfo
36
+ * @property {string} [institutionId] - Optional institution identifier
37
+ * @property {string} [profileId] - Optional profile identifier
38
+ * @property {string} [schoolId] - Optional school identifier
39
+ * @property {string} [schoolYearId] - Optional school year identifier
40
+ * @property {string} [classId] - Optional class identifier
41
+ * @property {unknown} [key] - Additional session properties
42
+ */
43
+ interface SessionInfo {
44
+ institutionId?: string;
45
+ profileId?: string;
46
+ schoolId?: string;
47
+ schoolYearId?: string;
48
+ classId?: string;
49
+ [key: string]: unknown;
50
+ }
51
+ /**
52
+ * Interface for authentication state
53
+ *
54
+ * @interface AuthState
55
+ * @property {boolean} isAuthenticated - Whether the user is authenticated
56
+ * @property {boolean} isLoading - Whether authentication is being checked
57
+ * @property {AuthUser | null} [user] - Current user information
58
+ * @property {SessionInfo | null} [sessionInfo] - Current session information
59
+ * @property {AuthTokens | null} [tokens] - Current authentication tokens
60
+ */
61
+ interface AuthState {
62
+ isAuthenticated: boolean;
63
+ isLoading: boolean;
64
+ user?: AuthUser | null;
65
+ sessionInfo?: SessionInfo | null;
66
+ tokens?: AuthTokens | null;
67
+ }
68
+ /**
69
+ * Interface for authentication context functions and state
70
+ *
71
+ * @interface AuthContextType
72
+ * @extends {AuthState}
73
+ * @property {() => Promise<boolean>} checkAuth - Function to check authentication status
74
+ * @property {() => void} signOut - Function to sign out the user
75
+ */
76
+ interface AuthContextType extends AuthState {
77
+ checkAuth: () => Promise<boolean>;
78
+ signOut: () => void;
79
+ }
80
+ /**
81
+ * Props for the AuthProvider component
82
+ *
83
+ * @interface AuthProviderProps
84
+ * @property {ReactNode} children - Child components
85
+ * @property {() => Promise<boolean> | boolean} [checkAuthFn] - Function to check if user is authenticated
86
+ * @property {() => void} [signOutFn] - Function to handle logout
87
+ * @property {Partial<AuthState>} [initialAuthState] - Initial authentication state
88
+ * @property {() => AuthUser | null | undefined} [getUserFn] - Function to get user data
89
+ * @property {() => SessionInfo | null | undefined} [getSessionFn] - Function to get session info
90
+ * @property {() => AuthTokens | null | undefined} [getTokensFn] - Function to get tokens
91
+ */
92
+ interface AuthProviderProps {
93
+ children: ReactNode;
94
+ /**
95
+ * Função para verificar se o usuário está autenticado
96
+ * Deve retornar uma Promise<boolean>
97
+ */
98
+ checkAuthFn?: () => Promise<boolean> | boolean;
99
+ /**
100
+ * Função para fazer logout
101
+ */
102
+ signOutFn?: () => void;
103
+ /**
104
+ * Estado de autenticação inicial
105
+ */
106
+ initialAuthState?: Partial<AuthState>;
107
+ /**
108
+ * Função para obter dados do usuário (opcional)
109
+ */
110
+ getUserFn?: () => AuthUser | null | undefined;
111
+ /**
112
+ * Função para obter informações da sessão (opcional)
113
+ */
114
+ getSessionFn?: () => SessionInfo | null | undefined;
115
+ /**
116
+ * Função para obter tokens (opcional)
117
+ */
118
+ getTokensFn?: () => AuthTokens | null | undefined;
119
+ }
120
+ /**
121
+ * Authentication provider that manages global auth state
122
+ * Compatible with any store (Zustand, Redux, Context, etc.)
123
+ *
124
+ * @param {AuthProviderProps} props - The provider props
125
+ * @returns {JSX.Element} The provider component
126
+ *
127
+ * @example
128
+ * ```tsx
129
+ * <AuthProvider
130
+ * checkAuthFn={checkAuthFunction}
131
+ * signOutFn={signOutFunction}
132
+ * getUserFn={getUserFunction}
133
+ * >
134
+ * <App />
135
+ * </AuthProvider>
136
+ * ```
137
+ */
138
+ declare const AuthProvider: ({ children, checkAuthFn, signOutFn, initialAuthState, getUserFn, getSessionFn, getTokensFn, }: AuthProviderProps) => react_jsx_runtime.JSX.Element;
139
+ /**
140
+ * Hook to use the authentication context
141
+ *
142
+ * @throws {Error} When used outside of AuthProvider
143
+ * @returns {AuthContextType} The authentication context
144
+ *
145
+ * @example
146
+ * ```tsx
147
+ * const { isAuthenticated, user, signOut } = useAuth();
148
+ * ```
149
+ */
150
+ declare const useAuth: () => AuthContextType;
151
+ /**
152
+ * Props for the ProtectedRoute component
153
+ *
154
+ * @interface ProtectedRouteProps
155
+ * @property {ReactNode} children - Components to render when authenticated
156
+ * @property {string} [redirectTo] - Path to redirect when not authenticated (default: '/')
157
+ * @property {ReactNode} [loadingComponent] - Custom loading component
158
+ * @property {(authState: AuthState) => boolean} [additionalCheck] - Additional authentication check
159
+ */
160
+ interface ProtectedRouteProps {
161
+ children: ReactNode;
162
+ /**
163
+ * Path para redirecionamento quando não autenticado
164
+ */
165
+ redirectTo?: string;
166
+ /**
167
+ * Componente de loading personalizado
168
+ */
169
+ loadingComponent?: ReactNode;
170
+ /**
171
+ * Função adicional de verificação (ex: verificar permissões específicas)
172
+ */
173
+ additionalCheck?: (authState: AuthState) => boolean;
174
+ }
175
+ /**
176
+ * Componente para proteger rotas que requerem autenticação
177
+ *
178
+ * @example
179
+ * ```tsx
180
+ * <ProtectedRoute redirectTo="/login">
181
+ * <PainelPage />
182
+ * </ProtectedRoute>
183
+ * ```
184
+ */
185
+ declare const ProtectedRoute: ({ children, redirectTo, loadingComponent, additionalCheck, }: ProtectedRouteProps) => react_jsx_runtime.JSX.Element | null;
186
+ /**
187
+ * Props for the PublicRoute component
188
+ *
189
+ * @interface PublicRouteProps
190
+ * @property {ReactNode} children - Components to render
191
+ * @property {string} [redirectTo] - Path to redirect to (default: '/painel')
192
+ * @property {boolean} [redirectIfAuthenticated] - Whether to redirect if authenticated
193
+ * @property {boolean} [checkAuthBeforeRender] - Whether to check auth before rendering
194
+ */
195
+ interface PublicRouteProps {
196
+ children: ReactNode;
197
+ /**
198
+ * Path para redirecionamento
199
+ */
200
+ redirectTo?: string;
201
+ /**
202
+ * Se deve redirecionar quando usuário estiver autenticado
203
+ */
204
+ redirectIfAuthenticated?: boolean;
205
+ /**
206
+ * Se deve verificar autenticação antes de renderizar
207
+ */
208
+ checkAuthBeforeRender?: boolean;
209
+ }
210
+ /**
211
+ * Componente para rotas públicas (login, recuperação de senha, etc.)
212
+ * Opcionalmente redireciona se o usuário já estiver autenticado
213
+ *
214
+ * @example
215
+ * ```tsx
216
+ * <PublicRoute redirectTo="/painel" redirectIfAuthenticated={true}>
217
+ * <LoginPage />
218
+ * </PublicRoute>
219
+ * ```
220
+ */
221
+ declare const PublicRoute: ({ children, redirectTo, redirectIfAuthenticated, checkAuthBeforeRender, }: PublicRouteProps) => react_jsx_runtime.JSX.Element;
222
+ /**
223
+ * Higher-Order Component to protect components with authentication
224
+ *
225
+ * @template P - Component props type
226
+ * @param {ComponentType<P>} Component - Component to wrap with authentication
227
+ * @param {Omit<ProtectedRouteProps, 'children'>} [options] - Protection options
228
+ * @returns {(props: P) => JSX.Element} Wrapped component
229
+ *
230
+ * @example
231
+ * ```tsx
232
+ * const ProtectedComponent = withAuth(MyComponent, {
233
+ * redirectTo: "/login",
234
+ * loadingComponent: <CustomSpinner />
235
+ * });
236
+ * ```
237
+ */
238
+ declare const withAuth: <P extends object>(Component: ComponentType<P>, options?: Omit<ProtectedRouteProps, "children">) => (props: P) => react_jsx_runtime.JSX.Element;
239
+ /**
240
+ * Hook for authentication guard with custom checks
241
+ *
242
+ * @param {object} [options] - Guard options
243
+ * @param {boolean} [options.requireAuth=true] - Whether authentication is required
244
+ * @param {(authState: AuthState) => boolean} [options.customCheck] - Custom check function
245
+ * @returns {object} Guard result with canAccess, isLoading, and authState
246
+ *
247
+ * @example
248
+ * ```tsx
249
+ * const { canAccess, isLoading } = useAuthGuard({
250
+ * requireAuth: true,
251
+ * customCheck: (authState) => authState.user?.role === 'admin'
252
+ * });
253
+ * ```
254
+ */
255
+ declare const useAuthGuard: (options?: {
256
+ requireAuth?: boolean;
257
+ customCheck?: (authState: AuthState) => boolean;
258
+ }) => {
259
+ canAccess: boolean;
260
+ isLoading: boolean;
261
+ authState: AuthContextType;
262
+ };
263
+ /**
264
+ * Hook to check authentication on specific routes
265
+ * Useful for conditional checks within components
266
+ *
267
+ * @param {string} [fallbackPath='/'] - Path to redirect when not authenticated
268
+ * @returns {object} Object with isAuthenticated, isLoading, and redirectToLogin function
269
+ *
270
+ * @example
271
+ * ```tsx
272
+ * const { isAuthenticated, redirectToLogin } = useRouteAuth();
273
+ *
274
+ * if (!isAuthenticated) {
275
+ * return redirectToLogin();
276
+ * }
277
+ * ```
278
+ */
279
+ declare const useRouteAuth: (fallbackPath?: string) => {
280
+ isAuthenticated: boolean;
281
+ isLoading: boolean;
282
+ redirectToLogin: () => react_jsx_runtime.JSX.Element;
283
+ };
284
+ /**
285
+ * Get the root domain from the current window location
286
+ * Handles localhost and subdomain cases
287
+ *
288
+ * @returns {string} The root domain URL
289
+ */
290
+ declare const getRootDomain: () => string;
291
+ declare const _default: {
292
+ AuthProvider: ({ children, checkAuthFn, signOutFn, initialAuthState, getUserFn, getSessionFn, getTokensFn, }: AuthProviderProps) => react_jsx_runtime.JSX.Element;
293
+ ProtectedRoute: ({ children, redirectTo, loadingComponent, additionalCheck, }: ProtectedRouteProps) => react_jsx_runtime.JSX.Element | null;
294
+ PublicRoute: ({ children, redirectTo, redirectIfAuthenticated, checkAuthBeforeRender, }: PublicRouteProps) => react_jsx_runtime.JSX.Element;
295
+ withAuth: <P extends object>(Component: ComponentType<P>, options?: Omit<ProtectedRouteProps, "children">) => (props: P) => react_jsx_runtime.JSX.Element;
296
+ useAuth: () => AuthContextType;
297
+ useAuthGuard: (options?: {
298
+ requireAuth?: boolean;
299
+ customCheck?: (authState: AuthState) => boolean;
300
+ }) => {
301
+ canAccess: boolean;
302
+ isLoading: boolean;
303
+ authState: AuthContextType;
304
+ };
305
+ useRouteAuth: (fallbackPath?: string) => {
306
+ isAuthenticated: boolean;
307
+ isLoading: boolean;
308
+ redirectToLogin: () => react_jsx_runtime.JSX.Element;
309
+ };
310
+ };
311
+
312
+ export { type AuthContextType, AuthProvider, type AuthProviderProps, type AuthState, type AuthTokens, type AuthUser, ProtectedRoute, type ProtectedRouteProps, PublicRoute, type PublicRouteProps, type SessionInfo, _default as default, getRootDomain, useAuth, useAuthGuard, useRouteAuth, withAuth };
@@ -1 +1,312 @@
1
- export * from '../index';
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { ReactNode, ComponentType } from 'react';
3
+
4
+ /**
5
+ * Interface for basic authentication tokens
6
+ *
7
+ * @interface AuthTokens
8
+ * @property {string} token - Main authentication token
9
+ * @property {string} refreshToken - Token used to refresh the main token
10
+ * @property {unknown} [key] - Additional properties that can be included
11
+ */
12
+ interface AuthTokens {
13
+ token: string;
14
+ refreshToken: string;
15
+ [key: string]: unknown;
16
+ }
17
+ /**
18
+ * Interface for basic user information
19
+ *
20
+ * @interface AuthUser
21
+ * @property {string} id - Unique user identifier
22
+ * @property {string} [name] - Optional user name
23
+ * @property {string} [email] - Optional user email
24
+ * @property {unknown} [key] - Additional user properties
25
+ */
26
+ interface AuthUser {
27
+ id: string;
28
+ name?: string;
29
+ email?: string;
30
+ [key: string]: unknown;
31
+ }
32
+ /**
33
+ * Interface for basic session information
34
+ *
35
+ * @interface SessionInfo
36
+ * @property {string} [institutionId] - Optional institution identifier
37
+ * @property {string} [profileId] - Optional profile identifier
38
+ * @property {string} [schoolId] - Optional school identifier
39
+ * @property {string} [schoolYearId] - Optional school year identifier
40
+ * @property {string} [classId] - Optional class identifier
41
+ * @property {unknown} [key] - Additional session properties
42
+ */
43
+ interface SessionInfo {
44
+ institutionId?: string;
45
+ profileId?: string;
46
+ schoolId?: string;
47
+ schoolYearId?: string;
48
+ classId?: string;
49
+ [key: string]: unknown;
50
+ }
51
+ /**
52
+ * Interface for authentication state
53
+ *
54
+ * @interface AuthState
55
+ * @property {boolean} isAuthenticated - Whether the user is authenticated
56
+ * @property {boolean} isLoading - Whether authentication is being checked
57
+ * @property {AuthUser | null} [user] - Current user information
58
+ * @property {SessionInfo | null} [sessionInfo] - Current session information
59
+ * @property {AuthTokens | null} [tokens] - Current authentication tokens
60
+ */
61
+ interface AuthState {
62
+ isAuthenticated: boolean;
63
+ isLoading: boolean;
64
+ user?: AuthUser | null;
65
+ sessionInfo?: SessionInfo | null;
66
+ tokens?: AuthTokens | null;
67
+ }
68
+ /**
69
+ * Interface for authentication context functions and state
70
+ *
71
+ * @interface AuthContextType
72
+ * @extends {AuthState}
73
+ * @property {() => Promise<boolean>} checkAuth - Function to check authentication status
74
+ * @property {() => void} signOut - Function to sign out the user
75
+ */
76
+ interface AuthContextType extends AuthState {
77
+ checkAuth: () => Promise<boolean>;
78
+ signOut: () => void;
79
+ }
80
+ /**
81
+ * Props for the AuthProvider component
82
+ *
83
+ * @interface AuthProviderProps
84
+ * @property {ReactNode} children - Child components
85
+ * @property {() => Promise<boolean> | boolean} [checkAuthFn] - Function to check if user is authenticated
86
+ * @property {() => void} [signOutFn] - Function to handle logout
87
+ * @property {Partial<AuthState>} [initialAuthState] - Initial authentication state
88
+ * @property {() => AuthUser | null | undefined} [getUserFn] - Function to get user data
89
+ * @property {() => SessionInfo | null | undefined} [getSessionFn] - Function to get session info
90
+ * @property {() => AuthTokens | null | undefined} [getTokensFn] - Function to get tokens
91
+ */
92
+ interface AuthProviderProps {
93
+ children: ReactNode;
94
+ /**
95
+ * Função para verificar se o usuário está autenticado
96
+ * Deve retornar uma Promise<boolean>
97
+ */
98
+ checkAuthFn?: () => Promise<boolean> | boolean;
99
+ /**
100
+ * Função para fazer logout
101
+ */
102
+ signOutFn?: () => void;
103
+ /**
104
+ * Estado de autenticação inicial
105
+ */
106
+ initialAuthState?: Partial<AuthState>;
107
+ /**
108
+ * Função para obter dados do usuário (opcional)
109
+ */
110
+ getUserFn?: () => AuthUser | null | undefined;
111
+ /**
112
+ * Função para obter informações da sessão (opcional)
113
+ */
114
+ getSessionFn?: () => SessionInfo | null | undefined;
115
+ /**
116
+ * Função para obter tokens (opcional)
117
+ */
118
+ getTokensFn?: () => AuthTokens | null | undefined;
119
+ }
120
+ /**
121
+ * Authentication provider that manages global auth state
122
+ * Compatible with any store (Zustand, Redux, Context, etc.)
123
+ *
124
+ * @param {AuthProviderProps} props - The provider props
125
+ * @returns {JSX.Element} The provider component
126
+ *
127
+ * @example
128
+ * ```tsx
129
+ * <AuthProvider
130
+ * checkAuthFn={checkAuthFunction}
131
+ * signOutFn={signOutFunction}
132
+ * getUserFn={getUserFunction}
133
+ * >
134
+ * <App />
135
+ * </AuthProvider>
136
+ * ```
137
+ */
138
+ declare const AuthProvider: ({ children, checkAuthFn, signOutFn, initialAuthState, getUserFn, getSessionFn, getTokensFn, }: AuthProviderProps) => react_jsx_runtime.JSX.Element;
139
+ /**
140
+ * Hook to use the authentication context
141
+ *
142
+ * @throws {Error} When used outside of AuthProvider
143
+ * @returns {AuthContextType} The authentication context
144
+ *
145
+ * @example
146
+ * ```tsx
147
+ * const { isAuthenticated, user, signOut } = useAuth();
148
+ * ```
149
+ */
150
+ declare const useAuth: () => AuthContextType;
151
+ /**
152
+ * Props for the ProtectedRoute component
153
+ *
154
+ * @interface ProtectedRouteProps
155
+ * @property {ReactNode} children - Components to render when authenticated
156
+ * @property {string} [redirectTo] - Path to redirect when not authenticated (default: '/')
157
+ * @property {ReactNode} [loadingComponent] - Custom loading component
158
+ * @property {(authState: AuthState) => boolean} [additionalCheck] - Additional authentication check
159
+ */
160
+ interface ProtectedRouteProps {
161
+ children: ReactNode;
162
+ /**
163
+ * Path para redirecionamento quando não autenticado
164
+ */
165
+ redirectTo?: string;
166
+ /**
167
+ * Componente de loading personalizado
168
+ */
169
+ loadingComponent?: ReactNode;
170
+ /**
171
+ * Função adicional de verificação (ex: verificar permissões específicas)
172
+ */
173
+ additionalCheck?: (authState: AuthState) => boolean;
174
+ }
175
+ /**
176
+ * Componente para proteger rotas que requerem autenticação
177
+ *
178
+ * @example
179
+ * ```tsx
180
+ * <ProtectedRoute redirectTo="/login">
181
+ * <PainelPage />
182
+ * </ProtectedRoute>
183
+ * ```
184
+ */
185
+ declare const ProtectedRoute: ({ children, redirectTo, loadingComponent, additionalCheck, }: ProtectedRouteProps) => react_jsx_runtime.JSX.Element | null;
186
+ /**
187
+ * Props for the PublicRoute component
188
+ *
189
+ * @interface PublicRouteProps
190
+ * @property {ReactNode} children - Components to render
191
+ * @property {string} [redirectTo] - Path to redirect to (default: '/painel')
192
+ * @property {boolean} [redirectIfAuthenticated] - Whether to redirect if authenticated
193
+ * @property {boolean} [checkAuthBeforeRender] - Whether to check auth before rendering
194
+ */
195
+ interface PublicRouteProps {
196
+ children: ReactNode;
197
+ /**
198
+ * Path para redirecionamento
199
+ */
200
+ redirectTo?: string;
201
+ /**
202
+ * Se deve redirecionar quando usuário estiver autenticado
203
+ */
204
+ redirectIfAuthenticated?: boolean;
205
+ /**
206
+ * Se deve verificar autenticação antes de renderizar
207
+ */
208
+ checkAuthBeforeRender?: boolean;
209
+ }
210
+ /**
211
+ * Componente para rotas públicas (login, recuperação de senha, etc.)
212
+ * Opcionalmente redireciona se o usuário já estiver autenticado
213
+ *
214
+ * @example
215
+ * ```tsx
216
+ * <PublicRoute redirectTo="/painel" redirectIfAuthenticated={true}>
217
+ * <LoginPage />
218
+ * </PublicRoute>
219
+ * ```
220
+ */
221
+ declare const PublicRoute: ({ children, redirectTo, redirectIfAuthenticated, checkAuthBeforeRender, }: PublicRouteProps) => react_jsx_runtime.JSX.Element;
222
+ /**
223
+ * Higher-Order Component to protect components with authentication
224
+ *
225
+ * @template P - Component props type
226
+ * @param {ComponentType<P>} Component - Component to wrap with authentication
227
+ * @param {Omit<ProtectedRouteProps, 'children'>} [options] - Protection options
228
+ * @returns {(props: P) => JSX.Element} Wrapped component
229
+ *
230
+ * @example
231
+ * ```tsx
232
+ * const ProtectedComponent = withAuth(MyComponent, {
233
+ * redirectTo: "/login",
234
+ * loadingComponent: <CustomSpinner />
235
+ * });
236
+ * ```
237
+ */
238
+ declare const withAuth: <P extends object>(Component: ComponentType<P>, options?: Omit<ProtectedRouteProps, "children">) => (props: P) => react_jsx_runtime.JSX.Element;
239
+ /**
240
+ * Hook for authentication guard with custom checks
241
+ *
242
+ * @param {object} [options] - Guard options
243
+ * @param {boolean} [options.requireAuth=true] - Whether authentication is required
244
+ * @param {(authState: AuthState) => boolean} [options.customCheck] - Custom check function
245
+ * @returns {object} Guard result with canAccess, isLoading, and authState
246
+ *
247
+ * @example
248
+ * ```tsx
249
+ * const { canAccess, isLoading } = useAuthGuard({
250
+ * requireAuth: true,
251
+ * customCheck: (authState) => authState.user?.role === 'admin'
252
+ * });
253
+ * ```
254
+ */
255
+ declare const useAuthGuard: (options?: {
256
+ requireAuth?: boolean;
257
+ customCheck?: (authState: AuthState) => boolean;
258
+ }) => {
259
+ canAccess: boolean;
260
+ isLoading: boolean;
261
+ authState: AuthContextType;
262
+ };
263
+ /**
264
+ * Hook to check authentication on specific routes
265
+ * Useful for conditional checks within components
266
+ *
267
+ * @param {string} [fallbackPath='/'] - Path to redirect when not authenticated
268
+ * @returns {object} Object with isAuthenticated, isLoading, and redirectToLogin function
269
+ *
270
+ * @example
271
+ * ```tsx
272
+ * const { isAuthenticated, redirectToLogin } = useRouteAuth();
273
+ *
274
+ * if (!isAuthenticated) {
275
+ * return redirectToLogin();
276
+ * }
277
+ * ```
278
+ */
279
+ declare const useRouteAuth: (fallbackPath?: string) => {
280
+ isAuthenticated: boolean;
281
+ isLoading: boolean;
282
+ redirectToLogin: () => react_jsx_runtime.JSX.Element;
283
+ };
284
+ /**
285
+ * Get the root domain from the current window location
286
+ * Handles localhost and subdomain cases
287
+ *
288
+ * @returns {string} The root domain URL
289
+ */
290
+ declare const getRootDomain: () => string;
291
+ declare const _default: {
292
+ AuthProvider: ({ children, checkAuthFn, signOutFn, initialAuthState, getUserFn, getSessionFn, getTokensFn, }: AuthProviderProps) => react_jsx_runtime.JSX.Element;
293
+ ProtectedRoute: ({ children, redirectTo, loadingComponent, additionalCheck, }: ProtectedRouteProps) => react_jsx_runtime.JSX.Element | null;
294
+ PublicRoute: ({ children, redirectTo, redirectIfAuthenticated, checkAuthBeforeRender, }: PublicRouteProps) => react_jsx_runtime.JSX.Element;
295
+ withAuth: <P extends object>(Component: ComponentType<P>, options?: Omit<ProtectedRouteProps, "children">) => (props: P) => react_jsx_runtime.JSX.Element;
296
+ useAuth: () => AuthContextType;
297
+ useAuthGuard: (options?: {
298
+ requireAuth?: boolean;
299
+ customCheck?: (authState: AuthState) => boolean;
300
+ }) => {
301
+ canAccess: boolean;
302
+ isLoading: boolean;
303
+ authState: AuthContextType;
304
+ };
305
+ useRouteAuth: (fallbackPath?: string) => {
306
+ isAuthenticated: boolean;
307
+ isLoading: boolean;
308
+ redirectToLogin: () => react_jsx_runtime.JSX.Element;
309
+ };
310
+ };
311
+
312
+ export { type AuthContextType, AuthProvider, type AuthProviderProps, type AuthState, type AuthTokens, type AuthUser, ProtectedRoute, type ProtectedRouteProps, PublicRoute, type PublicRouteProps, type SessionInfo, _default as default, getRootDomain, useAuth, useAuthGuard, useRouteAuth, withAuth };
@@ -210,3 +210,4 @@ var Auth_default = {
210
210
  useRouteAuth,
211
211
  withAuth
212
212
  });
213
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/components/Auth/Auth.tsx"],"sourcesContent":["import {\n createContext,\n useContext,\n useEffect,\n useState,\n ReactNode,\n ComponentType,\n useCallback,\n useMemo,\n} from 'react';\nimport { useLocation, Navigate } from 'react-router-dom';\n\n/**\n * Interface for basic authentication tokens\n *\n * @interface AuthTokens\n * @property {string} token - Main authentication token\n * @property {string} refreshToken - Token used to refresh the main token\n * @property {unknown} [key] - Additional properties that can be included\n */\nexport interface AuthTokens {\n token: string;\n refreshToken: string;\n [key: string]: unknown;\n}\n\n/**\n * Interface for basic user information\n *\n * @interface AuthUser\n * @property {string} id - Unique user identifier\n * @property {string} [name] - Optional user name\n * @property {string} [email] - Optional user email\n * @property {unknown} [key] - Additional user properties\n */\nexport interface AuthUser {\n id: string;\n name?: string;\n email?: string;\n [key: string]: unknown;\n}\n\n/**\n * Interface for basic session information\n *\n * @interface SessionInfo\n * @property {string} [institutionId] - Optional institution identifier\n * @property {string} [profileId] - Optional profile identifier\n * @property {string} [schoolId] - Optional school identifier\n * @property {string} [schoolYearId] - Optional school year identifier\n * @property {string} [classId] - Optional class identifier\n * @property {unknown} [key] - Additional session properties\n */\nexport interface SessionInfo {\n institutionId?: string;\n profileId?: string;\n schoolId?: string;\n schoolYearId?: string;\n classId?: string;\n [key: string]: unknown;\n}\n\n/**\n * Interface for authentication state\n *\n * @interface AuthState\n * @property {boolean} isAuthenticated - Whether the user is authenticated\n * @property {boolean} isLoading - Whether authentication is being checked\n * @property {AuthUser | null} [user] - Current user information\n * @property {SessionInfo | null} [sessionInfo] - Current session information\n * @property {AuthTokens | null} [tokens] - Current authentication tokens\n */\nexport interface AuthState {\n isAuthenticated: boolean;\n isLoading: boolean;\n user?: AuthUser | null;\n sessionInfo?: SessionInfo | null;\n tokens?: AuthTokens | null;\n}\n\n/**\n * Interface for authentication context functions and state\n *\n * @interface AuthContextType\n * @extends {AuthState}\n * @property {() => Promise<boolean>} checkAuth - Function to check authentication status\n * @property {() => void} signOut - Function to sign out the user\n */\nexport interface AuthContextType extends AuthState {\n checkAuth: () => Promise<boolean>;\n signOut: () => void;\n}\n\n/**\n * Authentication context for React components\n *\n * @private\n */\nconst AuthContext = createContext<AuthContextType | undefined>(undefined);\n\n/**\n * Props for the AuthProvider component\n *\n * @interface AuthProviderProps\n * @property {ReactNode} children - Child components\n * @property {() => Promise<boolean> | boolean} [checkAuthFn] - Function to check if user is authenticated\n * @property {() => void} [signOutFn] - Function to handle logout\n * @property {Partial<AuthState>} [initialAuthState] - Initial authentication state\n * @property {() => AuthUser | null | undefined} [getUserFn] - Function to get user data\n * @property {() => SessionInfo | null | undefined} [getSessionFn] - Function to get session info\n * @property {() => AuthTokens | null | undefined} [getTokensFn] - Function to get tokens\n */\nexport interface AuthProviderProps {\n children: ReactNode;\n /**\n * Função para verificar se o usuário está autenticado\n * Deve retornar uma Promise<boolean>\n */\n checkAuthFn?: () => Promise<boolean> | boolean;\n /**\n * Função para fazer logout\n */\n signOutFn?: () => void;\n /**\n * Estado de autenticação inicial\n */\n initialAuthState?: Partial<AuthState>;\n /**\n * Função para obter dados do usuário (opcional)\n */\n getUserFn?: () => AuthUser | null | undefined;\n /**\n * Função para obter informações da sessão (opcional)\n */\n getSessionFn?: () => SessionInfo | null | undefined;\n /**\n * Função para obter tokens (opcional)\n */\n getTokensFn?: () => AuthTokens | null | undefined;\n}\n\n/**\n * Authentication provider that manages global auth state\n * Compatible with any store (Zustand, Redux, Context, etc.)\n *\n * @param {AuthProviderProps} props - The provider props\n * @returns {JSX.Element} The provider component\n *\n * @example\n * ```tsx\n * <AuthProvider\n * checkAuthFn={checkAuthFunction}\n * signOutFn={signOutFunction}\n * getUserFn={getUserFunction}\n * >\n * <App />\n * </AuthProvider>\n * ```\n */\nexport const AuthProvider = ({\n children,\n checkAuthFn,\n signOutFn,\n initialAuthState = {},\n getUserFn,\n getSessionFn,\n getTokensFn,\n}: AuthProviderProps) => {\n const [authState, setAuthState] = useState<AuthState>({\n isAuthenticated: false,\n isLoading: true,\n ...initialAuthState,\n });\n\n /**\n * Check authentication status and update state accordingly\n *\n * @returns {Promise<boolean>} Promise that resolves to authentication status\n */\n const checkAuth = useCallback(async (): Promise<boolean> => {\n try {\n setAuthState((prev) => ({ ...prev, isLoading: true }));\n\n // Se não há função de verificação, assume como não autenticado\n if (!checkAuthFn) {\n setAuthState((prev) => ({\n ...prev,\n isAuthenticated: false,\n isLoading: false,\n }));\n return false;\n }\n\n const isAuth = await checkAuthFn();\n\n setAuthState((prev) => ({\n ...prev,\n isAuthenticated: isAuth,\n isLoading: false,\n user: getUserFn ? getUserFn() : prev.user,\n sessionInfo: getSessionFn ? getSessionFn() : prev.sessionInfo,\n tokens: getTokensFn ? getTokensFn() : prev.tokens,\n }));\n\n return isAuth;\n } catch (error) {\n console.error('Erro ao verificar autenticação:', error);\n setAuthState((prev) => ({\n ...prev,\n isAuthenticated: false,\n isLoading: false,\n }));\n return false;\n }\n }, [checkAuthFn, getUserFn, getSessionFn, getTokensFn]);\n\n /**\n * Sign out the current user and clear auth state\n *\n * @returns {void}\n */\n const signOut = useCallback(() => {\n if (signOutFn) {\n signOutFn();\n }\n setAuthState((prev) => ({\n ...prev,\n isAuthenticated: false,\n user: undefined,\n sessionInfo: undefined,\n tokens: undefined,\n }));\n }, [signOutFn]);\n\n useEffect(() => {\n checkAuth();\n }, [checkAuth]);\n\n const contextValue = useMemo(\n (): AuthContextType => ({\n ...authState,\n checkAuth,\n signOut,\n }),\n [authState, checkAuth, signOut]\n );\n\n return (\n <AuthContext.Provider value={contextValue}>{children}</AuthContext.Provider>\n );\n};\n\n/**\n * Hook to use the authentication context\n *\n * @throws {Error} When used outside of AuthProvider\n * @returns {AuthContextType} The authentication context\n *\n * @example\n * ```tsx\n * const { isAuthenticated, user, signOut } = useAuth();\n * ```\n */\nexport const useAuth = (): AuthContextType => {\n const context = useContext(AuthContext);\n if (context === undefined) {\n throw new Error('useAuth deve ser usado dentro de um AuthProvider');\n }\n return context;\n};\n\n/**\n * Props for the ProtectedRoute component\n *\n * @interface ProtectedRouteProps\n * @property {ReactNode} children - Components to render when authenticated\n * @property {string} [redirectTo] - Path to redirect when not authenticated (default: '/')\n * @property {ReactNode} [loadingComponent] - Custom loading component\n * @property {(authState: AuthState) => boolean} [additionalCheck] - Additional authentication check\n */\nexport interface ProtectedRouteProps {\n children: ReactNode;\n /**\n * Path para redirecionamento quando não autenticado\n */\n redirectTo?: string;\n /**\n * Componente de loading personalizado\n */\n loadingComponent?: ReactNode;\n /**\n * Função adicional de verificação (ex: verificar permissões específicas)\n */\n additionalCheck?: (authState: AuthState) => boolean;\n}\n\n/**\n * Componente para proteger rotas que requerem autenticação\n *\n * @example\n * ```tsx\n * <ProtectedRoute redirectTo=\"/login\">\n * <PainelPage />\n * </ProtectedRoute>\n * ```\n */\nexport const ProtectedRoute = ({\n children,\n redirectTo = '/',\n loadingComponent,\n additionalCheck,\n}: ProtectedRouteProps) => {\n const { isAuthenticated, isLoading, ...authState } = useAuth();\n\n // Componente de loading padrão\n const defaultLoadingComponent = (\n <div className=\"flex items-center justify-center min-h-screen\">\n <div className=\"text-text-950 text-lg\">Carregando...</div>\n </div>\n );\n\n // Mostrar loading enquanto verifica autenticação\n if (isLoading) {\n return <>{loadingComponent || defaultLoadingComponent}</>;\n }\n\n // Verificar autenticação básica\n if (!isAuthenticated) {\n if (typeof window !== 'undefined') {\n const rootDomain = getRootDomain();\n // Only redirect if the root domain is different from current location\n const currentLocation = `${window.location.protocol}//${window.location.hostname}${window.location.port ? ':' + window.location.port : ''}`;\n if (rootDomain !== currentLocation) {\n window.location.href = rootDomain;\n return null;\n }\n }\n return <Navigate to={redirectTo} replace />;\n }\n\n // Verificação adicional (ex: permissões)\n if (\n additionalCheck &&\n !additionalCheck({ isAuthenticated, isLoading, ...authState })\n ) {\n return <Navigate to={redirectTo} replace />;\n }\n\n return <>{children}</>;\n};\n\n/**\n * Props for the PublicRoute component\n *\n * @interface PublicRouteProps\n * @property {ReactNode} children - Components to render\n * @property {string} [redirectTo] - Path to redirect to (default: '/painel')\n * @property {boolean} [redirectIfAuthenticated] - Whether to redirect if authenticated\n * @property {boolean} [checkAuthBeforeRender] - Whether to check auth before rendering\n */\nexport interface PublicRouteProps {\n children: ReactNode;\n /**\n * Path para redirecionamento\n */\n redirectTo?: string;\n /**\n * Se deve redirecionar quando usuário estiver autenticado\n */\n redirectIfAuthenticated?: boolean;\n /**\n * Se deve verificar autenticação antes de renderizar\n */\n checkAuthBeforeRender?: boolean;\n}\n\n/**\n * Componente para rotas públicas (login, recuperação de senha, etc.)\n * Opcionalmente redireciona se o usuário já estiver autenticado\n *\n * @example\n * ```tsx\n * <PublicRoute redirectTo=\"/painel\" redirectIfAuthenticated={true}>\n * <LoginPage />\n * </PublicRoute>\n * ```\n */\nexport const PublicRoute = ({\n children,\n redirectTo = '/painel',\n redirectIfAuthenticated = false,\n checkAuthBeforeRender = false,\n}: PublicRouteProps) => {\n const { isAuthenticated, isLoading } = useAuth();\n\n // Se deve aguardar verificação de auth antes de renderizar\n if (checkAuthBeforeRender && isLoading) {\n return (\n <div className=\"flex items-center justify-center min-h-screen\">\n <div className=\"text-text-950 text-lg\">Carregando...</div>\n </div>\n );\n }\n\n // Redirecionar se já autenticado e configurado para isso\n if (isAuthenticated && redirectIfAuthenticated) {\n return <Navigate to={redirectTo} replace />;\n }\n\n return <>{children}</>;\n};\n\n/**\n * Higher-Order Component to protect components with authentication\n *\n * @template P - Component props type\n * @param {ComponentType<P>} Component - Component to wrap with authentication\n * @param {Omit<ProtectedRouteProps, 'children'>} [options] - Protection options\n * @returns {(props: P) => JSX.Element} Wrapped component\n *\n * @example\n * ```tsx\n * const ProtectedComponent = withAuth(MyComponent, {\n * redirectTo: \"/login\",\n * loadingComponent: <CustomSpinner />\n * });\n * ```\n */\nexport const withAuth = <P extends object>(\n Component: ComponentType<P>,\n options: Omit<ProtectedRouteProps, 'children'> = {}\n) => {\n return (props: P) => (\n <ProtectedRoute {...options}>\n <Component {...props} />\n </ProtectedRoute>\n );\n};\n\n/**\n * Hook for authentication guard with custom checks\n *\n * @param {object} [options] - Guard options\n * @param {boolean} [options.requireAuth=true] - Whether authentication is required\n * @param {(authState: AuthState) => boolean} [options.customCheck] - Custom check function\n * @returns {object} Guard result with canAccess, isLoading, and authState\n *\n * @example\n * ```tsx\n * const { canAccess, isLoading } = useAuthGuard({\n * requireAuth: true,\n * customCheck: (authState) => authState.user?.role === 'admin'\n * });\n * ```\n */\nexport const useAuthGuard = (\n options: {\n requireAuth?: boolean;\n customCheck?: (authState: AuthState) => boolean;\n } = {}\n) => {\n const authState = useAuth();\n const { requireAuth = true, customCheck } = options;\n\n const canAccess =\n !authState.isLoading &&\n (requireAuth\n ? authState.isAuthenticated && (!customCheck || customCheck(authState))\n : !authState.isAuthenticated || !customCheck || customCheck(authState));\n\n return {\n canAccess,\n isLoading: authState.isLoading,\n authState,\n };\n};\n\n/**\n * Hook to check authentication on specific routes\n * Useful for conditional checks within components\n *\n * @param {string} [fallbackPath='/'] - Path to redirect when not authenticated\n * @returns {object} Object with isAuthenticated, isLoading, and redirectToLogin function\n *\n * @example\n * ```tsx\n * const { isAuthenticated, redirectToLogin } = useRouteAuth();\n *\n * if (!isAuthenticated) {\n * return redirectToLogin();\n * }\n * ```\n */\nexport const useRouteAuth = (fallbackPath = '/') => {\n const { isAuthenticated, isLoading } = useAuth();\n const location = useLocation();\n\n const redirectToLogin = () => (\n <Navigate to={fallbackPath} state={{ from: location }} replace />\n );\n\n return {\n isAuthenticated,\n isLoading,\n redirectToLogin,\n };\n};\n\n/**\n * Get the root domain from the current window location\n * Handles localhost and subdomain cases\n *\n * @returns {string} The root domain URL\n */\nexport const getRootDomain = () => {\n const { hostname, protocol, port } = window.location;\n const portStr = port ? ':' + port : '';\n if (hostname === 'localhost') {\n return `${protocol}//${hostname}${portStr}`;\n }\n const parts = hostname.split('.');\n // Only treat as subdomain if there are 3+ parts (e.g., subdomain.example.com)\n if (parts.length > 2) {\n // Return the last 2 parts as the root domain (example.com)\n const base = parts.slice(-2).join('.');\n return `${protocol}//${base}${portStr}`;\n }\n // For 2-part domains (example.com) or single domains, return as-is\n return `${protocol}//${hostname}${portStr}`;\n};\n\nexport default {\n AuthProvider,\n ProtectedRoute,\n PublicRoute,\n withAuth,\n useAuth,\n useAuthGuard,\n useRouteAuth,\n};\n"],"mappings":"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","names":[]}
@@ -185,3 +185,4 @@ export {
185
185
  useRouteAuth,
186
186
  withAuth
187
187
  };
188
+ //# sourceMappingURL=index.mjs.map