@riligar/auth-react 1.10.0 → 1.11.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/README.md CHANGED
@@ -11,115 +11,130 @@ bun add @riligar/auth-react
11
11
  ## Basic Usage
12
12
 
13
13
  ```jsx
14
- import { AuthProvider, useAuth, useSignIn, ProtectedRoute } from '@riligar/auth-react';
14
+ import { AuthProvider, useAuth, useSignIn, Protect, SignedIn, SignedOut, SignIn } from '@riligar/auth-react'
15
15
 
16
16
  // 1. Wrap your app with AuthProvider
17
17
  function App() {
18
- return (
19
- <AuthProvider>
20
- <Routes>
21
- <Route path="/login" element={<Login />} />
22
- <Route element={<ProtectedRoute />}>
23
- <Route path="/" element={<Home />} />
24
- </Route>
25
- </Routes>
26
- </AuthProvider>
27
- );
18
+ return (
19
+ <AuthProvider
20
+ apiUrl="https://your-api.com"
21
+ apiKey="your-api-key"
22
+ >
23
+ <Routes>
24
+ <Route
25
+ path="/login"
26
+ element={<SignIn />}
27
+ />
28
+ <Route element={<Protect />}>
29
+ <Route
30
+ path="/"
31
+ element={<Home />}
32
+ />
33
+ </Route>
34
+ </Routes>
35
+ </AuthProvider>
36
+ )
28
37
  }
29
38
 
30
- // 2. Use hooks in your components
31
- function Login() {
32
- const signIn = useSignIn();
33
-
34
- async function handleSubmit(e) {
35
- e.preventDefault();
36
- const { email, password } = Object.fromEntries(new FormData(e.target));
37
- try {
38
- await signIn(email, password);
39
- } catch (err) {
40
- alert(err.message);
41
- }
42
- }
43
-
44
- return (
45
- <form onSubmit={handleSubmit}>
46
- <input name="email" type="email" placeholder="Email" required />
47
- <input name="password" type="password" placeholder="Password" required />
48
- <button>Sign In</button>
49
- </form>
50
- );
51
- }
52
-
53
- function Home() {
54
- const { user, isAuthenticated } = useAuth();
55
-
56
- if (!isAuthenticated) return <p>Not authenticated</p>;
57
-
58
- return <h1>Hello, {user?.email}!</h1>;
39
+ // 2. Use control components for conditional rendering
40
+ function Header() {
41
+ return (
42
+ <header>
43
+ <SignedIn>
44
+ <UserMenu />
45
+ </SignedIn>
46
+ <SignedOut>
47
+ <SignInButton />
48
+ </SignedOut>
49
+ </header>
50
+ )
59
51
  }
60
52
  ```
61
53
 
62
- ## Features
54
+ ## Components
63
55
 
64
- - **JWT Tokens** - Secure token-based authentication
65
- - ✅ **JWKS** - Signature verification with `/.well-known/jwks.json`
66
- - ✅ **Auto refresh** - Tokens renewed automatically
67
- - ✅ **Social login** - OAuth provider support
68
- - ✅ **Cross-tab sync** - Synchronized state across tabs
69
- - ✅ **Route protection** - Protected routes automatically
70
- - ✅ **SSR friendly** - Server-side rendering compatible
71
- - ✅ **LocalStorage** - Token persistence in browser
56
+ ### Authentication Components
72
57
 
73
- ## API
58
+ | Component | Description |
59
+ | ----------------------- | -------------------------------------------- |
60
+ | `<SignIn />` | Sign in form with email/password, magic link |
61
+ | `<SignUp />` | Registration form |
62
+ | `<MagicLink />` | Magic link request form |
63
+ | `<MagicLinkCallback />` | Magic link verification |
64
+ | `<ForgotPassword />` | Password reset request |
65
+ | `<ResetPassword />` | Password reset form |
66
+ | `<VerifyEmail />` | Email verification |
67
+ | `<UserProfile />` | User profile management modal |
74
68
 
75
- ### Hooks
69
+ ### Control Components
76
70
 
77
- ```jsx
78
- const { user, loading, error, isAuthenticated } = useAuth();
79
- const signIn = useSignIn();
80
- const signUp = useSignUp();
81
- const signOut = useSignOut();
82
- const checkToken = useCheckToken();
83
- ```
71
+ | Component | Description |
72
+ | --------------- | -------------------------------------------- |
73
+ | `<SignedIn>` | Renders children only when authenticated |
74
+ | `<SignedOut>` | Renders children only when NOT authenticated |
75
+ | `<AuthLoading>` | Renders children while auth is loading |
76
+ | `<AuthLoaded>` | Renders children when auth has loaded |
77
+ | `<Protect />` | Protected route wrapper |
84
78
 
85
- ### Utility functions
79
+ ### Unstyled Buttons
86
80
 
87
- ```jsx
88
- import {
89
- isAuthenticated,
90
- getCurrentUser,
91
- refreshToken,
92
- socialRedirect
93
- } from '@riligar/auth-react';
94
-
95
- // Check if authenticated
96
- if (isAuthenticated()) {
97
- console.log('User logged in');
98
- }
81
+ | Component | Description |
82
+ | ------------------- | ------------------------- |
83
+ | `<SignInButton />` | Navigates to sign-in page |
84
+ | `<SignUpButton />` | Navigates to sign-up page |
85
+ | `<SignOutButton />` | Signs out the user |
99
86
 
100
- // Get current user data
101
- const user = getCurrentUser();
87
+ ## Hooks
102
88
 
103
- // Manually refresh token
104
- await refreshToken();
105
-
106
- // Redirect to social login
107
- socialRedirect('google', '/dashboard');
89
+ ```jsx
90
+ const { user, loading, error, isAuthenticated } = useAuth()
91
+ const { user, updateProfile, changePassword, changeEmail } = useUser()
92
+ const signIn = useSignIn()
93
+ const signUp = useSignUp()
94
+ const signOut = useSignOut()
108
95
  ```
109
96
 
97
+ ## Features
98
+
99
+ - ✅ **JWT Tokens** - Secure token-based authentication
100
+ - ✅ **JWKS** - Signature verification with `/.well-known/jwks.json`
101
+ - ✅ **Auto refresh** - Tokens renewed automatically
102
+ - ✅ **Social login** - OAuth provider support
103
+ - ✅ **Cross-tab sync** - Synchronized state across tabs
104
+ - ✅ **Route protection** - Protected routes automatically
105
+ - ✅ **Control components** - Clerk-style conditional rendering
106
+ - ✅ **SSR friendly** - Server-side rendering compatible
107
+
108
+ ## Backwards Compatibility
109
+
110
+ The following deprecated aliases are still available:
111
+
112
+ | Deprecated | Use Instead |
113
+ | -------------------- | ------------------- |
114
+ | `SignInForm` | `SignIn` |
115
+ | `SignUpForm` | `SignUp` |
116
+ | `MagicLinkForm` | `MagicLink` |
117
+ | `MagicLinkVerify` | `MagicLinkCallback` |
118
+ | `ForgotPasswordForm` | `ForgotPassword` |
119
+ | `ResetPasswordForm` | `ResetPassword` |
120
+ | `VerifyEmailCard` | `VerifyEmail` |
121
+ | `AccountModal` | `UserProfile` |
122
+ | `ProtectedRoute` | `Protect` |
123
+ | `useProfile` | `useUser` |
124
+
110
125
  ## Backend Configuration
111
126
 
112
127
  The SDK expects your backend to expose:
113
128
 
114
- - `/.well-known/jwks.json` - Public keys for JWT verification
115
- - `/auth/sign-in` - Login (returns `{ token, user }`)
116
- - `/auth/sign-up` - Registration (returns `{ token, user }`)
117
- - `/auth/sign-out` - Logout
118
- - `/auth/refresh` - Token renewal
119
- - `/auth/sign-in/:provider` - Social login
129
+ - `/.well-known/jwks.json` - Public keys for JWT verification
130
+ - `/auth/sign-in` - Login (returns `{ token, user }`)
131
+ - `/auth/sign-up` - Registration (returns `{ token, user }`)
132
+ - `/auth/sign-out` - Logout
133
+ - `/auth/refresh` - Token renewal
134
+ - `/auth/sign-in/:provider` - Social login
120
135
 
121
136
  ## Build
122
137
 
123
138
  ```bash
124
139
  bun run build
125
- ```
140
+ ```
package/dist/index.esm.js CHANGED
@@ -2,7 +2,7 @@ import { create } from 'zustand';
2
2
  import { useMemo, useEffect, createContext, useState, useRef } from 'react';
3
3
  import { useShallow } from 'zustand/react/shallow';
4
4
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
5
- import { Navigate, Outlet } from 'react-router-dom';
5
+ import { Navigate, Outlet, useNavigate } from 'react-router-dom';
6
6
  import { Paper, Stack, Image, Title, Text, TextInput, PasswordInput, Anchor, Button, Divider, Group, Center, Loader, Modal, Box, Avatar, Collapse, Card, Tooltip, ThemeIcon } from '@mantine/core';
7
7
  import { useForm } from '@mantine/form';
8
8
  import { IconMail, IconLock, IconArrowRight, IconBrandGoogle, IconBrandGithub, IconUser, IconSend, IconCheck, IconX, IconRefresh, IconPhoto, IconTrash, IconPencil, IconShield, IconKey, IconUserCircle } from '@tabler/icons-react';
@@ -892,8 +892,8 @@ const useSession = () => useAuthStore(useShallow(s => ({
892
892
  // Loading States Hook
893
893
  const useAuthLoading = () => useAuthStore(s => s.loadingStates);
894
894
 
895
- // Profile Management Hook
896
- const useProfile = () => useAuthStore(useShallow(s => ({
895
+ // Profile Management Hook (novo nome estilo Clerk)
896
+ const useUser = () => useAuthStore(useShallow(s => ({
897
897
  user: s.user,
898
898
  updateProfile: s.updateProfile,
899
899
  changePassword: s.changePassword,
@@ -904,6 +904,9 @@ const useProfile = () => useAuthStore(useShallow(s => ({
904
904
  error: s.error
905
905
  })));
906
906
 
907
+ // Alias deprecado para backwards compatibility
908
+ const useProfile = useUser;
909
+
907
910
  // Application Logo Hook
908
911
  const useApplicationLogo = () => {
909
912
  const applicationInfo = useAuthStore(s => s.applicationInfo);
@@ -911,11 +914,11 @@ const useApplicationLogo = () => {
911
914
  return applicationInfo?.image || null;
912
915
  };
913
916
 
914
- function ProtectedRoute({
917
+ function Protect({
915
918
  fallback = /*#__PURE__*/jsx("p", {
916
919
  children: "\u231B Carregando..."
917
920
  }),
918
- redirectTo = "/login"
921
+ redirectTo = '/login'
919
922
  }) {
920
923
  const {
921
924
  user,
@@ -969,7 +972,7 @@ function AuthCard({
969
972
 
970
973
  var img = "";
971
974
 
972
- function SignInForm({
975
+ function SignIn({
973
976
  // Configuração
974
977
  logo,
975
978
  // Removido default, será calculado abaixo
@@ -1137,7 +1140,7 @@ function SignInForm({
1137
1140
  });
1138
1141
  }
1139
1142
 
1140
- function SignUpForm({
1143
+ function SignUp({
1141
1144
  // Configuração
1142
1145
  logo,
1143
1146
  title = 'Criar Conta',
@@ -1271,7 +1274,7 @@ function SignUpForm({
1271
1274
  });
1272
1275
  }
1273
1276
 
1274
- function MagicLinkForm({
1277
+ function MagicLink({
1275
1278
  // Configuração
1276
1279
  logo,
1277
1280
  title = 'Login sem Senha',
@@ -1349,7 +1352,7 @@ function MagicLinkForm({
1349
1352
  });
1350
1353
  }
1351
1354
 
1352
- function MagicLinkVerify({
1355
+ function MagicLinkCallback({
1353
1356
  // Configuração
1354
1357
  logo,
1355
1358
  // Token pode ser passado diretamente ou extraído da URL
@@ -1459,7 +1462,7 @@ function MagicLinkVerify({
1459
1462
  });
1460
1463
  }
1461
1464
 
1462
- function ForgotPasswordForm({
1465
+ function ForgotPassword({
1463
1466
  // Configuração
1464
1467
  logo,
1465
1468
  title = 'Recuperar Senha',
@@ -1537,7 +1540,7 @@ function ForgotPasswordForm({
1537
1540
  });
1538
1541
  }
1539
1542
 
1540
- function ResetPasswordForm({
1543
+ function ResetPassword({
1541
1544
  // Configuração
1542
1545
  logo,
1543
1546
  title = 'Nova Senha',
@@ -1676,7 +1679,7 @@ function ResetPasswordForm({
1676
1679
  });
1677
1680
  }
1678
1681
 
1679
- function VerifyEmailCard({
1682
+ function VerifyEmail({
1680
1683
  // Configuração
1681
1684
  logo,
1682
1685
  // Token pode ser passado diretamente ou extraído da URL
@@ -1840,7 +1843,7 @@ function VerifyEmailCard({
1840
1843
  });
1841
1844
  }
1842
1845
 
1843
- function AccountModal({
1846
+ function UserProfile({
1844
1847
  // Controle do modal
1845
1848
  opened,
1846
1849
  onClose,
@@ -2515,5 +2518,106 @@ function AccountModal({
2515
2518
  });
2516
2519
  }
2517
2520
 
2518
- export { AccountModal, AuthCard, AuthProvider, ForgotPasswordForm, MagicLinkForm, MagicLinkVerify, ProtectedRoute, ResetPasswordForm, SignInForm, SignUpForm, VerifyEmailCard, changeEmail, changePassword, configure, decodeJWT, forgotPassword, getApplicationInfo, getCurrentUser, getSession, isAuthenticated, refreshToken, resendVerification, resetPassword, sendMagicLink, signIn, signOut, signUp, socialRedirect, updateProfile, useAuth, useAuthLoading, useAuthStore, useCheckToken, useEmailVerification, useMagicLink, usePasswordReset, useProfile, useSession, useSignIn, useSignOut, useSignUp, verifyEmail, verifyMagicLink };
2521
+ /**
2522
+ * Renderiza children apenas quando o usuário está autenticado
2523
+ * Equivalente ao <SignedIn> do Clerk
2524
+ */
2525
+ function SignedIn({
2526
+ children
2527
+ }) {
2528
+ const {
2529
+ user,
2530
+ loading
2531
+ } = useAuth();
2532
+ if (loading || !user) return null;
2533
+ return children;
2534
+ }
2535
+
2536
+ /**
2537
+ * Renderiza children apenas quando o usuário NÃO está autenticado
2538
+ * Equivalente ao <SignedOut> do Clerk
2539
+ */
2540
+ function SignedOut({
2541
+ children
2542
+ }) {
2543
+ const {
2544
+ user,
2545
+ loading
2546
+ } = useAuth();
2547
+ if (loading || user) return null;
2548
+ return children;
2549
+ }
2550
+
2551
+ /**
2552
+ * Renderiza children enquanto a autenticação está carregando
2553
+ * Equivalente ao <ClerkLoading> do Clerk
2554
+ */
2555
+ function AuthLoading({
2556
+ children
2557
+ }) {
2558
+ const {
2559
+ loading
2560
+ } = useAuth();
2561
+ if (!loading) return null;
2562
+ return children;
2563
+ }
2564
+
2565
+ /**
2566
+ * Renderiza children quando a autenticação terminou de carregar
2567
+ * Equivalente ao <ClerkLoaded> do Clerk
2568
+ */
2569
+ function AuthLoaded({
2570
+ children
2571
+ }) {
2572
+ const {
2573
+ loading
2574
+ } = useAuth();
2575
+ if (loading) return null;
2576
+ return children;
2577
+ }
2578
+
2579
+ function SignInButton({
2580
+ children,
2581
+ redirectTo = '/login',
2582
+ ...props
2583
+ }) {
2584
+ const navigate = useNavigate();
2585
+ return /*#__PURE__*/jsx("button", {
2586
+ onClick: () => navigate(redirectTo),
2587
+ ...props,
2588
+ children: children || 'Sign In'
2589
+ });
2590
+ }
2591
+
2592
+ function SignUpButton({
2593
+ children,
2594
+ redirectTo = '/register',
2595
+ ...props
2596
+ }) {
2597
+ const navigate = useNavigate();
2598
+ return /*#__PURE__*/jsx("button", {
2599
+ onClick: () => navigate(redirectTo),
2600
+ ...props,
2601
+ children: children || 'Sign Up'
2602
+ });
2603
+ }
2604
+
2605
+ function SignOutButton({
2606
+ children,
2607
+ onSignOut,
2608
+ ...props
2609
+ }) {
2610
+ const signOut = useSignOut();
2611
+ const handleClick = async () => {
2612
+ await signOut();
2613
+ onSignOut?.();
2614
+ };
2615
+ return /*#__PURE__*/jsx("button", {
2616
+ onClick: handleClick,
2617
+ ...props,
2618
+ children: children || 'Sign Out'
2619
+ });
2620
+ }
2621
+
2622
+ export { UserProfile as AccountModal, AuthCard, AuthLoaded, AuthLoading, AuthProvider, ForgotPassword, ForgotPassword as ForgotPasswordForm, MagicLink, MagicLinkCallback, MagicLink as MagicLinkForm, MagicLinkCallback as MagicLinkVerify, Protect, Protect as ProtectedRoute, ResetPassword, ResetPassword as ResetPasswordForm, SignIn, SignInButton, SignIn as SignInForm, SignOutButton, SignUp, SignUpButton, SignUp as SignUpForm, SignedIn, SignedOut, UserProfile, VerifyEmail, VerifyEmail as VerifyEmailCard, changeEmail, changePassword, configure, decodeJWT, forgotPassword, getApplicationInfo, getCurrentUser, getSession, isAuthenticated, refreshToken, resendVerification, resetPassword, sendMagicLink, signIn, signOut, signUp, socialRedirect, updateProfile, useApplicationLogo, useAuth, useAuthLoading, useAuthStore, useCheckToken, useEmailVerification, useMagicLink, usePasswordReset, useUser as useProfile, useSession, useSignIn, useSignOut, useSignUp, useUser, verifyEmail, verifyMagicLink };
2519
2623
  //# sourceMappingURL=index.esm.js.map