@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.js CHANGED
@@ -274,6 +274,17 @@ const getSession = async () => {
274
274
  return await api('/auth/session');
275
275
  };
276
276
 
277
+ /*--- Application Info ----------------------------*/
278
+ const getApplicationInfo = async () => {
279
+ try {
280
+ const data = await api('/application/by-api-key');
281
+ return data?.data || null;
282
+ } catch (error) {
283
+ console.warn('[AuthSDK] Failed to fetch application info:', error.message);
284
+ return null;
285
+ }
286
+ };
287
+
277
288
  /* Social login redirect (ex.: Google) -----------*/
278
289
  function socialRedirect(provider, redirectTo = typeof window !== 'undefined' ? window.location.href : '/') {
279
290
  if (typeof window === 'undefined') return;
@@ -337,6 +348,8 @@ const useAuthStore = create((set, get) => ({
337
348
  verifyEmail: false,
338
349
  resendVerification: false
339
350
  },
351
+ // Application info (logo, nome, etc)
352
+ applicationInfo: null,
340
353
  // Helper para atualizar loading states
341
354
  setLoading: (key, value) => set(state => ({
342
355
  loadingStates: {
@@ -344,9 +357,29 @@ const useAuthStore = create((set, get) => ({
344
357
  [key]: value
345
358
  }
346
359
  })),
360
+ // Buscar informações da aplicação
361
+ fetchApplicationInfo: async () => {
362
+ try {
363
+ const appInfo = await getApplicationInfo();
364
+ set({
365
+ applicationInfo: appInfo
366
+ });
367
+ } catch (error) {
368
+ console.warn('[AuthStore] Failed to fetch application info:', error);
369
+ set({
370
+ applicationInfo: null
371
+ });
372
+ }
373
+ },
347
374
  /* Init ao montar o Provider */
348
375
  init: async () => {
376
+ const {
377
+ fetchApplicationInfo
378
+ } = get();
349
379
  try {
380
+ // Buscar application info primeiro (não bloqueia o init)
381
+ fetchApplicationInfo();
382
+
350
383
  // Verifica se há um token válido
351
384
  if (isAuthenticated()) {
352
385
  // Tenta extrair usuário do token (JWT)
@@ -865,6 +898,13 @@ const useSession = () => useAuthStore(useShallow(s => ({
865
898
  // Loading States Hook
866
899
  const useAuthLoading = () => useAuthStore(s => s.loadingStates);
867
900
 
901
+ // Application Logo Hook
902
+ const useApplicationLogo = () => {
903
+ const applicationInfo = useAuthStore(s => s.applicationInfo);
904
+ // Retorna o logo da aplicação ou null (componentes usam fallback padrão)
905
+ return applicationInfo?.image || null;
906
+ };
907
+
868
908
  function ProtectedRoute({
869
909
  fallback = /*#__PURE__*/React.createElement("p", null, "\u231B Carregando..."),
870
910
  redirectTo = "/login"
@@ -900,7 +940,7 @@ function AuthCard({
900
940
  title,
901
941
  subtitle,
902
942
  logo,
903
- logoHeight = 32,
943
+ logoHeight = 28,
904
944
  width = 350,
905
945
  ...props
906
946
  }) {
@@ -935,7 +975,8 @@ var img = "
935
975
  */
936
976
  function SignInForm({
937
977
  // Configuração
938
- logo = img,
978
+ logo,
979
+ // Removido default, será calculado abaixo
939
980
  title = 'Entrar',
940
981
  subtitle = 'Acesse sua conta para continuar',
941
982
  // Features
@@ -961,6 +1002,10 @@ function SignInForm({
961
1002
  const loadingSignIn = useAuthStore(s => s.loadingStates.signIn);
962
1003
  const loadingMagicLink = useAuthStore(s => s.loadingStates.magicLink);
963
1004
  const loadingResetPassword = useAuthStore(s => s.loadingStates.resetPassword);
1005
+
1006
+ // Hook para buscar logo da aplicação
1007
+ const applicationLogo = useApplicationLogo();
1008
+ const finalLogo = logo || applicationLogo || img;
964
1009
  const form$1 = form.useForm({
965
1010
  initialValues: {
966
1011
  email: '',
@@ -1005,7 +1050,7 @@ function SignInForm({
1005
1050
  };
1006
1051
  const isLoading = loadingSignIn || loadingMagicLink || loadingResetPassword;
1007
1052
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1008
- logo: logo,
1053
+ logo: finalLogo,
1009
1054
  title: title,
1010
1055
  subtitle: subtitle
1011
1056
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1083,7 +1128,7 @@ function SignInForm({
1083
1128
  */
1084
1129
  function SignUpForm({
1085
1130
  // Configuração
1086
- logo = img,
1131
+ logo,
1087
1132
  title = 'Criar Conta',
1088
1133
  subtitle = 'Preencha os dados para se cadastrar',
1089
1134
  // Features
@@ -1102,6 +1147,10 @@ function SignUpForm({
1102
1147
  }) {
1103
1148
  const signUp = useAuthStore(s => s.signUp);
1104
1149
  const loading = useAuthStore(s => s.loadingStates.signUp);
1150
+
1151
+ // Hook para buscar logo da aplicação
1152
+ const applicationLogo = useApplicationLogo();
1153
+ const finalLogo = logo || applicationLogo || img;
1105
1154
  const form$1 = form.useForm({
1106
1155
  initialValues: {
1107
1156
  name: '',
@@ -1125,7 +1174,7 @@ function SignUpForm({
1125
1174
  }
1126
1175
  };
1127
1176
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1128
- logo: logo,
1177
+ logo: finalLogo,
1129
1178
  title: title,
1130
1179
  subtitle: subtitle
1131
1180
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1202,7 +1251,7 @@ function SignUpForm({
1202
1251
  */
1203
1252
  function MagicLinkForm({
1204
1253
  // Configuração
1205
- logo = img,
1254
+ logo,
1206
1255
  title = 'Login sem Senha',
1207
1256
  subtitle = 'Receba um link de acesso no seu email',
1208
1257
  // Features
@@ -1218,6 +1267,10 @@ function MagicLinkForm({
1218
1267
  }) {
1219
1268
  const sendMagicLink = useAuthStore(s => s.sendMagicLink);
1220
1269
  const loading = useAuthStore(s => s.loadingStates.magicLink);
1270
+
1271
+ // Hook para buscar logo da aplicação
1272
+ const applicationLogo = useApplicationLogo();
1273
+ const finalLogo = logo || applicationLogo || img;
1221
1274
  const form$1 = form.useForm({
1222
1275
  initialValues: {
1223
1276
  email: ''
@@ -1235,7 +1288,7 @@ function MagicLinkForm({
1235
1288
  }
1236
1289
  };
1237
1290
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1238
- logo: logo,
1291
+ logo: finalLogo,
1239
1292
  title: title,
1240
1293
  subtitle: subtitle
1241
1294
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1271,7 +1324,7 @@ function MagicLinkForm({
1271
1324
  */
1272
1325
  function MagicLinkVerify({
1273
1326
  // Configuração
1274
- logo = img,
1327
+ logo,
1275
1328
  // Token pode ser passado diretamente ou extraído da URL
1276
1329
  token: propToken,
1277
1330
  // Callbacks
@@ -1287,6 +1340,10 @@ function MagicLinkVerify({
1287
1340
  const [status, setStatus] = React$1.useState('verifying'); // verifying, success, error
1288
1341
  const [errorMessage, setErrorMessage] = React$1.useState('');
1289
1342
  const verifyMagicLink = useAuthStore(s => s.verifyMagicLink);
1343
+
1344
+ // Hook para buscar logo da aplicação
1345
+ const applicationLogo = useApplicationLogo();
1346
+ const finalLogo = logo || applicationLogo || img;
1290
1347
  const verifyingTokenRef = React$1.useRef(null);
1291
1348
  React$1.useEffect(() => {
1292
1349
  const verify = async () => {
@@ -1325,7 +1382,7 @@ function MagicLinkVerify({
1325
1382
  // eslint-disable-next-line react-hooks/exhaustive-deps
1326
1383
  }, [propToken, redirectTo, redirectDelay]);
1327
1384
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1328
- logo: logo
1385
+ logo: finalLogo
1329
1386
  }, cardProps), status === 'verifying' && /*#__PURE__*/React.createElement(core.Stack, {
1330
1387
  align: "center",
1331
1388
  gap: "sm"
@@ -1369,7 +1426,7 @@ function MagicLinkVerify({
1369
1426
  */
1370
1427
  function ForgotPasswordForm({
1371
1428
  // Configuração
1372
- logo = img,
1429
+ logo,
1373
1430
  title = 'Recuperar Senha',
1374
1431
  subtitle = 'Enviaremos um link para redefinir sua senha',
1375
1432
  // Features
@@ -1385,6 +1442,10 @@ function ForgotPasswordForm({
1385
1442
  }) {
1386
1443
  const forgotPassword = useAuthStore(s => s.forgotPassword);
1387
1444
  const loading = useAuthStore(s => s.loadingStates.resetPassword);
1445
+
1446
+ // Hook para buscar logo da aplicação
1447
+ const applicationLogo = useApplicationLogo();
1448
+ const finalLogo = logo || applicationLogo || img;
1388
1449
  const form$1 = form.useForm({
1389
1450
  initialValues: {
1390
1451
  email: ''
@@ -1402,7 +1463,7 @@ function ForgotPasswordForm({
1402
1463
  }
1403
1464
  };
1404
1465
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1405
- logo: logo,
1466
+ logo: finalLogo,
1406
1467
  title: title,
1407
1468
  subtitle: subtitle
1408
1469
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1437,7 +1498,7 @@ function ForgotPasswordForm({
1437
1498
  */
1438
1499
  function ResetPasswordForm({
1439
1500
  // Configuração
1440
- logo = img,
1501
+ logo,
1441
1502
  title = 'Nova Senha',
1442
1503
  subtitle = 'Crie uma nova senha para sua conta',
1443
1504
  // Token pode ser passado diretamente ou extraído da URL
@@ -1456,6 +1517,10 @@ function ResetPasswordForm({
1456
1517
  const resetPassword = useAuthStore(s => s.resetPassword);
1457
1518
  const loading = useAuthStore(s => s.loadingStates.resetPassword);
1458
1519
 
1520
+ // Hook para buscar logo da aplicação
1521
+ const applicationLogo = useApplicationLogo();
1522
+ const finalLogo = logo || applicationLogo || img;
1523
+
1459
1524
  // Extrai token da URL se não foi passado como prop
1460
1525
  React$1.useEffect(() => {
1461
1526
  if (!propToken && typeof window !== 'undefined') {
@@ -1489,7 +1554,7 @@ function ResetPasswordForm({
1489
1554
  };
1490
1555
  if (success) {
1491
1556
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1492
- logo: logo
1557
+ logo: finalLogo
1493
1558
  }, cardProps), /*#__PURE__*/React.createElement(core.Stack, {
1494
1559
  align: "center",
1495
1560
  gap: "sm"
@@ -1510,7 +1575,7 @@ function ResetPasswordForm({
1510
1575
  }
1511
1576
  if (!token) {
1512
1577
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1513
- logo: logo
1578
+ logo: finalLogo
1514
1579
  }, cardProps), /*#__PURE__*/React.createElement(core.Stack, {
1515
1580
  align: "center",
1516
1581
  gap: "sm"
@@ -1524,7 +1589,7 @@ function ResetPasswordForm({
1524
1589
  }, labels.goToSignIn || 'Voltar para Login')));
1525
1590
  }
1526
1591
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1527
- logo: logo,
1592
+ logo: finalLogo,
1528
1593
  title: title,
1529
1594
  subtitle: subtitle
1530
1595
  }, cardProps), /*#__PURE__*/React.createElement("form", {
@@ -1560,7 +1625,7 @@ function ResetPasswordForm({
1560
1625
  */
1561
1626
  function VerifyEmailCard({
1562
1627
  // Configuração
1563
- logo = img,
1628
+ logo,
1564
1629
  // Token pode ser passado diretamente ou extraído da URL
1565
1630
  token: propToken,
1566
1631
  // Email para reenvio (opcional)
@@ -1585,6 +1650,10 @@ function VerifyEmailCard({
1585
1650
  const loadingResend = useAuthStore(s => s.loadingStates.resendVerification);
1586
1651
  const user = useAuthStore(s => s.user);
1587
1652
  const verifyingTokenRef = React$1.useRef(null);
1653
+
1654
+ // Hook para buscar logo da aplicação
1655
+ const applicationLogo = useApplicationLogo();
1656
+ const finalLogo = logo || applicationLogo || img;
1588
1657
  React$1.useEffect(() => {
1589
1658
  const verify = async () => {
1590
1659
  // Pega token da prop ou da URL
@@ -1644,7 +1713,7 @@ function VerifyEmailCard({
1644
1713
  }
1645
1714
  };
1646
1715
  return /*#__PURE__*/React.createElement(AuthCard, _extends({
1647
- logo: logo
1716
+ logo: finalLogo
1648
1717
  }, cardProps), status === 'verifying' && /*#__PURE__*/React.createElement(core.Stack, {
1649
1718
  align: "center",
1650
1719
  gap: "sm"
@@ -1716,6 +1785,7 @@ exports.VerifyEmailCard = VerifyEmailCard;
1716
1785
  exports.configure = configure;
1717
1786
  exports.decodeJWT = decodeJWT;
1718
1787
  exports.forgotPassword = forgotPassword;
1788
+ exports.getApplicationInfo = getApplicationInfo;
1719
1789
  exports.getCurrentUser = getCurrentUser;
1720
1790
  exports.getSession = getSession;
1721
1791
  exports.isAuthenticated = isAuthenticated;