@ipulsehq/auth-ui 1.3.2
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 +35 -0
- package/dist/AuthError.d.ts +14 -0
- package/dist/AuthError.d.ts.map +1 -0
- package/dist/AuthError.js +92 -0
- package/dist/AuthError.js.map +1 -0
- package/dist/AuthLayout.d.ts +18 -0
- package/dist/AuthLayout.d.ts.map +1 -0
- package/dist/AuthLayout.js +72 -0
- package/dist/AuthLayout.js.map +1 -0
- package/dist/IPulseClientAuthError.d.ts +21 -0
- package/dist/IPulseClientAuthError.d.ts.map +1 -0
- package/dist/IPulseClientAuthError.js +48 -0
- package/dist/IPulseClientAuthError.js.map +1 -0
- package/dist/IPulseRedirectSignIn.d.ts +21 -0
- package/dist/IPulseRedirectSignIn.d.ts.map +1 -0
- package/dist/IPulseRedirectSignIn.js +65 -0
- package/dist/IPulseRedirectSignIn.js.map +1 -0
- package/dist/SignIn.d.ts +24 -0
- package/dist/SignIn.d.ts.map +1 -0
- package/dist/SignIn.js +132 -0
- package/dist/SignIn.js.map +1 -0
- package/dist/SignUp.d.ts +26 -0
- package/dist/SignUp.d.ts.map +1 -0
- package/dist/SignUp.js +96 -0
- package/dist/SignUp.js.map +1 -0
- package/dist/UserButton.d.ts +24 -0
- package/dist/UserButton.d.ts.map +1 -0
- package/dist/UserButton.js +141 -0
- package/dist/UserButton.js.map +1 -0
- package/dist/VerifyRequest.d.ts +11 -0
- package/dist/VerifyRequest.d.ts.map +1 -0
- package/dist/VerifyRequest.js +73 -0
- package/dist/VerifyRequest.js.map +1 -0
- package/dist/auth-config.d.ts +63 -0
- package/dist/auth-config.d.ts.map +1 -0
- package/dist/auth-config.js +234 -0
- package/dist/auth-config.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +45 -0
- package/dist/index.js.map +1 -0
- package/dist/shared/AuthAlert.d.ts +11 -0
- package/dist/shared/AuthAlert.d.ts.map +1 -0
- package/dist/shared/AuthAlert.js +34 -0
- package/dist/shared/AuthAlert.js.map +1 -0
- package/dist/shared/AuthButton.d.ts +20 -0
- package/dist/shared/AuthButton.d.ts.map +1 -0
- package/dist/shared/AuthButton.js +84 -0
- package/dist/shared/AuthButton.js.map +1 -0
- package/dist/shared/AuthCard.d.ts +12 -0
- package/dist/shared/AuthCard.d.ts.map +1 -0
- package/dist/shared/AuthCard.js +30 -0
- package/dist/shared/AuthCard.js.map +1 -0
- package/dist/shared/AuthDivider.d.ts +10 -0
- package/dist/shared/AuthDivider.d.ts.map +1 -0
- package/dist/shared/AuthDivider.js +17 -0
- package/dist/shared/AuthDivider.js.map +1 -0
- package/dist/shared/AuthEmailInput.d.ts +17 -0
- package/dist/shared/AuthEmailInput.d.ts.map +1 -0
- package/dist/shared/AuthEmailInput.js +81 -0
- package/dist/shared/AuthEmailInput.js.map +1 -0
- package/dist/shared/AuthFooter.d.ts +14 -0
- package/dist/shared/AuthFooter.d.ts.map +1 -0
- package/dist/shared/AuthFooter.js +21 -0
- package/dist/shared/AuthFooter.js.map +1 -0
- package/dist/shared/AuthHeader.d.ts +13 -0
- package/dist/shared/AuthHeader.d.ts.map +1 -0
- package/dist/shared/AuthHeader.js +38 -0
- package/dist/shared/AuthHeader.js.map +1 -0
- package/dist/shared/AuthTextInput.d.ts +19 -0
- package/dist/shared/AuthTextInput.d.ts.map +1 -0
- package/dist/shared/AuthTextInput.js +81 -0
- package/dist/shared/AuthTextInput.js.map +1 -0
- package/dist/shared/styles.d.ts +6 -0
- package/dist/shared/styles.d.ts.map +1 -0
- package/dist/shared/styles.js +21 -0
- package/dist/shared/styles.js.map +1 -0
- package/dist/types.d.ts +119 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/utils.d.ts +32 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +50 -0
- package/dist/utils.js.map +1 -0
- package/package.json +42 -0
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Shared iPulse OAuth auth config for NextAuth.
|
|
4
|
+
* Use in PulseGuard, PulseFiles, PulseSync, etc.
|
|
5
|
+
*
|
|
6
|
+
* Required env: IPULSE_ISSUER, IPULSE_CLIENT_ID, IPULSE_CLIENT_SECRET
|
|
7
|
+
*/
|
|
8
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
9
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.getIPulseProvider = getIPulseProvider;
|
|
13
|
+
exports.createIPulseAuthConfig = createIPulseAuthConfig;
|
|
14
|
+
exports.createIPulseNextAuth = createIPulseNextAuth;
|
|
15
|
+
const next_auth_1 = __importDefault(require("next-auth"));
|
|
16
|
+
const IPULSE_ISSUER = process.env.IPULSE_ISSUER || 'https://ipulse.one';
|
|
17
|
+
/** iPulse OIDC provider config for NextAuth providers array */
|
|
18
|
+
function getIPulseProvider(options) {
|
|
19
|
+
const scope = options?.scope ?? 'openid email profile';
|
|
20
|
+
return {
|
|
21
|
+
id: 'ipulse',
|
|
22
|
+
name: 'iPulse',
|
|
23
|
+
type: 'oidc',
|
|
24
|
+
issuer: IPULSE_ISSUER,
|
|
25
|
+
clientId: process.env.IPULSE_CLIENT_ID,
|
|
26
|
+
clientSecret: process.env.IPULSE_CLIENT_SECRET,
|
|
27
|
+
wellKnown: `${IPULSE_ISSUER}/.well-known/openid-configuration`,
|
|
28
|
+
authorization: {
|
|
29
|
+
params: {
|
|
30
|
+
scope,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
profile(profile) {
|
|
34
|
+
return {
|
|
35
|
+
id: profile.sub,
|
|
36
|
+
email: profile.email,
|
|
37
|
+
name: profile.name,
|
|
38
|
+
image: profile.image,
|
|
39
|
+
role: profile.role,
|
|
40
|
+
};
|
|
41
|
+
},
|
|
42
|
+
checks: ['pkce', 'state'],
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
const SESSION_MAX_AGE = 3 * 24 * 60 * 60; // 3 dagen
|
|
46
|
+
const refreshLocks = new Map();
|
|
47
|
+
async function refreshAccessToken(token) {
|
|
48
|
+
const rt = token.refreshToken;
|
|
49
|
+
if (!rt)
|
|
50
|
+
return { ...token, error: 'RefreshAccessTokenError' };
|
|
51
|
+
const existing = refreshLocks.get(rt);
|
|
52
|
+
if (existing)
|
|
53
|
+
return existing;
|
|
54
|
+
const promise = doRefreshAccessToken(token);
|
|
55
|
+
refreshLocks.set(rt, promise);
|
|
56
|
+
try {
|
|
57
|
+
return await promise;
|
|
58
|
+
}
|
|
59
|
+
finally {
|
|
60
|
+
refreshLocks.delete(rt);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async function doRefreshAccessToken(token) {
|
|
64
|
+
try {
|
|
65
|
+
const response = await fetch(`${IPULSE_ISSUER}/api/oauth/token`, {
|
|
66
|
+
method: 'POST',
|
|
67
|
+
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
|
|
68
|
+
signal: AbortSignal.timeout(5000),
|
|
69
|
+
body: new URLSearchParams({
|
|
70
|
+
grant_type: 'refresh_token',
|
|
71
|
+
refresh_token: token.refreshToken,
|
|
72
|
+
client_id: process.env.IPULSE_CLIENT_ID,
|
|
73
|
+
client_secret: process.env.IPULSE_CLIENT_SECRET,
|
|
74
|
+
}),
|
|
75
|
+
});
|
|
76
|
+
const refreshed = await response.json();
|
|
77
|
+
if (!response.ok)
|
|
78
|
+
throw new Error(refreshed.error_description || refreshed.error || 'Token refresh failed');
|
|
79
|
+
const updatedToken = {
|
|
80
|
+
...token,
|
|
81
|
+
accessToken: refreshed.access_token,
|
|
82
|
+
refreshToken: refreshed.refresh_token ?? token.refreshToken,
|
|
83
|
+
accessTokenExpires: Date.now() + refreshed.expires_in * 1000,
|
|
84
|
+
error: undefined,
|
|
85
|
+
};
|
|
86
|
+
try {
|
|
87
|
+
const userinfoRes = await fetch(`${IPULSE_ISSUER}/api/oauth/userinfo`, {
|
|
88
|
+
headers: { Authorization: `Bearer ${refreshed.access_token}` },
|
|
89
|
+
});
|
|
90
|
+
if (userinfoRes.ok) {
|
|
91
|
+
const userinfo = await userinfoRes.json();
|
|
92
|
+
if (userinfo.image !== undefined)
|
|
93
|
+
updatedToken.image = userinfo.image;
|
|
94
|
+
if (userinfo.name !== undefined)
|
|
95
|
+
updatedToken.name = userinfo.name;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
catch { /* non-fatal */ }
|
|
99
|
+
return updatedToken;
|
|
100
|
+
}
|
|
101
|
+
catch (error) {
|
|
102
|
+
console.error('[auth] Failed to refresh access token:', error);
|
|
103
|
+
return { ...token, error: 'RefreshAccessTokenError' };
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Returns NextAuth config for iPulse OAuth.
|
|
108
|
+
* Spread into NextAuth({ ...authConfig, providers: [...], cookies: {...} })
|
|
109
|
+
*/
|
|
110
|
+
function createIPulseAuthConfig(options) {
|
|
111
|
+
const signIn = options?.signIn ?? '/sign-in';
|
|
112
|
+
const error = options?.error ?? '/auth-error';
|
|
113
|
+
return {
|
|
114
|
+
providers: [],
|
|
115
|
+
session: { strategy: 'jwt', maxAge: SESSION_MAX_AGE },
|
|
116
|
+
events: {
|
|
117
|
+
async signOut(message) {
|
|
118
|
+
const token = message?.token;
|
|
119
|
+
const refreshToken = token?.refreshToken;
|
|
120
|
+
if (!refreshToken)
|
|
121
|
+
return;
|
|
122
|
+
try {
|
|
123
|
+
await fetch(`${IPULSE_ISSUER}/api/oauth/revoke`, {
|
|
124
|
+
method: 'POST',
|
|
125
|
+
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
|
|
126
|
+
body: new URLSearchParams({
|
|
127
|
+
token: refreshToken,
|
|
128
|
+
token_type_hint: 'refresh_token',
|
|
129
|
+
client_id: process.env.IPULSE_CLIENT_ID,
|
|
130
|
+
client_secret: process.env.IPULSE_CLIENT_SECRET,
|
|
131
|
+
}),
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
catch {
|
|
135
|
+
// Non-fatal
|
|
136
|
+
}
|
|
137
|
+
},
|
|
138
|
+
},
|
|
139
|
+
callbacks: {
|
|
140
|
+
async jwt({ token, account, profile }) {
|
|
141
|
+
if (account && profile) {
|
|
142
|
+
token.accessToken = account.access_token;
|
|
143
|
+
token.refreshToken = account.refresh_token;
|
|
144
|
+
token.accessTokenExpires = account.expires_at
|
|
145
|
+
? account.expires_at * 1000
|
|
146
|
+
: Date.now() + 3600 * 1000;
|
|
147
|
+
token.id = profile.sub;
|
|
148
|
+
token.email = profile.email;
|
|
149
|
+
token.name = profile.name;
|
|
150
|
+
token.image = profile.image;
|
|
151
|
+
token.role = profile.role;
|
|
152
|
+
token.error = undefined;
|
|
153
|
+
if (!token.image && account.access_token) {
|
|
154
|
+
try {
|
|
155
|
+
const userinfoRes = await fetch(`${IPULSE_ISSUER}/api/oauth/userinfo`, {
|
|
156
|
+
headers: { Authorization: `Bearer ${account.access_token}` },
|
|
157
|
+
});
|
|
158
|
+
if (userinfoRes.ok) {
|
|
159
|
+
const userinfo = await userinfoRes.json();
|
|
160
|
+
if (userinfo.image !== undefined)
|
|
161
|
+
token.image = userinfo.image;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
catch { /* non-fatal */ }
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
if (Date.now() < (token.accessTokenExpires - 60000)) {
|
|
168
|
+
return token;
|
|
169
|
+
}
|
|
170
|
+
if (token.error === 'RefreshAccessTokenError') {
|
|
171
|
+
return token;
|
|
172
|
+
}
|
|
173
|
+
return refreshAccessToken(token);
|
|
174
|
+
},
|
|
175
|
+
async session({ session, token }) {
|
|
176
|
+
session.user.id = token.id;
|
|
177
|
+
session.user.email = token.email;
|
|
178
|
+
session.user.name = token.name;
|
|
179
|
+
session.user.image = token.image;
|
|
180
|
+
session.user.role = token.role;
|
|
181
|
+
session.accessToken = token.accessToken;
|
|
182
|
+
session.error = token.error;
|
|
183
|
+
return session;
|
|
184
|
+
},
|
|
185
|
+
authorized({ auth }) {
|
|
186
|
+
if (auth?.error === 'RefreshAccessTokenError')
|
|
187
|
+
return false;
|
|
188
|
+
return !!auth?.user;
|
|
189
|
+
},
|
|
190
|
+
},
|
|
191
|
+
pages: {
|
|
192
|
+
signIn,
|
|
193
|
+
error,
|
|
194
|
+
},
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* Creates full NextAuth instance for iPulse OAuth clients.
|
|
199
|
+
* Reduces auth.ts to a single call.
|
|
200
|
+
*/
|
|
201
|
+
function createIPulseNextAuth(options) {
|
|
202
|
+
const { appName, scope } = options;
|
|
203
|
+
const secret = process.env.NEXTAUTH_SECRET;
|
|
204
|
+
const isProd = process.env.NODE_ENV === 'production';
|
|
205
|
+
const cookiePrefix = isProd ? `__Secure-${appName}` : 'next-auth';
|
|
206
|
+
return (0, next_auth_1.default)({
|
|
207
|
+
...createIPulseAuthConfig(),
|
|
208
|
+
trustHost: true,
|
|
209
|
+
secret,
|
|
210
|
+
cookies: {
|
|
211
|
+
sessionToken: {
|
|
212
|
+
name: isProd ? `${cookiePrefix}.session-token` : 'next-auth.session-token',
|
|
213
|
+
options: {
|
|
214
|
+
httpOnly: true,
|
|
215
|
+
sameSite: 'lax',
|
|
216
|
+
path: '/',
|
|
217
|
+
maxAge: 3 * 24 * 60 * 60,
|
|
218
|
+
domain: isProd ? '.ipulse.one' : undefined,
|
|
219
|
+
secure: isProd,
|
|
220
|
+
},
|
|
221
|
+
},
|
|
222
|
+
pkceCodeVerifier: {
|
|
223
|
+
name: isProd ? `${cookiePrefix}.pkce.code_verifier` : 'next-auth.pkce.code_verifier',
|
|
224
|
+
options: { httpOnly: true, sameSite: 'lax', path: '/', secure: isProd },
|
|
225
|
+
},
|
|
226
|
+
state: {
|
|
227
|
+
name: isProd ? `${cookiePrefix}.state` : 'next-auth.state',
|
|
228
|
+
options: { httpOnly: true, sameSite: 'lax', path: '/', secure: isProd },
|
|
229
|
+
},
|
|
230
|
+
},
|
|
231
|
+
providers: [getIPulseProvider(scope ? { scope } : undefined)],
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
//# sourceMappingURL=auth-config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-config.js","sourceRoot":"","sources":["../src/auth-config.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export { createIPulseAuthConfig, getIPulseProvider, createIPulseNextAuth, } from './auth-config';
|
|
2
|
+
export * from './SignIn';
|
|
3
|
+
export * from './SignUp';
|
|
4
|
+
export * from './UserButton';
|
|
5
|
+
export * from './VerifyRequest';
|
|
6
|
+
export * from './AuthError';
|
|
7
|
+
export * from './AuthLayout';
|
|
8
|
+
export * from './IPulseRedirectSignIn';
|
|
9
|
+
export * from './IPulseClientAuthError';
|
|
10
|
+
export * from './shared/AuthCard';
|
|
11
|
+
export * from './shared/AuthAlert';
|
|
12
|
+
export * from './shared/AuthButton';
|
|
13
|
+
export * from './shared/AuthDivider';
|
|
14
|
+
export * from './shared/AuthEmailInput';
|
|
15
|
+
export * from './shared/AuthFooter';
|
|
16
|
+
export * from './shared/AuthHeader';
|
|
17
|
+
export * from './shared/AuthTextInput';
|
|
18
|
+
export type { IPulseUser, IPulseSession, AuthBranding, AuthTranslations } from './types';
|
|
19
|
+
export { getInitials, cn } from './utils';
|
|
20
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,sBAAsB,EACtB,iBAAiB,EACjB,oBAAoB,GACrB,MAAM,eAAe,CAAC;AAGvB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC;AAGxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,wBAAwB,CAAC;AAGvC,YAAY,EAAE,UAAU,EAAE,aAAa,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAGzF,OAAO,EAAE,WAAW,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.cn = exports.getInitials = exports.createIPulseNextAuth = exports.getIPulseProvider = exports.createIPulseAuthConfig = void 0;
|
|
18
|
+
// Auth config (NextAuth OAuth setup)
|
|
19
|
+
var auth_config_1 = require("./auth-config");
|
|
20
|
+
Object.defineProperty(exports, "createIPulseAuthConfig", { enumerable: true, get: function () { return auth_config_1.createIPulseAuthConfig; } });
|
|
21
|
+
Object.defineProperty(exports, "getIPulseProvider", { enumerable: true, get: function () { return auth_config_1.getIPulseProvider; } });
|
|
22
|
+
Object.defineProperty(exports, "createIPulseNextAuth", { enumerable: true, get: function () { return auth_config_1.createIPulseNextAuth; } });
|
|
23
|
+
// Components
|
|
24
|
+
__exportStar(require("./SignIn"), exports);
|
|
25
|
+
__exportStar(require("./SignUp"), exports);
|
|
26
|
+
__exportStar(require("./UserButton"), exports);
|
|
27
|
+
__exportStar(require("./VerifyRequest"), exports);
|
|
28
|
+
__exportStar(require("./AuthError"), exports);
|
|
29
|
+
__exportStar(require("./AuthLayout"), exports);
|
|
30
|
+
__exportStar(require("./IPulseRedirectSignIn"), exports);
|
|
31
|
+
__exportStar(require("./IPulseClientAuthError"), exports);
|
|
32
|
+
// Shared primitives (consumers can use these in custom auth UIs)
|
|
33
|
+
__exportStar(require("./shared/AuthCard"), exports);
|
|
34
|
+
__exportStar(require("./shared/AuthAlert"), exports);
|
|
35
|
+
__exportStar(require("./shared/AuthButton"), exports);
|
|
36
|
+
__exportStar(require("./shared/AuthDivider"), exports);
|
|
37
|
+
__exportStar(require("./shared/AuthEmailInput"), exports);
|
|
38
|
+
__exportStar(require("./shared/AuthFooter"), exports);
|
|
39
|
+
__exportStar(require("./shared/AuthHeader"), exports);
|
|
40
|
+
__exportStar(require("./shared/AuthTextInput"), exports);
|
|
41
|
+
// Utils
|
|
42
|
+
var utils_1 = require("./utils");
|
|
43
|
+
Object.defineProperty(exports, "getInitials", { enumerable: true, get: function () { return utils_1.getInitials; } });
|
|
44
|
+
Object.defineProperty(exports, "cn", { enumerable: true, get: function () { return utils_1.cn; } });
|
|
45
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,qCAAqC;AACrC,6CAIuB;AAHrB,qHAAA,sBAAsB,OAAA;AACtB,gHAAA,iBAAiB,OAAA;AACjB,mHAAA,oBAAoB,OAAA;AAGtB,aAAa;AACb,2CAAyB;AACzB,2CAAyB;AACzB,+CAA6B;AAC7B,kDAAgC;AAChC,8CAA4B;AAC5B,+CAA6B;AAC7B,yDAAuC;AACvC,0DAAwC;AAExC,iEAAiE;AACjE,oDAAkC;AAClC,qDAAmC;AACnC,sDAAoC;AACpC,uDAAqC;AACrC,0DAAwC;AACxC,sDAAoC;AACpC,sDAAoC;AACpC,yDAAuC;AAKvC,QAAQ;AACR,iCAA0C;AAAjC,oGAAA,WAAW,OAAA;AAAE,2FAAA,EAAE,OAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
interface AuthAlertProps {
|
|
3
|
+
type: 'error' | 'success';
|
|
4
|
+
message: string;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Shared error / success alert banner used across auth components.
|
|
8
|
+
*/
|
|
9
|
+
export declare const AuthAlert: React.FC<AuthAlertProps>;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=AuthAlert.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthAlert.d.ts","sourceRoot":"","sources":["../../src/shared/AuthAlert.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,UAAU,cAAc;IACpB,IAAI,EAAE,OAAO,GAAG,SAAS,CAAC;IAC1B,OAAO,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAiC9C,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AuthAlert = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const lucide_react_1 = require("lucide-react");
|
|
6
|
+
const utils_1 = require("../utils");
|
|
7
|
+
/**
|
|
8
|
+
* Shared error / success alert banner used across auth components.
|
|
9
|
+
*/
|
|
10
|
+
const AuthAlert = ({ type, message }) => {
|
|
11
|
+
const isError = type === 'error';
|
|
12
|
+
return ((0, jsx_runtime_1.jsxs)("div", { role: isError ? 'alert' : 'status', style: {
|
|
13
|
+
marginBottom: '1.25rem',
|
|
14
|
+
padding: '0.75rem 1rem',
|
|
15
|
+
borderRadius: utils_1.cssVars.radius.md,
|
|
16
|
+
backgroundColor: isError
|
|
17
|
+
? 'color-mix(in oklch, var(--color-destructive, #ef4444) 10%, transparent)'
|
|
18
|
+
: 'color-mix(in oklch, #22c55e 10%, transparent)',
|
|
19
|
+
border: `1px solid ${isError
|
|
20
|
+
? 'color-mix(in oklch, var(--color-destructive, #ef4444) 30%, transparent)'
|
|
21
|
+
: 'color-mix(in oklch, #22c55e 30%, transparent)'}`,
|
|
22
|
+
color: isError ? utils_1.cssVars.destructive : '#16a34a',
|
|
23
|
+
fontSize: '0.875rem',
|
|
24
|
+
lineHeight: 1.5,
|
|
25
|
+
display: 'flex',
|
|
26
|
+
alignItems: 'flex-start',
|
|
27
|
+
gap: '0.5rem',
|
|
28
|
+
animation: 'ipulse-slidein 0.2s ease-out',
|
|
29
|
+
}, children: [(0, jsx_runtime_1.jsx)("span", { style: { flexShrink: 0, marginTop: '0.0625rem' }, children: isError
|
|
30
|
+
? (0, jsx_runtime_1.jsx)(lucide_react_1.AlertCircle, { size: 15 })
|
|
31
|
+
: (0, jsx_runtime_1.jsx)(lucide_react_1.CheckCircle2, { size: 15 }) }), (0, jsx_runtime_1.jsx)("span", { children: message })] }));
|
|
32
|
+
};
|
|
33
|
+
exports.AuthAlert = AuthAlert;
|
|
34
|
+
//# sourceMappingURL=AuthAlert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthAlert.js","sourceRoot":"","sources":["../../src/shared/AuthAlert.tsx"],"names":[],"mappings":";;;;AACA,+CAAyD;AACzD,oCAAmC;AAOnC;;GAEG;AACI,MAAM,SAAS,GAA6B,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE;IACrE,MAAM,OAAO,GAAG,IAAI,KAAK,OAAO,CAAC;IAEjC,OAAO,CACH,iCACI,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAClC,KAAK,EAAE;YACH,YAAY,EAAE,SAAS;YACvB,OAAO,EAAE,cAAc;YACvB,YAAY,EAAE,eAAO,CAAC,MAAM,CAAC,EAAE;YAC/B,eAAe,EAAE,OAAO;gBACpB,CAAC,CAAC,yEAAyE;gBAC3E,CAAC,CAAC,+CAA+C;YACrD,MAAM,EAAE,aAAa,OAAO;gBACxB,CAAC,CAAC,yEAAyE;gBAC3E,CAAC,CAAC,+CAA+C,EAAE;YACvD,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,eAAO,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;YAChD,QAAQ,EAAE,UAAU;YACpB,UAAU,EAAE,GAAG;YACf,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,YAAY;YACxB,GAAG,EAAE,QAAQ;YACb,SAAS,EAAE,8BAA8B;SAC5C,aAED,iCAAM,KAAK,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,YACjD,OAAO;oBACJ,CAAC,CAAC,uBAAC,0BAAW,IAAC,IAAI,EAAE,EAAE,GAAI;oBAC3B,CAAC,CAAC,uBAAC,2BAAY,IAAC,IAAI,EAAE,EAAE,GAAI,GAC7B,EACP,2CAAO,OAAO,GAAQ,IACpB,CACT,CAAC;AACN,CAAC,CAAC;AAjCW,QAAA,SAAS,aAiCpB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
interface BaseButtonProps {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
onClick?: () => void;
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
loading?: boolean;
|
|
7
|
+
loadingText?: string;
|
|
8
|
+
type?: 'button' | 'submit' | 'reset';
|
|
9
|
+
tabIndex?: number;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Primary (filled) button — used for main CTA actions.
|
|
13
|
+
*/
|
|
14
|
+
export declare const AuthPrimaryButton: React.FC<BaseButtonProps>;
|
|
15
|
+
/**
|
|
16
|
+
* Secondary (outline) button — used for alternative actions like Passkey.
|
|
17
|
+
*/
|
|
18
|
+
export declare const AuthOutlineButton: React.FC<BaseButtonProps>;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=AuthButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthButton.d.ts","sourceRoot":"","sources":["../../src/shared/AuthButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,UAAU,eAAe;IACrB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,QAAQ,GAAG,QAAQ,GAAG,OAAO,CAAC;IACrC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA+DvD,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAgEvD,CAAC"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AuthOutlineButton = exports.AuthPrimaryButton = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const lucide_react_1 = require("lucide-react");
|
|
6
|
+
const utils_1 = require("../utils");
|
|
7
|
+
/**
|
|
8
|
+
* Primary (filled) button — used for main CTA actions.
|
|
9
|
+
*/
|
|
10
|
+
const AuthPrimaryButton = ({ children, onClick, disabled = false, loading = false, loadingText, type = 'submit', tabIndex = 0, }) => {
|
|
11
|
+
const isDisabled = disabled || loading;
|
|
12
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: type, onClick: onClick, disabled: isDisabled, tabIndex: tabIndex, style: {
|
|
13
|
+
width: '100%',
|
|
14
|
+
padding: '0.6875rem 1rem',
|
|
15
|
+
backgroundColor: utils_1.cssVars.primary,
|
|
16
|
+
color: utils_1.cssVars.primaryFg,
|
|
17
|
+
borderRadius: utils_1.cssVars.radius.md,
|
|
18
|
+
border: 'none',
|
|
19
|
+
cursor: isDisabled ? 'not-allowed' : 'pointer',
|
|
20
|
+
fontWeight: 600,
|
|
21
|
+
fontSize: '0.9375rem',
|
|
22
|
+
letterSpacing: '-0.01em',
|
|
23
|
+
display: 'flex',
|
|
24
|
+
alignItems: 'center',
|
|
25
|
+
justifyContent: 'center',
|
|
26
|
+
gap: '0.5rem',
|
|
27
|
+
transition: 'opacity 0.15s, transform 0.1s, box-shadow 0.15s',
|
|
28
|
+
opacity: isDisabled ? 0.55 : 1,
|
|
29
|
+
outline: 'none',
|
|
30
|
+
}, onMouseOver: (e) => {
|
|
31
|
+
if (!isDisabled) {
|
|
32
|
+
e.currentTarget.style.opacity = '0.88';
|
|
33
|
+
e.currentTarget.style.boxShadow = `0 4px 12px -2px color-mix(in oklch, ${utils_1.cssVars.primary} 40%, transparent)`;
|
|
34
|
+
}
|
|
35
|
+
}, onMouseOut: (e) => {
|
|
36
|
+
e.currentTarget.style.opacity = isDisabled ? '0.55' : '1';
|
|
37
|
+
e.currentTarget.style.boxShadow = 'none';
|
|
38
|
+
}, onFocus: (e) => {
|
|
39
|
+
e.currentTarget.style.boxShadow = `0 0 0 3px color-mix(in oklch, ${utils_1.cssVars.primary} 30%, transparent)`;
|
|
40
|
+
}, onBlur: (e) => {
|
|
41
|
+
e.currentTarget.style.boxShadow = 'none';
|
|
42
|
+
}, children: loading ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(lucide_react_1.Loader2, { size: 16, style: { animation: 'ipulse-spin 0.8s linear infinite', flexShrink: 0 } }), loadingText ?? children] })) : (children) }));
|
|
43
|
+
};
|
|
44
|
+
exports.AuthPrimaryButton = AuthPrimaryButton;
|
|
45
|
+
/**
|
|
46
|
+
* Secondary (outline) button — used for alternative actions like Passkey.
|
|
47
|
+
*/
|
|
48
|
+
const AuthOutlineButton = ({ children, onClick, disabled = false, loading = false, loadingText, type = 'button', tabIndex = 0, }) => {
|
|
49
|
+
const isDisabled = disabled || loading;
|
|
50
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: type, onClick: onClick, disabled: isDisabled, tabIndex: tabIndex, style: {
|
|
51
|
+
width: '100%',
|
|
52
|
+
padding: '0.6875rem 1rem',
|
|
53
|
+
backgroundColor: 'transparent',
|
|
54
|
+
color: utils_1.cssVars.fg,
|
|
55
|
+
borderRadius: utils_1.cssVars.radius.md,
|
|
56
|
+
border: `1.5px solid ${utils_1.cssVars.border}`,
|
|
57
|
+
cursor: isDisabled ? 'not-allowed' : 'pointer',
|
|
58
|
+
fontWeight: 500,
|
|
59
|
+
fontSize: '0.9375rem',
|
|
60
|
+
display: 'flex',
|
|
61
|
+
alignItems: 'center',
|
|
62
|
+
justifyContent: 'center',
|
|
63
|
+
gap: '0.625rem',
|
|
64
|
+
transition: 'background-color 0.15s, border-color 0.15s, box-shadow 0.15s',
|
|
65
|
+
opacity: isDisabled ? 0.55 : 1,
|
|
66
|
+
outline: 'none',
|
|
67
|
+
}, onMouseOver: (e) => {
|
|
68
|
+
if (!isDisabled) {
|
|
69
|
+
e.currentTarget.style.backgroundColor = utils_1.cssVars.muted;
|
|
70
|
+
e.currentTarget.style.borderColor = utils_1.cssVars.primary;
|
|
71
|
+
}
|
|
72
|
+
}, onMouseOut: (e) => {
|
|
73
|
+
e.currentTarget.style.backgroundColor = 'transparent';
|
|
74
|
+
e.currentTarget.style.borderColor = isDisabled ? utils_1.cssVars.border : utils_1.cssVars.border;
|
|
75
|
+
}, onFocus: (e) => {
|
|
76
|
+
e.currentTarget.style.borderColor = utils_1.cssVars.primary;
|
|
77
|
+
e.currentTarget.style.boxShadow = `0 0 0 3px color-mix(in oklch, ${utils_1.cssVars.primary} 15%, transparent)`;
|
|
78
|
+
}, onBlur: (e) => {
|
|
79
|
+
e.currentTarget.style.borderColor = utils_1.cssVars.border;
|
|
80
|
+
e.currentTarget.style.boxShadow = 'none';
|
|
81
|
+
}, children: loading ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(lucide_react_1.Loader2, { size: 16, style: { animation: 'ipulse-spin 0.8s linear infinite', flexShrink: 0 } }), loadingText ?? children] })) : (children) }));
|
|
82
|
+
};
|
|
83
|
+
exports.AuthOutlineButton = AuthOutlineButton;
|
|
84
|
+
//# sourceMappingURL=AuthButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthButton.js","sourceRoot":"","sources":["../../src/shared/AuthButton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface AuthCardProps {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
/** Max width of the card, default '420px' */
|
|
5
|
+
maxWidth?: string;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Shared card container used by all auth components.
|
|
9
|
+
* Handles max-width, shadow, border, radius, and keyframe injection.
|
|
10
|
+
*/
|
|
11
|
+
export declare const AuthCard: React.FC<AuthCardProps>;
|
|
12
|
+
//# sourceMappingURL=AuthCard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthCard.d.ts","sourceRoot":"","sources":["../../src/shared/AuthCard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,MAAM,WAAW,aAAa;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,6CAA6C;IAC7C,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;;GAGG;AACH,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CA8B5C,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AuthCard = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const utils_1 = require("../utils");
|
|
6
|
+
const styles_1 = require("./styles");
|
|
7
|
+
/**
|
|
8
|
+
* Shared card container used by all auth components.
|
|
9
|
+
* Handles max-width, shadow, border, radius, and keyframe injection.
|
|
10
|
+
*/
|
|
11
|
+
const AuthCard = ({ children, maxWidth = '420px' }) => ((0, jsx_runtime_1.jsxs)("div", { style: { maxWidth, margin: '0 auto', width: '100%', fontFamily: 'inherit' }, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
12
|
+
backgroundColor: utils_1.cssVars.card,
|
|
13
|
+
color: utils_1.cssVars.cardFg,
|
|
14
|
+
border: `1px solid ${utils_1.cssVars.borderMuted}`,
|
|
15
|
+
borderRadius: utils_1.cssVars.radius.xl,
|
|
16
|
+
padding: '2.5rem 2rem',
|
|
17
|
+
boxShadow: '0 12px 48px -12px rgba(0,0,0,0.10), 0 4px 16px -4px rgba(0,0,0,0.04)',
|
|
18
|
+
position: 'relative',
|
|
19
|
+
overflow: 'hidden',
|
|
20
|
+
}, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
21
|
+
position: 'absolute',
|
|
22
|
+
top: 0,
|
|
23
|
+
left: 0,
|
|
24
|
+
right: 0,
|
|
25
|
+
height: '2px',
|
|
26
|
+
background: `linear-gradient(90deg, transparent, ${utils_1.cssVars.primary}, transparent)`,
|
|
27
|
+
opacity: 0.35,
|
|
28
|
+
} }), children] }), (0, jsx_runtime_1.jsx)("style", { children: styles_1.AUTH_KEYFRAMES })] }));
|
|
29
|
+
exports.AuthCard = AuthCard;
|
|
30
|
+
//# sourceMappingURL=AuthCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthCard.js","sourceRoot":"","sources":["../../src/shared/AuthCard.tsx"],"names":[],"mappings":";;;;AACA,oCAAmC;AACnC,qCAA0C;AAQ1C;;;GAGG;AACI,MAAM,QAAQ,GAA4B,CAAC,EAAE,QAAQ,EAAE,QAAQ,GAAG,OAAO,EAAE,EAAE,EAAE,CAAC,CACnF,iCAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,aAC5E,iCACI,KAAK,EAAE;gBACH,eAAe,EAAE,eAAO,CAAC,IAAI;gBAC7B,KAAK,EAAE,eAAO,CAAC,MAAM;gBACrB,MAAM,EAAE,aAAa,eAAO,CAAC,WAAW,EAAE;gBAC1C,YAAY,EAAE,eAAO,CAAC,MAAM,CAAC,EAAE;gBAC/B,OAAO,EAAE,aAAa;gBACtB,SAAS,EAAE,sEAAsE;gBACjF,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE,QAAQ;aACrB,aAGD,gCACI,KAAK,EAAE;wBACH,QAAQ,EAAE,UAAU;wBACpB,GAAG,EAAE,CAAC;wBACN,IAAI,EAAE,CAAC;wBACP,KAAK,EAAE,CAAC;wBACR,MAAM,EAAE,KAAK;wBACb,UAAU,EAAE,uCAAuC,eAAO,CAAC,OAAO,gBAAgB;wBAClF,OAAO,EAAE,IAAI;qBAChB,GACH,EACD,QAAQ,IACP,EACN,4CAAQ,uBAAc,GAAS,IAC7B,CACT,CAAC;AA9BW,QAAA,QAAQ,YA8BnB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
interface AuthDividerProps {
|
|
3
|
+
label?: string;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* "— or —" style divider between auth methods.
|
|
7
|
+
*/
|
|
8
|
+
export declare const AuthDivider: React.FC<AuthDividerProps>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=AuthDivider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthDivider.d.ts","sourceRoot":"","sources":["../../src/shared/AuthDivider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,UAAU,gBAAgB;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAoBlD,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AuthDivider = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const utils_1 = require("../utils");
|
|
6
|
+
/**
|
|
7
|
+
* "— or —" style divider between auth methods.
|
|
8
|
+
*/
|
|
9
|
+
const AuthDivider = ({ label = 'of' }) => ((0, jsx_runtime_1.jsxs)("div", { role: "separator", "aria-label": label, style: { display: 'flex', alignItems: 'center', gap: '0.75rem' }, children: [(0, jsx_runtime_1.jsx)("div", { style: { flex: 1, height: '1px', backgroundColor: utils_1.cssVars.borderMuted } }), (0, jsx_runtime_1.jsx)("span", { style: {
|
|
10
|
+
color: utils_1.cssVars.mutedFg,
|
|
11
|
+
fontSize: '0.75rem',
|
|
12
|
+
textTransform: 'uppercase',
|
|
13
|
+
letterSpacing: '0.06em',
|
|
14
|
+
fontWeight: 500,
|
|
15
|
+
}, children: label }), (0, jsx_runtime_1.jsx)("div", { style: { flex: 1, height: '1px', backgroundColor: utils_1.cssVars.borderMuted } })] }));
|
|
16
|
+
exports.AuthDivider = AuthDivider;
|
|
17
|
+
//# sourceMappingURL=AuthDivider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthDivider.js","sourceRoot":"","sources":["../../src/shared/AuthDivider.tsx"],"names":[],"mappings":";;;;AACA,oCAAmC;AAMnC;;GAEG;AACI,MAAM,WAAW,GAA+B,CAAC,EAAE,KAAK,GAAG,IAAI,EAAE,EAAE,EAAE,CAAC,CACzE,iCACI,IAAI,EAAC,WAAW,gBACJ,KAAK,EACjB,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,aAEhE,gCAAK,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,eAAe,EAAE,eAAO,CAAC,WAAW,EAAE,GAAI,EAChF,iCACI,KAAK,EAAE;gBACH,KAAK,EAAE,eAAO,CAAC,OAAO;gBACtB,QAAQ,EAAE,SAAS;gBACnB,aAAa,EAAE,WAAW;gBAC1B,aAAa,EAAE,QAAQ;gBACvB,UAAU,EAAE,GAAG;aAClB,YAEA,KAAK,GACH,EACP,gCAAK,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,eAAe,EAAE,eAAO,CAAC,WAAW,EAAE,GAAI,IAC9E,CACT,CAAC;AApBW,QAAA,WAAW,eAoBtB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface AuthEmailInputProps {
|
|
3
|
+
id?: string;
|
|
4
|
+
value: string;
|
|
5
|
+
onChange: (value: string) => void;
|
|
6
|
+
placeholder?: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
autoFocus?: boolean;
|
|
10
|
+
onKeyDown?: React.KeyboardEventHandler<HTMLInputElement>;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Shared email input with animated icon, focus ring, and label.
|
|
14
|
+
* Fully keyboard-accessible: autoFocus, Tab, Enter support.
|
|
15
|
+
*/
|
|
16
|
+
export declare const AuthEmailInput: React.FC<AuthEmailInputProps>;
|
|
17
|
+
//# sourceMappingURL=AuthEmailInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthEmailInput.d.ts","sourceRoot":"","sources":["../../src/shared/AuthEmailInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAI/B,MAAM,WAAW,mBAAmB;IAChC,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,SAAS,CAAC,EAAE,KAAK,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,CAAC;CAC5D;AAED;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CA8ExD,CAAC"}
|