sa2kit 2.0.0 → 2.0.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.
Files changed (264) hide show
  1. package/README.md +1 -1
  2. package/dist/CollisionBalls-BpHufX3H.d.mts +41 -0
  3. package/dist/CollisionBalls-BpHufX3H.d.ts +41 -0
  4. package/dist/ConfigService-BxK06xP6.d.mts +262 -0
  5. package/dist/ConfigService-BxK06xP6.d.ts +262 -0
  6. package/dist/UniversalFileService-BpvbZitV.d.mts +139 -0
  7. package/dist/UniversalFileService-GsP6D3Rc.d.ts +139 -0
  8. package/dist/audioDetection/index.d.mts +449 -0
  9. package/dist/audioDetection/index.d.ts +449 -0
  10. package/dist/audioDetection/index.js +1244 -0
  11. package/dist/audioDetection/index.js.map +1 -0
  12. package/dist/audioDetection/index.mjs +1227 -0
  13. package/dist/audioDetection/index.mjs.map +1 -0
  14. package/dist/auth/legacy/core/index.d.mts +42 -0
  15. package/dist/auth/legacy/core/index.d.ts +42 -0
  16. package/dist/auth/legacy/core/index.js +242 -0
  17. package/dist/auth/legacy/core/index.js.map +1 -0
  18. package/dist/auth/legacy/core/index.mjs +226 -0
  19. package/dist/auth/legacy/core/index.mjs.map +1 -0
  20. package/dist/auth/legacy/db/index.d.mts +5 -0
  21. package/dist/auth/legacy/db/index.d.ts +5 -0
  22. package/dist/auth/legacy/db/index.js +261 -0
  23. package/dist/auth/legacy/db/index.js.map +1 -0
  24. package/dist/auth/legacy/db/index.mjs +250 -0
  25. package/dist/auth/legacy/db/index.mjs.map +1 -0
  26. package/dist/auth/legacy/index.d.mts +5 -0
  27. package/dist/auth/legacy/index.d.ts +5 -0
  28. package/dist/auth/legacy/index.js +1107 -0
  29. package/dist/auth/legacy/index.js.map +1 -0
  30. package/dist/auth/legacy/index.mjs +1086 -0
  31. package/dist/auth/legacy/index.mjs.map +1 -0
  32. package/dist/auth/legacy/logic/index.d.mts +9 -0
  33. package/dist/auth/legacy/logic/index.d.ts +9 -0
  34. package/dist/auth/legacy/logic/index.js +194 -0
  35. package/dist/auth/legacy/logic/index.js.map +1 -0
  36. package/dist/auth/legacy/logic/index.mjs +187 -0
  37. package/dist/auth/legacy/logic/index.mjs.map +1 -0
  38. package/dist/auth/legacy/miniapp/index.d.mts +5 -0
  39. package/dist/auth/legacy/miniapp/index.d.ts +5 -0
  40. package/dist/auth/legacy/miniapp/index.js +506 -0
  41. package/dist/auth/legacy/miniapp/index.js.map +1 -0
  42. package/dist/auth/legacy/miniapp/index.mjs +487 -0
  43. package/dist/auth/legacy/miniapp/index.mjs.map +1 -0
  44. package/dist/auth/legacy/routes/index.d.mts +53 -0
  45. package/dist/auth/legacy/routes/index.d.ts +53 -0
  46. package/dist/auth/legacy/routes/index.js +278 -0
  47. package/dist/auth/legacy/routes/index.js.map +1 -0
  48. package/dist/auth/legacy/routes/index.mjs +271 -0
  49. package/dist/auth/legacy/routes/index.mjs.map +1 -0
  50. package/dist/auth/legacy/schema/index.d.mts +401 -0
  51. package/dist/auth/legacy/schema/index.d.ts +401 -0
  52. package/dist/auth/legacy/schema/index.js +50 -0
  53. package/dist/auth/legacy/schema/index.js.map +1 -0
  54. package/dist/auth/legacy/schema/index.mjs +44 -0
  55. package/dist/auth/legacy/schema/index.mjs.map +1 -0
  56. package/dist/auth/legacy/server/index.d.mts +13 -0
  57. package/dist/auth/legacy/server/index.d.ts +13 -0
  58. package/dist/auth/legacy/server/index.js +21 -0
  59. package/dist/auth/legacy/server/index.js.map +1 -0
  60. package/dist/auth/legacy/server/index.mjs +19 -0
  61. package/dist/auth/legacy/server/index.mjs.map +1 -0
  62. package/dist/auth/legacy/services/index.d.mts +40 -0
  63. package/dist/auth/legacy/services/index.d.ts +40 -0
  64. package/dist/auth/legacy/services/index.js +258 -0
  65. package/dist/auth/legacy/services/index.js.map +1 -0
  66. package/dist/auth/legacy/services/index.mjs +252 -0
  67. package/dist/auth/legacy/services/index.mjs.map +1 -0
  68. package/dist/auth/legacy/ui/miniapp/index.d.mts +10 -0
  69. package/dist/auth/legacy/ui/miniapp/index.d.ts +10 -0
  70. package/dist/auth/legacy/ui/miniapp/index.js +298 -0
  71. package/dist/auth/legacy/ui/miniapp/index.js.map +1 -0
  72. package/dist/auth/legacy/ui/miniapp/index.mjs +290 -0
  73. package/dist/auth/legacy/ui/miniapp/index.mjs.map +1 -0
  74. package/dist/auth/legacy/ui/web/index.d.mts +22 -0
  75. package/dist/auth/legacy/ui/web/index.d.ts +22 -0
  76. package/dist/auth/legacy/ui/web/index.js +899 -0
  77. package/dist/auth/legacy/ui/web/index.js.map +1 -0
  78. package/dist/auth/legacy/ui/web/index.mjs +889 -0
  79. package/dist/auth/legacy/ui/web/index.mjs.map +1 -0
  80. package/dist/auth/legacy/web/index.d.mts +5 -0
  81. package/dist/auth/legacy/web/index.d.ts +5 -0
  82. package/dist/auth/legacy/web/index.js +1107 -0
  83. package/dist/auth/legacy/web/index.js.map +1 -0
  84. package/dist/auth/legacy/web/index.mjs +1086 -0
  85. package/dist/auth/legacy/web/index.mjs.map +1 -0
  86. package/dist/auth/rn/index.d.mts +64 -0
  87. package/dist/auth/rn/index.d.ts +64 -0
  88. package/dist/auth/rn/index.js +765 -0
  89. package/dist/auth/rn/index.js.map +1 -0
  90. package/dist/auth/rn/index.mjs +754 -0
  91. package/dist/auth/rn/index.mjs.map +1 -0
  92. package/dist/base-api-client-ACKKt13v.d.mts +277 -0
  93. package/dist/base-api-client-ACKKt13v.d.ts +277 -0
  94. package/dist/boothVaultService-Cn4WPhjg.d.mts +83 -0
  95. package/dist/boothVaultService-Cn4WPhjg.d.ts +83 -0
  96. package/dist/business/index.d.mts +6 -0
  97. package/dist/business/index.d.ts +6 -0
  98. package/dist/business/index.js +1682 -0
  99. package/dist/business/index.js.map +1 -0
  100. package/dist/business/index.mjs +1675 -0
  101. package/dist/business/index.mjs.map +1 -0
  102. package/dist/calendar/index.d.mts +1325 -0
  103. package/dist/calendar/index.d.ts +1325 -0
  104. package/dist/calendar/index.js +5964 -0
  105. package/dist/calendar/index.js.map +1 -0
  106. package/dist/calendar/index.mjs +5878 -0
  107. package/dist/calendar/index.mjs.map +1 -0
  108. package/dist/components/index.d.mts +405 -0
  109. package/dist/components/index.d.ts +405 -0
  110. package/dist/components/index.js +2516 -0
  111. package/dist/components/index.js.map +1 -0
  112. package/dist/components/index.mjs +2396 -0
  113. package/dist/components/index.mjs.map +1 -0
  114. package/dist/drizzle-schema-BNhqj2AZ.d.mts +1114 -0
  115. package/dist/drizzle-schema-BNhqj2AZ.d.ts +1114 -0
  116. package/dist/festivalCard/index.d.mts +75 -0
  117. package/dist/festivalCard/index.d.ts +75 -0
  118. package/dist/festivalCard/index.js +1492 -0
  119. package/dist/festivalCard/index.js.map +1 -0
  120. package/dist/festivalCard/index.mjs +1475 -0
  121. package/dist/festivalCard/index.mjs.map +1 -0
  122. package/dist/festivalCard/server/index.d.mts +120 -0
  123. package/dist/festivalCard/server/index.d.ts +120 -0
  124. package/dist/festivalCard/server/index.js +272 -0
  125. package/dist/festivalCard/server/index.js.map +1 -0
  126. package/dist/festivalCard/server/index.mjs +265 -0
  127. package/dist/festivalCard/server/index.mjs.map +1 -0
  128. package/dist/festivalCardService-CZomuQ4E.d.mts +80 -0
  129. package/dist/festivalCardService-CZomuQ4E.d.ts +80 -0
  130. package/dist/index-1Ag7IBXN.d.ts +144 -0
  131. package/dist/index-DNKZ7-R_.d.mts +184 -0
  132. package/dist/index-DNKZ7-R_.d.ts +184 -0
  133. package/dist/index-DSel44Ke.d.mts +93 -0
  134. package/dist/index-DSel44Ke.d.ts +93 -0
  135. package/dist/index-DdeZSeTJ.d.mts +144 -0
  136. package/dist/index-DrPcMJPc.d.mts +250 -0
  137. package/dist/index-DrPcMJPc.d.ts +250 -0
  138. package/dist/index.d.mts +5333 -0
  139. package/dist/index.d.ts +5333 -0
  140. package/dist/index.js +18809 -0
  141. package/dist/index.js.map +1 -0
  142. package/dist/index.mjs +18533 -0
  143. package/dist/index.mjs.map +1 -0
  144. package/dist/mikuContest/ui/web/index.d.mts +2 -0
  145. package/dist/mikuContest/ui/web/index.d.ts +2 -0
  146. package/dist/mikuContest/ui/web/index.js +353 -0
  147. package/dist/mikuContest/ui/web/index.js.map +1 -0
  148. package/dist/mikuContest/ui/web/index.mjs +343 -0
  149. package/dist/mikuContest/ui/web/index.mjs.map +1 -0
  150. package/dist/mikuFireworks3D/index.d.mts +268 -0
  151. package/dist/mikuFireworks3D/index.d.ts +268 -0
  152. package/dist/mikuFireworks3D/index.js +1267 -0
  153. package/dist/mikuFireworks3D/index.js.map +1 -0
  154. package/dist/mikuFireworks3D/index.mjs +1228 -0
  155. package/dist/mikuFireworks3D/index.mjs.map +1 -0
  156. package/dist/mikuFusionGame/index.d.mts +117 -0
  157. package/dist/mikuFusionGame/index.d.ts +117 -0
  158. package/dist/mikuFusionGame/index.js +1208 -0
  159. package/dist/mikuFusionGame/index.js.map +1 -0
  160. package/dist/mikuFusionGame/index.mjs +1195 -0
  161. package/dist/mikuFusionGame/index.mjs.map +1 -0
  162. package/dist/mmd/admin/index.d.mts +487 -0
  163. package/dist/mmd/admin/index.d.ts +487 -0
  164. package/dist/mmd/admin/index.js +1058 -0
  165. package/dist/mmd/admin/index.js.map +1 -0
  166. package/dist/mmd/admin/index.mjs +1027 -0
  167. package/dist/mmd/admin/index.mjs.map +1 -0
  168. package/dist/mmd/index.d.mts +2467 -0
  169. package/dist/mmd/index.d.ts +2467 -0
  170. package/dist/mmd/index.js +10119 -0
  171. package/dist/mmd/index.js.map +1 -0
  172. package/dist/mmd/index.mjs +10028 -0
  173. package/dist/mmd/index.mjs.map +1 -0
  174. package/dist/mmd/server/index.d.mts +139 -0
  175. package/dist/mmd/server/index.d.ts +139 -0
  176. package/dist/mmd/server/index.js +424 -0
  177. package/dist/mmd/server/index.js.map +1 -0
  178. package/dist/mmd/server/index.mjs +404 -0
  179. package/dist/mmd/server/index.mjs.map +1 -0
  180. package/dist/music/index.d.mts +74 -0
  181. package/dist/music/index.d.ts +74 -0
  182. package/dist/music/index.js +830 -0
  183. package/dist/music/index.js.map +1 -0
  184. package/dist/music/index.mjs +809 -0
  185. package/dist/music/index.mjs.map +1 -0
  186. package/dist/music/server/index.d.mts +1 -0
  187. package/dist/music/server/index.d.ts +1 -0
  188. package/dist/music/server/index.js +194 -0
  189. package/dist/music/server/index.js.map +1 -0
  190. package/dist/music/server/index.mjs +182 -0
  191. package/dist/music/server/index.mjs.map +1 -0
  192. package/dist/navigation/index.d.mts +93 -0
  193. package/dist/navigation/index.d.ts +93 -0
  194. package/dist/navigation/index.js +453 -0
  195. package/dist/navigation/index.js.map +1 -0
  196. package/dist/navigation/index.mjs +443 -0
  197. package/dist/navigation/index.mjs.map +1 -0
  198. package/dist/portfolio/index.d.mts +66 -0
  199. package/dist/portfolio/index.d.ts +66 -0
  200. package/dist/portfolio/index.js +736 -0
  201. package/dist/portfolio/index.js.map +1 -0
  202. package/dist/portfolio/index.mjs +724 -0
  203. package/dist/portfolio/index.mjs.map +1 -0
  204. package/dist/qqbot/server/index.d.mts +216 -0
  205. package/dist/qqbot/server/index.d.ts +216 -0
  206. package/dist/qqbot/server/index.js +394 -0
  207. package/dist/qqbot/server/index.js.map +1 -0
  208. package/dist/qqbot/server/index.mjs +385 -0
  209. package/dist/qqbot/server/index.mjs.map +1 -0
  210. package/dist/qqbot/ui/web/index.d.mts +10 -0
  211. package/dist/qqbot/ui/web/index.d.ts +10 -0
  212. package/dist/qqbot/ui/web/index.js +105 -0
  213. package/dist/qqbot/ui/web/index.js.map +1 -0
  214. package/dist/qqbot/ui/web/index.mjs +99 -0
  215. package/dist/qqbot/ui/web/index.mjs.map +1 -0
  216. package/dist/screenReceiver/index.d.mts +86 -0
  217. package/dist/screenReceiver/index.d.ts +86 -0
  218. package/dist/screenReceiver/index.js +281 -0
  219. package/dist/screenReceiver/index.js.map +1 -0
  220. package/dist/screenReceiver/index.mjs +273 -0
  221. package/dist/screenReceiver/index.mjs.map +1 -0
  222. package/dist/testYourself/admin/index.d.mts +58 -0
  223. package/dist/testYourself/admin/index.d.ts +58 -0
  224. package/dist/testYourself/admin/index.js +1009 -0
  225. package/dist/testYourself/admin/index.js.map +1 -0
  226. package/dist/testYourself/admin/index.mjs +1002 -0
  227. package/dist/testYourself/admin/index.mjs.map +1 -0
  228. package/dist/testYourself/index.d.mts +53 -0
  229. package/dist/testYourself/index.d.ts +53 -0
  230. package/dist/testYourself/index.js +2551 -0
  231. package/dist/testYourself/index.js.map +1 -0
  232. package/dist/testYourself/index.mjs +2531 -0
  233. package/dist/testYourself/index.mjs.map +1 -0
  234. package/dist/testYourself/server/index.d.mts +1029 -0
  235. package/dist/testYourself/server/index.d.ts +1029 -0
  236. package/dist/testYourself/server/index.js +825 -0
  237. package/dist/testYourself/server/index.js.map +1 -0
  238. package/dist/testYourself/server/index.mjs +816 -0
  239. package/dist/testYourself/server/index.mjs.map +1 -0
  240. package/dist/types-BTiaMsBz.d.mts +292 -0
  241. package/dist/types-DyG3ZV9V.d.mts +270 -0
  242. package/dist/types-DyG3ZV9V.d.ts +270 -0
  243. package/dist/types-ERmJyjx8.d.ts +292 -0
  244. package/dist/types-HorDyIRv.d.mts +303 -0
  245. package/dist/types-HorDyIRv.d.ts +303 -0
  246. package/dist/vocaloidBooth/index.d.mts +64 -0
  247. package/dist/vocaloidBooth/index.d.ts +64 -0
  248. package/dist/vocaloidBooth/index.js +376 -0
  249. package/dist/vocaloidBooth/index.js.map +1 -0
  250. package/dist/vocaloidBooth/index.mjs +362 -0
  251. package/dist/vocaloidBooth/index.mjs.map +1 -0
  252. package/dist/vocaloidBooth/server/index.d.mts +111 -0
  253. package/dist/vocaloidBooth/server/index.d.ts +111 -0
  254. package/dist/vocaloidBooth/server/index.js +247 -0
  255. package/dist/vocaloidBooth/server/index.js.map +1 -0
  256. package/dist/vocaloidBooth/server/index.mjs +237 -0
  257. package/dist/vocaloidBooth/server/index.mjs.map +1 -0
  258. package/dist/vocaloidBooth/web/index.d.mts +3 -0
  259. package/dist/vocaloidBooth/web/index.d.ts +3 -0
  260. package/dist/vocaloidBooth/web/index.js +376 -0
  261. package/dist/vocaloidBooth/web/index.js.map +1 -0
  262. package/dist/vocaloidBooth/web/index.mjs +362 -0
  263. package/dist/vocaloidBooth/web/index.mjs.map +1 -0
  264. package/package.json +1 -1
@@ -0,0 +1,290 @@
1
+ import React4, { createContext, useState, useContext } from 'react';
2
+ import { View, Text, Button, Input } from '@tarojs/components';
3
+
4
+ // src/business/auth-legacy/ui/miniapp/components/LoginModal.tsx
5
+ var AuthContext = createContext(void 0);
6
+ function useAuth() {
7
+ const context = useContext(AuthContext);
8
+ if (context === void 0) {
9
+ throw new Error("useAuth must be used within an AuthProvider");
10
+ }
11
+ return context;
12
+ }
13
+
14
+ // src/business/auth-legacy/utils/authUtils.ts
15
+ function validatePhoneNumber(phone) {
16
+ return /^1[3-9]\d{9}$/.test(phone);
17
+ }
18
+ function validatePassword(password) {
19
+ if (!password) {
20
+ return { valid: false, message: "\u5BC6\u7801\u4E0D\u80FD\u4E3A\u7A7A" };
21
+ }
22
+ if (password.length < 6) {
23
+ return { valid: false, message: "\u5BC6\u7801\u957F\u5EA6\u81F3\u5C116\u4F4D" };
24
+ }
25
+ return { valid: true };
26
+ }
27
+
28
+ // src/business/auth-legacy/ui/miniapp/components/LoginModal.tsx
29
+ function LoginModal({ isOpen, onClose, onSuccess, onSwitchToRegister }) {
30
+ const { login } = useAuth();
31
+ const [formData, setFormData] = useState({ phone: "", password: "" });
32
+ const [error, setError] = useState("");
33
+ const [loading, setLoading] = useState(false);
34
+ if (!isOpen) return null;
35
+ const handleSubmit = async () => {
36
+ setError("");
37
+ setLoading(true);
38
+ if (!formData.phone || !formData.password) {
39
+ setError("\u8BF7\u586B\u5199\u5B8C\u6574\u4FE1\u606F");
40
+ setLoading(false);
41
+ return;
42
+ }
43
+ if (!validatePhoneNumber(formData.phone)) {
44
+ setError("\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u624B\u673A\u53F7");
45
+ setLoading(false);
46
+ return;
47
+ }
48
+ const result = await login(formData);
49
+ if (result.success) {
50
+ onSuccess();
51
+ } else {
52
+ setError(result.message || "\u767B\u5F55\u5931\u8D25");
53
+ }
54
+ setLoading(false);
55
+ };
56
+ return /* @__PURE__ */ React4.createElement(View, { className: "auth-modal" }, /* @__PURE__ */ React4.createElement(View, { className: "auth-card" }, /* @__PURE__ */ React4.createElement(View, { className: "auth-header" }, /* @__PURE__ */ React4.createElement(Text, { className: "auth-title" }, "\u7528\u6237\u767B\u5F55"), /* @__PURE__ */ React4.createElement(Button, { className: "auth-close", onClick: onClose }, "\u5173\u95ED")), /* @__PURE__ */ React4.createElement(View, { className: "auth-form" }, /* @__PURE__ */ React4.createElement(
57
+ Input,
58
+ {
59
+ name: "phone",
60
+ value: formData.phone,
61
+ onInput: (e) => setFormData((prev) => ({ ...prev, phone: e.detail.value })),
62
+ placeholder: "\u8BF7\u8F93\u5165\u624B\u673A\u53F7",
63
+ type: "text"
64
+ }
65
+ ), /* @__PURE__ */ React4.createElement(
66
+ Input,
67
+ {
68
+ name: "password",
69
+ value: formData.password,
70
+ onInput: (e) => setFormData((prev) => ({ ...prev, password: e.detail.value })),
71
+ placeholder: "\u8BF7\u8F93\u5165\u5BC6\u7801",
72
+ type: "password"
73
+ }
74
+ ), error && /* @__PURE__ */ React4.createElement(Text, { className: "auth-error" }, error), /* @__PURE__ */ React4.createElement(Button, { className: "auth-submit", loading, onClick: handleSubmit }, loading ? "\u767B\u5F55\u4E2D..." : "\u767B\u5F55"), onSwitchToRegister && /* @__PURE__ */ React4.createElement(Button, { className: "auth-switch", onClick: onSwitchToRegister }, "\u53BB\u6CE8\u518C"))));
75
+ }
76
+ function RegisterModal({ isOpen, onClose, onSuccess, onSwitchToLogin }) {
77
+ const { register } = useAuth();
78
+ const [formData, setFormData] = useState({
79
+ phone: "",
80
+ name: "",
81
+ password: "",
82
+ confirmPassword: ""
83
+ });
84
+ const [error, setError] = useState("");
85
+ const [loading, setLoading] = useState(false);
86
+ if (!isOpen) return null;
87
+ const handleSubmit = async () => {
88
+ setError("");
89
+ setLoading(true);
90
+ if (!formData.phone || !formData.password || !formData.confirmPassword) {
91
+ setError("\u8BF7\u586B\u5199\u5B8C\u6574\u4FE1\u606F");
92
+ setLoading(false);
93
+ return;
94
+ }
95
+ if (!validatePhoneNumber(formData.phone)) {
96
+ setError("\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u624B\u673A\u53F7");
97
+ setLoading(false);
98
+ return;
99
+ }
100
+ const passwordValidation = validatePassword(formData.password);
101
+ if (!passwordValidation.valid) {
102
+ setError(passwordValidation.message || "\u5BC6\u7801\u683C\u5F0F\u9519\u8BEF");
103
+ setLoading(false);
104
+ return;
105
+ }
106
+ if (formData.password !== formData.confirmPassword) {
107
+ setError("\u4E24\u6B21\u8F93\u5165\u7684\u5BC6\u7801\u4E0D\u4E00\u81F4");
108
+ setLoading(false);
109
+ return;
110
+ }
111
+ const result = await register({
112
+ phone: formData.phone,
113
+ password: formData.password,
114
+ name: formData.name || void 0
115
+ });
116
+ if (result.success) {
117
+ onSuccess();
118
+ } else {
119
+ setError(result.message || "\u6CE8\u518C\u5931\u8D25");
120
+ }
121
+ setLoading(false);
122
+ };
123
+ return /* @__PURE__ */ React4.createElement(View, { className: "auth-modal" }, /* @__PURE__ */ React4.createElement(View, { className: "auth-card" }, /* @__PURE__ */ React4.createElement(View, { className: "auth-header" }, /* @__PURE__ */ React4.createElement(Text, { className: "auth-title" }, "\u7528\u6237\u6CE8\u518C"), /* @__PURE__ */ React4.createElement(Button, { className: "auth-close", onClick: onClose }, "\u5173\u95ED")), /* @__PURE__ */ React4.createElement(View, { className: "auth-form" }, /* @__PURE__ */ React4.createElement(
124
+ Input,
125
+ {
126
+ name: "phone",
127
+ value: formData.phone,
128
+ onInput: (e) => setFormData((prev) => ({ ...prev, phone: e.detail.value })),
129
+ placeholder: "\u8BF7\u8F93\u5165\u624B\u673A\u53F7",
130
+ type: "text"
131
+ }
132
+ ), /* @__PURE__ */ React4.createElement(
133
+ Input,
134
+ {
135
+ name: "name",
136
+ value: formData.name,
137
+ onInput: (e) => setFormData((prev) => ({ ...prev, name: e.detail.value })),
138
+ placeholder: "\u8BF7\u8F93\u5165\u6635\u79F0",
139
+ type: "text"
140
+ }
141
+ ), /* @__PURE__ */ React4.createElement(
142
+ Input,
143
+ {
144
+ name: "password",
145
+ value: formData.password,
146
+ onInput: (e) => setFormData((prev) => ({ ...prev, password: e.detail.value })),
147
+ placeholder: "\u8BF7\u8F93\u5165\u5BC6\u7801",
148
+ type: "password"
149
+ }
150
+ ), /* @__PURE__ */ React4.createElement(
151
+ Input,
152
+ {
153
+ name: "confirmPassword",
154
+ value: formData.confirmPassword,
155
+ onInput: (e) => setFormData((prev) => ({ ...prev, confirmPassword: e.detail.value })),
156
+ placeholder: "\u8BF7\u786E\u8BA4\u5BC6\u7801",
157
+ type: "password"
158
+ }
159
+ ), error && /* @__PURE__ */ React4.createElement(Text, { className: "auth-error" }, error), /* @__PURE__ */ React4.createElement(Button, { className: "auth-submit", loading, onClick: handleSubmit }, loading ? "\u6CE8\u518C\u4E2D..." : "\u6CE8\u518C"), onSwitchToLogin && /* @__PURE__ */ React4.createElement(Button, { className: "auth-switch", onClick: onSwitchToLogin }, "\u53BB\u767B\u5F55"))));
160
+ }
161
+ function ForgotPasswordModal({ isOpen, onClose, onSuccess }) {
162
+ const [step, setStep] = useState("phone");
163
+ const [formData, setFormData] = useState({
164
+ phone: "",
165
+ verificationCode: "",
166
+ newPassword: "",
167
+ confirmPassword: ""
168
+ });
169
+ const [error, setError] = useState("");
170
+ const [loading, setLoading] = useState(false);
171
+ if (!isOpen) return null;
172
+ const handleSendCode = async () => {
173
+ setError("");
174
+ setLoading(true);
175
+ if (!validatePhoneNumber(formData.phone)) {
176
+ setError("\u8BF7\u8F93\u5165\u6B63\u786E\u7684\u624B\u673A\u53F7");
177
+ setLoading(false);
178
+ return;
179
+ }
180
+ try {
181
+ const response = await fetch("/api/auth/send-verification-code", {
182
+ method: "POST",
183
+ headers: { "Content-Type": "application/json" },
184
+ body: JSON.stringify({ phone: formData.phone })
185
+ });
186
+ const data = await response.json();
187
+ if (data.success) {
188
+ setStep("verify");
189
+ } else {
190
+ setError(data.message || "\u53D1\u9001\u5931\u8D25");
191
+ }
192
+ } catch (error2) {
193
+ console.error("\u{1F4A5} [ForgotPasswordModal] \u53D1\u9001\u9A8C\u8BC1\u7801\u5F02\u5E38:", error2);
194
+ setError("\u53D1\u9001\u5931\u8D25\uFF0C\u8BF7\u7A0D\u540E\u91CD\u8BD5");
195
+ } finally {
196
+ setLoading(false);
197
+ }
198
+ };
199
+ const handleVerifyCode = () => {
200
+ if (!formData.verificationCode) {
201
+ setError("\u8BF7\u8F93\u5165\u9A8C\u8BC1\u7801");
202
+ return;
203
+ }
204
+ setStep("reset");
205
+ };
206
+ const handleResetPassword = async () => {
207
+ const passwordValidation = validatePassword(formData.newPassword);
208
+ if (!passwordValidation.valid) {
209
+ setError(passwordValidation.message || "\u5BC6\u7801\u683C\u5F0F\u9519\u8BEF");
210
+ return;
211
+ }
212
+ if (formData.newPassword !== formData.confirmPassword) {
213
+ setError("\u4E24\u6B21\u8F93\u5165\u7684\u5BC6\u7801\u4E0D\u4E00\u81F4");
214
+ return;
215
+ }
216
+ setLoading(true);
217
+ try {
218
+ const response = await fetch("/api/auth/reset-password", {
219
+ method: "POST",
220
+ headers: { "Content-Type": "application/json" },
221
+ body: JSON.stringify({
222
+ phone: formData.phone,
223
+ verificationCode: formData.verificationCode,
224
+ newPassword: formData.newPassword
225
+ })
226
+ });
227
+ const data = await response.json();
228
+ if (data.success) {
229
+ onSuccess();
230
+ } else {
231
+ setError(data.message || "\u91CD\u7F6E\u5931\u8D25");
232
+ }
233
+ } catch (error2) {
234
+ console.error("\u{1F4A5} [ForgotPasswordModal] \u91CD\u7F6E\u5BC6\u7801\u5F02\u5E38:", error2);
235
+ setError("\u91CD\u7F6E\u5931\u8D25\uFF0C\u8BF7\u7A0D\u540E\u91CD\u8BD5");
236
+ } finally {
237
+ setLoading(false);
238
+ }
239
+ };
240
+ const renderContent = () => {
241
+ if (step === "phone") {
242
+ return /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(
243
+ Input,
244
+ {
245
+ name: "phone",
246
+ value: formData.phone,
247
+ onInput: (e) => setFormData((prev) => ({ ...prev, phone: e.detail.value })),
248
+ placeholder: "\u8BF7\u8F93\u5165\u624B\u673A\u53F7",
249
+ type: "text"
250
+ }
251
+ ), /* @__PURE__ */ React4.createElement(Button, { className: "auth-submit", loading, onClick: handleSendCode }, loading ? "\u53D1\u9001\u4E2D..." : "\u53D1\u9001\u9A8C\u8BC1\u7801"));
252
+ }
253
+ if (step === "verify") {
254
+ return /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(
255
+ Input,
256
+ {
257
+ name: "verificationCode",
258
+ value: formData.verificationCode,
259
+ onInput: (e) => setFormData((prev) => ({ ...prev, verificationCode: e.detail.value })),
260
+ placeholder: "\u8BF7\u8F93\u5165\u9A8C\u8BC1\u7801",
261
+ type: "text"
262
+ }
263
+ ), /* @__PURE__ */ React4.createElement(Button, { className: "auth-submit", onClick: handleVerifyCode }, "\u4E0B\u4E00\u6B65"));
264
+ }
265
+ return /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(
266
+ Input,
267
+ {
268
+ name: "newPassword",
269
+ value: formData.newPassword,
270
+ onInput: (e) => setFormData((prev) => ({ ...prev, newPassword: e.detail.value })),
271
+ placeholder: "\u8BF7\u8F93\u5165\u65B0\u5BC6\u7801",
272
+ type: "password"
273
+ }
274
+ ), /* @__PURE__ */ React4.createElement(
275
+ Input,
276
+ {
277
+ name: "confirmPassword",
278
+ value: formData.confirmPassword,
279
+ onInput: (e) => setFormData((prev) => ({ ...prev, confirmPassword: e.detail.value })),
280
+ placeholder: "\u8BF7\u786E\u8BA4\u65B0\u5BC6\u7801",
281
+ type: "password"
282
+ }
283
+ ), /* @__PURE__ */ React4.createElement(Button, { className: "auth-submit", loading, onClick: handleResetPassword }, loading ? "\u63D0\u4EA4\u4E2D..." : "\u91CD\u7F6E\u5BC6\u7801"));
284
+ };
285
+ return /* @__PURE__ */ React4.createElement(View, { className: "auth-modal" }, /* @__PURE__ */ React4.createElement(View, { className: "auth-card" }, /* @__PURE__ */ React4.createElement(View, { className: "auth-header" }, /* @__PURE__ */ React4.createElement(Text, { className: "auth-title" }, "\u627E\u56DE\u5BC6\u7801"), /* @__PURE__ */ React4.createElement(Button, { className: "auth-close", onClick: onClose }, "\u5173\u95ED")), /* @__PURE__ */ React4.createElement(View, { className: "auth-form" }, renderContent(), error && /* @__PURE__ */ React4.createElement(Text, { className: "auth-error" }, error))));
286
+ }
287
+
288
+ export { ForgotPasswordModal, LoginModal, RegisterModal };
289
+ //# sourceMappingURL=index.mjs.map
290
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../src/business/auth-legacy/contexts/AuthContext.tsx","../../../../../src/business/auth-legacy/utils/authUtils.ts","../../../../../src/business/auth-legacy/ui/miniapp/components/LoginModal.tsx","../../../../../src/business/auth-legacy/ui/miniapp/components/RegisterModal.tsx","../../../../../src/business/auth-legacy/ui/miniapp/components/ForgotPasswordModal.tsx"],"names":["useState","React","View","Text","Button","Input","error"],"mappings":"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","file":"index.mjs","sourcesContent":["'use client';\n\nimport React, { createContext, useContext, useState, useEffect, useCallback, useRef } from 'react';\nimport type { User, UseAuthReturn, LoginRequest, RegisterRequest } from '../types';\n\ninterface AuthContextType extends UseAuthReturn {}\n\nconst AuthContext = createContext<AuthContextType | undefined>(undefined);\n\nfunction extractUser(data: any): User | null {\n return data?.user ?? data?.data?.user ?? null;\n}\n\nfunction extractValid(data: any): boolean {\n if (typeof data?.valid === 'boolean') return data.valid;\n if (typeof data?.data?.valid === 'boolean') return data.data.valid;\n return false;\n}\n\nexport function AuthProvider({ children }: { children: React.ReactNode }) {\n const [user, setUser] = useState<User | null>(null);\n const [loading, setLoading] = useState(true);\n const [isAuthenticated, setIsAuthenticated] = useState(false);\n const isMountedRef = useRef(true);\n\n // 安全的状态更新函数\n const safeSetState = useCallback((updater: () => void) => {\n if (isMountedRef.current) {\n updater();\n }\n }, []);\n\n // 验证会话\n const validateSession = useCallback(async () => {\n console.log('🔍 [AuthContext] 开始验证会话...');\n try {\n const response = await fetch('/api/auth/validate');\n console.log('📡 [AuthContext] 会话验证响应状态:', response.status);\n \n const data = await response.json();\n console.log('📄 [AuthContext] 会话验证响应数据:', data);\n const resolvedUser = extractUser(data);\n const resolvedValid = extractValid(data);\n \n safeSetState(() => {\n if (resolvedValid && resolvedUser) {\n console.log('✅ [AuthContext] 会话验证成功, 用户:', resolvedUser);\n setUser(resolvedUser);\n setIsAuthenticated(true);\n } else {\n console.log('❌ [AuthContext] 会话验证失败:', data.message);\n setUser(null);\n setIsAuthenticated(false);\n }\n setLoading(false);\n });\n } catch (error) {\n console.error('💥 [AuthContext] 会话验证异常:', error);\n safeSetState(() => {\n setUser(null);\n setIsAuthenticated(false);\n setLoading(false);\n });\n }\n }, [safeSetState]);\n\n // 登录\n const login = useCallback(async (credentials: LoginRequest) => {\n console.log('🔑 [AuthContext] 开始登录...');\n console.log('📝 [AuthContext] 登录凭据:', { phone: credentials.phone, password: '***' });\n \n try {\n console.log('📤 [AuthContext] 发送登录请求到 /api/auth/login');\n const response = await fetch('/api/auth/login', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(credentials),\n });\n\n console.log('📡 [AuthContext] 收到响应,状态码:', response.status);\n const data = await response.json();\n console.log('📄 [AuthContext] 响应数据:', data);\n const resolvedUser = extractUser(data);\n\n if (data.success && resolvedUser) {\n console.log('✅ [AuthContext] 登录成功, 开始更新全局状态');\n console.log('👤 [AuthContext] 用户数据:', resolvedUser);\n \n // 记录当前状态\n console.log('📊 [AuthContext] 更新前状态:', {\n currentUser: user ? `${user.name || '未设置'} (${user.phone})` : null,\n currentIsAuthenticated: isAuthenticated,\n currentLoading: loading\n });\n \n // 使用同步的状态更新确保立即生效\n console.log('🔄 [AuthContext] 执行全局状态更新...');\n safeSetState(() => {\n console.log('🔄 [AuthContext] 正在设置用户:', resolvedUser);\n setUser(resolvedUser);\n console.log('🔄 [AuthContext] 正在设置认证状态: true');\n setIsAuthenticated(true);\n console.log('🔄 [AuthContext] 正在设置加载状态: false');\n setLoading(false);\n console.log('✅ [AuthContext] 全局状态更新完成');\n });\n \n // 等待下一个事件循环后输出确认日志\n setTimeout(() => {\n console.log('🎉 [AuthContext] 延迟确认 - 全局登录状态应该已更新:', {\n user: resolvedUser,\n isAuthenticated: true\n });\n }, 0);\n \n console.log('🚀 [AuthContext] 返回成功结果');\n return { success: true, user: resolvedUser };\n } else {\n console.log('❌ [AuthContext] 登录失败:', data.message);\n return { success: false, message: data.message };\n }\n } catch (error) {\n console.error('💥 [AuthContext] 登录异常:', error);\n return { success: false, message: '登录失败,请稍后重试' };\n }\n }, [safeSetState, user, isAuthenticated, loading]);\n\n // 注册\n const register = useCallback(async (userData: RegisterRequest) => {\n console.log('📝 [AuthContext] 开始注册...');\n try {\n const response = await fetch('/api/auth/register', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(userData),\n });\n\n const data = await response.json();\n console.log('📡 [AuthContext] 注册响应:', data);\n const resolvedUser = extractUser(data);\n\n if (data.success && resolvedUser) {\n console.log('✅ [AuthContext] 注册成功, 立即更新全局状态');\n \n // 使用同步的状态更新确保立即生效\n safeSetState(() => {\n setUser(resolvedUser);\n setIsAuthenticated(true);\n setLoading(false);\n });\n \n console.log('🚀 [AuthContext] 返回注册成功结果');\n return { success: true, user: resolvedUser };\n } else {\n console.log('❌ [AuthContext] 注册失败:', data.message);\n return { success: false, message: data.message };\n }\n } catch (error) {\n console.error('💥 [AuthContext] 注册异常:', error);\n return { success: false, message: '注册失败,请稍后重试' };\n }\n }, [safeSetState]);\n\n // 登出\n const logout = useCallback(async () => {\n console.log('🚪 [AuthContext] 开始登出...');\n try {\n await fetch('/api/auth/logout', { method: 'POST' });\n safeSetState(() => {\n setUser(null);\n setIsAuthenticated(false);\n });\n console.log('✅ [AuthContext] 登出成功, 全局状态已清除');\n } catch (error) {\n console.error('💥 [AuthContext] 登出失败:', error);\n }\n }, [safeSetState]);\n\n // 刷新用户信息\n const refreshUser = useCallback(() => {\n console.log('🔄 [AuthContext] 刷新用户信息...');\n setLoading(true);\n validateSession();\n }, [validateSession]);\n\n // 组件挂载/卸载管理\n useEffect(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n };\n }, []);\n\n // 初始化时验证会话\n useEffect(() => {\n console.log('🚀 [AuthContext] 初始化, 开始验证会话');\n validateSession();\n }, [validateSession]);\n\n // 状态变化监控(用于调试)\n useEffect(() => {\n console.log('📊 [AuthContext] 全局状态变化:', {\n isAuthenticated,\n user: user ? `${user.name || '未设置'} (${user.phone})` : null,\n loading\n });\n }, [isAuthenticated, user, loading]);\n\n const value: AuthContextType = {\n user,\n loading,\n isAuthenticated,\n login,\n register,\n logout,\n refreshUser,\n };\n\n return (\n <AuthContext.Provider value={value}>\n {children}\n </AuthContext.Provider>\n );\n}\n\nexport function useAuth(): UseAuthReturn {\n const context = useContext(AuthContext);\n if (context === undefined) {\n throw new Error('useAuth must be used within an AuthProvider');\n }\n return context;\n} \n","import type { User } from '../types';\n\n/**\n * 验证手机号格式\n */\nexport function validatePhoneNumber(phone: string): boolean {\n return /^1[3-9]\\d{9}$/.test(phone);\n}\n\n/**\n * 验证密码强度(可扩展)\n */\nexport function validatePassword(password: string): { valid: boolean; message?: string } {\n if (!password) {\n return { valid: false, message: '密码不能为空' };\n }\n \n if (password.length < 6) {\n return { valid: false, message: '密码长度至少6位' };\n }\n \n return { valid: true };\n}\n\n/**\n * 生成安全的会话令牌\n */\nexport function generateSessionToken(): string {\n // 在实际环境中,应该使用更安全的随机数生成\n return Math.random().toString(36).substring(2) + \n Date.now().toString(36) + \n Math.random().toString(36).substring(2);\n}\n\n/**\n * 检查用户是否为管理员\n */\nexport function isAdmin(user: User | null): boolean {\n return user?.role === 'admin';\n}\n\n/**\n * 检查用户是否处于活跃状态\n */\nexport function isActiveUser(user: User | null): boolean {\n return user?.isActive === true;\n}\n\n/**\n * 格式化用户显示名称\n */\nexport function getUserDisplayName(user: User): string {\n return user.name || user.phone || '未知用户';\n}\n\n/**\n * 计算会话过期时间\n */\nexport function calculateSessionExpiry(days: number = 30): Date {\n return new Date(Date.now() + days * 24 * 60 * 60 * 1000);\n}\n\n/**\n * 检查会话是否过期\n */\nexport function isSessionExpired(expiresAt: Date): boolean {\n return new Date() > new Date(expiresAt);\n} ","'use client';\n\nimport React, { useState } from 'react';\nimport { View, Text, Input, Button } from '@tarojs/components';\nimport { useAuth } from '../../../contexts/AuthContext';\nimport { validatePhoneNumber } from '../../../utils/authUtils';\nimport type { LoginModalProps } from '../../../types';\n\ntype MiniappInputEvent = {\n detail: {\n value: string;\n };\n};\n\nexport default function LoginModal({ isOpen, onClose, onSuccess, onSwitchToRegister }: LoginModalProps) {\n const { login } = useAuth();\n const [formData, setFormData] = useState({ phone: '', password: '' });\n const [error, setError] = useState('');\n const [loading, setLoading] = useState(false);\n\n if (!isOpen) return null;\n\n const handleSubmit = async () => {\n setError('');\n setLoading(true);\n\n if (!formData.phone || !formData.password) {\n setError('请填写完整信息');\n setLoading(false);\n return;\n }\n\n if (!validatePhoneNumber(formData.phone)) {\n setError('请输入正确的手机号');\n setLoading(false);\n return;\n }\n\n const result = await login(formData);\n if (result.success) {\n onSuccess();\n } else {\n setError(result.message || '登录失败');\n }\n setLoading(false);\n };\n\n return (\n <View className=\"auth-modal\">\n <View className=\"auth-card\">\n <View className=\"auth-header\">\n <Text className=\"auth-title\">用户登录</Text>\n <Button className=\"auth-close\" onClick={onClose}>\n 关闭\n </Button>\n </View>\n <View className=\"auth-form\">\n <Input\n name=\"phone\"\n value={formData.phone}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, phone: e.detail.value }))}\n placeholder=\"请输入手机号\"\n type=\"text\"\n />\n <Input\n name=\"password\"\n value={formData.password}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, password: e.detail.value }))}\n placeholder=\"请输入密码\"\n type=\"password\"\n />\n {error && <Text className=\"auth-error\">{error}</Text>}\n <Button className=\"auth-submit\" loading={loading} onClick={handleSubmit}>\n {loading ? '登录中...' : '登录'}\n </Button>\n {onSwitchToRegister && (\n <Button className=\"auth-switch\" onClick={onSwitchToRegister}>\n 去注册\n </Button>\n )}\n </View>\n </View>\n </View>\n );\n}\n","'use client';\n\nimport React, { useState } from 'react';\nimport { View, Text, Input, Button } from '@tarojs/components';\nimport { useAuth } from '../../../contexts/AuthContext';\nimport { validatePhoneNumber, validatePassword } from '../../../utils/authUtils';\nimport type { RegisterModalProps } from '../../../types';\n\ntype MiniappInputEvent = {\n detail: {\n value: string;\n };\n};\n\nexport default function RegisterModal({ isOpen, onClose, onSuccess, onSwitchToLogin }: RegisterModalProps) {\n const { register } = useAuth();\n const [formData, setFormData] = useState({\n phone: '',\n name: '',\n password: '',\n confirmPassword: '',\n });\n const [error, setError] = useState('');\n const [loading, setLoading] = useState(false);\n\n if (!isOpen) return null;\n\n const handleSubmit = async () => {\n setError('');\n setLoading(true);\n\n if (!formData.phone || !formData.password || !formData.confirmPassword) {\n setError('请填写完整信息');\n setLoading(false);\n return;\n }\n\n if (!validatePhoneNumber(formData.phone)) {\n setError('请输入正确的手机号');\n setLoading(false);\n return;\n }\n\n const passwordValidation = validatePassword(formData.password);\n if (!passwordValidation.valid) {\n setError(passwordValidation.message || '密码格式错误');\n setLoading(false);\n return;\n }\n\n if (formData.password !== formData.confirmPassword) {\n setError('两次输入的密码不一致');\n setLoading(false);\n return;\n }\n\n const result = await register({\n phone: formData.phone,\n password: formData.password,\n name: formData.name || undefined,\n });\n\n if (result.success) {\n onSuccess();\n } else {\n setError(result.message || '注册失败');\n }\n\n setLoading(false);\n };\n\n return (\n <View className=\"auth-modal\">\n <View className=\"auth-card\">\n <View className=\"auth-header\">\n <Text className=\"auth-title\">用户注册</Text>\n <Button className=\"auth-close\" onClick={onClose}>\n 关闭\n </Button>\n </View>\n <View className=\"auth-form\">\n <Input\n name=\"phone\"\n value={formData.phone}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, phone: e.detail.value }))}\n placeholder=\"请输入手机号\"\n type=\"text\"\n />\n <Input\n name=\"name\"\n value={formData.name}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, name: e.detail.value }))}\n placeholder=\"请输入昵称\"\n type=\"text\"\n />\n <Input\n name=\"password\"\n value={formData.password}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, password: e.detail.value }))}\n placeholder=\"请输入密码\"\n type=\"password\"\n />\n <Input\n name=\"confirmPassword\"\n value={formData.confirmPassword}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, confirmPassword: e.detail.value }))}\n placeholder=\"请确认密码\"\n type=\"password\"\n />\n {error && <Text className=\"auth-error\">{error}</Text>}\n <Button className=\"auth-submit\" loading={loading} onClick={handleSubmit}>\n {loading ? '注册中...' : '注册'}\n </Button>\n {onSwitchToLogin && (\n <Button className=\"auth-switch\" onClick={onSwitchToLogin}>\n 去登录\n </Button>\n )}\n </View>\n </View>\n </View>\n );\n}\n","'use client';\n\nimport React, { useState } from 'react';\nimport { View, Text, Input, Button } from '@tarojs/components';\nimport { validatePhoneNumber, validatePassword } from '../../../utils/authUtils';\nimport type { ForgotPasswordModalProps } from '../../../types';\n\ntype MiniappInputEvent = {\n detail: {\n value: string;\n };\n};\n\nexport default function ForgotPasswordModal({ isOpen, onClose, onSuccess }: ForgotPasswordModalProps) {\n const [step, setStep] = useState<'phone' | 'verify' | 'reset'>('phone');\n const [formData, setFormData] = useState({\n phone: '',\n verificationCode: '',\n newPassword: '',\n confirmPassword: '',\n });\n const [error, setError] = useState('');\n const [loading, setLoading] = useState(false);\n\n if (!isOpen) return null;\n\n const handleSendCode = async () => {\n setError('');\n setLoading(true);\n\n if (!validatePhoneNumber(formData.phone)) {\n setError('请输入正确的手机号');\n setLoading(false);\n return;\n }\n\n try {\n const response = await fetch('/api/auth/send-verification-code', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ phone: formData.phone }),\n });\n const data = await response.json();\n if (data.success) {\n setStep('verify');\n } else {\n setError(data.message || '发送失败');\n }\n } catch (error) {\n console.error('💥 [ForgotPasswordModal] 发送验证码异常:', error);\n setError('发送失败,请稍后重试');\n } finally {\n setLoading(false);\n }\n };\n\n const handleVerifyCode = () => {\n if (!formData.verificationCode) {\n setError('请输入验证码');\n return;\n }\n setStep('reset');\n };\n\n const handleResetPassword = async () => {\n const passwordValidation = validatePassword(formData.newPassword);\n if (!passwordValidation.valid) {\n setError(passwordValidation.message || '密码格式错误');\n return;\n }\n if (formData.newPassword !== formData.confirmPassword) {\n setError('两次输入的密码不一致');\n return;\n }\n\n setLoading(true);\n try {\n const response = await fetch('/api/auth/reset-password', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n phone: formData.phone,\n verificationCode: formData.verificationCode,\n newPassword: formData.newPassword,\n }),\n });\n const data = await response.json();\n if (data.success) {\n onSuccess();\n } else {\n setError(data.message || '重置失败');\n }\n } catch (error) {\n console.error('💥 [ForgotPasswordModal] 重置密码异常:', error);\n setError('重置失败,请稍后重试');\n } finally {\n setLoading(false);\n }\n };\n\n const renderContent = () => {\n if (step === 'phone') {\n return (\n <>\n <Input\n name=\"phone\"\n value={formData.phone}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, phone: e.detail.value }))}\n placeholder=\"请输入手机号\"\n type=\"text\"\n />\n <Button className=\"auth-submit\" loading={loading} onClick={handleSendCode}>\n {loading ? '发送中...' : '发送验证码'}\n </Button>\n </>\n );\n }\n\n if (step === 'verify') {\n return (\n <>\n <Input\n name=\"verificationCode\"\n value={formData.verificationCode}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, verificationCode: e.detail.value }))}\n placeholder=\"请输入验证码\"\n type=\"text\"\n />\n <Button className=\"auth-submit\" onClick={handleVerifyCode}>\n 下一步\n </Button>\n </>\n );\n }\n\n return (\n <>\n <Input\n name=\"newPassword\"\n value={formData.newPassword}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, newPassword: e.detail.value }))}\n placeholder=\"请输入新密码\"\n type=\"password\"\n />\n <Input\n name=\"confirmPassword\"\n value={formData.confirmPassword}\n onInput={(e: MiniappInputEvent) => setFormData(prev => ({ ...prev, confirmPassword: e.detail.value }))}\n placeholder=\"请确认新密码\"\n type=\"password\"\n />\n <Button className=\"auth-submit\" loading={loading} onClick={handleResetPassword}>\n {loading ? '提交中...' : '重置密码'}\n </Button>\n </>\n );\n };\n\n return (\n <View className=\"auth-modal\">\n <View className=\"auth-card\">\n <View className=\"auth-header\">\n <Text className=\"auth-title\">找回密码</Text>\n <Button className=\"auth-close\" onClick={onClose}>\n 关闭\n </Button>\n </View>\n <View className=\"auth-form\">\n {renderContent()}\n {error && <Text className=\"auth-error\">{error}</Text>}\n </View>\n </View>\n </View>\n );\n}\n"]}
@@ -0,0 +1,22 @@
1
+ import React__default from 'react';
2
+ import { A as AuthGuardProps, g as UserMenuProps, e as LoginModalProps, f as RegisterModalProps, F as ForgotPasswordModalProps } from '../../../../index-DNKZ7-R_.mjs';
3
+
4
+ /**
5
+ * 认证守卫组件
6
+ * 保护需要登录的页面和组件
7
+ */
8
+ declare function AuthGuard({ children, fallback, requireAuth }: AuthGuardProps): React__default.JSX.Element;
9
+
10
+ declare function UserMenu({ customMenuItems, className }: UserMenuProps): React__default.JSX.Element;
11
+
12
+ /**
13
+ * 登录模态框组件
14
+ * 提供用户登录界面和逻辑
15
+ */
16
+ declare function LoginModal({ isOpen, onClose, onSuccess, onSwitchToRegister }: LoginModalProps): React__default.ReactPortal | null;
17
+
18
+ declare function RegisterModal({ isOpen, onClose, onSuccess, onSwitchToLogin }: RegisterModalProps): React__default.ReactPortal | null;
19
+
20
+ declare function ForgotPasswordModal({ isOpen, onClose, onSuccess }: ForgotPasswordModalProps): React__default.ReactPortal | null;
21
+
22
+ export { AuthGuard, ForgotPasswordModal, LoginModal, RegisterModal, UserMenu };
@@ -0,0 +1,22 @@
1
+ import React__default from 'react';
2
+ import { A as AuthGuardProps, g as UserMenuProps, e as LoginModalProps, f as RegisterModalProps, F as ForgotPasswordModalProps } from '../../../../index-DNKZ7-R_.js';
3
+
4
+ /**
5
+ * 认证守卫组件
6
+ * 保护需要登录的页面和组件
7
+ */
8
+ declare function AuthGuard({ children, fallback, requireAuth }: AuthGuardProps): React__default.JSX.Element;
9
+
10
+ declare function UserMenu({ customMenuItems, className }: UserMenuProps): React__default.JSX.Element;
11
+
12
+ /**
13
+ * 登录模态框组件
14
+ * 提供用户登录界面和逻辑
15
+ */
16
+ declare function LoginModal({ isOpen, onClose, onSuccess, onSwitchToRegister }: LoginModalProps): React__default.ReactPortal | null;
17
+
18
+ declare function RegisterModal({ isOpen, onClose, onSuccess, onSwitchToLogin }: RegisterModalProps): React__default.ReactPortal | null;
19
+
20
+ declare function ForgotPasswordModal({ isOpen, onClose, onSuccess }: ForgotPasswordModalProps): React__default.ReactPortal | null;
21
+
22
+ export { AuthGuard, ForgotPasswordModal, LoginModal, RegisterModal, UserMenu };