@riligar/auth-react 1.5.0 → 1.6.0

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/index.esm.js CHANGED
@@ -271,6 +271,17 @@ const getSession = async () => {
271
271
  return await api('/auth/session');
272
272
  };
273
273
 
274
+ /*--- Application Info ----------------------------*/
275
+ const getApplicationInfo = async () => {
276
+ try {
277
+ const data = await api('/application/by-api-key');
278
+ return data?.data || null;
279
+ } catch (error) {
280
+ console.warn('[AuthSDK] Failed to fetch application info:', error.message);
281
+ return null;
282
+ }
283
+ };
284
+
274
285
  /* Social login redirect (ex.: Google) -----------*/
275
286
  function socialRedirect(provider, redirectTo = typeof window !== 'undefined' ? window.location.href : '/') {
276
287
  if (typeof window === 'undefined') return;
@@ -334,6 +345,8 @@ const useAuthStore = create((set, get) => ({
334
345
  verifyEmail: false,
335
346
  resendVerification: false
336
347
  },
348
+ // Application info (logo, nome, etc)
349
+ applicationInfo: null,
337
350
  // Helper para atualizar loading states
338
351
  setLoading: (key, value) => set(state => ({
339
352
  loadingStates: {
@@ -341,9 +354,29 @@ const useAuthStore = create((set, get) => ({
341
354
  [key]: value
342
355
  }
343
356
  })),
357
+ // Buscar informações da aplicação
358
+ fetchApplicationInfo: async () => {
359
+ try {
360
+ const appInfo = await getApplicationInfo();
361
+ set({
362
+ applicationInfo: appInfo
363
+ });
364
+ } catch (error) {
365
+ console.warn('[AuthStore] Failed to fetch application info:', error);
366
+ set({
367
+ applicationInfo: null
368
+ });
369
+ }
370
+ },
344
371
  /* Init ao montar o Provider */
345
372
  init: async () => {
373
+ const {
374
+ fetchApplicationInfo
375
+ } = get();
346
376
  try {
377
+ // Buscar application info primeiro (não bloqueia o init)
378
+ fetchApplicationInfo();
379
+
347
380
  // Verifica se há um token válido
348
381
  if (isAuthenticated()) {
349
382
  // Tenta extrair usuário do token (JWT)
@@ -862,6 +895,13 @@ const useSession = () => useAuthStore(useShallow(s => ({
862
895
  // Loading States Hook
863
896
  const useAuthLoading = () => useAuthStore(s => s.loadingStates);
864
897
 
898
+ // Application Logo Hook
899
+ const useApplicationLogo = () => {
900
+ const applicationInfo = useAuthStore(s => s.applicationInfo);
901
+ // Retorna o logo da aplicação ou null (componentes usam fallback padrão)
902
+ return applicationInfo?.image || null;
903
+ };
904
+
865
905
  function ProtectedRoute({
866
906
  fallback = /*#__PURE__*/React.createElement("p", null, "\u231B Carregando..."),
867
907
  redirectTo = "/login"
@@ -897,7 +937,7 @@ function AuthCard({
897
937
  title,
898
938
  subtitle,
899
939
  logo,
900
- logoHeight = 32,
940
+ logoHeight = 28,
901
941
  width = 350,
902
942
  ...props
903
943
  }) {
@@ -932,7 +972,8 @@ var img = "
932
972
  */
933
973
  function SignInForm({
934
974
  // Configuração
935
- logo = img,
975
+ logo,
976
+ // Removido default, será calculado abaixo
936
977
  title = 'Entrar',
937
978
  subtitle = 'Acesse sua conta para continuar',
938
979
  // Features
@@ -958,6 +999,10 @@ function SignInForm({
958
999
  const loadingSignIn = useAuthStore(s => s.loadingStates.signIn);
959
1000
  const loadingMagicLink = useAuthStore(s => s.loadingStates.magicLink);
960
1001
  const loadingResetPassword = useAuthStore(s => s.loadingStates.resetPassword);
1002
+
1003
+ // Hook para buscar logo da aplicação
1004
+ const applicationLogo = useApplicationLogo();
1005
+ const finalLogo = logo || applicationLogo || img;
961
1006
  const form = useForm({
962
1007
  initialValues: {
963
1008
  email: '',
@@ -1002,7 +1047,7 @@ function SignInForm({
1002
1047
  };
1003
1048
  const isLoading = loadingSignIn || loadingMagicLink || loadingResetPassword;
1004
1049
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1005
- logo: logo,
1050
+ logo: finalLogo,
1006
1051
  title: title,
1007
1052
  subtitle: subtitle
1008
1053
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1080,7 +1125,7 @@ function SignInForm({
1080
1125
  */
1081
1126
  function SignUpForm({
1082
1127
  // Configuração
1083
- logo = img,
1128
+ logo,
1084
1129
  title = 'Criar Conta',
1085
1130
  subtitle = 'Preencha os dados para se cadastrar',
1086
1131
  // Features
@@ -1099,6 +1144,10 @@ function SignUpForm({
1099
1144
  }) {
1100
1145
  const signUp = useAuthStore(s => s.signUp);
1101
1146
  const loading = useAuthStore(s => s.loadingStates.signUp);
1147
+
1148
+ // Hook para buscar logo da aplicação
1149
+ const applicationLogo = useApplicationLogo();
1150
+ const finalLogo = logo || applicationLogo || img;
1102
1151
  const form = useForm({
1103
1152
  initialValues: {
1104
1153
  name: '',
@@ -1122,7 +1171,7 @@ function SignUpForm({
1122
1171
  }
1123
1172
  };
1124
1173
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1125
- logo: logo,
1174
+ logo: finalLogo,
1126
1175
  title: title,
1127
1176
  subtitle: subtitle
1128
1177
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1199,7 +1248,7 @@ function SignUpForm({
1199
1248
  */
1200
1249
  function MagicLinkForm({
1201
1250
  // Configuração
1202
- logo = img,
1251
+ logo,
1203
1252
  title = 'Login sem Senha',
1204
1253
  subtitle = 'Receba um link de acesso no seu email',
1205
1254
  // Features
@@ -1215,6 +1264,10 @@ function MagicLinkForm({
1215
1264
  }) {
1216
1265
  const sendMagicLink = useAuthStore(s => s.sendMagicLink);
1217
1266
  const loading = useAuthStore(s => s.loadingStates.magicLink);
1267
+
1268
+ // Hook para buscar logo da aplicação
1269
+ const applicationLogo = useApplicationLogo();
1270
+ const finalLogo = logo || applicationLogo || img;
1218
1271
  const form = useForm({
1219
1272
  initialValues: {
1220
1273
  email: ''
@@ -1232,7 +1285,7 @@ function MagicLinkForm({
1232
1285
  }
1233
1286
  };
1234
1287
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1235
- logo: logo,
1288
+ logo: finalLogo,
1236
1289
  title: title,
1237
1290
  subtitle: subtitle
1238
1291
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1268,7 +1321,7 @@ function MagicLinkForm({
1268
1321
  */
1269
1322
  function MagicLinkVerify({
1270
1323
  // Configuração
1271
- logo = img,
1324
+ logo,
1272
1325
  // Token pode ser passado diretamente ou extraído da URL
1273
1326
  token: propToken,
1274
1327
  // Callbacks
@@ -1284,6 +1337,10 @@ function MagicLinkVerify({
1284
1337
  const [status, setStatus] = useState('verifying'); // verifying, success, error
1285
1338
  const [errorMessage, setErrorMessage] = useState('');
1286
1339
  const verifyMagicLink = useAuthStore(s => s.verifyMagicLink);
1340
+
1341
+ // Hook para buscar logo da aplicação
1342
+ const applicationLogo = useApplicationLogo();
1343
+ const finalLogo = logo || applicationLogo || img;
1287
1344
  const verifyingTokenRef = useRef(null);
1288
1345
  useEffect(() => {
1289
1346
  const verify = async () => {
@@ -1322,7 +1379,7 @@ function MagicLinkVerify({
1322
1379
  // eslint-disable-next-line react-hooks/exhaustive-deps
1323
1380
  }, [propToken, redirectTo, redirectDelay]);
1324
1381
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1325
- logo: logo
1382
+ logo: finalLogo
1326
1383
  }, cardProps), status === 'verifying' && /*#__PURE__*/React.createElement(Stack, {
1327
1384
  align: "center",
1328
1385
  gap: "sm"
@@ -1366,7 +1423,7 @@ function MagicLinkVerify({
1366
1423
  */
1367
1424
  function ForgotPasswordForm({
1368
1425
  // Configuração
1369
- logo = img,
1426
+ logo,
1370
1427
  title = 'Recuperar Senha',
1371
1428
  subtitle = 'Enviaremos um link para redefinir sua senha',
1372
1429
  // Features
@@ -1382,6 +1439,10 @@ function ForgotPasswordForm({
1382
1439
  }) {
1383
1440
  const forgotPassword = useAuthStore(s => s.forgotPassword);
1384
1441
  const loading = useAuthStore(s => s.loadingStates.resetPassword);
1442
+
1443
+ // Hook para buscar logo da aplicação
1444
+ const applicationLogo = useApplicationLogo();
1445
+ const finalLogo = logo || applicationLogo || img;
1385
1446
  const form = useForm({
1386
1447
  initialValues: {
1387
1448
  email: ''
@@ -1399,7 +1460,7 @@ function ForgotPasswordForm({
1399
1460
  }
1400
1461
  };
1401
1462
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1402
- logo: logo,
1463
+ logo: finalLogo,
1403
1464
  title: title,
1404
1465
  subtitle: subtitle
1405
1466
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1434,7 +1495,7 @@ function ForgotPasswordForm({
1434
1495
  */
1435
1496
  function ResetPasswordForm({
1436
1497
  // Configuração
1437
- logo = img,
1498
+ logo,
1438
1499
  title = 'Nova Senha',
1439
1500
  subtitle = 'Crie uma nova senha para sua conta',
1440
1501
  // Token pode ser passado diretamente ou extraído da URL
@@ -1453,6 +1514,10 @@ function ResetPasswordForm({
1453
1514
  const resetPassword = useAuthStore(s => s.resetPassword);
1454
1515
  const loading = useAuthStore(s => s.loadingStates.resetPassword);
1455
1516
 
1517
+ // Hook para buscar logo da aplicação
1518
+ const applicationLogo = useApplicationLogo();
1519
+ const finalLogo = logo || applicationLogo || img;
1520
+
1456
1521
  // Extrai token da URL se não foi passado como prop
1457
1522
  useEffect(() => {
1458
1523
  if (!propToken && typeof window !== 'undefined') {
@@ -1486,7 +1551,7 @@ function ResetPasswordForm({
1486
1551
  };
1487
1552
  if (success) {
1488
1553
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1489
- logo: logo
1554
+ logo: finalLogo
1490
1555
  }, cardProps), /*#__PURE__*/React.createElement(Stack, {
1491
1556
  align: "center",
1492
1557
  gap: "sm"
@@ -1507,7 +1572,7 @@ function ResetPasswordForm({
1507
1572
  }
1508
1573
  if (!token) {
1509
1574
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1510
- logo: logo
1575
+ logo: finalLogo
1511
1576
  }, cardProps), /*#__PURE__*/React.createElement(Stack, {
1512
1577
  align: "center",
1513
1578
  gap: "sm"
@@ -1521,7 +1586,7 @@ function ResetPasswordForm({
1521
1586
  }, labels.goToSignIn || 'Voltar para Login')));
1522
1587
  }
1523
1588
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1524
- logo: logo,
1589
+ logo: finalLogo,
1525
1590
  title: title,
1526
1591
  subtitle: subtitle
1527
1592
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1557,7 +1622,7 @@ function ResetPasswordForm({
1557
1622
  */
1558
1623
  function VerifyEmailCard({
1559
1624
  // Configuração
1560
- logo = img,
1625
+ logo,
1561
1626
  // Token pode ser passado diretamente ou extraído da URL
1562
1627
  token: propToken,
1563
1628
  // Email para reenvio (opcional)
@@ -1582,6 +1647,10 @@ function VerifyEmailCard({
1582
1647
  const loadingResend = useAuthStore(s => s.loadingStates.resendVerification);
1583
1648
  const user = useAuthStore(s => s.user);
1584
1649
  const verifyingTokenRef = useRef(null);
1650
+
1651
+ // Hook para buscar logo da aplicação
1652
+ const applicationLogo = useApplicationLogo();
1653
+ const finalLogo = logo || applicationLogo || img;
1585
1654
  useEffect(() => {
1586
1655
  const verify = async () => {
1587
1656
  // Pega token da prop ou da URL
@@ -1641,7 +1710,7 @@ function VerifyEmailCard({
1641
1710
  }
1642
1711
  };
1643
1712
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1644
- logo: logo
1713
+ logo: finalLogo
1645
1714
  }, cardProps), status === 'verifying' && /*#__PURE__*/React.createElement(Stack, {
1646
1715
  align: "center",
1647
1716
  gap: "sm"
@@ -1700,5 +1769,5 @@ function VerifyEmailCard({
1700
1769
  }, labels.resend || 'Solicitar novo link')));
1701
1770
  }
1702
1771
 
1703
- export { AuthCard, AuthProvider, ForgotPasswordForm, MagicLinkForm, MagicLinkVerify, ProtectedRoute, ResetPasswordForm, SignInForm, SignUpForm, VerifyEmailCard, configure, decodeJWT, forgotPassword, getCurrentUser, getSession, isAuthenticated, refreshToken, resendVerification, resetPassword, sendMagicLink, signIn, signOut, signUp, socialRedirect, useAuth, useAuthLoading, useAuthStore, useCheckToken, useEmailVerification, useMagicLink, usePasswordReset, useSession, useSignIn, useSignOut, useSignUp, verifyEmail, verifyMagicLink };
1772
+ export { AuthCard, AuthProvider, ForgotPasswordForm, MagicLinkForm, MagicLinkVerify, ProtectedRoute, ResetPasswordForm, SignInForm, SignUpForm, VerifyEmailCard, configure, decodeJWT, forgotPassword, getApplicationInfo, getCurrentUser, getSession, isAuthenticated, refreshToken, resendVerification, resetPassword, sendMagicLink, signIn, signOut, signUp, socialRedirect, useAuth, useAuthLoading, useAuthStore, useCheckToken, useEmailVerification, useMagicLink, usePasswordReset, useSession, useSignIn, useSignOut, useSignUp, verifyEmail, verifyMagicLink };
1704
1773
  //# sourceMappingURL=index.esm.js.map