@windrun-huaiin/third-ui 7.1.2 → 7.2.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.
Files changed (77) hide show
  1. package/dist/clerk/clerk-page-generator-client.d.ts +10 -0
  2. package/dist/clerk/clerk-page-generator-client.js +28 -0
  3. package/dist/clerk/clerk-page-generator-client.mjs +25 -0
  4. package/dist/clerk/clerk-page-generator.js +1 -0
  5. package/dist/clerk/clerk-page-generator.mjs +1 -0
  6. package/dist/clerk/client-page-generator.d.ts +10 -0
  7. package/dist/clerk/client-page-generator.js +28 -0
  8. package/dist/clerk/client-page-generator.mjs +25 -0
  9. package/dist/clerk/context/FingerprintProvider.d.ts +25 -0
  10. package/dist/clerk/context/FingerprintProvider.js +71 -0
  11. package/dist/clerk/context/FingerprintProvider.mjs +65 -0
  12. package/dist/clerk/fingerprint/fingerprint-client.d.ts +47 -0
  13. package/dist/clerk/fingerprint/fingerprint-client.js +183 -0
  14. package/dist/clerk/fingerprint/fingerprint-client.mjs +174 -0
  15. package/dist/clerk/fingerprint/fingerprint-provider.d.ts +25 -0
  16. package/dist/clerk/fingerprint/fingerprint-provider.js +71 -0
  17. package/dist/clerk/fingerprint/fingerprint-provider.mjs +65 -0
  18. package/dist/clerk/fingerprint/fingerprint-server.d.ts +22 -0
  19. package/dist/clerk/fingerprint/fingerprint-server.js +75 -0
  20. package/dist/clerk/fingerprint/fingerprint-server.mjs +71 -0
  21. package/dist/clerk/fingerprint/fingerprint-shared.d.ts +17 -0
  22. package/dist/clerk/fingerprint/fingerprint-shared.js +35 -0
  23. package/dist/clerk/fingerprint/fingerprint-shared.mjs +29 -0
  24. package/dist/clerk/fingerprint/fingerprint.d.ts +55 -0
  25. package/dist/clerk/fingerprint/fingerprint.js +17 -0
  26. package/dist/clerk/fingerprint/fingerprint.mjs +15 -0
  27. package/dist/clerk/fingerprint/index.d.ts +5 -0
  28. package/dist/clerk/fingerprint/index.js +29 -0
  29. package/dist/clerk/fingerprint/index.mjs +5 -0
  30. package/dist/clerk/fingerprint/server.d.ts +3 -0
  31. package/dist/clerk/fingerprint/server.js +15 -0
  32. package/dist/clerk/fingerprint/server.mjs +2 -0
  33. package/dist/clerk/fingerprint/types.d.ts +42 -0
  34. package/dist/clerk/fingerprint/use-fingerprint.d.ts +6 -0
  35. package/dist/clerk/fingerprint/use-fingerprint.js +182 -0
  36. package/dist/clerk/fingerprint/use-fingerprint.mjs +180 -0
  37. package/dist/clerk/fingerprint.d.ts +55 -0
  38. package/dist/clerk/fingerprint.js +237 -0
  39. package/dist/clerk/fingerprint.mjs +225 -0
  40. package/dist/clerk/hooks/useFingerprint.d.ts +6 -0
  41. package/dist/clerk/hooks/useFingerprint.js +182 -0
  42. package/dist/clerk/hooks/useFingerprint.mjs +180 -0
  43. package/dist/clerk/index.d.ts +3 -0
  44. package/dist/clerk/index.js +7 -0
  45. package/dist/clerk/index.mjs +3 -0
  46. package/dist/clerk/signin-with-fingerprint-client.d.ts +7 -0
  47. package/dist/clerk/signin-with-fingerprint-client.js +52 -0
  48. package/dist/clerk/signin-with-fingerprint-client.mjs +47 -0
  49. package/dist/clerk/signup-with-fingerprint-client.d.ts +7 -0
  50. package/dist/clerk/signup-with-fingerprint-client.js +52 -0
  51. package/dist/clerk/signup-with-fingerprint-client.mjs +47 -0
  52. package/dist/clerk/types.d.ts +42 -0
  53. package/dist/fuma/mdx/toc-base.js +1 -1
  54. package/dist/fuma/mdx/toc-base.mjs +1 -1
  55. package/dist/node_modules/.pnpm/@fingerprintjs_fingerprintjs@4.6.2/node_modules/@fingerprintjs/fingerprintjs/dist/fp.esm.js +3245 -0
  56. package/dist/node_modules/.pnpm/@fingerprintjs_fingerprintjs@4.6.2/node_modules/@fingerprintjs/fingerprintjs/dist/fp.esm.mjs +3218 -0
  57. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.js +51 -0
  58. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.mjs +50 -1
  59. package/dist/node_modules/.pnpm/cose-base@1.0.3/node_modules/cose-base/cose-base.js +1 -1
  60. package/dist/node_modules/.pnpm/cose-base@2.2.0/node_modules/cose-base/cose-base.js +1 -1
  61. package/dist/node_modules/.pnpm/layout-base@1.0.2/node_modules/layout-base/layout-base.js +1 -1
  62. package/dist/node_modules/.pnpm/layout-base@2.0.1/node_modules/layout-base/layout-base.js +1 -1
  63. package/package.json +12 -1
  64. package/src/clerk/clerk-page-generator-client.tsx +37 -0
  65. package/src/clerk/clerk-page-generator.tsx +5 -1
  66. package/src/clerk/fingerprint/fingerprint-client.ts +202 -0
  67. package/src/clerk/fingerprint/fingerprint-provider.tsx +114 -0
  68. package/src/clerk/fingerprint/fingerprint-server.ts +88 -0
  69. package/src/clerk/fingerprint/fingerprint-shared.ts +29 -0
  70. package/src/clerk/fingerprint/index.ts +15 -0
  71. package/src/clerk/fingerprint/server.ts +9 -0
  72. package/src/clerk/fingerprint/types.ts +48 -0
  73. package/src/clerk/fingerprint/use-fingerprint.ts +208 -0
  74. package/src/clerk/index.ts +9 -2
  75. package/src/clerk/server.ts +1 -0
  76. package/src/clerk/signin-with-fingerprint-client.tsx +57 -0
  77. package/src/clerk/signup-with-fingerprint-client.tsx +57 -0
@@ -0,0 +1,180 @@
1
+ "use client";
2
+ import { __awaiter } from '../../node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.mjs';
3
+ import { useState, useCallback, useEffect } from 'react';
4
+ import { getFingerprintId, getOrGenerateFingerprintId, createFingerprintHeaders, setFingerprintId } from '../fingerprint.mjs';
5
+
6
+ /**
7
+ * Hook for managing fingerprint ID and anonymous user data
8
+ * Accepts configuration to customize API endpoint and behavior
9
+ */
10
+ function useFingerprint(config) {
11
+ const [fingerprintId, setFingerprintIdState] = useState(null);
12
+ const [anonymousUser, setAnonymousUser] = useState(null);
13
+ const [credits, setCredits] = useState(null);
14
+ const [isLoading, setIsLoading] = useState(true);
15
+ const [isInitialized, setIsInitialized] = useState(false);
16
+ const [error, setError] = useState(null);
17
+ /**
18
+ * 第一阶段:初始化fingerprint ID
19
+ */
20
+ const initializeFingerprintId = useCallback(() => __awaiter(this, void 0, void 0, function* () {
21
+ if (typeof window === 'undefined')
22
+ return null;
23
+ try {
24
+ // 优先检查现有ID
25
+ const existingId = getFingerprintId();
26
+ if (existingId) {
27
+ setFingerprintIdState(existingId);
28
+ return existingId;
29
+ }
30
+ // 生成新的fingerprint ID
31
+ const currentFingerprintId = yield getOrGenerateFingerprintId();
32
+ setFingerprintIdState(currentFingerprintId);
33
+ return currentFingerprintId;
34
+ }
35
+ catch (error) {
36
+ console.error('Failed to initialize fingerprint ID:', error);
37
+ setError('Failed to generate fingerprint ID');
38
+ return null;
39
+ }
40
+ }), []);
41
+ /**
42
+ * 第二阶段:初始化匿名用户
43
+ */
44
+ const initializeAnonymousUser = useCallback(() => __awaiter(this, void 0, void 0, function* () {
45
+ if (!fingerprintId) {
46
+ console.warn('Cannot initialize user without fingerprint ID');
47
+ return;
48
+ }
49
+ try {
50
+ setIsLoading(true);
51
+ setError(null);
52
+ const fingerprintHeaders = yield createFingerprintHeaders();
53
+ const response = yield fetch(config.apiEndpoint, {
54
+ method: 'POST',
55
+ headers: Object.assign({ 'Content-Type': 'application/json' }, fingerprintHeaders),
56
+ body: JSON.stringify({
57
+ fingerprintId: fingerprintId,
58
+ }),
59
+ });
60
+ if (!response.ok) {
61
+ const errorData = yield response.json().catch(() => ({}));
62
+ throw new Error(errorData.error || 'Failed to initialize anonymous user');
63
+ }
64
+ const data = yield response.json();
65
+ if (data.success) {
66
+ setAnonymousUser(data.user);
67
+ setCredits(data.credits);
68
+ setIsInitialized(true);
69
+ // 确保fingerprint ID同步
70
+ if (data.user.fingerprintId !== fingerprintId) {
71
+ setFingerprintId(data.user.fingerprintId);
72
+ setFingerprintIdState(data.user.fingerprintId);
73
+ }
74
+ }
75
+ else {
76
+ throw new Error(data.error || 'Unknown error occurred');
77
+ }
78
+ }
79
+ catch (err) {
80
+ console.error('Failed to initialize anonymous user:', err);
81
+ setError(err instanceof Error ? err.message : 'Unknown error');
82
+ }
83
+ finally {
84
+ setIsLoading(false);
85
+ }
86
+ }), [fingerprintId]);
87
+ /**
88
+ * 刷新用户数据
89
+ */
90
+ const refreshUserData = useCallback(() => __awaiter(this, void 0, void 0, function* () {
91
+ if (!fingerprintId)
92
+ return;
93
+ try {
94
+ setError(null);
95
+ const fingerprintHeaders = yield createFingerprintHeaders();
96
+ const response = yield fetch(`${config.apiEndpoint}?fingerprintId=${fingerprintId}`, {
97
+ method: 'GET',
98
+ headers: fingerprintHeaders,
99
+ });
100
+ if (!response.ok) {
101
+ if (response.status === 404) {
102
+ // 用户不存在,需要重新初始化
103
+ yield initializeAnonymousUser();
104
+ return;
105
+ }
106
+ throw new Error('Failed to fetch user data');
107
+ }
108
+ const data = yield response.json();
109
+ if (data.success) {
110
+ setAnonymousUser(data.user);
111
+ setCredits(data.credits);
112
+ }
113
+ }
114
+ catch (err) {
115
+ console.error('Failed to refresh user data:', err);
116
+ setError(err instanceof Error ? err.message : 'Unknown error');
117
+ }
118
+ }), [fingerprintId, initializeAnonymousUser, config.apiEndpoint]);
119
+ /**
120
+ * 检查现有用户数据(仅在有fingerprint ID时执行)
121
+ */
122
+ const checkExistingUser = useCallback(() => __awaiter(this, void 0, void 0, function* () {
123
+ if (!fingerprintId)
124
+ return;
125
+ try {
126
+ const fingerprintHeaders = yield createFingerprintHeaders();
127
+ const response = yield fetch(`${config.apiEndpoint}?fingerprintId=${fingerprintId}`, {
128
+ method: 'GET',
129
+ headers: fingerprintHeaders,
130
+ });
131
+ if (response.ok) {
132
+ const data = yield response.json();
133
+ if (data.success) {
134
+ setAnonymousUser(data.user);
135
+ setCredits(data.credits);
136
+ setIsInitialized(true);
137
+ }
138
+ }
139
+ }
140
+ catch (err) {
141
+ console.error('Failed to check existing user:', err);
142
+ }
143
+ }), [fingerprintId, config.apiEndpoint]);
144
+ // 第一阶段:页面加载完成后生成指纹ID
145
+ useEffect(() => {
146
+ if (typeof window === 'undefined')
147
+ return;
148
+ const initFingerprint = () => __awaiter(this, void 0, void 0, function* () {
149
+ yield initializeFingerprintId();
150
+ setIsLoading(false); // 第一阶段完成,结束加载状态
151
+ });
152
+ initFingerprint();
153
+ }, [initializeFingerprintId]);
154
+ // 第二阶段:有指纹ID后检查现有用户
155
+ useEffect(() => {
156
+ if (!fingerprintId || isInitialized)
157
+ return;
158
+ checkExistingUser();
159
+ }, [fingerprintId, isInitialized, checkExistingUser]);
160
+ // 第三阶段:如果没有现有用户且自动初始化开启,则创建新用户
161
+ useEffect(() => {
162
+ if (!fingerprintId || isInitialized || isLoading || error)
163
+ return;
164
+ if (config.autoInitialize === false)
165
+ return;
166
+ initializeAnonymousUser();
167
+ }, [fingerprintId, isInitialized, isLoading, error, initializeAnonymousUser, config.autoInitialize]);
168
+ return {
169
+ fingerprintId,
170
+ anonymousUser,
171
+ credits,
172
+ isLoading,
173
+ isInitialized,
174
+ error,
175
+ initializeAnonymousUser,
176
+ refreshUserData,
177
+ };
178
+ }
179
+
180
+ export { useFingerprint };
@@ -1 +1,4 @@
1
1
  export * from './clerk-provider-client';
2
+ export * from './signup-with-fingerprint-client';
3
+ export * from './signin-with-fingerprint-client';
4
+ export * from './clerk-page-generator-client';
@@ -2,7 +2,14 @@
2
2
  'use strict';
3
3
 
4
4
  var clerkProviderClient = require('./clerk-provider-client.js');
5
+ var signupWithFingerprintClient = require('./signup-with-fingerprint-client.js');
6
+ var signinWithFingerprintClient = require('./signin-with-fingerprint-client.js');
7
+ var clerkPageGeneratorClient = require('./clerk-page-generator-client.js');
5
8
 
6
9
 
7
10
 
8
11
  exports.ClerkProviderClient = clerkProviderClient.ClerkProviderClient;
12
+ exports.SignUpWithFingerprint = signupWithFingerprintClient.SignUpWithFingerprint;
13
+ exports.SignInWithFingerprint = signinWithFingerprintClient.SignInWithFingerprint;
14
+ exports.createSignInPageWithFingerprint = clerkPageGeneratorClient.createSignInPageWithFingerprint;
15
+ exports.createSignUpPageWithFingerprint = clerkPageGeneratorClient.createSignUpPageWithFingerprint;
@@ -1,2 +1,5 @@
1
1
  "use client";
2
2
  export { ClerkProviderClient } from './clerk-provider-client.mjs';
3
+ export { SignUpWithFingerprint } from './signup-with-fingerprint-client.mjs';
4
+ export { SignInWithFingerprint } from './signin-with-fingerprint-client.mjs';
5
+ export { createSignInPageWithFingerprint, createSignUpPageWithFingerprint } from './clerk-page-generator-client.mjs';
@@ -0,0 +1,7 @@
1
+ /**
2
+ * SignIn component with fingerprint awareness
3
+ * 如果没有FingerprintProvider,会优雅降级为普通SignIn组件
4
+ * 如果有FingerprintProvider,会处理fingerprint相关逻辑
5
+ */
6
+ export declare function SignInWithFingerprint(): import("react/jsx-runtime").JSX.Element;
7
+ export default SignInWithFingerprint;
@@ -0,0 +1,52 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ var tslib_es6 = require('../node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.js');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+ var nextjs = require('@clerk/nextjs');
9
+ var React = require('react');
10
+ var fingerprintProvider = require('./fingerprint/fingerprint-provider.js');
11
+
12
+ /**
13
+ * SignIn component with fingerprint awareness
14
+ * 如果没有FingerprintProvider,会优雅降级为普通SignIn组件
15
+ * 如果有FingerprintProvider,会处理fingerprint相关逻辑
16
+ */
17
+ function SignInWithFingerprint() {
18
+ const fingerprintContext = fingerprintProvider.useFingerprintContextSafe();
19
+ // 如果没有fingerprint context,使用默认值
20
+ const { fingerprintId = null, anonymousUser = null, isInitialized = false, initializeAnonymousUser = () => tslib_es6.__awaiter(this, void 0, void 0, function* () { }) } = fingerprintContext || {};
21
+ // 准备传递给Clerk的metadata,包含匿名用户信息
22
+ const unsafeMetadata = {
23
+ user_id: (anonymousUser === null || anonymousUser === void 0 ? void 0 : anonymousUser.userId) || null, // 数据库中的user_id
24
+ fingerprint_id: fingerprintId || null, // 浏览器指纹ID
25
+ };
26
+ // 确保匿名用户已初始化
27
+ React.useEffect(() => {
28
+ if (!isInitialized && fingerprintId) {
29
+ initializeAnonymousUser();
30
+ }
31
+ }, [fingerprintId, isInitialized, initializeAnonymousUser]);
32
+ // 调试日志和处理登录逻辑
33
+ React.useEffect(() => {
34
+ console.log('SignInWithFingerprint Debug:', {
35
+ fingerprintProvider: fingerprintContext ? 'Available' : 'Not found',
36
+ fingerprintId: fingerprintId || 'Not generated',
37
+ anonymousUser: anonymousUser ? 'Initialized' : 'Not initialized',
38
+ clerkMetadata: unsafeMetadata
39
+ });
40
+ if (anonymousUser && fingerprintId) {
41
+ console.log('User signed in with existing anonymous data:', {
42
+ anonymousUserId: anonymousUser.userId,
43
+ fingerprintId,
44
+ });
45
+ // TODO: 实现数据合并逻辑
46
+ }
47
+ }, [anonymousUser, fingerprintId, fingerprintContext, unsafeMetadata]);
48
+ return jsxRuntime.jsx(nextjs.SignIn, { unsafeMetadata: unsafeMetadata });
49
+ }
50
+
51
+ exports.SignInWithFingerprint = SignInWithFingerprint;
52
+ exports.default = SignInWithFingerprint;
@@ -0,0 +1,47 @@
1
+ "use client";
2
+ import { __awaiter } from '../node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.mjs';
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import { SignIn } from '@clerk/nextjs';
5
+ import { useEffect } from 'react';
6
+ import { useFingerprintContextSafe } from './fingerprint/fingerprint-provider.mjs';
7
+
8
+ /**
9
+ * SignIn component with fingerprint awareness
10
+ * 如果没有FingerprintProvider,会优雅降级为普通SignIn组件
11
+ * 如果有FingerprintProvider,会处理fingerprint相关逻辑
12
+ */
13
+ function SignInWithFingerprint() {
14
+ const fingerprintContext = useFingerprintContextSafe();
15
+ // 如果没有fingerprint context,使用默认值
16
+ const { fingerprintId = null, anonymousUser = null, isInitialized = false, initializeAnonymousUser = () => __awaiter(this, void 0, void 0, function* () { }) } = fingerprintContext || {};
17
+ // 准备传递给Clerk的metadata,包含匿名用户信息
18
+ const unsafeMetadata = {
19
+ user_id: (anonymousUser === null || anonymousUser === void 0 ? void 0 : anonymousUser.userId) || null, // 数据库中的user_id
20
+ fingerprint_id: fingerprintId || null, // 浏览器指纹ID
21
+ };
22
+ // 确保匿名用户已初始化
23
+ useEffect(() => {
24
+ if (!isInitialized && fingerprintId) {
25
+ initializeAnonymousUser();
26
+ }
27
+ }, [fingerprintId, isInitialized, initializeAnonymousUser]);
28
+ // 调试日志和处理登录逻辑
29
+ useEffect(() => {
30
+ console.log('SignInWithFingerprint Debug:', {
31
+ fingerprintProvider: fingerprintContext ? 'Available' : 'Not found',
32
+ fingerprintId: fingerprintId || 'Not generated',
33
+ anonymousUser: anonymousUser ? 'Initialized' : 'Not initialized',
34
+ clerkMetadata: unsafeMetadata
35
+ });
36
+ if (anonymousUser && fingerprintId) {
37
+ console.log('User signed in with existing anonymous data:', {
38
+ anonymousUserId: anonymousUser.userId,
39
+ fingerprintId,
40
+ });
41
+ // TODO: 实现数据合并逻辑
42
+ }
43
+ }, [anonymousUser, fingerprintId, fingerprintContext, unsafeMetadata]);
44
+ return jsx(SignIn, { unsafeMetadata: unsafeMetadata });
45
+ }
46
+
47
+ export { SignInWithFingerprint, SignInWithFingerprint as default };
@@ -0,0 +1,7 @@
1
+ /**
2
+ * SignUp component with fingerprint awareness
3
+ * 如果没有FingerprintProvider,会优雅降级为普通SignUp组件
4
+ * 如果有FingerprintProvider,会处理fingerprint相关逻辑
5
+ */
6
+ export declare function SignUpWithFingerprint(): import("react/jsx-runtime").JSX.Element;
7
+ export default SignUpWithFingerprint;
@@ -0,0 +1,52 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ var tslib_es6 = require('../node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.js');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+ var nextjs = require('@clerk/nextjs');
9
+ var React = require('react');
10
+ var fingerprintProvider = require('./fingerprint/fingerprint-provider.js');
11
+
12
+ /**
13
+ * SignUp component with fingerprint awareness
14
+ * 如果没有FingerprintProvider,会优雅降级为普通SignUp组件
15
+ * 如果有FingerprintProvider,会处理fingerprint相关逻辑
16
+ */
17
+ function SignUpWithFingerprint() {
18
+ const fingerprintContext = fingerprintProvider.useFingerprintContextSafe();
19
+ // 如果没有fingerprint context,使用默认值
20
+ const { fingerprintId = null, anonymousUser = null, isInitialized = false, initializeAnonymousUser = () => tslib_es6.__awaiter(this, void 0, void 0, function* () { }) } = fingerprintContext || {};
21
+ // 准备传递给Clerk的metadata,包含匿名用户信息
22
+ const unsafeMetadata = {
23
+ user_id: (anonymousUser === null || anonymousUser === void 0 ? void 0 : anonymousUser.userId) || null, // 数据库中的user_id
24
+ fingerprint_id: fingerprintId || null, // 浏览器指纹ID
25
+ };
26
+ // 确保匿名用户已初始化
27
+ React.useEffect(() => {
28
+ if (!isInitialized && fingerprintId) {
29
+ initializeAnonymousUser();
30
+ }
31
+ }, [fingerprintId, isInitialized, initializeAnonymousUser]);
32
+ // 调试日志和处理注册逻辑
33
+ React.useEffect(() => {
34
+ console.log('SignUpWithFingerprint Debug:', {
35
+ fingerprintProvider: fingerprintContext ? 'Available' : 'Not found',
36
+ fingerprintId: fingerprintId || 'Not generated',
37
+ anonymousUser: anonymousUser ? 'Initialized' : 'Not initialized',
38
+ clerkMetadata: unsafeMetadata
39
+ });
40
+ if (anonymousUser && fingerprintId) {
41
+ console.log('User signed up with existing anonymous data:', {
42
+ anonymousUserId: anonymousUser.userId,
43
+ fingerprintId,
44
+ });
45
+ // TODO: 实现数据迁移逻辑
46
+ }
47
+ }, [anonymousUser, fingerprintId, fingerprintContext, unsafeMetadata]);
48
+ return jsxRuntime.jsx(nextjs.SignUp, { unsafeMetadata: unsafeMetadata });
49
+ }
50
+
51
+ exports.SignUpWithFingerprint = SignUpWithFingerprint;
52
+ exports.default = SignUpWithFingerprint;
@@ -0,0 +1,47 @@
1
+ "use client";
2
+ import { __awaiter } from '../node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.46.2_tslib@2.8.1_typescript@5.9.2/node_modules/tslib/tslib.es6.mjs';
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import { SignUp } from '@clerk/nextjs';
5
+ import { useEffect } from 'react';
6
+ import { useFingerprintContextSafe } from './fingerprint/fingerprint-provider.mjs';
7
+
8
+ /**
9
+ * SignUp component with fingerprint awareness
10
+ * 如果没有FingerprintProvider,会优雅降级为普通SignUp组件
11
+ * 如果有FingerprintProvider,会处理fingerprint相关逻辑
12
+ */
13
+ function SignUpWithFingerprint() {
14
+ const fingerprintContext = useFingerprintContextSafe();
15
+ // 如果没有fingerprint context,使用默认值
16
+ const { fingerprintId = null, anonymousUser = null, isInitialized = false, initializeAnonymousUser = () => __awaiter(this, void 0, void 0, function* () { }) } = fingerprintContext || {};
17
+ // 准备传递给Clerk的metadata,包含匿名用户信息
18
+ const unsafeMetadata = {
19
+ user_id: (anonymousUser === null || anonymousUser === void 0 ? void 0 : anonymousUser.userId) || null, // 数据库中的user_id
20
+ fingerprint_id: fingerprintId || null, // 浏览器指纹ID
21
+ };
22
+ // 确保匿名用户已初始化
23
+ useEffect(() => {
24
+ if (!isInitialized && fingerprintId) {
25
+ initializeAnonymousUser();
26
+ }
27
+ }, [fingerprintId, isInitialized, initializeAnonymousUser]);
28
+ // 调试日志和处理注册逻辑
29
+ useEffect(() => {
30
+ console.log('SignUpWithFingerprint Debug:', {
31
+ fingerprintProvider: fingerprintContext ? 'Available' : 'Not found',
32
+ fingerprintId: fingerprintId || 'Not generated',
33
+ anonymousUser: anonymousUser ? 'Initialized' : 'Not initialized',
34
+ clerkMetadata: unsafeMetadata
35
+ });
36
+ if (anonymousUser && fingerprintId) {
37
+ console.log('User signed up with existing anonymous data:', {
38
+ anonymousUserId: anonymousUser.userId,
39
+ fingerprintId,
40
+ });
41
+ // TODO: 实现数据迁移逻辑
42
+ }
43
+ }, [anonymousUser, fingerprintId, fingerprintContext, unsafeMetadata]);
44
+ return jsx(SignUp, { unsafeMetadata: unsafeMetadata });
45
+ }
46
+
47
+ export { SignUpWithFingerprint, SignUpWithFingerprint as default };
@@ -0,0 +1,42 @@
1
+ /**
2
+ * Fingerprint System Types
3
+ * 指纹识别系统的类型定义
4
+ */
5
+ export interface AnonymousUser {
6
+ userId: string;
7
+ fingerprintId: string;
8
+ status: string;
9
+ createdAt: string;
10
+ }
11
+ export interface Credits {
12
+ balanceFree: number;
13
+ balancePaid: number;
14
+ totalBalance: number;
15
+ }
16
+ export interface FingerprintConfig {
17
+ /** API endpoint for anonymous user initialization */
18
+ apiEndpoint: string;
19
+ /** Whether to automatically initialize the user on load */
20
+ autoInitialize?: boolean;
21
+ /** Initial credits for new users */
22
+ initialCredits?: number;
23
+ }
24
+ export interface UseFingerprintResult {
25
+ fingerprintId: string | null;
26
+ anonymousUser: AnonymousUser | null;
27
+ credits: Credits | null;
28
+ isLoading: boolean;
29
+ isInitialized: boolean;
30
+ error: string | null;
31
+ initializeAnonymousUser: () => Promise<void>;
32
+ refreshUserData: () => Promise<void>;
33
+ }
34
+ export interface FingerprintContextType extends UseFingerprintResult {
35
+ }
36
+ export interface FingerprintProviderProps {
37
+ children: React.ReactNode;
38
+ config: FingerprintConfig;
39
+ }
40
+ export interface FingerprintFetch {
41
+ (url: string | URL | Request, init?: RequestInit): Promise<Response>;
42
+ }
@@ -62,7 +62,7 @@ function EditOnGitHub({ url }) {
62
62
  }
63
63
  // New component for displaying the last updated date with an icon
64
64
  function LastUpdatedDate({ date }) {
65
- return (jsxRuntime.jsxs("div", { className: "flex items-center gap-x-2 text-stone-600 dark:text-stone-400 text-sm", children: [jsxRuntime.jsx(server.globalLucideIcons.LastUpdated, {}), "Lastest on ", date ? date : "Ages ago"] }));
65
+ return (jsxRuntime.jsxs("div", { className: "flex items-center gap-x-2 text-stone-600 dark:text-stone-400 text-sm", children: [jsxRuntime.jsx(server.globalLucideIcons.LastUpdated, {}), "Latest on ", date ? date : "Ages ago"] }));
66
66
  }
67
67
 
68
68
  exports.EditOnGitHub = EditOnGitHub;
@@ -60,7 +60,7 @@ function EditOnGitHub({ url }) {
60
60
  }
61
61
  // New component for displaying the last updated date with an icon
62
62
  function LastUpdatedDate({ date }) {
63
- return (jsxs("div", { className: "flex items-center gap-x-2 text-stone-600 dark:text-stone-400 text-sm", children: [jsx(globalLucideIcons.LastUpdated, {}), "Lastest on ", date ? date : "Ages ago"] }));
63
+ return (jsxs("div", { className: "flex items-center gap-x-2 text-stone-600 dark:text-stone-400 text-sm", children: [jsx(globalLucideIcons.LastUpdated, {}), "Latest on ", date ? date : "Ages ago"] }));
64
64
  }
65
65
 
66
66
  export { EditOnGitHub, LLMCopyButton, LastUpdatedDate };