aha-components 1.7.12 → 1.8.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 (126) hide show
  1. package/README.md +10 -0
  2. package/dist/Avatar.esm.js +2 -0
  3. package/dist/Avatar.esm.js.map +1 -0
  4. package/dist/Avatar.js +2 -0
  5. package/dist/Avatar.js.map +1 -0
  6. package/dist/Badge.esm.js +2 -0
  7. package/dist/Badge.esm.js.map +1 -0
  8. package/dist/Badge.js +2 -0
  9. package/dist/Badge.js.map +1 -0
  10. package/dist/Checkbox.esm.js +1 -1
  11. package/dist/Checkbox.esm.js.map +1 -1
  12. package/dist/Checkbox.js +1 -1
  13. package/dist/Checkbox.js.map +1 -1
  14. package/dist/Input.esm.js +1 -1
  15. package/dist/Input.esm.js.map +1 -1
  16. package/dist/Input.js +1 -1
  17. package/dist/Input.js.map +1 -1
  18. package/dist/Pagination.esm.js +1 -1
  19. package/dist/Pagination.esm.js.map +1 -1
  20. package/dist/Pagination.js +1 -1
  21. package/dist/Pagination.js.map +1 -1
  22. package/dist/Radio.esm.js +1 -1
  23. package/dist/Radio.esm.js.map +1 -1
  24. package/dist/Radio.js +1 -1
  25. package/dist/Radio.js.map +1 -1
  26. package/dist/Table.esm.js +1 -1
  27. package/dist/Table.esm.js.map +1 -1
  28. package/dist/Table.js +1 -1
  29. package/dist/Table.js.map +1 -1
  30. package/dist/Tag.esm.js +1 -1
  31. package/dist/Tag.esm.js.map +1 -1
  32. package/dist/Tag.js +1 -1
  33. package/dist/Tag.js.map +1 -1
  34. package/dist/Textarea.esm.js +1 -1
  35. package/dist/Textarea.esm.js.map +1 -1
  36. package/dist/Textarea.js +1 -1
  37. package/dist/Textarea.js.map +1 -1
  38. package/dist/components/Avatar/Avatar.stories.d.ts +12 -0
  39. package/dist/components/Avatar/index.d.ts +42 -0
  40. package/dist/components/Badge/Badge.stories.d.ts +15 -0
  41. package/dist/components/Badge/index.d.ts +71 -0
  42. package/dist/components/Checkbox/Checkbox.stories 2.d.ts +12 -0
  43. package/dist/components/Checkbox/Checkbox.stories.d.ts +5 -4
  44. package/dist/components/Checkbox/index 2.d.ts +12 -0
  45. package/dist/components/Checkbox/index.d.ts +6 -0
  46. package/dist/components/DatePicker/DatePicker.stories 2.d.ts +25 -0
  47. package/dist/components/DatePicker/index 2.d.ts +96 -0
  48. package/dist/components/Drawer/Drawer.stories 2.d.ts +9 -0
  49. package/dist/components/Drawer/index 2.d.ts +58 -0
  50. package/dist/components/Form/Form.stories 2.d.ts +15 -0
  51. package/dist/components/Form/FormContext 2.d.ts +41 -0
  52. package/dist/components/Form/FormItem 2.d.ts +58 -0
  53. package/dist/components/Form/index 2.d.ts +85 -0
  54. package/dist/components/Input/Input.stories 2.d.ts +16 -0
  55. package/dist/components/Input/Input.stories.d.ts +7 -4
  56. package/dist/components/Input/InputGroup.d.ts +25 -0
  57. package/dist/components/Input/InputTags.d.ts +17 -0
  58. package/dist/components/Input/index 2.d.ts +41 -0
  59. package/dist/components/Input/index.d.ts +7 -18
  60. package/dist/components/Loading/Loading.stories 2.d.ts +11 -0
  61. package/dist/components/Loading/index 2.d.ts +10 -0
  62. package/dist/components/MenuList/MenuList.stories 2.d.ts +17 -0
  63. package/dist/components/MenuList/MenuList.test 2.d.ts +1 -0
  64. package/dist/components/MenuList/index 2.d.ts +85 -0
  65. package/dist/components/Pagination/Pagination.stories 2.d.ts +16 -0
  66. package/dist/components/Pagination/index 2.d.ts +27 -0
  67. package/dist/components/Popover/Popover.stories 2.d.ts +11 -0
  68. package/dist/components/Popover/index 2.d.ts +31 -0
  69. package/dist/components/Progress/Progress.stories 2.d.ts +18 -0
  70. package/dist/components/Progress/Progress.test 2.d.ts +1 -0
  71. package/dist/components/Progress/index 2.d.ts +33 -0
  72. package/dist/components/Radio/Radio.stories 2.d.ts +10 -0
  73. package/dist/components/Radio/Radio.stories.d.ts +6 -4
  74. package/dist/components/Radio/index 2.d.ts +13 -0
  75. package/dist/components/Radio/index.d.ts +6 -0
  76. package/dist/components/Select/Select.stories 2.d.ts +17 -0
  77. package/dist/components/Select/index 2.d.ts +74 -0
  78. package/dist/components/Switch/Switch.stories 2.d.ts +14 -0
  79. package/dist/components/Switch/index 2.d.ts +27 -0
  80. package/dist/components/Tab/Tab.stories 2.d.ts +19 -0
  81. package/dist/components/Tab/index 2.d.ts +26 -0
  82. package/dist/components/Table/Table.stories 2.d.ts +21 -0
  83. package/dist/components/Table/index 2.d.ts +167 -0
  84. package/dist/components/Tag/Tag.stories.d.ts +5 -8
  85. package/dist/components/Tag/index.d.ts +24 -2
  86. package/dist/components/Textarea/Textarea.stories 2.d.ts +15 -0
  87. package/dist/components/Textarea/Textarea.stories.d.ts +3 -6
  88. package/dist/components/Textarea/TextareaTags.d.ts +8 -0
  89. package/dist/components/Textarea/index 2.d.ts +38 -0
  90. package/dist/components/Textarea/index.d.ts +6 -17
  91. package/dist/components/Tooltip/Tooltip.stories 2.d.ts +20 -0
  92. package/dist/components/Tooltip/index 2.d.ts +35 -0
  93. package/dist/design-tokens/theme.css +26 -0
  94. package/dist/design-tokens/theme.tailwind4.css +26 -0
  95. package/dist/icons/index 2.d.ts +33 -0
  96. package/dist/index.css +4810 -1
  97. package/dist/index.d.ts +195 -39
  98. package/dist/index.esm.css +4810 -1
  99. package/dist/index.esm.js +1 -1
  100. package/dist/index.esm.js.map +1 -1
  101. package/dist/index.js +1 -1
  102. package/dist/index.js.map +1 -1
  103. package/dist/stories/DesignTokens.stories 2.d.ts +5 -0
  104. package/dist/theme/Theme.stories 2.d.ts +10 -0
  105. package/dist/theme/ThemeContext 2.d.ts +11 -0
  106. package/dist/theme/utils 2.d.ts +10 -0
  107. package/dist/theme.css +26 -0
  108. package/dist/tokens.d.ts +30 -0
  109. package/package.json +1 -1
  110. package/dist/AlertComponent.esm.js +0 -2
  111. package/dist/AlertComponent.esm.js.map +0 -1
  112. package/dist/AlertComponent.js +0 -2
  113. package/dist/AlertComponent.js.map +0 -1
  114. package/dist/Card.esm.js +0 -2
  115. package/dist/Card.esm.js.map +0 -1
  116. package/dist/Card.js +0 -2
  117. package/dist/Card.js.map +0 -1
  118. package/dist/TestComponent.esm.js +0 -2
  119. package/dist/TestComponent.esm.js.map +0 -1
  120. package/dist/TestComponent.js +0 -2
  121. package/dist/TestComponent.js.map +0 -1
  122. package/dist/Toast.css +0 -1
  123. package/dist/Toast.esm.css +0 -1
  124. package/dist/components/AlertComponent/index.d.ts +0 -9
  125. package/dist/components/Card/index.d.ts +0 -10
  126. package/dist/components/TestComponent/index.d.ts +0 -7
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/index.tsx","../src/components/Alert/icon.tsx","../src/components/Toast/icon.tsx","../src/components/Toast/index.tsx","../src/components/Tag/index.tsx","../src/components/Input/index.tsx","../src/components/Select/index.tsx","../src/icons/index.tsx","../src/components/Pagination/index.tsx","../src/components/Checkbox/index.tsx","../src/components/Table/index.tsx","../src/components/Radio/index.tsx","../src/components/Tab/index.tsx","../src/components/Textarea/index.tsx","../src/components/Switch/index.tsx","../src/components/DatePicker/index.tsx","../src/components/Form/FormContext.tsx","../src/components/Form/index.tsx","../src/components/Form/FormItem.tsx","../src/components/MenuList/index.tsx","../src/components/Tooltip/index.tsx","../src/components/Popover/index.tsx","../src/components/Drawer/index.tsx","../src/components/Loading/index.tsx","../src/components/Alert/index.tsx","../src/components/Progress/index.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import React, { createContext, useContext, useMemo } from 'react';\n\nexport interface ThemeConfig {\n primaryColor?: string;\n}\n\nconst defaultTheme: ThemeConfig = {\n primaryColor: '#FB6011',\n};\n\nconst ThemeContext = createContext<ThemeConfig>(defaultTheme);\n\nexport interface ThemeProviderProps {\n theme?: ThemeConfig;\n children: React.ReactNode;\n}\n\nexport const ThemeProvider: React.FC<ThemeProviderProps> = ({ theme, children }) => {\n const themeValue = useMemo(() => {\n return {\n ...defaultTheme,\n ...theme,\n };\n }, [theme]);\n\n return (\n <ThemeContext.Provider value={themeValue}>\n {children}\n </ThemeContext.Provider>\n );\n};\n\nexport const useTheme = (): ThemeConfig => {\n const context = useContext(ThemeContext);\n if (!context) {\n // 如果没有 Provider,返回默认主题\n return defaultTheme;\n }\n return context;\n};\n\n// 导出默认主题色,供组件内部使用\nexport const getDefaultPrimaryColor = () => defaultTheme.primaryColor!;\n\n","import React, { useState } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\n/**\n * 对齐 Figma: Untitled UI v7 — Buttons\n * 维度:Size × Hierarchy × State × Icon only\n * Size: sm(36) / md(40) / lg(44) / xl(48)\n * Hierarchy: primary / secondary / tertiary / link-color / link-gray\n * State: default / hover / focused / disabled / loading\n * Icon only: boolean\n */\n\nexport type ButtonHierarchy =\n | 'primary'\n | 'secondary'\n | 'tertiary'\n | 'link-color'\n | 'link-gray'\n | 'destructive-primary'\n | 'destructive-secondary'\n | 'destructive-tertiary'\n | 'destructive-link'\n // legacy alias\n | 'default';\n\nexport type ButtonSize =\n | 'sm'\n | 'md'\n | 'lg'\n | 'xl'\n // legacy aliases\n | 'small'\n | 'mediumSmall'\n | 'medium'\n | 'large';\n\nexport type ButtonType = ButtonHierarchy;\n\nexport interface ButtonProps {\n children?: React.ReactNode;\n /** 按钮层级(对应 Figma Hierarchy)。`default` 为 `secondary` 的旧名 */\n type?: ButtonHierarchy;\n /** 按钮尺寸(对应 Figma Size)。旧名会映射到新尺寸 */\n size?: ButtonSize;\n disabled?: boolean;\n loading?: boolean;\n /** 仅图标按钮。不传 `children`、仅传 `icon` 时自动开启 */\n iconOnly?: boolean;\n /** 受控的 Focused 视觉态,用于 Storybook 预览设计稿;真实键盘焦点由 :focus-visible 处理 */\n focused?: boolean;\n onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void;\n htmlType?: 'button' | 'submit' | 'reset';\n className?: string;\n style?: React.CSSProperties;\n icon?: React.ReactNode;\n iconPosition?: 'left' | 'right';\n [key: string]: any;\n}\n\ntype NormalizedSize = 'sm' | 'md' | 'lg' | 'xl';\ntype NormalizedHierarchy = 'primary' | 'secondary' | 'tertiary' | 'link-color' | 'link-gray' | 'destructive-primary' | 'destructive-secondary' | 'destructive-tertiary' | 'destructive-link';\n\nconst SIZE_ALIAS: Record<ButtonSize, NormalizedSize> = {\n sm: 'sm',\n md: 'md',\n lg: 'lg',\n xl: 'xl',\n small: 'sm',\n mediumSmall: 'sm',\n medium: 'md',\n large: 'xl',\n};\n\nconst HIERARCHY_ALIAS: Record<ButtonHierarchy, NormalizedHierarchy> = {\n primary: 'primary',\n secondary: 'secondary',\n tertiary: 'tertiary',\n 'link-color': 'link-color',\n 'link-gray': 'link-gray',\n 'destructive-primary': 'destructive-primary',\n 'destructive-secondary': 'destructive-secondary',\n 'destructive-tertiary': 'destructive-tertiary',\n 'destructive-link': 'destructive-link',\n default: 'secondary',\n};\n\n/** Figma 标注的尺寸参数:高度、内边距、字号/行高、图标尺寸、间距 */\nconst SIZE_TOKENS: Record<\n NormalizedSize,\n {\n height: number;\n paddingX: number;\n paddingXLg: number; // lg/xl 大号内边距(与图标拼接时稍大)\n fontSize: number;\n lineHeight: number;\n iconSize: number;\n gap: number;\n iconOnlyPad: number;\n }\n> = {\n sm: { height: 36, paddingX: 12, paddingXLg: 12, fontSize: 14, lineHeight: 20, iconSize: 20, gap: 4, iconOnlyPad: 8 },\n md: { height: 40, paddingX: 14, paddingXLg: 14, fontSize: 14, lineHeight: 20, iconSize: 20, gap: 4, iconOnlyPad: 10 },\n lg: { height: 44, paddingX: 16, paddingXLg: 16, fontSize: 16, lineHeight: 24, iconSize: 20, gap: 6, iconOnlyPad: 12 },\n xl: { height: 48, paddingX: 18, paddingXLg: 18, fontSize: 16, lineHeight: 24, iconSize: 20, gap: 6, iconOnlyPad: 14 },\n};\n\nconst LoadingSpinner: React.FC<{ size: number; color: string }> = ({ size, color }) => (\n <>\n <style>{`@keyframes aha-button-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}`}</style>\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n aria-hidden\n style={{ animation: 'aha-button-spin 1s linear infinite', flexShrink: 0 }}\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\" stroke={color} strokeWidth=\"2\" opacity=\"0.25\" />\n <path\n d=\"M22 12a10 10 0 0 1-10 10\"\n stroke={color}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n fill=\"none\"\n />\n </svg>\n </>\n);\n\nconst Button: React.FC<ButtonProps> = ({\n children,\n type = 'secondary',\n size = 'md',\n disabled = false,\n loading = false,\n iconOnly,\n focused = false,\n onClick,\n htmlType = 'button',\n className = '',\n style,\n icon,\n iconPosition = 'left',\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n const [isHovered, setIsHovered] = useState(false);\n const [isPressed, setIsPressed] = useState(false);\n\n const hierarchy = HIERARCHY_ALIAS[type] || 'secondary';\n const s = SIZE_TOKENS[SIZE_ALIAS[size] || 'md'];\n\n const isIconOnly = iconOnly ?? (!!icon && children == null);\n const isLink = hierarchy === 'link-color' || hierarchy === 'link-gray' || hierarchy === 'destructive-link';\n const isDisabled = disabled || loading;\n const showFocusRing = focused;\n\n const themeBrand = primaryColor; // 允许 ThemeProvider 覆盖主色\n\n /** 根据 hierarchy+state 计算视觉 token */\n const getVisuals = (): {\n bg: string;\n color: string;\n iconColor: string;\n border: string;\n boxShadow: string;\n textDecoration?: string;\n } => {\n // Disabled — 所有层级共享一套「灰态」,但 link/tertiary 无边框/阴影\n if (disabled) {\n if (hierarchy === 'primary' || hierarchy === 'secondary' || hierarchy === 'destructive-primary' || hierarchy === 'destructive-secondary') {\n return {\n bg: 'var(--color-bg-disabled, #f5f5f4)',\n color: 'var(--color-fg-disabled, #a9a29d)',\n iconColor: 'var(--color-fg-disabled, #a9a29d)',\n border: '1px solid var(--color-border-disabled_subtle, #e7e5e4)',\n boxShadow: 'none',\n };\n }\n return {\n bg: 'transparent',\n color: 'var(--color-fg-disabled, #a9a29d)',\n iconColor: 'var(--color-fg-disabled, #a9a29d)',\n border: 'none',\n boxShadow: 'none',\n };\n }\n\n const interactive = isHovered || isPressed;\n\n if (hierarchy === 'primary') {\n const bg = interactive\n ? 'var(--color-bg-brand-solid_hover, #ec470a)'\n : themeBrand || 'var(--color-bg-brand-solid, #fb6011)';\n return {\n bg,\n color: 'var(--color-text-white, #ffffff)',\n iconColor: 'var(--color-brand-300, #feb073)',\n border: 'none',\n boxShadow: 'var(--shadow-xs-skeuomorphic, 0 1px 2px 0 rgba(10,13,18,.05))',\n };\n }\n\n if (hierarchy === 'secondary') {\n return {\n bg: interactive\n ? 'var(--color-bg-primary_hover, #fafaf9)'\n : 'var(--color-bg-primary, #ffffff)',\n color: interactive\n ? 'var(--color-text-secondary_hover, #292524)'\n : 'var(--color-text-secondary, #44403c)',\n iconColor: interactive\n ? 'var(--color-fg-quaternary_hover, #79716b)'\n : 'var(--color-fg-quaternary, #a9a29d)',\n border: 'none',\n boxShadow: 'var(--shadow-xs-skeuomorphic)',\n };\n }\n\n if (hierarchy === 'tertiary') {\n return {\n bg: interactive ? 'var(--color-bg-primary_hover, #fafaf9)' : 'transparent',\n color: interactive\n ? 'var(--color-text-tertiary_hover, #44403c)'\n : 'var(--color-text-tertiary, #57534e)',\n iconColor: interactive\n ? 'var(--color-fg-quaternary_hover, #79716b)'\n : 'var(--color-fg-quaternary, #a9a29d)',\n border: 'none',\n boxShadow: 'none',\n };\n }\n\n if (hierarchy === 'link-color') {\n return {\n bg: 'transparent',\n color: interactive\n ? 'var(--color-text-brand-secondary_hover, #c4330a)'\n : 'var(--color-text-brand-secondary, #ec470a)',\n iconColor: 'var(--color-fg-brand-secondary_alt, #fb6011)',\n border: 'none',\n boxShadow: 'none',\n textDecoration: interactive ? 'underline' : 'none',\n };\n }\n\n if (hierarchy === 'link-gray') {\n return {\n bg: 'transparent',\n color: interactive\n ? 'var(--color-text-tertiary_hover, #44403c)'\n : 'var(--color-text-tertiary, #57534e)',\n iconColor: 'var(--color-fg-quaternary, #a9a29d)',\n border: 'none',\n boxShadow: 'none',\n textDecoration: interactive ? 'underline' : 'none',\n };\n }\n\n if (hierarchy === 'destructive-primary') {\n return {\n bg: interactive\n ? 'var(--color-error-600)'\n : 'var(--color-error-500)',\n color: 'var(--color-text-white)',\n iconColor: interactive\n ? 'var(--color-error-200)'\n : 'var(--color-error-300)',\n border: 'none',\n boxShadow: 'var(--shadow-xs-skeuomorphic)',\n };\n }\n\n if (hierarchy === 'destructive-secondary') {\n return {\n bg: interactive\n ? 'var(--color-bg-error-primary)'\n : 'var(--color-bg-primary)',\n color: 'var(--color-text-error-primary)',\n iconColor: 'var(--color-fg-error-secondary)',\n border: 'none',\n // 用 error border 色替换 skeuomorphic 中的暗色 inset,保持与 secondary 一致的 shadow 结构\n boxShadow: 'inset 0 0 0 1px var(--color-border-error_subtle), inset 0 -2px 0 0 rgba(10,13,18,0.05), 0 1px 2px 0 rgba(10,13,18,0.05)',\n };\n }\n\n if (hierarchy === 'destructive-tertiary') {\n return {\n bg: interactive ? 'var(--color-bg-error-primary)' : 'transparent',\n color: 'var(--color-text-error-primary)',\n iconColor: 'var(--color-fg-error-secondary)',\n border: 'none',\n boxShadow: 'none',\n };\n }\n\n // destructive-link\n return {\n bg: 'transparent',\n color: interactive\n ? 'var(--color-text-error-primary_hover)'\n : 'var(--color-text-error-primary)',\n iconColor: 'var(--color-fg-error-secondary)',\n border: 'none',\n boxShadow: 'none',\n textDecoration: interactive ? 'underline' : 'none',\n };\n };\n\n const visuals = getVisuals();\n\n /** focus ring: primary/secondary 使用 skeuomorphic 版本叠加基础阴影;其余使用纯环 */\n const focusShadow = (() => {\n if (!showFocusRing) return undefined;\n const isDestructive = hierarchy === 'destructive-primary' || hierarchy === 'destructive-secondary' || hierarchy === 'destructive-tertiary' || hierarchy === 'destructive-link';\n if (isDestructive) {\n if (hierarchy === 'destructive-primary' || hierarchy === 'destructive-secondary') {\n return 'var(--focus-ring-error-shadow-xs-skeuomorphic)';\n }\n return 'var(--focus-ring-error)';\n }\n if (hierarchy === 'primary' || hierarchy === 'secondary') {\n return 'var(--focus-ring-shadow-xs-skeuomorphic, 0 0 0 2px #fff, 0 0 0 4px #fb6011)';\n }\n return 'var(--focus-ring, 0 0 0 2px #fff, 0 0 0 4px #fb6011)';\n })();\n\n const buttonStyle: React.CSSProperties = {\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: s.gap,\n fontFamily: 'var(--font-family-body, \"DM Sans\", system-ui, sans-serif)',\n fontWeight: 600,\n fontSize: s.fontSize,\n lineHeight: `${s.lineHeight}px`,\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n outline: 'none',\n transition: 'background-color .15s ease, color .15s ease, box-shadow .15s ease',\n userSelect: 'none',\n WebkitTapHighlightColor: 'transparent',\n whiteSpace: 'nowrap',\n backgroundColor: visuals.bg,\n color: visuals.color,\n border: visuals.border,\n boxShadow: focusShadow ?? visuals.boxShadow,\n textDecoration: visuals.textDecoration,\n ...style,\n };\n\n if (isLink) {\n // Link 类:保留与同尺寸按钮一致的高度和横向内边距,无背景、无边框\n buttonStyle.borderRadius = '4px';\n buttonStyle.overflow = 'hidden';\n if (isIconOnly) {\n buttonStyle.width = s.height;\n buttonStyle.height = s.height;\n buttonStyle.padding = 0;\n } else {\n buttonStyle.height = s.height;\n buttonStyle.paddingLeft = s.paddingX;\n buttonStyle.paddingRight = s.paddingX;\n }\n } else {\n buttonStyle.borderRadius = 'var(--radius-md, 8px)';\n if (isIconOnly) {\n buttonStyle.width = s.height;\n buttonStyle.height = s.height;\n buttonStyle.padding = 0;\n } else {\n buttonStyle.height = s.height;\n buttonStyle.paddingLeft = s.paddingX;\n buttonStyle.paddingRight = s.paddingX;\n }\n }\n\n const handleClick = (e: React.MouseEvent<HTMLButtonElement>) => {\n if (isDisabled) {\n e.preventDefault();\n return;\n }\n onClick?.(e);\n };\n\n const renderIcon = () => {\n if (loading) {\n return <LoadingSpinner size={s.iconSize} color={visuals.iconColor} />;\n }\n if (!icon) return null;\n return (\n <span\n aria-hidden\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: s.iconSize,\n height: s.iconSize,\n color: visuals.iconColor,\n flexShrink: 0,\n }}\n >\n {icon}\n </span>\n );\n };\n\n const showLeftIcon = loading || (icon && iconPosition === 'left');\n const showRightIcon = !loading && icon && iconPosition === 'right';\n\n return (\n <button\n type={htmlType}\n className={[\n 'aha-button',\n `aha-button--${hierarchy}`,\n `aha-button--${SIZE_ALIAS[size] || 'md'}`,\n isIconOnly && 'aha-button--icon-only',\n isDisabled && 'aha-button--disabled',\n loading && 'aha-button--loading',\n showFocusRing && 'aha-button--focused',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n disabled={isDisabled}\n onClick={handleClick}\n onMouseEnter={() => !isDisabled && setIsHovered(true)}\n onMouseLeave={() => {\n setIsHovered(false);\n setIsPressed(false);\n }}\n onMouseDown={() => !isDisabled && setIsPressed(true)}\n onMouseUp={() => setIsPressed(false)}\n style={buttonStyle}\n {...rest}\n >\n {showLeftIcon && renderIcon()}\n {!isIconOnly && children}\n {showRightIcon && renderIcon()}\n {/* icon-only 且没传 icon 时,允许 children 作为图标 */}\n {isIconOnly && !icon && !loading && children}\n </button>\n );\n};\n\nButton.displayName = 'Button';\n\nexport default Button;\n","export const AlertIcon = {\n success: (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M10 1.66663C5.40002 1.66663 1.66669 5.39996 1.66669 9.99996C1.66669 14.6 5.40002 18.3333 10 18.3333C14.6 18.3333 18.3334 14.6 18.3334 9.99996C18.3334 5.39996 14.6 1.66663 10 1.66663ZM13.3584 8.49997L9.46668 12.3833C9.35001 12.5083 9.19168 12.5666 9.02501 12.5666C8.86668 12.5666 8.70834 12.5083 8.58334 12.3833L6.64169 10.4417C6.40002 10.2 6.40002 9.79994 6.64169 9.55827C6.88336 9.3166 7.28335 9.3166 7.52502 9.55827L9.02501 11.0583L12.475 7.61664C12.7167 7.36664 13.1167 7.36664 13.3584 7.61664C13.6 7.8583 13.6 8.24997 13.3584 8.49997Z\"\n fill=\"#00BC7D\"\n />\n </svg>\n ),\n error: (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M17.1342 6.3009L13.6999 2.86666C13.4658 2.63249 13.1474 2.50085 12.8157 2.50085H7.18504C6.85337 2.50085 6.53584 2.63249 6.30084 2.86666L2.8666 6.3009C2.63243 6.53507 2.50079 6.85343 2.50079 7.1851V12.8158C2.50079 13.1475 2.63243 13.465 2.8666 13.7L6.30084 17.1342C6.53501 17.3684 6.85337 17.5 7.18504 17.5H12.8157C13.1474 17.5 13.4649 17.3684 13.6999 17.1342L17.1342 13.7C17.3683 13.4658 17.5 13.1475 17.5 12.8158V7.1851C17.5 6.85343 17.3683 6.53507 17.1342 6.3009ZM12.525 11.6417C12.7692 11.8858 12.7692 12.2817 12.525 12.5259C12.4033 12.6475 12.2433 12.7092 12.0833 12.7092C11.9233 12.7092 11.7633 12.6484 11.6416 12.5259L9.99998 10.8842L8.35834 12.5259C8.23667 12.6475 8.07665 12.7092 7.91665 12.7092C7.75665 12.7092 7.59662 12.6484 7.47496 12.5259C7.23079 12.2817 7.23079 11.8858 7.47496 11.6417L9.1166 10L7.47496 8.3584C7.23079 8.11423 7.23079 7.71837 7.47496 7.4742C7.71912 7.23004 8.11498 7.23004 8.35915 7.4742L10.0008 9.11585L11.6424 7.4742C11.8866 7.23004 12.2825 7.23004 12.5266 7.4742C12.7708 7.71837 12.7708 8.11423 12.5266 8.3584L10.885 10L12.525 11.6417Z\"\n fill=\"#FB2C36\"\n />\n </svg>\n ),\n warning: (\n <svg \n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M18.0057 14.2935L12.4999 3.99662C11.4333 2.00162 8.56744 2.00162 7.49995 3.99662L1.99417 14.2935C1.01583 16.1235 2.3442 18.3334 4.42337 18.3334H15.5765C17.6549 18.3334 18.9841 16.1226 18.0057 14.2935ZM9.37495 8.33337C9.37495 7.98837 9.65494 7.70837 9.99994 7.70837C10.3449 7.70837 10.6249 7.98837 10.6249 8.33337V11.6667C10.6249 12.0117 10.3449 12.2917 9.99994 12.2917C9.65494 12.2917 9.37495 12.0117 9.37495 11.6667V8.33337ZM10.0166 15C9.55663 15 9.17902 14.6267 9.17902 14.1667C9.17902 13.7067 9.54829 13.3334 10.0083 13.3334H10.0166C10.4775 13.3334 10.85 13.7067 10.85 14.1667C10.85 14.6267 10.4766 15 10.0166 15Z\"\n fill=\"#FE9A00\"\n />\n </svg>\n ),\n info: (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M14.6875 2.5H5.3125C3.4375 2.5 2.5 3.4375 2.5 5.3125V14.6875C2.5 16.5625 3.4375 17.5 5.3125 17.5H14.6875C16.5625 17.5 17.5 16.5625 17.5 14.6875V5.3125C17.5 3.4375 16.5625 2.5 14.6875 2.5ZM10.625 13.75C10.625 14.095 10.345 14.375 10 14.375C9.655 14.375 9.375 14.095 9.375 13.75V9.9408C9.375 9.5958 9.655 9.3158 10 9.3158C10.345 9.3158 10.625 9.5958 10.625 9.9408V13.75ZM10.0167 7.91667C9.55668 7.91667 9.17908 7.54333 9.17908 7.08333C9.17908 6.62333 9.54834 6.25 10.0083 6.25H10.0167C10.4775 6.25 10.85 6.62333 10.85 7.08333C10.85 7.54333 10.4767 7.91667 10.0167 7.91667Z\"\n fill=\"#2B7FFF\"\n />\n </svg>\n ),\n};\n\nexport const CloseIcon = (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M15.4416 14.5583C15.6858 14.8025 15.6858 15.1984 15.4416 15.4425C15.32 15.5642 15.16 15.6258 15 15.6258C14.84 15.6258 14.68 15.565 14.5583 15.4425L9.99997 10.8842L5.44164 15.4425C5.31997 15.5642 5.15997 15.6258 4.99997 15.6258C4.83997 15.6258 4.67997 15.565 4.55831 15.4425C4.31414 15.1984 4.31414 14.8025 4.55831 14.5583L9.11664 10L4.55831 5.44171C4.31414 5.19754 4.31414 4.80168 4.55831 4.55751C4.80247 4.31335 5.19831 4.31335 5.44248 4.55751L10.0008 9.11587L14.5591 4.55751C14.8033 4.31335 15.1991 4.31335 15.4433 4.55751C15.6875 4.80168 15.6875 5.19754 15.4433 5.44171L10.885 10L15.4416 14.5583Z\"\n fill=\"#57534D\"\n />\n </svg>\n);\n","export const ToastIcon = {\n success: (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM16.03 10.2L11.36 14.86C11.22 15.01 11.03 15.08 10.83 15.08C10.64 15.08 10.45 15.01 10.3 14.86L7.97 12.53C7.68 12.24 7.68 11.76 7.97 11.47C8.26 11.18 8.74 11.18 9.03 11.47L10.83 13.27L14.97 9.14001C15.26 8.84001 15.74 8.84001 16.03 9.14001C16.32 9.43001 16.32 9.90001 16.03 10.2Z\"\n fill=\"#ECFDF5\"\n />\n </svg>\n ),\n error: (\n <svg\n width=\"25\"\n height=\"24\"\n viewBox=\"0 0 25 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M21.3506 7.56104L17.2295 3.43994C16.9485 3.15894 16.5665 3.00098 16.1685 3.00098H9.41162C9.01362 3.00098 8.63259 3.15894 8.35059 3.43994L4.22949 7.56104C3.94849 7.84204 3.79053 8.22407 3.79053 8.62207V15.3789C3.79053 15.7769 3.94849 16.1579 4.22949 16.4399L8.35059 20.561C8.63159 20.842 9.01362 21 9.41162 21H16.1685C16.5665 21 16.9475 20.842 17.2295 20.561L21.3506 16.4399C21.6316 16.1589 21.7896 15.7769 21.7896 15.3789V8.62207C21.7896 8.22407 21.6316 7.84204 21.3506 7.56104ZM15.8196 13.97C16.1126 14.263 16.1126 14.738 15.8196 15.031C15.6736 15.177 15.4816 15.251 15.2896 15.251C15.0976 15.251 14.9055 15.178 14.7595 15.031L12.7896 13.061L10.8196 15.031C10.6736 15.177 10.4816 15.251 10.2896 15.251C10.0976 15.251 9.90552 15.178 9.75952 15.031C9.46652 14.738 9.46652 14.263 9.75952 13.97L11.7295 12L9.75952 10.03C9.46652 9.73703 9.46652 9.26199 9.75952 8.96899C10.0525 8.67599 10.5276 8.67599 10.8206 8.96899L12.7905 10.939L14.7605 8.96899C15.0535 8.67599 15.5285 8.67599 15.8215 8.96899C16.1145 9.26199 16.1145 9.73703 15.8215 10.03L13.8516 12L15.8196 13.97Z\"\n fill=\"#FEF2F2\"\n />\n </svg>\n ),\n question: (\n <svg\n width=\"25\"\n height=\"24\"\n viewBox=\"0 0 25 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M18.2041 3H6.9541C4.7041 3 3.5791 4.125 3.5791 6.375V17.625C3.5791 19.875 4.7041 21 6.9541 21H18.2041C20.4541 21 21.5791 19.875 21.5791 17.625V6.375C21.5791 4.125 20.4541 3 18.2041 3ZM12.5991 17.5C12.0471 17.5 11.594 17.052 11.594 16.5C11.594 15.948 12.0371 15.5 12.5891 15.5H12.5991C13.1521 15.5 13.5991 15.948 13.5991 16.5C13.5991 17.052 13.1511 17.5 12.5991 17.5ZM14.1821 12.5281C13.4511 13.0181 13.315 13.291 13.29 13.363C13.185 13.676 12.8931 13.874 12.5791 13.874C12.5001 13.874 12.4201 13.862 12.3411 13.835C11.9481 13.703 11.7372 13.278 11.8682 12.885C12.0492 12.345 12.5182 11.836 13.3462 11.281C14.3672 10.597 14.2361 9.84707 14.1931 9.60107C14.0801 8.94707 13.5291 8.38988 12.8821 8.27588C12.3891 8.18588 11.9092 8.31488 11.5332 8.62988C11.1552 8.94688 10.938 9.41391 10.938 9.90991C10.938 10.3239 10.602 10.6599 10.188 10.6599C9.77399 10.6599 9.43799 10.3239 9.43799 9.90991C9.43799 8.96891 9.85009 8.08396 10.5691 7.48096C11.2811 6.88496 12.2181 6.63605 13.1431 6.80005C14.4101 7.02405 15.4492 8.07097 15.6702 9.34497C15.8902 10.607 15.3611 11.7381 14.1821 12.5281Z\"\n fill=\"#FAFAF9\"\n />\n </svg>\n ),\n info: (\n <svg\n width=\"25\"\n height=\"24\"\n viewBox=\"0 0 25 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M18.2041 3H6.9541C4.7041 3 3.5791 4.125 3.5791 6.375V17.625C3.5791 19.875 4.7041 21 6.9541 21H18.2041C20.4541 21 21.5791 19.875 21.5791 17.625V6.375C21.5791 4.125 20.4541 3 18.2041 3ZM12.5991 17.5C12.0471 17.5 11.594 17.052 11.594 16.5C11.594 15.948 12.0371 15.5 12.5891 15.5H12.5991C13.1521 15.5 13.5991 15.948 13.5991 16.5C13.5991 17.052 13.1511 17.5 12.5991 17.5ZM14.1821 12.5281C13.4511 13.0181 13.315 13.291 13.29 13.363C13.185 13.676 12.8931 13.874 12.5791 13.874C12.5001 13.874 12.4201 13.862 12.3411 13.835C11.9481 13.703 11.7372 13.278 11.8682 12.885C12.0492 12.345 12.5182 11.836 13.3462 11.281C14.3672 10.597 14.2361 9.84707 14.1931 9.60107C14.0801 8.94707 13.5291 8.38988 12.8821 8.27588C12.3891 8.18588 11.9092 8.31488 11.5332 8.62988C11.1552 8.94688 10.938 9.41391 10.938 9.90991C10.938 10.3239 10.602 10.6599 10.188 10.6599C9.77399 10.6599 9.43799 10.3239 9.43799 9.90991C9.43799 8.96891 9.85009 8.08396 10.5691 7.48096C11.2811 6.88496 12.2181 6.63605 13.1431 6.80005C14.4101 7.02405 15.4492 8.07097 15.6702 9.34497C15.8902 10.607 15.3611 11.7381 14.1821 12.5281Z\"\n fill=\"#FAFAF9\"\n />\n </svg>\n ),\n};\n\nexport const CloseIcon = ({ className }: any) => {\n return (\n <svg\n className={`flex-shrink-0 ${className}`}\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M15.4416 14.5583C15.6858 14.8025 15.6858 15.1984 15.4416 15.4425C15.32 15.5642 15.16 15.6258 15 15.6258C14.84 15.6258 14.68 15.565 14.5583 15.4425L9.99997 10.8842L5.44164 15.4425C5.31997 15.5642 5.15997 15.6258 4.99997 15.6258C4.83997 15.6258 4.67997 15.565 4.55831 15.4425C4.31414 15.1984 4.31414 14.8025 4.55831 14.5583L9.11664 10L4.55831 5.44171C4.31414 5.19754 4.31414 4.80168 4.55831 4.55751C4.80247 4.31335 5.19831 4.31335 5.44248 4.55751L10.0008 9.11587L14.5591 4.55751C14.8033 4.31335 15.1991 4.31335 15.4433 4.55751C15.6875 4.80168 15.6875 5.19754 15.4433 5.44171L10.885 10L15.4416 14.5583Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n};\n","import React, { useState, useEffect, useCallback } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport { CloseIcon, ToastIcon } from \"./icon\";\n\nexport type ToastType = \"success\" | \"error\" | \"info\" | \"question\";\nexport type ToastPosition = \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\";\n\nexport interface ToastProps {\n /** Toast 消息内容 */\n message: string;\n /** Toast 类型 */\n type?: ToastType;\n /** 显示位置 */\n position?: ToastPosition;\n /** 显示时长(毫秒),0 表示不自动关闭 */\n duration?: number;\n /** 自定义图标 */\n icon?: React.ReactNode;\n /** 自定义操作按钮 */\n action?: React.ReactNode;\n /** 是否显示关闭按钮 */\n showClose?: boolean;\n /** 关闭回调 */\n onClose?: () => void;\n /** 点击回调 */\n onClick?: () => void;\n /** 自定义样式类名 */\n className?: string;\n}\n\nexport interface ToastInstance {\n id: string;\n props: ToastProps;\n}\n\n// Toast 管理器\nclass ToastManager {\n private toasts: ToastInstance[] = [];\n private listeners: Set<() => void> = new Set();\n\n addToast(props: ToastProps): string {\n const id = Math.random().toString(36).slice(-8);\n const toastInstance = { id, props };\n this.toasts.push(toastInstance);\n console.log('Toast: 添加 Toast 到管理器,ID:', id, '当前总数:', this.toasts.length);\n this.notifyListeners();\n return id;\n }\n\n removeToast(id: string): void {\n this.toasts = this.toasts.filter((toast) => toast.id !== id);\n this.notifyListeners();\n }\n\n getToasts(): ToastInstance[] {\n return [...this.toasts]; // 返回副本,避免外部修改\n }\n\n subscribe(listener: () => void): () => void {\n this.listeners.add(listener);\n return () => this.listeners.delete(listener);\n }\n\n private notifyListeners(): void {\n console.log('Toast: 通知监听器,监听器数量:', this.listeners.size);\n this.listeners.forEach((listener) => listener());\n }\n\n // 清理所有 Toast(用于调试)\n clearAll(): void {\n this.toasts = [];\n this.notifyListeners();\n }\n}\n\n// 全局 Toast 管理器实例\nconst toastManager = new ToastManager();\n\n// Toast 容器组件\nconst ToastContainer: React.FC = () => {\n const [toasts, setToasts] = useState<ToastInstance[]>([]);\n\n useEffect(() => {\n console.log('Toast: ToastContainer 组件已挂载');\n \n // 立即获取当前的 Toast 列表\n const currentToasts = toastManager.getToasts();\n console.log('Toast: 初始 Toast 数量:', currentToasts.length);\n setToasts(currentToasts);\n \n const unsubscribe = toastManager.subscribe(() => {\n const currentToasts = toastManager.getToasts();\n console.log('Toast: 收到 Toast 更新,当前数量:', currentToasts.length, 'Toast IDs:', currentToasts.map(t => t.id));\n setToasts(currentToasts);\n });\n return unsubscribe;\n }, []);\n\n // 按位置分组 Toast\n const topLeftToasts = toasts.filter(\n (toast) => toast.props.position === \"top-left\"\n );\n const topRightToasts = toasts.filter(\n (toast) => toast.props.position === \"top-right\"\n );\n const bottomLeftToasts = toasts.filter(\n (toast) => toast.props.position === \"bottom-left\"\n );\n const bottomRightToasts = toasts.filter(\n (toast) => toast.props.position === \"bottom-right\"\n );\n\n return (\n <>\n {/* 左上角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n top: '16px', \n left: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {topLeftToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n\n {/* 右上角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n top: '16px', \n right: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {topRightToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n\n {/* 左下角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n bottom: '16px', \n left: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {bottomLeftToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n\n {/* 右下角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n bottom: '16px', \n right: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {bottomRightToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n </>\n );\n};\n\n// 单个 Toast 组件\nconst ToastItem: React.FC<ToastInstance> = ({ id, props }) => {\n const [isVisible, setIsVisible] = useState(false);\n const [isExiting, setIsExiting] = useState(false);\n\n const {\n message,\n type = \"info\",\n duration = 3000,\n icon,\n action,\n showClose = true,\n onClose,\n onClick,\n className = \"\",\n } = props;\n\n // 获取类型对应的样式和默认图标\n const getTypeStyles = (type: ToastType) => {\n switch (type) {\n case \"success\":\n return {\n bgColor: \"#009966\",\n defaultIcon: ToastIcon.success,\n };\n case \"error\":\n return {\n bgColor: \"#E7000B\",\n defaultIcon: ToastIcon.error,\n };\n case \"question\":\n return {\n bgColor: \"#1C1917\",\n defaultIcon: ToastIcon.question,\n };\n case \"info\":\n default:\n return {\n bgColor: \"#1447E6\",\n defaultIcon: ToastIcon.info,\n };\n }\n };\n\n const typeStyles = getTypeStyles(type);\n\n // 显示动画\n useEffect(() => {\n const timer = setTimeout(() => {\n setIsVisible(true);\n }, 10);\n return () => clearTimeout(timer);\n }, []);\n\n // 自动关闭\n useEffect(() => {\n if (duration > 0) {\n const timer = setTimeout(() => {\n handleClose();\n }, duration);\n return () => clearTimeout(timer);\n }\n }, [duration, id]); // 添加 id 依赖,确保每个 Toast 独立处理\n\n const handleClose = useCallback(() => {\n setIsExiting(true);\n setTimeout(() => {\n toastManager.removeToast(id);\n onClose?.();\n }, 300); // 动画持续时间\n }, [id, onClose]);\n\n const handleClick = useCallback(() => {\n onClick?.();\n }, [onClick]);\n\n return (\n <div\n style={{\n pointerEvents: 'auto',\n maxWidth: '380px',\n background: 'white',\n borderRadius: '8px',\n boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',\n overflow: 'hidden',\n transform: isVisible && !isExiting ? 'translateY(0) scale(1)' : 'translateY(8px) scale(0.95)',\n opacity: isVisible && !isExiting ? 1 : 0,\n transition: 'all 300ms ease-out',\n position: 'relative',\n cursor: onClick ? 'pointer' : 'default',\n }}\n onClick={handleClick}\n >\n <div style={{\n display: 'flex',\n alignItems: 'flex-start',\n padding: '16px',\n backgroundColor: typeStyles.bgColor,\n color: 'white',\n }}>\n {/* 图标 */}\n <div style={{\n flexShrink: 0,\n width: '24px',\n height: '24px',\n borderRadius: '50%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n marginRight: '8px',\n }}>\n {icon || typeStyles.defaultIcon}\n </div>\n\n {/* 内容区域 */}\n <div style={{\n flex: 1,\n minWidth: 0,\n paddingRight: '20px',\n }}>\n <div style={{\n width: '100%',\n justifyContent: 'flex-start',\n color: '#f0fdf4',\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '24px',\n }}>\n {message}\n </div>\n\n {/* 自定义操作 */}\n {action && <div style={{ marginTop: '12px' }}>{action}</div>}\n </div>\n\n {/* 关闭按钮 */}\n {showClose && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n handleClose();\n }}\n style={{\n flexShrink: 0,\n width: '20px',\n height: '20px',\n borderRadius: '50%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n transition: 'all 200ms',\n position: 'absolute',\n top: '14px',\n right: '16px',\n background: 'transparent',\n border: 'none',\n cursor: 'pointer',\n color: 'white',\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.background = 'rgba(255, 255, 255, 0.1)';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.background = 'transparent';\n }}\n >\n <CloseIcon />\n </button>\n )}\n </div>\n </div>\n );\n};\n\n// Toast 组件\nconst Toast: React.FC<ToastProps> = (props) => {\n // 这个组件主要用于直接渲染单个 Toast\n // 通常使用 toast() 函数来显示 Toast\n return <ToastItem id=\"direct\" props={props} />;\n};\n\n// Toast 显示函数\nexport const toast = (props: ToastProps): string => {\n console.log('Toast: 调用 toast 函数', props);\n \n // 确保 Toast 容器已挂载\n ensureToastContainer();\n \n // 使用 setTimeout 确保容器完全初始化\n setTimeout(() => {\n const id = toastManager.addToast(props);\n console.log('Toast: 添加 Toast 成功,ID:', id);\n }, 100);\n \n // 临时返回一个 ID\n return Math.random().toString(36).slice(-8);\n};\n\n// Toast 关闭函数\nexport const closeToast = (id: string): void => {\n toastManager.removeToast(id);\n};\n\n// 清理所有 Toast\nexport const clearAllToasts = (): void => {\n toastManager.clearAll();\n};\n\n// 调试函数\nexport const debugToast = () => {\n console.log('=== Toast 调试信息 ===');\n console.log('当前环境:', typeof window !== 'undefined' ? '浏览器' : '服务端');\n console.log('document 可用:', typeof document !== 'undefined');\n console.log('容器元素:', document.getElementById('aha-toast-container'));\n console.log('Toast 管理器状态:', toastManager.getToasts());\n console.log('容器根节点:', toastContainerRoot);\n console.log('是否正在初始化:', isInitializing);\n console.log('====================');\n};\n\n// 便捷方法\nexport const toastSuccess = (\n message: string,\n options?: Partial<ToastProps>\n) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"success\" });\n};\n\nexport const toastError = (message: string, options?: Partial<ToastProps>) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"error\" });\n};\n\nexport const toastInfo = (message: string, options?: Partial<ToastProps>) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"info\" });\n};\n\nexport const toastQuestion = (\n message: string,\n options?: Partial<ToastProps>\n) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"question\" });\n};\n\n// 自动挂载的 Toast 容器\nlet toastContainerElement: HTMLElement | null = null;\nlet toastContainerRoot: any = null;\nlet isInitializing = false;\n\nconst ensureToastContainer = () => {\n console.log('Toast: 开始确保容器存在');\n \n // 检查是否在浏览器环境\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n console.warn('Toast: 当前环境不支持 Toast 组件');\n return;\n }\n\n // 如果已经在初始化中,直接返回\n if (isInitializing) {\n console.log('Toast: 容器正在初始化中,跳过');\n return;\n }\n\n if (!toastContainerElement) {\n console.log('Toast: 创建新的 Toast 容器');\n isInitializing = true;\n \n try {\n // 检查是否已存在容器\n const existingContainer = document.getElementById('aha-toast-container');\n if (existingContainer) {\n console.log('Toast: 发现已存在的容器');\n toastContainerElement = existingContainer;\n isInitializing = false;\n return;\n }\n\n // 创建容器元素\n console.log('Toast: 创建容器元素');\n toastContainerElement = document.createElement('div');\n toastContainerElement.id = 'aha-toast-container';\n document.body.appendChild(toastContainerElement);\n console.log('Toast: 容器已添加到 document.body');\n\n // 尝试直接导入 ReactDOM\n console.log('Toast: 开始导入 ReactDOM');\n try {\n // 先尝试同步导入\n const { createRoot } = require('react-dom/client');\n console.log('Toast: ReactDOM 同步导入成功,创建根节点');\n toastContainerRoot = createRoot(toastContainerElement!);\n console.log('Toast: 渲染 ToastContainer 组件');\n toastContainerRoot.render(<ToastContainer />);\n console.log('Toast: 容器渲染完成');\n isInitializing = false;\n } catch (error) {\n console.log('Toast: 同步导入失败,尝试动态导入', error);\n // 如果同步导入失败,尝试动态导入\n import('react-dom/client').then(({ createRoot }) => {\n try {\n console.log('Toast: ReactDOM 动态导入成功,创建根节点');\n toastContainerRoot = createRoot(toastContainerElement!);\n console.log('Toast: 渲染 ToastContainer 组件');\n toastContainerRoot.render(<ToastContainer />);\n console.log('Toast: 容器渲染完成');\n } catch (error) {\n console.error('Toast: 渲染容器失败', error);\n }\n isInitializing = false;\n }).catch((error) => {\n console.error('Toast: 导入 ReactDOM 失败', error);\n isInitializing = false;\n });\n }\n } catch (error) {\n console.error('Toast: 创建容器失败', error);\n isInitializing = false;\n }\n } else {\n console.log('Toast: 容器已存在,跳过创建');\n }\n};\n\n// Toast 提供者组件(保持向后兼容)\nexport const ToastProvider: React.FC<{ children: React.ReactNode }> = ({\n children,\n}) => {\n const [mounted, setMounted] = useState(false);\n\n useEffect(() => {\n setMounted(true);\n }, []);\n\n return (\n <>\n {children}\n {mounted && createPortal(<ToastContainer />, document.body)}\n </>\n );\n};\n\nexport default Toast;\n","import React, { SVGProps } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport type TagColor = 'Green' | 'Red' | 'Orange' | 'Cyan' | 'Violet' | 'Pink' | 'Gray' | 'Yellow' | 'Blue' | string;\nexport type TagVariant = 'light' | 'fill';\nexport type TagSize = 'large' | 'small';\nexport type IconPosition = 'leading' | 'after' | 'none';\n\nexport interface TagProps {\n children: React.ReactNode;\n color: TagColor; // 必需属性,支持预定义颜色或自定义十六进制颜色\n variant?: TagVariant;\n size?: TagSize;\n stroke?: boolean; // 仅对 light 变体有效\n icon?: React.ReactElement; // 只允许 React 元素,不接受字符串\n iconPosition?: IconPosition;\n className?: string;\n onClick?: () => void;\n [key: string]: any;\n}\n\n// 颜色配置\nconst COLOR_CONFIG = {\n Green: {\n light: {\n bg: '#ECFDF5',\n text: '#006045',\n border: '#A4F4CF',\n },\n fill: {\n bg: '#00BC7D',\n text: '#FFFFFF',\n }\n },\n Red: {\n light: {\n bg: '#FEF2F2',\n text: '#9F0712',\n border: '#FFC9C9',\n },\n fill: {\n bg: '#FB2C36',\n text: '#FFFFFF',\n }\n },\n Orange: {\n light: {\n bg: '#FFF6ED',\n text: '#9B2911',\n border: '#FFD1A9',\n },\n fill: {\n bg: '#FB6011',\n text: '#FFFFFF',\n }\n },\n Cyan: {\n light: {\n bg: '#ECFEFF',\n text: '#005F78',\n border: '#A2F4FD',\n },\n fill: {\n bg: '#00B8DB',\n text: '#FFFFFF',\n }\n },\n Violet: {\n light: {\n bg: '#F5F3FF',\n text: '#5D0EC0',\n border: '#DDD6FF',\n },\n fill: {\n bg: '#8E51FF',\n text: '#FFFFFF',\n }\n },\n Pink: {\n light: {\n bg: '#FDF2F8',\n text: '#A3004C',\n border: '#FCCEE8',\n },\n fill: {\n bg: '#F6339A',\n text: '#FFFFFF',\n }\n },\n Gray: {\n light: {\n bg: '#F5F5F4',\n text: '#292524',\n border: '#E7E5E4',\n },\n fill: {\n bg: '#292524',\n text: '#FFFFFF',\n }\n },\n Yellow: {\n light: {\n bg: '#FFFBEB',\n text: '#973C00',\n border: '#FEE685',\n },\n fill: {\n bg: '#FE9A00',\n text: '#FFFFFF',\n }\n },\n Blue: {\n light: {\n bg: '#EFF6FF',\n text: '#193CB8',\n border: '#BEDBFF',\n },\n fill: {\n bg: '#2B7FFF',\n text: '#FFFFFF',\n }\n }\n};\n\n// 尺寸配置\nconst SIZE_CONFIG = {\n large: {\n padding: 'px-2 py-0.5',\n textSize: 'text-sm',\n iconSize: 'w-4 h-4',\n gap: 'gap-1',\n },\n small: {\n padding: 'px-2 py-0.5', // 与 large 相同的外层 padding\n textSize: 'text-xs',\n iconSize: 'w-3 h-3',\n gap: 'gap-0.5',\n }\n};\n\n// 获取颜色配置的函数\nconst getColorConfig = (color: TagColor, primaryColor?: string) => {\n // 如果是预定义颜色,返回对应的配置\n if (typeof color === 'string' && color in COLOR_CONFIG) {\n const config = COLOR_CONFIG[color as keyof typeof COLOR_CONFIG];\n // 如果是 Orange 颜色,使用主题色\n if (color === 'Orange' && primaryColor) {\n return {\n ...config,\n fill: {\n ...config.fill,\n bg: primaryColor,\n },\n };\n }\n return config;\n }\n \n // 如果是自定义颜色(十六进制),生成配置\n if (typeof color === 'string' && color.startsWith('#')) {\n // 将十六进制转换为 RGB 值\n const hex = color.replace('#', '');\n const r = parseInt(hex.substr(0, 2), 16);\n const g = parseInt(hex.substr(2, 2), 16);\n const b = parseInt(hex.substr(4, 2), 16);\n \n return {\n light: {\n bg: `rgba(${r}, ${g}, ${b}, 0.1)`, // 10% 透明度\n text: color,\n border: `rgba(${r}, ${g}, ${b}, 0.3)`, // 30% 透明度\n },\n fill: {\n bg: color,\n text: '#FFFFFF',\n }\n };\n }\n \n // 默认返回绿色配置\n return COLOR_CONFIG.Green;\n};\n\n// 获取图标颜色的函数\nconst getIconColor = (color: TagColor, primaryColor?: string) => {\n // 如果是预定义颜色,返回对应的图标颜色\n if (typeof color === 'string' && color in COLOR_CONFIG) {\n switch (color) {\n case 'Green': return '#009966';\n case 'Red': return '#E7000B';\n case 'Orange': return primaryColor || '#E17100'; // 使用主题色\n case 'Blue': return '#155DFC';\n case 'Yellow': return '#EC470A';\n case 'Cyan': return '#0092B8';\n case 'Violet': return '#7F22FE';\n case 'Pink': return '#E60076';\n case 'Gray': return '#57534D';\n default: return '#009966';\n }\n }\n \n // 如果是自定义颜色,返回原色\n if (typeof color === 'string' && color.startsWith('#')) {\n return color;\n }\n \n return '#009966';\n};\n\n// 获取边框颜色的函数\nconst getOutlineColor = (color: TagColor) => {\n // 如果是预定义颜色,返回对应的边框颜色\n if (typeof color === 'string' && color in COLOR_CONFIG) {\n switch (color) {\n case 'Green': return '#A4F4CF';\n case 'Red': return '#FFC9C9';\n case 'Orange': return '#FFD1A9';\n case 'Blue': return '#BEDBFF';\n case 'Yellow': return '#FFD1A9';\n case 'Cyan': return '#A2F4FD';\n case 'Violet': return '#DDD6FF';\n case 'Pink': return '#FCCEE8';\n case 'Gray': return '#E7E5E4';\n default: return '#A4F4CF';\n }\n }\n \n // 如果是自定义颜色,返回带透明度的颜色\n if (typeof color === 'string' && color.startsWith('#')) {\n const hex = color.replace('#', '');\n const r = parseInt(hex.substr(0, 2), 16);\n const g = parseInt(hex.substr(2, 2), 16);\n const b = parseInt(hex.substr(4, 2), 16);\n return `rgba(${r}, ${g}, ${b}, 0.3)`; // 30% 透明度\n }\n \n return '#A4F4CF';\n};\n\nconst Tag: React.FC<TagProps> = ({\n children,\n color,\n variant = 'light',\n size = 'large',\n stroke = false,\n icon,\n iconPosition = 'none',\n className = '',\n onClick,\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n const colorConfig = getColorConfig(color, primaryColor);\n const sizeConfig = SIZE_CONFIG[size];\n \n // 构建基础样式对象\n const baseStyle: React.CSSProperties = {\n borderRadius: '0.375rem', // rounded-md\n display: 'inline-flex',\n justifyContent: 'start',\n alignItems: 'center',\n padding: '2px 8px', // px-2 py-0.5 (所有尺寸都相同)\n gap: size === 'large' ? '4px' : '2px', // gap-1 or gap-0.5\n fontWeight: 500, // font-medium\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: size === 'large' ? '1.375' : '1', // leading-snug or leading-none\n transition: 'all 0.2s',\n fontSize: size === 'large' ? '14px' : '12px', // text-sm or text-xs\n height: size === 'small' ? '20px' : '24px', // Small 尺寸 20px,Large 尺寸 24px\n };\n\n // 根据变体和颜色添加样式\n if (variant === 'light') {\n baseStyle.backgroundColor = colorConfig.light.bg;\n baseStyle.color = colorConfig.light.text;\n if (stroke) {\n // 使用 outline 样式而不是 border\n baseStyle.outline = '1px solid';\n baseStyle.outlineOffset = '-1px';\n // 根据颜色设置 outline 颜色\n baseStyle.outlineColor = getOutlineColor(color);\n }\n }\n\n // 添加点击样式\n if (onClick) {\n baseStyle.cursor = 'pointer';\n baseStyle.opacity = '1';\n }\n\n // 构建类名\n const baseClasses = [\n 'rounded-md',\n 'inline-flex',\n 'justify-start',\n 'items-center',\n sizeConfig.padding,\n sizeConfig.gap,\n 'font-medium',\n 'font-dm-sans',\n size === 'large' ? 'leading-snug' : 'leading-none',\n 'transition-colors',\n 'duration-200',\n size === 'small' ? 'h-5' : 'h-6' // Small 尺寸 20px,Large 尺寸 24px\n ].filter(Boolean); // 过滤掉空字符串\n\n // 为 fill 变体添加样式\n if (variant === 'fill') {\n baseStyle.backgroundColor = colorConfig.fill.bg;\n baseStyle.color = colorConfig.fill.text;\n }\n\n if (onClick) {\n baseClasses.push('cursor-pointer', 'hover:opacity-80');\n }\n\n if (className) {\n baseClasses.push(className);\n }\n\n const containerClasses = baseClasses.join(' ');\n\n // 渲染图标\n const renderIcon = () => {\n if (!icon) return null;\n \n // 根据颜色设置图标颜色\n const iconColor = getIconColor(color, primaryColor);\n \n // 根据尺寸设置图标大小\n const iconSize = size === 'small' ? '14px' : '16px';\n \n return (\n <div className=\"flex items-center justify-center\" style={{ width: iconSize, height: iconSize }}>\n {icon.type === 'svg' ? (\n React.cloneElement(icon as React.ReactElement<SVGProps<SVGSVGElement>>, {\n width: iconSize,\n height: iconSize,\n style: { fill: iconColor }\n })\n ) : (\n icon\n )}\n </div>\n );\n };\n\n // 渲染文本内容\n const renderContent = () => {\n return (\n <div className=\"px-1 flex justify-center items-center\">\n <div className={`justify-center ${sizeConfig.textSize} font-medium font-dm-sans ${size === 'large' ? 'leading-snug' : 'leading-none'}`}>\n {children}\n </div>\n </div>\n );\n };\n\n return (\n <div\n className={containerClasses}\n style={baseStyle}\n onClick={onClick}\n {...rest}\n >\n {iconPosition === 'leading' && renderIcon()}\n {renderContent()}\n {iconPosition === 'after' && renderIcon()}\n </div>\n );\n};\n\nexport default Tag;\n","import React, { forwardRef, useRef, useEffect } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface InputProps\n extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'prefix' | 'suffix'> {\n /** 输入框大小 */\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 是否只读 */\n readOnly?: boolean;\n /** 输入框前缀图标 */\n prefix?: React.ReactNode;\n /** 输入框后缀图标 */\n suffix?: React.ReactNode;\n /** 允许清除 */\n allowClear?: boolean;\n /** 清除回调 */\n onClear?: () => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 输入框类型 */\n type?: string;\n /** 占位符 */\n placeholder?: string;\n /** 值 */\n value?: string;\n /** 默认值 */\n defaultValue?: string;\n /** 变化回调 */\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent<HTMLInputElement>) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent<HTMLInputElement>) => void;\n /** 按下回车回调 */\n onPressEnter?: (e: React.KeyboardEvent<HTMLInputElement>) => void;\n}\n\nconst Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n size = 'medium',\n disabled = false,\n error = false,\n readOnly = false,\n prefix,\n suffix,\n allowClear = false,\n onClear,\n className = '',\n style,\n type = 'text',\n placeholder,\n value,\n defaultValue,\n onChange,\n onFocus,\n onBlur,\n onPressEnter,\n ...restProps\n },\n ref\n ) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const inputRef = useRef<HTMLInputElement>(null);\n const [internalValue, setInternalValue] = React.useState(\n defaultValue || value || ''\n );\n const [focused, setFocused] = React.useState(false);\n\n // 合并 ref\n useEffect(() => {\n if (typeof ref === 'function') {\n ref(inputRef.current);\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLInputElement | null>).current =\n inputRef.current;\n }\n }, [ref]);\n\n // 受控/非受控处理\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setInternalValue(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLInputElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter' && onPressEnter) {\n onPressEnter(e);\n }\n restProps.onKeyDown?.(e);\n };\n\n const handleClear = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!isControlled) {\n setInternalValue('');\n }\n // 创建一个清除事件\n const syntheticEvent = {\n target: { value: '' },\n currentTarget: { value: '' },\n } as React.ChangeEvent<HTMLInputElement>;\n onChange?.(syntheticEvent);\n onClear?.();\n inputRef.current?.focus();\n };\n\n const showClear = allowClear && currentValue && !disabled;\n\n // 尺寸样式 - 高度包含边框(1px),实际内容区域需要减去上下边框(2px)\n // 字体 16px,line-height 24px,需要计算合适的 padding\n const sizeStyles = {\n small: {\n height: '32px', // 包含边框的实际高度\n paddingTop: '3px',\n paddingBottom: '3px',\n },\n mediumSmall: {\n height: '36px', // 包含边框的实际高度\n paddingTop: '5px',\n paddingBottom: '5px',\n },\n medium: {\n height: '40px', // 包含边框的实际高度\n paddingTop: '7px',\n paddingBottom: '7px',\n },\n large: {\n height: '48px', // 包含边框的实际高度\n paddingTop: '11px',\n paddingBottom: '11px',\n },\n };\n\n // 计算 padding-right\n const hasRightContent = suffix || showClear;\n const paddingRight = hasRightContent ? '40px' : '12px'; // 如果有后缀或清除按钮,右边留出空间\n\n const baseStyles: React.CSSProperties = {\n width: '100%',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px', // rounded-md (0.5rem)\n border: `1px solid ${error ? '#F04438' : focused ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : readOnly ? '#FAFAF9' : '#FFFFFF',\n color: disabled ? '#98A2B3' : '#1C1917',\n fontSize: '16px', // text-base - 至少 16px 避免 iOS Safari 自动缩放\n fontWeight: 400,\n lineHeight: '24px',\n paddingLeft: prefix ? '40px' : '12px', // 所有情况下,如果没有前缀,padding-left 都是 12px\n paddingRight,\n paddingTop: sizeStyles[size].paddingTop,\n paddingBottom: sizeStyles[size].paddingBottom,\n transition: 'all 0.2s',\n outline: 'none',\n WebkitAppearance: 'none', // 移除 iOS Safari 默认样式\n MozAppearance: 'textfield', // 移除 Firefox 数字输入框的上下箭头\n appearance: 'none',\n ...style,\n };\n\n // 占位符样式通过 CSS 类名处理\n const placeholderStyles = `\n .aha-input-wrapper input::placeholder {\n color: #D7D3D0;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-input-wrapper input::-webkit-input-placeholder {\n color: #D7D3D0;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-input-wrapper input::-moz-placeholder {\n color: #D7D3D0;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-input-wrapper input:-ms-input-placeholder {\n color: #D7D3D0;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n /* 移动端优化 */\n .aha-input-wrapper input {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n /* 移除数字输入框的上下箭头 */\n .aha-input-wrapper input[type=\"number\"]::-webkit-inner-spin-button,\n .aha-input-wrapper input[type=\"number\"]::-webkit-outer-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n .aha-input-wrapper input[type=\"number\"] {\n -moz-appearance: textfield;\n }\n `;\n\n // 清除图标\n const ClearIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n onClick={handleClear}\n style={{\n cursor: 'pointer',\n flexShrink: 0,\n color: '#78716C',\n }}\n >\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n return (\n <>\n <style>{placeholderStyles}</style>\n <div\n className={`aha-input-wrapper ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n width: '100%',\n }}\n >\n {prefix && (\n <span\n style={{\n position: 'absolute',\n left: '12px',\n display: 'flex',\n alignItems: 'center',\n color: disabled ? '#98A2B3' : '#78716C',\n zIndex: 1,\n pointerEvents: 'none',\n }}\n >\n {prefix}\n </span>\n )}\n <input\n ref={inputRef}\n type={type}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n style={baseStyles}\n autoComplete={restProps.autoComplete || 'off'}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n {...restProps}\n />\n {(suffix || showClear) && (\n <span\n style={{\n position: 'absolute',\n right: '12px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n color: disabled ? '#98A2B3' : '#78716C',\n zIndex: 1,\n }}\n >\n {showClear && <ClearIcon />}\n {suffix && <span style={{ pointerEvents: 'none' }}>{suffix}</span>}\n </span>\n )}\n </div>\n </>\n );\n }\n);\n\nInput.displayName = 'Input';\n\nexport default Input;\n\n","import React, { useState, useRef, useEffect, useCallback, useMemo } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface SelectOption {\n label: React.ReactNode;\n value: string | number;\n disabled?: boolean;\n [key: string]: any;\n}\n\nexport interface SelectProps {\n /** 当前选中的值 */\n value?: string | number | (string | number)[];\n /** 默认选中的值 */\n defaultValue?: string | number | (string | number)[];\n /** 选项数据 */\n options?: SelectOption[];\n /** 是否支持多选 */\n mode?: 'multiple' | 'tags';\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 占位符 */\n placeholder?: string;\n /** 尺寸 */\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n /** 是否可搜索 */\n showSearch?: boolean;\n /** 搜索过滤函数 */\n filterOption?: boolean | ((input: string, option: SelectOption) => boolean);\n /** 是否允许清除 */\n allowClear?: boolean;\n /** 变化回调 */\n onChange?: (\n value: string | number | (string | number)[],\n option: SelectOption | SelectOption[]\n ) => void;\n /** 选择回调 */\n onSelect?: (value: string | number, option: SelectOption) => void;\n /** 取消选择回调 */\n onDeselect?: (value: string | number, option: SelectOption) => void;\n /** 搜索回调 */\n onSearch?: (value: string) => void;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent) => void;\n /** 下拉框打开回调 */\n onDropdownVisibleChange?: (open: boolean) => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 下拉框类名 */\n dropdownClassName?: string;\n /** 下拉框样式 */\n dropdownStyle?: React.CSSProperties;\n /** 是否默认打开 */\n defaultOpen?: boolean;\n /** 是否打开(受控) */\n open?: boolean;\n /** 最大标签数量 */\n maxTagCount?: number | 'responsive';\n /** 标签渲染函数 */\n tagRender?: (props: {\n label: React.ReactNode;\n value: string | number;\n closable: boolean;\n onClose: () => void;\n }) => React.ReactNode;\n /** 选项渲染函数 */\n optionRender?: (option: SelectOption, info: {\n selected: boolean;\n focused: boolean;\n disabled: boolean;\n }) => React.ReactNode;\n}\n\nconst Select: React.FC<SelectProps> = ({\n value: controlledValue,\n defaultValue,\n options = [],\n mode,\n disabled = false,\n error = false,\n placeholder = 'Please select',\n size = 'medium',\n showSearch = false,\n filterOption = true,\n allowClear = false,\n onChange,\n onSelect,\n onDeselect,\n onSearch,\n onFocus,\n onBlur,\n onDropdownVisibleChange,\n className = '',\n style,\n dropdownClassName = '',\n dropdownStyle,\n defaultOpen = false,\n open: controlledOpen,\n maxTagCount,\n tagRender,\n optionRender,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const [internalValue, setInternalValue] = useState<\n string | number | (string | number)[] | undefined\n >(defaultValue !== undefined ? defaultValue : (mode ? [] : undefined));\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [searchValue, setSearchValue] = useState('');\n const [focusedIndex, setFocusedIndex] = useState(-1);\n\n const selectRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const dropdownRef = useRef<HTMLDivElement>(null);\n const [dropdownPosition, setDropdownPosition] = useState<{\n top: number;\n left: number;\n width: number;\n placement: 'top' | 'bottom';\n } | null>(null);\n\n const isControlled = controlledValue !== undefined;\n const isOpenControlled = controlledOpen !== undefined;\n const currentValue = isControlled ? controlledValue : internalValue;\n const isOpen = isOpenControlled ? controlledOpen : internalOpen;\n const isMultiple = mode === 'multiple' || mode === 'tags';\n\n // 获取选中的选项\n const getSelectedOptions = useCallback((): SelectOption[] => {\n if (!currentValue) return [];\n const values = Array.isArray(currentValue) ? currentValue : [currentValue];\n return options.filter((opt) => values.includes(opt.value));\n }, [currentValue, options]);\n\n // 过滤选项\n const getFilteredOptions = useCallback((): SelectOption[] => {\n if (!showSearch || !searchValue) return options;\n\n if (filterOption === false) return options;\n\n if (typeof filterOption === 'function') {\n return options.filter((opt) => filterOption(searchValue, opt));\n }\n\n // 默认过滤:匹配 label\n return options.filter((opt) => {\n const label = String(opt.label || '').toLowerCase();\n const search = searchValue.toLowerCase();\n return label.includes(search);\n });\n }, [options, searchValue, showSearch, filterOption]);\n\n const filteredOptions = useMemo(() => getFilteredOptions(), [getFilteredOptions]);\n\n // 计算下拉框位置\n useEffect(() => {\n if (isOpen && selectRef.current) {\n const updatePosition = () => {\n if (selectRef.current) {\n const rect = selectRef.current.getBoundingClientRect();\n const estimatedDropdownHeight =\n dropdownRef.current?.offsetHeight ??\n Math.min(256, Math.max(40, filteredOptions.length * 40));\n const gap = 4;\n const spaceBelow = window.innerHeight - rect.bottom;\n const spaceAbove = rect.top;\n const shouldOpenUp =\n spaceBelow < estimatedDropdownHeight + gap && spaceAbove > spaceBelow;\n const top = shouldOpenUp\n ? rect.top + window.scrollY - estimatedDropdownHeight - gap\n : rect.bottom + window.scrollY + gap;\n\n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement: shouldOpenUp ? 'top' : 'bottom',\n });\n }\n };\n\n updatePosition();\n requestAnimationFrame(updatePosition);\n\n // 监听窗口大小变化和滚动,更新位置\n window.addEventListener('resize', updatePosition);\n window.addEventListener('scroll', updatePosition, true);\n\n return () => {\n window.removeEventListener('resize', updatePosition);\n window.removeEventListener('scroll', updatePosition, true);\n };\n } else {\n setDropdownPosition(null);\n }\n }, [isOpen, filteredOptions.length]);\n\n // 点击外部关闭(支持鼠标和触摸事件)\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent | TouchEvent) => {\n const target = event.target as Node;\n if (\n selectRef.current &&\n !selectRef.current.contains(target) &&\n dropdownRef.current &&\n !dropdownRef.current.contains(target)\n ) {\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onDropdownVisibleChange?.(false);\n setSearchValue('');\n }\n };\n\n if (isOpen) {\n // 使用 capture 阶段确保能捕获到事件\n document.addEventListener('mousedown', handleClickOutside, true);\n document.addEventListener('touchstart', handleClickOutside, true);\n return () => {\n document.removeEventListener('mousedown', handleClickOutside, true);\n document.removeEventListener('touchstart', handleClickOutside, true);\n };\n }\n }, [isOpen, isOpenControlled, onDropdownVisibleChange]);\n\n // 键盘导航\n useEffect(() => {\n if (!isOpen) return;\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === 'ArrowDown') {\n e.preventDefault();\n setFocusedIndex((prev) =>\n prev < filteredOptions.length - 1 ? prev + 1 : prev\n );\n } else if (e.key === 'ArrowUp') {\n e.preventDefault();\n setFocusedIndex((prev) => (prev > 0 ? prev - 1 : 0));\n } else if (e.key === 'Enter' && focusedIndex >= 0) {\n e.preventDefault();\n const option = filteredOptions[focusedIndex];\n if (option && !option.disabled) {\n handleSelect(option);\n }\n } else if (e.key === 'Escape') {\n e.preventDefault();\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onDropdownVisibleChange?.(false);\n selectRef.current?.focus();\n }\n };\n\n window.addEventListener('keydown', handleKeyDown);\n return () => {\n window.removeEventListener('keydown', handleKeyDown);\n };\n }, [isOpen, filteredOptions, focusedIndex, isOpenControlled, onDropdownVisibleChange]);\n\n // 滚动到聚焦项\n useEffect(() => {\n if (focusedIndex >= 0 && dropdownRef.current) {\n const items = dropdownRef.current.querySelectorAll('.aha-select-option');\n const focusedItem = items[focusedIndex] as HTMLElement;\n if (focusedItem) {\n focusedItem.scrollIntoView({ block: 'nearest', behavior: 'smooth' });\n }\n }\n }, [focusedIndex]);\n\n const handleSelect = useCallback((option: SelectOption) => {\n if (option.disabled) return;\n\n if (isMultiple) {\n const currentValues = Array.isArray(currentValue) ? currentValue : [];\n const isSelected = currentValues.includes(option.value);\n\n let newValues: (string | number)[];\n if (isSelected) {\n newValues = currentValues.filter((v) => v !== option.value);\n onDeselect?.(option.value, option);\n } else {\n newValues = [...currentValues, option.value];\n onSelect?.(option.value, option);\n }\n\n if (!isControlled) {\n setInternalValue(newValues);\n }\n // 计算选中的选项\n const selectedOptions = options.filter((opt) => newValues.includes(opt.value));\n onChange?.(newValues, selectedOptions);\n } else {\n if (!isControlled) {\n setInternalValue(option.value);\n }\n onChange?.(option.value, option);\n onSelect?.(option.value, option);\n\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onDropdownVisibleChange?.(false);\n setSearchValue('');\n selectRef.current?.focus();\n }\n }, [isMultiple, currentValue, isControlled, isOpenControlled, options, onChange, onSelect, onDeselect, onDropdownVisibleChange]);\n\n const handleRemoveTag = useCallback((e: React.MouseEvent, value: string | number) => {\n e.stopPropagation();\n if (isMultiple && Array.isArray(currentValue)) {\n const newValues = currentValue.filter((v) => v !== value);\n const option = options.find((opt) => opt.value === value);\n if (!isControlled) {\n setInternalValue(newValues);\n }\n onChange?.(newValues, getSelectedOptions());\n onDeselect?.(value, option!);\n }\n }, [isMultiple, currentValue, isControlled, options, onChange, onDeselect, getSelectedOptions]);\n\n const handleClear = (e: React.MouseEvent) => {\n e.stopPropagation();\n const newValue: string | number | (string | number)[] | undefined = isMultiple ? [] : undefined;\n if (!isControlled) {\n setInternalValue(newValue);\n }\n onChange?.(newValue as any, []);\n setSearchValue('');\n };\n\n const handleToggle = () => {\n if (disabled) return;\n const newOpen = !isOpen;\n if (!isOpenControlled) {\n setInternalOpen(newOpen);\n }\n onDropdownVisibleChange?.(newOpen);\n if (newOpen && showSearch) {\n setTimeout(() => {\n inputRef.current?.focus();\n }, 0);\n } else {\n setSearchValue('');\n }\n };\n\n const handleSearch = (e: React.ChangeEvent<HTMLInputElement>) => {\n const val = e.target.value;\n setSearchValue(val);\n onSearch?.(val);\n setFocusedIndex(-1);\n };\n\n const handleFocus = (e: React.FocusEvent) => {\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent) => {\n onBlur?.(e);\n };\n\n // 尺寸样式 - 对齐 Input 组件\n const sizeStyles = {\n small: {\n height: '32px',\n paddingTop: '3px',\n paddingBottom: '3px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n mediumSmall: {\n height: '36px',\n paddingTop: '5px',\n paddingBottom: '5px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n medium: {\n height: '40px',\n paddingTop: '7px',\n paddingBottom: '7px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n large: {\n height: '48px',\n paddingTop: '11px',\n paddingBottom: '11px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n };\n\n const selectedOptions = useMemo(() => getSelectedOptions(), [getSelectedOptions]);\n const showClear = useMemo(() => allowClear && currentValue && !disabled, [allowClear, currentValue, disabled]);\n const hasValue = useMemo(() => \n isMultiple\n ? Array.isArray(currentValue) && currentValue.length > 0\n : currentValue !== undefined && currentValue !== null && currentValue !== '',\n [isMultiple, currentValue]\n );\n\n // 渲染标签 - 使用 useMemo 优化\n const renderTags = useMemo(() => {\n if (!isMultiple || !Array.isArray(currentValue) || currentValue.length === 0) {\n return null;\n }\n\n const tagsToShow =\n maxTagCount === 'responsive'\n ? selectedOptions.slice(0, 2) // 简化处理\n : maxTagCount\n ? selectedOptions.slice(0, maxTagCount)\n : selectedOptions;\n\n const remainingCount =\n maxTagCount && selectedOptions.length > tagsToShow.length\n ? selectedOptions.length - tagsToShow.length\n : 0;\n\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n flexWrap: 'wrap',\n gap: '4px',\n flex: 1,\n minWidth: 0,\n }}\n >\n {tagsToShow.map((option) => {\n const tagProps = {\n label: option.label,\n value: option.value,\n closable: !disabled,\n onClose: () => handleRemoveTag({} as any, option.value),\n };\n\n if (tagRender) {\n return <React.Fragment key={option.value}>{tagRender(tagProps)}</React.Fragment>;\n }\n\n return (\n <span\n key={option.value}\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n gap: '4px',\n padding: '2px 8px',\n backgroundColor: '#F5F5F4',\n borderRadius: '4px',\n fontSize: '12px',\n lineHeight: '18px',\n color: '#101828',\n fontFamily: \"DM Sans, sans-serif\",\n maxWidth: '100%',\n }}\n >\n <span\n style={{\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n >\n {option.label}\n </span>\n {!disabled && (\n <span\n onClick={(e) => handleRemoveTag(e, option.value)}\n style={{\n cursor: 'pointer',\n display: 'flex',\n alignItems: 'center',\n color: '#78716C',\n marginLeft: '4px',\n }}\n >\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9 3L3 9M3 3L9 9\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </span>\n )}\n </span>\n );\n })}\n {remainingCount > 0 && (\n <span\n style={{\n fontSize: '12px',\n lineHeight: '18px',\n color: '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n +{remainingCount}\n </span>\n )}\n </div>\n );\n }, [isMultiple, currentValue, selectedOptions, maxTagCount, disabled, tagRender]);\n\n // 下拉箭头图标\n const ArrowIcon = ({ isOpen: open }: { isOpen: boolean }) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{\n transform: open ? 'rotate(180deg)' : 'rotate(0deg)',\n transition: 'transform 0.2s ease-in-out',\n flexShrink: 0,\n }}\n >\n <path\n d=\"M4 6L8 10L12 6\"\n stroke=\"#78716C\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n // 清除图标\n const ClearIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n onClick={handleClear}\n style={{\n cursor: 'pointer',\n flexShrink: 0,\n color: '#78716C',\n }}\n >\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n // 下拉框动画样式\n const dropdownAnimationStyles = `\n @keyframes dropdownFadeIn {\n from {\n opacity: 0;\n transform: translateY(-8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n `;\n\n return (\n <>\n <style>{dropdownAnimationStyles}</style>\n <div\n ref={selectRef}\n className={`aha-select ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n width: '100%',\n minWidth: '120px',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px', // rounded-md\n border: `1px solid ${error ? '#F04438' : isOpen ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : '#FFFFFF',\n cursor: disabled ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n paddingLeft: '12px',\n paddingRight: '36px', // 为箭头和清除按钮留出空间(箭头16px + 右边距12px + 清除按钮8px)\n paddingTop: sizeStyles[size].paddingTop,\n paddingBottom: sizeStyles[size].paddingBottom,\n fontSize: sizeStyles[size].fontSize,\n lineHeight: sizeStyles[size].lineHeight,\n fontWeight: 400,\n WebkitTapHighlightColor: 'transparent', // 移动端移除点击高亮\n WebkitTouchCallout: 'none', // 禁用长按菜单\n touchAction: 'manipulation', // 优化触摸响应\n userSelect: 'none', // 禁用文本选择\n ...style,\n }}\n onClick={handleToggle}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onTouchStart={(e) => {\n // 移动端触摸优化\n if (!disabled) {\n e.currentTarget.style.opacity = '0.8';\n }\n }}\n onTouchEnd={(e) => {\n e.currentTarget.style.opacity = '1';\n }}\n tabIndex={disabled ? -1 : 0}\n >\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n flex: 1,\n minWidth: 0,\n gap: '8px',\n }}\n >\n {isMultiple ? (\n (renderTags || (placeholder ? (\n <span\n style={{\n flex: 1,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n color: '#79716B',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n }}\n >\n {placeholder}\n </span>\n ) : (\n <span style={{ flex: 1, minHeight: '24px' }} />\n )))) : showSearch && isOpen ? (\n <input\n ref={inputRef}\n type=\"text\"\n value={searchValue}\n onChange={handleSearch}\n onClick={(e) => e.stopPropagation()}\n onFocus={(e) => e.stopPropagation()}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px', // 至少 16px 避免 iOS Safari 自动缩放\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : '#1C1917',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n placeholder={hasValue ? undefined : placeholder}\n autoComplete=\"off\"\n autoCorrect=\"off\"\n autoCapitalize=\"off\"\n spellCheck={false}\n />\n ) : (\n <span\n style={{\n flex: 1,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n color: hasValue\n ? disabled\n ? '#98A2B3'\n : '#1C1917'\n : '#79716B',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n minHeight: '24px',\n display: 'inline-block',\n }}\n >\n {hasValue\n ? selectedOptions[0]?.label || currentValue\n : placeholder || '\\u00A0'}\n </span>\n )}\n </div>\n\n <div\n style={{\n position: 'absolute',\n right: '12px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n }}\n >\n {showClear && <ClearIcon />}\n <ArrowIcon isOpen={isOpen} />\n </div>\n </div>\n\n {isOpen && dropdownPosition && createPortal(\n <div\n ref={dropdownRef}\n className={`aha-select-dropdown ${dropdownClassName}`}\n style={{\n position: 'absolute',\n top: `${dropdownPosition.top}px`,\n left: `${dropdownPosition.left}px`,\n width: `${dropdownPosition.width}px`,\n zIndex: 1050,\n backgroundColor: '#FFFFFF',\n borderRadius: '8px',\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.15)',\n border: '1px solid #E7E5E4',\n maxHeight: '256px',\n overflow: 'auto',\n opacity: 0,\n transform:\n dropdownPosition.placement === 'top'\n ? 'translateY(8px)'\n : 'translateY(-8px)',\n animation: 'dropdownFadeIn 0.2s ease-out forwards',\n transformOrigin:\n dropdownPosition.placement === 'top'\n ? 'bottom center'\n : 'top center',\n WebkitOverflowScrolling: 'touch', // iOS 平滑滚动\n overscrollBehavior: 'contain', // 防止滚动穿透\n ...dropdownStyle,\n }}\n >\n {filteredOptions.length === 0 ? (\n <div\n style={{\n padding: '8px 16px',\n textAlign: 'center',\n color: '#78716C',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n No data\n </div>\n ) : (\n filteredOptions.map((option, index) => {\n const isSelected = isMultiple\n ? Array.isArray(currentValue) && currentValue.includes(option.value)\n : currentValue === option.value;\n const isFocused = index === focusedIndex;\n\n // 如果提供了自定义渲染函数,使用自定义渲染\n if (optionRender) {\n return (\n <div\n key={option.value}\n className={`aha-select-option ${!option.disabled ? 'hover:bg-[#FAFAF9]' : ''} ${isSelected ? 'bg-[#FAFAF9]' : ''}`}\n onClick={() => !option.disabled && handleSelect(option)}\n style={{\n cursor: option.disabled ? 'not-allowed' : 'pointer',\n transition: 'background-color 0.2s',\n }}\n >\n {optionRender(option, {\n selected: isSelected,\n focused: isFocused,\n disabled: option.disabled || false,\n })}\n </div>\n );\n }\n\n // 默认渲染\n return (\n <div\n key={option.value}\n className={`aha-select-option ${!option.disabled ? 'hover:bg-[#FAFAF9]' : ''} ${isSelected ? 'bg-[#FAFAF9]' : ''}`}\n onClick={() => handleSelect(option)}\n style={{\n padding: '8px 16px',\n cursor: option.disabled ? 'not-allowed' : 'pointer',\n color: option.disabled ? '#98A2B3' : '#101828',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: \"DM Sans, sans-serif\",\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n transition: 'background-color 0.2s',\n }}\n >\n <span>{option.label}</span>\n {/* 只有选中时才显示标识 */}\n {isSelected && (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={isFocused ? 'hidden' : ''}\n >\n <path\n d=\"M13.3333 4L6 11.3333L2.66667 8\"\n stroke={primaryColor}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )}\n </div>\n );\n })\n )}\n </div>,\n document.body\n )}\n </>\n );\n};\n\nSelect.displayName = 'Select';\n\nexport default Select;\n\n","import React from \"react\";\n\n// Checkbox 选中图标\nexport const CheckIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M11.6666 3.5L5.24992 9.91667L2.33325 7\"\n stroke=\"white\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Checkbox 半选中图标(减号)\nexport const MinusIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M3.5 7H10.5\"\n stroke=\"white\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Sort 图标\nexport const SortIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M3.5 7.5L6 10L8.5 7.5M3.5 4.5L6 2L8.5 4.5\"\n stroke=\"#A9A29D\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Sort 图标 降序\nexport const SortDescIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M3.5 4.5L6 2L8.5 4.5\"\n stroke=\"#A9A29D\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M3.5 7.5L6 10L8.5 7.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Sort 图标 升序\nexport const SortAscIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M8.5 7.5L6 10L3.5 7.5\"\n stroke=\"#A9A29D\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M8.5 4.5L6 2L3.5 4.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n// 向左的箭头\nexport const LeftArrowIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M15.8334 10H4.16675M4.16675 10L10.0001 15.8334M4.16675 10L10.0001 4.16669\"\n stroke=\"currentColor\"\n strokeWidth=\"1.66667\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n// 向右的箭头\nexport const RightArrowIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M4.16675 10H15.8334M15.8334 10L10.0001 4.16669M15.8334 10L10.0001 15.8334\"\n stroke=\"currentColor\"\n strokeWidth=\"1.66667\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n// 提示信息图标\nexport const TooltipIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <g clipPath=\"url(#clip0_54_1653)\">\n <path\n d=\"M6.06 6C6.21674 5.55444 6.5261 5.17873 6.9333 4.93942C7.34051 4.7001 7.81926 4.61262 8.28479 4.69247C8.75031 4.77232 9.17255 5.01434 9.47672 5.37568C9.78089 5.73702 9.94737 6.19434 9.94667 6.66666C9.94667 8 7.94667 8.66666 7.94667 8.66666M8 11.3333H8.00667M14.6667 8C14.6667 11.6819 11.6819 14.6667 8 14.6667C4.3181 14.6667 1.33333 11.6819 1.33333 8C1.33333 4.3181 4.3181 1.33333 8 1.33333C11.6819 1.33333 14.6667 4.3181 14.6667 8Z\"\n stroke=\"currentColor\"\n strokeWidth=\"1.33333\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </g>\n <defs>\n <clipPath id=\"clip0_54_1653\">\n <rect width=\"16\" height=\"16\" fill=\"currentColor\" />\n </clipPath>\n </defs>\n </svg>\n);\n","import React, { useState, useEffect, useMemo } from \"react\";\nimport { useTheme } from \"../../theme/ThemeContext\";\nimport Button from \"../Button\";\nimport Input from \"../Input\";\nimport Select from \"../Select\";\nimport { LeftArrowIcon, RightArrowIcon } from \"../../icons\";\n\nexport interface PaginationProps {\n current?: number;\n defaultCurrent?: number;\n total?: number;\n pageSize?: number;\n defaultPageSize?: number;\n showSizeChanger?: boolean;\n pageSizeOptions?: string[];\n showQuickJumper?: boolean | { goButton?: React.ReactNode };\n showTotal?: (total: number, range: [number, number]) => React.ReactNode;\n onChange?: (page: number, pageSize?: number) => void;\n onShowSizeChange?: (current: number, size: number) => void;\n simple?: boolean;\n disabled?: boolean;\n hideOnSinglePage?: boolean;\n className?: string;\n style?: React.CSSProperties;\n size?: \"default\" | \"small\";\n responsive?: boolean;\n showLessItems?: boolean;\n itemRender?: (\n page: number,\n type: \"page\" | \"prev\" | \"next\" | \"jump-prev\" | \"jump-next\",\n originalElement: React.ReactNode\n ) => React.ReactNode;\n}\n\nconst Pagination: React.FC<PaginationProps> = ({\n current: controlledCurrent,\n defaultCurrent = 1,\n total = 0,\n pageSize: controlledPageSize,\n defaultPageSize = 10,\n showSizeChanger = false,\n pageSizeOptions = [\"10\", \"20\", \"50\", \"100\"],\n showQuickJumper = false,\n showTotal,\n onChange,\n onShowSizeChange,\n simple = false,\n disabled = false,\n hideOnSinglePage = false,\n className = \"\",\n style,\n size = \"default\",\n responsive = false,\n showLessItems = false,\n itemRender,\n}) => {\n const { primaryColor = \"#FB6011\" } = useTheme();\n const [internalCurrent, setInternalCurrent] = useState(defaultCurrent);\n const [internalPageSize, setInternalPageSize] = useState(defaultPageSize);\n const [jumpToPage, setJumpToPage] = useState(\"\");\n\n const current = controlledCurrent ?? internalCurrent;\n const pageSize = controlledPageSize ?? internalPageSize;\n\n const totalPages = useMemo(\n () => Math.ceil(total / pageSize),\n [total, pageSize]\n );\n\n useEffect(() => {\n if (controlledCurrent !== undefined) {\n setInternalCurrent(controlledCurrent);\n }\n }, [controlledCurrent]);\n\n useEffect(() => {\n if (controlledPageSize !== undefined) {\n setInternalPageSize(controlledPageSize);\n }\n }, [controlledPageSize]);\n\n const handlePageChange = (page: number) => {\n if (page < 1 || page > totalPages || page === current || disabled) return;\n\n if (controlledCurrent === undefined) {\n setInternalCurrent(page);\n }\n onChange?.(page, pageSize);\n };\n\n const handlePageSizeChange = (newPageSize: number) => {\n const newTotalPages = Math.ceil(total / newPageSize);\n const newCurrent = current > newTotalPages ? newTotalPages : current;\n\n if (controlledPageSize === undefined) {\n setInternalPageSize(newPageSize);\n }\n if (controlledCurrent === undefined) {\n setInternalCurrent(newCurrent);\n }\n\n onShowSizeChange?.(newCurrent, newPageSize);\n onChange?.(newCurrent, newPageSize);\n };\n\n const handleJumpTo = () => {\n const page = parseInt(jumpToPage, 10);\n if (page >= 1 && page <= totalPages) {\n handlePageChange(page);\n setJumpToPage(\"\");\n }\n };\n\n const getPageNumbers = (): (number | string)[] => {\n if (totalPages <= 7) {\n return Array.from({ length: totalPages }, (_, i) => i + 1);\n }\n\n const pages: (number | string)[] = [];\n\n if (current <= 4) {\n for (let i = 1; i <= 5; i++) {\n pages.push(i);\n }\n pages.push(\"jump-next\");\n pages.push(totalPages);\n } else if (current >= totalPages - 3) {\n pages.push(1);\n pages.push(\"jump-prev\");\n for (let i = totalPages - 4; i <= totalPages; i++) {\n pages.push(i);\n }\n } else {\n pages.push(1);\n pages.push(\"jump-prev\");\n for (let i = current - 1; i <= current + 1; i++) {\n pages.push(i);\n }\n pages.push(\"jump-next\");\n pages.push(totalPages);\n }\n\n return pages;\n };\n\n const renderItem = (item: number | string): React.ReactNode => {\n if (typeof item === \"number\") {\n const isActive = item === current;\n const element = (\n <Button\n key={item}\n onClick={() => handlePageChange(item)}\n disabled={disabled}\n type={isActive ? \"primary\" : \"default\"}\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n minWidth: size === \"small\" ? \"32px\" : \"36px\",\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n margin: 0,\n fontWeight: isActive ? 500 : 400,\n border: isActive ? `1px solid ${primaryColor}` : undefined,\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n {item}\n </Button>\n );\n\n return itemRender ? itemRender(item, \"page\", element) : element;\n }\n\n if (item === \"jump-prev\") {\n const element = (\n <Button\n key=\"jump-prev\"\n onClick={() => handlePageChange(Math.max(1, current - 5))}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n minWidth: size === \"small\" ? \"32px\" : \"36px\",\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n margin: 0,\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n •••\n </Button>\n );\n\n return itemRender\n ? itemRender(current - 5, \"jump-prev\", element)\n : element;\n }\n\n if (item === \"jump-next\") {\n const element = (\n <Button\n key=\"jump-next\"\n onClick={() => handlePageChange(Math.min(totalPages, current + 5))}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n minWidth: size === \"small\" ? \"32px\" : \"36px\",\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n margin: 0,\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n •••\n </Button>\n );\n\n return itemRender\n ? itemRender(current + 5, \"jump-next\", element)\n : element;\n }\n\n return null;\n };\n\n if (hideOnSinglePage && totalPages <= 1) {\n return null;\n }\n\n if (simple) {\n return (\n <div\n className={`aha-pagination aha-pagination-simple ${className}`}\n style={style}\n >\n <Button\n onClick={() => handlePageChange(current - 1)}\n disabled={disabled || current === 1}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n marginRight: \"8px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <LeftArrowIcon />\n </Button>\n <span\n style={{\n margin: \"0 8px\",\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {current} / {totalPages}\n </span>\n <Button\n onClick={() => handlePageChange(current + 1)}\n disabled={disabled || current === totalPages}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n marginLeft: \"8px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <RightArrowIcon />\n </Button>\n </div>\n );\n }\n\n const start = (current - 1) * pageSize + 1;\n const end = Math.min(current * pageSize, total);\n\n return (\n <div\n className={`aha-pagination w-full ${className}`}\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"space-between\",\n flexWrap: responsive ? \"wrap\" : \"nowrap\",\n fontFamily: \"DM Sans, sans-serif\",\n ...style,\n }}\n >\n {showTotal && (\n <div className=\"justify-start text-Text-text-secondary text-sm font-medium font-['DM_Sans'] leading-5\">\n {showTotal(total, [start, end])}\n </div>\n )}\n\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n gap: \"12px\",\n }}\n >\n {total > 0 && (\n <>\n {itemRender ? (\n itemRender(\n current - 1,\n \"prev\",\n <Button\n onClick={() => handlePageChange(current - 1)}\n disabled={disabled || current === 1}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <LeftArrowIcon />\n </Button>\n )\n ) : (\n <Button\n onClick={() => handlePageChange(current - 1)}\n disabled={disabled || current === 1}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <LeftArrowIcon />\n </Button>\n )}\n </>\n )}\n\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\n {getPageNumbers().map((item) => renderItem(item))}\n </div>\n\n {total > 0 && (\n <>\n {itemRender ? (\n itemRender(\n current + 1,\n \"next\",\n <Button\n onClick={() => handlePageChange(current + 1)}\n disabled={disabled || current === totalPages}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <RightArrowIcon />\n </Button>\n )\n ) : (\n <Button\n onClick={() => handlePageChange(current + 1)}\n disabled={disabled || current === totalPages}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <RightArrowIcon />\n </Button>\n )}\n </>\n )}\n\n {showSizeChanger && (\n <Select\n value={pageSize}\n options={pageSizeOptions.map((s) => ({\n label: `${s} / page`,\n value: Number(s),\n }))}\n onChange={(val) => handlePageSizeChange(Number(val))}\n disabled={disabled}\n size={size === \"small\" ? \"small\" : \"medium\"}\n style={{ minWidth: size === \"small\" ? 80 : 96 }}\n />\n )}\n\n {showQuickJumper && (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n gap: \"8px\",\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n <span\n style={{\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n }}\n >\n Go to\n </span>\n <Input\n type=\"number\"\n min={1}\n value={jumpToPage}\n onChange={(e) => setJumpToPage(e.target.value)}\n onPressEnter={handleJumpTo}\n disabled={disabled}\n size={size === \"small\" ? \"small\" : \"medium\"}\n style={{ width: 56, minWidth: 56 }}\n />\n <span\n style={{\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n }}\n >\n page\n </span>\n {typeof showQuickJumper === \"object\" && showQuickJumper.goButton ? (\n <Button\n onClick={handleJumpTo}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n {showQuickJumper.goButton}\n </Button>\n ) : (\n <Button\n onClick={handleJumpTo}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n OK\n </Button>\n )}\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport default Pagination;\n","import React from 'react';\nimport { CheckIcon, MinusIcon } from '../../icons';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface CheckboxProps {\n checked?: boolean;\n indeterminate?: boolean;\n disabled?: boolean;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n className?: string;\n style?: React.CSSProperties;\n children?: React.ReactNode;\n}\n\nconst Checkbox: React.FC<CheckboxProps> = ({\n checked = false,\n indeterminate = false,\n disabled = false,\n onChange,\n className = '',\n style,\n children,\n}) => {\n const { primaryColor } = useTheme();\n \n const handleClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (disabled) return;\n // 创建一个合成事件来触发 onChange\n const syntheticEvent = {\n target: { checked: !checked },\n currentTarget: { checked: !checked },\n } as React.ChangeEvent<HTMLInputElement>;\n onChange?.(syntheticEvent);\n };\n\n const isChecked = checked || indeterminate;\n const backgroundColor = disabled\n ? '#FAFAF9'\n : isChecked\n ? primaryColor\n : 'white';\n const borderColor = disabled ? '#FAFAF9' : isChecked ? primaryColor : '#D7D3D0';\n\n return (\n <div\n className={`aha-checkbox ${className}`}\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n gap: '8px',\n cursor: disabled ? 'not-allowed' : 'pointer',\n ...style,\n }}\n onClick={handleClick}\n >\n <div\n style={{\n position: 'relative',\n width: '20px',\n height: '20px',\n minWidth: '20px',\n minHeight: '20px',\n borderRadius: '4px', // spacing-sm 通常是 4px\n border: `1px solid ${borderColor}`,\n backgroundColor,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n transition: 'all 0.2s',\n flexShrink: 0,\n boxSizing: 'border-box',\n }}\n >\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '14px',\n height: '14px',\n opacity: isChecked ? 1 : 0,\n transition: 'opacity 0.2s',\n pointerEvents: 'none',\n }}\n >\n {indeterminate ? (\n <MinusIcon style={{ width: '14px', height: '14px', display: 'block' }} />\n ) : (\n <CheckIcon style={{ width: '14px', height: '14px', display: 'block' }} />\n )}\n </div>\n </div>\n {children && (\n <span\n style={{\n fontSize: '14px',\n lineHeight: '20px',\n color: disabled ? '#98A2B3' : '#101828',\n fontFamily: 'DM Sans, sans-serif',\n }}\n >\n {children}\n </span>\n )}\n <input\n type=\"checkbox\"\n checked={checked}\n ref={(el) => {\n if (el) el.indeterminate = indeterminate;\n }}\n onChange={onChange}\n disabled={disabled}\n style={{\n position: 'absolute',\n opacity: 0,\n width: 0,\n height: 0,\n pointerEvents: 'none',\n }}\n aria-hidden=\"true\"\n />\n </div>\n );\n};\n\nCheckbox.displayName = 'Checkbox';\n\nexport default Checkbox;\n\n","import React, { useState, useMemo, useCallback, useRef, useEffect } from 'react';\nimport Pagination from '../Pagination';\nimport Checkbox from '../Checkbox';\nimport { SortIcon, SortDescIcon, SortAscIcon } from '../../icons';\nimport { useTheme } from '../../theme/ThemeContext';\n\n// ==================== Loading 遮罩 ====================\n\nconst TableLoadingSpinner: React.FC<{ color: string }> = ({ color }) => (\n <>\n <style>{`\n @keyframes aha-table-loading-spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n `}</style>\n <svg\n width={32}\n height={32}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n aria-hidden\n style={{ animation: 'aha-table-loading-spin 1s linear infinite' }}\n >\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke={color}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"24\"\n opacity={0.3}\n />\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke={color}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"16\"\n />\n </svg>\n </>\n);\n\nconst TableLoadingOverlay: React.FC<{\n loading: boolean | React.ReactNode;\n spinColor: string;\n}> = ({ loading, spinColor }) => {\n if (!loading) return null;\n const content = loading === true ? <TableLoadingSpinner color={spinColor} /> : loading;\n return (\n <div\n role=\"status\"\n aria-live=\"polite\"\n aria-label=\"Loading\"\n className=\"aha-table-loading-overlay\"\n style={{\n position: 'absolute',\n inset: 0,\n zIndex: 50,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: 'rgba(255, 255, 255, 0.55)',\n pointerEvents: 'auto',\n }}\n >\n {content}\n </div>\n );\n};\n\n// ==================== 类型定义 ====================\n\nexport type SortOrder = 'ascend' | 'descend' | null;\nexport type TableSize = 'small' | 'middle' | 'large';\nexport type TableLayout = 'auto' | 'fixed';\n\nexport interface SorterResult<T = any> {\n column?: ColumnType<T>;\n order?: SortOrder;\n field?: string | string[];\n columnKey?: string | string[];\n}\n\nexport interface TableCurrentDataSource<T = any> {\n currentDataSource: T[];\n action: 'paginate' | 'sort';\n}\n\nexport interface SelectionItem {\n key: string | number;\n text: React.ReactNode;\n onSelect?: (changeableRowKeys: (string | number)[]) => void;\n}\n\nexport interface TableRowSelection<T = any> {\n type?: 'checkbox' | 'radio';\n selectedRowKeys?: (string | number)[];\n defaultSelectedRowKeys?: (string | number)[];\n onChange?: (selectedRowKeys: (string | number)[], selectedRows: T[]) => void;\n onSelect?: (record: T, selected: boolean, selectedRows: T[], nativeEvent: Event) => void;\n onSelectAll?: (selected: boolean, selectedRows: T[], changeRows: T[]) => void;\n onSelectInvert?: (selectedRowKeys: (string | number)[]) => void;\n onSelectNone?: () => void;\n getCheckboxProps?: (record: T) => {\n disabled?: boolean;\n name?: string;\n };\n hideSelectAll?: boolean;\n fixed?: boolean | 'left' | 'right';\n columnWidth?: string | number;\n columnTitle?: string | React.ReactNode;\n checkStrictly?: boolean;\n preserveSelectedRowKeys?: boolean;\n renderCell?: (checked: boolean, record: T, index: number, node: React.ReactNode) => React.ReactNode;\n}\n\nexport interface ColumnType<T = any> {\n title?: React.ReactNode | ((props: { sortOrder?: SortOrder; sortColumn?: ColumnType<T> }) => React.ReactNode);\n key?: string;\n dataIndex?: string | string[];\n align?: 'left' | 'right' | 'center';\n ellipsis?: boolean | { showTitle?: boolean };\n colSpan?: number;\n width?: string | number;\n minWidth?: string | number;\n fixed?: boolean | 'left' | 'right';\n render?: (value: any, record: T, index: number) => React.ReactNode;\n sorter?: boolean | ((a: T, b: T) => number) | { compare?: (a: T, b: T) => number; multiple?: number };\n sortOrder?: SortOrder | SortOrder[];\n defaultSortOrder?: SortOrder;\n onCell?: (record: T, index?: number) => React.HTMLAttributes<HTMLTableCellElement>;\n onHeaderCell?: (column: ColumnType<T>) => React.HTMLAttributes<HTMLTableCellElement>;\n className?: string;\n children?: ColumnType<T>[];\n onSorterChange?: (sorter: SorterResult<T>) => void;\n rowSpan?: number;\n rowScope?: 'row' | 'col' | 'rowgroup' | 'colgroup';\n}\n\nexport interface TableProps<T = any> {\n columns?: ColumnType<T>[];\n dataSource?: T[];\n rowKey?: string | ((record: T) => string | number);\n rowSelection?: TableRowSelection<T>;\n pagination?: false | {\n current?: number;\n pageSize?: number;\n total?: number;\n defaultCurrent?: number;\n defaultPageSize?: number;\n showSizeChanger?: boolean;\n pageSizeOptions?: string[];\n showQuickJumper?: boolean | { goButton?: React.ReactNode };\n showTotal?: (total: number, range: [number, number]) => React.ReactNode;\n onChange?: (page: number, pageSize?: number) => void;\n onShowSizeChange?: (current: number, size: number) => void;\n position?: 'topLeft' | 'topCenter' | 'topRight' | 'bottomLeft' | 'bottomCenter' | 'bottomRight';\n simple?: boolean;\n responsive?: boolean;\n };\n size?: TableSize;\n bordered?: boolean;\n loading?: boolean | React.ReactNode;\n locale?: {\n emptyText?: React.ReactNode | (() => React.ReactNode);\n selectAll?: React.ReactNode;\n selectInvert?: React.ReactNode;\n selectNone?: React.ReactNode;\n selectionAll?: React.ReactNode;\n sortTitle?: string;\n expand?: string;\n collapse?: string;\n triggerDesc?: string;\n triggerAsc?: string;\n cancelSort?: string;\n };\n showHeader?: boolean;\n title?: (currentData: T[]) => React.ReactNode;\n footer?: (currentData: T[]) => React.ReactNode;\n summary?: (currentData: T[]) => React.ReactNode;\n scroll?: {\n x?: number | string | true;\n y?: number | string;\n scrollToFirstRowOnChange?: boolean;\n };\n tableLayout?: TableLayout;\n onChange?: (pagination: any, filters: Record<string, any>, sorter: SorterResult<T> | SorterResult<T>[], extra: TableCurrentDataSource<T>) => void;\n onSorterChange?: (sorter: SorterResult<T> | SorterResult<T>[]) => void;\n onPaginationChange?: (page: number, pageSize: number) => void;\n onRow?: (record: T, index?: number) => React.HTMLAttributes<HTMLTableRowElement>;\n getPopupContainer?: (triggerNode: HTMLElement) => HTMLElement;\n className?: string;\n innerClassName?: string;\n style?: React.CSSProperties;\n children?: React.ReactNode;\n expandable?: {\n expandedRowKeys?: (string | number)[];\n defaultExpandedRowKeys?: (string | number)[];\n expandedRowRender?: (record: T, index: number, indent: number, expanded: boolean) => React.ReactNode;\n expandRowByClick?: boolean;\n onExpand?: (expanded: boolean, record: T) => void;\n onExpandedRowsChange?: (expandedKeys: (string | number)[]) => void;\n defaultExpandAllRows?: boolean;\n indentSize?: number;\n expandIcon?: (props: { expanded: boolean; onExpand: (record: T, e: React.MouseEvent<HTMLElement>) => void; record: T }) => React.ReactNode;\n rowExpandable?: (record: T) => boolean;\n };\n indentSize?: number;\n rowClassName?: string | ((record: T, index: number) => string);\n onHeaderRow?: (columns: ColumnType<T>[], index?: number) => React.HTMLAttributes<HTMLTableRowElement>;\n components?: {\n header?: {\n cell?: React.ComponentType<any>;\n row?: React.ComponentType<any>;\n wrapper?: React.ComponentType<any>;\n };\n body?: {\n cell?: React.ComponentType<any>;\n row?: React.ComponentType<any>;\n wrapper?: React.ComponentType<any>;\n };\n };\n sticky?: boolean | { offsetHeader?: number; offsetScroll?: number; getContainer?: () => HTMLElement };\n}\n\n// ==================== 工具函数 ====================\n\nconst getValue = (obj: any, path: string | string[]): any => {\n if (typeof path === 'string') {\n return obj?.[path];\n }\n return path.reduce((acc, key) => acc?.[key], obj);\n};\n\nconst getRowKey = <T,>(record: T, rowKey?: string | ((record: T) => string | number)): string | number => {\n if (typeof rowKey === 'function') {\n return rowKey(record);\n }\n if (typeof rowKey === 'string') {\n return getValue(record, rowKey) ?? '';\n }\n return (record as any).key ?? '';\n};\n\n// ==================== 默认图标 ====================\n\nconst SortIconComponent: React.FC<{ order?: SortOrder }> = ({ order }) => {\n const { primaryColor } = useTheme();\n \n if (order === 'ascend') {\n return (\n <SortAscIcon style={{ color: primaryColor }}/>\n );\n }\n if (order === 'descend') {\n return (\n <SortDescIcon style={{ color: primaryColor }}/>\n );\n }\n return (\n <SortIcon/>\n );\n};\n\n\n\n// ==================== Table 组件 ====================\n\nconst Table = <T extends Record<string, any> = any>({\n columns = [],\n dataSource = [],\n rowKey = 'key',\n rowSelection,\n pagination = false,\n size = 'middle',\n bordered = false,\n loading = false,\n locale,\n showHeader = true,\n title,\n footer,\n summary,\n scroll,\n tableLayout = 'auto',\n onChange,\n onSorterChange,\n onPaginationChange,\n onRow,\n className = '',\n innerClassName = '',\n style,\n expandable,\n rowClassName,\n onHeaderRow,\n sticky,\n ...rest\n}: TableProps<T>) => {\n const { primaryColor } = useTheme();\n const loadingSpinColor = primaryColor || '#FB6011';\n\n // ==================== State ====================\n const [selectedRowKeys, setSelectedRowKeys] = useState<(string | number)[]>(\n rowSelection?.selectedRowKeys || rowSelection?.defaultSelectedRowKeys || []\n );\n\n // 同步外部传入的 selectedRowKeys\n useEffect(() => {\n if (rowSelection?.selectedRowKeys !== undefined) {\n setSelectedRowKeys(rowSelection.selectedRowKeys);\n }\n }, [rowSelection?.selectedRowKeys]);\n const [sorters, setSorters] = useState<Map<string, SortOrder>>(new Map());\n const [expandedRowKeys, setExpandedRowKeys] = useState<(string | number)[]>(\n expandable?.defaultExpandedRowKeys || []\n );\n const [currentPage, setCurrentPage] = useState(\n pagination && typeof pagination === 'object' \n ? (pagination.current || pagination.defaultCurrent || 1) \n : 1\n );\n const [pageSize, setPageSize] = useState(\n pagination && typeof pagination === 'object' \n ? (pagination.pageSize || pagination.defaultPageSize || 10) \n : 10\n );\n\n // 同步外部传入的 pagination\n useEffect(() => {\n if (pagination && typeof pagination === 'object') {\n if (pagination.current !== undefined) {\n setCurrentPage(pagination.current);\n }\n if (pagination.pageSize !== undefined) {\n setPageSize(pagination.pageSize);\n }\n }\n }, [pagination]);\n const [draggedRowIndex, setDraggedRowIndex] = useState<number | null>(null);\n const [dragOverRowIndex, setDragOverRowIndex] = useState<number | null>(null);\n const [isMobile, setIsMobile] = useState(false);\n const tableRef = useRef<HTMLDivElement>(null);\n const headerRef = useRef<HTMLTableSectionElement>(null);\n\n // 检测移动端\n useEffect(() => {\n const checkMobile = () => {\n setIsMobile(window.innerWidth < 768);\n };\n checkMobile();\n window.addEventListener('resize', checkMobile);\n return () => window.removeEventListener('resize', checkMobile);\n }, []);\n\n // ==================== 处理行选择 ====================\n const handleSelect = useCallback((record: T, selected: boolean) => {\n // 检查是否禁用\n const checkboxProps = rowSelection?.getCheckboxProps?.(record);\n if (checkboxProps?.disabled) {\n return;\n }\n\n const key = getRowKey(record, rowKey);\n let newSelectedRowKeys: (string | number)[];\n \n if (rowSelection?.type === 'radio') {\n newSelectedRowKeys = selected ? [key] : [];\n } else {\n if (selected) {\n newSelectedRowKeys = [...selectedRowKeys, key];\n } else {\n newSelectedRowKeys = selectedRowKeys.filter(k => k !== key);\n }\n }\n\n setSelectedRowKeys(newSelectedRowKeys);\n \n const selectedRows = dataSource.filter(d => newSelectedRowKeys.includes(getRowKey(d, rowKey)));\n \n rowSelection?.onChange?.(newSelectedRowKeys, selectedRows);\n rowSelection?.onSelect?.(record, selected, selectedRows, new Event('select'));\n }, [selectedRowKeys, rowKey, rowSelection, dataSource]);\n\n const handleSelectAll = useCallback((selected: boolean, currentPageData: T[]) => {\n // 只选择未禁用的行\n const keys = currentPageData\n .filter(d => !rowSelection?.getCheckboxProps?.(d).disabled)\n .map(d => getRowKey(d, rowKey));\n const newSelectedRowKeys = selected ? keys : [];\n \n setSelectedRowKeys(newSelectedRowKeys);\n \n const selectedRows = dataSource.filter(d => newSelectedRowKeys.includes(getRowKey(d, rowKey)));\n const changeRows = selected ? currentPageData.filter(d => !rowSelection?.getCheckboxProps?.(d).disabled) : [];\n \n rowSelection?.onChange?.(newSelectedRowKeys, selectedRows);\n rowSelection?.onSelectAll?.(selected, selectedRows, changeRows);\n }, [rowKey, rowSelection, dataSource]);\n\n // ==================== 处理排序 ====================\n const handleSort = useCallback((column: ColumnType<T>, order: SortOrder) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex);\n if (!columnKey) return;\n\n const newSorters = new Map(sorters);\n \n if (order === null) {\n newSorters.delete(columnKey as string);\n } else {\n newSorters.set(columnKey as string, order);\n }\n\n setSorters(newSorters);\n \n // 构建排序结果数组\n const sorterArray: SorterResult<T>[] = Array.from(newSorters.entries()).map(([key, order]) => {\n const col = columns.find(c => {\n const cKey = c.key || (Array.isArray(c.dataIndex) ? c.dataIndex.join('.') : c.dataIndex);\n return cKey === key;\n });\n return {\n column: col || column,\n order: order!,\n field: key,\n columnKey: key,\n };\n });\n \n // 当前列的排序结果\n const currentSorter: SorterResult<T> = {\n column,\n order: order!,\n field: columnKey as string,\n columnKey: columnKey as string,\n };\n \n // 调用列的 onSorterChange 回调(单个列的排序变化)\n if (column.onSorterChange) {\n column.onSorterChange(currentSorter);\n }\n \n // 调用 Table 的 onSorterChange 回调(所有列的排序变化)\n if (onSorterChange) {\n onSorterChange(sorterArray.length === 1 ? sorterArray[0] : sorterArray);\n }\n \n // 触发 onChange(综合回调,包含分页、筛选、排序)\n if (onChange) {\n onChange(\n { current: currentPage, pageSize },\n {},\n sorterArray.length === 1 ? sorterArray[0] : sorterArray,\n { currentDataSource: dataSource, action: 'sort' }\n );\n }\n }, [sorters, onChange, onSorterChange, currentPage, pageSize, dataSource, columns]);\n\n // ==================== 处理展开 ====================\n const handleExpand = useCallback((record: T, expanded: boolean) => {\n const key = getRowKey(record, rowKey);\n let newExpandedRowKeys: (string | number)[];\n \n if (expanded) {\n newExpandedRowKeys = [...expandedRowKeys, key];\n } else {\n newExpandedRowKeys = expandedRowKeys.filter(k => k !== key);\n }\n \n setExpandedRowKeys(newExpandedRowKeys);\n expandable?.onExpand?.(expanded, record);\n expandable?.onExpandedRowsChange?.(newExpandedRowKeys);\n }, [expandedRowKeys, rowKey, expandable]);\n\n // ==================== 数据处理 ====================\n const getProcessedData = useCallback((): T[] => {\n let processed = [...dataSource];\n\n // 排序\n if (sorters.size > 0) {\n processed.sort((a, b) => {\n const sorterEntries = Array.from(sorters.entries());\n for (const [columnKey, order] of sorterEntries) {\n const column = columns.find(col => {\n const colKey = col.key || (Array.isArray(col.dataIndex) ? col.dataIndex.join('.') : col.dataIndex);\n return colKey === columnKey;\n });\n \n if (!column) continue;\n \n let compareResult = 0;\n \n if (typeof column.sorter === 'function') {\n compareResult = column.sorter(a, b);\n } else if (column.sorter === true) {\n const aVal = getValue(a, column.dataIndex || columnKey);\n const bVal = getValue(b, column.dataIndex || columnKey);\n if (aVal < bVal) compareResult = -1;\n else if (aVal > bVal) compareResult = 1;\n }\n \n if (compareResult !== 0) {\n return order === 'ascend' ? compareResult : -compareResult;\n }\n }\n return 0;\n });\n }\n\n return processed;\n }, [dataSource, sorters, columns]);\n\n const processedData = getProcessedData();\n\n // ==================== 分页处理 ====================\n // 当传入 pagination.total 时视为服务端分页:dataSource 已是当前页数据,不再做客户端 slice\n const isServerPagination = Boolean(pagination && typeof pagination === 'object' && pagination.total !== undefined);\n const paginatedData = useMemo(() => {\n if (pagination === false || !pagination) return processedData;\n if (isServerPagination) return processedData;\n const start = (currentPage - 1) * pageSize;\n const end = start + pageSize;\n return processedData.slice(start, end);\n }, [processedData, currentPage, pageSize, pagination, isServerPagination]);\n\n const handlePageChange = useCallback((page: number, size?: number) => {\n const newPageSize = size ?? pageSize;\n setCurrentPage(page);\n if (size) setPageSize(size);\n \n // 调用 Table 的 onPaginationChange 回调(专门用于分页变化)\n if (onPaginationChange) {\n onPaginationChange(page, newPageSize);\n }\n \n // 调用 pagination 内部的回调(保持向后兼容)\n if (pagination && typeof pagination === 'object') {\n pagination.onChange?.(page, size);\n if (size) pagination.onShowSizeChange?.(page, size);\n }\n \n // 触发 Table 的 onChange(综合回调,包含分页、筛选、排序)\n if (onChange) {\n const sorterArray: SorterResult<T>[] = Array.from(sorters.entries()).map(([key, order]) => {\n const col = columns.find(c => {\n const cKey = c.key || (Array.isArray(c.dataIndex) ? c.dataIndex.join('.') : c.dataIndex);\n return cKey === key;\n });\n return {\n column: col,\n order: order!,\n field: key,\n columnKey: key,\n };\n });\n \n onChange(\n { current: page, pageSize: newPageSize },\n {},\n sorterArray.length === 1 ? sorterArray[0] : sorterArray,\n { currentDataSource: processedData, action: 'paginate' }\n );\n }\n }, [pagination, onPaginationChange, onChange, pageSize, sorters, columns, processedData]);\n\n // ==================== 渲染单元格 ====================\n const renderCell = useCallback((column: ColumnType<T>, record: T, index: number): React.ReactNode => {\n const value = getValue(record, column.dataIndex || '');\n \n if (column.render) {\n return column.render(value, record, index);\n }\n \n return value;\n }, []);\n\n // ==================== 计算固定列的偏移量 ====================\n const getFixedOffset = useCallback((columnIndex: number, fixed: 'left' | 'right' | boolean | undefined, isHeader: boolean = false) => {\n if (!fixed) return undefined;\n \n const fixedDirection = fixed === true ? 'left' : fixed;\n let offset = 0;\n \n if (fixedDirection === 'left') {\n // 计算左侧固定列的偏移量\n // 如果有行选择且固定在左侧,先加上选择列的宽度\n if (rowSelection && (rowSelection.fixed === 'left' || rowSelection.fixed === true)) {\n const selectWidth = typeof rowSelection.columnWidth === 'number' \n ? rowSelection.columnWidth \n : (typeof rowSelection.columnWidth === 'string' ? parseInt(rowSelection.columnWidth) : 60);\n offset += selectWidth;\n }\n // 然后加上前面所有左侧固定列的宽度\n for (let i = 0; i < columnIndex; i++) {\n const col = columns[i];\n if (col.fixed === 'left' || col.fixed === true) {\n const colWidth = col.width \n ? (typeof col.width === 'number' ? col.width : parseInt(col.width as string) || 0)\n : 150; // 默认宽度\n offset += colWidth;\n }\n }\n return offset;\n } else if (fixedDirection === 'right') {\n // 计算右侧固定列的偏移量\n for (let i = columnIndex + 1; i < columns.length; i++) {\n const col = columns[i];\n if (col.fixed === 'right') {\n const colWidth = col.width \n ? (typeof col.width === 'number' ? col.width : parseInt(col.width as string) || 0)\n : 150; // 默认宽度\n offset += colWidth;\n }\n }\n // 如果有行选择且固定在右侧,需要加上选择列的宽度\n if (rowSelection && rowSelection.fixed === 'right') {\n const selectWidth = typeof rowSelection.columnWidth === 'number' \n ? rowSelection.columnWidth \n : (typeof rowSelection.columnWidth === 'string' ? parseInt(rowSelection.columnWidth) : 60);\n offset += selectWidth;\n }\n return offset;\n }\n \n return undefined;\n }, [columns, rowSelection]);\n\n // ==================== 渲染表头 ====================\n const renderHeader = useCallback(() => {\n if (!showHeader) return null;\n\n const headerColumns = columns.map((column, colIndex) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex) || colIndex;\n const sortOrder = sorters.get(columnKey as string) || null;\n const fixedOffset = getFixedOffset(colIndex, column.fixed, true);\n const columnWidth = column.width \n ? (typeof column.width === 'number' ? `${column.width}px` : column.width)\n : undefined;\n\n return (\n <th\n key={columnKey}\n className={`${column.className || ''} ${column.align ? `text-${column.align}` : ''}`}\n style={{\n width: columnWidth,\n minWidth: column.minWidth ? (typeof column.minWidth === 'number' ? `${column.minWidth}px` : column.minWidth) : (columnWidth || undefined),\n maxWidth: columnWidth,\n position: column.fixed ? 'sticky' : 'relative',\n left: column.fixed === 'left' || column.fixed === true ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n right: column.fixed === 'right' ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n zIndex: column.fixed ? (column.fixed === 'left' || column.fixed === true ? 10 : 9) : 1,\n backgroundColor: column.fixed ? '#F9FAFB' : '#F9FAFB',\n boxShadow: column.fixed === 'left' || column.fixed === true \n ? '2px 0 4px rgba(0, 0, 0, 0.05)' \n : column.fixed === 'right' \n ? '-2px 0 4px rgba(0, 0, 0, 0.05)' \n : undefined,\n padding: '12px 16px',\n textAlign: column.align || 'left',\n borderBottom: '1px solid #EAECF0',\n fontWeight: 600,\n fontSize: '12px',\n lineHeight: '18px',\n color: '#475467',\n fontFamily: 'DM Sans, sans-serif',\n }}\n {...(column.onHeaderCell?.(column) || {})}\n >\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n justifyContent: column.align === 'right' ? 'flex-end' : column.align === 'center' ? 'center' : 'flex-start',\n }}\n >\n <span style={{ fontWeight: 600, fontSize: '12px', lineHeight: '18px', color: '#475467' }}>\n {typeof column.title === 'function' ? column.title({ sortOrder, sortColumn: column }) : column.title}\n </span>\n {column.sorter && (\n <button\n onClick={() => {\n const nextOrder = sortOrder === null ? 'ascend' : sortOrder === 'ascend' ? 'descend' : null;\n handleSort(column, nextOrder);\n }}\n style={{\n border: 'none',\n background: 'none',\n cursor: 'pointer',\n display: 'flex',\n alignItems: 'center',\n padding: '2px',\n color: sortOrder ? '#475467' : '#98A2B3',\n }}\n >\n <SortIconComponent order={sortOrder || undefined} />\n </button>\n )}\n </div>\n </th>\n );\n });\n\n // 如果有行选择,添加选择列\n if (rowSelection) {\n const selectWidth = typeof rowSelection.columnWidth === 'number' \n ? `${rowSelection.columnWidth}px` \n : (typeof rowSelection.columnWidth === 'string' ? rowSelection.columnWidth : '60px');\n const selectColumn = (\n <th\n key=\"selection\"\n style={{\n width: selectWidth,\n position: rowSelection.fixed ? 'sticky' : 'relative',\n left: rowSelection.fixed === 'left' || rowSelection.fixed === true ? '0px' : undefined,\n right: rowSelection.fixed === 'right' ? '0px' : undefined,\n zIndex: rowSelection.fixed ? (rowSelection.fixed === 'left' || rowSelection.fixed === true ? 12 : 11) : 1,\n backgroundColor: '#F9FAFB',\n padding: '12px 16px',\n borderBottom: '1px solid #EAECF0',\n fontWeight: 600,\n fontSize: '12px',\n lineHeight: '18px',\n color: '#475467',\n fontFamily: 'DM Sans, sans-serif',\n textAlign: 'center',\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n {!rowSelection.hideSelectAll && rowSelection.type !== 'radio' && (() => {\n const enabledRows = paginatedData.filter(d => !rowSelection.getCheckboxProps?.(d).disabled);\n const enabledKeys = enabledRows.map(d => getRowKey(d, rowKey));\n const allSelected = enabledRows.length > 0 && enabledKeys.every(key => selectedRowKeys.includes(key));\n const someSelected = enabledKeys.some(key => selectedRowKeys.includes(key));\n \n return (\n <Checkbox\n checked={allSelected}\n indeterminate={someSelected && !allSelected}\n onChange={(e) => handleSelectAll(e.target.checked, paginatedData)}\n />\n );\n })()}\n {rowSelection.columnTitle && <span style={{ marginLeft: rowSelection.hideSelectAll ? 0 : '8px' }}>{rowSelection.columnTitle}</span>}\n </div>\n </th>\n );\n headerColumns.unshift(selectColumn);\n }\n\n const headerRowProps = onHeaderRow?.(columns, 0);\n \n return (\n <thead ref={headerRef}>\n <tr {...(headerRowProps || {})}>{headerColumns}</tr>\n </thead>\n );\n }, [columns, showHeader, sorters, rowSelection, selectedRowKeys, paginatedData, rowKey, handleSort, handleSelectAll, locale, onHeaderRow, getFixedOffset]);\n\n // ==================== 拖拽排序处理 ====================\n const handleDragStart = useCallback((index: number) => {\n setDraggedRowIndex(index);\n }, []);\n\n const handleDragOver = useCallback((e: React.DragEvent, index: number) => {\n e.preventDefault();\n setDragOverRowIndex(index);\n }, []);\n\n const handleDrop = useCallback((e: React.DragEvent, dropIndex: number) => {\n e.preventDefault();\n if (draggedRowIndex === null || draggedRowIndex === dropIndex) {\n setDraggedRowIndex(null);\n setDragOverRowIndex(null);\n return;\n }\n\n const newData = [...paginatedData];\n const draggedItem = newData[draggedRowIndex];\n newData.splice(draggedRowIndex, 1);\n newData.splice(dropIndex, 0, draggedItem);\n\n // 这里可以触发 onChange 回调,让外部处理数据更新\n setDraggedRowIndex(null);\n setDragOverRowIndex(null);\n }, [draggedRowIndex, paginatedData]);\n\n const handleDragEnd = useCallback(() => {\n setDraggedRowIndex(null);\n setDragOverRowIndex(null);\n }, []);\n\n // ==================== 渲染空状态 ====================\n const renderEmpty = useCallback(() => {\n const emptyText = locale?.emptyText;\n const content =\n typeof emptyText === 'function'\n ? emptyText()\n : emptyText !== undefined\n ? emptyText\n : 'No data';\n const colSpan = columns.length + (rowSelection ? 1 : 0);\n return (\n <tr className=\"aha-table-placeholder\">\n <td colSpan={colSpan} style={{\n padding: '48px 16px',\n textAlign: 'center',\n color: '#98A2B3',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: 'DM Sans, sans-serif',\n borderBottom: 'none',\n backgroundColor: 'white',\n }}>\n {content}\n </td>\n </tr>\n );\n }, [locale?.emptyText, columns.length, rowSelection]);\n\n // ==================== 渲染表格行 ====================\n const renderRows = useCallback(() => {\n if (paginatedData.length === 0) {\n return renderEmpty();\n }\n return paginatedData.map((record, index) => {\n const key = getRowKey(record, rowKey);\n const isSelected = selectedRowKeys.includes(key);\n const isExpanded = expandedRowKeys.includes(key);\n const rowProps = onRow?.(record, index) || {};\n const isLastRow = index === paginatedData.length - 1;\n\n return (\n <React.Fragment key={key}>\n <tr\n className={`${typeof rowClassName === 'function' ? rowClassName(record, index) : rowClassName || ''} ${draggedRowIndex === index ? 'dragging' : ''} ${dragOverRowIndex === index ? 'drag-over' : ''}`}\n draggable={true}\n onDragStart={() => handleDragStart(index)}\n onDragOver={(e) => handleDragOver(e, index)}\n onDrop={(e) => handleDrop(e, index)}\n onDragEnd={handleDragEnd}\n style={{\n cursor: 'move',\n opacity: draggedRowIndex === index ? 0.5 : 1,\n backgroundColor: dragOverRowIndex === index ? '#F9FAFB' : 'white',\n transition: 'background-color 0.2s',\n ...rowProps.style,\n }}\n onMouseEnter={(e) => {\n if (draggedRowIndex !== index && dragOverRowIndex !== index) {\n e.currentTarget.style.backgroundColor = '#F9FAFB';\n }\n }}\n onMouseLeave={(e) => {\n if (draggedRowIndex !== index && dragOverRowIndex !== index) {\n e.currentTarget.style.backgroundColor = 'white';\n }\n }}\n {...rowProps}\n >\n {rowSelection && (\n <td\n style={{\n width: typeof rowSelection.columnWidth === 'number' \n ? `${rowSelection.columnWidth}px` \n : (typeof rowSelection.columnWidth === 'string' ? rowSelection.columnWidth : '60px'),\n position: rowSelection.fixed ? 'sticky' : 'relative',\n left: rowSelection.fixed === 'left' || rowSelection.fixed === true ? '0px' : undefined,\n right: rowSelection.fixed === 'right' ? '0px' : undefined,\n zIndex: rowSelection.fixed ? (rowSelection.fixed === 'left' || rowSelection.fixed === true ? 12 : 11) : 1,\n backgroundColor: 'white',\n padding: '16px',\n borderBottom: isLastRow ? 'none' : '1px solid #EAECF0',\n textAlign: 'center',\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n <Checkbox\n checked={isSelected}\n onChange={(e) => handleSelect(record, e.target.checked)}\n disabled={rowSelection.getCheckboxProps?.(record).disabled}\n />\n </div>\n </td>\n )}\n {columns.map((column, colIndex) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex) || colIndex;\n const cellProps = column.onCell?.(record, index) || {};\n const fixedOffset = getFixedOffset(colIndex, column.fixed, false);\n const columnWidth = column.width \n ? (typeof column.width === 'number' ? `${column.width}px` : column.width)\n : undefined;\n \n return (\n <td\n key={columnKey}\n className={`${column.className || ''} ${column.align ? `text-${column.align}` : ''}`}\n style={{\n width: columnWidth,\n minWidth: column.minWidth ? (typeof column.minWidth === 'number' ? `${column.minWidth}px` : column.minWidth) : (columnWidth || undefined),\n maxWidth: columnWidth,\n position: column.fixed ? 'sticky' : 'relative',\n left: column.fixed === 'left' || column.fixed === true ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n right: column.fixed === 'right' ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n zIndex: column.fixed ? (column.fixed === 'left' || column.fixed === true ? 10 : 9) : 1,\n backgroundColor: 'white',\n boxShadow: column.fixed === 'left' || column.fixed === true \n ? '2px 0 4px rgba(0, 0, 0, 0.05)' \n : column.fixed === 'right' \n ? '-2px 0 4px rgba(0, 0, 0, 0.05)' \n : undefined,\n padding: '16px',\n borderBottom: isLastRow ? 'none' : '1px solid #EAECF0',\n fontSize: '14px',\n lineHeight: '20px',\n color: '#101828',\n fontFamily: 'DM Sans, sans-serif',\n textAlign: column.align || 'left',\n ...cellProps.style,\n }}\n colSpan={column.colSpan}\n rowSpan={column.rowSpan}\n {...cellProps}\n >\n {renderCell(column, record, index)}\n </td>\n );\n })}\n </tr>\n {expandable?.expandedRowRender && isExpanded && (\n <tr>\n <td colSpan={columns.length + (rowSelection ? 1 : 0)}>\n {expandable.expandedRowRender(record, index, 0, true)}\n </td>\n </tr>\n )}\n </React.Fragment>\n );\n });\n }, [paginatedData, rowKey, selectedRowKeys, expandedRowKeys, rowSelection, columns, onRow, rowClassName, handleSelect, renderCell, expandable, draggedRowIndex, dragOverRowIndex, handleDragStart, handleDragOver, handleDrop, handleDragEnd, getFixedOffset, renderEmpty]);\n\n // ==================== 渲染分页 ====================\n const renderPagination = () => {\n if (pagination === false || !pagination) return null;\n \n const total = pagination.total ?? processedData.length;\n const position = pagination.position || 'bottomRight';\n \n return (\n <div\n style={{\n marginTop: '16px',\n display: 'flex',\n justifyContent: position.includes('Right') ? 'flex-end' : position.includes('Left') ? 'flex-start' : 'center',\n }}\n >\n <Pagination\n current={currentPage}\n total={total}\n pageSize={pageSize}\n showSizeChanger={pagination.showSizeChanger}\n pageSizeOptions={pagination.pageSizeOptions}\n showQuickJumper={pagination.showQuickJumper}\n showTotal={pagination.showTotal}\n onChange={handlePageChange}\n onShowSizeChange={handlePageChange}\n simple={pagination.simple}\n responsive={pagination.responsive}\n size={size === 'small' ? 'small' : 'default'}\n />\n </div>\n );\n };\n\n // ==================== 移动端渲染 ====================\n const renderMobileView = () => {\n const emptyContent =\n typeof locale?.emptyText === 'function'\n ? locale.emptyText()\n : locale?.emptyText !== undefined\n ? locale.emptyText\n : 'No data';\n if (paginatedData.length === 0) {\n return (\n <div className=\"aha-table-mobile aha-table-placeholder\" style={{\n padding: '48px 16px',\n textAlign: 'center',\n color: '#98A2B3',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: 'DM Sans, sans-serif',\n }}>\n {emptyContent}\n </div>\n );\n }\n return (\n <div className=\"aha-table-mobile\">\n {paginatedData.map((record, index) => {\n const key = getRowKey(record, rowKey);\n const isSelected = selectedRowKeys.includes(key);\n \n return (\n <div\n key={key}\n className={`aha-table-mobile-row ${isSelected ? 'selected' : ''}`}\n style={{\n border: '1px solid #e8e8e8',\n borderRadius: '4px',\n padding: '12px',\n marginBottom: '12px',\n backgroundColor: isSelected ? '#e6f7ff' : 'white',\n }}\n >\n {rowSelection && (\n <div style={{ marginBottom: '8px' }}>\n <Checkbox\n checked={isSelected}\n onChange={(e) => handleSelect(record, e.target.checked)}\n disabled={rowSelection.getCheckboxProps?.(record).disabled}\n />\n </div>\n )}\n {columns.map((column) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex);\n const value = getValue(record, column.dataIndex || '');\n const displayValue = column.render ? column.render(value, record, index) : value;\n \n return (\n <div\n key={columnKey}\n style={{\n display: 'flex',\n justifyContent: 'space-between',\n marginBottom: '8px',\n paddingBottom: '8px',\n borderBottom: '1px solid #f0f0f0',\n }}\n >\n <span style={{ fontWeight: 'bold', color: '#666' }}>\n {typeof column.title === 'function' ? column.title({}) : column.title}:\n </span>\n <span style={{ flex: 1, textAlign: 'right' }}>{displayValue}</span>\n </div>\n );\n })}\n </div>\n );\n })}\n </div>\n );\n };\n\n // ==================== 主渲染 ====================\n // 检查是否有固定列\n const hasFixedColumns = useMemo(() => {\n return columns.some(col => col.fixed) || (rowSelection && rowSelection.fixed);\n }, [columns, rowSelection]);\n\n // 检查是否所有列都有宽度\n const hasAllColumnWidths = useMemo(() => {\n return columns.every(col => col.width) && (!rowSelection || rowSelection.columnWidth);\n }, [columns, rowSelection]);\n\n // 计算表格总宽度\n // 只有在设置了 scroll.x 或者有固定列且需要滚动时,才使用固定宽度\n // 否则使用 100% 让表格撑满父元素\n const totalWidth = useMemo(() => {\n // 如果设置了 scroll.x,使用 scroll.x 作为表格宽度(Ant Design 的方式)\n if (scroll?.x) {\n if (typeof scroll.x === 'number') {\n return scroll.x;\n } else if (scroll.x === true) {\n // scroll.x === true 时,计算所有列的宽度总和\n const widthSum = columns.reduce((sum, col) => {\n const w = col.width \n ? (typeof col.width === 'number' ? col.width : parseInt(String(col.width).replace('px', '')) || 0)\n : 150; // 默认宽度\n return sum + w;\n }, 0);\n const total = widthSum + (rowSelection ? (typeof rowSelection.columnWidth === 'number' ? rowSelection.columnWidth : parseInt(String(rowSelection.columnWidth || '60').replace('px', '')) || 60) : 0);\n return total;\n }\n }\n \n // 如果有固定列,需要计算最小宽度以确保固定列能正常工作\n // 但表格本身仍然使用 100% 宽度撑满父元素\n if (hasFixedColumns) {\n // 计算所有固定列的宽度总和,作为最小宽度\n const fixedWidthSum = columns.reduce((sum, col) => {\n if (col.fixed && col.width) {\n const w = typeof col.width === 'number' ? col.width : parseInt(String(col.width).replace('px', '')) || 0;\n return sum + w;\n }\n return sum;\n }, 0);\n const rowSelectionWidth = (rowSelection && rowSelection.fixed && rowSelection.columnWidth) \n ? (typeof rowSelection.columnWidth === 'number' ? rowSelection.columnWidth : parseInt(String(rowSelection.columnWidth).replace('px', '')) || 60)\n : 0;\n // 返回最小宽度,但表格宽度仍然使用 100%\n return fixedWidthSum + rowSelectionWidth;\n }\n \n // 默认返回 undefined,让表格使用 100% 宽度撑满父元素\n return undefined;\n }, [columns, scroll?.x, rowSelection, hasFixedColumns]);\n\n // 如果有固定列或所有列都有 width,使用 fixed layout\n const effectiveTableLayout = useMemo(() => {\n if (tableLayout === 'fixed') return 'fixed';\n if (hasFixedColumns) return 'fixed';\n if (hasAllColumnWidths) return 'fixed';\n // 如果有部分列设置了宽度,也使用 fixed layout,让未设置宽度的列自适应\n if (columns.some(col => col.width)) return 'fixed';\n return tableLayout;\n }, [tableLayout, hasFixedColumns, hasAllColumnWidths, columns]);\n\n const tableStyle: React.CSSProperties = {\n width: '100%', // 始终使用 100% 宽度撑满父元素\n minWidth: totalWidth ? `${totalWidth}px` : '100%', // 如果有固定列,设置最小宽度\n borderCollapse: 'separate',\n borderSpacing: 0,\n tableLayout: effectiveTableLayout,\n backgroundColor: 'white',\n ...(bordered && { borderRadius: '8px', border: '1px solid #EAECF0' }),\n overflow: 'hidden',\n };\n\n const wrapperStyle: React.CSSProperties = {\n position: 'relative',\n width: '100%',\n maxWidth: '100%',\n maxHeight: typeof scroll?.y === 'number' ? `${scroll.y}px` : undefined,\n borderRadius: '8px',\n ...style,\n };\n\n // 移动端使用卡片式布局\n if (isMobile) {\n return (\n <div\n ref={tableRef}\n className={`aha-table aha-table-mobile-wrapper ${className}`}\n style={wrapperStyle}\n aria-busy={loading ? true : undefined}\n {...rest}\n >\n {title && <div style={{ marginBottom: '16px' }}>{title(processedData)}</div>}\n {pagination && typeof pagination === 'object' && pagination.position?.startsWith('top') && renderPagination()}\n {renderMobileView()}\n {footer && <div style={{ marginTop: '16px' }}>{footer(processedData)}</div>}\n {pagination && (typeof pagination === 'object' ? !pagination.position?.startsWith('top') : true) && renderPagination()}\n <TableLoadingOverlay loading={loading} spinColor={loadingSpinColor} />\n </div>\n );\n }\n\n // 滚动容器的样式\n const scrollContainerStyle: React.CSSProperties = {\n position: 'relative',\n overflowX: (scroll?.x || hasFixedColumns) ? 'auto' : 'visible',\n overflowY: scroll?.y ? 'auto' : 'visible',\n width: '100%',\n // 关键:容器宽度必须小于表格宽度,才能触发滚动\n // 只有在设置了 scroll.x 时才限制容器宽度\n maxWidth: scroll?.x === true \n ? '100%' \n : typeof scroll?.x === 'number' \n ? `${scroll.x}px` \n : undefined,\n maxHeight: typeof scroll?.y === 'number' ? `${scroll.y}px` : undefined,\n // 确保滚动容器有明确的边界\n borderRadius: '8px',\n };\n\n return (\n <div\n ref={tableRef}\n className={`aha-table ${className}`}\n style={wrapperStyle}\n aria-busy={loading ? true : undefined}\n {...rest}\n >\n {title && <div style={{ marginBottom: '16px' }}>{title(processedData)}</div>}\n {pagination && typeof pagination === 'object' && pagination.position?.startsWith('top') && renderPagination()}\n <div style={scrollContainerStyle}>\n <div style={{ \n width: '100%', \n minWidth: totalWidth ? `${totalWidth}px` : '100%', \n display: 'block' \n }}>\n <table style={tableStyle} className={innerClassName}>\n {renderHeader()}\n <tbody>{renderRows()}</tbody>\n {summary && (\n <tfoot>\n <tr>\n <td colSpan={columns.length + (rowSelection ? 1 : 0)}>{summary(processedData)}</td>\n </tr>\n </tfoot>\n )}\n </table>\n </div>\n </div>\n {footer && <div style={{ marginTop: '16px' }}>{footer(processedData)}</div>}\n {pagination && (typeof pagination === 'object' ? !pagination.position?.startsWith('top') : true) && renderPagination()}\n <TableLoadingOverlay loading={loading} spinColor={loadingSpinColor} />\n </div>\n );\n};\n\nexport default Table;\n\n","import React from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface RadioProps {\n checked?: boolean;\n disabled?: boolean;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n className?: string;\n style?: React.CSSProperties;\n children?: React.ReactNode;\n value?: any;\n name?: string;\n}\n\nconst Radio: React.FC<RadioProps> = ({\n checked = false,\n disabled = false,\n onChange,\n className = '',\n style,\n children,\n value,\n name,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n \n const handleClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (disabled) return;\n // 创建一个合成事件来触发 onChange\n const syntheticEvent = {\n target: { checked: !checked, value },\n currentTarget: { checked: !checked, value },\n } as React.ChangeEvent<HTMLInputElement>;\n onChange?.(syntheticEvent);\n };\n\n const backgroundColor = disabled\n ? '#FAFAF9'\n : checked\n ? primaryColor\n : 'white';\n const borderColor = disabled \n ? '#FAFAF9' \n : checked \n ? primaryColor \n : '#D7D3D0';\n\n return (\n <div\n className={`aha-radio ${className}`}\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n gap: '8px',\n cursor: disabled ? 'not-allowed' : 'pointer',\n ...style,\n }}\n onClick={handleClick}\n >\n <div\n style={{\n position: 'relative',\n width: '20px',\n height: '20px',\n minWidth: '20px',\n minHeight: '20px',\n borderRadius: '50%',\n border: `1px solid ${borderColor}`,\n backgroundColor,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n transition: 'all 0.2s',\n flexShrink: 0,\n boxSizing: 'border-box',\n }}\n >\n <div\n style={{\n width: '8px',\n height: '8px',\n minWidth: '8px',\n minHeight: '8px',\n borderRadius: '50%',\n backgroundColor: 'white',\n opacity: checked ? 1 : 0,\n transition: 'opacity 0.2s',\n pointerEvents: 'none',\n boxSizing: 'border-box',\n }}\n />\n </div>\n {children && (\n <span\n style={{\n fontSize: '14px',\n lineHeight: '20px',\n color: disabled ? '#98A2B3' : '#101828',\n fontFamily: 'DM Sans, sans-serif',\n }}\n >\n {children}\n </span>\n )}\n <input\n type=\"radio\"\n checked={checked}\n onChange={onChange}\n disabled={disabled}\n value={value}\n name={name}\n style={{\n position: 'absolute',\n opacity: 0,\n width: 0,\n height: 0,\n pointerEvents: 'none',\n }}\n aria-hidden=\"true\"\n />\n </div>\n );\n};\n\nRadio.displayName = 'Radio';\n\nexport default Radio;\n\n","import React, { useState, useCallback, useRef, useEffect, useMemo } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport type TabVariant = 'underline' | 'background';\nexport type TabLayout = 'equal' | 'spaced';\n\nexport interface TabItem {\n key: string | number;\n label: React.ReactNode;\n icon?: React.ReactElement | React.ComponentType<any>;\n badge?: number | string;\n customElement?: React.ReactNode;\n disabled?: boolean;\n children?: React.ReactNode; // 用于 children 模式的内容\n}\n\nexport interface TabProps {\n items: TabItem[] | string[] | number[];\n variant?: TabVariant;\n layout?: TabLayout; // 仅对 background 样式有效\n defaultValue?: string | number;\n value?: string | number;\n onChange?: (value: string | number) => void;\n className?: string;\n mode?: 'children' | 'value'; // children: 渲染 children,value: 只输出 value\n scrollable?: boolean; // 是否支持横向滚动(仅对 underline 样式有效,移动端/小宽度容器)\n [key: string]: any;\n}\n\nconst Tab: React.FC<TabProps> = ({\n items = [],\n variant = 'underline',\n layout = 'equal',\n defaultValue,\n value: controlledValue,\n onChange,\n className = '',\n mode = 'children',\n scrollable = false,\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n \n // 如果没有 items,返回空\n if (!items || items.length === 0) {\n return null;\n }\n\n // 将 string[] 或 number[] 转换为 TabItem[]\n // 使用 useMemo 稳定引用,避免导致无限循环\n const normalizedItems: TabItem[] = useMemo(() => {\n if (items.length === 0) return [];\n \n // 判断第一个元素的类型\n const firstItem = items[0];\n if (typeof firstItem === 'string' || typeof firstItem === 'number') {\n return (items as (string | number)[]).map((item, index) => ({\n key: String(item),\n label: String(item),\n }));\n }\n \n return items as TabItem[];\n }, [items]);\n\n // 简单的受控/非受控逻辑\n const isControlled = controlledValue !== undefined;\n const firstKey: string | number = normalizedItems.length > 0 ? normalizedItems[0].key : '';\n \n // 查找匹配的 key:如果 value 在 normalizedItems 中找不到,尝试使用第一个 key\n const findMatchingKey = (value: string | number | undefined): string | number => {\n if (value === undefined) return firstKey;\n \n // 精确匹配(同时支持字符串和数字的比较)\n const exactMatch = normalizedItems.find(item => {\n // 1. 直接比较(最严格)\n if (item.key === value) return true;\n \n // 2. 字符串比较\n if (String(item.key) === String(value)) return true;\n \n // 3. 数字比较(确保两个都是有效数字)\n const itemNum = Number(item.key);\n const valueNum = Number(value);\n if (!isNaN(itemNum) && !isNaN(valueNum) && itemNum === valueNum) {\n return true;\n }\n \n return false;\n });\n \n if (exactMatch) {\n // 返回找到的 key,保持原始类型\n return exactMatch.key;\n }\n \n // 如果找不到,返回第一个 key(回退逻辑)\n return firstKey;\n };\n \n const [internalValue, setInternalValue] = useState<string | number>(() => {\n // 只在第一次渲染时计算\n const initialValue = controlledValue ?? defaultValue ?? firstKey;\n const matchedKey = findMatchingKey(initialValue);\n return matchedKey;\n });\n \n // 每次渲染时重新计算 currentValue,确保类型匹配\n const currentValue = isControlled \n ? (controlledValue !== undefined ? findMatchingKey(controlledValue) : firstKey)\n : internalValue;\n \n // 调试日志(可以帮助定位问题,问题解决后可以删除)\n useEffect(() => {\n console.log('[Tab Debug] currentValue:', currentValue, 'type:', typeof currentValue);\n console.log('[Tab Debug] normalizedItems:', normalizedItems.map(item => ({ key: item.key, type: typeof item.key })));\n console.log('[Tab Debug] controlledValue:', controlledValue, 'isControlled:', isControlled);\n }, [currentValue, normalizedItems, controlledValue, isControlled]);\n\n const handleTabClick = useCallback(\n (key: string | number, disabled?: boolean) => {\n if (disabled) return;\n if (!isControlled) {\n setInternalValue(key);\n }\n // 如果原始 items 是 number[],返回 number,否则返回 string\n const originalItem = items[0];\n const returnValue = typeof originalItem === 'number' && typeof key === 'number' ? key : (typeof key === 'number' ? String(key) : key);\n onChange?.(returnValue);\n \n // 如果支持滚动,点击后自动滚动到可见区域\n if (scrollable && variant === 'underline') {\n const activeTabElement = tabRefs.current[getKeyString(key)];\n const container = containerRef.current;\n if (activeTabElement && container) {\n // 标记正在滚动\n isScrollingRef.current = true;\n \n // 先立即更新一次位置(基于当前滚动位置)\n const updatePosition = () => {\n if (!container || !underlineRef.current || !activeTabElement) return;\n const containerRect = container.getBoundingClientRect();\n const tabRect = activeTabElement.getBoundingClientRect();\n \n if (containerRect.width > 0 && tabRect.width > 0) {\n // 下划线是绝对定位,相对于容器内容区域\n // 需要加上容器的滚动距离\n const scrollLeft = container.scrollLeft || 0;\n const left = tabRect.left - containerRect.left + scrollLeft;\n const width = tabRect.width;\n setUnderlineStyle({\n width: `${width}px`,\n left: `${left}px`,\n opacity: 1,\n });\n }\n };\n \n // 监听滚动事件,实时更新位置\n let scrollTimeout: NodeJS.Timeout;\n const handleScroll = () => {\n updatePosition();\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n // 滚动停止后,最终更新一次位置\n updatePosition();\n isScrollingRef.current = false;\n container.removeEventListener('scroll', handleScroll);\n }, 150); // 滚动停止 150ms 后认为滚动完成\n };\n \n container.addEventListener('scroll', handleScroll, { passive: true });\n \n // 使用 scrollIntoView 滚动到可见区域\n activeTabElement.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n inline: 'center',\n });\n \n // 如果 scrollIntoView 不支持或立即完成,也更新位置\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n updatePosition();\n });\n });\n }\n }\n },\n [isControlled, onChange, items, scrollable, variant]\n );\n\n const activeItem = normalizedItems.find((item) => {\n // 支持多种比较方式\n if (item.key === currentValue) return true;\n if (String(item.key) === String(currentValue)) return true;\n // 数字比较:确保两个都是数字且相等\n const itemNum = Number(item.key);\n const currentNum = Number(currentValue);\n if (!isNaN(itemNum) && !isNaN(currentNum) && itemNum === currentNum) return true;\n return false;\n });\n const activeColor = primaryColor || '#FB6011';\n \n // 用于下划线和背景滑块动画的 refs\n const tabRefs = useRef<{ [key: string]: HTMLDivElement | null }>({});\n \n // 将 key 转为字符串的辅助函数\n const getKeyString = (key: string | number): string => String(key);\n const underlineRef = useRef<HTMLDivElement>(null);\n const backgroundSliderRef = useRef<HTMLDivElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const backgroundContainerRef = useRef<HTMLDivElement>(null);\n const prevCurrentValueRef = useRef<string | number>('');\n const refsInitializedRef = useRef<Set<string>>(new Set());\n const isScrollingRef = useRef<boolean>(false); // 标记是否正在滚动\n const [underlineStyle, setUnderlineStyle] = useState<React.CSSProperties>({\n width: 0,\n left: 0,\n opacity: 0,\n });\n const [backgroundSliderStyle, setBackgroundSliderStyle] = useState<React.CSSProperties>({\n width: 0,\n left: 0,\n opacity: 0,\n });\n\n // 更新下划线的辅助函数\n const updateUnderlinePosition = useCallback(() => {\n if (variant !== 'underline' || !containerRef.current || !currentValue) {\n return;\n }\n \n // 使用双重 requestAnimationFrame 确保 DOM 完全渲染完成\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n // 再次检查 refs 和 currentValue,确保它们仍然有效\n if (!underlineRef.current || !containerRef.current) {\n return;\n }\n \n let activeTab = tabRefs.current[getKeyString(currentValue)];\n \n // 如果找不到精确匹配的 tab,尝试使用第一个 item(回退逻辑)\n if (!activeTab && normalizedItems.length > 0) {\n const firstKey = normalizedItems[0].key;\n activeTab = tabRefs.current[getKeyString(firstKey)];\n }\n \n if (!activeTab) {\n return;\n }\n \n const containerRect = containerRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n // 如果容器或标签页的尺寸为 0,说明还没有渲染完成,不更新\n if (containerRect.width === 0 || tabRect.width === 0) {\n return;\n }\n \n // 计算下划线位置\n // 下划线是绝对定位,相对于容器(position: relative)\n // getBoundingClientRect() 返回的是相对于视口的位置\n // 下划线的 left 是相对于容器内容区域的起始位置\n // 所以需要:tab 相对于容器视口的位置 + 容器的滚动距离\n const scrollLeft = containerRef.current.scrollLeft || 0;\n const left = tabRect.left - containerRect.left + scrollLeft;\n const width = tabRect.width;\n const newLeft = `${left}px`;\n const newWidth = `${width}px`;\n \n // 更新下划线样式\n setUnderlineStyle((prev) => {\n if (prev.left === newLeft && prev.width === newWidth && prev.opacity === 1) {\n return prev; // 值相同,返回原对象,避免重新渲染\n }\n return {\n width: newWidth,\n left: newLeft,\n opacity: 1,\n };\n });\n });\n });\n }, [variant, currentValue, normalizedItems]);\n\n // 更新背景滑块位置的辅助函数\n const updateBackgroundSliderPosition = useCallback(() => {\n if (variant !== 'background' || !backgroundContainerRef.current || !backgroundSliderRef.current || !currentValue) {\n return;\n }\n \n // 使用双重 requestAnimationFrame 确保 DOM 完全渲染完成\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n // 再次检查 refs 和 currentValue,确保它们仍然有效\n if (!backgroundSliderRef.current || !backgroundContainerRef.current) {\n return;\n }\n \n let activeTab = tabRefs.current[getKeyString(currentValue)];\n \n // 如果找不到精确匹配的 tab,尝试使用第一个 item(回退逻辑)\n if (!activeTab && normalizedItems.length > 0) {\n const firstKey = normalizedItems[0].key;\n activeTab = tabRefs.current[getKeyString(firstKey)];\n }\n \n if (!activeTab) {\n return;\n }\n \n const containerRect = backgroundContainerRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n // 如果容器或标签页的尺寸为 0,说明还没有渲染完成,不更新\n if (containerRect.width === 0 || tabRect.width === 0) {\n return;\n }\n \n const left = tabRect.left - containerRect.left;\n const width = tabRect.width;\n const newLeft = `${left}px`;\n const newWidth = `${width}px`;\n \n // 更新背景滑块样式\n setBackgroundSliderStyle((prev) => {\n if (prev.left === newLeft && prev.width === newWidth && prev.opacity === 1) {\n return prev; // 值相同,返回原对象,避免重新渲染\n }\n return {\n width: newWidth,\n left: newLeft,\n opacity: 1,\n };\n });\n });\n });\n }, [variant, currentValue, normalizedItems]);\n\n // 更新下划线和背景滑块位置\n useEffect(() => {\n // 如果没有 currentValue,不执行任何操作\n if (!currentValue) {\n prevCurrentValueRef.current = '';\n return;\n }\n \n // 如果 currentValue 没有变化,不执行(避免无限循环)\n if (prevCurrentValueRef.current === currentValue) {\n return;\n }\n \n // 更新 ref\n prevCurrentValueRef.current = currentValue;\n\n // 更新下划线位置\n // 如果正在滚动,不立即更新,等待滚动完成后再更新(在 handleTabClick 中处理)\n if (variant === 'underline' && containerRef.current && !isScrollingRef.current) {\n updateUnderlinePosition();\n }\n\n // 更新背景滑块位置\n if (variant === 'background' && backgroundContainerRef.current && backgroundSliderRef.current) {\n updateBackgroundSliderPosition();\n }\n }, [currentValue, variant, normalizedItems.length, isControlled, updateUnderlinePosition, updateBackgroundSliderPosition]);\n \n // 初始渲染后,确保下划线和背景滑块正确显示(解决初始渲染时宽度为 0 的问题)\n // 只在组件挂载后执行一次\n useEffect(() => {\n if (!currentValue) return;\n \n // 延迟执行,确保所有 refs 都已设置\n const timer = setTimeout(() => {\n if (variant === 'underline') {\n // 检查 activeTab 是否存在\n const activeTab = tabRefs.current[getKeyString(currentValue)];\n if (activeTab && containerRef.current && underlineRef.current) {\n updateUnderlinePosition();\n \n // 如果支持滚动,初始渲染时自动滚动到激活项\n if (scrollable) {\n activeTab.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n inline: 'center',\n });\n }\n }\n } else if (variant === 'background') {\n // 更新背景滑块位置\n const activeTab = tabRefs.current[getKeyString(currentValue)];\n if (activeTab && backgroundContainerRef.current && backgroundSliderRef.current) {\n const containerRect = backgroundContainerRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n if (containerRect.width > 0 && tabRect.width > 0) {\n const left = tabRect.left - containerRect.left;\n const width = tabRect.width;\n const newLeft = `${left}px`;\n const newWidth = `${width}px`;\n \n setBackgroundSliderStyle({\n width: newWidth,\n left: newLeft,\n opacity: 1,\n });\n }\n }\n }\n }, 100); // 增加延迟,确保 refs 和 DOM 都已准备好\n \n return () => clearTimeout(timer);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []); // 只在组件挂载时执行一次\n \n // 当 currentValue 变化时,如果支持滚动,自动滚动到激活项\n // 注意:这个 useEffect 只在非点击触发的 currentValue 变化时执行(比如受控组件外部更新)\n useEffect(() => {\n if (!scrollable || variant !== 'underline' || !currentValue) return;\n \n // 如果正在滚动(由点击触发),不执行这个 useEffect 的滚动逻辑\n if (isScrollingRef.current) return;\n \n const timer = setTimeout(() => {\n const activeTab = tabRefs.current[getKeyString(currentValue)];\n const container = containerRef.current;\n if (activeTab && container) {\n isScrollingRef.current = true;\n \n // 更新位置的函数\n const updatePosition = () => {\n if (!container || !underlineRef.current || !activeTab) return;\n const containerRect = container.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n if (containerRect.width > 0 && tabRect.width > 0) {\n // 下划线是绝对定位,相对于容器内容区域\n // 需要加上容器的滚动距离\n const scrollLeft = container.scrollLeft || 0;\n const left = tabRect.left - containerRect.left + scrollLeft;\n const width = tabRect.width;\n setUnderlineStyle({\n width: `${width}px`,\n left: `${left}px`,\n opacity: 1,\n });\n }\n };\n \n // 监听滚动事件\n let scrollTimeout: NodeJS.Timeout;\n const handleScroll = () => {\n updatePosition();\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n updatePosition();\n isScrollingRef.current = false;\n container.removeEventListener('scroll', handleScroll);\n }, 150);\n };\n \n container.addEventListener('scroll', handleScroll, { passive: true });\n \n activeTab.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n inline: 'center',\n });\n \n // 立即更新一次\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n updatePosition();\n });\n });\n }\n }, 50);\n \n return () => clearTimeout(timer);\n }, [currentValue, scrollable, variant]);\n\n // 下划线样式\n const renderUnderlineStyle = () => {\n const containerStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n gap: '32px',\n borderBottom: '1px solid #E7E5E4',\n paddingBottom: '0',\n position: 'relative',\n };\n \n // 如果支持滚动,添加滚动样式\n if (scrollable) {\n containerStyle.overflowX = 'auto';\n containerStyle.overflowY = 'hidden';\n containerStyle.scrollBehavior = 'smooth';\n // 隐藏滚动条但保持滚动功能\n containerStyle.scrollbarWidth = 'none'; // Firefox\n // @ts-ignore - WebKit 私有属性\n containerStyle.WebkitOverflowScrolling = 'touch'; // iOS 平滑滚动\n }\n \n return (\n <div\n ref={containerRef}\n className={`aha-tab aha-tab--underline ${scrollable ? 'aha-tab--scrollable' : ''} ${className}`}\n style={containerStyle}\n {...rest}\n >\n {/* 动画下划线指示器 */}\n <div\n ref={underlineRef}\n style={{\n position: 'absolute',\n bottom: '0px',\n height: '2px',\n backgroundColor: activeColor,\n borderRadius: '1px 1px 0 0',\n transition: 'left 0.3s cubic-bezier(0.4, 0, 0.2, 1), width 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease-in-out',\n ...underlineStyle,\n }}\n />\n \n {normalizedItems.map((item) => {\n // 支持多种比较方式:直接比较、字符串比较、数字比较\n const isActive = (() => {\n // 直接比较(最严格)\n if (item.key === currentValue) {\n return true;\n }\n // 字符串比较\n if (String(item.key) === String(currentValue)) {\n return true;\n }\n // 数字比较:确保两个都是有效数字且相等\n const itemNum = Number(item.key);\n const currentNum = Number(currentValue);\n if (!isNaN(itemNum) && !isNaN(currentNum) && itemNum === currentNum) {\n return true;\n }\n return false;\n })();\n \n // 调试日志(仅对第一个 item 输出,避免太多日志)\n if (item.key === normalizedItems[0].key) {\n console.log('[Tab Debug] isActive check:', {\n itemKey: item.key,\n itemKeyType: typeof item.key,\n currentValue,\n currentValueType: typeof currentValue,\n isActive,\n variant,\n });\n }\n\n return (\n <div\n key={item.key}\n ref={(el) => {\n tabRefs.current[getKeyString(item.key)] = el;\n }}\n onClick={() => handleTabClick(item.key, item.disabled)}\n style={{\n position: 'relative',\n padding: '12px 0',\n cursor: item.disabled ? 'not-allowed' : 'pointer',\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n opacity: item.disabled ? 0.5 : 1,\n transition: 'color 0.2s ease-in-out',\n // 如果支持滚动,tab 项需要 flex-shrink: 0 防止压缩\n flexShrink: scrollable ? 0 : undefined,\n whiteSpace: scrollable ? 'nowrap' : undefined,\n }}\n >\n {/* 图标 */}\n {item.icon && (() => {\n // 调试日志\n const iconType = typeof item.icon;\n const isReactElement = React.isValidElement(item.icon);\n console.log('[Tab Debug] Icon render:', {\n itemKey: item.key,\n iconType,\n isReactElement,\n iconValue: item.icon,\n });\n \n // 如果 icon 是 ReactElement,直接克隆\n if (React.isValidElement(item.icon)) {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.cloneElement(item.icon as React.ReactElement<any>, {\n width: 20,\n height: 20,\n style: {\n ...(item.icon.props as any)?.style,\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n },\n })}\n </div>\n );\n }\n \n // 如果 icon 是组件类型(函数),使用 createElement\n if (typeof item.icon === 'function') {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.createElement(item.icon as React.ComponentType<any>, {\n width: 20,\n height: 20,\n style: {\n color: isActive ? activeColor : '#79716B',\n },\n })}\n </div>\n );\n }\n \n // 其他情况直接渲染\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.icon as React.ReactNode}\n </div>\n );\n })()}\n\n {/* 标签文本 */}\n <span\n style={{\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n color: isActive ? activeColor : '#79716B',\n lineHeight: '1.375',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.label}\n </span>\n\n {/* Badge */}\n {item.badge !== undefined && item.badge !== null && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n minWidth: '20px',\n height: '20px',\n padding: '0 6px',\n borderRadius: '10px',\n backgroundColor: isActive ? '#FFF6ED' : '#FAFAF9',\n border: isActive ? '1px solid #FFD1A9' : '1px solid #E7E5E4',\n color: isActive ? '#C4330A' : '#44403C',\n fontSize: '12px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '1',\n transition: 'all 0.2s ease-in-out',\n }}\n >\n {item.badge}\n </div>\n )}\n\n {/* 自定义元素 */}\n {item.customElement}\n </div>\n );\n })}\n </div>\n );\n };\n\n // 背景边框样式\n const renderBackgroundStyle = () => {\n const containerStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n backgroundColor: '#FAFAF9',\n borderRadius: '8px',\n padding: '4px',\n border: '1px solid #E7E5E4',\n gap: '4px',\n position: 'relative',\n };\n\n if (layout === 'equal') {\n containerStyle.width = '100%';\n } else {\n // spaced 模式:等边距\n containerStyle.width = 'fit-content';\n }\n\n return (\n <div\n ref={backgroundContainerRef}\n className={`aha-tab aha-tab--background aha-tab--${layout} ${className}`}\n style={containerStyle}\n {...rest}\n >\n {/* 背景滑块 */}\n <div\n ref={backgroundSliderRef}\n style={{\n position: 'absolute',\n top: '4px',\n bottom: '4px',\n borderRadius: '6px',\n backgroundColor: '#FFFFFF',\n border: 'none',\n boxShadow: '0px 1px 2px 0px rgba(10, 13, 18, 0.1)',\n transition: 'left 0.3s cubic-bezier(0.4, 0, 0.2, 1), width 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease-in-out',\n pointerEvents: 'none',\n ...backgroundSliderStyle,\n }}\n />\n \n {normalizedItems.map((item) => {\n // 支持多种比较方式:直接比较、字符串比较、数字比较\n const isActive = (() => {\n // 直接比较(最严格)\n if (item.key === currentValue) {\n return true;\n }\n // 字符串比较\n if (String(item.key) === String(currentValue)) {\n return true;\n }\n // 数字比较:确保两个都是有效数字且相等\n const itemNum = Number(item.key);\n const currentNum = Number(currentValue);\n if (!isNaN(itemNum) && !isNaN(currentNum) && itemNum === currentNum) {\n return true;\n }\n return false;\n })();\n \n // 调试日志(仅对第一个 item 输出,避免太多日志)\n if (item.key === normalizedItems[0].key) {\n console.log('[Tab Debug] isActive check:', {\n itemKey: item.key,\n itemKeyType: typeof item.key,\n currentValue,\n currentValueType: typeof currentValue,\n isActive,\n variant,\n });\n }\n\n const itemStyle: React.CSSProperties = {\n position: 'relative',\n padding: '8px 16px',\n cursor: item.disabled ? 'not-allowed' : 'pointer',\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n borderRadius: '6px',\n opacity: item.disabled ? 0.5 : 1,\n flex: layout === 'equal' ? 1 : 'none',\n justifyContent: 'center',\n backgroundColor: 'transparent',\n border: '1px solid transparent',\n transition: 'color 0.2s ease-in-out',\n zIndex: 1,\n };\n\n return (\n <div\n key={item.key}\n ref={(el) => {\n tabRefs.current[getKeyString(item.key)] = el;\n }}\n onClick={() => handleTabClick(item.key, item.disabled)}\n style={itemStyle}\n >\n {/* 图标 */}\n {item.icon && (() => {\n // 如果 icon 是 ReactElement,直接克隆\n if (React.isValidElement(item.icon)) {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '16px',\n height: '16px',\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.cloneElement(item.icon as React.ReactElement<any>, {\n width: 16,\n height: 16,\n style: {\n ...(item.icon.props as any)?.style,\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n },\n })}\n </div>\n );\n }\n \n // 如果 icon 是组件类型(函数),使用 createElement\n if (typeof item.icon === 'function') {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '16px',\n height: '16px',\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.createElement(item.icon as React.ComponentType<any>, {\n width: 16,\n height: 16,\n style: {\n color: isActive ? '#44403C' : '#79716B',\n },\n })}\n </div>\n );\n }\n \n // 其他情况直接渲染\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '16px',\n height: '16px',\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.icon as React.ReactNode}\n </div>\n );\n })()}\n\n {/* 标签文本 */}\n <span\n style={{\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n color: isActive ? '#44403C' : '#79716B',\n lineHeight: '1.375',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.label}\n </span>\n\n {/* Badge */}\n {item.badge !== undefined && item.badge !== null && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n minWidth: '20px',\n height: '20px',\n padding: '0 6px',\n borderRadius: '10px',\n backgroundColor: isActive ? '#FFF6ED' : '#FAFAF9',\n border: isActive ? '1px solid #FFD1A9' : '1px solid #E7E5E4',\n color: isActive ? '#C4330A' : '#44403C',\n fontSize: '12px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '1',\n transition: 'all 0.2s ease-in-out',\n }}\n >\n {item.badge}\n </div>\n )}\n\n {/* 自定义元素 */}\n {item.customElement}\n </div>\n );\n })}\n </div>\n );\n };\n\n return (\n <div className=\"aha-tab-container\">\n {variant === 'underline' ? renderUnderlineStyle() : renderBackgroundStyle()}\n \n {/* 添加样式隐藏滚动条(仅对支持滚动的 underline 模式) */}\n {scrollable && variant === 'underline' && (\n <style>\n {`\n .aha-tab--scrollable::-webkit-scrollbar {\n display: none;\n }\n .aha-tab--scrollable {\n -ms-overflow-style: none;\n }\n `}\n </style>\n )}\n {mode === 'children' && activeItem?.children && (\n <div className=\"aha-tab-content\" style={{ marginTop: '24px' }}>\n {activeItem.children}\n </div>\n )}\n </div>\n );\n};\n\nexport default Tab;\n","import React, { forwardRef, useRef, useEffect, useMemo, useLayoutEffect } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\ninterface LinkifyOptions {\n validate?: (url: string) => boolean;\n className?: string;\n needProtocol?: boolean;\n needHost?: boolean;\n allowedTlds?: string[];\n}\n\nexport interface TextareaProps\n extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size'> {\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 是否只读 */\n readOnly?: boolean;\n /** 是否显示字符计数 */\n showCount?: boolean;\n /** 最大字符数 */\n maxLength?: number;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 占位符 */\n placeholder?: string;\n /** 值 */\n value?: string;\n /** 默认值 */\n defaultValue?: string;\n /** 行数 */\n rows?: number;\n /** 是否自动调整高度 */\n autoSize?: boolean | { minRows?: number; maxRows?: number };\n /** 变化回调 */\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n /** 是否启用实时链接识别 */\n linkify?: boolean;\n /** 链接识别配置 */\n linkifyOptions?: LinkifyOptions;\n}\n\ntype TextToken =\n | { type: 'text'; text: string }\n | { type: 'url'; text: string; href: string };\n\nconst DOMAIN_REGEX = /^(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}$/;\nconst URL_CANDIDATE_REGEX =\n /(https?:\\/\\/[^\\s<]+|www\\.[^\\s<]+|(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}(?:\\/[^\\s<]*)?)/gi;\nconst DEFAULT_ALLOWED_TLDS = new Set([\n 'com',\n 'cn',\n 'net',\n 'org',\n 'io',\n 'co',\n 'edu',\n 'gov',\n 'ai',\n 'app',\n 'dev',\n 'me',\n 'info',\n 'biz',\n 'tech',\n 'cc',\n 'tv',\n 'xyz',\n 'top',\n 'vip',\n 'pro',\n 'store',\n 'site',\n 'online',\n 'cloud',\n]);\n\nexport const websiteValidator = (\n url: string,\n needProtocol: boolean = true,\n needHost: boolean = true,\n allowedTlds?: string[]\n): boolean => {\n if (!url || typeof url !== 'string') return false;\n const trimmed = url.trim();\n if (!trimmed) return false;\n\n const hasProtocol = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(trimmed);\n if (needProtocol && !hasProtocol) return false;\n\n const normalized = hasProtocol ? trimmed : `https://${trimmed}`;\n\n try {\n const parsed = new URL(normalized);\n const protocol = parsed.protocol.toLowerCase();\n if (protocol !== 'http:' && protocol !== 'https:') return false;\n\n if (needHost) {\n const host = parsed.hostname.toLowerCase();\n if (!host) return false;\n if (host === 'localhost') return true;\n if (/^\\d{1,3}(\\.\\d{1,3}){3}$/.test(host)) {\n return host.split('.').every((segment) => {\n const num = Number(segment);\n return Number.isInteger(num) && num >= 0 && num <= 255;\n });\n }\n if (!DOMAIN_REGEX.test(host)) return false;\n const tld = host.split('.').pop() || '';\n const tldSet = allowedTlds\n ? new Set(allowedTlds.map((item) => item.toLowerCase()))\n : DEFAULT_ALLOWED_TLDS;\n if (!tldSet.has(tld)) return false;\n }\n return true;\n } catch {\n return false;\n }\n};\n\nconst trimTrailingPunctuation = (value: string): { core: string; suffix: string } => {\n const match = value.match(/^(.*?)([),.;!?]+)?$/);\n return {\n core: match?.[1] || value,\n suffix: match?.[2] || '',\n };\n};\n\nconst tokenizeText = (\n text: string,\n options?: LinkifyOptions\n): TextToken[] => {\n if (!text) return [];\n\n const tokens: TextToken[] = [];\n let lastIndex = 0;\n const regex = new RegExp(URL_CANDIDATE_REGEX);\n let match = regex.exec(text);\n\n while (match) {\n const matchedText = match[0];\n const start = match.index;\n const end = start + matchedText.length;\n\n if (start > lastIndex) {\n tokens.push({ type: 'text', text: text.slice(lastIndex, start) });\n }\n\n const { core, suffix } = trimTrailingPunctuation(matchedText);\n const href = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(core)\n ? core\n : `https://${core}`;\n const defaultIsValid = websiteValidator(\n core,\n options?.needProtocol ?? false,\n options?.needHost ?? true,\n options?.allowedTlds\n );\n const isValid = options?.validate ? options.validate(href) : defaultIsValid;\n\n if (isValid && core) {\n tokens.push({ type: 'url', text: core, href });\n if (suffix) {\n tokens.push({ type: 'text', text: suffix });\n }\n } else {\n tokens.push({ type: 'text', text: matchedText });\n }\n\n lastIndex = end;\n match = regex.exec(text);\n }\n\n if (lastIndex < text.length) {\n tokens.push({ type: 'text', text: text.slice(lastIndex) });\n }\n\n return tokens;\n};\n\nconst escapeHtml = (value: string): string =>\n value\n .replace(/&/g, '&amp;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&#39;');\n\nconst ZWSP = '\\u200B';\nconst stripEditorArtifacts = (value: string): string =>\n value.replace(new RegExp(ZWSP, 'g'), '');\n\nconst renderTokensAsHtml = (\n text: string,\n options?: LinkifyOptions,\n disabled?: boolean\n): string => {\n const tokens = tokenizeText(text, options);\n if (tokens.length === 0) return '';\n\n const html = tokens\n .map((token) => {\n if (token.type === 'text') {\n return escapeHtml(token.text);\n }\n\n const classAttr = options?.className ? ` class=\"${options.className}\"` : '';\n const pointerEvents = disabled ? 'pointer-events: none;' : '';\n return `<a href=\"${escapeHtml(token.href)}\" target=\"_blank\" rel=\"noopener noreferrer\"${classAttr} style=\"color: #2563EB; text-decoration: underline; ${pointerEvents}\">${escapeHtml(token.text)}</a>`;\n })\n .join('');\n\n // contentEditable 在末尾是换行时可能吞掉视觉换行,补一个零宽字符占位\n if (text.endsWith('\\n')) {\n return `${html}<span data-aha-zwsp=\"true\">${ZWSP}</span>`;\n }\n return html;\n};\n\nconst getCaretOffset = (container: HTMLElement): number => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return 0;\n\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer)) return 0;\n\n const preRange = range.cloneRange();\n preRange.selectNodeContents(container);\n preRange.setEnd(range.startContainer, range.startOffset);\n return stripEditorArtifacts(preRange.toString()).length;\n};\n\nconst setCaretOffset = (container: HTMLElement, offset: number): void => {\n const range = document.createRange();\n const selection = window.getSelection();\n if (!selection) return;\n\n let remaining = Math.max(0, offset);\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_TEXT);\n let currentNode = walker.nextNode();\n\n while (currentNode) {\n const rawText = currentNode.textContent || '';\n let visibleCount = 0;\n let targetOffsetInNode = -1;\n for (let i = 0; i < rawText.length; i += 1) {\n if (rawText[i] !== ZWSP) {\n visibleCount += 1;\n }\n if (visibleCount === remaining) {\n targetOffsetInNode = i + 1;\n break;\n }\n }\n\n if (remaining === 0) {\n range.setStart(currentNode, 0);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n if (targetOffsetInNode !== -1) {\n range.setStart(currentNode, targetOffsetInNode);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n remaining -= visibleCount;\n currentNode = walker.nextNode();\n }\n\n range.selectNodeContents(container);\n range.collapse(false);\n selection.removeAllRanges();\n selection.addRange(range);\n};\n\nconst getSelectionOffsets = (\n container: HTMLElement\n): { start: number; end: number } | null => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return null;\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer) || !container.contains(range.endContainer)) {\n return null;\n }\n\n const startRange = range.cloneRange();\n startRange.selectNodeContents(container);\n startRange.setEnd(range.startContainer, range.startOffset);\n\n const endRange = range.cloneRange();\n endRange.selectNodeContents(container);\n endRange.setEnd(range.endContainer, range.endOffset);\n\n return {\n start: stripEditorArtifacts(startRange.toString()).length,\n end: stripEditorArtifacts(endRange.toString()).length,\n };\n};\n\nconst Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>(\n (\n {\n disabled = false,\n error = false,\n readOnly = false,\n showCount = false,\n maxLength,\n className = '',\n style,\n placeholder,\n value,\n defaultValue,\n rows = 3,\n autoSize = false,\n onChange,\n onFocus,\n onBlur,\n linkify = false,\n linkifyOptions,\n ...restProps\n },\n ref\n ) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const editableRef = useRef<HTMLDivElement>(null);\n const isComposingRef = useRef(false);\n const caretOffsetRef = useRef<number | null>(null);\n const [internalValue, setInternalValue] = React.useState(\n defaultValue || value || ''\n );\n const [focused, setFocused] = React.useState(false);\n const [height, setHeight] = React.useState<number | undefined>(undefined);\n\n // 合并 ref(仅原生 textarea 模式)\n useEffect(() => {\n if (typeof ref === 'function') {\n ref(linkify ? null : textareaRef.current);\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLTextAreaElement | null>).current =\n linkify ? null : textareaRef.current;\n }\n }, [ref, linkify]);\n\n // 受控/非受控处理\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n const currentLength = String(currentValue || '').length;\n\n const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n if (!isControlled) {\n setInternalValue(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const getMaxLengthValue = useMemo(\n () => (typeof maxLength === 'number' ? maxLength : undefined),\n [maxLength]\n );\n\n // 自动调整高度(原生 textarea)\n useEffect(() => {\n if (!linkify && autoSize && textareaRef.current) {\n const textarea = textareaRef.current;\n const minRows =\n typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows =\n typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n // 重置高度以获取正确的 scrollHeight\n textarea.style.height = 'auto';\n const scrollHeight = textarea.scrollHeight;\n\n // 计算行高(假设每行约 22px,根据字体大小调整)\n const lineHeight = parseInt(\n window.getComputedStyle(textarea).lineHeight || '22',\n 10\n );\n const minHeight = minRows * lineHeight;\n const maxHeight = maxRows ? maxRows * lineHeight : undefined;\n\n let newHeight = Math.max(scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n\n textarea.style.height = `${newHeight}px`;\n setHeight(newHeight);\n }\n }, [currentValue, autoSize, linkify]);\n\n // 自动调整高度(linkify + contentEditable)\n useEffect(() => {\n if (!linkify || !autoSize || !editableRef.current) return;\n const editable = editableRef.current;\n const minRows = typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows = typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n const lineHeight = parseInt(\n window.getComputedStyle(editable).lineHeight || '24',\n 10\n );\n const minHeight = minRows * lineHeight + 24;\n const maxHeight = maxRows ? maxRows * lineHeight + 24 : undefined;\n\n editable.style.height = 'auto';\n let newHeight = Math.max(editable.scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n editable.style.height = `${newHeight}px`;\n editable.style.overflowY = maxHeight && editable.scrollHeight > maxHeight ? 'auto' : 'hidden';\n setHeight(newHeight);\n }, [autoSize, currentValue, linkify]);\n\n useLayoutEffect(() => {\n if (!linkify || !editableRef.current || isComposingRef.current) return;\n const editable = editableRef.current;\n const isActive = document.activeElement === editable;\n const fallbackOffset = isActive ? getCaretOffset(editable) : 0;\n const caretOffset = caretOffsetRef.current ?? fallbackOffset;\n const nextHtml = renderTokensAsHtml(\n String(currentValue || ''),\n linkifyOptions,\n disabled\n );\n\n if (editable.innerHTML !== nextHtml) {\n editable.innerHTML = nextHtml;\n }\n\n if (isActive) {\n const maxOffset = String(currentValue || '').length;\n setCaretOffset(editable, Math.min(caretOffset, maxOffset));\n }\n caretOffsetRef.current = null;\n }, [currentValue, disabled, linkify, linkifyOptions]);\n\n const notifyChange = (nextValue: string) => {\n const syntheticEvent = {\n target: { value: nextValue },\n currentTarget: { value: nextValue },\n } as React.ChangeEvent<HTMLTextAreaElement>;\n onChange?.(syntheticEvent);\n };\n\n const handleEditableInput = () => {\n if (!editableRef.current || isComposingRef.current) return;\n caretOffsetRef.current = getCaretOffset(editableRef.current);\n const rawValue = stripEditorArtifacts(editableRef.current.textContent || '');\n const nextValue = getMaxLengthValue ? rawValue.slice(0, getMaxLengthValue) : rawValue;\n\n if (!isControlled) {\n setInternalValue(nextValue);\n }\n notifyChange(nextValue);\n };\n\n const handleEditablePaste = (e: React.ClipboardEvent<HTMLDivElement>) => {\n e.preventDefault();\n if (readOnly || disabled) return;\n\n const pastedText = e.clipboardData.getData('text/plain');\n const currentText = String(currentValue || '');\n const selection = window.getSelection();\n let nextText = `${currentText}${pastedText}`;\n let caretOffset = currentText.length + pastedText.length;\n\n if (\n selection &&\n selection.rangeCount > 0 &&\n editableRef.current?.contains(selection.anchorNode)\n ) {\n const startOffset = getCaretOffset(editableRef.current);\n const endOffset = (() => {\n const range = selection.getRangeAt(0);\n const preRange = range.cloneRange();\n preRange.selectNodeContents(editableRef.current);\n preRange.setEnd(range.endContainer, range.endOffset);\n return preRange.toString().length;\n })();\n nextText =\n currentText.slice(0, startOffset) +\n pastedText +\n currentText.slice(endOffset);\n caretOffset = startOffset + pastedText.length;\n }\n\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n caretOffset = Math.min(caretOffset, nextText.length);\n }\n caretOffsetRef.current = caretOffset;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const handleEditableKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (e.key !== 'Enter' || e.nativeEvent.isComposing) return;\n if (disabled || readOnly) return;\n if (!editableRef.current) return;\n\n e.preventDefault();\n const currentText = String(currentValue || '');\n const offsets = getSelectionOffsets(editableRef.current);\n const start = offsets?.start ?? currentText.length;\n const end = offsets?.end ?? start;\n\n let nextText = `${currentText.slice(0, start)}\\n${currentText.slice(end)}`;\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n }\n\n const nextCaret = Math.min(start + 1, nextText.length);\n caretOffsetRef.current = nextCaret;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const baseStyles: React.CSSProperties = {\n width: '100%',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px', // rounded-md\n border: `1px solid ${error ? '#F04438' : focused ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : readOnly ? '#FAFAF9' : '#FFFFFF',\n color: disabled ? '#98A2B3' : '#1C1917',\n fontSize: '16px', // text-base - 至少 16px 避免 iOS Safari 自动缩放\n fontWeight: 400,\n lineHeight: '24px',\n padding: '12px 14px', // 上下 12px,左右 14px\n boxShadow: '0 1px 2px rgba(10, 13, 18, 0.05)', // #0A0D120D 5%\n transition: 'all 0.2s',\n outline: 'none',\n resize: autoSize || linkify ? 'none' : 'vertical',\n cursor: disabled ? 'not-allowed' : 'text',\n WebkitAppearance: 'none', // 移除 iOS Safari 默认样式\n appearance: 'none',\n ...(height !== undefined && autoSize ? { height: `${height}px` } : {}),\n ...style,\n };\n\n // 占位符样式通过 CSS 类名处理\n const placeholderStyles = `\n .aha-textarea-wrapper textarea::placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-webkit-input-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-moz-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea:-ms-input-placeholder {\n color: #79716B;\n font-size: 16px;\n font-weight: 400;\n opacity: 1;\n }\n /* 移动端优化 */\n .aha-textarea-wrapper textarea {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-textarea-wrapper .aha-textarea-editable {\n white-space: pre-wrap;\n word-break: break-word;\n }\n .aha-textarea-wrapper .aha-textarea-editable:empty::before {\n content: attr(data-placeholder);\n color: #79716B;\n }\n .aha-textarea-wrapper .aha-textarea-editable a {\n color: #2563EB;\n }\n `;\n\n return (\n <>\n <style>{placeholderStyles}</style>\n <div\n className={`aha-textarea-wrapper ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n flexDirection: 'column',\n width: '100%',\n }}\n >\n {linkify ? (\n <div\n ref={editableRef}\n className=\"aha-textarea-editable\"\n contentEditable={!disabled && !readOnly}\n suppressContentEditableWarning\n role=\"textbox\"\n aria-multiline=\"true\"\n aria-disabled={disabled}\n data-placeholder={placeholder || ''}\n onInput={handleEditableInput}\n onPaste={handleEditablePaste}\n onKeyDown={handleEditableKeyDown}\n onFocus={(e) => handleFocus(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onBlur={(e) => handleBlur(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onCompositionStart={() => {\n isComposingRef.current = true;\n }}\n onCompositionEnd={() => {\n isComposingRef.current = false;\n handleEditableInput();\n }}\n style={{\n ...baseStyles,\n minHeight: autoSize ? undefined : `${rows * 24 + 24}px`,\n overflowY: autoSize ? 'hidden' : 'auto',\n }}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n />\n ) : (\n <textarea\n ref={textareaRef}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n rows={autoSize ? undefined : rows}\n maxLength={maxLength}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n style={baseStyles}\n autoComplete={restProps.autoComplete || 'off'}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n {...restProps}\n />\n )}\n {(showCount || maxLength) && (\n <div\n style={{\n display: 'flex',\n justifyContent: 'flex-end',\n marginTop: '4px',\n fontSize: '12px',\n lineHeight: '18px',\n color: disabled ? '#98A2B3' : '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {maxLength ? (\n <span>\n {currentLength} / {maxLength}\n </span>\n ) : (\n <span>{currentLength}</span>\n )}\n </div>\n )}\n </div>\n </>\n );\n }\n);\n\nTextarea.displayName = 'Textarea';\n\nexport default Textarea;\n\n","import React from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface SwitchProps {\n /** 是否选中 */\n checked?: boolean;\n /** 默认是否选中 */\n defaultChecked?: boolean;\n /** 是否禁用 */\n disabled?: boolean;\n /** 变化回调 */\n onChange?: (checked: boolean, event: React.MouseEvent) => void;\n /** 点击回调 */\n onClick?: (checked: boolean, event: React.MouseEvent) => void;\n /** 选中时的内容 */\n checkedChildren?: React.ReactNode;\n /** 非选中时的内容 */\n unCheckedChildren?: React.ReactNode;\n /** 尺寸 */\n size?: 'small' | 'default';\n /** 加载状态 */\n loading?: boolean;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n}\n\nconst Switch: React.FC<SwitchProps> = ({\n checked: controlledChecked,\n defaultChecked = false,\n disabled = false,\n onChange,\n onClick,\n checkedChildren,\n unCheckedChildren,\n size = 'default',\n loading = false,\n className = '',\n style,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const [internalChecked, setInternalChecked] = React.useState(defaultChecked);\n const isControlled = controlledChecked !== undefined;\n const checked = isControlled ? controlledChecked : internalChecked;\n\n const handleClick = (e: React.MouseEvent<HTMLButtonElement>) => {\n if (disabled || loading) return;\n\n const newChecked = !checked;\n if (!isControlled) {\n setInternalChecked(newChecked);\n }\n onChange?.(newChecked, e);\n onClick?.(newChecked, e);\n };\n\n // 尺寸配置\n const sizeConfig = {\n small: {\n width: '36px',\n height: '20px',\n thumbSize: '16px',\n thumbOffset: '2px',\n fontSize: '10px',\n },\n default: {\n width: '44px',\n height: '24px',\n thumbSize: '20px',\n thumbOffset: '2px',\n fontSize: '12px',\n },\n };\n\n const config = sizeConfig[size];\n const isChecked = checked || loading;\n\n // 背景色\n const backgroundColor = disabled\n ? '#E7E5E4'\n : isChecked\n ? primaryColor\n : '#F5F5F4';\n\n // 滑块位置 - 使用 left 定位更准确\n const thumbLeft = isChecked\n ? `calc(100% - ${config.thumbSize} - ${config.thumbOffset})`\n : config.thumbOffset;\n\n return (\n <button\n type=\"button\"\n role=\"switch\"\n aria-checked={checked}\n disabled={disabled || loading}\n onClick={handleClick}\n className={`aha-switch ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: isChecked ? 'flex-end' : 'flex-start',\n width: config.width,\n height: config.height,\n padding: '0',\n margin: '0',\n border: 'none',\n borderRadius: size === 'small' ? '10px' : '12px', // 圆角为高度的一半\n backgroundColor,\n cursor: disabled || loading ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n outline: 'none',\n boxSizing: 'border-box',\n ...style,\n }}\n >\n {/* 内容区域 */}\n {(checkedChildren || unCheckedChildren) && (\n <span\n style={{\n position: 'absolute',\n left: isChecked ? '6px' : 'auto',\n right: isChecked ? 'auto' : '6px',\n fontSize: config.fontSize,\n lineHeight: '1',\n color: '#FFFFFF',\n fontFamily: \"DM Sans, sans-serif\",\n fontWeight: 500,\n transition: 'opacity 0.2s',\n opacity: disabled ? 0.5 : 1,\n zIndex: 1,\n pointerEvents: 'none',\n }}\n >\n {isChecked ? checkedChildren : unCheckedChildren}\n </span>\n )}\n\n {/* 滑块 */}\n <span\n style={{\n position: 'absolute',\n left: thumbLeft,\n top: '50%',\n transform: 'translateY(-50%)',\n width: config.thumbSize,\n height: config.thumbSize,\n borderRadius: '50%',\n backgroundColor: '#FFFFFF',\n boxShadow: '0 2px 4px rgba(0, 0, 0, 0.2)',\n transition: 'left 0.2s, background-color 0.2s',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: 2,\n }}\n >\n {loading && (\n <svg\n width={size === 'small' ? '8' : '10'}\n height={size === 'small' ? '8' : '10'}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n style={{\n animation: 'spin 1s linear infinite',\n }}\n >\n <style>\n {`\n @keyframes spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n `}\n </style>\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"32\"\n opacity=\"0.3\"\n />\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"24\"\n />\n </svg>\n )}\n </span>\n </button>\n );\n};\n\nSwitch.displayName = 'Switch';\n\nexport default Switch;\n\n","import React, { useState, useRef, useEffect, useCallback, useMemo } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useTheme } from '../../theme/ThemeContext';\n\n// 日期范围类型\nexport interface DateRange {\n startDate: Date | null;\n endDate: Date | null;\n}\n\n// 预设日期范围类型\nexport interface PresetRange {\n label: string;\n range: DateRange;\n}\n\n// 基础 Props(单个日期模式)\nexport interface DatePickerBaseProps {\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 占位符(单个日期模式) */\n placeholder?: string;\n /** 开始日期占位符(范围模式) */\n startPlaceholder?: string;\n /** 结束日期占位符(范围模式) */\n endPlaceholder?: string;\n /** 尺寸 */\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n /** 是否允许清除 */\n allowClear?: boolean;\n /** 日期格式 */\n format?: string;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent) => void;\n /** 下拉框打开回调 */\n onOpenChange?: (open: boolean) => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 下拉框类名 */\n dropdownClassName?: string;\n /** 下拉框样式 */\n dropdownStyle?: React.CSSProperties;\n /** 是否默认打开 */\n defaultOpen?: boolean;\n /** 是否打开(受控) */\n open?: boolean;\n /** 最小日期 */\n minDate?: Date;\n /** 最大日期 */\n maxDate?: Date;\n /** 分隔符(范围模式) */\n separator?: string;\n /** 预设日期范围列表(仅在范围模式下有效) */\n presetRanges?: PresetRange[] | boolean;\n /** 显示日历数量:1=单月,2=双月(仅在范围模式下有效,默认1) */\n calendarCount?: 1 | 2;\n /** 是否显示 Apply/Cancel 按钮(仅在范围模式下有效) */\n showApplyCancel?: boolean;\n /** Apply 按钮文本 */\n applyText?: string;\n /** Cancel 按钮文本 */\n cancelText?: string;\n /** Apply 按钮回调 */\n onApply?: (range: DateRange) => void;\n /** Cancel 按钮回调 */\n onCancel?: () => void;\n /** 是否显示选中的日期段(仅在范围模式下有效,默认false) */\n showSelectedRange?: boolean;\n /** 选中的开始日期段文本 */\n startSelectedRangeText?: string;\n /** 选中的结束日期段文本 */\n endSelectedRangeText?: string;\n /** 范围显示模式:'range'=显示两个输入框(xxx - xxx),'text'=显示一句话(仅在范围模式下有效,默认'range') */\n rangeDisplayMode?: 'range' | 'text';\n}\n\n// 单个日期模式 Props\nexport interface DatePickerSingleProps extends DatePickerBaseProps {\n /** 模式:单个日期 */\n mode?: 'date';\n /** 当前选中的值 */\n value?: Date | null;\n /** 默认选中的值 */\n defaultValue?: Date | null;\n /** 变化回调 */\n onChange?: (date: Date | null) => void;\n}\n\n// 日期范围模式 Props\nexport interface DatePickerRangeProps extends DatePickerBaseProps {\n /** 模式:日期范围 */\n mode: 'range';\n /** 当前选中的值 */\n value?: DateRange;\n /** 默认选中的值 */\n defaultValue?: DateRange;\n /** 变化回调 */\n onChange?: (range: DateRange) => void;\n}\n\n// 联合类型\nexport type DatePickerProps = DatePickerSingleProps | DatePickerRangeProps;\n\n// 月份名称\nconst monthNamesShort = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\nconst monthNamesFull = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\n\n// 格式化日期\nconst formatDate = (date: Date | null, format: string = 'YYYY-MM-DD'): string => {\n if (!date) return '';\n \n const year = date.getFullYear();\n const month = date.getMonth();\n const monthNum = String(month + 1).padStart(2, '0');\n const day = String(date.getDate()).padStart(2, '0');\n const dayNum = String(date.getDate());\n \n // 使用特殊占位符避免替换冲突\n // 使用不常见的 Unicode 私有区域字符作为占位符\n const PLACEHOLDER_YYYY = '\\uE000';\n const PLACEHOLDER_YY = '\\uE001';\n const PLACEHOLDER_MMMM = '\\uE002';\n const PLACEHOLDER_MMM = '\\uE003';\n const PLACEHOLDER_MM = '\\uE004';\n const PLACEHOLDER_M = '\\uE005';\n const PLACEHOLDER_DD = '\\uE006';\n const PLACEHOLDER_D = '\\uE007';\n \n // 按从长到短的顺序替换,使用占位符避免冲突\n let result = format\n // 先替换所有格式标记为占位符\n .replace(/YYYY/g, PLACEHOLDER_YYYY)\n .replace(/YY/g, PLACEHOLDER_YY)\n .replace(/MMMM/g, PLACEHOLDER_MMMM)\n .replace(/MMM/g, PLACEHOLDER_MMM)\n .replace(/MM/g, PLACEHOLDER_MM)\n .replace(/DD/g, PLACEHOLDER_DD)\n .replace(/D/g, PLACEHOLDER_D)\n .replace(/M/g, PLACEHOLDER_M)\n // 然后将占位符替换为实际值\n .replace(new RegExp(PLACEHOLDER_YYYY, 'g'), String(year))\n .replace(new RegExp(PLACEHOLDER_YY, 'g'), String(year).slice(-2))\n .replace(new RegExp(PLACEHOLDER_MMMM, 'g'), monthNamesFull[month])\n .replace(new RegExp(PLACEHOLDER_MMM, 'g'), monthNamesShort[month])\n .replace(new RegExp(PLACEHOLDER_MM, 'g'), monthNum)\n .replace(new RegExp(PLACEHOLDER_M, 'g'), String(month + 1))\n .replace(new RegExp(PLACEHOLDER_DD, 'g'), day)\n .replace(new RegExp(PLACEHOLDER_D, 'g'), dayNum);\n \n return result;\n};\n\n// 获取月份的第一天是星期几(0=周日, 1=周一, ...)\nconst getFirstDayOfMonth = (year: number, month: number): number => {\n return new Date(year, month, 1).getDay();\n};\n\n// 获取月份的天数\nconst getDaysInMonth = (year: number, month: number): number => {\n return new Date(year, month + 1, 0).getDate();\n};\n\n// 判断两个日期是否是同一天\nconst isSameDay = (date1: Date | null, date2: Date | null): boolean => {\n if (!date1 || !date2) return false;\n return (\n date1.getFullYear() === date2.getFullYear() &&\n date1.getMonth() === date2.getMonth() &&\n date1.getDate() === date2.getDate()\n );\n};\n\n// 判断日期是否在范围内\nconst isDateInRange = (date: Date, minDate?: Date, maxDate?: Date): boolean => {\n if (minDate && date < minDate) return false;\n if (maxDate && date > maxDate) return false;\n return true;\n};\n\n// 判断日期是否在选择的范围内\nconst isDateInSelectedRange = (date: Date, startDate: Date | null, endDate: Date | null): boolean => {\n if (!startDate || !endDate) return false;\n const dateTime = date.getTime();\n const startTime = startDate.getTime();\n const endTime = endDate.getTime();\n return dateTime >= startTime && dateTime <= endTime;\n};\n\n// 判断日期是否是范围的开始或结束\nconst isRangeEdge = (date: Date, startDate: Date | null, endDate: Date | null): 'start' | 'end' | 'both' | null => {\n if (!startDate || !endDate) return null;\n const isStart = isSameDay(date, startDate);\n const isEnd = isSameDay(date, endDate);\n if (isStart && isEnd) return 'both';\n if (isStart) return 'start';\n if (isEnd) return 'end';\n return null;\n};\n\nconst DatePicker: React.FC<DatePickerProps> = (props) => {\n const {\n mode = 'date',\n disabled = false,\n error = false,\n placeholder = 'Select date',\n startPlaceholder = 'Start date',\n endPlaceholder = 'End date',\n size = 'medium',\n allowClear = false,\n format = mode === 'range' ? 'MMM D, YYYY' : 'YYYY-MM-DD',\n onFocus,\n onBlur,\n onOpenChange,\n className = '',\n style,\n dropdownClassName = '',\n dropdownStyle,\n defaultOpen = false,\n open: controlledOpen,\n minDate,\n maxDate,\n separator = ' - ',\n presetRanges = false,\n calendarCount = 1,\n showApplyCancel = false,\n applyText = 'Apply',\n cancelText = 'Cancel',\n onApply,\n onCancel,\n showSelectedRange = false,\n startSelectedRangeText = 'Select dates',\n endSelectedRangeText = 'Select dates',\n rangeDisplayMode = 'range',\n } = props;\n\n const { primaryColor = '#FB6011' } = useTheme();\n const isRangeMode = mode === 'range';\n\n // 单个日期模式的状态\n const [internalSingleValue, setInternalSingleValue] = useState<Date | null>(() => {\n if (mode === 'date' && 'defaultValue' in props) {\n const val = props.defaultValue as Date | null | undefined;\n return val || null;\n }\n return null;\n });\n \n // 范围模式的状态\n const [internalRangeValue, setInternalRangeValue] = useState<DateRange>(() => {\n if (mode === 'range' && 'defaultValue' in props) {\n const val = props.defaultValue as DateRange | undefined;\n return val || { startDate: null, endDate: null };\n }\n return { startDate: null, endDate: null };\n });\n\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [selectingStart, setSelectingStart] = useState(true); // 范围模式:true=选择开始日期, false=选择结束日期\n const [tempRangeValue, setTempRangeValue] = useState<DateRange | null>(null); // 临时范围值(用于 Apply/Cancel)\n const [currentMonth, setCurrentMonth] = useState(() => {\n if (mode === 'date' && 'value' in props && props.value) {\n const date = props.value as Date | null;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n if (mode === 'range' && 'value' in props && props.value) {\n const range = props.value as DateRange;\n const date = range.startDate || range.endDate;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n if (mode === 'date' && 'defaultValue' in props && props.defaultValue) {\n const date = props.defaultValue as Date | null;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n if (mode === 'range' && 'defaultValue' in props && props.defaultValue) {\n const range = props.defaultValue as DateRange;\n const date = range.startDate || range.endDate;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n const now = new Date();\n return { year: now.getFullYear(), month: now.getMonth() };\n });\n \n // 第二个月份(用于双月显示)\n const [secondMonth, setSecondMonth] = useState<{ year: number; month: number } | null>(() => {\n if (calendarCount === 2 && isRangeMode) {\n const nextMonth = new Date(currentMonth.year, currentMonth.month + 1, 1);\n return { year: nextMonth.getFullYear(), month: nextMonth.getMonth() };\n }\n return null;\n });\n \n // 当第一个月份变化时,更新第二个月份\n useEffect(() => {\n if (calendarCount === 2 && isRangeMode) {\n const nextMonth = new Date(currentMonth.year, currentMonth.month + 1, 1);\n setSecondMonth({ year: nextMonth.getFullYear(), month: nextMonth.getMonth() });\n } else {\n setSecondMonth(null);\n }\n }, [currentMonth, calendarCount, isRangeMode]);\n\n const pickerRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const startInputRef = useRef<HTMLInputElement>(null);\n const endInputRef = useRef<HTMLInputElement>(null);\n const dropdownRef = useRef<HTMLDivElement>(null);\n const [dropdownPosition, setDropdownPosition] = useState<{ top: number; left: number; width: number; placement?: 'top' | 'bottom' } | null>(null);\n const hasOpenedRef = useRef(false); // 跟踪日历是否已经打开过\n const placementDeterminedRef = useRef(false); // 跟踪位置方向是否已确定\n const determinedPlacementRef = useRef<'top' | 'bottom' | null>(null); // 已确定的位置方向\n\n // 判断是否受控\n const isControlled = 'value' in props && props.value !== undefined;\n const isOpenControlled = controlledOpen !== undefined;\n \n // 当前值\n const currentSingleValue: Date | null = isRangeMode\n ? null\n : isControlled && mode === 'date' && 'value' in props\n ? (props.value as Date | null)\n : internalSingleValue;\n \n const currentRangeValue: DateRange = !isRangeMode\n ? { startDate: null, endDate: null }\n : isControlled && mode === 'range' && 'value' in props\n ? (props.value as DateRange) || { startDate: null, endDate: null }\n : internalRangeValue;\n\n const isOpen = isOpenControlled ? controlledOpen : internalOpen;\n\n // 当日历首次打开时,如果当前月份与选中日期月份不一致,才更新月份视图\n // 之后用户切换月份后,即使选择日期,也不应该自动更新月份\n useEffect(() => {\n if (isOpen && !hasOpenedRef.current) {\n // 首次打开时,根据选中日期设置月份\n if (isRangeMode) {\n const date = currentRangeValue.startDate || currentRangeValue.endDate;\n if (date) {\n const dateYear = date.getFullYear();\n const dateMonth = date.getMonth();\n setCurrentMonth({\n year: dateYear,\n month: dateMonth,\n });\n } else {\n // 如果没有选中日期,设置为当前月份\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n } else {\n if (currentSingleValue) {\n const dateYear = currentSingleValue.getFullYear();\n const dateMonth = currentSingleValue.getMonth();\n setCurrentMonth({\n year: dateYear,\n month: dateMonth,\n });\n } else {\n // 如果没有选中日期,设置为当前月份\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n hasOpenedRef.current = true;\n } else if (!isOpen) {\n // 日历关闭时,重置标记,下次打开时重新判断\n hasOpenedRef.current = false;\n }\n }, [isOpen, currentSingleValue, currentRangeValue, isRangeMode]);\n\n // 计算下拉框位置\n useEffect(() => {\n if (isOpen && pickerRef.current) {\n // 重置位置方向确定标记\n placementDeterminedRef.current = false;\n determinedPlacementRef.current = null;\n \n const updatePosition = () => {\n if (pickerRef.current) {\n const rect = pickerRef.current.getBoundingClientRect();\n const gap = 4; // 下拉框与输入框的间距\n \n // 如果位置方向已经确定,只更新坐标,不改变方向\n if (placementDeterminedRef.current && determinedPlacementRef.current !== null) {\n const placement = determinedPlacementRef.current;\n let top: number;\n \n if (dropdownRef.current) {\n const dropdownHeight = dropdownRef.current.offsetHeight;\n if (placement === 'top') {\n top = rect.top + window.scrollY - dropdownHeight - gap;\n } else {\n top = rect.bottom + window.scrollY + gap;\n }\n } else {\n // 如果下拉框还没渲染,使用默认计算\n top = placement === 'top' \n ? rect.top + window.scrollY - 400 - gap // 估算高度\n : rect.bottom + window.scrollY + gap;\n }\n \n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement,\n });\n return;\n }\n \n // 首次打开时,计算位置方向\n // 先设置为下方位置(默认)\n let top = rect.bottom + window.scrollY + gap;\n let placement: 'top' | 'bottom' = 'bottom';\n \n // 计算位置的函数\n const calculatePosition = () => {\n if (dropdownRef.current) {\n const dropdownHeight = dropdownRef.current.offsetHeight;\n const viewportHeight = window.innerHeight;\n const spaceBelow = viewportHeight - rect.bottom - gap;\n const spaceAbove = rect.top - gap;\n \n // 如果下方空间不够,但上方空间足够,则显示在上方\n if (spaceBelow < dropdownHeight && spaceAbove >= dropdownHeight) {\n top = rect.top + window.scrollY - dropdownHeight - gap;\n placement = 'top';\n } else if (spaceBelow < dropdownHeight && spaceAbove < dropdownHeight) {\n // 如果上下都不够,选择空间更大的那一侧\n if (spaceAbove > spaceBelow) {\n top = rect.top + window.scrollY - dropdownHeight - gap;\n placement = 'top';\n }\n // 否则保持下方(即使可能被裁剪,也比上方好)\n }\n \n // 确定位置方向\n placementDeterminedRef.current = true;\n determinedPlacementRef.current = placement;\n }\n \n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement,\n });\n };\n \n // 先设置默认位置,让下拉框先渲染\n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement,\n });\n \n // 等待下拉框渲染后,重新计算位置\n // 使用双重 requestAnimationFrame 确保 DOM 已完全渲染\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n calculatePosition();\n });\n });\n }\n };\n\n updatePosition();\n\n window.addEventListener('resize', updatePosition);\n window.addEventListener('scroll', updatePosition, true);\n\n return () => {\n window.removeEventListener('resize', updatePosition);\n window.removeEventListener('scroll', updatePosition, true);\n };\n } else {\n setDropdownPosition(null);\n // 关闭时重置标记\n placementDeterminedRef.current = false;\n determinedPlacementRef.current = null;\n }\n }, [isOpen]);\n\n // 点击外部关闭\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent | TouchEvent) => {\n const target = event.target as Node;\n if (\n pickerRef.current &&\n !pickerRef.current.contains(target) &&\n dropdownRef.current &&\n !dropdownRef.current.contains(target)\n ) {\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n };\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside, true);\n document.addEventListener('touchstart', handleClickOutside, true);\n return () => {\n document.removeEventListener('mousedown', handleClickOutside, true);\n document.removeEventListener('touchstart', handleClickOutside, true);\n };\n }\n }, [isOpen, isOpenControlled, onOpenChange]);\n\n // 处理日期选择(单个日期模式)\n const handleSelectSingleDate = useCallback((date: Date) => {\n if (!isDateInRange(date, minDate, maxDate)) return;\n\n if (!isControlled) {\n setInternalSingleValue(date);\n }\n if (mode === 'date' && 'onChange' in props) {\n (props.onChange as (date: Date | null) => void)?.(date);\n }\n\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }, [isControlled, isOpenControlled, mode, props, onOpenChange, minDate, maxDate]);\n\n // 处理日期选择(范围模式)\n const handleSelectRangeDate = useCallback((date: Date) => {\n if (!isDateInRange(date, minDate, maxDate)) return;\n\n // 使用临时值或当前值\n const workingRange = showApplyCancel && tempRangeValue ? tempRangeValue : currentRangeValue;\n let newRange: DateRange;\n\n // 如果已经有完整的日期范围(开始和结束日期都存在),重新点击日期时清空之前的选择\n if (workingRange.startDate && workingRange.endDate) {\n // 清空之前的选择,将新点击的日期作为新的开始日期\n newRange = {\n startDate: date,\n endDate: null,\n };\n setSelectingStart(false); // 下一步选择结束日期\n } else if (selectingStart) {\n // 选择开始日期\n if (workingRange.endDate && date > workingRange.endDate) {\n // 如果选择的开始日期大于结束日期,交换它们\n newRange = {\n startDate: workingRange.endDate,\n endDate: date,\n };\n setSelectingStart(false);\n } else {\n newRange = {\n startDate: date,\n endDate: workingRange.endDate,\n };\n // 如果已经有结束日期,完成选择\n if (workingRange.endDate) {\n setSelectingStart(true);\n if (!showApplyCancel) {\n // 如果没有 Apply/Cancel 按钮,直接关闭\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n } else {\n setSelectingStart(false);\n }\n }\n } else {\n // 选择结束日期\n if (workingRange.startDate && date < workingRange.startDate) {\n // 如果选择的结束日期小于开始日期,交换它们\n newRange = {\n startDate: date,\n endDate: workingRange.startDate,\n };\n setSelectingStart(false);\n } else {\n newRange = {\n startDate: workingRange.startDate,\n endDate: date,\n };\n // 完成选择\n setSelectingStart(true);\n if (!showApplyCancel) {\n // 如果没有 Apply/Cancel 按钮,直接关闭\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n }\n }\n\n if (showApplyCancel) {\n // 使用临时值\n setTempRangeValue(newRange);\n } else {\n // 直接更新\n if (!isControlled) {\n setInternalRangeValue(newRange);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(newRange);\n }\n }\n }, [selectingStart, currentRangeValue, tempRangeValue, showApplyCancel, isControlled, isOpenControlled, mode, props, onOpenChange, minDate, maxDate]);\n\n // 处理清除\n const handleClear = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (isRangeMode) {\n const newRange: DateRange = { startDate: null, endDate: null };\n if (!isControlled) {\n setInternalRangeValue(newRange);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(newRange);\n }\n setSelectingStart(true);\n } else {\n if (!isControlled) {\n setInternalSingleValue(null);\n }\n if (mode === 'date' && 'onChange' in props) {\n (props.onChange as (date: Date | null) => void)?.(null);\n }\n }\n // 清空后,只有在日历关闭时才重置月份为当前月份\n // 如果日历是打开的,保持当前显示的月份不变\n if (!isOpen) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n };\n\n // 切换下拉框\n const handleToggle = () => {\n if (disabled) return;\n const newOpen = !isOpen;\n if (!isOpenControlled) {\n setInternalOpen(newOpen);\n }\n onOpenChange?.(newOpen);\n if (newOpen) {\n // 打开日历时,如果没有选中日期,设置为当前月份\n if (isRangeMode) {\n setSelectingStart(!currentRangeValue.startDate);\n // 初始化临时值\n if (showApplyCancel) {\n setTempRangeValue(currentRangeValue);\n }\n // 如果没有选中日期,设置为当前月份\n if (!currentRangeValue.startDate && !currentRangeValue.endDate) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n } else {\n // 如果没有选中日期,设置为当前月份\n if (!currentSingleValue) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n } else if (!newOpen && showApplyCancel) {\n // 关闭时重置临时值\n setTempRangeValue(null);\n }\n };\n \n // 处理 Apply 按钮\n const handleApply = () => {\n if (tempRangeValue) {\n if (!isControlled) {\n setInternalRangeValue(tempRangeValue);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(tempRangeValue);\n }\n onApply?.(tempRangeValue);\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n setTempRangeValue(null);\n }\n };\n \n // 处理 Cancel 按钮\n const handleCancel = () => {\n setTempRangeValue(null);\n onCancel?.();\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n };\n \n // 默认预设日期范围\n const defaultPresetRanges = useMemo(() => {\n const today = new Date();\n today.setHours(0, 0, 0, 0);\n \n // Last week: 从当前日期往前推7天(包含今天,共7天)\n const lastWeekEnd = new Date(today);\n const lastWeekStart = new Date(today);\n lastWeekStart.setDate(today.getDate() - 6); // 往前推6天,加上今天共7天\n \n // Last month: 从当前日期往前推一个月\n const lastMonthEnd = new Date(today);\n const lastMonthStart = new Date(today);\n const originalDate = today.getDate();\n lastMonthStart.setMonth(today.getMonth() - 1);\n // 如果往前推一个月后日期被调整了(比如3月31日往前推一个月变成3月3日,因为2月没有31日),\n // 说明原日期在上个月不存在,需要取上个月的最后一天\n if (lastMonthStart.getDate() !== originalDate) {\n // 设置为上个月的最后一天\n lastMonthStart.setDate(0);\n }\n \n // Last year: 从当前日期往前推一年\n const lastYearEnd = new Date(today);\n const lastYearStart = new Date(today);\n lastYearStart.setFullYear(today.getFullYear() - 1);\n \n return [\n { label: 'Last week', range: { startDate: lastWeekStart, endDate: lastWeekEnd } },\n { label: 'Last month', range: { startDate: lastMonthStart, endDate: lastMonthEnd } },\n { label: 'Last year', range: { startDate: lastYearStart, endDate: lastYearEnd } },\n ];\n }, []);\n\n // 预设日期范围列表\n const presetRangesList = useMemo(() => {\n if (Array.isArray(presetRanges)) {\n // 如果传入的是数组,直接使用\n return presetRanges;\n } else if (presetRanges === true) {\n // 如果传入的是 true,使用默认值\n return defaultPresetRanges;\n } else {\n // 如果传入的是 false 或 undefined,返回空数组\n return [];\n }\n }, [presetRanges, defaultPresetRanges]);\n\n // 是否显示预设日期范围\n const hasPresetRanges = presetRangesList.length > 0;\n \n // 处理预设范围选择\n const handlePresetRangeSelect = (range: DateRange) => {\n // 更新日历显示为开始日期的月份\n if (range.startDate) {\n const startYear = range.startDate.getFullYear();\n const startMonth = range.startDate.getMonth();\n setCurrentMonth({\n year: startYear,\n month: startMonth,\n });\n }\n \n if (showApplyCancel) {\n setTempRangeValue(range);\n } else {\n if (!isControlled) {\n setInternalRangeValue(range);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(range);\n }\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n };\n\n // 处理输入框聚焦\n const handleFocus = (e: React.FocusEvent) => {\n onFocus?.(e);\n };\n\n // 处理输入框失焦\n const handleBlur = (e: React.FocusEvent) => {\n onBlur?.(e);\n };\n\n // 处理开始日期输入框点击\n const handleStartInputClick = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!disabled) {\n setSelectingStart(true);\n if (!isOpen) {\n handleToggle();\n } else {\n // 如果日历已经打开,检查是否需要重置月份\n if (!currentRangeValue.startDate && !currentRangeValue.endDate) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n }\n };\n\n // 处理结束日期输入框点击\n const handleEndInputClick = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!disabled) {\n setSelectingStart(false);\n if (!isOpen) {\n handleToggle();\n } else {\n // 如果日历已经打开,检查是否需要重置月份\n if (!currentRangeValue.startDate && !currentRangeValue.endDate) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n }\n };\n\n // 上一个月\n const handlePrevMonth = () => {\n setCurrentMonth((prev) => {\n if (prev.month === 0) {\n return { year: prev.year - 1, month: 11 };\n }\n return { year: prev.year, month: prev.month - 1 };\n });\n };\n\n // 下一个月\n const handleNextMonth = () => {\n setCurrentMonth((prev) => {\n if (prev.month === 11) {\n return { year: prev.year + 1, month: 0 };\n }\n return { year: prev.year, month: prev.month + 1 };\n });\n };\n\n // 生成日历数据的辅助函数\n const generateCalendarData = useCallback((year: number, month: number) => {\n const daysInMonth = getDaysInMonth(year, month);\n const days: (Date | null)[] = [];\n\n // 只生成当前月的日期\n for (let day = 1; day <= daysInMonth; day++) {\n days.push(new Date(year, month, day));\n }\n\n return days;\n }, []);\n\n // 生成日历数据\n const calendarData = useMemo(() => {\n return generateCalendarData(currentMonth.year, currentMonth.month);\n }, [currentMonth, generateCalendarData]);\n \n // 生成第二个月份的日历数据\n const secondCalendarData = useMemo(() => {\n if (calendarCount === 2 && isRangeMode && secondMonth) {\n return generateCalendarData(secondMonth.year, secondMonth.month);\n }\n return null;\n }, [calendarCount, isRangeMode, secondMonth, generateCalendarData]);\n \n // 处理第二个月份的导航\n const handleSecondPrevMonth = () => {\n if (secondMonth) {\n setSecondMonth((prev) => {\n if (!prev) return null;\n if (prev.month === 0) {\n return { year: prev.year - 1, month: 11 };\n }\n return { year: prev.year, month: prev.month - 1 };\n });\n }\n };\n \n const handleSecondNextMonth = () => {\n if (secondMonth) {\n setSecondMonth((prev) => {\n if (!prev) return null;\n if (prev.month === 11) {\n return { year: prev.year + 1, month: 0 };\n }\n return { year: prev.year, month: prev.month + 1 };\n });\n }\n };\n\n // 尺寸样式\n const sizeStyles = {\n small: {\n height: '32px',\n paddingTop: '3px',\n paddingBottom: '3px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n mediumSmall: {\n height: '36px',\n paddingTop: '5px',\n paddingBottom: '5px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n medium: {\n height: '40px',\n paddingTop: '7px',\n paddingBottom: '7px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n large: {\n height: '48px',\n paddingTop: '11px',\n paddingBottom: '11px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n };\n\n const showClear = allowClear && !disabled && (\n isRangeMode\n ? (currentRangeValue.startDate || currentRangeValue.endDate)\n : currentSingleValue\n );\n \n const singleDisplayValue = currentSingleValue ? formatDate(currentSingleValue, format) : '';\n const startDisplayValue = currentRangeValue.startDate ? formatDate(currentRangeValue.startDate, format) : '';\n const endDisplayValue = currentRangeValue.endDate ? formatDate(currentRangeValue.endDate, format) : '';\n \n // 计算范围文本显示值(当 rangeDisplayMode === 'text' 时使用)\n const rangeTextValue = useMemo(() => {\n if (!isRangeMode || rangeDisplayMode !== 'text') return '';\n \n // 默认格式化:如果两个日期都有,显示 \"Jan 10, 2025 - Jan 20, 2025\"\n // 如果只有一个日期,显示该日期\n // 如果都没有,返回空字符串\n if (currentRangeValue.startDate && currentRangeValue.endDate) {\n const startText = formatDate(currentRangeValue.startDate, 'MMM D, YYYY');\n const endText = formatDate(currentRangeValue.endDate, 'MMM D, YYYY');\n return `${startText} ${separator} ${endText}`;\n } else if (currentRangeValue.startDate) {\n return formatDate(currentRangeValue.startDate, 'MMM D, YYYY');\n } else if (currentRangeValue.endDate) {\n return formatDate(currentRangeValue.endDate, 'MMM D, YYYY');\n }\n return '';\n }, [isRangeMode, rangeDisplayMode, currentRangeValue, separator]);\n\n // 日历图标\n const CalendarIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M12.6667 2.66667H12V2C12 1.63181 11.7015 1.33333 11.3333 1.33333C10.9651 1.33333 10.6667 1.63181 10.6667 2V2.66667H5.33333V2C5.33333 1.63181 5.03486 1.33333 4.66667 1.33333C4.29848 1.33333 4 1.63181 4 2V2.66667H3.33333C2.59695 2.66667 2 3.26362 2 4V13.3333C2 14.0697 2.59695 14.6667 3.33333 14.6667H12.6667C13.403 14.6667 14 14.0697 14 13.3333V4C14 3.26362 13.403 2.66667 12.6667 2.66667ZM12.6667 13.3333H3.33333V7.33333H12.6667V13.3333ZM12.6667 6H3.33333V4H12.6667V6Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n\n // 清除图标\n const ClearIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n onClick={handleClear}\n style={{\n cursor: 'pointer',\n flexShrink: 0,\n color: '#78716C',\n }}\n >\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n // 下拉框动画样式\n const dropdownAnimationStyles = `\n @keyframes dropdownFadeIn {\n from {\n opacity: 0;\n transform: translateY(-8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n @keyframes dropdownFadeInTop {\n from {\n opacity: 0;\n transform: translateY(8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n `;\n\n // 周几名称(周一开始)\n const weekDays = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];\n\n return (\n <>\n <style>{dropdownAnimationStyles}</style>\n <div\n ref={pickerRef}\n className={`aha-date-picker ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px',\n border: `1px solid ${error ? '#F04438' : isOpen ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : '#FFFFFF',\n cursor: disabled ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n paddingLeft: '40px', // 为日历图标留出空间\n paddingRight: showClear ? '30px' : '12px', // 为清除按钮留出空间(如果有)\n paddingTop: sizeStyles[size].paddingTop,\n paddingBottom: sizeStyles[size].paddingBottom,\n fontSize: sizeStyles[size].fontSize,\n lineHeight: sizeStyles[size].lineHeight,\n fontWeight: 400,\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n touchAction: 'manipulation',\n userSelect: 'none',\n ...style,\n }}\n onClick={handleToggle}\n onFocus={handleFocus}\n onBlur={handleBlur}\n tabIndex={disabled ? -1 : 0}\n >\n {/* 日历图标 */}\n <span\n style={{\n position: 'absolute',\n left: '12px',\n display: 'flex',\n alignItems: 'center',\n color: disabled ? '#98A2B3' : '#78716C',\n zIndex: 1,\n pointerEvents: 'none',\n }}\n >\n <CalendarIcon />\n </span>\n\n {/* 输入框内容 */}\n {isRangeMode ? (\n rangeDisplayMode === 'text' ? (\n // 文本模式:显示单个输入框,显示格式化后的范围文本\n <input\n ref={inputRef}\n type=\"text\"\n value={rangeTextValue}\n readOnly\n placeholder={placeholder}\n disabled={disabled}\n onClick={(e) => {\n e.stopPropagation();\n if (!disabled) {\n handleToggle();\n }\n }}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : (currentRangeValue.startDate || currentRangeValue.endDate) ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n ) : (\n // 范围模式:显示两个输入框\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n flex: 1,\n gap: '8px',\n minWidth: 0,\n }}\n >\n {/* 开始日期输入框 */}\n <input\n ref={startInputRef}\n type=\"text\"\n value={startDisplayValue}\n readOnly\n placeholder={startPlaceholder}\n disabled={disabled}\n onClick={handleStartInputClick}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : currentRangeValue.startDate ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n\n {/* 分隔符 */}\n <span\n style={{\n color: disabled ? '#98A2B3' : '#78716C',\n fontSize: '16px',\n flexShrink: 0,\n }}\n >\n {separator}\n </span>\n\n {/* 结束日期输入框 */}\n <input\n ref={endInputRef}\n type=\"text\"\n value={endDisplayValue}\n readOnly\n placeholder={endPlaceholder}\n disabled={disabled}\n onClick={handleEndInputClick}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : currentRangeValue.endDate ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n </div>\n )\n ) : (\n <input\n ref={inputRef}\n type=\"text\"\n value={singleDisplayValue}\n readOnly\n placeholder={placeholder}\n disabled={disabled}\n onClick={(e) => {\n e.stopPropagation();\n if (!disabled) {\n handleToggle();\n }\n }}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : currentSingleValue ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n )}\n\n {/* 右侧图标 */}\n {showClear && (\n <div\n style={{\n position: 'absolute',\n right: '10px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n }}\n >\n <ClearIcon />\n </div>\n )}\n </div>\n\n {/* 日历下拉框 */}\n {isOpen && dropdownPosition && createPortal(\n <div\n ref={dropdownRef}\n className={`aha-date-picker-dropdown ${dropdownClassName}`}\n style={{\n position: 'absolute',\n top: `${dropdownPosition.top}px`,\n left: `${dropdownPosition.left}px`,\n zIndex: 1050,\n backgroundColor: '#FFFFFF',\n borderRadius: '8px',\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.15)',\n border: '1px solid #E7E5E4',\n padding: '0',\n opacity: 0,\n transform: (dropdownPosition.placement || 'bottom') === 'top' ? 'translateY(8px)' : 'translateY(-8px)',\n animation: (dropdownPosition.placement || 'bottom') === 'top' \n ? 'dropdownFadeInTop 0.2s ease-out forwards' \n : 'dropdownFadeIn 0.2s ease-out forwards',\n display: 'flex',\n flexDirection: 'column',\n ...dropdownStyle,\n }}\n >\n {/* 内容区域 */}\n <div\n style={{\n display: 'flex',\n flex: 1,\n minHeight: 0,\n flexDirection: isRangeMode && hasPresetRanges && calendarCount === 1 ? 'column' : 'row',\n }}\n >\n {/* 预设日期范围列表(左侧 - 仅双月模式) */}\n {isRangeMode && hasPresetRanges && calendarCount === 2 && (\n <div\n style={{\n width: '140px',\n borderRight: '1px solid #E7E5E4',\n padding: '12px 0',\n backgroundColor: '#FFFFFF',\n borderTopLeftRadius: '8px',\n borderBottomLeftRadius: showApplyCancel ? '0' : '8px',\n }}\n >\n {presetRangesList.map((preset, idx) => {\n const isSelected = tempRangeValue\n ? isSameDay(preset.range.startDate, tempRangeValue.startDate) &&\n isSameDay(preset.range.endDate, tempRangeValue.endDate)\n : isSameDay(preset.range.startDate, currentRangeValue.startDate) &&\n isSameDay(preset.range.endDate, currentRangeValue.endDate);\n \n return (\n <div\n key={idx}\n onClick={() => handlePresetRangeSelect(preset.range)}\n style={{\n padding: '8px 16px',\n cursor: 'pointer',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n color: isSelected ? primaryColor : '#1C1917',\n backgroundColor: isSelected ? '#FAFAF9' : 'transparent',\n fontWeight: isSelected ? 500 : 400,\n transition: 'all 0.2s',\n }}\n onMouseEnter={(e) => {\n if (!isSelected) {\n e.currentTarget.style.backgroundColor = '#F5F5F4';\n }\n }}\n onMouseLeave={(e) => {\n if (!isSelected) {\n e.currentTarget.style.backgroundColor = 'transparent';\n }\n }}\n >\n {preset.label}\n </div>\n );\n })}\n </div>\n )}\n <div>\n {/* 日历区域 */}\n <div\n style={{\n flex: 1,\n padding: '16px',\n display: 'flex',\n flexDirection: calendarCount === 2 ? 'row' : 'column',\n gap: calendarCount === 2 ? '24px' : '0',\n }}\n >\n \n {/* 渲染第一个日历 */}\n {(() => {\n const renderCalendar = (\n monthData: { year: number; month: number },\n calendarDays: (Date | null)[],\n onPrevMonth: () => void,\n onNextMonth: () => void,\n monthIndex: number = 0\n ) => (\n <div\n key={monthIndex}\n style={{\n flex: 1,\n display: 'flex',\n flexDirection: 'column',\n }}\n >\n {/* 月份导航 */}\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: calendarCount === 2 && isRangeMode ? 'center' : 'space-between',\n marginBottom: '16px',\n position: 'relative',\n }}\n >\n {/* 左侧月份(monthIndex === 0)在两个月模式下隐藏左箭头,右侧月份(monthIndex === 1)在两个月模式下隐藏左箭头 */}\n {!(calendarCount === 2 && isRangeMode && monthIndex === 1) && (\n <button\n type=\"button\"\n onClick={onPrevMonth}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '32px',\n height: '32px',\n border: 'none',\n background: 'transparent',\n cursor: 'pointer',\n borderRadius: '4px',\n color: '#78716C',\n transition: 'all 0.2s',\n position: calendarCount === 2 && isRangeMode ? 'absolute' : 'relative',\n left: calendarCount === 2 && isRangeMode ? 0 : undefined,\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'transparent';\n }}\n >\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path\n d=\"M10 12L6 8L10 4\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n )}\n\n <div\n style={{\n fontSize: '16px',\n fontWeight: 500,\n color: '#1C1917',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {monthNamesFull[monthData.month]} {monthData.year}\n </div>\n\n {/* 左侧月份(monthIndex === 0)在两个月模式下隐藏右箭头 */}\n {!(calendarCount === 2 && isRangeMode && monthIndex === 0) && (\n <button\n type=\"button\"\n onClick={onNextMonth}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '32px',\n height: '32px',\n border: 'none',\n background: 'transparent',\n cursor: 'pointer',\n borderRadius: '4px',\n color: '#78716C',\n transition: 'all 0.2s',\n position: calendarCount === 2 && isRangeMode ? 'absolute' : 'relative',\n right: calendarCount === 2 && isRangeMode ? 0 : undefined,\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'transparent';\n }}\n >\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path\n d=\"M6 4L10 8L6 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n )}\n </div>\n\n {/* 显示选中的日期段(单月模式,在月份导航下面) */}\n {isRangeMode && showSelectedRange && calendarCount === 1 && monthIndex === 0 && (() => {\n const workingRange = showApplyCancel && tempRangeValue ? tempRangeValue : currentRangeValue;\n \n // 使用固定的 \"MMM D, YYYY\" 格式显示日期(如 \"Jan 10, 2025\")\n const startText = workingRange.startDate ? formatDate(workingRange.startDate, 'MMM D, YYYY') : startSelectedRangeText;\n const endText = workingRange.endDate ? formatDate(workingRange.endDate, 'MMM D, YYYY') : endSelectedRangeText;\n \n return (\n <div\n className='flex items-center gap-2'\n style={{\n fontSize: '14px',\n marginBottom: '16px',\n }}\n >\n <div \n className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.startDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}\n >{startText}</div>\n <div>{separator}</div>\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.endDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{endText}</div>\n </div>\n );\n })()}\n\n {/* 预设日期范围列表(上方 - 仅单月模式) */}\n {isRangeMode && hasPresetRanges && calendarCount === 1 && (\n <div\n style={{\n width: '252px',\n display: 'flex',\n flexWrap: 'wrap',\n paddingBottom: '16px',\n }}\n >\n {presetRangesList.map((preset, idx) => {\n const isSelected = tempRangeValue\n ? isSameDay(preset.range.startDate, tempRangeValue.startDate) &&\n isSameDay(preset.range.endDate, tempRangeValue.endDate)\n : isSameDay(preset.range.startDate, currentRangeValue.startDate) &&\n isSameDay(preset.range.endDate, currentRangeValue.endDate);\n \n return (\n <button\n key={idx}\n type=\"button\"\n onClick={() => handlePresetRangeSelect(preset.range)}\n style={{\n padding: '4px 8px',\n cursor: 'pointer',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n color: isSelected ? primaryColor : '#1C1917',\n backgroundColor: isSelected ? '#FAFAF9' : 'transparent',\n border: 'none',\n fontWeight: isSelected ? 500 : 400,\n transition: 'all 0.2s',\n borderRadius: '4px',\n }}\n >\n {preset.label}\n </button>\n );\n })}\n </div>\n )}\n\n {/* 星期标题 */}\n <div\n style={{\n width: '252px',\n display: 'grid',\n gridTemplateColumns: 'repeat(7, 1fr)',\n marginBottom: '8px',\n }}\n >\n {weekDays.map((day) => (\n <div\n key={day}\n style={{\n width: '36px',\n textAlign: 'center',\n fontSize: '12px',\n fontWeight: 500,\n color: '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n padding: '4px',\n }}\n >\n {day}\n </div>\n ))}\n </div>\n\n {/* 日期网格 */}\n <div\n style={{\n width: '252px',\n display: 'grid',\n gridTemplateColumns: 'repeat(7, 1fr)',\n rowGap: '4px',\n columnGap: '0px',\n }}\n >\n {(() => {\n // 计算第一天是星期几(0=周日, 1=周一, ...)\n const firstDay = getFirstDayOfMonth(monthData.year, monthData.month);\n // 将周日(0)转换为7,使周一作为第一天\n const firstDayOfWeek = firstDay === 0 ? 7 : firstDay;\n const offset = firstDayOfWeek - 1; // 需要偏移的空格数\n \n const cells: React.ReactNode[] = [];\n \n // 添加前面的空单元格\n for (let i = 0; i < offset; i++) {\n cells.push(<div key={`empty-${i}`} />);\n }\n \n // 添加当前月的日期\n calendarDays.forEach((date, index) => {\n if (!date) return;\n \n const actualIndex = offset + index;\n const isCurrentMonth = date.getMonth() === monthData.month;\n const isToday = isSameDay(date, new Date());\n const isDisabled = !isDateInRange(date, minDate, maxDate);\n\n if (isRangeMode) {\n // 范围模式 - 使用临时值或当前值\n const workingRange = showApplyCancel && tempRangeValue ? tempRangeValue : currentRangeValue;\n const isStartDate = isSameDay(date, workingRange.startDate);\n const isEndDate = isSameDay(date, workingRange.endDate);\n const isInRange = isDateInSelectedRange(date, workingRange.startDate, workingRange.endDate);\n\n // 判断是否是行的第一个或最后一个(基于 actualIndex,包含空单元格)\n const isFirstInRow = actualIndex % 7 === 0;\n const isLastInRow = actualIndex % 7 === 6;\n \n const isRangeStart = isStartDate;\n const isRangeEnd = isEndDate;\n\n // 计算背景和圆角样式\n let buttonStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '36px',\n height: '36px',\n border: 'none',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n transition: 'all 0.2s',\n opacity: isDisabled ? 0.4 : 1,\n position: 'relative',\n padding: 0,\n margin: 0,\n };\n\n // 开始和结束日期:圆形背景,橙色\n if (isRangeStart || isRangeEnd) {\n buttonStyle.background = primaryColor;\n buttonStyle.borderRadius = '50%';\n buttonStyle.color = '#FFFFFF';\n buttonStyle.fontWeight = 500;\n } \n // 范围中间的日期:浅灰色矩形背景\n else if (isInRange) {\n buttonStyle.background = '#F5F5F4';\n buttonStyle.color = isCurrentMonth\n ? isDisabled\n ? '#D7D3D0'\n : '#1C1917'\n : '#78716C';\n buttonStyle.fontWeight = 400;\n \n // 判断是否是月份的第一天或最后一天\n const isFirstDayOfMonth = date.getDate() === 1;\n const daysInMonth = getDaysInMonth(monthData.year, monthData.month);\n const isLastDayOfMonth = date.getDate() === daysInMonth;\n \n // 判断是否需要左边圆角或右边圆角\n const needsLeftRadius = isFirstInRow || isFirstDayOfMonth;\n const needsRightRadius = isLastInRow || isLastDayOfMonth;\n \n // 设置圆角:每一行的第一个日期有左边圆角,最后一个日期有右边圆角\n // 每月的第一天和最后一天也要有圆角\n if (needsLeftRadius && needsRightRadius) {\n // 同时需要左边和右边圆角(单独一个日期或跨行的情况)\n buttonStyle.borderRadius = '18px';\n } else if (needsLeftRadius) {\n // 行的第一个或月份的第一天:添加左侧圆角(上下都有)\n buttonStyle.borderTopLeftRadius = '18px';\n buttonStyle.borderBottomLeftRadius = '18px';\n buttonStyle.borderTopRightRadius = '0';\n buttonStyle.borderBottomRightRadius = '0';\n } else if (needsRightRadius) {\n // 行的最后一个或月份的最后一天:添加右侧圆角(上下都有)\n buttonStyle.borderTopRightRadius = '18px';\n buttonStyle.borderBottomRightRadius = '18px';\n buttonStyle.borderTopLeftRadius = '0';\n buttonStyle.borderBottomLeftRadius = '0';\n } else {\n // 中间:无圆角,保持连续\n buttonStyle.borderRadius = '0';\n }\n } \n // 不在范围内的日期\n else {\n buttonStyle.background = 'transparent';\n buttonStyle.borderRadius = '50%';\n buttonStyle.color = isCurrentMonth\n ? isDisabled\n ? '#D7D3D0'\n : '#1C1917'\n : '#78716C';\n buttonStyle.fontWeight = 400;\n }\n\n cells.push(\n <button\n key={`date-${index}`}\n type=\"button\"\n disabled={isDisabled}\n onClick={() => handleSelectRangeDate(date)}\n style={buttonStyle}\n onMouseEnter={(e) => {\n if (!isDisabled && !isRangeStart && !isRangeEnd) {\n if (isInRange) {\n e.currentTarget.style.backgroundColor = '#E7E5E4';\n } else {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }\n }\n }}\n onMouseLeave={(e) => {\n if (!isRangeStart && !isRangeEnd) {\n if (isInRange) {\n e.currentTarget.style.backgroundColor = '#F5F5F4';\n } else {\n e.currentTarget.style.backgroundColor = 'transparent';\n }\n }\n }}\n >\n {date.getDate()}\n {isToday && (\n <div\n style={{\n position: 'absolute',\n bottom: '3px',\n left: '50%',\n transform: 'translateX(-50%)',\n width: '4px',\n height: '4px',\n borderRadius: '50%',\n backgroundColor: (isRangeStart || isRangeEnd) ? \"#FFFFFF\" : primaryColor,\n }}\n />\n )}\n </button>\n );\n } else {\n // 单个日期模式\n const isSelected = isSameDay(date, currentSingleValue);\n\n cells.push(\n <button\n key={`date-${index}`}\n type=\"button\"\n disabled={isDisabled}\n onClick={() => handleSelectSingleDate(date)}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '36px',\n height: '36px',\n border: 'none',\n background: isSelected ? primaryColor : 'transparent',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n borderRadius: '4px',\n fontSize: '14px',\n fontWeight: isSelected ? 500 : 400,\n color: isSelected\n ? '#FFFFFF'\n : isCurrentMonth\n ? isDisabled\n ? '#D7D3D0'\n : '#1C1917'\n : '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n transition: 'all 0.2s',\n opacity: isDisabled ? 0.4 : 1,\n position: 'relative',\n padding: 0,\n margin: 0,\n }}\n onMouseEnter={(e) => {\n if (!isDisabled && !isSelected) {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }\n }}\n onMouseLeave={(e) => {\n if (!isSelected) {\n e.currentTarget.style.backgroundColor = 'transparent';\n }\n }}\n >\n {date.getDate()}\n {isToday && !isSelected && (\n <div\n style={{\n position: 'absolute',\n bottom: '2px',\n left: '50%',\n transform: 'translateX(-50%)',\n width: '4px',\n height: '4px',\n borderRadius: '50%',\n backgroundColor: primaryColor,\n }}\n />\n )}\n </button>\n );\n }\n });\n \n return cells;\n })()}\n </div>\n </div>\n );\n\n return (\n <>\n {renderCalendar(currentMonth, calendarData, handlePrevMonth, handleNextMonth, 0)}\n {calendarCount === 2 && isRangeMode && secondMonth && secondCalendarData && (\n renderCalendar(secondMonth, secondCalendarData, handleSecondPrevMonth, handleSecondNextMonth, 1)\n )}\n \n </>\n );\n })()}\n </div>\n {/* 显示选中的日期段(双月模式,无按钮时) */}\n {isRangeMode && showSelectedRange && calendarCount === 2 && !showApplyCancel && (() => {\n const workingRange = currentRangeValue;\n \n // 使用固定的 \"MMM D, YYYY\" 格式显示日期(如 \"Jan 10, 2025\")\n const startText = workingRange.startDate ? formatDate(workingRange.startDate, 'MMM D, YYYY') : startSelectedRangeText;\n const endText = workingRange.endDate ? formatDate(workingRange.endDate, 'MMM D, YYYY') : endSelectedRangeText;\n \n return (\n <div\n className='flex items-center gap-2'\n style={{\n padding: '12px 16px',\n borderTop: '1px solid #E7E5E4',\n borderBottomLeftRadius: '8px',\n borderBottomRightRadius: '8px',\n }}\n >\n <div\n className='w-[260px] flex items-center gap-2'\n style={{\n fontSize: '14px',\n }}\n >\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.startDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{startText}</div>\n <div>{separator}</div>\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.endDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{endText}</div>\n </div>\n </div>\n );\n })()}\n {/* Apply/Cancel 按钮 */}\n {isRangeMode && showApplyCancel && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n gap: '8px',\n padding: '12px 16px',\n borderTop: '1px solid #E7E5E4',\n borderBottomLeftRadius: '8px',\n borderBottomRightRadius: '8px',\n }}\n >\n {/* 显示选中的日期段(双月模式,在按钮旁边) */}\n {showSelectedRange && calendarCount === 2 && (() => {\n const workingRange = tempRangeValue || currentRangeValue;\n \n // 使用固定的 \"MMM D, YYYY\" 格式显示日期(如 \"Jan 10, 2025\")\n const startText = workingRange.startDate ? formatDate(workingRange.startDate, 'MMM D, YYYY') : startSelectedRangeText;\n const endText = workingRange.endDate ? formatDate(workingRange.endDate, 'MMM D, YYYY') : endSelectedRangeText;\n \n return (\n <div\n className='w-[260px] flex items-center gap-2'\n style={{\n fontSize: '14px',\n }}\n >\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.startDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{startText}</div>\n <div>{separator}</div>\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.endDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{endText}</div>\n </div>\n );\n })()}\n <div\n className={`${ calendarCount === 2 ? '' : 'w-full'}`}\n style={{ display: 'flex', gap: '8px', flexShrink: 0, marginLeft: 'auto' }}\n >\n <button\n type=\"button\"\n onClick={handleCancel}\n style={{\n flex: 1,\n padding: '8px 16px',\n border: '1px solid #E7E5E4',\n borderRadius: '8px',\n background: '#FFFFFF',\n color: '#1C1917',\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: \"DM Sans, sans-serif\",\n cursor: 'pointer',\n transition: 'all 0.2s',\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = '#FFFFFF';\n }}\n >\n {cancelText}\n </button>\n <button\n type=\"button\"\n onClick={handleApply}\n disabled={!tempRangeValue || (!tempRangeValue.startDate || !tempRangeValue.endDate)}\n style={{\n flex: 1,\n padding: '8px 16px',\n border: 'none',\n borderRadius: '8px',\n background: (!tempRangeValue || !tempRangeValue.startDate || !tempRangeValue.endDate) ? '#D7D3D0' : primaryColor,\n color: '#FFFFFF',\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: \"DM Sans, sans-serif\",\n cursor: (!tempRangeValue || !tempRangeValue.startDate || !tempRangeValue.endDate) ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n }}\n onMouseEnter={(e) => {\n if (tempRangeValue && tempRangeValue.startDate && tempRangeValue.endDate) {\n e.currentTarget.style.backgroundColor = '#FD843A';\n }\n }}\n onMouseLeave={(e) => {\n if (tempRangeValue && tempRangeValue.startDate && tempRangeValue.endDate) {\n e.currentTarget.style.backgroundColor = primaryColor;\n }\n }}\n >\n {applyText}\n </button>\n </div>\n </div>\n )}\n </div>\n </div>\n </div>,\n document.body\n )}\n </>\n );\n};\n\nDatePicker.displayName = 'DatePicker';\n\nexport default DatePicker;\n","import React, { createContext } from 'react';\n\nexport interface FieldData {\n value?: any;\n error?: string;\n touched?: boolean;\n validating?: boolean;\n rules?: any[];\n required?: boolean;\n}\n\nexport interface FormContextValue {\n // 字段管理\n fields: Record<string, FieldData>;\n // 获取字段值\n getFieldValue: (name: string) => any;\n // 设置字段值\n setFieldValue: (name: string, value: any) => void;\n // 获取字段错误\n getFieldError: (name: string) => string | undefined;\n // 设置字段错误\n setFieldError: (name: string, error: string | undefined) => void;\n // 是否字段被触摸\n isFieldTouched: (name: string) => boolean;\n // 设置字段触摸状态\n setFieldTouched: (name: string, touched: boolean) => void;\n // 是否字段正在校验\n isFieldValidating: (name: string) => boolean;\n // 设置字段校验状态\n setFieldValidating: (name: string, validating: boolean) => void;\n // 注册字段\n registerField: (name: string, options: { rules?: any[]; required?: boolean }) => void;\n // 注销字段\n unregisterField: (name: string) => void;\n // 校验字段\n validateField: (name: string) => Promise<string | undefined>;\n // 校验所有字段\n validateFields: (nameList?: string[]) => Promise<any>;\n // 重置字段\n resetFields: (nameList?: string[]) => void;\n // 获取所有字段值\n getFieldsValue: (nameList?: string[]) => any;\n // 设置所有字段值\n setFieldsValue: (values: Record<string, any>) => void;\n // 提交表单\n submit: () => Promise<any>;\n // 批量设置字段(值 + 错误),类似 antd setFields\n setFields: (fields: Array<{ name: string; value?: any; errors?: string[] }>) => void;\n // 滚动到指定字段,类似 antd scrollToField\n scrollToField: (name: string, options?: ScrollIntoViewOptions) => void;\n // 注册字段 DOM 节点(供 scrollToField 使用,FormItem 内部调用)\n registerFieldRef: (name: string, element: HTMLElement | null) => void;\n // 标签宽度\n labelWidth?: number | string;\n // 标签对齐\n labelAlign?: 'left' | 'right';\n}\n\nexport const FormContext = createContext<FormContextValue | null>(null);\n\n","import React, { useRef, useCallback, useState, useImperativeHandle, useEffect, useMemo } from 'react';\nimport { FormContext, FormContextValue, FieldData } from './FormContext';\nimport FormItem from './FormItem';\n\nexport interface FormProps {\n /** 表单初始值 */\n initialValues?: Record<string, any>;\n /** 表单值变化回调 */\n onValuesChange?: (changedValues: Record<string, any>, allValues: Record<string, any>) => void;\n /** 表单提交回调 */\n onFinish?: (values: Record<string, any>) => void;\n /** 表单提交失败回调 */\n onFinishFailed?: (errorInfo: { values: Record<string, any>; errorFields: Array<{ name: string; errors: string[] }> }) => void;\n /** 标签宽度 */\n labelWidth?: number | string;\n /** 标签对齐方式 */\n labelAlign?: 'left' | 'right';\n /** 布局方式 */\n layout?: 'horizontal' | 'vertical' | 'inline';\n /** 尺寸 */\n size?: 'small' | 'medium' | 'large';\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 子元素 */\n children?: React.ReactNode;\n}\n\n/** scrollToField 的选项,与 Element.scrollIntoView 一致 */\nexport type ScrollToFieldOptions = ScrollIntoViewOptions;\n\n/** 校验失败时抛出的错误,携带 values 和 errorFields,便于 catch 后使用 */\nexport class FormValidationError extends Error {\n /** 当前表单值 */\n values: Record<string, any>;\n /** 校验失败的字段列表 */\n errorFields: Array<{ name: string; errors: string[] }>;\n\n constructor(message: string, values: Record<string, any>, errorFields: Array<{ name: string; errors: string[] }>) {\n super(message);\n this.name = 'FormValidationError';\n this.values = values;\n this.errorFields = errorFields;\n Object.setPrototypeOf(this, FormValidationError.prototype);\n }\n}\n\nexport interface FormInstance {\n /** 获取字段值 */\n getFieldValue: (name: string) => any;\n /** 获取所有字段值 */\n getFieldsValue: (nameList?: string[]) => any;\n /** 设置字段值 */\n setFieldValue: (name: string, value: any) => void;\n /** 设置所有字段值 */\n setFieldsValue: (values: Record<string, any>) => void;\n /** 批量设置字段(值 + 错误),类似 antd 的 setFields */\n setFields: (fields: Array<{ name: string; value?: any; errors?: string[] }>) => void;\n /** 获取字段错误 */\n getFieldError: (name: string) => string | undefined;\n /** 校验字段 */\n validateField: (name: string) => Promise<string | undefined>;\n /** 校验所有字段 */\n validateFields: (nameList?: string[]) => Promise<any>;\n /** 重置字段 */\n resetFields: (nameList?: string[]) => void;\n /** 提交表单:校验通过时 resolve 表单值,校验失败时 reject 为 FormValidationError(需 await 或 .catch() 才能捕获) */\n submit: () => Promise<any>;\n /** 滚动到指定字段(如第一个报错项) */\n scrollToField: (name: string, options?: ScrollToFieldOptions) => void;\n}\n\nconst Form = React.forwardRef<FormInstance, FormProps>(\n (\n {\n initialValues = {},\n onValuesChange,\n onFinish,\n onFinishFailed,\n labelWidth = '120px',\n labelAlign = 'right',\n layout = 'horizontal',\n size = 'medium',\n className = '',\n style,\n children,\n },\n ref\n ) => {\n const [fields, setFieldsState] = useState<Record<string, FieldData>>(() => {\n const initialFields: Record<string, FieldData> = {};\n Object.keys(initialValues).forEach((key) => {\n initialFields[key] = {\n value: initialValues[key],\n error: undefined,\n touched: false,\n validating: false,\n };\n });\n return initialFields;\n });\n\n // 使用 ref 保存最新的 fields,避免闭包问题\n const fieldsRef = useRef(fields);\n useEffect(() => {\n fieldsRef.current = fields;\n }, [fields]);\n\n // 存储每个字段的 DOM 元素,供 scrollToField 使用\n const fieldElementsRef = useRef<Record<string, HTMLElement>>({});\n\n // 获取字段值 - 从 ref 读取,确保获取最新值\n const getFieldValue = useCallback((name: string) => {\n return fieldsRef.current[name]?.value;\n }, []);\n\n // 设置字段值\n const setFieldValue = useCallback((name: string, value: any) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value,\n error: undefined,\n touched: false,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n value,\n };\n }\n\n // 同步更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n value,\n };\n } else {\n fieldsRef.current[name] = {\n value,\n error: undefined,\n touched: false,\n validating: false,\n };\n }\n\n // 触发 onValuesChange\n if (onValuesChange) {\n const changedValues: Record<string, any> = {};\n changedValues[name] = value;\n const allValues: Record<string, any> = {};\n Object.keys(newFields).forEach((key) => {\n allValues[key] = newFields[key].value;\n });\n onValuesChange(changedValues, allValues);\n }\n\n return newFields;\n });\n }, [onValuesChange]);\n\n // 获取字段错误 - 从 ref 读取,确保获取最新值\n const getFieldError = useCallback((name: string) => {\n return fieldsRef.current[name]?.error;\n }, []);\n\n // 设置字段错误\n const setFieldError = useCallback((name: string, error: string | undefined) => {\n // 先更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n error,\n };\n }\n \n // 然后更新 state\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: undefined,\n error,\n touched: false,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n error,\n };\n }\n return newFields;\n });\n }, []);\n\n // 是否字段被触摸 - 从 ref 读取,确保获取最新值\n const isFieldTouched = useCallback((name: string) => {\n return fieldsRef.current[name]?.touched || false;\n }, []);\n\n // 设置字段触摸状态\n const setFieldTouched = useCallback((name: string, touched: boolean) => {\n // 先更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n touched,\n };\n }\n \n // 然后更新 state\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: undefined,\n error: undefined,\n touched,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n touched,\n };\n }\n return newFields;\n });\n }, []);\n\n // 是否字段正在校验 - 从 ref 读取,确保获取最新值\n const isFieldValidating = useCallback((name: string) => {\n return fieldsRef.current[name]?.validating || false;\n }, []);\n\n // 设置字段校验状态\n const setFieldValidating = useCallback((name: string, validating: boolean) => {\n // 先更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n validating,\n };\n }\n \n // 然后更新 state\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: undefined,\n error: undefined,\n touched: false,\n validating,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n validating,\n };\n }\n return newFields;\n });\n }, []);\n\n // 使用 ref 存储 registerField 函数,避免依赖变化\n const registerFieldFnRef = useRef<(name: string, options: { rules?: any[]; required?: boolean }) => void>();\n \n registerFieldFnRef.current = (name: string, options: { rules?: any[]; required?: boolean }) => {\n setFieldsState((prev) => {\n // 如果字段已存在且 rules 和 required 没有变化,不更新\n if (prev[name]) {\n const existingRules = prev[name].rules || [];\n const newRules = options.rules || [];\n \n // 深度比较 rules\n let rulesEqual = existingRules.length === newRules.length;\n if (rulesEqual && existingRules.length > 0) {\n for (let i = 0; i < existingRules.length; i++) {\n const existingRule = existingRules[i];\n const newRule = newRules[i];\n if (\n existingRule?.required !== newRule?.required ||\n existingRule?.message !== newRule?.message ||\n existingRule?.type !== newRule?.type ||\n existingRule?.pattern !== newRule?.pattern ||\n existingRule?.min !== newRule?.min ||\n existingRule?.max !== newRule?.max ||\n existingRule?.len !== newRule?.len ||\n existingRule?.whitespace !== newRule?.whitespace\n ) {\n rulesEqual = false;\n break;\n }\n }\n }\n \n if (rulesEqual && prev[name].required === options.required) {\n return prev; // 没有变化,返回原对象,避免触发重新渲染\n }\n }\n \n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: initialValues[name],\n error: undefined,\n touched: false,\n validating: false,\n rules: options.rules,\n required: options.required,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n rules: options.rules,\n required: options.required,\n };\n }\n return newFields;\n });\n };\n\n const registerField = useCallback((name: string, options: { rules?: any[]; required?: boolean }) => {\n registerFieldFnRef.current?.(name, options);\n }, []);\n\n // 注销字段\n const unregisterField = useCallback((name: string) => {\n delete fieldElementsRef.current[name];\n setFieldsState((prev) => {\n const newFields = { ...prev };\n delete newFields[name];\n return newFields;\n });\n delete fieldsRef.current[name];\n }, []);\n\n // 校验单个字段\n const validateField = useCallback(async (name: string): Promise<string | undefined> => {\n // 使用 ref 获取最新的 fields 状态,避免闭包问题\n const field = fieldsRef.current[name];\n if (!field) {\n return undefined;\n }\n\n setFieldValidating(name, true);\n\n const rules = field.rules || [];\n let error: string | undefined;\n\n for (const rule of rules) {\n const value = field.value;\n\n // required 校验\n if (rule.required) {\n if (value === undefined || value === null || value === '') {\n error = rule.message || `${name} is required`;\n break;\n }\n }\n\n // type 校验\n if (rule.type && value !== undefined && value !== null && value !== '') {\n const typeMap: Record<string, (v: any) => boolean> = {\n string: (v) => typeof v === 'string',\n number: (v) => typeof v === 'number' && !isNaN(v),\n boolean: (v) => typeof v === 'boolean',\n email: (v) => /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(String(v)),\n url: (v) => {\n try {\n new URL(String(v));\n return true;\n } catch {\n return false;\n }\n },\n };\n\n const validator = typeMap[rule.type];\n if (validator && !validator(value)) {\n error = rule.message || `${name} must be a valid ${rule.type}`;\n break;\n }\n }\n\n // pattern 校验\n if (rule.pattern && value !== undefined && value !== null && value !== '') {\n if (!rule.pattern.test(String(value))) {\n error = rule.message || `${name} format is invalid`;\n break;\n }\n }\n\n // min 校验\n if (rule.min !== undefined && value !== undefined && value !== null && value !== '') {\n const numValue = typeof value === 'string' ? value.length : Number(value);\n if (numValue < rule.min) {\n error = rule.message || `${name} must be at least ${rule.min}`;\n break;\n }\n }\n\n // max 校验\n if (rule.max !== undefined && value !== undefined && value !== null && value !== '') {\n const numValue = typeof value === 'string' ? value.length : Number(value);\n if (numValue > rule.max) {\n error = rule.message || `${name} must be at most ${rule.max}`;\n break;\n }\n }\n\n // len 校验\n if (rule.len !== undefined && value !== undefined && value !== null && value !== '') {\n const lenValue = typeof value === 'string' ? value.length : Number(value);\n if (lenValue !== rule.len) {\n error = rule.message || `${name} must be exactly ${rule.len}`;\n break;\n }\n }\n\n // whitespace 校验\n if (rule.whitespace && typeof value === 'string' && value.trim() !== value) {\n error = rule.message || `${name} cannot be whitespace`;\n break;\n }\n\n // 自定义 validator\n if (rule.validator) {\n try {\n await rule.validator(rule, value);\n } catch (err: any) {\n error = err?.message || rule.message || `${name} validation failed`;\n break;\n }\n }\n }\n\n // 先同步更新 ref,确保立即可用\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n error,\n validating: false,\n touched: true,\n };\n } else {\n fieldsRef.current[name] = {\n value: field.value,\n error,\n touched: true,\n validating: false,\n rules: field.rules,\n required: field.required,\n };\n }\n\n // 然后更新 state - 使用函数式更新确保状态正确更新\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (newFields[name]) {\n newFields[name] = {\n ...newFields[name],\n error,\n validating: false,\n touched: true,\n };\n } else {\n // 如果字段不存在,创建一个新字段\n newFields[name] = {\n value: field.value,\n error,\n touched: true,\n validating: false,\n rules: field.rules,\n required: field.required,\n };\n }\n return newFields;\n });\n\n // 返回错误信息\n return error;\n }, []);\n\n // 获取所有字段值\n const getFieldsValue = useCallback((nameList?: string[]) => {\n const currentFields = fieldsRef.current;\n const values: Record<string, any> = {};\n const fieldsToGet = nameList || Object.keys(currentFields);\n\n fieldsToGet.forEach((name) => {\n values[name] = currentFields[name]?.value;\n });\n\n return values;\n }, []);\n\n // 校验所有字段\n const validateFields = useCallback(async (nameList?: string[]): Promise<any> => {\n // 使用 ref 获取最新的 fields 状态\n const currentFields = fieldsRef.current;\n const fieldsToValidate = nameList || Object.keys(currentFields);\n const errors: Array<{ name: string; errors: string[] }> = [];\n\n // 并行校验所有字段,并收集错误\n const validationResults = await Promise.all(\n fieldsToValidate.map(async (name) => {\n const field = currentFields[name];\n // 如果字段存在且有 rules,才进行校验\n if (field && field.rules && field.rules.length > 0) {\n const error = await validateField(name);\n return { name, error };\n }\n return { name, error: undefined };\n })\n );\n\n // 收集所有错误\n validationResults.forEach(({ name, error }) => {\n if (error) {\n errors.push({\n name,\n errors: [error],\n });\n }\n });\n\n // 等待状态更新完成 - 使用 requestAnimationFrame 确保 DOM 更新\n await new Promise((resolve) => requestAnimationFrame(() => {\n setTimeout(resolve, 0);\n }));\n\n if (errors.length > 0) {\n const values = getFieldsValue();\n const errorInfo = { values, errorFields: errors };\n onFinishFailed?.(errorInfo);\n // 抛出 Error 子类,保证可被 try/catch 和 Promise.catch 正常捕获,避免页面“挂掉”\n throw new FormValidationError('Form validation failed', values, errors);\n }\n\n return getFieldsValue();\n }, [validateField, getFieldsValue, onFinishFailed]);\n\n // 重置字段\n const resetFields = useCallback((nameList?: string[]) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n const fieldsToReset = nameList || Object.keys(newFields);\n\n fieldsToReset.forEach((name) => {\n if (newFields[name]) {\n newFields[name] = {\n ...newFields[name],\n value: initialValues[name],\n error: undefined,\n touched: false,\n validating: false,\n };\n fieldsRef.current[name] = { ...newFields[name] };\n }\n });\n\n return newFields;\n });\n }, [initialValues]);\n\n // 设置所有字段值\n const setFieldsValue = useCallback((values: Record<string, any>) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n Object.keys(values).forEach((name) => {\n if (!newFields[name]) {\n newFields[name] = {\n value: values[name],\n error: undefined,\n touched: false,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n value: values[name],\n };\n }\n fieldsRef.current[name] = { ...newFields[name] };\n });\n\n if (onValuesChange) {\n const allValues: Record<string, any> = {};\n Object.keys(newFields).forEach((key) => {\n allValues[key] = newFields[key].value;\n });\n onValuesChange(values, allValues);\n }\n\n return newFields;\n });\n }, [onValuesChange]);\n\n // 提交表单\n const submit = useCallback(async () => {\n try {\n const values = await validateFields();\n onFinish?.(values);\n return values;\n } catch (error) {\n throw error;\n }\n }, [validateFields, onFinish]);\n\n // 批量设置字段(值 + 错误),类似 antd setFields\n const setFields = useCallback((fieldsToSet: Array<{ name: string; value?: any; errors?: string[] }>) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n fieldsToSet.forEach(({ name, value, errors }) => {\n const error = errors && errors.length > 0 ? errors[0] : undefined;\n if (!newFields[name]) {\n newFields[name] = {\n value: value !== undefined ? value : undefined,\n error,\n touched: true,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n ...(value !== undefined && { value }),\n error,\n touched: true,\n };\n }\n fieldsRef.current[name] = { ...newFields[name] };\n });\n return newFields;\n });\n if (onValuesChange && fieldsToSet.some((f) => f.value !== undefined)) {\n const changedValues: Record<string, any> = {};\n fieldsToSet.forEach((f) => {\n if (f.value !== undefined) changedValues[f.name] = f.value;\n });\n setTimeout(() => onValuesChange(changedValues, getFieldsValue()), 0);\n }\n }, [onValuesChange, getFieldsValue]);\n\n // 注册字段 DOM 节点\n const registerFieldRef = useCallback((name: string, element: HTMLElement | null) => {\n if (element) {\n fieldElementsRef.current[name] = element;\n } else {\n delete fieldElementsRef.current[name];\n }\n }, []);\n\n // 滚动到指定字段\n const scrollToField = useCallback((name: string, options?: ScrollIntoViewOptions) => {\n const el = fieldElementsRef.current[name];\n el?.scrollIntoView({ behavior: 'smooth', block: 'center', ...options });\n }, []);\n\n // 暴露方法给 ref\n useImperativeHandle(ref, () => ({\n getFieldValue,\n getFieldsValue,\n setFieldValue,\n setFieldsValue,\n setFields,\n getFieldError,\n validateField,\n validateFields,\n resetFields,\n submit,\n scrollToField,\n }));\n\n // 使用 useMemo 缓存 contextValue,但 fields 必须包含在依赖中,以便 FormItem 能重新渲染\n const contextValue: FormContextValue = useMemo(() => ({\n fields,\n getFieldValue,\n setFieldValue,\n getFieldError,\n setFieldError,\n isFieldTouched,\n setFieldTouched,\n isFieldValidating,\n setFieldValidating,\n registerField,\n unregisterField,\n validateField,\n validateFields,\n resetFields,\n getFieldsValue,\n setFieldsValue,\n setFields,\n submit,\n scrollToField,\n registerFieldRef,\n labelWidth,\n labelAlign,\n }), [\n fields,\n getFieldValue,\n setFieldValue,\n getFieldError,\n setFieldError,\n isFieldTouched,\n setFieldTouched,\n isFieldValidating,\n setFieldValidating,\n registerField,\n unregisterField,\n validateField,\n validateFields,\n resetFields,\n getFieldsValue,\n setFieldsValue,\n setFields,\n submit,\n scrollToField,\n registerFieldRef,\n labelWidth,\n labelAlign,\n ]);\n\n const formStyle: React.CSSProperties = {\n ...style,\n };\n\n if (layout === 'vertical') {\n formStyle.display = 'flex';\n formStyle.flexDirection = 'column';\n } else if (layout === 'inline') {\n formStyle.display = 'inline-flex';\n formStyle.flexWrap = 'wrap';\n formStyle.gap = '16px';\n }\n\n return (\n <FormContext.Provider value={contextValue}>\n <form\n className={`aha-form ${className}`}\n style={formStyle}\n onSubmit={async (e) => {\n e.preventDefault();\n try {\n const values = await validateFields();\n // 只有校验通过才调用 onFinish\n onFinish?.(values);\n } catch (error) {\n // 校验失败,不调用 onFinish,错误信息已经通过 setFieldError 设置\n // 错误信息会显示在 FormItem 中\n // onFinishFailed 已经在 validateFields 中调用\n }\n }}\n >\n {children}\n </form>\n </FormContext.Provider>\n );\n }\n);\n\nForm.displayName = 'Form';\n\n/** 获取表单实例的 hook,用法与 antd Form.useForm() 一致,返回的 ref 传给 <Form ref={formRef} /> 后即可使用 formRef.current?.setFieldValue 等方法 */\nfunction useForm(): [React.RefObject<FormInstance | null>] {\n const formRef = useRef<FormInstance | null>(null);\n return [formRef];\n}\n\n// 导出 FormItem 作为 Form.Item,并挂载 useForm\nconst FormWithItem = Form as typeof Form & {\n Item: typeof FormItem;\n useForm: typeof useForm;\n};\nFormWithItem.Item = FormItem;\nFormWithItem.useForm = useForm;\n\nexport default FormWithItem;\nexport { useForm };\n\n","import React, { useContext, useEffect, useRef, useMemo, useCallback } from 'react';\nimport { FormContext } from './FormContext';\nimport { TooltipIcon } from '../../icons';\n\nexport interface FormItemProps {\n /** 字段名 */\n name?: string;\n /** 标签 */\n label?: React.ReactNode;\n /** 标签的 HTML for 属性 */\n htmlFor?: string;\n /** 标签布局 */\n labelCol?: { span?: number; offset?: number };\n /** 输入控件布局 */\n wrapperCol?: { span?: number; offset?: number };\n /** 是否必填(显示红色星号) */\n required?: boolean;\n /** 校验规则 */\n rules?: Array<{\n required?: boolean;\n message?: string;\n validator?: (rule: any, value: any) => Promise<void> | void;\n pattern?: RegExp;\n min?: number;\n max?: number;\n len?: number;\n type?: 'string' | 'number' | 'boolean' | 'method' | 'regexp' | 'integer' | 'float' | 'array' | 'object' | 'enum' | 'date' | 'url' | 'hex' | 'email';\n whitespace?: boolean;\n [key: string]: any;\n }>;\n /** 是否显示校验信息 */\n hasFeedback?: boolean;\n /** 校验状态 */\n validateStatus?: 'success' | 'warning' | 'error' | 'validating';\n /** 帮助信息 */\n help?: React.ReactNode;\n /** 额外的提示信息 */\n extra?: React.ReactNode;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 子元素 */\n children?: React.ReactNode;\n /** 标签对齐方式 */\n labelAlign?: 'left' | 'right';\n /** 标签宽度 */\n labelWidth?: number | string;\n /** 是否隐藏 */\n hidden?: boolean;\n /** 标签提示信息(tooltip) */\n tooltip?: React.ReactNode;\n}\n\nconst FormItem: React.FC<FormItemProps> = ({\n name,\n label,\n htmlFor,\n labelCol,\n wrapperCol,\n required = false,\n rules = [],\n hasFeedback = false,\n validateStatus,\n help,\n extra,\n className = '',\n style,\n children,\n labelAlign = 'right',\n labelWidth,\n hidden = false,\n tooltip,\n}) => {\n const formContext = useContext(FormContext);\n const itemRef = useRef<HTMLDivElement>(null);\n\n // 注册字段 DOM 节点,供 Form 的 scrollToField 使用\n const setItemRef = useCallback(\n (el: HTMLDivElement | null) => {\n (itemRef as React.MutableRefObject<HTMLDivElement | null>).current = el;\n if (name && formContext?.registerFieldRef) {\n formContext.registerFieldRef(name, el);\n }\n },\n [name, formContext]\n );\n\n // 从 Form 上下文获取字段值、错误信息等\n // 使用 formContext.fields 来触发重新渲染,当 fields 变化时组件会重新渲染\n const fields = formContext?.fields || {};\n const fieldValue = name && formContext ? formContext.getFieldValue(name) : undefined;\n const fieldError = name && formContext ? formContext.getFieldError(name) : undefined;\n const fieldTouched = name && formContext ? formContext.isFieldTouched(name) : false;\n const fieldValidating = name && formContext ? formContext.isFieldValidating(name) : false;\n \n // 使用 fields 来触发重新渲染,确保错误信息能显示\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const _ = name ? fields[name] : undefined; // 读取 fields[name] 来建立依赖关系\n\n // 计算校验状态\n // 如果有错误就显示错误状态,不管是否 touched(提交时会强制校验)\n const computedValidateStatus =\n validateStatus ||\n (fieldError\n ? 'error'\n : fieldValidating\n ? 'validating'\n : fieldTouched && !fieldError\n ? 'success'\n : undefined);\n\n // 计算帮助信息 - 如果有错误就显示,不管是否 touched\n const computedHelp = help !== undefined ? help : (fieldError || undefined);\n\n // 使用 useRef 存储上一次的 rules 和 required,避免不必要的更新\n const prevRulesRef = useRef(rules);\n const prevRequiredRef = useRef(required);\n const isMountedRef = useRef(false);\n\n // 计算是否必填\n const isRequired = required || rules.some((rule) => rule.required);\n\n // 检查 rules 是否真的变化了(深度比较)\n const rulesChanged = useMemo(() => {\n if (!isMountedRef.current) {\n isMountedRef.current = true;\n return true; // 首次挂载时注册\n }\n \n if (prevRulesRef.current.length !== rules.length) {\n return true;\n }\n // 简单比较:如果引用相同,肯定没变化\n if (prevRulesRef.current === rules) {\n return false;\n }\n // 深度比较关键属性\n for (let i = 0; i < rules.length; i++) {\n const prevRule = prevRulesRef.current[i];\n const currRule = rules[i];\n if (\n prevRule?.required !== currRule?.required ||\n prevRule?.message !== currRule?.message ||\n prevRule?.type !== currRule?.type ||\n prevRule?.pattern !== currRule?.pattern ||\n prevRule?.min !== currRule?.min ||\n prevRule?.max !== currRule?.max ||\n prevRule?.len !== currRule?.len ||\n prevRule?.whitespace !== currRule?.whitespace\n ) {\n return true;\n }\n }\n return false;\n }, [rules]);\n\n // 注册字段到 Form - 只在 name 变化时注册,rules 和 required 通过内部比较\n useEffect(() => {\n if (!name || !formContext) return;\n\n // 检查是否需要更新\n const shouldUpdate = \n !prevRulesRef.current || // 首次注册\n rulesChanged || \n prevRequiredRef.current !== required;\n\n if (shouldUpdate) {\n prevRulesRef.current = rules;\n prevRequiredRef.current = required;\n\n formContext.registerField(name, {\n rules,\n required: isRequired,\n });\n }\n\n return () => {\n if (name && formContext) {\n formContext.unregisterField(name);\n }\n };\n // 只依赖 name,formContext 是稳定的,rules 和 required 通过 ref 比较\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [name]);\n\n // 克隆子元素,注入 value、onChange、error 等 props\n const cloneChild = (child: React.ReactElement) => {\n if (!React.isValidElement(child)) return child;\n\n const childProps: any = {\n ...(child.props as Record<string, any>),\n };\n\n // 注入 value 和 onChange\n if (name && formContext) {\n const fieldValue = formContext.getFieldValue(name);\n const setFieldValue = formContext.setFieldValue;\n\n if (!setFieldValue) {\n // 如果没有 formContext,直接返回原组件\n return child;\n }\n\n // 处理不同类型的组件(函数组件 typeof 为 'function',React.memo 等为 'object')\n const childType = child.type as any;\n if (childType && (typeof childType === 'object' || typeof childType === 'function') && 'displayName' in childType) {\n const displayName = childType.displayName;\n\n // Input, Textarea\n if (displayName === 'Input' || displayName === 'Textarea') {\n childProps.value = fieldValue || '';\n const originalOnChange = (child.props as any)?.onChange;\n const originalOnBlur = (child.props as any)?.onBlur;\n childProps.onChange = (e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n setFieldValue(name, e.target.value);\n originalOnChange?.(e);\n // 值变化时立即触发校验\n if (name && formContext) {\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n childProps.onBlur = (e: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n formContext.validateField(name);\n }\n originalOnBlur?.(e);\n };\n childProps.error = computedValidateStatus === 'error';\n }\n // Select\n else if (displayName === 'Select') {\n childProps.value = fieldValue;\n const originalOnChange = (child.props as any)?.onChange;\n const originalOnBlur = (child.props as any)?.onBlur;\n childProps.onChange = (value: any, option: any) => {\n setFieldValue(name, value);\n originalOnChange?.(value, option);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n childProps.onBlur = (e: React.FocusEvent) => {\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n formContext.validateField(name);\n }\n originalOnBlur?.(e);\n };\n childProps.error = computedValidateStatus === 'error';\n }\n // Switch\n else if (displayName === 'Switch') {\n childProps.checked = fieldValue || false;\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (checked: boolean, event: any) => {\n setFieldValue(name, checked);\n originalOnChange?.(checked, event);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n }\n // Checkbox\n else if (displayName === 'Checkbox') {\n childProps.checked = fieldValue || false;\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setFieldValue(name, e.target.checked);\n originalOnChange?.(e);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n }\n // Radio\n else if (displayName === 'Radio') {\n // Radio 通常需要 Radio.Group,这里只处理单个 Radio\n const radioValue = (child.props as any)?.value;\n if (radioValue !== undefined) {\n childProps.checked = fieldValue === radioValue;\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setFieldValue(name, radioValue);\n originalOnChange?.(e);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n }\n }\n } else {\n // 通用处理:尝试注入 value 和 onChange\n if (fieldValue !== undefined) {\n childProps.value = fieldValue;\n }\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (e: any) => {\n const value = e?.target?.value ?? e;\n setFieldValue(name, value);\n originalOnChange?.(e);\n };\n }\n }\n\n // 注入 error 状态(如果组件支持)\n if (computedValidateStatus === 'error' && 'error' in childProps) {\n childProps.error = true;\n }\n\n return React.cloneElement(child, childProps);\n };\n\n if (hidden) return null;\n\n // Tooltip 组件(简单实现)\n const TooltipWrapper = ({ content }: { content: React.ReactNode }) => {\n const [showTooltip, setShowTooltip] = React.useState(false);\n const tooltipRef = React.useRef<HTMLDivElement>(null);\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (tooltipRef.current && !tooltipRef.current.contains(event.target as Node)) {\n setShowTooltip(false);\n }\n };\n\n if (showTooltip) {\n document.addEventListener('mousedown', handleClickOutside);\n return () => {\n document.removeEventListener('mousedown', handleClickOutside);\n };\n }\n }, [showTooltip]);\n\n return (\n <div style={{ position: 'relative', display: 'inline-block', marginLeft: '4px' }}>\n <div\n onClick={(e) => {\n e.stopPropagation();\n setShowTooltip(!showTooltip);\n }}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n cursor: 'pointer',\n color: '#A9A29D',\n }}\n >\n <TooltipIcon />\n </div>\n {showTooltip && (\n <div\n ref={tooltipRef}\n style={{\n position: 'absolute',\n top: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginTop: '4px',\n padding: '8px 12px',\n backgroundColor: '#1C1917',\n color: '#FFFFFF',\n fontSize: '12px',\n lineHeight: '18px',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '6px',\n whiteSpace: 'nowrap',\n zIndex: 1000,\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.15)',\n }}\n >\n {content}\n <div\n style={{\n position: 'absolute',\n top: '-4px',\n left: '50%',\n transform: 'translateX(-50%)',\n width: 0,\n height: 0,\n borderLeft: '4px solid transparent',\n borderRight: '4px solid transparent',\n borderBottom: '4px solid #1C1917',\n }}\n />\n </div>\n )}\n </div>\n );\n };\n\n return (\n <div\n ref={setItemRef}\n className={`aha-form-item ${className}`}\n style={{\n display: 'flex',\n flexDirection: 'column',\n marginBottom: '16px',\n ...style,\n }}\n >\n {label && (\n <label\n htmlFor={htmlFor}\n style={{\n display: 'flex',\n alignItems: 'center',\n marginBottom: '6px',\n fontSize: '14px', // text-sm\n lineHeight: '20px',\n color: '#44403C',\n fontFamily: \"DM Sans, sans-serif\",\n fontWeight: 500, // font-medium\n }}\n >\n {label}\n {isRequired && (\n <span\n style={{\n color: '#EC470A',\n marginLeft: '4px',\n }}\n >\n *\n </span>\n )}\n {tooltip && <TooltipWrapper content={tooltip} />}\n </label>\n )}\n <div style={{ width: '100%' }}>\n <div>\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return cloneChild(child);\n }\n return child;\n })}\n </div>\n {computedHelp && (\n <div\n style={{\n marginTop: '6px',\n fontSize: '14px', // text-sm\n lineHeight: '20px',\n fontWeight: 400, // font-normal\n color:\n computedValidateStatus === 'error'\n ? '#D92D20'\n : computedValidateStatus === 'warning'\n ? '#F59E0B'\n : '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {computedHelp}\n </div>\n )}\n {extra && !computedHelp && (\n <div\n style={{\n marginTop: '4px',\n fontSize: '12px',\n lineHeight: '18px',\n color: '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {extra}\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport default FormItem;\n\n","import React, { useState, useCallback, useRef, useEffect } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface MenuItemType {\n /** 唯一标识 */\n key: string;\n /** 菜单项标签 */\n label: React.ReactNode;\n /** 菜单项图标 */\n icon?: React.ReactNode;\n /** 菜单项右侧图标 */\n suffixIcon?: React.ReactNode;\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否危险项(红色) */\n danger?: boolean;\n /** 自定义渲染函数,如果提供则完全自定义该项的渲染 */\n render?: (item: MenuItemType, isSelected: boolean) => React.ReactNode;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 点击事件 */\n onClick?: (info: { key: string; keyPath: string[] }) => void;\n /** 是否跳过全局点击事件(MenuList 的 onClick),默认为 false */\n skipGlobalClick?: boolean;\n}\n\nexport interface MenuGroupType {\n /** 分组标题 */\n title?: React.ReactNode;\n /** 分组下的菜单项 */\n children: MenuItemType[];\n /** 自定义类名 */\n className?: string;\n}\n\nexport interface UserProfileType {\n /** 用户头像 */\n avatar?: React.ReactNode;\n /** 用户姓名 */\n name: React.ReactNode;\n /** 用户邮箱 */\n email?: React.ReactNode;\n /** 在线状态 */\n online?: boolean;\n /** 自定义渲染函数,如果提供则完全自定义用户资料的渲染 */\n render?: (profile: UserProfileType) => React.ReactNode;\n /** 点击事件 */\n onClick?: () => void;\n}\n\nexport interface MenuListProps {\n /** 菜单项数据 */\n items: (MenuItemType | MenuGroupType)[];\n /** 用户资料信息(显示在顶部) */\n userProfile?: UserProfileType;\n /** 当前选中的菜单项 key */\n selectedKeys?: string[];\n /** 默认选中的菜单项 key */\n defaultSelectedKeys?: string[];\n /** 选中项变化时的回调 */\n onSelect?: (info: { key: string; keyPath: string[]; selectedKeys: string[] }) => void;\n /** 取消选中时的回调 */\n onDeselect?: (info: { key: string; keyPath: string[]; selectedKeys: string[] }) => void;\n /** 统一的点击事件,无论点击哪个子项都会触发 */\n onClick?: (info: { key: string; keyPath: string[] }) => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 菜单宽度 */\n width?: number | string;\n}\n\nconst MenuList: React.FC<MenuListProps> = ({\n items = [],\n userProfile,\n selectedKeys: controlledSelectedKeys,\n defaultSelectedKeys = [],\n onSelect,\n onDeselect,\n onClick,\n className = '',\n style,\n width = 320,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const menuRef = useRef<HTMLDivElement>(null);\n const itemRefs = useRef<{ [key: string]: HTMLDivElement | null }>({});\n\n // 受控/非受控逻辑\n const isSelectedKeysControlled = controlledSelectedKeys !== undefined;\n const [internalSelectedKeys, setInternalSelectedKeys] = useState<string[]>(defaultSelectedKeys);\n\n const selectedKeys = isSelectedKeysControlled ? controlledSelectedKeys : internalSelectedKeys;\n\n // 判断是否是分组\n const isGroup = (item: MenuItemType | MenuGroupType): item is MenuGroupType => {\n return 'children' in item && Array.isArray(item.children);\n };\n\n // 获取菜单项的完整路径\n const getKeyPath = useCallback(\n (key: string, items: (MenuItemType | MenuGroupType)[], path: string[] = []): string[] | null => {\n for (const item of items) {\n if (isGroup(item)) {\n // 是分组,递归查找子项\n const found = getKeyPath(key, item.children, path);\n if (found) return found;\n } else {\n const menuItem = item as MenuItemType;\n const currentPath = [...path, menuItem.key];\n if (menuItem.key === key) {\n return currentPath;\n }\n }\n }\n return null;\n },\n []\n );\n\n // 处理菜单项点击\n const handleItemClick = useCallback(\n (item: MenuItemType) => {\n if (item.disabled) return;\n\n const keyPath = getKeyPath(item.key, items) || [item.key];\n const isSelected = selectedKeys.includes(item.key);\n let newSelectedKeys: string[];\n\n if (isSelected) {\n newSelectedKeys = selectedKeys.filter((k) => k !== item.key);\n onDeselect?.({ key: item.key, keyPath, selectedKeys: newSelectedKeys });\n } else {\n newSelectedKeys = [item.key];\n onSelect?.({ key: item.key, keyPath, selectedKeys: newSelectedKeys });\n }\n\n if (!isSelectedKeysControlled) {\n setInternalSelectedKeys(newSelectedKeys);\n }\n\n // 先调用菜单项自己的 onClick\n item.onClick?.({ key: item.key, keyPath });\n \n // 再调用统一的 onClick(MenuList 级别的),除非该菜单项设置了 skipGlobalClick\n if (!item.skipGlobalClick) {\n onClick?.({ key: item.key, keyPath });\n }\n },\n [selectedKeys, isSelectedKeysControlled, onSelect, onDeselect, onClick, items, getKeyPath]\n );\n\n // 渲染用户资料\n const renderUserProfile = () => {\n if (!userProfile) return null;\n\n // 如果提供了自定义渲染函数,使用自定义渲染\n if (userProfile.render) {\n return userProfile.render(userProfile);\n }\n\n return (\n <div\n onClick={userProfile.onClick}\n style={{\n padding: '16px',\n cursor: userProfile.onClick ? 'pointer' : 'default',\n borderBottom: '1px solid #E7E5E4',\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', gap: '12px' }}>\n {/* 头像 */}\n <div style={{ position: 'relative', flexShrink: 0 }}>\n {userProfile.avatar || (\n <div\n style={{\n width: '40px',\n height: '40px',\n borderRadius: '50%',\n backgroundColor: '#F5F5F4',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n fontSize: '16px',\n color: '#78716C',\n }}\n >\n {typeof userProfile.name === 'string' ? userProfile.name.charAt(0).toUpperCase() : 'U'}\n </div>\n )}\n {/* 在线状态指示器 */}\n {userProfile.online !== undefined && (\n <div\n style={{\n position: 'absolute',\n bottom: '0',\n right: '0',\n width: '12px',\n height: '12px',\n borderRadius: '50%',\n backgroundColor: userProfile.online ? '#10B981' : '#9CA3AF',\n border: '2px solid #FFFFFF',\n }}\n />\n )}\n </div>\n {/* 用户信息 */}\n <div style={{ flex: 1, minWidth: 0 }}>\n <div\n style={{\n fontSize: '14px',\n fontWeight: 500,\n lineHeight: '20px',\n color: '#101828',\n fontFamily: 'DM Sans, sans-serif',\n marginBottom: '2px',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n >\n {userProfile.name}\n </div>\n {userProfile.email && (\n <div\n style={{\n fontSize: '14px',\n lineHeight: '20px',\n color: '#78716C',\n fontFamily: 'DM Sans, sans-serif',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n >\n {userProfile.email}\n </div>\n )}\n </div>\n </div>\n </div>\n );\n };\n\n // 渲染单个菜单项\n const renderMenuItem = (item: MenuItemType): React.ReactNode => {\n const isSelected = selectedKeys.includes(item.key);\n\n // 如果提供了自定义渲染函数,使用自定义渲染\n if (item.render) {\n return (\n <div key={item.key} className={item.className} style={item.style}>\n {item.render(item, isSelected)}\n </div>\n );\n }\n\n const itemStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n padding: '10px 16px',\n cursor: item.disabled ? 'not-allowed' : 'pointer',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: 'DM Sans, sans-serif',\n fontWeight: 600,\n color: item.disabled\n ? '#98A2B3'\n : item.danger\n ? '#DC2626'\n : '#44403C',\n backgroundColor: 'transparent',\n transition: 'background-color 0.15s',\n opacity: item.disabled ? 0.5 : 1,\n ...item.style,\n };\n\n return (\n <div\n key={item.key}\n ref={(el) => {\n itemRefs.current[item.key] = el;\n }}\n className={`aha-menu-item ${item.className || ''}`}\n style={itemStyle}\n onClick={() => handleItemClick(item)}\n onMouseEnter={(e) => {\n if (!item.disabled) {\n e.currentTarget.style.backgroundColor = '#F9FAFB';\n }\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'transparent';\n }}\n >\n {/* 图标 - 可选,如果提供了icon则显示 */}\n {item.icon && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n marginRight: '12px',\n flexShrink: 0,\n color: item.disabled\n ? '#98A2B3'\n : item.danger\n ? '#DC2626'\n : '#101828',\n }}\n >\n {item.icon}\n </div>\n )}\n {/* 标签文本 */}\n <span style={{ flex: 1 }}>{item.label}</span>\n {/* 右侧图标 */}\n {item.suffixIcon && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n marginLeft: '12px',\n flexShrink: 0,\n color: item.disabled\n ? '#98A2B3'\n : item.danger\n ? '#DC2626'\n : '#101828',\n }}\n >\n {item.suffixIcon}\n </div>\n )}\n </div>\n );\n };\n\n // 渲染菜单分组\n const renderGroup = (group: MenuGroupType): React.ReactNode => {\n return (\n <div key={`group-${group.title}`} className={`aha-menu-group ${group.className || ''}`}>\n {group.children.map((item) => renderMenuItem(item))}\n </div>\n );\n };\n\n // 主容器样式\n const containerStyle: React.CSSProperties = {\n width: typeof width === 'number' ? `${width}px` : width,\n backgroundColor: '#FFFFFF',\n borderRadius: '12px',\n boxShadow: '0px 10px 38px rgba(22, 23, 24, 0.35), 0px 10px 20px rgba(22, 23, 24, 0.2)',\n overflow: 'hidden',\n fontFamily: 'DM Sans, sans-serif',\n ...style,\n };\n\n // 计算是否需要显示分隔线\n const shouldShowDivider = (index: number, items: (MenuItemType | MenuGroupType)[]): boolean => {\n if (index === 0) return false;\n const currentItem = items[index];\n const prevItem = items[index - 1];\n \n // 如果前一项是分组,显示分隔线\n if (isGroup(prevItem)) {\n return true;\n }\n // 如果当前项是分组,且前一项不是分组,显示分隔线\n if (isGroup(currentItem) && !isGroup(prevItem)) {\n return true;\n }\n return false;\n };\n\n return (\n <div ref={menuRef} className={`aha-menu-list ${className}`} style={containerStyle}>\n {/* 用户资料 */}\n {userProfile && renderUserProfile()}\n \n {/* 菜单项 */}\n <div>\n {items.map((item, index) => (\n <React.Fragment key={index}>\n {/* 分隔线 */}\n {shouldShowDivider(index, items) && (\n <div\n style={{\n height: '1px',\n backgroundColor: '#E7E5E4',\n margin: '4px 0',\n }}\n />\n )}\n {/* 菜单项或分组 */}\n {isGroup(item)\n ? renderGroup(item)\n : renderMenuItem(item)}\n </React.Fragment>\n ))}\n </div>\n </div>\n );\n};\n\nMenuList.displayName = 'MenuList';\n\nexport default MenuList;\n","import React, { useState, useRef, useEffect, useCallback } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nexport type TooltipPosition = \n | \"top\" \n | \"bottom\" \n | \"left\" \n | \"right\"\n | \"top-left\"\n | \"top-right\"\n | \"bottom-left\"\n | \"bottom-right\";\n\nexport type TooltipTrigger = \"hover\" | \"click\";\n\nexport interface TooltipProps {\n /** Tooltip 内容 */\n content: React.ReactNode;\n /** 触发元素 */\n children: React.ReactNode;\n /** 显示位置 */\n position?: TooltipPosition;\n /** 触发方式 */\n trigger?: TooltipTrigger;\n /** 延迟显示时间(毫秒) */\n delay?: number;\n /** 是否禁用 */\n disabled?: boolean;\n /** 自定义样式类名 */\n className?: string;\n /** 自定义 tooltip 样式类名 */\n tooltipClassName?: string;\n /** Tooltip 与触发元素的间距(像素) */\n gap?: number;\n /** 是否显示箭头 */\n showArrow?: boolean;\n /** Tooltip 内容宽度(如 \"200px\"、\"50%\" 等),不设置则使用自动计算 */\n width?: string | number;\n /** 是否默认显示(非受控) */\n defaultVisible?: boolean;\n /** 是否显示(受控) */\n visible?: boolean;\n /** 显示/隐藏时的回调 */\n onVisibleChange?: (visible: boolean) => void;\n}\n\n// 箭头尺寸\nconst ARROW_SIZE = 6;\n// 默认间距\nconst GAP_DEFAULT = 6;\n\n// 计算箭头位置(相对于 tooltip 内容的位置)\nconst getArrowPosition = (\n position: TooltipPosition,\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n tooltipLeft: number,\n tooltipTop: number\n): React.CSSProperties => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n \n const triggerCenterX = triggerRect.left + (triggerRect.width - ARROW_SIZE) / 2;\n const triggerCenterY = triggerRect.top + (triggerRect.height - ARROW_SIZE) / 2;\n \n // 计算箭头相对于 tooltip 内容的位置\n const tooltipAbsoluteLeft = tooltipLeft - scrollX;\n const tooltipAbsoluteTop = tooltipTop - scrollY;\n \n switch (position) {\n case \"top\":\n return {\n bottom: -ARROW_SIZE,\n left: Math.min(Math.max(triggerCenterX - tooltipAbsoluteLeft, ARROW_SIZE), tooltipRect.width - ARROW_SIZE),\n };\n case \"bottom\":\n return {\n top: -ARROW_SIZE,\n left: Math.min(Math.max(triggerCenterX - tooltipAbsoluteLeft, ARROW_SIZE), tooltipRect.width - ARROW_SIZE),\n };\n case \"left\":\n return {\n right: -ARROW_SIZE,\n top: Math.min(Math.max(triggerCenterY - tooltipAbsoluteTop, ARROW_SIZE), tooltipRect.height - ARROW_SIZE),\n };\n case \"right\":\n return {\n left: -ARROW_SIZE,\n top: Math.min(Math.max(triggerCenterY - tooltipAbsoluteTop, ARROW_SIZE), tooltipRect.height - ARROW_SIZE),\n };\n case \"top-left\":\n return {\n bottom: -ARROW_SIZE,\n left: 12,\n };\n case \"top-right\":\n return {\n bottom: -ARROW_SIZE,\n right: 12,\n };\n case \"bottom-left\":\n return {\n top: -ARROW_SIZE,\n left: 12,\n };\n case \"bottom-right\":\n return {\n top: -ARROW_SIZE,\n right: 12,\n };\n default:\n return {};\n }\n};\n\n// 计算 tooltip 位置\nconst calculatePosition = (\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n position: TooltipPosition,\n gap: number = GAP_DEFAULT\n): { top: number; left: number } => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n \n const triggerCenterX = triggerRect.left + triggerRect.width / 2;\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n \n // 考虑箭头的高度\n const arrowOffset = ARROW_SIZE;\n const totalGap = gap + arrowOffset;\n \n let top = 0;\n let left = 0;\n \n switch (position) {\n case \"top\":\n top = triggerRect.top - tooltipRect.height - totalGap + scrollY;\n left = triggerCenterX - tooltipRect.width / 2 + scrollX;\n break;\n case \"bottom\":\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerCenterX - tooltipRect.width / 2 + scrollX;\n break;\n case \"left\":\n top = triggerCenterY - tooltipRect.height / 2 + scrollY;\n left = triggerRect.left - tooltipRect.width - totalGap + scrollX;\n break;\n case \"right\":\n top = triggerCenterY - tooltipRect.height / 2 + scrollY;\n left = triggerRect.right + totalGap + scrollX;\n break;\n case \"top-left\":\n top = triggerRect.top - tooltipRect.height - totalGap + scrollY;\n left = triggerRect.left + scrollX;\n break;\n case \"top-right\":\n top = triggerRect.top - tooltipRect.height - totalGap + scrollY;\n left = triggerRect.right - tooltipRect.width + scrollX;\n break;\n case \"bottom-left\":\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerRect.left + scrollX;\n break;\n case \"bottom-right\":\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerRect.right - tooltipRect.width + scrollX;\n break;\n default:\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerCenterX - tooltipRect.width / 2 + scrollX;\n }\n \n // 边界检测,确保 tooltip 不会超出视口\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const padding = 8;\n \n if (left < scrollX + padding) {\n left = scrollX + padding;\n } else if (left + tooltipRect.width > scrollX + viewportWidth - padding) {\n left = scrollX + viewportWidth - tooltipRect.width - padding;\n }\n \n if (top < scrollY + padding) {\n top = scrollY + padding;\n } else if (top + tooltipRect.height > scrollY + viewportHeight - padding) {\n top = scrollY + viewportHeight - tooltipRect.height - padding;\n }\n return { top, left };\n};\n\n// 检查指定位置是否会遮挡触发元素(使用实际计算后的位置)\nconst willOverlap = (\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n position: TooltipPosition,\n gap: number = GAP_DEFAULT\n): boolean => {\n // 使用 calculatePosition 计算实际位置(包含边界调整)\n const { top: calculatedTop, left: calculatedLeft } = calculatePosition(\n triggerRect,\n tooltipRect,\n position,\n gap\n );\n \n // 转换为视口坐标(不包含 scroll)\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n const top = calculatedTop - scrollY;\n const left = calculatedLeft - scrollX;\n \n // 检查 tooltip 和触发元素是否重叠\n const tooltipBottom = top + tooltipRect.height;\n const tooltipRight = left + tooltipRect.width;\n const tooltipTop = top;\n const tooltipLeft = left;\n \n // 计算重叠区域\n const overlapTop = Math.max(tooltipTop, triggerRect.top);\n const overlapBottom = Math.min(tooltipBottom, triggerRect.bottom);\n const overlapLeft = Math.max(tooltipLeft, triggerRect.left);\n const overlapRight = Math.min(tooltipRight, triggerRect.right);\n \n // 如果有重叠,返回 true\n return overlapBottom > overlapTop + 1 && overlapRight > overlapLeft + 1;\n};\n\n// 自动选择最佳位置:灵活尝试多个方向\nconst getAutoPosition = (\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n preferredPosition: TooltipPosition,\n gap: number = GAP_DEFAULT\n): TooltipPosition => {\n // 如果不会遮挡,直接返回指定位置\n if (!willOverlap(triggerRect, tooltipRect, preferredPosition, gap)) {\n return preferredPosition;\n }\n \n // 定义位置优先级列表\n const getPositionCandidates = (pos: TooltipPosition): TooltipPosition[] => {\n switch (pos) {\n case \"top\":\n return [\"bottom\", \"right\", \"left\"];\n case \"bottom\":\n return [\"top\", \"right\", \"left\"];\n case \"left\":\n return [\"right\", \"top\", \"bottom\"];\n case \"right\":\n return [\"left\", \"top\", \"bottom\"];\n case \"top-left\":\n return [\"bottom-left\", \"top-right\", \"bottom-right\", \"right\", \"left\"];\n case \"top-right\":\n return [\"bottom-right\", \"top-left\", \"bottom-left\", \"left\", \"right\"];\n case \"bottom-left\":\n return [\"top-left\", \"bottom-right\", \"top-right\", \"right\", \"left\"];\n case \"bottom-right\":\n return [\"top-right\", \"bottom-left\", \"top-left\", \"left\", \"right\"];\n default:\n return [];\n }\n };\n \n // 尝试候选位置,找到第一个不遮挡的\n const candidates = getPositionCandidates(preferredPosition);\n for (const candidate of candidates) {\n if (!willOverlap(triggerRect, tooltipRect, candidate, gap)) {\n return candidate;\n }\n }\n \n // 如果所有位置都遮挡,返回首选位置(至少保证功能可用)\n return preferredPosition;\n};\n\n// 渲染箭头\nconst renderArrow = (\n position: TooltipPosition,\n arrowStyle: React.CSSProperties\n) => {\n const baseArrowStyle: React.CSSProperties = {\n position: \"absolute\",\n width: 0,\n height: 0,\n borderStyle: \"solid\" as const,\n ...arrowStyle,\n };\n\n const arrowStyles: Record<TooltipPosition, React.CSSProperties> = {\n top: {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px 0 ${ARROW_SIZE}px`,\n borderColor: \"#0C0A09 transparent transparent transparent\",\n },\n bottom: {\n ...baseArrowStyle,\n borderWidth: `0 ${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent #0C0A09 transparent\",\n },\n left: {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px 0 ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent transparent #0C0A09\",\n },\n right: {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px 0`,\n borderColor: \"transparent #0C0A09 transparent transparent\",\n },\n \"top-left\": {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px 0 ${ARROW_SIZE}px`,\n borderColor: \"#0C0A09 transparent transparent transparent\",\n },\n \"top-right\": {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px 0 ${ARROW_SIZE}px`,\n borderColor: \"#0C0A09 transparent transparent transparent\",\n },\n \"bottom-left\": {\n ...baseArrowStyle,\n borderWidth: `0 ${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent #0C0A09 transparent\",\n },\n \"bottom-right\": {\n ...baseArrowStyle,\n borderWidth: `0 ${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent #0C0A09 transparent\",\n },\n };\n return <div style={arrowStyles[position] as any} />;\n};\n\nconst Tooltip: React.FC<TooltipProps> = ({\n content,\n children,\n position = \"top\",\n trigger = \"hover\",\n delay = 200,\n disabled = false,\n className = \"\",\n tooltipClassName = \"\",\n gap = GAP_DEFAULT,\n showArrow = true,\n width,\n defaultVisible = false,\n visible,\n onVisibleChange,\n}) => {\n // 受控或非受控模式\n const isControlled = visible !== undefined;\n const [internalVisible, setInternalVisible] = useState(defaultVisible);\n const isVisible = isControlled ? visible : internalVisible;\n \n // 初始化 isAnimating 状态:受控模式用 visible,非受控模式用 defaultVisible\n const [isAnimating, setIsAnimating] = useState(isControlled ? (visible ?? false) : defaultVisible);\n \n const setIsVisible = useCallback((newVisible: boolean) => {\n if (!isControlled) {\n setInternalVisible(newVisible);\n }\n onVisibleChange?.(newVisible);\n }, [isControlled, onVisibleChange]);\n\n // 当受控模式的 visible 改变时,同步更新 isAnimating\n useEffect(() => {\n if (isControlled) {\n if (visible) {\n // 显示时,延迟一点再开始动画\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n } else {\n // 隐藏时,先停止动画,然后隐藏\n setIsAnimating(false);\n }\n }\n }, [isControlled, visible]);\n const [actualPosition, setActualPosition] = useState<TooltipPosition>(position);\n const [tooltipMaxWidth, setTooltipMaxWidth] = useState<string>(\"320px\");\n const [tooltipStyle, setTooltipStyle] = useState<React.CSSProperties>({\n position: \"absolute\",\n top: 0,\n left: 0,\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n });\n const [arrowStyle, setArrowStyle] = useState<React.CSSProperties>({});\n \n const triggerRef = useRef<HTMLDivElement>(null);\n const tooltipRef = useRef<HTMLDivElement>(null);\n const timeoutRef = useRef<NodeJS.Timeout | null>(null);\n const hideTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n \n const updatePosition = useCallback(() => {\n if (!triggerRef.current || !tooltipRef.current || !isVisible) return;\n \n // 如果正在隐藏动画中,不更新位置,避免移位\n if (!isAnimating) return;\n \n const triggerRect = triggerRef.current.getBoundingClientRect();\n const tooltipRect = tooltipRef.current.getBoundingClientRect();\n \n // 自动选择最佳位置,避免超出视口或被遮挡\n const finalPosition = getAutoPosition(triggerRect, tooltipRect, position, gap);\n setActualPosition(finalPosition);\n \n const { top, left } = calculatePosition(triggerRect, tooltipRect, finalPosition, gap);\n setTooltipStyle((prev) => ({\n ...prev,\n position: \"absolute\",\n top: `${top}px`,\n left: `${left}px`,\n // opacity 由 tooltipContainerStyle 控制,不在这里设置\n // hover 模式下允许鼠标事件,click 模式下禁用\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n zIndex: 9999,\n }));\n\n // 计算箭头位置\n if (showArrow) {\n const arrowPos = getArrowPosition(\n finalPosition,\n triggerRect,\n tooltipRect,\n left,\n top\n );\n setArrowStyle(arrowPos);\n }\n }, [isVisible, position, gap, showArrow, isAnimating, trigger]);\n \n const showTooltip = useCallback(() => {\n if (disabled) return;\n \n // 清除隐藏定时器\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n hideTimeoutRef.current = null;\n }\n \n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n \n timeoutRef.current = setTimeout(() => {\n setIsVisible(true);\n // 触发动画\n if (!isControlled) {\n // 非受控模式下,直接设置动画状态\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n }\n // 受控模式下,动画状态由 visible prop 变化触发的 useEffect 控制\n }, delay);\n }, [disabled, delay, setIsVisible, isControlled]);\n \n const hideTooltip = useCallback(() => {\n // 清除显示定时器\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = null;\n }\n \n // 清除隐藏定时器\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n }\n \n if (!isControlled) {\n // 非受控模式下,先停止动画,然后隐藏\n setIsAnimating(false);\n hideTimeoutRef.current = setTimeout(() => {\n setIsVisible(false);\n hideTimeoutRef.current = null;\n }, 150);\n } else {\n // 受控模式下,直接调用 setIsVisible(会触发 onVisibleChange)\n setIsVisible(false);\n }\n }, [setIsVisible, isControlled]);\n\n // 保持 tooltip 显示(当鼠标在 tooltip 内容上时)\n const keepTooltipVisible = useCallback(() => {\n if (trigger !== \"hover\") return;\n \n // 清除隐藏定时器\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n hideTimeoutRef.current = null;\n }\n \n // 确保 tooltip 可见\n if (!isVisible) {\n setIsVisible(true);\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n }\n }, [trigger, isVisible]);\n\n // 点击触发工具提示(click 模式)\n const handleClick = useCallback((e: React.MouseEvent) => {\n if (disabled || trigger !== \"click\") return;\n \n e.stopPropagation();\n \n // 如果已经显示,则隐藏\n if (isVisible) {\n hideTooltip();\n } else {\n // 清除延迟定时器,立即显示(click 模式不使用延迟)\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = null;\n }\n setIsVisible(true);\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n }\n }, [disabled, trigger, isVisible, hideTooltip]);\n\n // 当 defaultVisible 为 true 时,确保初始位置正确计算\n useEffect(() => {\n if (defaultVisible && isVisible && isAnimating) {\n // 多次尝试更新位置,确保 DOM 已渲染\n const tryUpdatePosition = () => {\n if (triggerRef.current && tooltipRef.current) {\n updatePosition();\n } else {\n // 如果 DOM 还没准备好,再试一次\n setTimeout(() => {\n requestAnimationFrame(tryUpdatePosition);\n }, 10);\n }\n };\n \n // 延迟执行,确保 Portal 已渲染到 DOM\n setTimeout(() => {\n requestAnimationFrame(tryUpdatePosition);\n }, 0);\n }\n }, [defaultVisible, isVisible, isAnimating, updatePosition]); // 只在初始化时执行\n\n useEffect(() => {\n if (isVisible) {\n // 使用 requestAnimationFrame 确保 DOM 已更新\n requestAnimationFrame(() => {\n updatePosition();\n });\n \n // 监听滚动和窗口大小变化\n window.addEventListener(\"scroll\", updatePosition, true);\n window.addEventListener(\"resize\", updatePosition);\n \n return () => {\n window.removeEventListener(\"scroll\", updatePosition, true);\n window.removeEventListener(\"resize\", updatePosition);\n };\n }\n }, [isVisible, updatePosition]);\n\n // 点击外部区域关闭 tooltip(仅 click 模式)\n useEffect(() => {\n if (!isVisible || trigger !== \"click\") return;\n\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current &&\n tooltipRef.current &&\n !triggerRef.current.contains(event.target as Node) &&\n !tooltipRef.current.contains(event.target as Node)\n ) {\n hideTooltip();\n }\n };\n\n // 使用捕获阶段确保在其他点击处理之前执行\n document.addEventListener(\"mousedown\", handleClickOutside, true);\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside, true);\n };\n }, [isVisible, trigger, hideTooltip]);\n \n useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n }\n };\n }, []);\n\n // Tooltip 容器样式\n const tooltipContainerStyle: React.CSSProperties = {\n position: \"absolute\",\n top: 0,\n left: 0,\n opacity: isAnimating ? 1 : 0,\n transform: isAnimating ? \"scale(1)\" : \"scale(0.95)\",\n transition: \"opacity 150ms ease-out, transform 150ms ease-out\",\n // hover 模式下允许鼠标事件,click 模式下禁用\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n zIndex: 9999,\n };\n\n // 计算 tooltip 最大宽度\n const calculateTooltipMaxWidth = useCallback((): string => {\n if (typeof window === \"undefined\") return \"320px\";\n const viewportWidth = window.innerWidth;\n // 移动端:使用 calc 确保不超出屏幕\n // 桌面端:最大宽度 320px\n return viewportWidth >= 768 ? \"320px\" : \"calc(100vw - 32px)\";\n }, []);\n\n // 更新 tooltip 最大宽度\n useEffect(() => {\n const updateMaxWidth = () => {\n setTooltipMaxWidth(calculateTooltipMaxWidth());\n };\n \n updateMaxWidth();\n window.addEventListener(\"resize\", updateMaxWidth);\n \n return () => {\n window.removeEventListener(\"resize\", updateMaxWidth);\n };\n }, [calculateTooltipMaxWidth]);\n\n // Tooltip 内容样式(符合设计系统)\n const tooltipContentStyle: React.CSSProperties = {\n backgroundColor: \"#0C0A09\",\n color: \"#FFFFFF\",\n padding: \"8px 12px\",\n borderRadius: \"6px\",\n fontSize: \"12px\",\n fontWeight: 400,\n fontFamily: \"DM Sans, sans-serif\",\n lineHeight: \"16px\",\n // 如果设置了 width,使用设置的宽度,但在移动端也要限制最大宽度;否则使用自动计算的最大宽度\n ...(width !== undefined\n ? {\n width: typeof width === \"number\" ? `${width}px` : width,\n // 移动端也要限制最大宽度,不能超出屏幕\n maxWidth: typeof window !== \"undefined\" && window.innerWidth < 768 \n ? \"calc(100vw - 32px)\" \n : undefined,\n }\n : {\n maxWidth: tooltipMaxWidth,\n width: \"max-content\",\n }),\n wordWrap: \"break-word\",\n boxShadow: \"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)\",\n whiteSpace: \"pre-wrap\",\n position: \"relative\",\n boxSizing: \"border-box\",\n };\n\n const tooltipContent = (\n <div\n style={{\n ...tooltipContainerStyle,\n ...tooltipStyle,\n // 确保 hover 模式下 pointerEvents 为 auto\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n } as any}\n className={`aha-tooltip-wrapper ${tooltipClassName}`}\n onMouseEnter={trigger === \"hover\" ? keepTooltipVisible : undefined}\n onMouseLeave={trigger === \"hover\" ? hideTooltip : undefined}\n >\n <div\n ref={tooltipRef}\n className={`aha-tooltip ${tooltipClassName}`}\n style={tooltipContentStyle as any}\n role=\"tooltip\"\n >\n {content}\n </div>\n {showArrow && renderArrow(actualPosition, arrowStyle)}\n </div>\n );\n \n // 延迟隐藏(用于从触发元素移动到 tooltip 内容的过渡)\n const handleTriggerMouseLeave = useCallback(() => {\n if (trigger !== \"hover\") return;\n \n // 延迟隐藏,给用户时间移动到 tooltip 内容上\n // 如果用户在延迟期间移动到 tooltip 内容上,keepTooltipVisible 会清除这个定时器\n hideTimeoutRef.current = setTimeout(() => {\n hideTooltip();\n }, 100);\n }, [trigger, hideTooltip]);\n\n // 根据触发模式设置事件处理器\n const triggerProps = trigger === \"click\" \n ? {\n onClick: handleClick,\n }\n : {\n onMouseEnter: showTooltip,\n onMouseLeave: handleTriggerMouseLeave,\n onFocus: showTooltip,\n onBlur: hideTooltip,\n };\n\n return (\n <>\n <div\n ref={triggerRef}\n className={`aha-tooltip-trigger ${className}`}\n style={{ display: \"inline-block\", cursor: trigger === \"click\" ? \"pointer\" : \"default\" }}\n {...triggerProps}\n >\n {children}\n </div>\n {isVisible && typeof document !== \"undefined\" && createPortal(tooltipContent, document.body)}\n </>\n );\n};\n\nexport default Tooltip;","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nexport type PopoverTrigger = \"click\" | \"hover\";\nexport type PopoverPlacement = \"top\" | \"right\" | \"bottom\" | \"left\";\n\nexport interface PopoverProps {\n /** 触发节点 */\n children: React.ReactNode;\n /** Popover 内容 */\n content: React.ReactNode;\n /** 触发模式 */\n trigger?: PopoverTrigger;\n /** 是否显示(受控) */\n open?: boolean;\n /** 默认是否显示(非受控) */\n defaultOpen?: boolean;\n /** 显示状态变化回调 */\n onOpenChange?: (open: boolean) => void;\n /** 展示方向 */\n placement?: PopoverPlacement;\n /** 内容宽度 */\n width?: string | number;\n /** 触发节点和 Popover 的间距 */\n offset?: number;\n /** 自定义容器类名 */\n className?: string;\n /** 自定义 Popover 类名 */\n popoverClassName?: string;\n /** 是否禁用 */\n disabled?: boolean;\n /** 关闭时是否销毁内容,默认 true */\n destroyOnHide?: boolean;\n /** antd 兼容参数:关闭时是否销毁内容 */\n destroyTooltipOnHide?: boolean;\n /** 是否显示箭头(兼容参数,当前不渲染箭头) */\n arrow?: boolean;\n}\n\nconst DEFAULT_OFFSET = 8;\nconst VIEWPORT_PADDING = 8;\n\nconst getOppositePlacement = (placement: PopoverPlacement): PopoverPlacement => {\n switch (placement) {\n case \"top\":\n return \"bottom\";\n case \"bottom\":\n return \"top\";\n case \"left\":\n return \"right\";\n case \"right\":\n default:\n return \"left\";\n }\n};\n\nconst hasEnoughSpace = (\n triggerRect: DOMRect,\n popoverRect: DOMRect,\n placement: PopoverPlacement,\n offset: number\n) => {\n switch (placement) {\n case \"top\":\n return triggerRect.top >= popoverRect.height + offset + VIEWPORT_PADDING;\n case \"bottom\":\n return window.innerHeight - triggerRect.bottom >= popoverRect.height + offset + VIEWPORT_PADDING;\n case \"left\":\n return triggerRect.left >= popoverRect.width + offset + VIEWPORT_PADDING;\n case \"right\":\n default:\n return window.innerWidth - triggerRect.right >= popoverRect.width + offset + VIEWPORT_PADDING;\n }\n};\n\nconst getAvailableSpace = (triggerRect: DOMRect, placement: PopoverPlacement) => {\n switch (placement) {\n case \"top\":\n return triggerRect.top;\n case \"bottom\":\n return window.innerHeight - triggerRect.bottom;\n case \"left\":\n return triggerRect.left;\n case \"right\":\n default:\n return window.innerWidth - triggerRect.right;\n }\n};\n\nconst getPlacementPosition = (\n triggerRect: DOMRect,\n popoverRect: DOMRect,\n placement: PopoverPlacement,\n offset: number\n) => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n const triggerCenterX = triggerRect.left + triggerRect.width / 2;\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n\n switch (placement) {\n case \"top\":\n return {\n top: triggerRect.top - popoverRect.height - offset + scrollY,\n left: triggerCenterX - popoverRect.width / 2 + scrollX,\n };\n case \"bottom\":\n return {\n top: triggerRect.bottom + offset + scrollY,\n left: triggerCenterX - popoverRect.width / 2 + scrollX,\n };\n case \"left\":\n return {\n top: triggerCenterY - popoverRect.height / 2 + scrollY,\n left: triggerRect.left - popoverRect.width - offset + scrollX,\n };\n case \"right\":\n default:\n return {\n top: triggerCenterY - popoverRect.height / 2 + scrollY,\n left: triggerRect.right + offset + scrollX,\n };\n }\n};\n\nconst clampToViewport = (top: number, left: number, popoverRect: DOMRect) => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const boundaryPadding = VIEWPORT_PADDING;\n\n let nextTop = top;\n let nextLeft = left;\n\n if (nextLeft < scrollX + boundaryPadding) {\n nextLeft = scrollX + boundaryPadding;\n }\n if (nextLeft + popoverRect.width > scrollX + viewportWidth - boundaryPadding) {\n nextLeft = scrollX + viewportWidth - popoverRect.width - boundaryPadding;\n }\n\n if (nextTop < scrollY + boundaryPadding) {\n nextTop = scrollY + boundaryPadding;\n }\n if (nextTop + popoverRect.height > scrollY + viewportHeight - boundaryPadding) {\n nextTop = scrollY + viewportHeight - popoverRect.height - boundaryPadding;\n }\n\n return { top: nextTop, left: nextLeft };\n};\n\nconst Popover: React.FC<PopoverProps> = ({\n children,\n content,\n trigger = \"click\",\n open,\n defaultOpen = false,\n onOpenChange,\n placement = \"right\",\n width,\n offset = DEFAULT_OFFSET,\n className = \"\",\n popoverClassName = \"\",\n disabled = false,\n destroyOnHide,\n destroyTooltipOnHide,\n}) => {\n const shouldDestroyOnHide =\n destroyOnHide ?? destroyTooltipOnHide ?? true;\n const isControlled = open !== undefined;\n const [internalVisible, setInternalVisible] = useState(defaultOpen);\n const visible = isControlled ? !!open : internalVisible;\n const [popoverStyle, setPopoverStyle] = useState<React.CSSProperties>({\n top: 0,\n left: 0,\n opacity: 0,\n });\n\n const triggerRef = useRef<HTMLDivElement>(null);\n const popoverRef = useRef<HTMLDivElement>(null);\n\n const setVisible = useCallback(\n (nextVisible: boolean) => {\n if (!isControlled) {\n setInternalVisible(nextVisible);\n }\n onOpenChange?.(nextVisible);\n },\n [isControlled, onOpenChange]\n );\n\n const updatePosition = useCallback(() => {\n if (!visible || !triggerRef.current || !popoverRef.current) {\n return;\n }\n\n const triggerRect = triggerRef.current.getBoundingClientRect();\n const popoverRect = popoverRef.current.getBoundingClientRect();\n const nextPlacement = (() => {\n if (hasEnoughSpace(triggerRect, popoverRect, placement, offset)) {\n return placement;\n }\n const oppositePlacement = getOppositePlacement(placement);\n if (hasEnoughSpace(triggerRect, popoverRect, oppositePlacement, offset)) {\n return oppositePlacement;\n }\n return getAvailableSpace(triggerRect, oppositePlacement) > getAvailableSpace(triggerRect, placement)\n ? oppositePlacement\n : placement;\n })();\n\n const { top, left } = getPlacementPosition(triggerRect, popoverRect, nextPlacement, offset);\n const clamped = clampToViewport(top, left, popoverRect);\n\n setPopoverStyle({\n top: clamped.top,\n left: clamped.left,\n opacity: 1,\n });\n }, [visible, placement, offset]);\n\n const openPopover = useCallback(() => {\n if (disabled) return;\n setVisible(true);\n }, [disabled, setVisible]);\n\n const closePopover = useCallback(() => {\n setVisible(false);\n }, [setVisible]);\n\n const togglePopover = useCallback(() => {\n if (disabled) return;\n setVisible(!visible);\n }, [disabled, visible, setVisible]);\n\n useEffect(() => {\n if (!visible) return;\n\n requestAnimationFrame(() => {\n updatePosition();\n });\n\n window.addEventListener(\"resize\", updatePosition);\n window.addEventListener(\"scroll\", updatePosition, true);\n\n return () => {\n window.removeEventListener(\"resize\", updatePosition);\n window.removeEventListener(\"scroll\", updatePosition, true);\n };\n }, [visible, updatePosition]);\n\n useEffect(() => {\n if (!visible || trigger !== \"click\") return;\n\n const handleClickOutside = (event: MouseEvent) => {\n const target = event.target as Node;\n if (\n triggerRef.current &&\n popoverRef.current &&\n !triggerRef.current.contains(target) &&\n !popoverRef.current.contains(target)\n ) {\n closePopover();\n }\n };\n\n document.addEventListener(\"mousedown\", handleClickOutside);\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n };\n }, [visible, trigger, closePopover]);\n\n const triggerEvents =\n trigger === \"hover\"\n ? {\n onMouseEnter: openPopover,\n onMouseLeave: closePopover,\n onFocus: openPopover,\n onBlur: closePopover,\n }\n : {\n onClick: (event: React.MouseEvent) => {\n event.stopPropagation();\n togglePopover();\n },\n };\n\n const shouldRenderPopoverNode = visible || !shouldDestroyOnHide;\n\n const popoverNode = shouldRenderPopoverNode ? (\n <div\n ref={popoverRef}\n className={`aha-popover ${popoverClassName}`}\n style={{\n position: \"absolute\",\n zIndex: 9999,\n top: popoverStyle.top,\n left: popoverStyle.left,\n opacity: visible ? popoverStyle.opacity : 0,\n visibility: visible ? \"visible\" : \"hidden\",\n pointerEvents: visible ? \"auto\" : \"none\",\n transition: \"opacity 120ms ease-out\",\n width: typeof width === \"number\" ? `${width}px` : width,\n maxWidth: `calc(100vw - ${VIEWPORT_PADDING * 2}px)`,\n backgroundColor: \"#FFFFFF\",\n border: \"1px solid #00000014\",\n borderRadius: \"12px\",\n padding: \"6px\",\n boxSizing: \"border-box\",\n boxShadow:\n \"0px 2px 2px -1px var(--ColorsEffectsShadowsshadow-lg03), 0px 4px 6px -2px var(--ColorsEffectsShadowsshadow-lg02), 0px 12px 16px -4px var(--ColorsEffectsShadowsshadow-lg01)\",\n }}\n onMouseEnter={trigger === \"hover\" ? openPopover : undefined}\n onMouseLeave={trigger === \"hover\" ? closePopover : undefined}\n onMouseDown={trigger === \"click\" ? (event) => event.stopPropagation() : undefined}\n >\n {content}\n </div>\n ) : null;\n\n return (\n <>\n <div\n ref={triggerRef}\n className={`aha-popover-trigger ${className}`}\n style={{ display: \"inline-block\", cursor: disabled ? \"not-allowed\" : \"pointer\" }}\n {...triggerEvents}\n >\n {children}\n </div>\n {popoverNode && typeof document !== \"undefined\" && createPortal(popoverNode, document.body)}\n </>\n );\n};\n\nPopover.displayName = \"Popover\";\n\nexport default Popover;\n","import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nexport type DrawerPlacement = \"left\" | \"right\" | \"top\" | \"bottom\";\n\nexport interface DrawerProps {\n /** 是否打开(受控) */\n open?: boolean;\n /** 默认是否打开(非受控) */\n defaultOpen?: boolean;\n /** 关闭回调 */\n onClose?: (e?: React.MouseEvent | React.KeyboardEvent) => void;\n /** 打开/关闭动画结束回调 */\n afterOpenChange?: (open: boolean) => void;\n /** 抽屉标题 */\n title?: React.ReactNode;\n /** 头部右侧内容 */\n extra?: React.ReactNode;\n /** 底部内容 */\n footer?: React.ReactNode;\n /** 内容 */\n children?: React.ReactNode;\n /** 打开方向 */\n placement?: DrawerPlacement;\n /** PC 端宽度(移动端始终使用 100vw) */\n width?: number | string;\n /** 高度(top/bottom 生效,移动端同样支持) */\n height?: number | string;\n /** 是否显示遮罩 */\n mask?: boolean;\n /** 点击遮罩是否关闭 */\n maskClosable?: boolean;\n /** 是否显示右上角关闭按钮 */\n closable?: boolean;\n /** 自定义关闭图标 */\n closeIcon?: React.ReactNode;\n /** 是否支持 Esc 关闭 */\n keyboard?: boolean;\n /** 是否在关闭后销毁内容 */\n destroyOnClose?: boolean;\n /** 层级 */\n zIndex?: number;\n /** 移动端断点 */\n mobileBreakpoint?: number;\n /** 容器类名 */\n className?: string;\n /** 容器样式 */\n style?: React.CSSProperties;\n /** 抽屉面板类名 */\n drawerStyle?: React.CSSProperties;\n /** 头部样式 */\n headerStyle?: React.CSSProperties;\n /** 内容样式 */\n bodyStyle?: React.CSSProperties;\n /** 底部样式 */\n footerStyle?: React.CSSProperties;\n /** 遮罩样式 */\n maskStyle?: React.CSSProperties;\n}\n\nconst ANIMATION_DURATION = 240;\n\nconst Drawer: React.FC<DrawerProps> = ({\n open,\n defaultOpen = false,\n onClose,\n afterOpenChange,\n title,\n extra,\n footer,\n children,\n placement = \"right\",\n width = 378,\n height = 378,\n mask = true,\n maskClosable = true,\n closable = true,\n closeIcon,\n keyboard = true,\n destroyOnClose = false,\n zIndex = 1000,\n mobileBreakpoint = 768,\n className = \"\",\n style,\n drawerStyle,\n headerStyle,\n bodyStyle,\n footerStyle,\n maskStyle,\n}) => {\n const isControlled = open !== undefined;\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const mergedOpen = isControlled ? !!open : internalOpen;\n const [shouldRender, setShouldRender] = useState(mergedOpen);\n const [animatedOpen, setAnimatedOpen] = useState(mergedOpen);\n const [mounted, setMounted] = useState(false);\n const [isMobile, setIsMobile] = useState(false);\n\n useEffect(() => {\n setMounted(true);\n }, []);\n\n useEffect(() => {\n const updateMobile = () => {\n setIsMobile(window.innerWidth < mobileBreakpoint);\n };\n\n updateMobile();\n window.addEventListener(\"resize\", updateMobile);\n return () => {\n window.removeEventListener(\"resize\", updateMobile);\n };\n }, [mobileBreakpoint]);\n\n useEffect(() => {\n if (mergedOpen) {\n setShouldRender(true);\n // 先在新方向的“关闭位置”渲染一帧,再执行打开动画,避免方向切换时动画起点错误\n setAnimatedOpen(false);\n const raf = requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n setAnimatedOpen(true);\n });\n });\n const timer = window.setTimeout(() => {\n afterOpenChange?.(true);\n }, ANIMATION_DURATION);\n return () => {\n cancelAnimationFrame(raf);\n window.clearTimeout(timer);\n };\n }\n\n setAnimatedOpen(false);\n const timer = window.setTimeout(() => {\n if (destroyOnClose) {\n setShouldRender(false);\n }\n afterOpenChange?.(false);\n }, ANIMATION_DURATION);\n\n return () => window.clearTimeout(timer);\n }, [mergedOpen, destroyOnClose, afterOpenChange]);\n\n useEffect(() => {\n if (!mergedOpen || !keyboard) return;\n\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onClose?.(event as unknown as React.KeyboardEvent);\n if (!isControlled) {\n setInternalOpen(false);\n }\n }\n };\n\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => {\n document.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [mergedOpen, keyboard, onClose, isControlled]);\n\n useEffect(() => {\n if (!mounted) return;\n if (!mergedOpen) return;\n\n const previousOverflow = document.body.style.overflow;\n document.body.style.overflow = \"hidden\";\n\n return () => {\n document.body.style.overflow = previousOverflow;\n };\n }, [mergedOpen, mounted]);\n\n const closeDrawer = useCallback(\n (e?: React.MouseEvent | React.KeyboardEvent) => {\n onClose?.(e);\n if (!isControlled) {\n setInternalOpen(false);\n }\n },\n [onClose, isControlled]\n );\n\n const resolvedWidth = useMemo(() => {\n if (isMobile) return \"100vw\";\n if (placement === \"left\" || placement === \"right\") {\n return typeof width === \"number\" ? `${width}px` : width;\n }\n return \"100vw\";\n }, [placement, isMobile, width]);\n\n const resolvedHeight = useMemo(() => {\n if (placement === \"top\" || placement === \"bottom\") {\n return typeof height === \"number\" ? `${height}px` : height;\n }\n return \"100vh\";\n }, [placement, height]);\n\n const effectivePlacement: DrawerPlacement = useMemo(() => {\n if (!isMobile) return placement;\n // 移动端仅支持 top / bottom,left / right 自动降级为 bottom\n if (placement === \"left\" || placement === \"right\") return \"bottom\";\n return placement;\n }, [isMobile, placement]);\n\n const drawerPositionStyle: React.CSSProperties = useMemo(() => {\n const base: React.CSSProperties = {\n position: \"fixed\",\n backgroundColor: \"#FFFFFF\",\n display: \"flex\",\n flexDirection: \"column\",\n boxSizing: \"border-box\",\n boxShadow: \"0 6px 16px rgba(0, 0, 0, 0.08), 0 3px 6px rgba(0, 0, 0, 0.12)\",\n transition: `transform ${ANIMATION_DURATION}ms cubic-bezier(0.2, 0, 0, 1)`,\n zIndex: zIndex + 1,\n };\n\n switch (effectivePlacement) {\n case \"left\":\n return {\n ...base,\n top: 0,\n left: 0,\n width: resolvedWidth,\n height: \"100vh\",\n transform: animatedOpen ? \"translateX(0)\" : \"translateX(-100%)\",\n };\n case \"right\":\n return {\n ...base,\n top: 0,\n right: 0,\n width: resolvedWidth,\n height: \"100vh\",\n transform: animatedOpen ? \"translateX(0)\" : \"translateX(100%)\",\n };\n case \"top\":\n return {\n ...base,\n top: 0,\n left: 0,\n width: \"100vw\",\n height: resolvedHeight,\n transform: animatedOpen ? \"translateY(0)\" : \"translateY(-100%)\",\n };\n case \"bottom\":\n default:\n return {\n ...base,\n bottom: 0,\n left: 0,\n width: \"100vw\",\n height: resolvedHeight,\n transform: animatedOpen ? \"translateY(0)\" : \"translateY(100%)\",\n };\n }\n }, [effectivePlacement, resolvedWidth, resolvedHeight, animatedOpen, zIndex]);\n\n if (!mounted || (!shouldRender && !mergedOpen)) {\n return null;\n }\n\n const node = (\n <div\n className={`aha-drawer-root ${className}`}\n style={{\n position: \"fixed\",\n inset: 0,\n zIndex,\n pointerEvents: mergedOpen || animatedOpen ? \"auto\" : \"none\",\n ...style,\n }}\n >\n {mask && (\n <div\n aria-hidden\n onClick={maskClosable ? (e) => closeDrawer(e) : undefined}\n style={{\n position: \"absolute\",\n inset: 0,\n background: \"rgba(0, 0, 0, 0.45)\",\n opacity: animatedOpen ? 1 : 0,\n transition: `opacity ${ANIMATION_DURATION}ms cubic-bezier(0.2, 0, 0, 1)`,\n ...maskStyle,\n }}\n />\n )}\n\n <div\n key={`${effectivePlacement}-${mergedOpen ? \"open\" : \"closed\"}`}\n role=\"dialog\"\n aria-modal=\"true\"\n style={{ ...drawerPositionStyle, ...drawerStyle }}\n >\n {(title !== undefined || closable || extra) && (\n <div\n style={{\n minHeight: \"56px\",\n padding: \"16px 24px\",\n borderBottom: \"1px solid #F0F0F0\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"space-between\",\n gap: \"12px\",\n ...headerStyle,\n }}\n >\n <div style={{ fontSize: \"16px\", fontWeight: 600, color: \"#1F2937\", flex: 1 }}>{title}</div>\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\n {extra}\n {closable && (\n <button\n type=\"button\"\n onClick={(e) => closeDrawer(e)}\n style={{\n border: \"none\",\n background: \"transparent\",\n padding: 0,\n margin: 0,\n width: \"24px\",\n height: \"24px\",\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n cursor: \"pointer\",\n color: \"#6B7280\",\n }}\n aria-label=\"Close\"\n >\n {closeIcon || (\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )}\n </button>\n )}\n </div>\n </div>\n )}\n\n <div\n style={{\n padding: \"24px\",\n overflowY: \"auto\",\n flex: 1,\n boxSizing: \"border-box\",\n ...bodyStyle,\n }}\n >\n {children}\n </div>\n\n {footer !== undefined && (\n <div\n style={{\n borderTop: \"1px solid #F0F0F0\",\n padding: \"12px 16px\",\n ...footerStyle,\n }}\n >\n {footer}\n </div>\n )}\n </div>\n </div>\n );\n\n return createPortal(node, document.body);\n};\n\nDrawer.displayName = \"Drawer\";\n\nexport default Drawer;\n","import React, { useEffect, useRef, useState } from 'react';\n\nconst curve = {\n name: 'Thinking Five',\n tag: 'Custom Rose Trail',\n rotate: true,\n particleCount: 62,\n trailSpan: 0.38,\n durationMs: 3900,\n rotationDurationMs: 28000,\n pulseDurationMs: 3000,\n strokeWidth: 5.5,\n baseRadius: 7,\n detailAmplitude: 3,\n petalCount: 5,\n curveScale: 3,\n} as const;\n\ntype CurveConfig = typeof curve;\n\nfunction point(\n progress: number,\n detailScaleValue: number,\n config: CurveConfig\n): { x: number; y: number } {\n const t = progress * Math.PI * 2;\n const petals = Math.round(config.petalCount);\n const x =\n config.baseRadius * Math.cos(t) -\n config.detailAmplitude * detailScaleValue * Math.cos(petals * t);\n const y =\n config.baseRadius * Math.sin(t) -\n config.detailAmplitude * detailScaleValue * Math.sin(petals * t);\n return {\n x: 50 + x * config.curveScale,\n y: 50 + y * config.curveScale,\n };\n}\n\nfunction getDetailScale(elapsedMs: number, config: CurveConfig): number {\n const pulseProgress =\n (elapsedMs % config.pulseDurationMs) / config.pulseDurationMs;\n const pulseAngle = pulseProgress * Math.PI * 2;\n return 0.52 + ((Math.sin(pulseAngle + 0.55) + 1) / 2) * 0.48;\n}\n\nfunction normalizeProgress(progress: number): number {\n return ((progress % 1) + 1) % 1;\n}\n\nfunction buildPath(detailScaleValue: number, config: CurveConfig, steps = 480): string {\n const parts: string[] = [];\n for (let index = 0; index <= steps; index += 1) {\n const p = point(index / steps, detailScaleValue, config);\n parts.push(`${index === 0 ? 'M' : 'L'} ${p.x.toFixed(2)} ${p.y.toFixed(2)}`);\n }\n return parts.join(' ');\n}\n\nfunction getParticle(\n index: number,\n progress: number,\n detailScaleValue: number,\n config: CurveConfig\n): { x: number; y: number; radius: number; opacity: number } {\n const denom = Math.max(1, config.particleCount - 1);\n const tailOffset = index / denom;\n const p = point(\n normalizeProgress(progress - tailOffset * config.trailSpan),\n detailScaleValue,\n config\n );\n const fade = Math.pow(1 - tailOffset, 0.56);\n return {\n x: p.x,\n y: p.y,\n radius: 0.9 + fade * 2.7,\n opacity: 0.04 + fade * 0.96,\n };\n}\n\nfunction getRotationDeg(elapsedMs: number, config: CurveConfig): number {\n if (!config.rotate) return 0;\n return -(\n ((elapsedMs % config.rotationDurationMs) / config.rotationDurationMs) *\n 360\n );\n}\n\nexport interface LoadingProps {\n width?: number | string;\n height?: number | string;\n strokeWidth?: number;\n color?: string;\n className?: string;\n}\n\nconst Loading: React.FC<LoadingProps> = ({\n width = 80,\n height = 80,\n strokeWidth: strokeWidthProp,\n color = 'var(--theme-color, #5A31F0)',\n className,\n}) => {\n const [frame, setFrame] = useState(0);\n const startRef = useRef<number | null>(null);\n\n useEffect(() => {\n let id: number;\n const tick = (now: number) => {\n if (startRef.current === null) {\n startRef.current = now;\n }\n setFrame(now - startRef.current);\n id = requestAnimationFrame(tick);\n };\n id = requestAnimationFrame(tick);\n return () => cancelAnimationFrame(id);\n }, []);\n\n const elapsed = frame;\n const s = getDetailScale(elapsed, curve);\n const progress = (elapsed % curve.durationMs) / curve.durationMs;\n const rotationDeg = getRotationDeg(elapsed, curve);\n const lineWeight = strokeWidthProp ?? curve.strokeWidth;\n const strokeScale = lineWeight / curve.strokeWidth;\n\n const pathD = buildPath(s, curve);\n\n const particles: { cx: number; cy: number; opacity: number; r: number }[] =\n [];\n for (let i = 0; i < curve.particleCount; i += 1) {\n const pt = getParticle(i, progress, s, curve);\n particles.push({\n cx: pt.x,\n cy: pt.y,\n opacity: pt.opacity,\n r: pt.radius * strokeScale,\n });\n }\n\n return (\n <div\n className={className}\n style={{\n width,\n height,\n display: 'inline-block',\n color,\n }}\n role=\"status\"\n aria-label=\"Loading\"\n >\n <svg\n width=\"100%\"\n height=\"100%\"\n viewBox=\"0 0 100 100\"\n fill=\"none\"\n preserveAspectRatio=\"xMidYMid meet\"\n style={{ overflow: 'visible' }}\n >\n <title>Thinking Five</title>\n <g transform={curve.rotate ? `rotate(${rotationDeg} 50 50)` : undefined}>\n <path\n d={pathD}\n stroke=\"currentColor\"\n strokeWidth={lineWeight}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n fill=\"none\"\n opacity={0.1}\n />\n {particles.map((pt, i) => (\n <circle\n key={i}\n cx={pt.cx}\n cy={pt.cy}\n r={pt.r}\n fill=\"currentColor\"\n opacity={pt.opacity}\n />\n ))}\n </g>\n </svg>\n </div>\n );\n};\n\nexport default Loading;\n","import React, { useState } from \"react\";\nimport { AlertIcon, CloseIcon } from \"./icon\";\n\nexport interface AlertProps {\n title?: string;\n description?: string;\n className?: string;\n type?: \"success\" | \"error\" | \"warning\" | \"info\";\n icon?: React.ReactNode;\n showIcon?: boolean;\n closeable?: boolean;\n action?: React.ReactNode;\n children?: React.ReactNode;\n /** 关闭回调 */\n onClose?: () => void;\n}\n\nconst Alert: React.FC<AlertProps> = ({\n className = \"\",\n type = \"info\",\n title,\n description,\n icon = AlertIcon[type],\n showIcon = true,\n closeable = false,\n action,\n children,\n onClose\n}) => {\n const baseClasses = \"aha-alert px-4 py-3 rounded-md flex gap-2\";\n\n // 使用内联样式作为备选方案,确保样式始终生效\n const typeStyles = {\n success: { backgroundColor: '#ECFDF5' },\n error: { backgroundColor: '#FEF2F2' },\n warning: { backgroundColor: '#FFFBEB' },\n info: { backgroundColor: '#EFF6FF' },\n };\n\n const [visible, setVisible] = useState(true);\n const handleClose = () => {\n setVisible(false);\n onClose?.();\n };\n\n const hasRightSlot = action || closeable;\n\n if (!visible) return null;\n\n return (\n <div \n className={`${baseClasses} ${className}`}\n style={typeStyles[type]}\n >\n {showIcon && icon}\n <div\n className={`flex flex-col gap-1 ${hasRightSlot ? \"flex-1 min-w-0\" : \"\"}`}\n >\n {title && (\n <div className=\"justify-start text-[#292524] text-base font-semibold font-['DM_Sans'] leading-normal\">\n {title}\n </div>\n )}\n {description && (\n <div className=\"w-full justify-center text-[#57534D] text-sm font-normal font-['DM_Sans'] leading-snug\">\n {description}\n </div>\n )}\n {children && (\n <div className=\"w-full justify-center text-[#57534D] text-sm font-normal font-['DM_Sans'] leading-snug\">\n {children}\n </div>\n )}\n </div>\n {hasRightSlot && (\n <div className=\"ml-auto flex-shrink-0 self-center flex items-center gap-2\">\n {action}\n {closeable && (\n <div\n className=\"cursor-pointer relative top-[-12px]\"\n onClick={handleClose}\n onKeyDown={(e) => e.key === \"Enter\" && handleClose()}\n role=\"button\"\n tabIndex={0}\n aria-label=\"关闭\"\n >\n {CloseIcon}\n </div>\n )}\n </div>\n )}\n </div>\n );\n};\n\nexport default Alert;\n","import React, { useRef, useEffect, useState } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport type ProgressType = 'circle' | 'semicircle' | string;\nexport type ProgressStatus = 'normal' | 'success' | 'exception' | 'active';\nexport type TitlePosition = 'inside' | 'outside';\n\nexport interface ProgressProps {\n /** 进度百分比,范围 0-100 */\n percent?: number;\n /** 进度条类型,目前支持 circle(圆形)和 semicircle(半圆) */\n type?: ProgressType;\n /** 进度条宽度(尺寸),单位 px */\n width?: number;\n /** 标题文本 */\n title?: string;\n /** 标题位置,圆内(inside)或圆外(outside),圆外时显示在圆下方 */\n titlePosition?: TitlePosition;\n /** 是否显示百分比 */\n showPercent?: boolean;\n /** 是否启用动画效果 */\n animated?: boolean;\n /** 进度条状态 */\n status?: ProgressStatus;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 进度条颜色,不设置则使用主题色 */\n strokeColor?: string;\n /** 进度条轨道颜色 */\n trailColor?: string;\n [key: string]: any;\n}\n\n// 获取标题位置:默认圆内\nconst getTitlePosition = (userPosition?: TitlePosition): TitlePosition => {\n return userPosition || 'inside';\n};\n\n// 计算标题字体大小:统一使用 text-sm (14px)\nconst getTitleFontSize = () => {\n return '14px'; // text-sm\n};\n\n// 计算百分比字体大小:统一使用 text-xs (12px)\nconst getPercentFontSize = () => {\n return '12px'; // text-xs\n};\n\nconst Progress: React.FC<ProgressProps> = ({\n percent = 0,\n type = 'circle',\n width = 120,\n title,\n titlePosition: userTitlePosition,\n showPercent = true,\n animated = false,\n status = 'normal',\n className = '',\n style,\n strokeColor,\n trailColor = '#F5F5F4',\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n \n // 确保 percent 在 0-100 范围内\n const normalizedPercent = Math.min(100, Math.max(0, percent));\n \n // 跟踪是否是首次渲染,动画只在首次渲染时执行一次\n const isFirstRender = useRef(true);\n const [shouldAnimate, setShouldAnimate] = useState(false);\n const [animatingPercent, setAnimatingPercent] = useState(0); // 动画中的百分比\n \n useEffect(() => {\n if (animated && isFirstRender.current && normalizedPercent > 0) {\n // 首次渲染且启用了动画且 percent > 0 时,启用动画\n isFirstRender.current = false;\n // 初始设置为 0,然后启用动画,让它过渡到目标值\n setAnimatingPercent(0);\n setShouldAnimate(true);\n // 使用 requestAnimationFrame 确保在下一个渲染周期更新到目标值\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n setAnimatingPercent(normalizedPercent);\n });\n });\n // 动画结束后(0.3s)禁用动画,确保只执行一次\n const timer = setTimeout(() => {\n setShouldAnimate(false);\n setAnimatingPercent(normalizedPercent); // 确保最终值是目标值\n }, 300);\n return () => clearTimeout(timer);\n } else if (isFirstRender.current) {\n // 首次渲染但不需要动画,直接标记为已渲染\n isFirstRender.current = false;\n setShouldAnimate(false);\n setAnimatingPercent(normalizedPercent);\n } else {\n // 非首次渲染,直接更新到目标值,无动画\n setAnimatingPercent(normalizedPercent);\n }\n }, [animated, normalizedPercent]);\n \n // 计算实际使用的颜色\n let finalStrokeColor = strokeColor || primaryColor || '#FB6011';\n \n // 根据状态调整颜色\n if (status === 'success') {\n finalStrokeColor = '#00BC7D';\n } else if (status === 'exception') {\n finalStrokeColor = '#FB2C36';\n }\n \n // 计算标题位置:默认圆内\n const titlePosition = getTitlePosition(userTitlePosition);\n \n // 计算圆环宽度(strokeWidth),根据 width 成比例,最小 4px\n const strokeWidth = Math.max(4, Math.round(width * 0.06));\n \n // 半径(用于 SVG 绘制)\n const radius = (width - strokeWidth) / 2;\n \n // 半圆的高度是宽度的一半\n const semicircleHeight = type === 'semicircle' ? width / 2 : width;\n \n // 标题字体大小:统一使用 14px (text-sm)\n const titleFontSize = getTitleFontSize();\n // 百分比字体大小:统一使用 12px (text-xs)\n const percentFontSize = getPercentFontSize();\n \n // 渲染圆形进度\n const renderCircleProgress = () => {\n // 计算容器高度\n const containerHeight = title && titlePosition === 'outside' \n ? width + 4 + 18 + 4\n : width;\n \n // 圆形进度计算\n const circumference = 2 * Math.PI * radius;\n // 如果正在动画,使用动画中的百分比,否则使用目标百分比\n const currentPercent = shouldAnimate ? animatingPercent : normalizedPercent;\n const offset = circumference - (currentPercent / 100) * circumference;\n \n return (\n <div\n style={{\n position: 'relative',\n width: width,\n height: containerHeight,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n }}\n >\n {/* SVG 绘制圆形进度,支持圆角 */}\n <svg\n width={width}\n height={width}\n style={{\n position: 'absolute',\n top: 0,\n left: 0,\n }}\n >\n {/* 背景轨道 */}\n <circle\n cx={width / 2}\n cy={width / 2}\n r={radius}\n fill=\"none\"\n stroke={trailColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n />\n {/* 进度条:从上方开始,顺时针 */}\n <circle\n cx={width / 2}\n cy={width / 2}\n r={radius}\n fill=\"none\"\n stroke={finalStrokeColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n strokeDasharray={circumference}\n strokeDashoffset={offset}\n transform={`rotate(-90 ${width / 2} ${width / 2})`}\n style={{\n transition: shouldAnimate ? 'stroke-dashoffset 0.3s ease' : 'none',\n }}\n />\n </svg>\n \n {/* 内容:百分比和标题 */}\n {title && titlePosition === 'inside' ? (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: '50%',\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: 6,\n }}\n >\n <div\n style={{\n fontSize: titleFontSize,\n color: '#292524',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {title}\n </div>\n {showPercent && (\n <div\n style={{\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n </div>\n ) : (\n <>\n {showPercent && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${width / 2}px`, // 相对于圆的位置,不是容器\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n {title && titlePosition === 'outside' && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${width}px`,\n transform: 'translateX(-50%)',\n marginTop: '4px',\n textAlign: 'center',\n fontSize: titleFontSize,\n color: '#57534E',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '18px',\n }}\n >\n {title}\n </div>\n )}\n </>\n )}\n </div>\n );\n };\n \n // 渲染半圆进度\n const renderSemicircleProgress = () => {\n // 半圆弧形的起始点和结束点\n // 为了确保上方不被裁剪,把半圆弧形往下移\n // 在 SVG 顶部留出圆角空间,让弧形从顶部向下偏移\n \n const topPadding = strokeWidth; // 顶部留出圆角空间\n const svgHeight = semicircleHeight + topPadding; // SVG 总高度(包含顶部空间)\n \n const startX = strokeWidth / 2;\n const endX = width - strokeWidth / 2;\n // 底部位置:往下移,底部在 svgHeight - strokeWidth / 2\n const bottomY = svgHeight - strokeWidth / 2;\n \n // 半圆的中心点(用于文字定位)- 文字也相应往下移\n // 为了让文字更居中,需要适当往下移一些\n const textCenterY = (semicircleHeight / 2) + topPadding / 2 + strokeWidth / 2; // 在弧形中心位置,适当往下移\n \n // 计算容器高度:半圆的标准高度(width / 2),加上顶部空间\n // 如果 title 在圆外,再加 title 空间\n const baseContainerHeight = svgHeight; // 容器高度包含完整的 SVG(包括顶部空间)\n const containerHeight = title && titlePosition === 'outside' \n ? baseContainerHeight + 4 + 18 + 4\n : baseContainerHeight;\n \n // 半圆进度计算\n const semicircleCircumference = Math.PI * radius;\n // 如果正在动画,使用动画中的百分比,否则使用目标百分比\n const currentPercent = shouldAnimate ? animatingPercent : normalizedPercent;\n const semicircleOffset = semicircleCircumference - (currentPercent / 100) * semicircleCircumference;\n \n return (\n <div\n style={{\n position: 'relative',\n width: width,\n height: containerHeight,\n overflow: 'hidden', // 最外层设置 overflow: hidden,只裁剪底部\n }}\n >\n {/* SVG 绘制半圆进度,支持圆角(包括底部两个端点) */}\n <svg\n width={width}\n height={svgHeight}\n viewBox={`0 0 ${width} ${svgHeight}`}\n style={{\n position: 'absolute',\n top: 0,\n left: 0,\n }}\n >\n {/* 背景轨道(半圆) */}\n <path\n d={`M ${startX} ${bottomY} A ${radius} ${radius} 0 0 1 ${endX} ${bottomY}`}\n fill=\"none\"\n stroke={trailColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n />\n {/* 进度条(半圆):从底部左侧开始,顺时针 */}\n <path\n d={`M ${startX} ${bottomY} A ${radius} ${radius} 0 0 1 ${endX} ${bottomY}`}\n fill=\"none\"\n stroke={finalStrokeColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n strokeDasharray={semicircleCircumference}\n strokeDashoffset={semicircleOffset}\n style={{\n transition: shouldAnimate ? 'stroke-dashoffset 0.3s ease' : 'none',\n }}\n />\n </svg>\n \n {/* 内容:百分比和标题 */}\n {title && titlePosition === 'inside' ? (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${textCenterY}px`,\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: 6,\n }}\n >\n <div\n style={{\n fontSize: titleFontSize,\n color: '#57534E',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {title}\n </div>\n {showPercent && (\n <div\n style={{\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n </div>\n ) : (\n <>\n {showPercent && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${textCenterY}px`, // 相对于半圆的位置,不是容器\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n {title && titlePosition === 'outside' && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${svgHeight}px`, // 相对于 SVG 底部的位置\n transform: 'translateX(-50%)',\n marginTop: '4px',\n textAlign: 'center',\n fontSize: titleFontSize,\n color: '#57534E',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '18px',\n }}\n >\n {title}\n </div>\n )}\n </>\n )}\n </div>\n );\n };\n \n const containerStyle: React.CSSProperties = {\n display: 'inline-flex',\n flexDirection: 'column',\n alignItems: 'center',\n width: width,\n ...style,\n };\n \n // 根据类型渲染不同的进度条\n const renderProgress = () => {\n switch (type) {\n case 'circle':\n return renderCircleProgress();\n case 'semicircle':\n return renderSemicircleProgress();\n default:\n console.warn(`Progress type \"${type}\" is not supported yet, using \"circle\" as fallback`);\n return renderCircleProgress();\n }\n };\n \n return (\n <div\n className={`aha-progress aha-progress--${type} ${className}`}\n style={containerStyle}\n {...rest}\n >\n {renderProgress()}\n </div>\n );\n};\n\nexport default Progress;\n"],"names":["extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__assign","assign","t","s","i","n","arguments","length","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","rejected","result","done","then","__generator","body","f","y","_","label","sent","trys","ops","g","create","Iterator","verb","Symbol","iterator","v","op","TypeError","pop","push","__spreadArray","to","from","pack","ar","l","slice","concat","SuppressedError","defaultTheme","primaryColor","ThemeContext","createContext","useTheme","context","useContext","SIZE_ALIAS","sm","md","lg","xl","small","mediumSmall","medium","large","HIERARCHY_ALIAS","primary","secondary","tertiary","default","SIZE_TOKENS","height","paddingX","paddingXLg","fontSize","lineHeight","iconSize","gap","iconOnlyPad","LoadingSpinner","_a","size","color","_jsxs","jsxs","_Fragment","Fragment","children","_jsx","jsx","width","viewBox","fill","style","animation","flexShrink","cx","cy","r","stroke","strokeWidth","opacity","strokeLinecap","Button","_b","type","_c","_d","disabled","_e","loading","iconOnly","_f","focused","onClick","_g","htmlType","_h","className","icon","_j","iconPosition","rest","_k","useState","isHovered","setIsHovered","_l","isPressed","setIsPressed","hierarchy","isIconOnly","isLink","isDisabled","showFocusRing","themeBrand","visuals","bg","iconColor","border","boxShadow","interactive","textDecoration","getVisuals","focusShadow","buttonStyle","position","display","alignItems","justifyContent","fontFamily","fontWeight","cursor","outline","transition","userSelect","WebkitTapHighlightColor","whiteSpace","backgroundColor","borderRadius","overflow","padding","paddingLeft","paddingRight","renderIcon","showLeftIcon","showRightIcon","filter","Boolean","join","preventDefault","onMouseEnter","onMouseLeave","onMouseDown","onMouseUp","displayName","AlertIcon","success","xmlns","error","warning","info","CloseIcon","ToastIcon","question","ToastManager","toasts","listeners","Set","addToast","props","id","Math","random","toString","toastInstance","console","log","notifyListeners","removeToast","toast","getToasts","subscribe","listener","_this","add","delete","forEach","clearAll","toastManager","ToastContainer","setToasts","useEffect","currentToasts","unsubscribe","map","topLeftToasts","topRightToasts","bottomLeftToasts","bottomRightToasts","top","left","zIndex","pointerEvents","flexDirection","ToastItem","right","bottom","isVisible","setIsVisible","isExiting","setIsExiting","message","duration","action","showClose","onClose","typeStyles","bgColor","defaultIcon","getTypeStyles","timer","setTimeout","clearTimeout","timer_1","handleClose","useCallback","handleClick","maxWidth","background","transform","marginRight","flex","minWidth","marginTop","stopPropagation","currentTarget","ensureToastContainer","toastContainerElement","toastContainerRoot","isInitializing","window","document","existingContainer","getElementById","createElement","appendChild","createRoot","require","render","import","catch","warn","COLOR_CONFIG","Green","light","text","Red","Orange","Cyan","Violet","Pink","Gray","Yellow","Blue","SIZE_CONFIG","textSize","Input","forwardRef","ref","readOnly","prefix","suffix","allowClear","onClear","placeholder","defaultValue","onChange","onFocus","onBlur","onPressEnter","restProps","inputRef","useRef","React","internalValue","setInternalValue","setFocused","current","isControlled","undefined","currentValue","handleClear","target","focus","showClear","sizeStyles","paddingTop","paddingBottom","baseStyles","boxSizing","WebkitAppearance","MozAppearance","appearance","onKeyDown","key","autoComplete","autoCorrect","autoCapitalize","spellCheck","strokeLinejoin","Select","controlledValue","options","mode","showSearch","filterOption","onSelect","onDeselect","onSearch","onDropdownVisibleChange","_m","dropdownClassName","dropdownStyle","_o","defaultOpen","controlledOpen","open","maxTagCount","tagRender","optionRender","_p","_q","_r","internalOpen","setInternalOpen","_s","searchValue","setSearchValue","_t","focusedIndex","setFocusedIndex","selectRef","dropdownRef","_u","dropdownPosition","setDropdownPosition","isOpenControlled","isOpen","isMultiple","getSelectedOptions","values","isArray","opt","includes","getFilteredOptions","String","toLowerCase","search","filteredOptions","useMemo","updatePosition_1","rect","getBoundingClientRect","estimatedDropdownHeight","offsetHeight","min","max","spaceBelow","innerHeight","spaceAbove","shouldOpenUp","top_1","scrollY","scrollX","placement","requestAnimationFrame","addEventListener","removeEventListener","handleClickOutside","event","contains","handleKeyDown","prev","option","handleSelect","focusedItem","querySelectorAll","scrollIntoView","block","behavior","newValues_1","currentValues","selectedOptions_1","handleRemoveTag","newValues","find","newValue","selectedOptions","hasValue","renderTags","tagsToShow","remainingCount","flexWrap","tagProps","closable","textOverflow","marginLeft","WebkitTouchCallout","touchAction","newOpen","onTouchStart","onTouchEnd","tabIndex","minHeight","val","createPortal","maxHeight","transformOrigin","WebkitOverflowScrolling","overscrollBehavior","textAlign","index","isSelected","isFocused","selected","CheckIcon","MinusIcon","SortIcon","SortDescIcon","SortAscIcon","LeftArrowIcon","RightArrowIcon","TooltipIcon","clipPath","Pagination","controlledCurrent","defaultCurrent","total","controlledPageSize","pageSize","defaultPageSize","showSizeChanger","pageSizeOptions","showQuickJumper","showTotal","onShowSizeChange","simple","hideOnSinglePage","responsive","showLessItems","itemRender","internalCurrent","setInternalCurrent","internalPageSize","setInternalPageSize","jumpToPage","setJumpToPage","totalPages","ceil","handlePageChange","page","handleJumpTo","parseInt","margin","start","end","pages","getPageNumbers","item","isActive","element","renderItem","Number","newPageSize","newTotalPages","newCurrent","goButton","Checkbox","checked","indeterminate","isChecked","borderColor","el","TableLoadingSpinner","strokeDasharray","strokeDashoffset","TableLoadingOverlay","spinColor","content","role","inset","getValue","obj","path","reduce","acc","getRowKey","record","rowKey","SortIconComponent","order","Radio","name","DOMAIN_REGEX","URL_CANDIDATE_REGEX","DEFAULT_ALLOWED_TLDS","websiteValidator","url","needProtocol","needHost","allowedTlds","trimmed","trim","hasProtocol","test","normalized","parsed","URL","protocol","host","hostname","split","every","segment","num","isInteger","tld","has","trimTrailingPunctuation","match","core","escapeHtml","replace","stripEditorArtifacts","RegExp","renderTokensAsHtml","tokens","lastIndex","regex","exec","matchedText","href","defaultIsValid","validate","tokenizeText","html","token","classAttr","endsWith","getCaretOffset","container","selection","getSelection","rangeCount","range","getRangeAt","startContainer","preRange","cloneRange","selectNodeContents","setEnd","startOffset","Textarea","showCount","maxLength","rows","autoSize","linkify","linkifyOptions","textareaRef","editableRef","isComposingRef","caretOffsetRef","setHeight","currentLength","handleFocus","handleBlur","getMaxLengthValue","textarea","minRows","maxRows","scrollHeight","getComputedStyle","newHeight","editable","overflowY","useLayoutEffect","activeElement","fallbackOffset","caretOffset","nextHtml","innerHTML","maxOffset","offset","createRange","remaining","walker","createTreeWalker","NodeFilter","SHOW_TEXT","currentNode","nextNode","rawText","textContent","visibleCount","targetOffsetInNode","setStart","collapse","removeAllRanges","addRange","setCaretOffset","notifyChange","nextValue","handleEditableInput","rawValue","resize","contentEditable","suppressContentEditableWarning","onInput","onPaste","pastedText","clipboardData","getData","currentText","nextText","anchorNode","endOffset","endContainer","nativeEvent","isComposing","offsets","startRange","endRange","getSelectionOffsets","nextCaret","onCompositionStart","onCompositionEnd","Switch","controlledChecked","defaultChecked","checkedChildren","unCheckedChildren","internalChecked","setInternalChecked","config","thumbSize","thumbOffset","thumbLeft","newChecked","monthNamesShort","monthNamesFull","formatDate","date","format","year","getFullYear","month","getMonth","monthNum","padStart","day","getDate","dayNum","getDaysInMonth","Date","isSameDay","date1","date2","isDateInRange","minDate","maxDate","DatePicker","startPlaceholder","endPlaceholder","onOpenChange","separator","presetRanges","calendarCount","showApplyCancel","applyText","cancelText","onApply","onCancel","showSelectedRange","_v","startSelectedRangeText","_w","endSelectedRangeText","_x","rangeDisplayMode","_y","isRangeMode","_z","internalSingleValue","setInternalSingleValue","_0","startDate","endDate","internalRangeValue","setInternalRangeValue","_1","_2","selectingStart","setSelectingStart","_3","tempRangeValue","setTempRangeValue","_4","now","currentMonth","setCurrentMonth","_5","nextMonth","secondMonth","setSecondMonth","pickerRef","startInputRef","endInputRef","_6","hasOpenedRef","placementDeterminedRef","determinedPlacementRef","currentSingleValue","currentRangeValue","dateYear","dateMonth","rect_1","placement_1","dropdownHeight","top_2","placement_2","calculatePosition_1","workingRange","startText","endText","renderCalendar","handleSelectSingleDate","handleSelectRangeDate","newRange","handleToggle","defaultPresetRanges","today","setHours","lastWeekEnd","lastWeekStart","setDate","lastMonthEnd","lastMonthStart","originalDate","setMonth","lastYearEnd","lastYearStart","setFullYear","presetRangesList","hasPresetRanges","handlePresetRangeSelect","startYear","startMonth","handlePrevMonth","handleNextMonth","generateCalendarData","daysInMonth","days","calendarData","secondCalendarData","handleSecondPrevMonth","handleSecondNextMonth","singleDisplayValue","startDisplayValue","endDisplayValue","rangeTextValue","weekDays","borderRight","borderTopLeftRadius","borderBottomLeftRadius","preset","idx","monthData","calendarDays","onPrevMonth","onNextMonth","monthIndex","marginBottom","gridTemplateColumns","rowGap","columnGap","firstDay","getDay","cells","actualIndex","isCurrentMonth","isToday","isStartDate","isEndDate","isInRange_1","dateTime","getTime","startTime","endTime","isDateInSelectedRange","isFirstInRow","isLastInRow","isRangeStart_1","isRangeEnd_1","isFirstDayOfMonth","isLastDayOfMonth","needsLeftRadius","needsRightRadius","borderTopRightRadius","borderBottomRightRadius","isSelected_1","borderTop","FormContext","FormValidationError","_super","errorFields","__","constructor","__extends","Error","Form","initialValues","onValuesChange","onFinish","onFinishFailed","labelWidth","labelAlign","layout","initialFields","keys","touched","validating","fields","setFieldsState","fieldsRef","fieldElementsRef","getFieldValue","setFieldValue","newFields","changedValues","allValues_1","getFieldError","setFieldError","isFieldTouched","setFieldTouched","isFieldValidating","setFieldValidating","registerFieldFnRef","existingRules","rules","newRules","rulesEqual","existingRule","newRule","required","pattern","len","whitespace","registerField","unregisterField","validateField","field","_i","rules_1","rule","validator","string","number","isNaN","boolean","email","err_1","getFieldsValue","nameList","currentFields","validateFields","fieldsToValidate","errors","all","errorInfo","resetFields","setFieldsValue","allValues_2","submit","setFields","fieldsToSet","some","changedValues_1","registerFieldRef","scrollToField","useImperativeHandle","contextValue","formStyle","Provider","onSubmit","FormWithItem","Item","htmlFor","wrapperCol","hasFeedback","validateStatus","help","extra","hidden","tooltip","formContext","itemRef","setItemRef","fieldError","fieldTouched","fieldValidating","computedValidateStatus","computedHelp","prevRulesRef","prevRequiredRef","isMountedRef","isRequired","rulesChanged","prevRule","currRule","showTooltip","setShowTooltip","tooltipRef","borderLeft","borderBottom","Children","child","isValidElement","childProps","fieldValue_1","setFieldValue_1","childType","originalOnChange_1","originalOnBlur_1","originalOnChange_2","originalOnBlur_2","originalOnChange_3","originalOnChange_4","radioValue_1","originalOnChange_5","originalOnChange_6","cloneElement","cloneChild","useForm","MenuList","items","userProfile","controlledSelectedKeys","selectedKeys","defaultSelectedKeys","menuRef","itemRefs","isSelectedKeysControlled","internalSelectedKeys","setInternalSelectedKeys","isGroup","getKeyPath","items_1","found","menuItem","currentPath","handleItemClick","newSelectedKeys","keyPath","k","skipGlobalClick","renderMenuItem","itemStyle","danger","suffixIcon","containerStyle","shouldShowDivider","currentItem","prevItem","avatar","charAt","toUpperCase","online","group","title","calculatePosition","triggerRect","tooltipRect","pageXOffset","pageYOffset","triggerCenterX","triggerCenterY","totalGap","viewportWidth","innerWidth","viewportHeight","willOverlap","calculatedTop","calculatedLeft","tooltipBottom","tooltipRight","tooltipTop","tooltipLeft","overlapTop","overlapBottom","overlapLeft","overlapRight","renderArrow","arrowStyle","baseArrowStyle","borderStyle","arrowStyles","borderWidth","hasEnoughSpace","popoverRect","getAvailableSpace","Popover","trigger","popoverClassName","destroyOnHide","destroyTooltipOnHide","shouldDestroyOnHide","internalVisible","setInternalVisible","visible","popoverStyle","setPopoverStyle","triggerRef","popoverRef","setVisible","nextVisible","updatePosition","nextPlacement","oppositePlacement","getOppositePlacement","getPlacementPosition","clamped","nextTop","nextLeft","clampToViewport","openPopover","closePopover","togglePopover","triggerEvents","popoverNode","visibility","VIEWPORT_PADDING","ANIMATION_DURATION","Drawer","afterOpenChange","footer","mask","maskClosable","closeIcon","keyboard","destroyOnClose","mobileBreakpoint","drawerStyle","headerStyle","bodyStyle","footerStyle","maskStyle","mergedOpen","shouldRender","setShouldRender","animatedOpen","setAnimatedOpen","mounted","setMounted","isMobile","setIsMobile","updateMobile","raf_1","cancelAnimationFrame","previousOverflow","closeDrawer","resolvedWidth","resolvedHeight","effectivePlacement","drawerPositionStyle","base","node","curve","tag","rotate","particleCount","trailSpan","durationMs","rotationDurationMs","pulseDurationMs","baseRadius","detailAmplitude","petalCount","curveScale","point","progress","detailScaleValue","PI","petals","round","x","cos","sin","getParticle","tailOffset","normalizeProgress","fade","pow","radius","description","showIcon","closeable","hasRightSlot","strokeWidthProp","frame","setFrame","startRef","tick","pulseAngle","elapsed","rotationDeg","elapsedMs","getRotationDeg","lineWeight","strokeScale","pathD","steps","parts","toFixed","buildPath","particles","pt","preserveAspectRatio","percent","userTitlePosition","titlePosition","showPercent","animated","status","strokeColor","trailColor","normalizedPercent","isFirstRender","shouldAnimate","setShouldAnimate","animatingPercent","setAnimatingPercent","finalStrokeColor","semicircleHeight","titleFontSize","percentFontSize","renderCircleProgress","containerHeight","circumference","startX","endX","bottomY","svgHeight","textCenterY","semicircleCircumference","semicircleOffset","renderProgress","variant","scrollable","normalizedItems","firstItem","firstKey","findMatchingKey","exactMatch","itemNum","valueNum","initialValue","handleTabClick","returnValue","activeTabElement_1","tabRefs","getKeyString","container_1","containerRef","isScrollingRef","scrollTimeout_1","underlineRef","containerRect","tabRect","scrollLeft","setUnderlineStyle","handleScroll_1","passive","inline","activeItem","currentNum","activeColor","backgroundSliderRef","backgroundContainerRef","prevCurrentValueRef","underlineStyle","backgroundSliderStyle","setBackgroundSliderStyle","updateUnderlinePosition","activeTab","firstKey_1","newLeft","newWidth","updateBackgroundSliderPosition","firstKey_2","scrollTimeout_2","updatePosition_2","handleScroll_2","overflowX","scrollBehavior","scrollbarWidth","itemKey","itemKeyType","currentValueType","iconType","isReactElement","iconValue","badge","customElement","renderBackgroundStyle","columns","dataSource","rowSelection","pagination","bordered","locale","showHeader","summary","scroll","tableLayout","onSorterChange","onPaginationChange","onRow","innerClassName","expandable","rowClassName","onHeaderRow","sticky","loadingSpinColor","selectedRowKeys","defaultSelectedRowKeys","setSelectedRowKeys","Map","sorters","setSorters","defaultExpandedRowKeys","expandedRowKeys","setExpandedRowKeys","currentPage","setCurrentPage","setPageSize","draggedRowIndex","setDraggedRowIndex","dragOverRowIndex","setDragOverRowIndex","tableRef","headerRef","checkMobile","checkboxProps","getCheckboxProps","newSelectedRowKeys","selectedRows","Event","handleSelectAll","currentPageData","changeRows","onSelectAll","handleSort","column","columnKey","dataIndex","newSorters","set","sorterArray","entries","c","currentSorter","currentDataSource","expanded","newExpandedRowKeys","onExpand","onExpandedRowsChange","emptyContent","getProcessedData","processed","sort","a","_loop_1","col","compareResult","sorter","aVal","bVal","sorterEntries_1","state_1","processedData","isServerPagination","paginatedData","renderCell","getFixedOffset","columnIndex","fixed","isHeader","fixedDirection","columnWidth","renderHeader","enabledRows","enabledKeys","allSelected","someSelected","headerColumns","colIndex","sortOrder","get","fixedOffset","align","onHeaderCell","sortColumn","selectWidth","selectColumn","hideSelectAll","columnTitle","unshift","headerRowProps","handleDragStart","handleDragOver","handleDrop","dropIndex","newData","draggedItem","splice","handleDragEnd","renderEmpty","emptyText","colSpan","renderRows","isExpanded","rowProps","isLastRow","draggable","onDragStart","onDragOver","onDrop","onDragEnd","cellProps","onCell","rowSpan","expandedRowRender","renderPagination","hasFixedColumns","hasAllColumnWidths","totalWidth","sum","effectiveTableLayout","tableStyle","borderCollapse","borderSpacing","wrapperStyle","startsWith","displayValue","scrollContainerStyle","colorConfig","hex","substr","getColorConfig","sizeConfig","baseStyle","outlineOffset","outlineColor","getOutlineColor","baseClasses","containerClasses","getIconColor","theme","themeValue","delay","tooltipClassName","showArrow","defaultVisible","onVisibleChange","isAnimating","setIsAnimating","newVisible","actualPosition","setActualPosition","tooltipMaxWidth","setTooltipMaxWidth","tooltipStyle","setTooltipStyle","setArrowStyle","timeoutRef","hideTimeoutRef","finalPosition","preferredPosition","candidates_1","pos","getPositionCandidates","candidate","getAutoPosition","arrowPos","tooltipAbsoluteLeft","tooltipAbsoluteTop","getArrowPosition","hideTooltip","keepTooltipVisible","tryUpdatePosition_1","tooltipContainerStyle","calculateTooltipMaxWidth","updateMaxWidth","tooltipContentStyle","wordWrap","tooltipContent","handleTriggerMouseLeave","triggerProps"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/index.tsx","../src/components/Alert/icon.tsx","../src/components/Toast/icon.tsx","../src/components/Toast/index.tsx","../src/components/Tag/index.tsx","../src/components/Input/InputGroup.tsx","../src/components/Input/InputTags.tsx","../src/components/Input/index.tsx","../src/components/Select/index.tsx","../src/icons/index.tsx","../src/components/Pagination/index.tsx","../src/components/Checkbox/index.tsx","../src/components/Table/index.tsx","../src/components/Radio/index.tsx","../src/components/Tab/index.tsx","../src/components/Textarea/index.tsx","../src/components/Switch/index.tsx","../src/components/DatePicker/index.tsx","../src/components/Form/FormContext.tsx","../src/components/Form/index.tsx","../src/components/Form/FormItem.tsx","../src/components/MenuList/index.tsx","../src/components/Tooltip/index.tsx","../src/components/Popover/index.tsx","../src/components/Drawer/index.tsx","../src/components/Loading/index.tsx","../src/components/Badge/index.tsx","../src/components/Avatar/index.tsx","../src/components/Alert/index.tsx","../src/components/Progress/index.tsx","../src/components/Textarea/TextareaTags.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import React, { createContext, useContext, useMemo } from 'react';\n\nexport interface ThemeConfig {\n primaryColor?: string;\n}\n\nconst defaultTheme: ThemeConfig = {\n primaryColor: '#FB6011',\n};\n\nconst ThemeContext = createContext<ThemeConfig>(defaultTheme);\n\nexport interface ThemeProviderProps {\n theme?: ThemeConfig;\n children: React.ReactNode;\n}\n\nexport const ThemeProvider: React.FC<ThemeProviderProps> = ({ theme, children }) => {\n const themeValue = useMemo(() => {\n return {\n ...defaultTheme,\n ...theme,\n };\n }, [theme]);\n\n return (\n <ThemeContext.Provider value={themeValue}>\n {children}\n </ThemeContext.Provider>\n );\n};\n\nexport const useTheme = (): ThemeConfig => {\n const context = useContext(ThemeContext);\n if (!context) {\n // 如果没有 Provider,返回默认主题\n return defaultTheme;\n }\n return context;\n};\n\n// 导出默认主题色,供组件内部使用\nexport const getDefaultPrimaryColor = () => defaultTheme.primaryColor!;\n\n","import React, { useState } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\n/**\n * 对齐 Figma: Untitled UI v7 — Buttons\n * 维度:Size × Hierarchy × State × Icon only\n * Size: sm(36) / md(40) / lg(44) / xl(48)\n * Hierarchy: primary / secondary / tertiary / link-color / link-gray\n * State: default / hover / focused / disabled / loading\n * Icon only: boolean\n */\n\nexport type ButtonHierarchy =\n | 'primary'\n | 'secondary'\n | 'tertiary'\n | 'link-color'\n | 'link-gray'\n | 'destructive-primary'\n | 'destructive-secondary'\n | 'destructive-tertiary'\n | 'destructive-link'\n // legacy alias\n | 'default';\n\nexport type ButtonSize =\n | 'sm'\n | 'md'\n | 'lg'\n | 'xl'\n // legacy aliases\n | 'small'\n | 'mediumSmall'\n | 'medium'\n | 'large';\n\nexport type ButtonType = ButtonHierarchy;\n\nexport interface ButtonProps {\n children?: React.ReactNode;\n /** 按钮层级(对应 Figma Hierarchy)。`default` 为 `secondary` 的旧名 */\n type?: ButtonHierarchy;\n /** 按钮尺寸(对应 Figma Size)。旧名会映射到新尺寸 */\n size?: ButtonSize;\n disabled?: boolean;\n loading?: boolean;\n /** 仅图标按钮。不传 `children`、仅传 `icon` 时自动开启 */\n iconOnly?: boolean;\n /** 受控的 Focused 视觉态,用于 Storybook 预览设计稿;真实键盘焦点由 :focus-visible 处理 */\n focused?: boolean;\n onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void;\n htmlType?: 'button' | 'submit' | 'reset';\n className?: string;\n style?: React.CSSProperties;\n icon?: React.ReactNode;\n iconPosition?: 'left' | 'right';\n [key: string]: any;\n}\n\ntype NormalizedSize = 'sm' | 'md' | 'lg' | 'xl';\ntype NormalizedHierarchy = 'primary' | 'secondary' | 'tertiary' | 'link-color' | 'link-gray' | 'destructive-primary' | 'destructive-secondary' | 'destructive-tertiary' | 'destructive-link';\n\nconst SIZE_ALIAS: Record<ButtonSize, NormalizedSize> = {\n sm: 'sm',\n md: 'md',\n lg: 'lg',\n xl: 'xl',\n small: 'sm',\n mediumSmall: 'sm',\n medium: 'md',\n large: 'xl',\n};\n\nconst HIERARCHY_ALIAS: Record<ButtonHierarchy, NormalizedHierarchy> = {\n primary: 'primary',\n secondary: 'secondary',\n tertiary: 'tertiary',\n 'link-color': 'link-color',\n 'link-gray': 'link-gray',\n 'destructive-primary': 'destructive-primary',\n 'destructive-secondary': 'destructive-secondary',\n 'destructive-tertiary': 'destructive-tertiary',\n 'destructive-link': 'destructive-link',\n default: 'secondary',\n};\n\n/** Figma 标注的尺寸参数:高度、内边距、字号/行高、图标尺寸、间距 */\nconst SIZE_TOKENS: Record<\n NormalizedSize,\n {\n height: number;\n paddingX: number;\n paddingXLg: number; // lg/xl 大号内边距(与图标拼接时稍大)\n fontSize: number;\n lineHeight: number;\n iconSize: number;\n gap: number;\n iconOnlyPad: number;\n }\n> = {\n sm: { height: 36, paddingX: 12, paddingXLg: 12, fontSize: 14, lineHeight: 20, iconSize: 20, gap: 4, iconOnlyPad: 8 },\n md: { height: 40, paddingX: 14, paddingXLg: 14, fontSize: 14, lineHeight: 20, iconSize: 20, gap: 4, iconOnlyPad: 10 },\n lg: { height: 44, paddingX: 16, paddingXLg: 16, fontSize: 16, lineHeight: 24, iconSize: 20, gap: 6, iconOnlyPad: 12 },\n xl: { height: 48, paddingX: 18, paddingXLg: 18, fontSize: 16, lineHeight: 24, iconSize: 20, gap: 6, iconOnlyPad: 14 },\n};\n\nconst LoadingSpinner: React.FC<{ size: number; color: string }> = ({ size, color }) => (\n <>\n <style>{`@keyframes aha-button-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}`}</style>\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n aria-hidden\n style={{ animation: 'aha-button-spin 1s linear infinite', flexShrink: 0 }}\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\" stroke={color} strokeWidth=\"2\" opacity=\"0.25\" />\n <path\n d=\"M22 12a10 10 0 0 1-10 10\"\n stroke={color}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n fill=\"none\"\n />\n </svg>\n </>\n);\n\nconst Button: React.FC<ButtonProps> = ({\n children,\n type = 'secondary',\n size = 'md',\n disabled = false,\n loading = false,\n iconOnly,\n focused = false,\n onClick,\n htmlType = 'button',\n className = '',\n style,\n icon,\n iconPosition = 'left',\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n const [isHovered, setIsHovered] = useState(false);\n const [isPressed, setIsPressed] = useState(false);\n\n const hierarchy = HIERARCHY_ALIAS[type] || 'secondary';\n const s = SIZE_TOKENS[SIZE_ALIAS[size] || 'md'];\n\n const isIconOnly = iconOnly ?? (!!icon && children == null);\n const isLink = hierarchy === 'link-color' || hierarchy === 'link-gray' || hierarchy === 'destructive-link';\n const isDisabled = disabled || loading;\n const showFocusRing = focused;\n\n const themeBrand = primaryColor; // 允许 ThemeProvider 覆盖主色\n\n /** 根据 hierarchy+state 计算视觉 token */\n const getVisuals = (): {\n bg: string;\n color: string;\n iconColor: string;\n border: string;\n boxShadow: string;\n textDecoration?: string;\n } => {\n // Disabled — 所有层级共享一套「灰态」,但 link/tertiary 无边框/阴影\n if (disabled) {\n if (hierarchy === 'primary' || hierarchy === 'secondary' || hierarchy === 'destructive-primary' || hierarchy === 'destructive-secondary') {\n return {\n bg: 'var(--color-bg-disabled, #f5f5f4)',\n color: 'var(--color-fg-disabled, #a9a29d)',\n iconColor: 'var(--color-fg-disabled, #a9a29d)',\n border: '1px solid var(--color-border-disabled_subtle, #e7e5e4)',\n boxShadow: 'none',\n };\n }\n return {\n bg: 'transparent',\n color: 'var(--color-fg-disabled, #a9a29d)',\n iconColor: 'var(--color-fg-disabled, #a9a29d)',\n border: 'none',\n boxShadow: 'none',\n };\n }\n\n const interactive = isHovered || isPressed;\n\n if (hierarchy === 'primary') {\n const bg = interactive\n ? 'var(--color-bg-brand-solid_hover, #ec470a)'\n : themeBrand || 'var(--color-bg-brand-solid, #fb6011)';\n return {\n bg,\n color: 'var(--color-text-white, #ffffff)',\n iconColor: 'var(--color-brand-300, #feb073)',\n border: 'none',\n boxShadow: 'var(--shadow-xs-skeuomorphic, 0 1px 2px 0 rgba(10,13,18,.05))',\n };\n }\n\n if (hierarchy === 'secondary') {\n return {\n bg: interactive\n ? 'var(--color-bg-primary_hover, #fafaf9)'\n : 'var(--color-bg-primary, #ffffff)',\n color: interactive\n ? 'var(--color-text-secondary_hover, #292524)'\n : 'var(--color-text-secondary, #44403c)',\n iconColor: interactive\n ? 'var(--color-fg-quaternary_hover, #79716b)'\n : 'var(--color-fg-quaternary, #a9a29d)',\n border: 'none',\n boxShadow: 'var(--shadow-xs-skeuomorphic)',\n };\n }\n\n if (hierarchy === 'tertiary') {\n return {\n bg: interactive ? 'var(--color-bg-primary_hover, #fafaf9)' : 'transparent',\n color: interactive\n ? 'var(--color-text-tertiary_hover, #44403c)'\n : 'var(--color-text-tertiary, #57534e)',\n iconColor: interactive\n ? 'var(--color-fg-quaternary_hover, #79716b)'\n : 'var(--color-fg-quaternary, #a9a29d)',\n border: 'none',\n boxShadow: 'none',\n };\n }\n\n if (hierarchy === 'link-color') {\n return {\n bg: 'transparent',\n color: interactive\n ? 'var(--color-text-brand-secondary_hover, #c4330a)'\n : 'var(--color-text-brand-secondary, #ec470a)',\n iconColor: 'var(--color-fg-brand-secondary_alt, #fb6011)',\n border: 'none',\n boxShadow: 'none',\n textDecoration: interactive ? 'underline' : 'none',\n };\n }\n\n if (hierarchy === 'link-gray') {\n return {\n bg: 'transparent',\n color: interactive\n ? 'var(--color-text-tertiary_hover, #44403c)'\n : 'var(--color-text-tertiary, #57534e)',\n iconColor: 'var(--color-fg-quaternary, #a9a29d)',\n border: 'none',\n boxShadow: 'none',\n textDecoration: interactive ? 'underline' : 'none',\n };\n }\n\n if (hierarchy === 'destructive-primary') {\n return {\n bg: interactive\n ? 'var(--color-error-600)'\n : 'var(--color-error-500)',\n color: 'var(--color-text-white)',\n iconColor: interactive\n ? 'var(--color-error-200)'\n : 'var(--color-error-300)',\n border: 'none',\n boxShadow: 'var(--shadow-xs-skeuomorphic)',\n };\n }\n\n if (hierarchy === 'destructive-secondary') {\n return {\n bg: interactive\n ? 'var(--color-bg-error-primary)'\n : 'var(--color-bg-primary)',\n color: 'var(--color-text-error-primary)',\n iconColor: 'var(--color-fg-error-secondary)',\n border: 'none',\n // 用 error border 色替换 skeuomorphic 中的暗色 inset,保持与 secondary 一致的 shadow 结构\n boxShadow: 'inset 0 0 0 1px var(--color-border-error_subtle), inset 0 -2px 0 0 rgba(10,13,18,0.05), 0 1px 2px 0 rgba(10,13,18,0.05)',\n };\n }\n\n if (hierarchy === 'destructive-tertiary') {\n return {\n bg: interactive ? 'var(--color-bg-error-primary)' : 'transparent',\n color: 'var(--color-text-error-primary)',\n iconColor: 'var(--color-fg-error-secondary)',\n border: 'none',\n boxShadow: 'none',\n };\n }\n\n // destructive-link\n return {\n bg: 'transparent',\n color: interactive\n ? 'var(--color-text-error-primary_hover)'\n : 'var(--color-text-error-primary)',\n iconColor: 'var(--color-fg-error-secondary)',\n border: 'none',\n boxShadow: 'none',\n textDecoration: interactive ? 'underline' : 'none',\n };\n };\n\n const visuals = getVisuals();\n\n /** focus ring: primary/secondary 使用 skeuomorphic 版本叠加基础阴影;其余使用纯环 */\n const focusShadow = (() => {\n if (!showFocusRing) return undefined;\n const isDestructive = hierarchy === 'destructive-primary' || hierarchy === 'destructive-secondary' || hierarchy === 'destructive-tertiary' || hierarchy === 'destructive-link';\n if (isDestructive) {\n if (hierarchy === 'destructive-primary' || hierarchy === 'destructive-secondary') {\n return 'var(--focus-ring-error-shadow-xs-skeuomorphic)';\n }\n return 'var(--focus-ring-error)';\n }\n if (hierarchy === 'primary' || hierarchy === 'secondary') {\n return 'var(--focus-ring-shadow-xs-skeuomorphic, 0 0 0 2px #fff, 0 0 0 4px #fb6011)';\n }\n return 'var(--focus-ring, 0 0 0 2px #fff, 0 0 0 4px #fb6011)';\n })();\n\n const buttonStyle: React.CSSProperties = {\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: s.gap,\n fontFamily: 'var(--font-family-body, \"DM Sans\", system-ui, sans-serif)',\n fontWeight: 600,\n fontSize: s.fontSize,\n lineHeight: `${s.lineHeight}px`,\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n outline: 'none',\n transition: 'background-color .15s ease, color .15s ease, box-shadow .15s ease',\n userSelect: 'none',\n WebkitTapHighlightColor: 'transparent',\n whiteSpace: 'nowrap',\n backgroundColor: visuals.bg,\n color: visuals.color,\n border: visuals.border,\n boxShadow: focusShadow ?? visuals.boxShadow,\n textDecoration: visuals.textDecoration,\n ...style,\n };\n\n if (isLink) {\n // Link 类:保留与同尺寸按钮一致的高度和横向内边距,无背景、无边框\n buttonStyle.borderRadius = '4px';\n buttonStyle.overflow = 'hidden';\n if (isIconOnly) {\n buttonStyle.width = s.height;\n buttonStyle.height = s.height;\n buttonStyle.padding = 0;\n } else {\n buttonStyle.height = s.height;\n buttonStyle.paddingLeft = s.paddingX;\n buttonStyle.paddingRight = s.paddingX;\n }\n } else {\n buttonStyle.borderRadius = 'var(--radius-md, 8px)';\n if (isIconOnly) {\n buttonStyle.width = s.height;\n buttonStyle.height = s.height;\n buttonStyle.padding = 0;\n } else {\n buttonStyle.height = s.height;\n buttonStyle.paddingLeft = s.paddingX;\n buttonStyle.paddingRight = s.paddingX;\n }\n }\n\n const handleClick = (e: React.MouseEvent<HTMLButtonElement>) => {\n if (isDisabled) {\n e.preventDefault();\n return;\n }\n onClick?.(e);\n };\n\n const renderIcon = () => {\n if (loading) {\n return <LoadingSpinner size={s.iconSize} color={visuals.iconColor} />;\n }\n if (!icon) return null;\n return (\n <span\n aria-hidden\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: s.iconSize,\n height: s.iconSize,\n color: visuals.iconColor,\n flexShrink: 0,\n }}\n >\n {icon}\n </span>\n );\n };\n\n const showLeftIcon = loading || (icon && iconPosition === 'left');\n const showRightIcon = !loading && icon && iconPosition === 'right';\n\n return (\n <button\n type={htmlType}\n className={[\n 'aha-button',\n `aha-button--${hierarchy}`,\n `aha-button--${SIZE_ALIAS[size] || 'md'}`,\n isIconOnly && 'aha-button--icon-only',\n isDisabled && 'aha-button--disabled',\n loading && 'aha-button--loading',\n showFocusRing && 'aha-button--focused',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n disabled={isDisabled}\n onClick={handleClick}\n onMouseEnter={() => !isDisabled && setIsHovered(true)}\n onMouseLeave={() => {\n setIsHovered(false);\n setIsPressed(false);\n }}\n onMouseDown={() => !isDisabled && setIsPressed(true)}\n onMouseUp={() => setIsPressed(false)}\n style={buttonStyle}\n {...rest}\n >\n {showLeftIcon && renderIcon()}\n {!isIconOnly && children}\n {showRightIcon && renderIcon()}\n {/* icon-only 且没传 icon 时,允许 children 作为图标 */}\n {isIconOnly && !icon && !loading && children}\n </button>\n );\n};\n\nButton.displayName = 'Button';\n\nexport default Button;\n","export const AlertIcon = {\n success: (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M10 1.66663C5.40002 1.66663 1.66669 5.39996 1.66669 9.99996C1.66669 14.6 5.40002 18.3333 10 18.3333C14.6 18.3333 18.3334 14.6 18.3334 9.99996C18.3334 5.39996 14.6 1.66663 10 1.66663ZM13.3584 8.49997L9.46668 12.3833C9.35001 12.5083 9.19168 12.5666 9.02501 12.5666C8.86668 12.5666 8.70834 12.5083 8.58334 12.3833L6.64169 10.4417C6.40002 10.2 6.40002 9.79994 6.64169 9.55827C6.88336 9.3166 7.28335 9.3166 7.52502 9.55827L9.02501 11.0583L12.475 7.61664C12.7167 7.36664 13.1167 7.36664 13.3584 7.61664C13.6 7.8583 13.6 8.24997 13.3584 8.49997Z\"\n fill=\"#00BC7D\"\n />\n </svg>\n ),\n error: (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M17.1342 6.3009L13.6999 2.86666C13.4658 2.63249 13.1474 2.50085 12.8157 2.50085H7.18504C6.85337 2.50085 6.53584 2.63249 6.30084 2.86666L2.8666 6.3009C2.63243 6.53507 2.50079 6.85343 2.50079 7.1851V12.8158C2.50079 13.1475 2.63243 13.465 2.8666 13.7L6.30084 17.1342C6.53501 17.3684 6.85337 17.5 7.18504 17.5H12.8157C13.1474 17.5 13.4649 17.3684 13.6999 17.1342L17.1342 13.7C17.3683 13.4658 17.5 13.1475 17.5 12.8158V7.1851C17.5 6.85343 17.3683 6.53507 17.1342 6.3009ZM12.525 11.6417C12.7692 11.8858 12.7692 12.2817 12.525 12.5259C12.4033 12.6475 12.2433 12.7092 12.0833 12.7092C11.9233 12.7092 11.7633 12.6484 11.6416 12.5259L9.99998 10.8842L8.35834 12.5259C8.23667 12.6475 8.07665 12.7092 7.91665 12.7092C7.75665 12.7092 7.59662 12.6484 7.47496 12.5259C7.23079 12.2817 7.23079 11.8858 7.47496 11.6417L9.1166 10L7.47496 8.3584C7.23079 8.11423 7.23079 7.71837 7.47496 7.4742C7.71912 7.23004 8.11498 7.23004 8.35915 7.4742L10.0008 9.11585L11.6424 7.4742C11.8866 7.23004 12.2825 7.23004 12.5266 7.4742C12.7708 7.71837 12.7708 8.11423 12.5266 8.3584L10.885 10L12.525 11.6417Z\"\n fill=\"#FB2C36\"\n />\n </svg>\n ),\n warning: (\n <svg \n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M18.0057 14.2935L12.4999 3.99662C11.4333 2.00162 8.56744 2.00162 7.49995 3.99662L1.99417 14.2935C1.01583 16.1235 2.3442 18.3334 4.42337 18.3334H15.5765C17.6549 18.3334 18.9841 16.1226 18.0057 14.2935ZM9.37495 8.33337C9.37495 7.98837 9.65494 7.70837 9.99994 7.70837C10.3449 7.70837 10.6249 7.98837 10.6249 8.33337V11.6667C10.6249 12.0117 10.3449 12.2917 9.99994 12.2917C9.65494 12.2917 9.37495 12.0117 9.37495 11.6667V8.33337ZM10.0166 15C9.55663 15 9.17902 14.6267 9.17902 14.1667C9.17902 13.7067 9.54829 13.3334 10.0083 13.3334H10.0166C10.4775 13.3334 10.85 13.7067 10.85 14.1667C10.85 14.6267 10.4766 15 10.0166 15Z\"\n fill=\"#FE9A00\"\n />\n </svg>\n ),\n info: (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M14.6875 2.5H5.3125C3.4375 2.5 2.5 3.4375 2.5 5.3125V14.6875C2.5 16.5625 3.4375 17.5 5.3125 17.5H14.6875C16.5625 17.5 17.5 16.5625 17.5 14.6875V5.3125C17.5 3.4375 16.5625 2.5 14.6875 2.5ZM10.625 13.75C10.625 14.095 10.345 14.375 10 14.375C9.655 14.375 9.375 14.095 9.375 13.75V9.9408C9.375 9.5958 9.655 9.3158 10 9.3158C10.345 9.3158 10.625 9.5958 10.625 9.9408V13.75ZM10.0167 7.91667C9.55668 7.91667 9.17908 7.54333 9.17908 7.08333C9.17908 6.62333 9.54834 6.25 10.0083 6.25H10.0167C10.4775 6.25 10.85 6.62333 10.85 7.08333C10.85 7.54333 10.4767 7.91667 10.0167 7.91667Z\"\n fill=\"#2B7FFF\"\n />\n </svg>\n ),\n};\n\nexport const CloseIcon = (\n <svg\n className=\"flex-shrink-0\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M15.4416 14.5583C15.6858 14.8025 15.6858 15.1984 15.4416 15.4425C15.32 15.5642 15.16 15.6258 15 15.6258C14.84 15.6258 14.68 15.565 14.5583 15.4425L9.99997 10.8842L5.44164 15.4425C5.31997 15.5642 5.15997 15.6258 4.99997 15.6258C4.83997 15.6258 4.67997 15.565 4.55831 15.4425C4.31414 15.1984 4.31414 14.8025 4.55831 14.5583L9.11664 10L4.55831 5.44171C4.31414 5.19754 4.31414 4.80168 4.55831 4.55751C4.80247 4.31335 5.19831 4.31335 5.44248 4.55751L10.0008 9.11587L14.5591 4.55751C14.8033 4.31335 15.1991 4.31335 15.4433 4.55751C15.6875 4.80168 15.6875 5.19754 15.4433 5.44171L10.885 10L15.4416 14.5583Z\"\n fill=\"#57534D\"\n />\n </svg>\n);\n","export const ToastIcon = {\n success: (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM16.03 10.2L11.36 14.86C11.22 15.01 11.03 15.08 10.83 15.08C10.64 15.08 10.45 15.01 10.3 14.86L7.97 12.53C7.68 12.24 7.68 11.76 7.97 11.47C8.26 11.18 8.74 11.18 9.03 11.47L10.83 13.27L14.97 9.14001C15.26 8.84001 15.74 8.84001 16.03 9.14001C16.32 9.43001 16.32 9.90001 16.03 10.2Z\"\n fill=\"#ECFDF5\"\n />\n </svg>\n ),\n error: (\n <svg\n width=\"25\"\n height=\"24\"\n viewBox=\"0 0 25 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M21.3506 7.56104L17.2295 3.43994C16.9485 3.15894 16.5665 3.00098 16.1685 3.00098H9.41162C9.01362 3.00098 8.63259 3.15894 8.35059 3.43994L4.22949 7.56104C3.94849 7.84204 3.79053 8.22407 3.79053 8.62207V15.3789C3.79053 15.7769 3.94849 16.1579 4.22949 16.4399L8.35059 20.561C8.63159 20.842 9.01362 21 9.41162 21H16.1685C16.5665 21 16.9475 20.842 17.2295 20.561L21.3506 16.4399C21.6316 16.1589 21.7896 15.7769 21.7896 15.3789V8.62207C21.7896 8.22407 21.6316 7.84204 21.3506 7.56104ZM15.8196 13.97C16.1126 14.263 16.1126 14.738 15.8196 15.031C15.6736 15.177 15.4816 15.251 15.2896 15.251C15.0976 15.251 14.9055 15.178 14.7595 15.031L12.7896 13.061L10.8196 15.031C10.6736 15.177 10.4816 15.251 10.2896 15.251C10.0976 15.251 9.90552 15.178 9.75952 15.031C9.46652 14.738 9.46652 14.263 9.75952 13.97L11.7295 12L9.75952 10.03C9.46652 9.73703 9.46652 9.26199 9.75952 8.96899C10.0525 8.67599 10.5276 8.67599 10.8206 8.96899L12.7905 10.939L14.7605 8.96899C15.0535 8.67599 15.5285 8.67599 15.8215 8.96899C16.1145 9.26199 16.1145 9.73703 15.8215 10.03L13.8516 12L15.8196 13.97Z\"\n fill=\"#FEF2F2\"\n />\n </svg>\n ),\n question: (\n <svg\n width=\"25\"\n height=\"24\"\n viewBox=\"0 0 25 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M18.2041 3H6.9541C4.7041 3 3.5791 4.125 3.5791 6.375V17.625C3.5791 19.875 4.7041 21 6.9541 21H18.2041C20.4541 21 21.5791 19.875 21.5791 17.625V6.375C21.5791 4.125 20.4541 3 18.2041 3ZM12.5991 17.5C12.0471 17.5 11.594 17.052 11.594 16.5C11.594 15.948 12.0371 15.5 12.5891 15.5H12.5991C13.1521 15.5 13.5991 15.948 13.5991 16.5C13.5991 17.052 13.1511 17.5 12.5991 17.5ZM14.1821 12.5281C13.4511 13.0181 13.315 13.291 13.29 13.363C13.185 13.676 12.8931 13.874 12.5791 13.874C12.5001 13.874 12.4201 13.862 12.3411 13.835C11.9481 13.703 11.7372 13.278 11.8682 12.885C12.0492 12.345 12.5182 11.836 13.3462 11.281C14.3672 10.597 14.2361 9.84707 14.1931 9.60107C14.0801 8.94707 13.5291 8.38988 12.8821 8.27588C12.3891 8.18588 11.9092 8.31488 11.5332 8.62988C11.1552 8.94688 10.938 9.41391 10.938 9.90991C10.938 10.3239 10.602 10.6599 10.188 10.6599C9.77399 10.6599 9.43799 10.3239 9.43799 9.90991C9.43799 8.96891 9.85009 8.08396 10.5691 7.48096C11.2811 6.88496 12.2181 6.63605 13.1431 6.80005C14.4101 7.02405 15.4492 8.07097 15.6702 9.34497C15.8902 10.607 15.3611 11.7381 14.1821 12.5281Z\"\n fill=\"#FAFAF9\"\n />\n </svg>\n ),\n info: (\n <svg\n width=\"25\"\n height=\"24\"\n viewBox=\"0 0 25 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M18.2041 3H6.9541C4.7041 3 3.5791 4.125 3.5791 6.375V17.625C3.5791 19.875 4.7041 21 6.9541 21H18.2041C20.4541 21 21.5791 19.875 21.5791 17.625V6.375C21.5791 4.125 20.4541 3 18.2041 3ZM12.5991 17.5C12.0471 17.5 11.594 17.052 11.594 16.5C11.594 15.948 12.0371 15.5 12.5891 15.5H12.5991C13.1521 15.5 13.5991 15.948 13.5991 16.5C13.5991 17.052 13.1511 17.5 12.5991 17.5ZM14.1821 12.5281C13.4511 13.0181 13.315 13.291 13.29 13.363C13.185 13.676 12.8931 13.874 12.5791 13.874C12.5001 13.874 12.4201 13.862 12.3411 13.835C11.9481 13.703 11.7372 13.278 11.8682 12.885C12.0492 12.345 12.5182 11.836 13.3462 11.281C14.3672 10.597 14.2361 9.84707 14.1931 9.60107C14.0801 8.94707 13.5291 8.38988 12.8821 8.27588C12.3891 8.18588 11.9092 8.31488 11.5332 8.62988C11.1552 8.94688 10.938 9.41391 10.938 9.90991C10.938 10.3239 10.602 10.6599 10.188 10.6599C9.77399 10.6599 9.43799 10.3239 9.43799 9.90991C9.43799 8.96891 9.85009 8.08396 10.5691 7.48096C11.2811 6.88496 12.2181 6.63605 13.1431 6.80005C14.4101 7.02405 15.4492 8.07097 15.6702 9.34497C15.8902 10.607 15.3611 11.7381 14.1821 12.5281Z\"\n fill=\"#FAFAF9\"\n />\n </svg>\n ),\n};\n\nexport const CloseIcon = ({ className }: any) => {\n return (\n <svg\n className={`flex-shrink-0 ${className}`}\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M15.4416 14.5583C15.6858 14.8025 15.6858 15.1984 15.4416 15.4425C15.32 15.5642 15.16 15.6258 15 15.6258C14.84 15.6258 14.68 15.565 14.5583 15.4425L9.99997 10.8842L5.44164 15.4425C5.31997 15.5642 5.15997 15.6258 4.99997 15.6258C4.83997 15.6258 4.67997 15.565 4.55831 15.4425C4.31414 15.1984 4.31414 14.8025 4.55831 14.5583L9.11664 10L4.55831 5.44171C4.31414 5.19754 4.31414 4.80168 4.55831 4.55751C4.80247 4.31335 5.19831 4.31335 5.44248 4.55751L10.0008 9.11587L14.5591 4.55751C14.8033 4.31335 15.1991 4.31335 15.4433 4.55751C15.6875 4.80168 15.6875 5.19754 15.4433 5.44171L10.885 10L15.4416 14.5583Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n};\n","import React, { useState, useEffect, useCallback } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport { CloseIcon, ToastIcon } from \"./icon\";\n\nexport type ToastType = \"success\" | \"error\" | \"info\" | \"question\";\nexport type ToastPosition = \"top-left\" | \"top-right\" | \"bottom-left\" | \"bottom-right\";\n\nexport interface ToastProps {\n /** Toast 消息内容 */\n message: string;\n /** Toast 类型 */\n type?: ToastType;\n /** 显示位置 */\n position?: ToastPosition;\n /** 显示时长(毫秒),0 表示不自动关闭 */\n duration?: number;\n /** 自定义图标 */\n icon?: React.ReactNode;\n /** 自定义操作按钮 */\n action?: React.ReactNode;\n /** 是否显示关闭按钮 */\n showClose?: boolean;\n /** 关闭回调 */\n onClose?: () => void;\n /** 点击回调 */\n onClick?: () => void;\n /** 自定义样式类名 */\n className?: string;\n}\n\nexport interface ToastInstance {\n id: string;\n props: ToastProps;\n}\n\n// Toast 管理器\nclass ToastManager {\n private toasts: ToastInstance[] = [];\n private listeners: Set<() => void> = new Set();\n\n addToast(props: ToastProps): string {\n const id = Math.random().toString(36).slice(-8);\n const toastInstance = { id, props };\n this.toasts.push(toastInstance);\n console.log('Toast: 添加 Toast 到管理器,ID:', id, '当前总数:', this.toasts.length);\n this.notifyListeners();\n return id;\n }\n\n removeToast(id: string): void {\n this.toasts = this.toasts.filter((toast) => toast.id !== id);\n this.notifyListeners();\n }\n\n getToasts(): ToastInstance[] {\n return [...this.toasts]; // 返回副本,避免外部修改\n }\n\n subscribe(listener: () => void): () => void {\n this.listeners.add(listener);\n return () => this.listeners.delete(listener);\n }\n\n private notifyListeners(): void {\n console.log('Toast: 通知监听器,监听器数量:', this.listeners.size);\n this.listeners.forEach((listener) => listener());\n }\n\n // 清理所有 Toast(用于调试)\n clearAll(): void {\n this.toasts = [];\n this.notifyListeners();\n }\n}\n\n// 全局 Toast 管理器实例\nconst toastManager = new ToastManager();\n\n// Toast 容器组件\nconst ToastContainer: React.FC = () => {\n const [toasts, setToasts] = useState<ToastInstance[]>([]);\n\n useEffect(() => {\n console.log('Toast: ToastContainer 组件已挂载');\n \n // 立即获取当前的 Toast 列表\n const currentToasts = toastManager.getToasts();\n console.log('Toast: 初始 Toast 数量:', currentToasts.length);\n setToasts(currentToasts);\n \n const unsubscribe = toastManager.subscribe(() => {\n const currentToasts = toastManager.getToasts();\n console.log('Toast: 收到 Toast 更新,当前数量:', currentToasts.length, 'Toast IDs:', currentToasts.map(t => t.id));\n setToasts(currentToasts);\n });\n return unsubscribe;\n }, []);\n\n // 按位置分组 Toast\n const topLeftToasts = toasts.filter(\n (toast) => toast.props.position === \"top-left\"\n );\n const topRightToasts = toasts.filter(\n (toast) => toast.props.position === \"top-right\"\n );\n const bottomLeftToasts = toasts.filter(\n (toast) => toast.props.position === \"bottom-left\"\n );\n const bottomRightToasts = toasts.filter(\n (toast) => toast.props.position === \"bottom-right\"\n );\n\n return (\n <>\n {/* 左上角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n top: '16px', \n left: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {topLeftToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n\n {/* 右上角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n top: '16px', \n right: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {topRightToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n\n {/* 左下角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n bottom: '16px', \n left: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {bottomLeftToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n\n {/* 右下角 Toast 容器 */}\n <div style={{ \n position: 'fixed', \n bottom: '16px', \n right: '16px', \n zIndex: 9999, \n pointerEvents: 'none',\n display: 'flex', \n flexDirection: 'column', \n gap: '8px' \n }}>\n {bottomRightToasts.map((toast) => (\n <ToastItem key={toast.id} {...toast} />\n ))}\n </div>\n </>\n );\n};\n\n// 单个 Toast 组件\nconst ToastItem: React.FC<ToastInstance> = ({ id, props }) => {\n const [isVisible, setIsVisible] = useState(false);\n const [isExiting, setIsExiting] = useState(false);\n\n const {\n message,\n type = \"info\",\n duration = 3000,\n icon,\n action,\n showClose = true,\n onClose,\n onClick,\n className = \"\",\n } = props;\n\n // 获取类型对应的样式和默认图标\n const getTypeStyles = (type: ToastType) => {\n switch (type) {\n case \"success\":\n return {\n bgColor: \"#009966\",\n defaultIcon: ToastIcon.success,\n };\n case \"error\":\n return {\n bgColor: \"#E7000B\",\n defaultIcon: ToastIcon.error,\n };\n case \"question\":\n return {\n bgColor: \"#1C1917\",\n defaultIcon: ToastIcon.question,\n };\n case \"info\":\n default:\n return {\n bgColor: \"#1447E6\",\n defaultIcon: ToastIcon.info,\n };\n }\n };\n\n const typeStyles = getTypeStyles(type);\n\n // 显示动画\n useEffect(() => {\n const timer = setTimeout(() => {\n setIsVisible(true);\n }, 10);\n return () => clearTimeout(timer);\n }, []);\n\n // 自动关闭\n useEffect(() => {\n if (duration > 0) {\n const timer = setTimeout(() => {\n handleClose();\n }, duration);\n return () => clearTimeout(timer);\n }\n }, [duration, id]); // 添加 id 依赖,确保每个 Toast 独立处理\n\n const handleClose = useCallback(() => {\n setIsExiting(true);\n setTimeout(() => {\n toastManager.removeToast(id);\n onClose?.();\n }, 300); // 动画持续时间\n }, [id, onClose]);\n\n const handleClick = useCallback(() => {\n onClick?.();\n }, [onClick]);\n\n return (\n <div\n style={{\n pointerEvents: 'auto',\n maxWidth: '380px',\n background: 'white',\n borderRadius: '8px',\n boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',\n overflow: 'hidden',\n transform: isVisible && !isExiting ? 'translateY(0) scale(1)' : 'translateY(8px) scale(0.95)',\n opacity: isVisible && !isExiting ? 1 : 0,\n transition: 'all 300ms ease-out',\n position: 'relative',\n cursor: onClick ? 'pointer' : 'default',\n }}\n onClick={handleClick}\n >\n <div style={{\n display: 'flex',\n alignItems: 'flex-start',\n padding: '16px',\n backgroundColor: typeStyles.bgColor,\n color: 'white',\n }}>\n {/* 图标 */}\n <div style={{\n flexShrink: 0,\n width: '24px',\n height: '24px',\n borderRadius: '50%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n marginRight: '8px',\n }}>\n {icon || typeStyles.defaultIcon}\n </div>\n\n {/* 内容区域 */}\n <div style={{\n flex: 1,\n minWidth: 0,\n paddingRight: '20px',\n }}>\n <div style={{\n width: '100%',\n justifyContent: 'flex-start',\n color: '#f0fdf4',\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '24px',\n }}>\n {message}\n </div>\n\n {/* 自定义操作 */}\n {action && <div style={{ marginTop: '12px' }}>{action}</div>}\n </div>\n\n {/* 关闭按钮 */}\n {showClose && (\n <button\n onClick={(e) => {\n e.stopPropagation();\n handleClose();\n }}\n style={{\n flexShrink: 0,\n width: '20px',\n height: '20px',\n borderRadius: '50%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n transition: 'all 200ms',\n position: 'absolute',\n top: '14px',\n right: '16px',\n background: 'transparent',\n border: 'none',\n cursor: 'pointer',\n color: 'white',\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.background = 'rgba(255, 255, 255, 0.1)';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.background = 'transparent';\n }}\n >\n <CloseIcon />\n </button>\n )}\n </div>\n </div>\n );\n};\n\n// Toast 组件\nconst Toast: React.FC<ToastProps> = (props) => {\n // 这个组件主要用于直接渲染单个 Toast\n // 通常使用 toast() 函数来显示 Toast\n return <ToastItem id=\"direct\" props={props} />;\n};\n\n// Toast 显示函数\nexport const toast = (props: ToastProps): string => {\n console.log('Toast: 调用 toast 函数', props);\n \n // 确保 Toast 容器已挂载\n ensureToastContainer();\n \n // 使用 setTimeout 确保容器完全初始化\n setTimeout(() => {\n const id = toastManager.addToast(props);\n console.log('Toast: 添加 Toast 成功,ID:', id);\n }, 100);\n \n // 临时返回一个 ID\n return Math.random().toString(36).slice(-8);\n};\n\n// Toast 关闭函数\nexport const closeToast = (id: string): void => {\n toastManager.removeToast(id);\n};\n\n// 清理所有 Toast\nexport const clearAllToasts = (): void => {\n toastManager.clearAll();\n};\n\n// 调试函数\nexport const debugToast = () => {\n console.log('=== Toast 调试信息 ===');\n console.log('当前环境:', typeof window !== 'undefined' ? '浏览器' : '服务端');\n console.log('document 可用:', typeof document !== 'undefined');\n console.log('容器元素:', document.getElementById('aha-toast-container'));\n console.log('Toast 管理器状态:', toastManager.getToasts());\n console.log('容器根节点:', toastContainerRoot);\n console.log('是否正在初始化:', isInitializing);\n console.log('====================');\n};\n\n// 便捷方法\nexport const toastSuccess = (\n message: string,\n options?: Partial<ToastProps>\n) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"success\" });\n};\n\nexport const toastError = (message: string, options?: Partial<ToastProps>) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"error\" });\n};\n\nexport const toastInfo = (message: string, options?: Partial<ToastProps>) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"info\" });\n};\n\nexport const toastQuestion = (\n message: string,\n options?: Partial<ToastProps>\n) => {\n ensureToastContainer();\n return toast({ ...options, message, type: \"question\" });\n};\n\n// 自动挂载的 Toast 容器\nlet toastContainerElement: HTMLElement | null = null;\nlet toastContainerRoot: any = null;\nlet isInitializing = false;\n\nconst ensureToastContainer = () => {\n console.log('Toast: 开始确保容器存在');\n \n // 检查是否在浏览器环境\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n console.warn('Toast: 当前环境不支持 Toast 组件');\n return;\n }\n\n // 如果已经在初始化中,直接返回\n if (isInitializing) {\n console.log('Toast: 容器正在初始化中,跳过');\n return;\n }\n\n if (!toastContainerElement) {\n console.log('Toast: 创建新的 Toast 容器');\n isInitializing = true;\n \n try {\n // 检查是否已存在容器\n const existingContainer = document.getElementById('aha-toast-container');\n if (existingContainer) {\n console.log('Toast: 发现已存在的容器');\n toastContainerElement = existingContainer;\n isInitializing = false;\n return;\n }\n\n // 创建容器元素\n console.log('Toast: 创建容器元素');\n toastContainerElement = document.createElement('div');\n toastContainerElement.id = 'aha-toast-container';\n document.body.appendChild(toastContainerElement);\n console.log('Toast: 容器已添加到 document.body');\n\n // 尝试直接导入 ReactDOM\n console.log('Toast: 开始导入 ReactDOM');\n try {\n // 先尝试同步导入\n const { createRoot } = require('react-dom/client');\n console.log('Toast: ReactDOM 同步导入成功,创建根节点');\n toastContainerRoot = createRoot(toastContainerElement!);\n console.log('Toast: 渲染 ToastContainer 组件');\n toastContainerRoot.render(<ToastContainer />);\n console.log('Toast: 容器渲染完成');\n isInitializing = false;\n } catch (error) {\n console.log('Toast: 同步导入失败,尝试动态导入', error);\n // 如果同步导入失败,尝试动态导入\n import('react-dom/client').then(({ createRoot }) => {\n try {\n console.log('Toast: ReactDOM 动态导入成功,创建根节点');\n toastContainerRoot = createRoot(toastContainerElement!);\n console.log('Toast: 渲染 ToastContainer 组件');\n toastContainerRoot.render(<ToastContainer />);\n console.log('Toast: 容器渲染完成');\n } catch (error) {\n console.error('Toast: 渲染容器失败', error);\n }\n isInitializing = false;\n }).catch((error) => {\n console.error('Toast: 导入 ReactDOM 失败', error);\n isInitializing = false;\n });\n }\n } catch (error) {\n console.error('Toast: 创建容器失败', error);\n isInitializing = false;\n }\n } else {\n console.log('Toast: 容器已存在,跳过创建');\n }\n};\n\n// Toast 提供者组件(保持向后兼容)\nexport const ToastProvider: React.FC<{ children: React.ReactNode }> = ({\n children,\n}) => {\n const [mounted, setMounted] = useState(false);\n\n useEffect(() => {\n setMounted(true);\n }, []);\n\n return (\n <>\n {children}\n {mounted && createPortal(<ToastContainer />, document.body)}\n </>\n );\n};\n\nexport default Toast;\n","import React, { SVGProps, useState } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport type TagColor =\n | 'Green' | 'Red' | 'Orange' | 'Cyan' | 'Violet'\n | 'Pink' | 'Gray' | 'Yellow' | 'Blue' | string;\n\nexport type TagVariant = 'light' | 'fill';\n\n/** sm/md/lg are the canonical sizes; large/small are legacy aliases */\nexport type TagSize = 'sm' | 'md' | 'lg' | 'large' | 'small';\n\n/** Leading icon variant */\nexport type TagIconType = 'none' | 'dot' | 'avatar' | 'icon';\n\n/** Right-side action */\nexport type TagAction = 'none' | 'x-close' | 'count';\n\n/** @deprecated Use iconType instead */\nexport type IconPosition = 'leading' | 'after' | 'none';\n\nexport interface TagProps {\n children: React.ReactNode;\n color?: TagColor;\n variant?: TagVariant;\n size?: TagSize;\n stroke?: boolean;\n // Icon variants (mutually exclusive; avatar takes precedence over icon)\n iconType?: TagIconType;\n icon?: React.ReactElement;\n avatarSrc?: string;\n dotColor?: string;\n // Action variants\n action?: TagAction;\n count?: number;\n onClose?: () => void;\n // Checkbox variant\n checkbox?: boolean;\n checked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n /** @deprecated use iconType='icon' */\n iconPosition?: IconPosition;\n className?: string;\n onClick?: () => void;\n [key: string]: any;\n}\n\n// ─── Color Configs ────────────────────────────────────────────────────────────\n\nconst COLOR_CONFIG = {\n Green: { light: { bg: '#ECFDF5', text: '#006045', border: '#A4F4CF' }, fill: { bg: '#00BC7D', text: '#FFFFFF' } },\n Red: { light: { bg: '#FEF2F2', text: '#9F0712', border: '#FFC9C9' }, fill: { bg: '#FB2C36', text: '#FFFFFF' } },\n Orange: { light: { bg: '#FFF6ED', text: '#9B2911', border: '#FFD1A9' }, fill: { bg: '#FB6011', text: '#FFFFFF' } },\n Cyan: { light: { bg: '#ECFEFF', text: '#005F78', border: '#A2F4FD' }, fill: { bg: '#00B8DB', text: '#FFFFFF' } },\n Violet: { light: { bg: '#F5F3FF', text: '#5D0EC0', border: '#DDD6FF' }, fill: { bg: '#8E51FF', text: '#FFFFFF' } },\n Pink: { light: { bg: '#FDF2F8', text: '#A3004C', border: '#FCCEE8' }, fill: { bg: '#F6339A', text: '#FFFFFF' } },\n Gray: { light: { bg: '#F5F5F4', text: '#292524', border: '#E7E5E4' }, fill: { bg: '#292524', text: '#FFFFFF' } },\n Yellow: { light: { bg: '#FFFBEB', text: '#973C00', border: '#FEE685' }, fill: { bg: '#FE9A00', text: '#FFFFFF' } },\n Blue: { light: { bg: '#EFF6FF', text: '#193CB8', border: '#BEDBFF' }, fill: { bg: '#2B7FFF', text: '#FFFFFF' } },\n};\n\nconst getColorConfig = (color: TagColor, primaryColor?: string) => {\n if (color in COLOR_CONFIG) {\n const config = COLOR_CONFIG[color as keyof typeof COLOR_CONFIG];\n if (color === 'Orange' && primaryColor) {\n return { ...config, fill: { ...config.fill, bg: primaryColor } };\n }\n return config;\n }\n if (color.startsWith('#')) {\n const r = parseInt(color.slice(1, 3), 16);\n const g = parseInt(color.slice(3, 5), 16);\n const b = parseInt(color.slice(5, 7), 16);\n return {\n light: { bg: `rgba(${r},${g},${b},0.1)`, text: color, border: `rgba(${r},${g},${b},0.3)` },\n fill: { bg: color, text: '#FFFFFF' },\n };\n }\n return COLOR_CONFIG.Gray;\n};\n\nconst getIconColor = (color: TagColor, primaryColor?: string): string => {\n const map: Record<string, string> = {\n Green: '#009966', Red: '#E7000B', Orange: primaryColor || '#E17100',\n Blue: '#155DFC', Yellow: '#EC470A', Cyan: '#0092B8',\n Violet: '#7F22FE', Pink: '#E60076', Gray: '#57534D',\n };\n return map[color] ?? (color.startsWith('#') ? color : '#57534D');\n};\n\nconst getOutlineColor = (color: TagColor): string => {\n const map: Record<string, string> = {\n Green: '#A4F4CF', Red: '#FFC9C9', Orange: '#FFD1A9',\n Blue: '#BEDBFF', Yellow: '#FFD1A9', Cyan: '#A2F4FD',\n Violet: '#DDD6FF', Pink: '#FCCEE8', Gray: '#E7E5E4',\n };\n if (color in map) return map[color];\n if (color.startsWith('#')) {\n const r = parseInt(color.slice(1, 3), 16);\n const g = parseInt(color.slice(3, 5), 16);\n const b = parseInt(color.slice(5, 7), 16);\n return `rgba(${r},${g},${b},0.3)`;\n }\n return '#E7E5E4';\n};\n\n// ─── Size Config ──────────────────────────────────────────────────────────────\n// Values derived from Figma design (node 3307:417515)\n\ntype NSize = 'sm' | 'md' | 'lg';\n\nconst normalizeSize = (size: TagSize): NSize => {\n if (size === 'large') return 'lg';\n if (size === 'small') return 'sm';\n return size as NSize;\n};\n\nconst SIZE = {\n sm: {\n // Base padding: px-8px py-3px (h=24px with lh-18px)\n basePx: 8, basePy: 3,\n // Left padding adjustments per leading element (checkbox wins over icon)\n plCheckbox: 5, plAvatar: 4, plDot: 6, plIcon: 4,\n // Right padding adjustments per action\n prClose: 4, prCount: 4,\n fontSize: 12, lineHeight: '18px', height: 24,\n avatarSize: 16, checkboxSize: 14,\n contentGap: 4, rootGap: 3,\n countPx: 4, countFontSize: 12,\n closeSize: 10, closePad: 2,\n },\n md: {\n // Base padding: px-9px py-2px (h=24px with lh-20px)\n basePx: 9, basePy: 2,\n plCheckbox: 4, plAvatar: 5, plDot: 7, plIcon: 5,\n prClose: 4, prCount: 3,\n fontSize: 14, lineHeight: '20px', height: 24,\n avatarSize: 16, checkboxSize: 16,\n contentGap: 5, rootGap: 4,\n countPx: 5, countFontSize: 12,\n closeSize: 12, closePad: 2,\n },\n lg: {\n // Base padding: px-10px py-4px (h=28px with lh-20px)\n basePx: 10, basePy: 4,\n plCheckbox: 5, plAvatar: 7, plDot: 9, plIcon: 7,\n prClose: 4, prCount: 4,\n fontSize: 14, lineHeight: '20px', height: 28,\n avatarSize: 18, checkboxSize: 18,\n contentGap: 6, rootGap: 4,\n countPx: 6, countFontSize: 14,\n closeSize: 14, closePad: 3,\n },\n} as const;\n\n// ─── TagAvatar ────────────────────────────────────────────────────────────────\n\nexport interface TagAvatarProps {\n src?: string;\n alt?: string;\n size?: number;\n}\n\nexport const TagAvatar: React.FC<TagAvatarProps> = ({ src, alt = 'Avatar', size = 16 }) => {\n const [failed, setFailed] = useState(false);\n return (\n <div\n style={{\n width: size, height: size, borderRadius: '50%',\n overflow: 'hidden', flexShrink: 0,\n border: '0.667px solid rgba(0,0,0,0.08)',\n background: '#e5e5e4',\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n }}\n >\n {src && !failed ? (\n <img\n src={src} alt={alt}\n onError={() => setFailed(true)}\n style={{ width: '100%', height: '100%', objectFit: 'cover', display: 'block' }}\n />\n ) : (\n <svg\n width={size * 0.625} height={size * 0.625}\n viewBox=\"0 0 10 10\" fill=\"none\"\n >\n <circle cx=\"5\" cy=\"3.5\" r=\"2\" stroke=\"#999\" strokeWidth=\"1.2\" />\n <path d=\"M1 9.5c0-2.2 1.8-4 4-4s4 1.8 4 4\" stroke=\"#999\" strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n </svg>\n )}\n </div>\n );\n};\n\n// ─── Tag ──────────────────────────────────────────────────────────────────────\n\nconst Tag: React.FC<TagProps> = ({\n children,\n color,\n variant = 'light',\n size = 'md',\n stroke = false,\n iconType: iconTypeProp,\n icon,\n avatarSrc,\n dotColor,\n action = 'none',\n count,\n onClose,\n checkbox = false,\n checked: checkedProp,\n onCheckedChange,\n iconPosition,\n className = '',\n onClick,\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n const [internalChecked, setInternalChecked] = useState(false);\n\n const nSize = normalizeSize(size);\n const s = SIZE[nSize];\n\n // Controlled/uncontrolled checkbox\n const isChecked = checkedProp !== undefined ? checkedProp : internalChecked;\n const handleCheckboxToggle = (e: React.MouseEvent) => {\n e.stopPropagation();\n const next = !isChecked;\n if (checkedProp === undefined) setInternalChecked(next);\n onCheckedChange?.(next);\n };\n\n // Resolve icon type; backward-compat: legacy iconPosition='leading' → iconType='icon'\n const iconType: TagIconType =\n iconTypeProp ??\n (icon && iconPosition === 'leading' ? 'icon' : 'none');\n\n const hasLeading = iconType !== 'none';\n const effectiveAction = action !== 'none' ? action : undefined;\n\n // Compute left padding (checkbox wins > dot > avatar/icon > base)\n const pl = checkbox ? s.plCheckbox\n : iconType === 'dot' ? s.plDot\n : iconType === 'avatar' || iconType === 'icon' ? s.plAvatar\n : s.basePx;\n\n // Compute right padding\n const pr = effectiveAction === 'x-close' ? s.prClose\n : effectiveAction === 'count' ? s.prCount\n : s.basePx;\n\n // Base neutral style matching Figma (white bg + gray border)\n const containerStyle: React.CSSProperties = {\n display: 'inline-flex',\n alignItems: 'center',\n gap: effectiveAction === 'x-close' ? s.rootGap : 0,\n paddingLeft: pl,\n paddingRight: pr,\n paddingTop: s.basePy,\n paddingBottom: s.basePy,\n height: s.height,\n borderRadius: 6,\n fontFamily: 'DM Sans, sans-serif',\n fontWeight: 500,\n fontSize: s.fontSize,\n lineHeight: s.lineHeight,\n transition: 'all 0.2s',\n cursor: onClick ? 'pointer' : 'default',\n boxSizing: 'border-box',\n backgroundColor: '#ffffff',\n color: '#44403c',\n // Inset outline matches Figma: outline-1 outline-offset-[-1px]\n outline: '1px solid #d7d3d0',\n outlineOffset: '-1px',\n };\n\n // Optional color override (keeps backward compat with color prop)\n if (color) {\n const colorConfig = getColorConfig(color, primaryColor);\n if (variant === 'light') {\n containerStyle.backgroundColor = colorConfig.light.bg;\n containerStyle.color = colorConfig.light.text;\n containerStyle.outline = stroke ? `1px solid ${getOutlineColor(color)}` : 'none';\n containerStyle.outlineOffset = stroke ? '-1px' : undefined;\n } else {\n containerStyle.backgroundColor = colorConfig.fill.bg;\n containerStyle.color = colorConfig.fill.text;\n containerStyle.outline = 'none';\n }\n }\n\n if (onClick) {\n containerStyle.cursor = 'pointer';\n }\n\n // Leading icon element\n const renderLeadingIcon = () => {\n if (iconType === 'avatar') {\n return <TagAvatar src={avatarSrc} size={s.avatarSize} />;\n }\n if (iconType === 'dot') {\n return (\n <svg width={8} height={8} viewBox=\"0 0 8 8\" fill=\"none\" style={{ flexShrink: 0 }}>\n <circle cx={4} cy={4} r={3.5} fill={dotColor || 'currentColor'} />\n </svg>\n );\n }\n if (iconType === 'icon' && icon) {\n return (\n <span style={{ display: 'flex', alignItems: 'center', flexShrink: 0 }}>\n {React.cloneElement(icon as React.ReactElement<SVGProps<SVGSVGElement>>, {\n width: s.avatarSize,\n height: s.avatarSize,\n })}\n </span>\n );\n }\n return null;\n };\n\n return (\n <div\n className={className}\n style={containerStyle}\n onClick={onClick}\n {...rest}\n >\n {/* Content row: checkbox + icon + text + count */}\n <div style={{ display: 'flex', alignItems: 'center', gap: s.contentGap, flexShrink: 0 }}>\n {/* Checkbox */}\n {checkbox && (\n <div\n role=\"checkbox\"\n aria-checked={isChecked}\n onClick={handleCheckboxToggle}\n style={{\n width: s.checkboxSize, height: s.checkboxSize,\n borderRadius: 4, flexShrink: 0,\n border: isChecked ? 'none' : '1px solid #d7d3d0',\n background: isChecked ? (primaryColor || '#7F56D9') : '#ffffff',\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n cursor: 'pointer',\n }}\n >\n {isChecked && (\n <svg\n width={Math.round(s.checkboxSize * 0.65)}\n height={Math.round(s.checkboxSize * 0.65)}\n viewBox=\"0 0 10 10\" fill=\"none\"\n >\n <path d=\"M8.5 2L4 7.5 1.5 5\" stroke=\"#fff\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n )}\n </div>\n )}\n\n {/* Leading icon (avatar / dot / generic icon) */}\n {renderLeadingIcon()}\n\n {/* Text label */}\n <span style={{ whiteSpace: 'nowrap' }}>{children}</span>\n\n {/* Count badge */}\n {effectiveAction === 'count' && typeof count === 'number' && (\n <span style={{\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n paddingLeft: s.countPx, paddingRight: s.countPx,\n paddingTop: 1, paddingBottom: 1,\n background: 'rgba(0,0,0,0.07)',\n borderRadius: 3,\n fontSize: s.countFontSize,\n fontWeight: 500,\n lineHeight: '16px',\n flexShrink: 0,\n }}>\n {count}\n </span>\n )}\n </div>\n\n {/* Close X (outside content row, right side) */}\n {effectiveAction === 'x-close' && (\n <button\n aria-label=\"Remove\"\n onClick={(e) => { e.stopPropagation(); onClose?.(); }}\n style={{\n display: 'flex', alignItems: 'center', justifyContent: 'center',\n padding: s.closePad, borderRadius: 3,\n border: 'none', background: 'transparent',\n cursor: 'pointer', flexShrink: 0,\n color: 'inherit', opacity: 0.55,\n lineHeight: 0,\n }}\n >\n <svg width={s.closeSize} height={s.closeSize} viewBox=\"0 0 10 10\" fill=\"none\">\n <path d=\"M7.5 2.5l-5 5M2.5 2.5l5 5\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n </button>\n )}\n\n {/* Legacy: icon rendered after text when iconPosition='after' */}\n {iconPosition === 'after' && icon && !iconTypeProp && (\n <span style={{ display: 'flex', alignItems: 'center', flexShrink: 0, marginLeft: s.contentGap }}>\n {icon}\n </span>\n )}\n </div>\n );\n};\n\nexport default Tag;\n","import React, { forwardRef, useRef, useEffect, useState } from 'react';\nimport { InputProps } from './index';\n\nexport interface InputGroupProps\n extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'prefix' | 'suffix'> {\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n error?: boolean;\n readOnly?: boolean;\n disabled?: boolean;\n prefix?: React.ReactNode;\n suffix?: React.ReactNode;\n /** Text addon on the left (e.g. \"https://\") — auto-styled with correct padding */\n leadingText?: React.ReactNode;\n /** Text addon on the right (e.g. \"USD\") — auto-styled with correct padding */\n trailingText?: React.ReactNode;\n /** Raw ReactNode on the left (dropdown, icon button, etc.) — no padding added */\n leadingAddon?: React.ReactNode;\n /** Raw ReactNode on the right (button, select, etc.) — no padding added */\n trailingAddon?: React.ReactNode;\n onPressEnter?: (e: React.KeyboardEvent<HTMLInputElement>) => void;\n className?: string;\n style?: React.CSSProperties;\n label?: string;\n required?: boolean;\n hintText?: string;\n}\n\nconst SHADOW_XS = 'var(--shadow-xs)';\n\nconst sizeMap: Record<NonNullable<InputGroupProps['size']>, { pt: string; pb: string }> = {\n small: { pt: '5px', pb: '5px' },\n mediumSmall: { pt: '7px', pb: '7px' },\n medium: { pt: '9px', pb: '9px' },\n large: { pt: '11px', pb: '11px' },\n};\n\nconst InputGroup = forwardRef<HTMLInputElement, InputGroupProps>(({\n size = 'mediumSmall',\n error = false,\n disabled = false,\n readOnly = false,\n prefix,\n suffix,\n leadingText,\n trailingText,\n leadingAddon,\n trailingAddon,\n className = '',\n style,\n onFocus,\n onBlur,\n onKeyDown,\n onPressEnter,\n value,\n defaultValue,\n onChange,\n placeholder,\n type = 'text',\n label,\n required,\n hintText,\n ...restProps\n}, ref) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const [focused, setFocused] = useState(false);\n const [internalValue, setInternalValue] = useState(defaultValue ?? '');\n\n useEffect(() => {\n if (typeof ref === 'function') ref(inputRef.current);\n else if (ref) (ref as React.MutableRefObject<HTMLInputElement | null>).current = inputRef.current;\n }, [ref]);\n\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) setInternalValue(e.target.value);\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLInputElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter' && onPressEnter) onPressEnter(e);\n onKeyDown?.(e);\n };\n\n const getFocusStyles = (): React.CSSProperties => {\n if (disabled) return { border: '1px solid var(--color-border-disabled)', boxShadow: SHADOW_XS, outline: 'none' };\n if (error && focused) return { border: '1px solid var(--color-border-error)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-error)', outlineOffset: '-2px' };\n if (error) return { border: '1px solid var(--color-border-error_subtle)', boxShadow: SHADOW_XS, outline: 'none' };\n if (focused) return { border: '1px solid var(--color-border-brand)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-brand)', outlineOffset: '-2px' };\n return { border: '1px solid var(--color-border-primary)', boxShadow: SHADOW_XS, outline: 'none' };\n };\n\n const { border, boxShadow, outline, outlineOffset } = getFocusStyles();\n const { pt, pb } = sizeMap[size];\n const dividerColor = disabled ? 'var(--color-border-disabled)' : 'var(--color-border-primary)';\n const iconColor = disabled ? 'var(--color-fg-disabled)' : 'var(--color-fg-quaternary)';\n const hasPrefixIcon = !!prefix;\n const hasSuffixIcon = !!suffix;\n\n const iconSlotStyle: React.CSSProperties = {\n position: 'absolute',\n top: '50%',\n transform: 'translateY(-50%)',\n display: 'flex',\n alignItems: 'center',\n color: iconColor,\n zIndex: 1,\n pointerEvents: 'none',\n };\n\n const addonTextStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n paddingTop: pt,\n paddingBottom: pb,\n paddingLeft: '14px',\n paddingRight: '12px',\n color: 'var(--color-text-tertiary)',\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-md)',\n lineHeight: 'var(--line-height-text-md)',\n whiteSpace: 'nowrap',\n flexShrink: 0,\n backgroundColor: disabled ? 'var(--color-bg-disabled_subtle)' : 'transparent',\n };\n\n const groupEl = (\n <div\n className={`aha-input-group ${className}`}\n style={{\n display: 'flex',\n alignItems: 'stretch',\n width: '100%',\n border,\n boxShadow,\n outline,\n outlineOffset,\n borderRadius: 'var(--radius-md)',\n backgroundColor: disabled || readOnly ? 'var(--color-bg-disabled_subtle)' : 'var(--color-bg-primary)',\n overflow: 'hidden',\n boxSizing: 'border-box',\n transition: 'border-color 0.15s ease, box-shadow 0.15s ease',\n ...style,\n }}\n >\n {/* Leading text addon (auto-padded) */}\n {leadingText !== undefined && (\n <div style={{ ...addonTextStyle, borderRight: `1px solid ${dividerColor}` }}>\n {leadingText}\n </div>\n )}\n {/* Leading raw addon (no auto-padding) */}\n {leadingAddon !== undefined && (\n <div style={{ display: 'flex', alignItems: 'stretch', flexShrink: 0, borderRight: `1px solid ${dividerColor}` }}>\n {leadingAddon}\n </div>\n )}\n\n {/* Input area */}\n <div style={{ flex: 1, position: 'relative', display: 'flex', alignItems: 'stretch', minWidth: 0 }}>\n {hasPrefixIcon && (\n <span style={{ ...iconSlotStyle, left: '14px' }}>{prefix}</span>\n )}\n <input\n ref={inputRef}\n type={type}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n width: '100%',\n boxSizing: 'border-box',\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-md)',\n fontWeight: 400,\n lineHeight: 'var(--line-height-text-md)',\n backgroundColor: 'transparent',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-primary)',\n paddingTop: pt,\n paddingBottom: pb,\n paddingLeft: hasPrefixIcon ? '40px' : '14px',\n paddingRight: hasSuffixIcon ? '40px' : '14px',\n }}\n autoComplete={restProps.autoComplete || 'off'}\n {...restProps}\n />\n {hasSuffixIcon && (\n <span style={{ ...iconSlotStyle, right: '14px' }}>{suffix}</span>\n )}\n </div>\n\n {/* Trailing text addon (auto-padded) */}\n {trailingText !== undefined && (\n <div style={{ ...addonTextStyle, paddingLeft: '12px', paddingRight: '14px', borderLeft: `1px solid ${dividerColor}` }}>\n {trailingText}\n </div>\n )}\n {/* Trailing raw addon (no auto-padding) */}\n {trailingAddon !== undefined && (\n <div style={{ display: 'flex', alignItems: 'stretch', flexShrink: 0, borderLeft: `1px solid ${dividerColor}` }}>\n {trailingAddon}\n </div>\n )}\n </div>\n );\n\n if (!label && !hintText) return groupEl;\n\n const labelStyle: React.CSSProperties = {\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n };\n\n const hintStyle: React.CSSProperties = {\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n };\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={labelStyle}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n </label>\n )}\n {groupEl}\n {hintText && <p style={hintStyle}>{hintText}</p>}\n </div>\n );\n});\n\nInputGroup.displayName = 'InputGroup';\n\nexport default InputGroup;\n","import React, { useState, useRef, KeyboardEvent } from 'react';\nimport Tag from '../Tag';\n\nexport interface InputTagsProps {\n value?: string[];\n defaultValue?: string[];\n onChange?: (tags: string[]) => void;\n placeholder?: string;\n disabled?: boolean;\n error?: boolean;\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n className?: string;\n style?: React.CSSProperties;\n label?: string;\n required?: boolean;\n hintText?: string;\n}\n\nconst SHADOW_XS = 'var(--shadow-xs)';\n\nconst containerPadding = {\n small: '4px',\n mediumSmall: '6px',\n medium: '8px',\n large: '10px',\n};\n\nconst tagSizeMap = {\n small: 'sm',\n mediumSmall: 'sm',\n medium: 'md',\n large: 'lg',\n} as const;\n\nconst InputTags: React.FC<InputTagsProps> = ({\n value,\n defaultValue = [],\n onChange,\n placeholder = 'Add tag...',\n disabled = false,\n error = false,\n size = 'mediumSmall',\n className = '',\n style,\n label,\n required,\n hintText,\n}) => {\n const [internalTags, setInternalTags] = useState<string[]>(defaultValue);\n const [inputValue, setInputValue] = useState('');\n const [focused, setFocused] = useState(false);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const isControlled = value !== undefined;\n const tags = isControlled ? value! : internalTags;\n\n const updateTags = (next: string[]) => {\n if (!isControlled) setInternalTags(next);\n onChange?.(next);\n };\n\n const addTag = (tag: string) => {\n const trimmed = tag.trim();\n if (!trimmed || tags.includes(trimmed)) return;\n updateTags([...tags, trimmed]);\n setInputValue('');\n };\n\n const removeTag = (index: number) => {\n updateTags(tags.filter((_, i) => i !== index));\n };\n\n const handleKeyDown = (e: KeyboardEvent<HTMLInputElement>) => {\n if ((e.key === 'Enter' || e.key === ',') && inputValue) {\n e.preventDefault();\n addTag(inputValue);\n }\n if (e.key === 'Backspace' && !inputValue && tags.length > 0) {\n removeTag(tags.length - 1);\n }\n };\n\n const getFocusStyles = (): React.CSSProperties => {\n if (disabled) return { border: '1px solid var(--color-border-disabled)', boxShadow: SHADOW_XS, outline: 'none' };\n if (error && focused) return { border: '1px solid var(--color-border-error)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-error)', outlineOffset: '-2px' };\n if (error) return { border: '1px solid var(--color-border-error_subtle)', boxShadow: SHADOW_XS, outline: 'none' };\n if (focused) return { border: '1px solid var(--color-border-brand)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-brand)', outlineOffset: '-2px' };\n return { border: '1px solid var(--color-border-primary)', boxShadow: SHADOW_XS, outline: 'none' };\n };\n\n const { border, boxShadow, outline, outlineOffset } = getFocusStyles();\n const p = containerPadding[size];\n const tagSize = tagSizeMap[size];\n\n const labelStyle: React.CSSProperties = {\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n };\n\n const tagsEl = (\n <div\n className={`aha-input-tags ${className}`}\n onClick={() => inputRef.current?.focus()}\n style={{\n display: 'flex',\n flexWrap: 'wrap',\n alignItems: 'center',\n gap: '6px',\n padding: p,\n border,\n boxShadow,\n outline,\n outlineOffset,\n borderRadius: 'var(--radius-md)',\n backgroundColor: disabled ? 'var(--color-bg-disabled_subtle)' : 'var(--color-bg-primary)',\n boxSizing: 'border-box',\n width: '100%',\n transition: 'border-color 0.15s ease, box-shadow 0.15s ease',\n cursor: disabled ? 'not-allowed' : 'text',\n ...style,\n }}\n >\n {tags.map((tag, i) => (\n <Tag\n key={i}\n size={tagSize}\n action={disabled ? 'none' : 'x-close'}\n onClose={() => removeTag(i)}\n >\n {tag}\n </Tag>\n ))}\n <input\n ref={inputRef}\n value={inputValue}\n onChange={(e) => setInputValue(e.target.value)}\n onKeyDown={handleKeyDown}\n onFocus={() => setFocused(true)}\n onBlur={() => { setFocused(false); if (inputValue) addTag(inputValue); }}\n disabled={disabled}\n placeholder={tags.length === 0 ? placeholder : ''}\n style={{\n flex: 1,\n minWidth: '80px',\n border: 'none',\n outline: 'none',\n padding: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-md)',\n lineHeight: 'var(--line-height-text-md)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-primary)',\n backgroundColor: 'transparent',\n }}\n />\n <style>{`\n .aha-input-tags input::placeholder { color: var(--color-text-placeholder); }\n `}</style>\n </div>\n );\n\n if (!label && !hintText) return tagsEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={labelStyle}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n </label>\n )}\n {tagsEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n};\n\nexport default InputTags;\n","import React, { forwardRef, useRef, useEffect } from 'react';\n\nexport interface InputProps\n extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'prefix' | 'suffix'> {\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n disabled?: boolean;\n error?: boolean;\n readOnly?: boolean;\n prefix?: React.ReactNode;\n suffix?: React.ReactNode;\n allowClear?: boolean;\n onClear?: () => void;\n className?: string;\n style?: React.CSSProperties;\n type?: string;\n placeholder?: string;\n value?: string;\n defaultValue?: string;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n onFocus?: (e: React.FocusEvent<HTMLInputElement>) => void;\n onBlur?: (e: React.FocusEvent<HTMLInputElement>) => void;\n onPressEnter?: (e: React.KeyboardEvent<HTMLInputElement>) => void;\n label?: string;\n required?: boolean;\n hintText?: string;\n}\n\n// sm=36px, mediumSmall=40px, md=44px (matches Figma md), lg=48px\n// With box-sizing:border-box: height = 1px border × 2 + paddingTop + 24px lineHeight + paddingBottom\nconst sizeStyles: Record<NonNullable<InputProps['size']>, React.CSSProperties> = {\n small: { height: '36px', paddingTop: '5px', paddingBottom: '5px' },\n mediumSmall: { height: '40px', paddingTop: '7px', paddingBottom: '7px' },\n medium: { height: '44px', paddingTop: '9px', paddingBottom: '9px' },\n large: { height: '48px', paddingTop: '11px', paddingBottom: '11px' },\n};\n\nconst SHADOW_XS = 'var(--shadow-xs)';\n\nconst ClearIcon: React.FC<{ onClick: (e: React.MouseEvent) => void }> = ({ onClick }) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n onClick={onClick}\n style={{ cursor: 'pointer', flexShrink: 0 }}\n >\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\nconst Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n size = 'mediumSmall',\n disabled = false,\n error = false,\n readOnly = false,\n prefix,\n suffix,\n allowClear = false,\n onClear,\n className = '',\n style,\n type = 'text',\n placeholder,\n value,\n defaultValue,\n onChange,\n onFocus,\n onBlur,\n onPressEnter,\n label,\n required,\n hintText,\n ...restProps\n },\n ref\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const [internalValue, setInternalValue] = React.useState(defaultValue || value || '');\n const [focused, setFocused] = React.useState(false);\n\n useEffect(() => {\n if (typeof ref === 'function') {\n ref(inputRef.current);\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLInputElement | null>).current = inputRef.current;\n }\n }, [ref]);\n\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) setInternalValue(e.target.value);\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLInputElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter' && onPressEnter) onPressEnter(e);\n restProps.onKeyDown?.(e);\n };\n\n const handleClear = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!isControlled) setInternalValue('');\n const syntheticEvent = {\n target: { value: '' },\n currentTarget: { value: '' },\n } as React.ChangeEvent<HTMLInputElement>;\n onChange?.(syntheticEvent);\n onClear?.();\n inputRef.current?.focus();\n };\n\n const showClear = allowClear && currentValue && !disabled;\n\n const getFocusStyles = (): React.CSSProperties => {\n if (disabled) return {\n border: '1px solid var(--color-border-disabled)',\n boxShadow: SHADOW_XS,\n outline: 'none',\n };\n if (error && focused) return {\n border: '1px solid var(--color-border-error)',\n boxShadow: SHADOW_XS,\n outline: '2px solid var(--color-border-error)',\n outlineOffset: '-2px',\n };\n if (error) return {\n border: '1px solid var(--color-border-error_subtle)',\n boxShadow: SHADOW_XS,\n outline: 'none',\n };\n if (focused) return {\n border: '1px solid var(--color-border-brand)',\n boxShadow: SHADOW_XS,\n outline: '2px solid var(--color-border-brand)',\n outlineOffset: '-2px',\n };\n return {\n border: '1px solid var(--color-border-primary)',\n boxShadow: SHADOW_XS,\n outline: 'none',\n };\n };\n\n const { border, boxShadow, outline, outlineOffset } = getFocusStyles();\n const { height, paddingTop, paddingBottom } = sizeStyles[size];\n\n const hasRightContent = suffix || showClear;\n const paddingLeft = prefix ? '40px' : '14px';\n const paddingRight = hasRightContent ? '40px' : '14px';\n\n const baseStyles: React.CSSProperties = {\n width: '100%',\n height,\n boxSizing: 'border-box',\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-md)',\n fontWeight: 400,\n lineHeight: 'var(--line-height-text-md)',\n borderRadius: 'var(--radius-md)',\n border,\n boxShadow,\n backgroundColor:\n disabled || readOnly\n ? 'var(--color-bg-disabled_subtle)'\n : 'var(--color-bg-primary)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-primary)',\n paddingTop,\n paddingBottom,\n paddingLeft,\n paddingRight,\n transition: 'border-color 0.15s ease, box-shadow 0.15s ease, outline-color 0.15s ease',\n outline,\n outlineOffset,\n WebkitAppearance: 'none',\n MozAppearance: 'textfield',\n appearance: 'none',\n ...style,\n };\n\n const placeholderStyles = `\n .aha-input-wrapper input::placeholder {\n color: var(--color-text-placeholder);\n font-size: var(--font-size-text-md);\n font-weight: 400;\n opacity: 1;\n }\n .aha-input-wrapper input::-webkit-input-placeholder { color: var(--color-text-placeholder); }\n .aha-input-wrapper input::-moz-placeholder { color: var(--color-text-placeholder); }\n .aha-input-wrapper input:-ms-input-placeholder { color: var(--color-text-placeholder); }\n .aha-input-wrapper input {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-input-wrapper input[type=\"number\"]::-webkit-inner-spin-button,\n .aha-input-wrapper input[type=\"number\"]::-webkit-outer-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n .aha-input-wrapper input[type=\"number\"] { -moz-appearance: textfield; }\n `;\n\n const iconColor = disabled\n ? 'var(--color-fg-disabled)'\n : 'var(--color-fg-quaternary)';\n\n const iconSlotStyle: React.CSSProperties = {\n position: 'absolute',\n top: '50%',\n transform: 'translateY(-50%)',\n display: 'flex',\n alignItems: 'center',\n color: iconColor,\n zIndex: 1,\n };\n\n const inputEl = (\n <>\n <style>{placeholderStyles}</style>\n <div\n className={`aha-input-wrapper ${className}`}\n style={{ position: 'relative', display: 'block', width: '100%' }}\n >\n {prefix && (\n <span style={{ ...iconSlotStyle, left: '14px', pointerEvents: 'none' }}>\n {prefix}\n </span>\n )}\n <input\n ref={inputRef}\n type={type}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n style={baseStyles}\n autoComplete={restProps.autoComplete || 'off'}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n {...restProps}\n />\n {(suffix || showClear) && (\n <span style={{ ...iconSlotStyle, right: '14px', gap: 'var(--spacing-xs)' }}>\n {showClear && <ClearIcon onClick={handleClear} />}\n {suffix}\n </span>\n )}\n </div>\n </>\n );\n\n if (!label && !hintText) return inputEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={{\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n }}>\n {label}\n {required && (\n <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>\n )}\n </label>\n )}\n {inputEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n }\n);\n\nInput.displayName = 'Input';\n\nexport default Input;\n\nexport { default as InputGroup } from './InputGroup';\nexport type { InputGroupProps } from './InputGroup';\nexport { default as InputTags } from './InputTags';\nexport type { InputTagsProps } from './InputTags';\n","import React, { useState, useRef, useEffect, useCallback, useMemo } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface SelectOption {\n label: React.ReactNode;\n value: string | number;\n disabled?: boolean;\n [key: string]: any;\n}\n\nexport interface SelectProps {\n /** 当前选中的值 */\n value?: string | number | (string | number)[];\n /** 默认选中的值 */\n defaultValue?: string | number | (string | number)[];\n /** 选项数据 */\n options?: SelectOption[];\n /** 是否支持多选 */\n mode?: 'multiple' | 'tags';\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 占位符 */\n placeholder?: string;\n /** 尺寸 */\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n /** 是否可搜索 */\n showSearch?: boolean;\n /** 搜索过滤函数 */\n filterOption?: boolean | ((input: string, option: SelectOption) => boolean);\n /** 是否允许清除 */\n allowClear?: boolean;\n /** 变化回调 */\n onChange?: (\n value: string | number | (string | number)[],\n option: SelectOption | SelectOption[]\n ) => void;\n /** 选择回调 */\n onSelect?: (value: string | number, option: SelectOption) => void;\n /** 取消选择回调 */\n onDeselect?: (value: string | number, option: SelectOption) => void;\n /** 搜索回调 */\n onSearch?: (value: string) => void;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent) => void;\n /** 下拉框打开回调 */\n onDropdownVisibleChange?: (open: boolean) => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 下拉框类名 */\n dropdownClassName?: string;\n /** 下拉框样式 */\n dropdownStyle?: React.CSSProperties;\n /** 是否默认打开 */\n defaultOpen?: boolean;\n /** 是否打开(受控) */\n open?: boolean;\n /** 最大标签数量 */\n maxTagCount?: number | 'responsive';\n /** 标签渲染函数 */\n tagRender?: (props: {\n label: React.ReactNode;\n value: string | number;\n closable: boolean;\n onClose: () => void;\n }) => React.ReactNode;\n /** 选项渲染函数 */\n optionRender?: (option: SelectOption, info: {\n selected: boolean;\n focused: boolean;\n disabled: boolean;\n }) => React.ReactNode;\n}\n\nconst Select: React.FC<SelectProps> = ({\n value: controlledValue,\n defaultValue,\n options = [],\n mode,\n disabled = false,\n error = false,\n placeholder = 'Please select',\n size = 'medium',\n showSearch = false,\n filterOption = true,\n allowClear = false,\n onChange,\n onSelect,\n onDeselect,\n onSearch,\n onFocus,\n onBlur,\n onDropdownVisibleChange,\n className = '',\n style,\n dropdownClassName = '',\n dropdownStyle,\n defaultOpen = false,\n open: controlledOpen,\n maxTagCount,\n tagRender,\n optionRender,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const [internalValue, setInternalValue] = useState<\n string | number | (string | number)[] | undefined\n >(defaultValue !== undefined ? defaultValue : (mode ? [] : undefined));\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [searchValue, setSearchValue] = useState('');\n const [focusedIndex, setFocusedIndex] = useState(-1);\n\n const selectRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const dropdownRef = useRef<HTMLDivElement>(null);\n const [dropdownPosition, setDropdownPosition] = useState<{\n top: number;\n left: number;\n width: number;\n placement: 'top' | 'bottom';\n } | null>(null);\n\n const isControlled = controlledValue !== undefined;\n const isOpenControlled = controlledOpen !== undefined;\n const currentValue = isControlled ? controlledValue : internalValue;\n const isOpen = isOpenControlled ? controlledOpen : internalOpen;\n const isMultiple = mode === 'multiple' || mode === 'tags';\n\n // 获取选中的选项\n const getSelectedOptions = useCallback((): SelectOption[] => {\n if (!currentValue) return [];\n const values = Array.isArray(currentValue) ? currentValue : [currentValue];\n return options.filter((opt) => values.includes(opt.value));\n }, [currentValue, options]);\n\n // 过滤选项\n const getFilteredOptions = useCallback((): SelectOption[] => {\n if (!showSearch || !searchValue) return options;\n\n if (filterOption === false) return options;\n\n if (typeof filterOption === 'function') {\n return options.filter((opt) => filterOption(searchValue, opt));\n }\n\n // 默认过滤:匹配 label\n return options.filter((opt) => {\n const label = String(opt.label || '').toLowerCase();\n const search = searchValue.toLowerCase();\n return label.includes(search);\n });\n }, [options, searchValue, showSearch, filterOption]);\n\n const filteredOptions = useMemo(() => getFilteredOptions(), [getFilteredOptions]);\n\n // 计算下拉框位置\n useEffect(() => {\n if (isOpen && selectRef.current) {\n const updatePosition = () => {\n if (selectRef.current) {\n const rect = selectRef.current.getBoundingClientRect();\n const estimatedDropdownHeight =\n dropdownRef.current?.offsetHeight ??\n Math.min(256, Math.max(40, filteredOptions.length * 40));\n const gap = 4;\n const spaceBelow = window.innerHeight - rect.bottom;\n const spaceAbove = rect.top;\n const shouldOpenUp =\n spaceBelow < estimatedDropdownHeight + gap && spaceAbove > spaceBelow;\n const top = shouldOpenUp\n ? rect.top + window.scrollY - estimatedDropdownHeight - gap\n : rect.bottom + window.scrollY + gap;\n\n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement: shouldOpenUp ? 'top' : 'bottom',\n });\n }\n };\n\n updatePosition();\n requestAnimationFrame(updatePosition);\n\n // 监听窗口大小变化和滚动,更新位置\n window.addEventListener('resize', updatePosition);\n window.addEventListener('scroll', updatePosition, true);\n\n return () => {\n window.removeEventListener('resize', updatePosition);\n window.removeEventListener('scroll', updatePosition, true);\n };\n } else {\n setDropdownPosition(null);\n }\n }, [isOpen, filteredOptions.length]);\n\n // 点击外部关闭(支持鼠标和触摸事件)\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent | TouchEvent) => {\n const target = event.target as Node;\n if (\n selectRef.current &&\n !selectRef.current.contains(target) &&\n dropdownRef.current &&\n !dropdownRef.current.contains(target)\n ) {\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onDropdownVisibleChange?.(false);\n setSearchValue('');\n }\n };\n\n if (isOpen) {\n // 使用 capture 阶段确保能捕获到事件\n document.addEventListener('mousedown', handleClickOutside, true);\n document.addEventListener('touchstart', handleClickOutside, true);\n return () => {\n document.removeEventListener('mousedown', handleClickOutside, true);\n document.removeEventListener('touchstart', handleClickOutside, true);\n };\n }\n }, [isOpen, isOpenControlled, onDropdownVisibleChange]);\n\n // 键盘导航\n useEffect(() => {\n if (!isOpen) return;\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === 'ArrowDown') {\n e.preventDefault();\n setFocusedIndex((prev) =>\n prev < filteredOptions.length - 1 ? prev + 1 : prev\n );\n } else if (e.key === 'ArrowUp') {\n e.preventDefault();\n setFocusedIndex((prev) => (prev > 0 ? prev - 1 : 0));\n } else if (e.key === 'Enter' && focusedIndex >= 0) {\n e.preventDefault();\n const option = filteredOptions[focusedIndex];\n if (option && !option.disabled) {\n handleSelect(option);\n }\n } else if (e.key === 'Escape') {\n e.preventDefault();\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onDropdownVisibleChange?.(false);\n selectRef.current?.focus();\n }\n };\n\n window.addEventListener('keydown', handleKeyDown);\n return () => {\n window.removeEventListener('keydown', handleKeyDown);\n };\n }, [isOpen, filteredOptions, focusedIndex, isOpenControlled, onDropdownVisibleChange]);\n\n // 滚动到聚焦项\n useEffect(() => {\n if (focusedIndex >= 0 && dropdownRef.current) {\n const items = dropdownRef.current.querySelectorAll('.aha-select-option');\n const focusedItem = items[focusedIndex] as HTMLElement;\n if (focusedItem) {\n focusedItem.scrollIntoView({ block: 'nearest', behavior: 'smooth' });\n }\n }\n }, [focusedIndex]);\n\n const handleSelect = useCallback((option: SelectOption) => {\n if (option.disabled) return;\n\n if (isMultiple) {\n const currentValues = Array.isArray(currentValue) ? currentValue : [];\n const isSelected = currentValues.includes(option.value);\n\n let newValues: (string | number)[];\n if (isSelected) {\n newValues = currentValues.filter((v) => v !== option.value);\n onDeselect?.(option.value, option);\n } else {\n newValues = [...currentValues, option.value];\n onSelect?.(option.value, option);\n }\n\n if (!isControlled) {\n setInternalValue(newValues);\n }\n // 计算选中的选项\n const selectedOptions = options.filter((opt) => newValues.includes(opt.value));\n onChange?.(newValues, selectedOptions);\n } else {\n if (!isControlled) {\n setInternalValue(option.value);\n }\n onChange?.(option.value, option);\n onSelect?.(option.value, option);\n\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onDropdownVisibleChange?.(false);\n setSearchValue('');\n selectRef.current?.focus();\n }\n }, [isMultiple, currentValue, isControlled, isOpenControlled, options, onChange, onSelect, onDeselect, onDropdownVisibleChange]);\n\n const handleRemoveTag = useCallback((e: React.MouseEvent, value: string | number) => {\n e.stopPropagation();\n if (isMultiple && Array.isArray(currentValue)) {\n const newValues = currentValue.filter((v) => v !== value);\n const option = options.find((opt) => opt.value === value);\n if (!isControlled) {\n setInternalValue(newValues);\n }\n onChange?.(newValues, getSelectedOptions());\n onDeselect?.(value, option!);\n }\n }, [isMultiple, currentValue, isControlled, options, onChange, onDeselect, getSelectedOptions]);\n\n const handleClear = (e: React.MouseEvent) => {\n e.stopPropagation();\n const newValue: string | number | (string | number)[] | undefined = isMultiple ? [] : undefined;\n if (!isControlled) {\n setInternalValue(newValue);\n }\n onChange?.(newValue as any, []);\n setSearchValue('');\n };\n\n const handleToggle = () => {\n if (disabled) return;\n const newOpen = !isOpen;\n if (!isOpenControlled) {\n setInternalOpen(newOpen);\n }\n onDropdownVisibleChange?.(newOpen);\n if (newOpen && showSearch) {\n setTimeout(() => {\n inputRef.current?.focus();\n }, 0);\n } else {\n setSearchValue('');\n }\n };\n\n const handleSearch = (e: React.ChangeEvent<HTMLInputElement>) => {\n const val = e.target.value;\n setSearchValue(val);\n onSearch?.(val);\n setFocusedIndex(-1);\n };\n\n const handleFocus = (e: React.FocusEvent) => {\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent) => {\n onBlur?.(e);\n };\n\n // 尺寸样式 - 对齐 Input 组件\n const sizeStyles = {\n small: {\n height: '32px',\n paddingTop: '3px',\n paddingBottom: '3px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n mediumSmall: {\n height: '36px',\n paddingTop: '5px',\n paddingBottom: '5px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n medium: {\n height: '40px',\n paddingTop: '7px',\n paddingBottom: '7px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n large: {\n height: '48px',\n paddingTop: '11px',\n paddingBottom: '11px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n };\n\n const selectedOptions = useMemo(() => getSelectedOptions(), [getSelectedOptions]);\n const showClear = useMemo(() => allowClear && currentValue && !disabled, [allowClear, currentValue, disabled]);\n const hasValue = useMemo(() => \n isMultiple\n ? Array.isArray(currentValue) && currentValue.length > 0\n : currentValue !== undefined && currentValue !== null && currentValue !== '',\n [isMultiple, currentValue]\n );\n\n // 渲染标签 - 使用 useMemo 优化\n const renderTags = useMemo(() => {\n if (!isMultiple || !Array.isArray(currentValue) || currentValue.length === 0) {\n return null;\n }\n\n const tagsToShow =\n maxTagCount === 'responsive'\n ? selectedOptions.slice(0, 2) // 简化处理\n : maxTagCount\n ? selectedOptions.slice(0, maxTagCount)\n : selectedOptions;\n\n const remainingCount =\n maxTagCount && selectedOptions.length > tagsToShow.length\n ? selectedOptions.length - tagsToShow.length\n : 0;\n\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n flexWrap: 'wrap',\n gap: '4px',\n flex: 1,\n minWidth: 0,\n }}\n >\n {tagsToShow.map((option) => {\n const tagProps = {\n label: option.label,\n value: option.value,\n closable: !disabled,\n onClose: () => handleRemoveTag({} as any, option.value),\n };\n\n if (tagRender) {\n return <React.Fragment key={option.value}>{tagRender(tagProps)}</React.Fragment>;\n }\n\n return (\n <span\n key={option.value}\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n gap: '4px',\n padding: '2px 8px',\n backgroundColor: '#F5F5F4',\n borderRadius: '4px',\n fontSize: '12px',\n lineHeight: '18px',\n color: '#101828',\n fontFamily: \"DM Sans, sans-serif\",\n maxWidth: '100%',\n }}\n >\n <span\n style={{\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n >\n {option.label}\n </span>\n {!disabled && (\n <span\n onClick={(e) => handleRemoveTag(e, option.value)}\n style={{\n cursor: 'pointer',\n display: 'flex',\n alignItems: 'center',\n color: '#78716C',\n marginLeft: '4px',\n }}\n >\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9 3L3 9M3 3L9 9\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </span>\n )}\n </span>\n );\n })}\n {remainingCount > 0 && (\n <span\n style={{\n fontSize: '12px',\n lineHeight: '18px',\n color: '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n +{remainingCount}\n </span>\n )}\n </div>\n );\n }, [isMultiple, currentValue, selectedOptions, maxTagCount, disabled, tagRender]);\n\n // 下拉箭头图标\n const ArrowIcon = ({ isOpen: open }: { isOpen: boolean }) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{\n transform: open ? 'rotate(180deg)' : 'rotate(0deg)',\n transition: 'transform 0.2s ease-in-out',\n flexShrink: 0,\n }}\n >\n <path\n d=\"M4 6L8 10L12 6\"\n stroke=\"#78716C\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n // 清除图标\n const ClearIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n onClick={handleClear}\n style={{\n cursor: 'pointer',\n flexShrink: 0,\n color: '#78716C',\n }}\n >\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n // 下拉框动画样式\n const dropdownAnimationStyles = `\n @keyframes dropdownFadeIn {\n from {\n opacity: 0;\n transform: translateY(-8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n `;\n\n return (\n <>\n <style>{dropdownAnimationStyles}</style>\n <div\n ref={selectRef}\n className={`aha-select ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n width: '100%',\n minWidth: '120px',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px', // rounded-md\n border: `1px solid ${error ? '#F04438' : isOpen ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : '#FFFFFF',\n cursor: disabled ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n paddingLeft: '12px',\n paddingRight: '36px', // 为箭头和清除按钮留出空间(箭头16px + 右边距12px + 清除按钮8px)\n paddingTop: sizeStyles[size].paddingTop,\n paddingBottom: sizeStyles[size].paddingBottom,\n fontSize: sizeStyles[size].fontSize,\n lineHeight: sizeStyles[size].lineHeight,\n fontWeight: 400,\n WebkitTapHighlightColor: 'transparent', // 移动端移除点击高亮\n WebkitTouchCallout: 'none', // 禁用长按菜单\n touchAction: 'manipulation', // 优化触摸响应\n userSelect: 'none', // 禁用文本选择\n ...style,\n }}\n onClick={handleToggle}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onTouchStart={(e) => {\n // 移动端触摸优化\n if (!disabled) {\n e.currentTarget.style.opacity = '0.8';\n }\n }}\n onTouchEnd={(e) => {\n e.currentTarget.style.opacity = '1';\n }}\n tabIndex={disabled ? -1 : 0}\n >\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n flex: 1,\n minWidth: 0,\n gap: '8px',\n }}\n >\n {isMultiple ? (\n (renderTags || (placeholder ? (\n <span\n style={{\n flex: 1,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n color: '#79716B',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n }}\n >\n {placeholder}\n </span>\n ) : (\n <span style={{ flex: 1, minHeight: '24px' }} />\n )))) : showSearch && isOpen ? (\n <input\n ref={inputRef}\n type=\"text\"\n value={searchValue}\n onChange={handleSearch}\n onClick={(e) => e.stopPropagation()}\n onFocus={(e) => e.stopPropagation()}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px', // 至少 16px 避免 iOS Safari 自动缩放\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : '#1C1917',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n placeholder={hasValue ? undefined : placeholder}\n autoComplete=\"off\"\n autoCorrect=\"off\"\n autoCapitalize=\"off\"\n spellCheck={false}\n />\n ) : (\n <span\n style={{\n flex: 1,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n color: hasValue\n ? disabled\n ? '#98A2B3'\n : '#1C1917'\n : '#79716B',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n minHeight: '24px',\n display: 'inline-block',\n }}\n >\n {hasValue\n ? selectedOptions[0]?.label || currentValue\n : placeholder || '\\u00A0'}\n </span>\n )}\n </div>\n\n <div\n style={{\n position: 'absolute',\n right: '12px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n }}\n >\n {showClear && <ClearIcon />}\n <ArrowIcon isOpen={isOpen} />\n </div>\n </div>\n\n {isOpen && dropdownPosition && createPortal(\n <div\n ref={dropdownRef}\n className={`aha-select-dropdown ${dropdownClassName}`}\n style={{\n position: 'absolute',\n top: `${dropdownPosition.top}px`,\n left: `${dropdownPosition.left}px`,\n width: `${dropdownPosition.width}px`,\n zIndex: 1050,\n backgroundColor: '#FFFFFF',\n borderRadius: '8px',\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.15)',\n border: '1px solid #E7E5E4',\n maxHeight: '256px',\n overflow: 'auto',\n opacity: 0,\n transform:\n dropdownPosition.placement === 'top'\n ? 'translateY(8px)'\n : 'translateY(-8px)',\n animation: 'dropdownFadeIn 0.2s ease-out forwards',\n transformOrigin:\n dropdownPosition.placement === 'top'\n ? 'bottom center'\n : 'top center',\n WebkitOverflowScrolling: 'touch', // iOS 平滑滚动\n overscrollBehavior: 'contain', // 防止滚动穿透\n ...dropdownStyle,\n }}\n >\n {filteredOptions.length === 0 ? (\n <div\n style={{\n padding: '8px 16px',\n textAlign: 'center',\n color: '#78716C',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n No data\n </div>\n ) : (\n filteredOptions.map((option, index) => {\n const isSelected = isMultiple\n ? Array.isArray(currentValue) && currentValue.includes(option.value)\n : currentValue === option.value;\n const isFocused = index === focusedIndex;\n\n // 如果提供了自定义渲染函数,使用自定义渲染\n if (optionRender) {\n return (\n <div\n key={option.value}\n className={`aha-select-option ${!option.disabled ? 'hover:bg-[#FAFAF9]' : ''} ${isSelected ? 'bg-[#FAFAF9]' : ''}`}\n onClick={() => !option.disabled && handleSelect(option)}\n style={{\n cursor: option.disabled ? 'not-allowed' : 'pointer',\n transition: 'background-color 0.2s',\n }}\n >\n {optionRender(option, {\n selected: isSelected,\n focused: isFocused,\n disabled: option.disabled || false,\n })}\n </div>\n );\n }\n\n // 默认渲染\n return (\n <div\n key={option.value}\n className={`aha-select-option ${!option.disabled ? 'hover:bg-[#FAFAF9]' : ''} ${isSelected ? 'bg-[#FAFAF9]' : ''}`}\n onClick={() => handleSelect(option)}\n style={{\n padding: '8px 16px',\n cursor: option.disabled ? 'not-allowed' : 'pointer',\n color: option.disabled ? '#98A2B3' : '#101828',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: \"DM Sans, sans-serif\",\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n transition: 'background-color 0.2s',\n }}\n >\n <span>{option.label}</span>\n {/* 只有选中时才显示标识 */}\n {isSelected && (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={isFocused ? 'hidden' : ''}\n >\n <path\n d=\"M13.3333 4L6 11.3333L2.66667 8\"\n stroke={primaryColor}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )}\n </div>\n );\n })\n )}\n </div>,\n document.body\n )}\n </>\n );\n};\n\nSelect.displayName = 'Select';\n\nexport default Select;\n\n","import React from \"react\";\n\n// Checkbox 选中图标\nexport const CheckIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M11.6666 3.5L5.24992 9.91667L2.33325 7\"\n stroke=\"white\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Checkbox 半选中图标(减号)\nexport const MinusIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M3.5 7H10.5\"\n stroke=\"white\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Sort 图标\nexport const SortIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M3.5 7.5L6 10L8.5 7.5M3.5 4.5L6 2L8.5 4.5\"\n stroke=\"#A9A29D\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Sort 图标 降序\nexport const SortDescIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M3.5 4.5L6 2L8.5 4.5\"\n stroke=\"#A9A29D\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M3.5 7.5L6 10L8.5 7.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// Sort 图标 升序\nexport const SortAscIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M8.5 7.5L6 10L3.5 7.5\"\n stroke=\"#A9A29D\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M8.5 4.5L6 2L3.5 4.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n// 向左的箭头\nexport const LeftArrowIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M15.8334 10H4.16675M4.16675 10L10.0001 15.8334M4.16675 10L10.0001 4.16669\"\n stroke=\"currentColor\"\n strokeWidth=\"1.66667\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n// 向右的箭头\nexport const RightArrowIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <path\n d=\"M4.16675 10H15.8334M15.8334 10L10.0001 4.16669M15.8334 10L10.0001 15.8334\"\n stroke=\"currentColor\"\n strokeWidth=\"1.66667\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n// 提示信息图标\nexport const TooltipIcon: React.FC<{\n className?: string;\n style?: React.CSSProperties;\n}> = ({ className, style }) => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n style={style}\n >\n <g clipPath=\"url(#clip0_54_1653)\">\n <path\n d=\"M6.06 6C6.21674 5.55444 6.5261 5.17873 6.9333 4.93942C7.34051 4.7001 7.81926 4.61262 8.28479 4.69247C8.75031 4.77232 9.17255 5.01434 9.47672 5.37568C9.78089 5.73702 9.94737 6.19434 9.94667 6.66666C9.94667 8 7.94667 8.66666 7.94667 8.66666M8 11.3333H8.00667M14.6667 8C14.6667 11.6819 11.6819 14.6667 8 14.6667C4.3181 14.6667 1.33333 11.6819 1.33333 8C1.33333 4.3181 4.3181 1.33333 8 1.33333C11.6819 1.33333 14.6667 4.3181 14.6667 8Z\"\n stroke=\"currentColor\"\n strokeWidth=\"1.33333\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </g>\n <defs>\n <clipPath id=\"clip0_54_1653\">\n <rect width=\"16\" height=\"16\" fill=\"currentColor\" />\n </clipPath>\n </defs>\n </svg>\n);\n","import React, { useState, useEffect, useMemo } from \"react\";\nimport { useTheme } from \"../../theme/ThemeContext\";\nimport Button from \"../Button\";\nimport Input from \"../Input\";\nimport Select from \"../Select\";\nimport { LeftArrowIcon, RightArrowIcon } from \"../../icons\";\n\nexport interface PaginationProps {\n current?: number;\n defaultCurrent?: number;\n total?: number;\n pageSize?: number;\n defaultPageSize?: number;\n showSizeChanger?: boolean;\n pageSizeOptions?: string[];\n showQuickJumper?: boolean | { goButton?: React.ReactNode };\n showTotal?: (total: number, range: [number, number]) => React.ReactNode;\n onChange?: (page: number, pageSize?: number) => void;\n onShowSizeChange?: (current: number, size: number) => void;\n simple?: boolean;\n disabled?: boolean;\n hideOnSinglePage?: boolean;\n className?: string;\n style?: React.CSSProperties;\n size?: \"default\" | \"small\";\n responsive?: boolean;\n showLessItems?: boolean;\n itemRender?: (\n page: number,\n type: \"page\" | \"prev\" | \"next\" | \"jump-prev\" | \"jump-next\",\n originalElement: React.ReactNode\n ) => React.ReactNode;\n}\n\nconst Pagination: React.FC<PaginationProps> = ({\n current: controlledCurrent,\n defaultCurrent = 1,\n total = 0,\n pageSize: controlledPageSize,\n defaultPageSize = 10,\n showSizeChanger = false,\n pageSizeOptions = [\"10\", \"20\", \"50\", \"100\"],\n showQuickJumper = false,\n showTotal,\n onChange,\n onShowSizeChange,\n simple = false,\n disabled = false,\n hideOnSinglePage = false,\n className = \"\",\n style,\n size = \"default\",\n responsive = false,\n showLessItems = false,\n itemRender,\n}) => {\n const { primaryColor = \"#FB6011\" } = useTheme();\n const [internalCurrent, setInternalCurrent] = useState(defaultCurrent);\n const [internalPageSize, setInternalPageSize] = useState(defaultPageSize);\n const [jumpToPage, setJumpToPage] = useState(\"\");\n\n const current = controlledCurrent ?? internalCurrent;\n const pageSize = controlledPageSize ?? internalPageSize;\n\n const totalPages = useMemo(\n () => Math.ceil(total / pageSize),\n [total, pageSize]\n );\n\n useEffect(() => {\n if (controlledCurrent !== undefined) {\n setInternalCurrent(controlledCurrent);\n }\n }, [controlledCurrent]);\n\n useEffect(() => {\n if (controlledPageSize !== undefined) {\n setInternalPageSize(controlledPageSize);\n }\n }, [controlledPageSize]);\n\n const handlePageChange = (page: number) => {\n if (page < 1 || page > totalPages || page === current || disabled) return;\n\n if (controlledCurrent === undefined) {\n setInternalCurrent(page);\n }\n onChange?.(page, pageSize);\n };\n\n const handlePageSizeChange = (newPageSize: number) => {\n const newTotalPages = Math.ceil(total / newPageSize);\n const newCurrent = current > newTotalPages ? newTotalPages : current;\n\n if (controlledPageSize === undefined) {\n setInternalPageSize(newPageSize);\n }\n if (controlledCurrent === undefined) {\n setInternalCurrent(newCurrent);\n }\n\n onShowSizeChange?.(newCurrent, newPageSize);\n onChange?.(newCurrent, newPageSize);\n };\n\n const handleJumpTo = () => {\n const page = parseInt(jumpToPage, 10);\n if (page >= 1 && page <= totalPages) {\n handlePageChange(page);\n setJumpToPage(\"\");\n }\n };\n\n const getPageNumbers = (): (number | string)[] => {\n if (totalPages <= 7) {\n return Array.from({ length: totalPages }, (_, i) => i + 1);\n }\n\n const pages: (number | string)[] = [];\n\n if (current <= 4) {\n for (let i = 1; i <= 5; i++) {\n pages.push(i);\n }\n pages.push(\"jump-next\");\n pages.push(totalPages);\n } else if (current >= totalPages - 3) {\n pages.push(1);\n pages.push(\"jump-prev\");\n for (let i = totalPages - 4; i <= totalPages; i++) {\n pages.push(i);\n }\n } else {\n pages.push(1);\n pages.push(\"jump-prev\");\n for (let i = current - 1; i <= current + 1; i++) {\n pages.push(i);\n }\n pages.push(\"jump-next\");\n pages.push(totalPages);\n }\n\n return pages;\n };\n\n const renderItem = (item: number | string): React.ReactNode => {\n if (typeof item === \"number\") {\n const isActive = item === current;\n const element = (\n <Button\n key={item}\n onClick={() => handlePageChange(item)}\n disabled={disabled}\n type={isActive ? \"primary\" : \"default\"}\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n minWidth: size === \"small\" ? \"32px\" : \"36px\",\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n margin: 0,\n fontWeight: isActive ? 500 : 400,\n border: isActive ? `1px solid ${primaryColor}` : undefined,\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n {item}\n </Button>\n );\n\n return itemRender ? itemRender(item, \"page\", element) : element;\n }\n\n if (item === \"jump-prev\") {\n const element = (\n <Button\n key=\"jump-prev\"\n onClick={() => handlePageChange(Math.max(1, current - 5))}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n minWidth: size === \"small\" ? \"32px\" : \"36px\",\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n margin: 0,\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n •••\n </Button>\n );\n\n return itemRender\n ? itemRender(current - 5, \"jump-prev\", element)\n : element;\n }\n\n if (item === \"jump-next\") {\n const element = (\n <Button\n key=\"jump-next\"\n onClick={() => handlePageChange(Math.min(totalPages, current + 5))}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n minWidth: size === \"small\" ? \"32px\" : \"36px\",\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n margin: 0,\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n •••\n </Button>\n );\n\n return itemRender\n ? itemRender(current + 5, \"jump-next\", element)\n : element;\n }\n\n return null;\n };\n\n if (hideOnSinglePage && totalPages <= 1) {\n return null;\n }\n\n if (simple) {\n return (\n <div\n className={`aha-pagination aha-pagination-simple ${className}`}\n style={style}\n >\n <Button\n onClick={() => handlePageChange(current - 1)}\n disabled={disabled || current === 1}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n marginRight: \"8px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <LeftArrowIcon />\n </Button>\n <span\n style={{\n margin: \"0 8px\",\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {current} / {totalPages}\n </span>\n <Button\n onClick={() => handlePageChange(current + 1)}\n disabled={disabled || current === totalPages}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n marginLeft: \"8px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <RightArrowIcon />\n </Button>\n </div>\n );\n }\n\n const start = (current - 1) * pageSize + 1;\n const end = Math.min(current * pageSize, total);\n\n return (\n <div\n className={`aha-pagination w-full ${className}`}\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"space-between\",\n flexWrap: responsive ? \"wrap\" : \"nowrap\",\n fontFamily: \"DM Sans, sans-serif\",\n ...style,\n }}\n >\n {showTotal && (\n <div className=\"justify-start text-Text-text-secondary text-sm font-medium font-['DM_Sans'] leading-5\">\n {showTotal(total, [start, end])}\n </div>\n )}\n\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n gap: \"12px\",\n }}\n >\n {total > 0 && (\n <>\n {itemRender ? (\n itemRender(\n current - 1,\n \"prev\",\n <Button\n onClick={() => handlePageChange(current - 1)}\n disabled={disabled || current === 1}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <LeftArrowIcon />\n </Button>\n )\n ) : (\n <Button\n onClick={() => handlePageChange(current - 1)}\n disabled={disabled || current === 1}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <LeftArrowIcon />\n </Button>\n )}\n </>\n )}\n\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\n {getPageNumbers().map((item) => renderItem(item))}\n </div>\n\n {total > 0 && (\n <>\n {itemRender ? (\n itemRender(\n current + 1,\n \"next\",\n <Button\n onClick={() => handlePageChange(current + 1)}\n disabled={disabled || current === totalPages}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <RightArrowIcon />\n </Button>\n )\n ) : (\n <Button\n onClick={() => handlePageChange(current + 1)}\n disabled={disabled || current === totalPages}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n height: size === \"small\" ? \"32px\" : \"36px\",\n padding: \"0 12px\",\n gap: \"4px\",\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n <RightArrowIcon />\n </Button>\n )}\n </>\n )}\n\n {showSizeChanger && (\n <Select\n value={pageSize}\n options={pageSizeOptions.map((s) => ({\n label: `${s} / page`,\n value: Number(s),\n }))}\n onChange={(val) => handlePageSizeChange(Number(val))}\n disabled={disabled}\n size={size === \"small\" ? \"small\" : \"medium\"}\n style={{ minWidth: size === \"small\" ? 80 : 96 }}\n />\n )}\n\n {showQuickJumper && (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n gap: \"8px\",\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n <span\n style={{\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n }}\n >\n Go to\n </span>\n <Input\n type=\"number\"\n min={1}\n value={jumpToPage}\n onChange={(e) => setJumpToPage(e.target.value)}\n onPressEnter={handleJumpTo}\n disabled={disabled}\n size={size === \"small\" ? \"small\" : \"medium\"}\n style={{ width: 56, minWidth: 56 }}\n />\n <span\n style={{\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n }}\n >\n page\n </span>\n {typeof showQuickJumper === \"object\" && showQuickJumper.goButton ? (\n <Button\n onClick={handleJumpTo}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n {showQuickJumper.goButton}\n </Button>\n ) : (\n <Button\n onClick={handleJumpTo}\n disabled={disabled}\n type=\"default\"\n size={size === \"default\" ? \"medium\" : \"small\"}\n style={{\n border: \"1px solid #EAECF0\",\n boxShadow: \"none\",\n borderRadius: \"8px\",\n }}\n >\n OK\n </Button>\n )}\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport default Pagination;\n","import React, { useState } from 'react';\n\nexport interface CheckboxProps {\n checked?: boolean;\n indeterminate?: boolean;\n disabled?: boolean;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n className?: string;\n style?: React.CSSProperties;\n children?: React.ReactNode;\n /** sm = 16px, md = 20px */\n size?: 'sm' | 'md';\n /** Secondary description rendered below the label */\n hint?: React.ReactNode;\n /** Force focused appearance (useful for Storybook demos) */\n isFocused?: boolean;\n}\n\nconst Checkbox: React.FC<CheckboxProps> = ({\n checked = false,\n indeterminate = false,\n disabled = false,\n onChange,\n className = '',\n style,\n children,\n size = 'sm',\n hint,\n isFocused: isFocusedProp,\n}) => {\n const [hovered, setHovered] = useState(false);\n const [focused, setFocused] = useState(false);\n\n const isActive = checked || indeterminate;\n const showFocus = isFocusedProp ?? focused;\n\n const handleClick = () => {\n if (disabled) return;\n const syntheticEvent = {\n target: { checked: !checked },\n currentTarget: { checked: !checked },\n } as React.ChangeEvent<HTMLInputElement>;\n onChange?.(syntheticEvent);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (e.key === ' ' || e.key === 'Enter') {\n e.preventDefault();\n handleClick();\n }\n };\n\n const boxSize = size === 'sm' ? '16px' : '20px';\n const iconSize = size === 'sm' ? '12px' : '14px';\n const borderRadius = size === 'sm' ? 'var(--radius-xs, 4px)' : 'var(--radius-sm, 6px)';\n const fontSize = size === 'sm' ? 'var(--font-size-text-sm, 14px)' : 'var(--font-size-text-md, 16px)';\n const lineHeight = size === 'sm' ? 'var(--line-height-text-sm, 20px)' : 'var(--line-height-text-md, 24px)';\n const gap = size === 'sm' ? 'var(--spacing-md, 8px)' : 'var(--spacing-lg, 12px)';\n\n const getBoxBg = () => {\n if (disabled) return 'var(--color-bg-disabled_subtle, #fafaf9)';\n if (isActive) return hovered ? 'var(--color-bg-brand-solid_hover, #ec470a)' : 'var(--color-bg-brand-solid, #fb6011)';\n return hovered ? 'var(--color-bg-primary_hover, #fafaf9)' : 'var(--color-bg-primary, #ffffff)';\n };\n\n const getBoxBorder = () => {\n if (disabled) return '1px solid var(--color-border-disabled, #d7d3d0)';\n if (isActive) return hovered ? '1px solid var(--color-bg-brand-solid_hover, #ec470a)' : '1px solid var(--color-bg-brand-solid, #fb6011)';\n return '1px solid var(--color-border-primary, #d7d3d0)';\n };\n\n // Disabled active: use muted icon so it's visible on the light bg\n const iconColor = disabled && isActive\n ? 'var(--color-fg-disabled_subtle, #d7d3d0)'\n : 'var(--color-fg-white, #ffffff)';\n\n const hasLabel = children || hint;\n\n return (\n <div\n className={`aha-checkbox ${className}`}\n role=\"checkbox\"\n aria-checked={indeterminate ? 'mixed' : checked}\n aria-disabled={disabled}\n tabIndex={disabled ? -1 : 0}\n style={{\n display: 'inline-flex',\n alignItems: 'flex-start',\n gap,\n cursor: disabled ? 'not-allowed' : 'pointer',\n outline: 'none',\n ...style,\n }}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n onMouseEnter={() => !disabled && setHovered(true)}\n onMouseLeave={() => setHovered(false)}\n onFocus={() => !disabled && setFocused(true)}\n onBlur={() => setFocused(false)}\n >\n {/* Checkbox box */}\n <div\n style={{\n position: 'relative',\n width: boxSize,\n height: boxSize,\n minWidth: boxSize,\n minHeight: boxSize,\n flexShrink: 0,\n borderRadius,\n border: getBoxBorder(),\n backgroundColor: getBoxBg(),\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n transition: 'background-color 0.15s, border-color 0.15s, box-shadow 0.15s',\n boxSizing: 'border-box',\n boxShadow: showFocus ? 'var(--focus-ring, 0px 0px 0px 2px #ffffff, 0px 0px 0px 4px #fb6011)' : 'none',\n marginTop: hasLabel ? '2px' : '0',\n }}\n >\n {/* Indeterminate dash */}\n <svg\n aria-hidden=\"true\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n style={{\n position: 'absolute',\n width: iconSize,\n height: iconSize,\n color: iconColor,\n opacity: indeterminate ? 1 : 0,\n transition: 'opacity 0.15s',\n pointerEvents: 'none',\n }}\n >\n <path d=\"M2.91675 7H11.0834\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n\n {/* Check mark */}\n <svg\n aria-hidden=\"true\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n style={{\n position: 'absolute',\n width: iconSize,\n height: iconSize,\n color: iconColor,\n opacity: checked && !indeterminate ? 1 : 0,\n transition: 'opacity 0.15s',\n pointerEvents: 'none',\n }}\n >\n <path d=\"M11.6666 3.5L5.24992 9.91667L2.33325 7\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n </div>\n\n {/* Label + hint */}\n {hasLabel && (\n <div style={{ display: 'inline-flex', flexDirection: 'column', gap: size === 'md' ? 'var(--spacing-xxs, 2px)' : '0' }}>\n {children && (\n <span\n style={{\n fontSize,\n lineHeight,\n fontWeight: 'var(--font-weight-medium, 500)' as React.CSSProperties['fontWeight'],\n fontFamily: 'var(--font-family-body, \"DM Sans\", sans-serif)',\n color: disabled ? 'var(--color-text-disabled, #79716b)' : 'var(--color-text-secondary, #44403c)',\n userSelect: 'none',\n }}\n >\n {children}\n </span>\n )}\n {hint && (\n <span\n style={{\n fontSize,\n lineHeight,\n fontWeight: 'var(--font-weight-regular, 400)' as React.CSSProperties['fontWeight'],\n fontFamily: 'var(--font-family-body, \"DM Sans\", sans-serif)',\n color: 'var(--color-text-tertiary, #57534e)',\n }}\n onClick={(e) => e.stopPropagation()}\n >\n {hint}\n </span>\n )}\n </div>\n )}\n </div>\n );\n};\n\nCheckbox.displayName = 'Checkbox';\n\nexport default Checkbox;\n","import React, { useState, useMemo, useCallback, useRef, useEffect } from 'react';\nimport Pagination from '../Pagination';\nimport Checkbox from '../Checkbox';\nimport { SortIcon, SortDescIcon, SortAscIcon } from '../../icons';\nimport { useTheme } from '../../theme/ThemeContext';\n\n// ==================== Loading 遮罩 ====================\n\nconst TableLoadingSpinner: React.FC<{ color: string }> = ({ color }) => (\n <>\n <style>{`\n @keyframes aha-table-loading-spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n `}</style>\n <svg\n width={32}\n height={32}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n aria-hidden\n style={{ animation: 'aha-table-loading-spin 1s linear infinite' }}\n >\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke={color}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"24\"\n opacity={0.3}\n />\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke={color}\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"16\"\n />\n </svg>\n </>\n);\n\nconst TableLoadingOverlay: React.FC<{\n loading: boolean | React.ReactNode;\n spinColor: string;\n}> = ({ loading, spinColor }) => {\n if (!loading) return null;\n const content = loading === true ? <TableLoadingSpinner color={spinColor} /> : loading;\n return (\n <div\n role=\"status\"\n aria-live=\"polite\"\n aria-label=\"Loading\"\n className=\"aha-table-loading-overlay\"\n style={{\n position: 'absolute',\n inset: 0,\n zIndex: 50,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: 'rgba(255, 255, 255, 0.55)',\n pointerEvents: 'auto',\n }}\n >\n {content}\n </div>\n );\n};\n\n// ==================== 类型定义 ====================\n\nexport type SortOrder = 'ascend' | 'descend' | null;\nexport type TableSize = 'small' | 'middle' | 'large';\nexport type TableLayout = 'auto' | 'fixed';\n\nexport interface SorterResult<T = any> {\n column?: ColumnType<T>;\n order?: SortOrder;\n field?: string | string[];\n columnKey?: string | string[];\n}\n\nexport interface TableCurrentDataSource<T = any> {\n currentDataSource: T[];\n action: 'paginate' | 'sort';\n}\n\nexport interface SelectionItem {\n key: string | number;\n text: React.ReactNode;\n onSelect?: (changeableRowKeys: (string | number)[]) => void;\n}\n\nexport interface TableRowSelection<T = any> {\n type?: 'checkbox' | 'radio';\n selectedRowKeys?: (string | number)[];\n defaultSelectedRowKeys?: (string | number)[];\n onChange?: (selectedRowKeys: (string | number)[], selectedRows: T[]) => void;\n onSelect?: (record: T, selected: boolean, selectedRows: T[], nativeEvent: Event) => void;\n onSelectAll?: (selected: boolean, selectedRows: T[], changeRows: T[]) => void;\n onSelectInvert?: (selectedRowKeys: (string | number)[]) => void;\n onSelectNone?: () => void;\n getCheckboxProps?: (record: T) => {\n disabled?: boolean;\n name?: string;\n };\n hideSelectAll?: boolean;\n fixed?: boolean | 'left' | 'right';\n columnWidth?: string | number;\n columnTitle?: string | React.ReactNode;\n checkStrictly?: boolean;\n preserveSelectedRowKeys?: boolean;\n renderCell?: (checked: boolean, record: T, index: number, node: React.ReactNode) => React.ReactNode;\n}\n\nexport interface ColumnType<T = any> {\n title?: React.ReactNode | ((props: { sortOrder?: SortOrder; sortColumn?: ColumnType<T> }) => React.ReactNode);\n key?: string;\n dataIndex?: string | string[];\n align?: 'left' | 'right' | 'center';\n ellipsis?: boolean | { showTitle?: boolean };\n colSpan?: number;\n width?: string | number;\n minWidth?: string | number;\n fixed?: boolean | 'left' | 'right';\n render?: (value: any, record: T, index: number) => React.ReactNode;\n sorter?: boolean | ((a: T, b: T) => number) | { compare?: (a: T, b: T) => number; multiple?: number };\n sortOrder?: SortOrder | SortOrder[];\n defaultSortOrder?: SortOrder;\n onCell?: (record: T, index?: number) => React.HTMLAttributes<HTMLTableCellElement>;\n onHeaderCell?: (column: ColumnType<T>) => React.HTMLAttributes<HTMLTableCellElement>;\n className?: string;\n children?: ColumnType<T>[];\n onSorterChange?: (sorter: SorterResult<T>) => void;\n rowSpan?: number;\n rowScope?: 'row' | 'col' | 'rowgroup' | 'colgroup';\n}\n\nexport interface TableProps<T = any> {\n columns?: ColumnType<T>[];\n dataSource?: T[];\n rowKey?: string | ((record: T) => string | number);\n rowSelection?: TableRowSelection<T>;\n pagination?: false | {\n current?: number;\n pageSize?: number;\n total?: number;\n defaultCurrent?: number;\n defaultPageSize?: number;\n showSizeChanger?: boolean;\n pageSizeOptions?: string[];\n showQuickJumper?: boolean | { goButton?: React.ReactNode };\n showTotal?: (total: number, range: [number, number]) => React.ReactNode;\n onChange?: (page: number, pageSize?: number) => void;\n onShowSizeChange?: (current: number, size: number) => void;\n position?: 'topLeft' | 'topCenter' | 'topRight' | 'bottomLeft' | 'bottomCenter' | 'bottomRight';\n simple?: boolean;\n responsive?: boolean;\n };\n size?: TableSize;\n bordered?: boolean;\n loading?: boolean | React.ReactNode;\n locale?: {\n emptyText?: React.ReactNode | (() => React.ReactNode);\n selectAll?: React.ReactNode;\n selectInvert?: React.ReactNode;\n selectNone?: React.ReactNode;\n selectionAll?: React.ReactNode;\n sortTitle?: string;\n expand?: string;\n collapse?: string;\n triggerDesc?: string;\n triggerAsc?: string;\n cancelSort?: string;\n };\n showHeader?: boolean;\n title?: (currentData: T[]) => React.ReactNode;\n footer?: (currentData: T[]) => React.ReactNode;\n summary?: (currentData: T[]) => React.ReactNode;\n scroll?: {\n x?: number | string | true;\n y?: number | string;\n scrollToFirstRowOnChange?: boolean;\n };\n tableLayout?: TableLayout;\n onChange?: (pagination: any, filters: Record<string, any>, sorter: SorterResult<T> | SorterResult<T>[], extra: TableCurrentDataSource<T>) => void;\n onSorterChange?: (sorter: SorterResult<T> | SorterResult<T>[]) => void;\n onPaginationChange?: (page: number, pageSize: number) => void;\n onRow?: (record: T, index?: number) => React.HTMLAttributes<HTMLTableRowElement>;\n getPopupContainer?: (triggerNode: HTMLElement) => HTMLElement;\n className?: string;\n innerClassName?: string;\n style?: React.CSSProperties;\n children?: React.ReactNode;\n expandable?: {\n expandedRowKeys?: (string | number)[];\n defaultExpandedRowKeys?: (string | number)[];\n expandedRowRender?: (record: T, index: number, indent: number, expanded: boolean) => React.ReactNode;\n expandRowByClick?: boolean;\n onExpand?: (expanded: boolean, record: T) => void;\n onExpandedRowsChange?: (expandedKeys: (string | number)[]) => void;\n defaultExpandAllRows?: boolean;\n indentSize?: number;\n expandIcon?: (props: { expanded: boolean; onExpand: (record: T, e: React.MouseEvent<HTMLElement>) => void; record: T }) => React.ReactNode;\n rowExpandable?: (record: T) => boolean;\n };\n indentSize?: number;\n rowClassName?: string | ((record: T, index: number) => string);\n onHeaderRow?: (columns: ColumnType<T>[], index?: number) => React.HTMLAttributes<HTMLTableRowElement>;\n components?: {\n header?: {\n cell?: React.ComponentType<any>;\n row?: React.ComponentType<any>;\n wrapper?: React.ComponentType<any>;\n };\n body?: {\n cell?: React.ComponentType<any>;\n row?: React.ComponentType<any>;\n wrapper?: React.ComponentType<any>;\n };\n };\n sticky?: boolean | { offsetHeader?: number; offsetScroll?: number; getContainer?: () => HTMLElement };\n}\n\n// ==================== 工具函数 ====================\n\nconst getValue = (obj: any, path: string | string[]): any => {\n if (typeof path === 'string') {\n return obj?.[path];\n }\n return path.reduce((acc, key) => acc?.[key], obj);\n};\n\nconst getRowKey = <T,>(record: T, rowKey?: string | ((record: T) => string | number)): string | number => {\n if (typeof rowKey === 'function') {\n return rowKey(record);\n }\n if (typeof rowKey === 'string') {\n return getValue(record, rowKey) ?? '';\n }\n return (record as any).key ?? '';\n};\n\n// ==================== 默认图标 ====================\n\nconst SortIconComponent: React.FC<{ order?: SortOrder }> = ({ order }) => {\n const { primaryColor } = useTheme();\n \n if (order === 'ascend') {\n return (\n <SortAscIcon style={{ color: primaryColor }}/>\n );\n }\n if (order === 'descend') {\n return (\n <SortDescIcon style={{ color: primaryColor }}/>\n );\n }\n return (\n <SortIcon/>\n );\n};\n\n\n\n// ==================== Table 组件 ====================\n\nconst Table = <T extends Record<string, any> = any>({\n columns = [],\n dataSource = [],\n rowKey = 'key',\n rowSelection,\n pagination = false,\n size = 'middle',\n bordered = false,\n loading = false,\n locale,\n showHeader = true,\n title,\n footer,\n summary,\n scroll,\n tableLayout = 'auto',\n onChange,\n onSorterChange,\n onPaginationChange,\n onRow,\n className = '',\n innerClassName = '',\n style,\n expandable,\n rowClassName,\n onHeaderRow,\n sticky,\n ...rest\n}: TableProps<T>) => {\n const { primaryColor } = useTheme();\n const loadingSpinColor = primaryColor || '#FB6011';\n\n // ==================== State ====================\n const [selectedRowKeys, setSelectedRowKeys] = useState<(string | number)[]>(\n rowSelection?.selectedRowKeys || rowSelection?.defaultSelectedRowKeys || []\n );\n\n // 同步外部传入的 selectedRowKeys\n useEffect(() => {\n if (rowSelection?.selectedRowKeys !== undefined) {\n setSelectedRowKeys(rowSelection.selectedRowKeys);\n }\n }, [rowSelection?.selectedRowKeys]);\n const [sorters, setSorters] = useState<Map<string, SortOrder>>(new Map());\n const [expandedRowKeys, setExpandedRowKeys] = useState<(string | number)[]>(\n expandable?.defaultExpandedRowKeys || []\n );\n const [currentPage, setCurrentPage] = useState(\n pagination && typeof pagination === 'object' \n ? (pagination.current || pagination.defaultCurrent || 1) \n : 1\n );\n const [pageSize, setPageSize] = useState(\n pagination && typeof pagination === 'object' \n ? (pagination.pageSize || pagination.defaultPageSize || 10) \n : 10\n );\n\n // 同步外部传入的 pagination\n useEffect(() => {\n if (pagination && typeof pagination === 'object') {\n if (pagination.current !== undefined) {\n setCurrentPage(pagination.current);\n }\n if (pagination.pageSize !== undefined) {\n setPageSize(pagination.pageSize);\n }\n }\n }, [pagination]);\n const [draggedRowIndex, setDraggedRowIndex] = useState<number | null>(null);\n const [dragOverRowIndex, setDragOverRowIndex] = useState<number | null>(null);\n const [isMobile, setIsMobile] = useState(false);\n const tableRef = useRef<HTMLDivElement>(null);\n const headerRef = useRef<HTMLTableSectionElement>(null);\n\n // 检测移动端\n useEffect(() => {\n const checkMobile = () => {\n setIsMobile(window.innerWidth < 768);\n };\n checkMobile();\n window.addEventListener('resize', checkMobile);\n return () => window.removeEventListener('resize', checkMobile);\n }, []);\n\n // ==================== 处理行选择 ====================\n const handleSelect = useCallback((record: T, selected: boolean) => {\n // 检查是否禁用\n const checkboxProps = rowSelection?.getCheckboxProps?.(record);\n if (checkboxProps?.disabled) {\n return;\n }\n\n const key = getRowKey(record, rowKey);\n let newSelectedRowKeys: (string | number)[];\n \n if (rowSelection?.type === 'radio') {\n newSelectedRowKeys = selected ? [key] : [];\n } else {\n if (selected) {\n newSelectedRowKeys = [...selectedRowKeys, key];\n } else {\n newSelectedRowKeys = selectedRowKeys.filter(k => k !== key);\n }\n }\n\n setSelectedRowKeys(newSelectedRowKeys);\n \n const selectedRows = dataSource.filter(d => newSelectedRowKeys.includes(getRowKey(d, rowKey)));\n \n rowSelection?.onChange?.(newSelectedRowKeys, selectedRows);\n rowSelection?.onSelect?.(record, selected, selectedRows, new Event('select'));\n }, [selectedRowKeys, rowKey, rowSelection, dataSource]);\n\n const handleSelectAll = useCallback((selected: boolean, currentPageData: T[]) => {\n // 只选择未禁用的行\n const keys = currentPageData\n .filter(d => !rowSelection?.getCheckboxProps?.(d).disabled)\n .map(d => getRowKey(d, rowKey));\n const newSelectedRowKeys = selected ? keys : [];\n \n setSelectedRowKeys(newSelectedRowKeys);\n \n const selectedRows = dataSource.filter(d => newSelectedRowKeys.includes(getRowKey(d, rowKey)));\n const changeRows = selected ? currentPageData.filter(d => !rowSelection?.getCheckboxProps?.(d).disabled) : [];\n \n rowSelection?.onChange?.(newSelectedRowKeys, selectedRows);\n rowSelection?.onSelectAll?.(selected, selectedRows, changeRows);\n }, [rowKey, rowSelection, dataSource]);\n\n // ==================== 处理排序 ====================\n const handleSort = useCallback((column: ColumnType<T>, order: SortOrder) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex);\n if (!columnKey) return;\n\n const newSorters = new Map(sorters);\n \n if (order === null) {\n newSorters.delete(columnKey as string);\n } else {\n newSorters.set(columnKey as string, order);\n }\n\n setSorters(newSorters);\n \n // 构建排序结果数组\n const sorterArray: SorterResult<T>[] = Array.from(newSorters.entries()).map(([key, order]) => {\n const col = columns.find(c => {\n const cKey = c.key || (Array.isArray(c.dataIndex) ? c.dataIndex.join('.') : c.dataIndex);\n return cKey === key;\n });\n return {\n column: col || column,\n order: order!,\n field: key,\n columnKey: key,\n };\n });\n \n // 当前列的排序结果\n const currentSorter: SorterResult<T> = {\n column,\n order: order!,\n field: columnKey as string,\n columnKey: columnKey as string,\n };\n \n // 调用列的 onSorterChange 回调(单个列的排序变化)\n if (column.onSorterChange) {\n column.onSorterChange(currentSorter);\n }\n \n // 调用 Table 的 onSorterChange 回调(所有列的排序变化)\n if (onSorterChange) {\n onSorterChange(sorterArray.length === 1 ? sorterArray[0] : sorterArray);\n }\n \n // 触发 onChange(综合回调,包含分页、筛选、排序)\n if (onChange) {\n onChange(\n { current: currentPage, pageSize },\n {},\n sorterArray.length === 1 ? sorterArray[0] : sorterArray,\n { currentDataSource: dataSource, action: 'sort' }\n );\n }\n }, [sorters, onChange, onSorterChange, currentPage, pageSize, dataSource, columns]);\n\n // ==================== 处理展开 ====================\n const handleExpand = useCallback((record: T, expanded: boolean) => {\n const key = getRowKey(record, rowKey);\n let newExpandedRowKeys: (string | number)[];\n \n if (expanded) {\n newExpandedRowKeys = [...expandedRowKeys, key];\n } else {\n newExpandedRowKeys = expandedRowKeys.filter(k => k !== key);\n }\n \n setExpandedRowKeys(newExpandedRowKeys);\n expandable?.onExpand?.(expanded, record);\n expandable?.onExpandedRowsChange?.(newExpandedRowKeys);\n }, [expandedRowKeys, rowKey, expandable]);\n\n // ==================== 数据处理 ====================\n const getProcessedData = useCallback((): T[] => {\n let processed = [...dataSource];\n\n // 排序\n if (sorters.size > 0) {\n processed.sort((a, b) => {\n const sorterEntries = Array.from(sorters.entries());\n for (const [columnKey, order] of sorterEntries) {\n const column = columns.find(col => {\n const colKey = col.key || (Array.isArray(col.dataIndex) ? col.dataIndex.join('.') : col.dataIndex);\n return colKey === columnKey;\n });\n \n if (!column) continue;\n \n let compareResult = 0;\n \n if (typeof column.sorter === 'function') {\n compareResult = column.sorter(a, b);\n } else if (column.sorter === true) {\n const aVal = getValue(a, column.dataIndex || columnKey);\n const bVal = getValue(b, column.dataIndex || columnKey);\n if (aVal < bVal) compareResult = -1;\n else if (aVal > bVal) compareResult = 1;\n }\n \n if (compareResult !== 0) {\n return order === 'ascend' ? compareResult : -compareResult;\n }\n }\n return 0;\n });\n }\n\n return processed;\n }, [dataSource, sorters, columns]);\n\n const processedData = getProcessedData();\n\n // ==================== 分页处理 ====================\n // 当传入 pagination.total 时视为服务端分页:dataSource 已是当前页数据,不再做客户端 slice\n const isServerPagination = Boolean(pagination && typeof pagination === 'object' && pagination.total !== undefined);\n const paginatedData = useMemo(() => {\n if (pagination === false || !pagination) return processedData;\n if (isServerPagination) return processedData;\n const start = (currentPage - 1) * pageSize;\n const end = start + pageSize;\n return processedData.slice(start, end);\n }, [processedData, currentPage, pageSize, pagination, isServerPagination]);\n\n const handlePageChange = useCallback((page: number, size?: number) => {\n const newPageSize = size ?? pageSize;\n setCurrentPage(page);\n if (size) setPageSize(size);\n \n // 调用 Table 的 onPaginationChange 回调(专门用于分页变化)\n if (onPaginationChange) {\n onPaginationChange(page, newPageSize);\n }\n \n // 调用 pagination 内部的回调(保持向后兼容)\n if (pagination && typeof pagination === 'object') {\n pagination.onChange?.(page, size);\n if (size) pagination.onShowSizeChange?.(page, size);\n }\n \n // 触发 Table 的 onChange(综合回调,包含分页、筛选、排序)\n if (onChange) {\n const sorterArray: SorterResult<T>[] = Array.from(sorters.entries()).map(([key, order]) => {\n const col = columns.find(c => {\n const cKey = c.key || (Array.isArray(c.dataIndex) ? c.dataIndex.join('.') : c.dataIndex);\n return cKey === key;\n });\n return {\n column: col,\n order: order!,\n field: key,\n columnKey: key,\n };\n });\n \n onChange(\n { current: page, pageSize: newPageSize },\n {},\n sorterArray.length === 1 ? sorterArray[0] : sorterArray,\n { currentDataSource: processedData, action: 'paginate' }\n );\n }\n }, [pagination, onPaginationChange, onChange, pageSize, sorters, columns, processedData]);\n\n // ==================== 渲染单元格 ====================\n const renderCell = useCallback((column: ColumnType<T>, record: T, index: number): React.ReactNode => {\n const value = getValue(record, column.dataIndex || '');\n \n if (column.render) {\n return column.render(value, record, index);\n }\n \n return value;\n }, []);\n\n // ==================== 计算固定列的偏移量 ====================\n const getFixedOffset = useCallback((columnIndex: number, fixed: 'left' | 'right' | boolean | undefined, isHeader: boolean = false) => {\n if (!fixed) return undefined;\n \n const fixedDirection = fixed === true ? 'left' : fixed;\n let offset = 0;\n \n if (fixedDirection === 'left') {\n // 计算左侧固定列的偏移量\n // 如果有行选择且固定在左侧,先加上选择列的宽度\n if (rowSelection && (rowSelection.fixed === 'left' || rowSelection.fixed === true)) {\n const selectWidth = typeof rowSelection.columnWidth === 'number' \n ? rowSelection.columnWidth \n : (typeof rowSelection.columnWidth === 'string' ? parseInt(rowSelection.columnWidth) : 60);\n offset += selectWidth;\n }\n // 然后加上前面所有左侧固定列的宽度\n for (let i = 0; i < columnIndex; i++) {\n const col = columns[i];\n if (col.fixed === 'left' || col.fixed === true) {\n const colWidth = col.width \n ? (typeof col.width === 'number' ? col.width : parseInt(col.width as string) || 0)\n : 150; // 默认宽度\n offset += colWidth;\n }\n }\n return offset;\n } else if (fixedDirection === 'right') {\n // 计算右侧固定列的偏移量\n for (let i = columnIndex + 1; i < columns.length; i++) {\n const col = columns[i];\n if (col.fixed === 'right') {\n const colWidth = col.width \n ? (typeof col.width === 'number' ? col.width : parseInt(col.width as string) || 0)\n : 150; // 默认宽度\n offset += colWidth;\n }\n }\n // 如果有行选择且固定在右侧,需要加上选择列的宽度\n if (rowSelection && rowSelection.fixed === 'right') {\n const selectWidth = typeof rowSelection.columnWidth === 'number' \n ? rowSelection.columnWidth \n : (typeof rowSelection.columnWidth === 'string' ? parseInt(rowSelection.columnWidth) : 60);\n offset += selectWidth;\n }\n return offset;\n }\n \n return undefined;\n }, [columns, rowSelection]);\n\n // ==================== 渲染表头 ====================\n const renderHeader = useCallback(() => {\n if (!showHeader) return null;\n\n const headerColumns = columns.map((column, colIndex) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex) || colIndex;\n const sortOrder = sorters.get(columnKey as string) || null;\n const fixedOffset = getFixedOffset(colIndex, column.fixed, true);\n const columnWidth = column.width \n ? (typeof column.width === 'number' ? `${column.width}px` : column.width)\n : undefined;\n\n return (\n <th\n key={columnKey}\n className={`${column.className || ''} ${column.align ? `text-${column.align}` : ''}`}\n style={{\n width: columnWidth,\n minWidth: column.minWidth ? (typeof column.minWidth === 'number' ? `${column.minWidth}px` : column.minWidth) : (columnWidth || undefined),\n maxWidth: columnWidth,\n position: column.fixed ? 'sticky' : 'relative',\n left: column.fixed === 'left' || column.fixed === true ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n right: column.fixed === 'right' ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n zIndex: column.fixed ? (column.fixed === 'left' || column.fixed === true ? 10 : 9) : 1,\n backgroundColor: column.fixed ? '#F9FAFB' : '#F9FAFB',\n boxShadow: column.fixed === 'left' || column.fixed === true \n ? '2px 0 4px rgba(0, 0, 0, 0.05)' \n : column.fixed === 'right' \n ? '-2px 0 4px rgba(0, 0, 0, 0.05)' \n : undefined,\n padding: '12px 16px',\n textAlign: column.align || 'left',\n borderBottom: '1px solid #EAECF0',\n fontWeight: 600,\n fontSize: '12px',\n lineHeight: '18px',\n color: '#475467',\n fontFamily: 'DM Sans, sans-serif',\n }}\n {...(column.onHeaderCell?.(column) || {})}\n >\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n justifyContent: column.align === 'right' ? 'flex-end' : column.align === 'center' ? 'center' : 'flex-start',\n }}\n >\n <span style={{ fontWeight: 600, fontSize: '12px', lineHeight: '18px', color: '#475467' }}>\n {typeof column.title === 'function' ? column.title({ sortOrder, sortColumn: column }) : column.title}\n </span>\n {column.sorter && (\n <button\n onClick={() => {\n const nextOrder = sortOrder === null ? 'ascend' : sortOrder === 'ascend' ? 'descend' : null;\n handleSort(column, nextOrder);\n }}\n style={{\n border: 'none',\n background: 'none',\n cursor: 'pointer',\n display: 'flex',\n alignItems: 'center',\n padding: '2px',\n color: sortOrder ? '#475467' : '#98A2B3',\n }}\n >\n <SortIconComponent order={sortOrder || undefined} />\n </button>\n )}\n </div>\n </th>\n );\n });\n\n // 如果有行选择,添加选择列\n if (rowSelection) {\n const selectWidth = typeof rowSelection.columnWidth === 'number' \n ? `${rowSelection.columnWidth}px` \n : (typeof rowSelection.columnWidth === 'string' ? rowSelection.columnWidth : '60px');\n const selectColumn = (\n <th\n key=\"selection\"\n style={{\n width: selectWidth,\n position: rowSelection.fixed ? 'sticky' : 'relative',\n left: rowSelection.fixed === 'left' || rowSelection.fixed === true ? '0px' : undefined,\n right: rowSelection.fixed === 'right' ? '0px' : undefined,\n zIndex: rowSelection.fixed ? (rowSelection.fixed === 'left' || rowSelection.fixed === true ? 12 : 11) : 1,\n backgroundColor: '#F9FAFB',\n padding: '12px 16px',\n borderBottom: '1px solid #EAECF0',\n fontWeight: 600,\n fontSize: '12px',\n lineHeight: '18px',\n color: '#475467',\n fontFamily: 'DM Sans, sans-serif',\n textAlign: 'center',\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n {!rowSelection.hideSelectAll && rowSelection.type !== 'radio' && (() => {\n const enabledRows = paginatedData.filter(d => !rowSelection.getCheckboxProps?.(d).disabled);\n const enabledKeys = enabledRows.map(d => getRowKey(d, rowKey));\n const allSelected = enabledRows.length > 0 && enabledKeys.every(key => selectedRowKeys.includes(key));\n const someSelected = enabledKeys.some(key => selectedRowKeys.includes(key));\n \n return (\n <Checkbox\n checked={allSelected}\n indeterminate={someSelected && !allSelected}\n onChange={(e) => handleSelectAll(e.target.checked, paginatedData)}\n />\n );\n })()}\n {rowSelection.columnTitle && <span style={{ marginLeft: rowSelection.hideSelectAll ? 0 : '8px' }}>{rowSelection.columnTitle}</span>}\n </div>\n </th>\n );\n headerColumns.unshift(selectColumn);\n }\n\n const headerRowProps = onHeaderRow?.(columns, 0);\n \n return (\n <thead ref={headerRef}>\n <tr {...(headerRowProps || {})}>{headerColumns}</tr>\n </thead>\n );\n }, [columns, showHeader, sorters, rowSelection, selectedRowKeys, paginatedData, rowKey, handleSort, handleSelectAll, locale, onHeaderRow, getFixedOffset]);\n\n // ==================== 拖拽排序处理 ====================\n const handleDragStart = useCallback((index: number) => {\n setDraggedRowIndex(index);\n }, []);\n\n const handleDragOver = useCallback((e: React.DragEvent, index: number) => {\n e.preventDefault();\n setDragOverRowIndex(index);\n }, []);\n\n const handleDrop = useCallback((e: React.DragEvent, dropIndex: number) => {\n e.preventDefault();\n if (draggedRowIndex === null || draggedRowIndex === dropIndex) {\n setDraggedRowIndex(null);\n setDragOverRowIndex(null);\n return;\n }\n\n const newData = [...paginatedData];\n const draggedItem = newData[draggedRowIndex];\n newData.splice(draggedRowIndex, 1);\n newData.splice(dropIndex, 0, draggedItem);\n\n // 这里可以触发 onChange 回调,让外部处理数据更新\n setDraggedRowIndex(null);\n setDragOverRowIndex(null);\n }, [draggedRowIndex, paginatedData]);\n\n const handleDragEnd = useCallback(() => {\n setDraggedRowIndex(null);\n setDragOverRowIndex(null);\n }, []);\n\n // ==================== 渲染空状态 ====================\n const renderEmpty = useCallback(() => {\n const emptyText = locale?.emptyText;\n const content =\n typeof emptyText === 'function'\n ? emptyText()\n : emptyText !== undefined\n ? emptyText\n : 'No data';\n const colSpan = columns.length + (rowSelection ? 1 : 0);\n return (\n <tr className=\"aha-table-placeholder\">\n <td colSpan={colSpan} style={{\n padding: '48px 16px',\n textAlign: 'center',\n color: '#98A2B3',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: 'DM Sans, sans-serif',\n borderBottom: 'none',\n backgroundColor: 'white',\n }}>\n {content}\n </td>\n </tr>\n );\n }, [locale?.emptyText, columns.length, rowSelection]);\n\n // ==================== 渲染表格行 ====================\n const renderRows = useCallback(() => {\n if (paginatedData.length === 0) {\n return renderEmpty();\n }\n return paginatedData.map((record, index) => {\n const key = getRowKey(record, rowKey);\n const isSelected = selectedRowKeys.includes(key);\n const isExpanded = expandedRowKeys.includes(key);\n const rowProps = onRow?.(record, index) || {};\n const isLastRow = index === paginatedData.length - 1;\n\n return (\n <React.Fragment key={key}>\n <tr\n className={`${typeof rowClassName === 'function' ? rowClassName(record, index) : rowClassName || ''} ${draggedRowIndex === index ? 'dragging' : ''} ${dragOverRowIndex === index ? 'drag-over' : ''}`}\n draggable={true}\n onDragStart={() => handleDragStart(index)}\n onDragOver={(e) => handleDragOver(e, index)}\n onDrop={(e) => handleDrop(e, index)}\n onDragEnd={handleDragEnd}\n style={{\n cursor: 'move',\n opacity: draggedRowIndex === index ? 0.5 : 1,\n backgroundColor: dragOverRowIndex === index ? '#F9FAFB' : 'white',\n transition: 'background-color 0.2s',\n ...rowProps.style,\n }}\n onMouseEnter={(e) => {\n if (draggedRowIndex !== index && dragOverRowIndex !== index) {\n e.currentTarget.style.backgroundColor = '#F9FAFB';\n }\n }}\n onMouseLeave={(e) => {\n if (draggedRowIndex !== index && dragOverRowIndex !== index) {\n e.currentTarget.style.backgroundColor = 'white';\n }\n }}\n {...rowProps}\n >\n {rowSelection && (\n <td\n style={{\n width: typeof rowSelection.columnWidth === 'number' \n ? `${rowSelection.columnWidth}px` \n : (typeof rowSelection.columnWidth === 'string' ? rowSelection.columnWidth : '60px'),\n position: rowSelection.fixed ? 'sticky' : 'relative',\n left: rowSelection.fixed === 'left' || rowSelection.fixed === true ? '0px' : undefined,\n right: rowSelection.fixed === 'right' ? '0px' : undefined,\n zIndex: rowSelection.fixed ? (rowSelection.fixed === 'left' || rowSelection.fixed === true ? 12 : 11) : 1,\n backgroundColor: 'white',\n padding: '16px',\n borderBottom: isLastRow ? 'none' : '1px solid #EAECF0',\n textAlign: 'center',\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n <Checkbox\n checked={isSelected}\n onChange={(e) => handleSelect(record, e.target.checked)}\n disabled={rowSelection.getCheckboxProps?.(record).disabled}\n />\n </div>\n </td>\n )}\n {columns.map((column, colIndex) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex) || colIndex;\n const cellProps = column.onCell?.(record, index) || {};\n const fixedOffset = getFixedOffset(colIndex, column.fixed, false);\n const columnWidth = column.width \n ? (typeof column.width === 'number' ? `${column.width}px` : column.width)\n : undefined;\n \n return (\n <td\n key={columnKey}\n className={`${column.className || ''} ${column.align ? `text-${column.align}` : ''}`}\n style={{\n width: columnWidth,\n minWidth: column.minWidth ? (typeof column.minWidth === 'number' ? `${column.minWidth}px` : column.minWidth) : (columnWidth || undefined),\n maxWidth: columnWidth,\n position: column.fixed ? 'sticky' : 'relative',\n left: column.fixed === 'left' || column.fixed === true ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n right: column.fixed === 'right' ? (fixedOffset !== undefined ? `${fixedOffset}px` : '0') : undefined,\n zIndex: column.fixed ? (column.fixed === 'left' || column.fixed === true ? 10 : 9) : 1,\n backgroundColor: 'white',\n boxShadow: column.fixed === 'left' || column.fixed === true \n ? '2px 0 4px rgba(0, 0, 0, 0.05)' \n : column.fixed === 'right' \n ? '-2px 0 4px rgba(0, 0, 0, 0.05)' \n : undefined,\n padding: '16px',\n borderBottom: isLastRow ? 'none' : '1px solid #EAECF0',\n fontSize: '14px',\n lineHeight: '20px',\n color: '#101828',\n fontFamily: 'DM Sans, sans-serif',\n textAlign: column.align || 'left',\n ...cellProps.style,\n }}\n colSpan={column.colSpan}\n rowSpan={column.rowSpan}\n {...cellProps}\n >\n {renderCell(column, record, index)}\n </td>\n );\n })}\n </tr>\n {expandable?.expandedRowRender && isExpanded && (\n <tr>\n <td colSpan={columns.length + (rowSelection ? 1 : 0)}>\n {expandable.expandedRowRender(record, index, 0, true)}\n </td>\n </tr>\n )}\n </React.Fragment>\n );\n });\n }, [paginatedData, rowKey, selectedRowKeys, expandedRowKeys, rowSelection, columns, onRow, rowClassName, handleSelect, renderCell, expandable, draggedRowIndex, dragOverRowIndex, handleDragStart, handleDragOver, handleDrop, handleDragEnd, getFixedOffset, renderEmpty]);\n\n // ==================== 渲染分页 ====================\n const renderPagination = () => {\n if (pagination === false || !pagination) return null;\n \n const total = pagination.total ?? processedData.length;\n const position = pagination.position || 'bottomRight';\n \n return (\n <div\n style={{\n marginTop: '16px',\n display: 'flex',\n justifyContent: position.includes('Right') ? 'flex-end' : position.includes('Left') ? 'flex-start' : 'center',\n }}\n >\n <Pagination\n current={currentPage}\n total={total}\n pageSize={pageSize}\n showSizeChanger={pagination.showSizeChanger}\n pageSizeOptions={pagination.pageSizeOptions}\n showQuickJumper={pagination.showQuickJumper}\n showTotal={pagination.showTotal}\n onChange={handlePageChange}\n onShowSizeChange={handlePageChange}\n simple={pagination.simple}\n responsive={pagination.responsive}\n size={size === 'small' ? 'small' : 'default'}\n />\n </div>\n );\n };\n\n // ==================== 移动端渲染 ====================\n const renderMobileView = () => {\n const emptyContent =\n typeof locale?.emptyText === 'function'\n ? locale.emptyText()\n : locale?.emptyText !== undefined\n ? locale.emptyText\n : 'No data';\n if (paginatedData.length === 0) {\n return (\n <div className=\"aha-table-mobile aha-table-placeholder\" style={{\n padding: '48px 16px',\n textAlign: 'center',\n color: '#98A2B3',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: 'DM Sans, sans-serif',\n }}>\n {emptyContent}\n </div>\n );\n }\n return (\n <div className=\"aha-table-mobile\">\n {paginatedData.map((record, index) => {\n const key = getRowKey(record, rowKey);\n const isSelected = selectedRowKeys.includes(key);\n \n return (\n <div\n key={key}\n className={`aha-table-mobile-row ${isSelected ? 'selected' : ''}`}\n style={{\n border: '1px solid #e8e8e8',\n borderRadius: '4px',\n padding: '12px',\n marginBottom: '12px',\n backgroundColor: isSelected ? '#e6f7ff' : 'white',\n }}\n >\n {rowSelection && (\n <div style={{ marginBottom: '8px' }}>\n <Checkbox\n checked={isSelected}\n onChange={(e) => handleSelect(record, e.target.checked)}\n disabled={rowSelection.getCheckboxProps?.(record).disabled}\n />\n </div>\n )}\n {columns.map((column) => {\n const columnKey = column.key || (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex);\n const value = getValue(record, column.dataIndex || '');\n const displayValue = column.render ? column.render(value, record, index) : value;\n \n return (\n <div\n key={columnKey}\n style={{\n display: 'flex',\n justifyContent: 'space-between',\n marginBottom: '8px',\n paddingBottom: '8px',\n borderBottom: '1px solid #f0f0f0',\n }}\n >\n <span style={{ fontWeight: 'bold', color: '#666' }}>\n {typeof column.title === 'function' ? column.title({}) : column.title}:\n </span>\n <span style={{ flex: 1, textAlign: 'right' }}>{displayValue}</span>\n </div>\n );\n })}\n </div>\n );\n })}\n </div>\n );\n };\n\n // ==================== 主渲染 ====================\n // 检查是否有固定列\n const hasFixedColumns = useMemo(() => {\n return columns.some(col => col.fixed) || (rowSelection && rowSelection.fixed);\n }, [columns, rowSelection]);\n\n // 检查是否所有列都有宽度\n const hasAllColumnWidths = useMemo(() => {\n return columns.every(col => col.width) && (!rowSelection || rowSelection.columnWidth);\n }, [columns, rowSelection]);\n\n // 计算表格总宽度\n // 只有在设置了 scroll.x 或者有固定列且需要滚动时,才使用固定宽度\n // 否则使用 100% 让表格撑满父元素\n const totalWidth = useMemo(() => {\n // 如果设置了 scroll.x,使用 scroll.x 作为表格宽度(Ant Design 的方式)\n if (scroll?.x) {\n if (typeof scroll.x === 'number') {\n return scroll.x;\n } else if (scroll.x === true) {\n // scroll.x === true 时,计算所有列的宽度总和\n const widthSum = columns.reduce((sum, col) => {\n const w = col.width \n ? (typeof col.width === 'number' ? col.width : parseInt(String(col.width).replace('px', '')) || 0)\n : 150; // 默认宽度\n return sum + w;\n }, 0);\n const total = widthSum + (rowSelection ? (typeof rowSelection.columnWidth === 'number' ? rowSelection.columnWidth : parseInt(String(rowSelection.columnWidth || '60').replace('px', '')) || 60) : 0);\n return total;\n }\n }\n \n // 如果有固定列,需要计算最小宽度以确保固定列能正常工作\n // 但表格本身仍然使用 100% 宽度撑满父元素\n if (hasFixedColumns) {\n // 计算所有固定列的宽度总和,作为最小宽度\n const fixedWidthSum = columns.reduce((sum, col) => {\n if (col.fixed && col.width) {\n const w = typeof col.width === 'number' ? col.width : parseInt(String(col.width).replace('px', '')) || 0;\n return sum + w;\n }\n return sum;\n }, 0);\n const rowSelectionWidth = (rowSelection && rowSelection.fixed && rowSelection.columnWidth) \n ? (typeof rowSelection.columnWidth === 'number' ? rowSelection.columnWidth : parseInt(String(rowSelection.columnWidth).replace('px', '')) || 60)\n : 0;\n // 返回最小宽度,但表格宽度仍然使用 100%\n return fixedWidthSum + rowSelectionWidth;\n }\n \n // 默认返回 undefined,让表格使用 100% 宽度撑满父元素\n return undefined;\n }, [columns, scroll?.x, rowSelection, hasFixedColumns]);\n\n // 如果有固定列或所有列都有 width,使用 fixed layout\n const effectiveTableLayout = useMemo(() => {\n if (tableLayout === 'fixed') return 'fixed';\n if (hasFixedColumns) return 'fixed';\n if (hasAllColumnWidths) return 'fixed';\n // 如果有部分列设置了宽度,也使用 fixed layout,让未设置宽度的列自适应\n if (columns.some(col => col.width)) return 'fixed';\n return tableLayout;\n }, [tableLayout, hasFixedColumns, hasAllColumnWidths, columns]);\n\n const tableStyle: React.CSSProperties = {\n width: '100%', // 始终使用 100% 宽度撑满父元素\n minWidth: totalWidth ? `${totalWidth}px` : '100%', // 如果有固定列,设置最小宽度\n borderCollapse: 'separate',\n borderSpacing: 0,\n tableLayout: effectiveTableLayout,\n backgroundColor: 'white',\n ...(bordered && { borderRadius: '8px', border: '1px solid #EAECF0' }),\n overflow: 'hidden',\n };\n\n const wrapperStyle: React.CSSProperties = {\n position: 'relative',\n width: '100%',\n maxWidth: '100%',\n maxHeight: typeof scroll?.y === 'number' ? `${scroll.y}px` : undefined,\n borderRadius: '8px',\n ...style,\n };\n\n // 移动端使用卡片式布局\n if (isMobile) {\n return (\n <div\n ref={tableRef}\n className={`aha-table aha-table-mobile-wrapper ${className}`}\n style={wrapperStyle}\n aria-busy={loading ? true : undefined}\n {...rest}\n >\n {title && <div style={{ marginBottom: '16px' }}>{title(processedData)}</div>}\n {pagination && typeof pagination === 'object' && pagination.position?.startsWith('top') && renderPagination()}\n {renderMobileView()}\n {footer && <div style={{ marginTop: '16px' }}>{footer(processedData)}</div>}\n {pagination && (typeof pagination === 'object' ? !pagination.position?.startsWith('top') : true) && renderPagination()}\n <TableLoadingOverlay loading={loading} spinColor={loadingSpinColor} />\n </div>\n );\n }\n\n // 滚动容器的样式\n const scrollContainerStyle: React.CSSProperties = {\n position: 'relative',\n overflowX: (scroll?.x || hasFixedColumns) ? 'auto' : 'visible',\n overflowY: scroll?.y ? 'auto' : 'visible',\n width: '100%',\n // 关键:容器宽度必须小于表格宽度,才能触发滚动\n // 只有在设置了 scroll.x 时才限制容器宽度\n maxWidth: scroll?.x === true \n ? '100%' \n : typeof scroll?.x === 'number' \n ? `${scroll.x}px` \n : undefined,\n maxHeight: typeof scroll?.y === 'number' ? `${scroll.y}px` : undefined,\n // 确保滚动容器有明确的边界\n borderRadius: '8px',\n };\n\n return (\n <div\n ref={tableRef}\n className={`aha-table ${className}`}\n style={wrapperStyle}\n aria-busy={loading ? true : undefined}\n {...rest}\n >\n {title && <div style={{ marginBottom: '16px' }}>{title(processedData)}</div>}\n {pagination && typeof pagination === 'object' && pagination.position?.startsWith('top') && renderPagination()}\n <div style={scrollContainerStyle}>\n <div style={{ \n width: '100%', \n minWidth: totalWidth ? `${totalWidth}px` : '100%', \n display: 'block' \n }}>\n <table style={tableStyle} className={innerClassName}>\n {renderHeader()}\n <tbody>{renderRows()}</tbody>\n {summary && (\n <tfoot>\n <tr>\n <td colSpan={columns.length + (rowSelection ? 1 : 0)}>{summary(processedData)}</td>\n </tr>\n </tfoot>\n )}\n </table>\n </div>\n </div>\n {footer && <div style={{ marginTop: '16px' }}>{footer(processedData)}</div>}\n {pagination && (typeof pagination === 'object' ? !pagination.position?.startsWith('top') : true) && renderPagination()}\n <TableLoadingOverlay loading={loading} spinColor={loadingSpinColor} />\n </div>\n );\n};\n\nexport default Table;\n\n","import React, { useState } from 'react';\n\nexport interface RadioProps {\n checked?: boolean;\n disabled?: boolean;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n className?: string;\n style?: React.CSSProperties;\n children?: React.ReactNode;\n value?: any;\n name?: string;\n /** sm = 16px, md = 20px */\n size?: 'sm' | 'md';\n /** Secondary description rendered below the label */\n hint?: React.ReactNode;\n /** Force focused appearance (useful for Storybook demos) */\n isFocused?: boolean;\n}\n\nconst Radio: React.FC<RadioProps> = ({\n checked = false,\n disabled = false,\n onChange,\n className = '',\n style,\n children,\n value,\n name,\n size = 'sm',\n hint,\n isFocused: isFocusedProp,\n}) => {\n const [hovered, setHovered] = useState(false);\n const [focused, setFocused] = useState(false);\n\n const showFocus = isFocusedProp ?? focused;\n\n const handleClick = () => {\n if (disabled || checked) return;\n const syntheticEvent = {\n target: { checked: true, value },\n currentTarget: { checked: true, value },\n } as React.ChangeEvent<HTMLInputElement>;\n onChange?.(syntheticEvent);\n };\n\n const boxSize = size === 'sm' ? '16px' : '20px';\n const dotSize = size === 'sm' ? '6px' : '8px';\n const fontSize = size === 'sm' ? 'var(--font-size-text-sm, 14px)' : 'var(--font-size-text-md, 16px)';\n const lineHeight = size === 'sm' ? 'var(--line-height-text-sm, 20px)' : 'var(--line-height-text-md, 24px)';\n const gap = size === 'sm' ? 'var(--spacing-md, 8px)' : 'var(--spacing-lg, 12px)';\n\n const getBoxBg = () => {\n if (disabled) return 'var(--color-bg-disabled_subtle, #fafaf9)';\n if (checked) return hovered ? 'var(--color-bg-brand-solid_hover, #ec470a)' : 'var(--color-bg-brand-solid, #fb6011)';\n return hovered ? 'var(--color-bg-primary_hover, #fafaf9)' : 'var(--color-bg-primary, #ffffff)';\n };\n\n const getBoxBorder = () => {\n if (disabled) return '1px solid var(--color-border-disabled, #d7d3d0)';\n if (checked) return hovered ? '1px solid var(--color-bg-brand-solid_hover, #ec470a)' : '1px solid var(--color-bg-brand-solid, #fb6011)';\n return '1px solid var(--color-border-primary, #d7d3d0)';\n };\n\n const hasLabel = children || hint;\n\n // Disabled checked: use muted dot color so it's visible on the light bg\n const dotColor = disabled && checked\n ? 'var(--color-fg-disabled_subtle, #d7d3d0)'\n : 'var(--color-fg-white, #ffffff)';\n\n return (\n <div\n className={`aha-radio ${className}`}\n role=\"radio\"\n aria-checked={checked}\n aria-disabled={disabled}\n tabIndex={disabled ? -1 : 0}\n style={{\n display: 'inline-flex',\n alignItems: 'flex-start',\n gap,\n cursor: disabled ? 'not-allowed' : 'pointer',\n outline: 'none',\n ...style,\n }}\n onClick={handleClick}\n onKeyDown={(e) => {\n if (e.key === ' ' || e.key === 'Enter') {\n e.preventDefault();\n handleClick();\n }\n }}\n onMouseEnter={() => !disabled && setHovered(true)}\n onMouseLeave={() => setHovered(false)}\n onFocus={() => !disabled && setFocused(true)}\n onBlur={() => setFocused(false)}\n >\n {/* Radio circle */}\n <div\n style={{\n position: 'relative',\n width: boxSize,\n height: boxSize,\n minWidth: boxSize,\n minHeight: boxSize,\n flexShrink: 0,\n borderRadius: '50%',\n border: getBoxBorder(),\n backgroundColor: getBoxBg(),\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n transition: 'background-color 0.15s, border-color 0.15s, box-shadow 0.15s',\n boxSizing: 'border-box',\n boxShadow: showFocus ? 'var(--focus-ring, 0px 0px 0px 2px #ffffff, 0px 0px 0px 4px #fb6011)' : 'none',\n marginTop: hasLabel ? '2px' : '0',\n }}\n >\n {/* Inner dot */}\n <div\n style={{\n width: dotSize,\n height: dotSize,\n borderRadius: '50%',\n backgroundColor: dotColor,\n opacity: checked ? 1 : 0,\n transition: 'opacity 0.15s',\n pointerEvents: 'none',\n flexShrink: 0,\n }}\n />\n </div>\n\n {/* Label + hint */}\n {hasLabel && (\n <div style={{ display: 'inline-flex', flexDirection: 'column', gap: size === 'md' ? 'var(--spacing-xxs, 2px)' : '0' }}>\n {children && (\n <span\n style={{\n fontSize,\n lineHeight,\n fontWeight: 'var(--font-weight-medium, 500)' as React.CSSProperties['fontWeight'],\n fontFamily: 'var(--font-family-body, \"DM Sans\", sans-serif)',\n color: disabled ? 'var(--color-text-disabled, #79716b)' : 'var(--color-text-secondary, #44403c)',\n userSelect: 'none',\n }}\n >\n {children}\n </span>\n )}\n {hint && (\n <span\n style={{\n fontSize,\n lineHeight,\n fontWeight: 'var(--font-weight-regular, 400)' as React.CSSProperties['fontWeight'],\n fontFamily: 'var(--font-family-body, \"DM Sans\", sans-serif)',\n color: 'var(--color-text-tertiary, #57534e)',\n }}\n onClick={(e) => e.stopPropagation()}\n >\n {hint}\n </span>\n )}\n </div>\n )}\n\n </div>\n );\n};\n\nRadio.displayName = 'Radio';\n\nexport default Radio;\n","import React, { useState, useCallback, useRef, useEffect, useMemo } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport type TabVariant = 'underline' | 'background';\nexport type TabLayout = 'equal' | 'spaced';\n\nexport interface TabItem {\n key: string | number;\n label: React.ReactNode;\n icon?: React.ReactElement | React.ComponentType<any>;\n badge?: number | string;\n customElement?: React.ReactNode;\n disabled?: boolean;\n children?: React.ReactNode; // 用于 children 模式的内容\n}\n\nexport interface TabProps {\n items: TabItem[] | string[] | number[];\n variant?: TabVariant;\n layout?: TabLayout; // 仅对 background 样式有效\n defaultValue?: string | number;\n value?: string | number;\n onChange?: (value: string | number) => void;\n className?: string;\n mode?: 'children' | 'value'; // children: 渲染 children,value: 只输出 value\n scrollable?: boolean; // 是否支持横向滚动(仅对 underline 样式有效,移动端/小宽度容器)\n [key: string]: any;\n}\n\nconst Tab: React.FC<TabProps> = ({\n items = [],\n variant = 'underline',\n layout = 'equal',\n defaultValue,\n value: controlledValue,\n onChange,\n className = '',\n mode = 'children',\n scrollable = false,\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n \n // 如果没有 items,返回空\n if (!items || items.length === 0) {\n return null;\n }\n\n // 将 string[] 或 number[] 转换为 TabItem[]\n // 使用 useMemo 稳定引用,避免导致无限循环\n const normalizedItems: TabItem[] = useMemo(() => {\n if (items.length === 0) return [];\n \n // 判断第一个元素的类型\n const firstItem = items[0];\n if (typeof firstItem === 'string' || typeof firstItem === 'number') {\n return (items as (string | number)[]).map((item, index) => ({\n key: String(item),\n label: String(item),\n }));\n }\n \n return items as TabItem[];\n }, [items]);\n\n // 简单的受控/非受控逻辑\n const isControlled = controlledValue !== undefined;\n const firstKey: string | number = normalizedItems.length > 0 ? normalizedItems[0].key : '';\n \n // 查找匹配的 key:如果 value 在 normalizedItems 中找不到,尝试使用第一个 key\n const findMatchingKey = (value: string | number | undefined): string | number => {\n if (value === undefined) return firstKey;\n \n // 精确匹配(同时支持字符串和数字的比较)\n const exactMatch = normalizedItems.find(item => {\n // 1. 直接比较(最严格)\n if (item.key === value) return true;\n \n // 2. 字符串比较\n if (String(item.key) === String(value)) return true;\n \n // 3. 数字比较(确保两个都是有效数字)\n const itemNum = Number(item.key);\n const valueNum = Number(value);\n if (!isNaN(itemNum) && !isNaN(valueNum) && itemNum === valueNum) {\n return true;\n }\n \n return false;\n });\n \n if (exactMatch) {\n // 返回找到的 key,保持原始类型\n return exactMatch.key;\n }\n \n // 如果找不到,返回第一个 key(回退逻辑)\n return firstKey;\n };\n \n const [internalValue, setInternalValue] = useState<string | number>(() => {\n // 只在第一次渲染时计算\n const initialValue = controlledValue ?? defaultValue ?? firstKey;\n const matchedKey = findMatchingKey(initialValue);\n return matchedKey;\n });\n \n // 每次渲染时重新计算 currentValue,确保类型匹配\n const currentValue = isControlled \n ? (controlledValue !== undefined ? findMatchingKey(controlledValue) : firstKey)\n : internalValue;\n \n // 调试日志(可以帮助定位问题,问题解决后可以删除)\n useEffect(() => {\n console.log('[Tab Debug] currentValue:', currentValue, 'type:', typeof currentValue);\n console.log('[Tab Debug] normalizedItems:', normalizedItems.map(item => ({ key: item.key, type: typeof item.key })));\n console.log('[Tab Debug] controlledValue:', controlledValue, 'isControlled:', isControlled);\n }, [currentValue, normalizedItems, controlledValue, isControlled]);\n\n const handleTabClick = useCallback(\n (key: string | number, disabled?: boolean) => {\n if (disabled) return;\n if (!isControlled) {\n setInternalValue(key);\n }\n // 如果原始 items 是 number[],返回 number,否则返回 string\n const originalItem = items[0];\n const returnValue = typeof originalItem === 'number' && typeof key === 'number' ? key : (typeof key === 'number' ? String(key) : key);\n onChange?.(returnValue);\n \n // 如果支持滚动,点击后自动滚动到可见区域\n if (scrollable && variant === 'underline') {\n const activeTabElement = tabRefs.current[getKeyString(key)];\n const container = containerRef.current;\n if (activeTabElement && container) {\n // 标记正在滚动\n isScrollingRef.current = true;\n \n // 先立即更新一次位置(基于当前滚动位置)\n const updatePosition = () => {\n if (!container || !underlineRef.current || !activeTabElement) return;\n const containerRect = container.getBoundingClientRect();\n const tabRect = activeTabElement.getBoundingClientRect();\n \n if (containerRect.width > 0 && tabRect.width > 0) {\n // 下划线是绝对定位,相对于容器内容区域\n // 需要加上容器的滚动距离\n const scrollLeft = container.scrollLeft || 0;\n const left = tabRect.left - containerRect.left + scrollLeft;\n const width = tabRect.width;\n setUnderlineStyle({\n width: `${width}px`,\n left: `${left}px`,\n opacity: 1,\n });\n }\n };\n \n // 监听滚动事件,实时更新位置\n let scrollTimeout: NodeJS.Timeout;\n const handleScroll = () => {\n updatePosition();\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n // 滚动停止后,最终更新一次位置\n updatePosition();\n isScrollingRef.current = false;\n container.removeEventListener('scroll', handleScroll);\n }, 150); // 滚动停止 150ms 后认为滚动完成\n };\n \n container.addEventListener('scroll', handleScroll, { passive: true });\n \n // 使用 scrollIntoView 滚动到可见区域\n activeTabElement.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n inline: 'center',\n });\n \n // 如果 scrollIntoView 不支持或立即完成,也更新位置\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n updatePosition();\n });\n });\n }\n }\n },\n [isControlled, onChange, items, scrollable, variant]\n );\n\n const activeItem = normalizedItems.find((item) => {\n // 支持多种比较方式\n if (item.key === currentValue) return true;\n if (String(item.key) === String(currentValue)) return true;\n // 数字比较:确保两个都是数字且相等\n const itemNum = Number(item.key);\n const currentNum = Number(currentValue);\n if (!isNaN(itemNum) && !isNaN(currentNum) && itemNum === currentNum) return true;\n return false;\n });\n const activeColor = primaryColor || '#FB6011';\n \n // 用于下划线和背景滑块动画的 refs\n const tabRefs = useRef<{ [key: string]: HTMLDivElement | null }>({});\n \n // 将 key 转为字符串的辅助函数\n const getKeyString = (key: string | number): string => String(key);\n const underlineRef = useRef<HTMLDivElement>(null);\n const backgroundSliderRef = useRef<HTMLDivElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const backgroundContainerRef = useRef<HTMLDivElement>(null);\n const prevCurrentValueRef = useRef<string | number>('');\n const refsInitializedRef = useRef<Set<string>>(new Set());\n const isScrollingRef = useRef<boolean>(false); // 标记是否正在滚动\n const [underlineStyle, setUnderlineStyle] = useState<React.CSSProperties>({\n width: 0,\n left: 0,\n opacity: 0,\n });\n const [backgroundSliderStyle, setBackgroundSliderStyle] = useState<React.CSSProperties>({\n width: 0,\n left: 0,\n opacity: 0,\n });\n\n // 更新下划线的辅助函数\n const updateUnderlinePosition = useCallback(() => {\n if (variant !== 'underline' || !containerRef.current || !currentValue) {\n return;\n }\n \n // 使用双重 requestAnimationFrame 确保 DOM 完全渲染完成\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n // 再次检查 refs 和 currentValue,确保它们仍然有效\n if (!underlineRef.current || !containerRef.current) {\n return;\n }\n \n let activeTab = tabRefs.current[getKeyString(currentValue)];\n \n // 如果找不到精确匹配的 tab,尝试使用第一个 item(回退逻辑)\n if (!activeTab && normalizedItems.length > 0) {\n const firstKey = normalizedItems[0].key;\n activeTab = tabRefs.current[getKeyString(firstKey)];\n }\n \n if (!activeTab) {\n return;\n }\n \n const containerRect = containerRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n // 如果容器或标签页的尺寸为 0,说明还没有渲染完成,不更新\n if (containerRect.width === 0 || tabRect.width === 0) {\n return;\n }\n \n // 计算下划线位置\n // 下划线是绝对定位,相对于容器(position: relative)\n // getBoundingClientRect() 返回的是相对于视口的位置\n // 下划线的 left 是相对于容器内容区域的起始位置\n // 所以需要:tab 相对于容器视口的位置 + 容器的滚动距离\n const scrollLeft = containerRef.current.scrollLeft || 0;\n const left = tabRect.left - containerRect.left + scrollLeft;\n const width = tabRect.width;\n const newLeft = `${left}px`;\n const newWidth = `${width}px`;\n \n // 更新下划线样式\n setUnderlineStyle((prev) => {\n if (prev.left === newLeft && prev.width === newWidth && prev.opacity === 1) {\n return prev; // 值相同,返回原对象,避免重新渲染\n }\n return {\n width: newWidth,\n left: newLeft,\n opacity: 1,\n };\n });\n });\n });\n }, [variant, currentValue, normalizedItems]);\n\n // 更新背景滑块位置的辅助函数\n const updateBackgroundSliderPosition = useCallback(() => {\n if (variant !== 'background' || !backgroundContainerRef.current || !backgroundSliderRef.current || !currentValue) {\n return;\n }\n \n // 使用双重 requestAnimationFrame 确保 DOM 完全渲染完成\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n // 再次检查 refs 和 currentValue,确保它们仍然有效\n if (!backgroundSliderRef.current || !backgroundContainerRef.current) {\n return;\n }\n \n let activeTab = tabRefs.current[getKeyString(currentValue)];\n \n // 如果找不到精确匹配的 tab,尝试使用第一个 item(回退逻辑)\n if (!activeTab && normalizedItems.length > 0) {\n const firstKey = normalizedItems[0].key;\n activeTab = tabRefs.current[getKeyString(firstKey)];\n }\n \n if (!activeTab) {\n return;\n }\n \n const containerRect = backgroundContainerRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n // 如果容器或标签页的尺寸为 0,说明还没有渲染完成,不更新\n if (containerRect.width === 0 || tabRect.width === 0) {\n return;\n }\n \n const left = tabRect.left - containerRect.left;\n const width = tabRect.width;\n const newLeft = `${left}px`;\n const newWidth = `${width}px`;\n \n // 更新背景滑块样式\n setBackgroundSliderStyle((prev) => {\n if (prev.left === newLeft && prev.width === newWidth && prev.opacity === 1) {\n return prev; // 值相同,返回原对象,避免重新渲染\n }\n return {\n width: newWidth,\n left: newLeft,\n opacity: 1,\n };\n });\n });\n });\n }, [variant, currentValue, normalizedItems]);\n\n // 更新下划线和背景滑块位置\n useEffect(() => {\n // 如果没有 currentValue,不执行任何操作\n if (!currentValue) {\n prevCurrentValueRef.current = '';\n return;\n }\n \n // 如果 currentValue 没有变化,不执行(避免无限循环)\n if (prevCurrentValueRef.current === currentValue) {\n return;\n }\n \n // 更新 ref\n prevCurrentValueRef.current = currentValue;\n\n // 更新下划线位置\n // 如果正在滚动,不立即更新,等待滚动完成后再更新(在 handleTabClick 中处理)\n if (variant === 'underline' && containerRef.current && !isScrollingRef.current) {\n updateUnderlinePosition();\n }\n\n // 更新背景滑块位置\n if (variant === 'background' && backgroundContainerRef.current && backgroundSliderRef.current) {\n updateBackgroundSliderPosition();\n }\n }, [currentValue, variant, normalizedItems.length, isControlled, updateUnderlinePosition, updateBackgroundSliderPosition]);\n \n // 初始渲染后,确保下划线和背景滑块正确显示(解决初始渲染时宽度为 0 的问题)\n // 只在组件挂载后执行一次\n useEffect(() => {\n if (!currentValue) return;\n \n // 延迟执行,确保所有 refs 都已设置\n const timer = setTimeout(() => {\n if (variant === 'underline') {\n // 检查 activeTab 是否存在\n const activeTab = tabRefs.current[getKeyString(currentValue)];\n if (activeTab && containerRef.current && underlineRef.current) {\n updateUnderlinePosition();\n \n // 如果支持滚动,初始渲染时自动滚动到激活项\n if (scrollable) {\n activeTab.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n inline: 'center',\n });\n }\n }\n } else if (variant === 'background') {\n // 更新背景滑块位置\n const activeTab = tabRefs.current[getKeyString(currentValue)];\n if (activeTab && backgroundContainerRef.current && backgroundSliderRef.current) {\n const containerRect = backgroundContainerRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n if (containerRect.width > 0 && tabRect.width > 0) {\n const left = tabRect.left - containerRect.left;\n const width = tabRect.width;\n const newLeft = `${left}px`;\n const newWidth = `${width}px`;\n \n setBackgroundSliderStyle({\n width: newWidth,\n left: newLeft,\n opacity: 1,\n });\n }\n }\n }\n }, 100); // 增加延迟,确保 refs 和 DOM 都已准备好\n \n return () => clearTimeout(timer);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []); // 只在组件挂载时执行一次\n \n // 当 currentValue 变化时,如果支持滚动,自动滚动到激活项\n // 注意:这个 useEffect 只在非点击触发的 currentValue 变化时执行(比如受控组件外部更新)\n useEffect(() => {\n if (!scrollable || variant !== 'underline' || !currentValue) return;\n \n // 如果正在滚动(由点击触发),不执行这个 useEffect 的滚动逻辑\n if (isScrollingRef.current) return;\n \n const timer = setTimeout(() => {\n const activeTab = tabRefs.current[getKeyString(currentValue)];\n const container = containerRef.current;\n if (activeTab && container) {\n isScrollingRef.current = true;\n \n // 更新位置的函数\n const updatePosition = () => {\n if (!container || !underlineRef.current || !activeTab) return;\n const containerRect = container.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n \n if (containerRect.width > 0 && tabRect.width > 0) {\n // 下划线是绝对定位,相对于容器内容区域\n // 需要加上容器的滚动距离\n const scrollLeft = container.scrollLeft || 0;\n const left = tabRect.left - containerRect.left + scrollLeft;\n const width = tabRect.width;\n setUnderlineStyle({\n width: `${width}px`,\n left: `${left}px`,\n opacity: 1,\n });\n }\n };\n \n // 监听滚动事件\n let scrollTimeout: NodeJS.Timeout;\n const handleScroll = () => {\n updatePosition();\n clearTimeout(scrollTimeout);\n scrollTimeout = setTimeout(() => {\n updatePosition();\n isScrollingRef.current = false;\n container.removeEventListener('scroll', handleScroll);\n }, 150);\n };\n \n container.addEventListener('scroll', handleScroll, { passive: true });\n \n activeTab.scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n inline: 'center',\n });\n \n // 立即更新一次\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n updatePosition();\n });\n });\n }\n }, 50);\n \n return () => clearTimeout(timer);\n }, [currentValue, scrollable, variant]);\n\n // 下划线样式\n const renderUnderlineStyle = () => {\n const containerStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n gap: '32px',\n borderBottom: '1px solid #E7E5E4',\n paddingBottom: '0',\n position: 'relative',\n };\n \n // 如果支持滚动,添加滚动样式\n if (scrollable) {\n containerStyle.overflowX = 'auto';\n containerStyle.overflowY = 'hidden';\n containerStyle.scrollBehavior = 'smooth';\n // 隐藏滚动条但保持滚动功能\n containerStyle.scrollbarWidth = 'none'; // Firefox\n // @ts-ignore - WebKit 私有属性\n containerStyle.WebkitOverflowScrolling = 'touch'; // iOS 平滑滚动\n }\n \n return (\n <div\n ref={containerRef}\n className={`aha-tab aha-tab--underline ${scrollable ? 'aha-tab--scrollable' : ''} ${className}`}\n style={containerStyle}\n {...rest}\n >\n {/* 动画下划线指示器 */}\n <div\n ref={underlineRef}\n style={{\n position: 'absolute',\n bottom: '0px',\n height: '2px',\n backgroundColor: activeColor,\n borderRadius: '1px 1px 0 0',\n transition: 'left 0.3s cubic-bezier(0.4, 0, 0.2, 1), width 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease-in-out',\n ...underlineStyle,\n }}\n />\n \n {normalizedItems.map((item) => {\n // 支持多种比较方式:直接比较、字符串比较、数字比较\n const isActive = (() => {\n // 直接比较(最严格)\n if (item.key === currentValue) {\n return true;\n }\n // 字符串比较\n if (String(item.key) === String(currentValue)) {\n return true;\n }\n // 数字比较:确保两个都是有效数字且相等\n const itemNum = Number(item.key);\n const currentNum = Number(currentValue);\n if (!isNaN(itemNum) && !isNaN(currentNum) && itemNum === currentNum) {\n return true;\n }\n return false;\n })();\n \n // 调试日志(仅对第一个 item 输出,避免太多日志)\n if (item.key === normalizedItems[0].key) {\n console.log('[Tab Debug] isActive check:', {\n itemKey: item.key,\n itemKeyType: typeof item.key,\n currentValue,\n currentValueType: typeof currentValue,\n isActive,\n variant,\n });\n }\n\n return (\n <div\n key={item.key}\n ref={(el) => {\n tabRefs.current[getKeyString(item.key)] = el;\n }}\n onClick={() => handleTabClick(item.key, item.disabled)}\n style={{\n position: 'relative',\n padding: '12px 0',\n cursor: item.disabled ? 'not-allowed' : 'pointer',\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n opacity: item.disabled ? 0.5 : 1,\n transition: 'color 0.2s ease-in-out',\n // 如果支持滚动,tab 项需要 flex-shrink: 0 防止压缩\n flexShrink: scrollable ? 0 : undefined,\n whiteSpace: scrollable ? 'nowrap' : undefined,\n }}\n >\n {/* 图标 */}\n {item.icon && (() => {\n // 调试日志\n const iconType = typeof item.icon;\n const isReactElement = React.isValidElement(item.icon);\n console.log('[Tab Debug] Icon render:', {\n itemKey: item.key,\n iconType,\n isReactElement,\n iconValue: item.icon,\n });\n \n // 如果 icon 是 ReactElement,直接克隆\n if (React.isValidElement(item.icon)) {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.cloneElement(item.icon as React.ReactElement<any>, {\n width: 20,\n height: 20,\n style: {\n ...(item.icon.props as any)?.style,\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n },\n })}\n </div>\n );\n }\n \n // 如果 icon 是组件类型(函数),使用 createElement\n if (typeof item.icon === 'function') {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.createElement(item.icon as React.ComponentType<any>, {\n width: 20,\n height: 20,\n style: {\n color: isActive ? activeColor : '#79716B',\n },\n })}\n </div>\n );\n }\n \n // 其他情况直接渲染\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n color: isActive ? activeColor : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.icon as React.ReactNode}\n </div>\n );\n })()}\n\n {/* 标签文本 */}\n <span\n style={{\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n color: isActive ? activeColor : '#79716B',\n lineHeight: '1.375',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.label}\n </span>\n\n {/* Badge */}\n {item.badge !== undefined && item.badge !== null && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n minWidth: '20px',\n height: '20px',\n padding: '0 6px',\n borderRadius: '10px',\n backgroundColor: isActive ? '#FFF6ED' : '#FAFAF9',\n border: isActive ? '1px solid #FFD1A9' : '1px solid #E7E5E4',\n color: isActive ? '#C4330A' : '#44403C',\n fontSize: '12px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '1',\n transition: 'all 0.2s ease-in-out',\n }}\n >\n {item.badge}\n </div>\n )}\n\n {/* 自定义元素 */}\n {item.customElement}\n </div>\n );\n })}\n </div>\n );\n };\n\n // 背景边框样式\n const renderBackgroundStyle = () => {\n const containerStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n backgroundColor: '#FAFAF9',\n borderRadius: '8px',\n padding: '4px',\n border: '1px solid #E7E5E4',\n gap: '4px',\n position: 'relative',\n };\n\n if (layout === 'equal') {\n containerStyle.width = '100%';\n } else {\n // spaced 模式:等边距\n containerStyle.width = 'fit-content';\n }\n\n return (\n <div\n ref={backgroundContainerRef}\n className={`aha-tab aha-tab--background aha-tab--${layout} ${className}`}\n style={containerStyle}\n {...rest}\n >\n {/* 背景滑块 */}\n <div\n ref={backgroundSliderRef}\n style={{\n position: 'absolute',\n top: '4px',\n bottom: '4px',\n borderRadius: '6px',\n backgroundColor: '#FFFFFF',\n border: 'none',\n boxShadow: '0px 1px 2px 0px rgba(10, 13, 18, 0.1)',\n transition: 'left 0.3s cubic-bezier(0.4, 0, 0.2, 1), width 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease-in-out',\n pointerEvents: 'none',\n ...backgroundSliderStyle,\n }}\n />\n \n {normalizedItems.map((item) => {\n // 支持多种比较方式:直接比较、字符串比较、数字比较\n const isActive = (() => {\n // 直接比较(最严格)\n if (item.key === currentValue) {\n return true;\n }\n // 字符串比较\n if (String(item.key) === String(currentValue)) {\n return true;\n }\n // 数字比较:确保两个都是有效数字且相等\n const itemNum = Number(item.key);\n const currentNum = Number(currentValue);\n if (!isNaN(itemNum) && !isNaN(currentNum) && itemNum === currentNum) {\n return true;\n }\n return false;\n })();\n \n // 调试日志(仅对第一个 item 输出,避免太多日志)\n if (item.key === normalizedItems[0].key) {\n console.log('[Tab Debug] isActive check:', {\n itemKey: item.key,\n itemKeyType: typeof item.key,\n currentValue,\n currentValueType: typeof currentValue,\n isActive,\n variant,\n });\n }\n\n const itemStyle: React.CSSProperties = {\n position: 'relative',\n padding: '8px 16px',\n cursor: item.disabled ? 'not-allowed' : 'pointer',\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n borderRadius: '6px',\n opacity: item.disabled ? 0.5 : 1,\n flex: layout === 'equal' ? 1 : 'none',\n justifyContent: 'center',\n backgroundColor: 'transparent',\n border: '1px solid transparent',\n transition: 'color 0.2s ease-in-out',\n zIndex: 1,\n };\n\n return (\n <div\n key={item.key}\n ref={(el) => {\n tabRefs.current[getKeyString(item.key)] = el;\n }}\n onClick={() => handleTabClick(item.key, item.disabled)}\n style={itemStyle}\n >\n {/* 图标 */}\n {item.icon && (() => {\n // 如果 icon 是 ReactElement,直接克隆\n if (React.isValidElement(item.icon)) {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '16px',\n height: '16px',\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.cloneElement(item.icon as React.ReactElement<any>, {\n width: 16,\n height: 16,\n style: {\n ...(item.icon.props as any)?.style,\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n },\n })}\n </div>\n );\n }\n \n // 如果 icon 是组件类型(函数),使用 createElement\n if (typeof item.icon === 'function') {\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '16px',\n height: '16px',\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {React.createElement(item.icon as React.ComponentType<any>, {\n width: 16,\n height: 16,\n style: {\n color: isActive ? '#44403C' : '#79716B',\n },\n })}\n </div>\n );\n }\n \n // 其他情况直接渲染\n return (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '16px',\n height: '16px',\n color: isActive ? '#44403C' : '#79716B',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.icon as React.ReactNode}\n </div>\n );\n })()}\n\n {/* 标签文本 */}\n <span\n style={{\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n color: isActive ? '#44403C' : '#79716B',\n lineHeight: '1.375',\n transition: 'color 0.2s ease-in-out',\n }}\n >\n {item.label}\n </span>\n\n {/* Badge */}\n {item.badge !== undefined && item.badge !== null && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n minWidth: '20px',\n height: '20px',\n padding: '0 6px',\n borderRadius: '10px',\n backgroundColor: isActive ? '#FFF6ED' : '#FAFAF9',\n border: isActive ? '1px solid #FFD1A9' : '1px solid #E7E5E4',\n color: isActive ? '#C4330A' : '#44403C',\n fontSize: '12px',\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '1',\n transition: 'all 0.2s ease-in-out',\n }}\n >\n {item.badge}\n </div>\n )}\n\n {/* 自定义元素 */}\n {item.customElement}\n </div>\n );\n })}\n </div>\n );\n };\n\n return (\n <div className=\"aha-tab-container\">\n {variant === 'underline' ? renderUnderlineStyle() : renderBackgroundStyle()}\n \n {/* 添加样式隐藏滚动条(仅对支持滚动的 underline 模式) */}\n {scrollable && variant === 'underline' && (\n <style>\n {`\n .aha-tab--scrollable::-webkit-scrollbar {\n display: none;\n }\n .aha-tab--scrollable {\n -ms-overflow-style: none;\n }\n `}\n </style>\n )}\n {mode === 'children' && activeItem?.children && (\n <div className=\"aha-tab-content\" style={{ marginTop: '24px' }}>\n {activeItem.children}\n </div>\n )}\n </div>\n );\n};\n\nexport default Tab;\n","import React, { forwardRef, useRef, useEffect, useMemo, useLayoutEffect } from 'react';\n\ninterface LinkifyOptions {\n validate?: (url: string) => boolean;\n className?: string;\n needProtocol?: boolean;\n needHost?: boolean;\n allowedTlds?: string[];\n}\n\nexport interface TextareaProps\n extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size'> {\n disabled?: boolean;\n error?: boolean;\n readOnly?: boolean;\n showCount?: boolean;\n maxLength?: number;\n className?: string;\n style?: React.CSSProperties;\n placeholder?: string;\n value?: string;\n defaultValue?: string;\n rows?: number;\n autoSize?: boolean | { minRows?: number; maxRows?: number };\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;\n onFocus?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n onBlur?: (e: React.FocusEvent<HTMLTextAreaElement>) => void;\n linkify?: boolean;\n linkifyOptions?: LinkifyOptions;\n label?: string;\n required?: boolean;\n hintText?: string;\n helpIcon?: React.ReactNode;\n}\n\ntype TextToken =\n | { type: 'text'; text: string }\n | { type: 'url'; text: string; href: string };\n\nconst DOMAIN_REGEX = /^(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}$/;\nconst URL_CANDIDATE_REGEX =\n /(https?:\\/\\/[^\\s<]+|www\\.[^\\s<]+|(?:[a-zA-Z0-9-]+\\.)+[a-zA-Z]{2,}(?:\\/[^\\s<]*)?)/gi;\nconst DEFAULT_ALLOWED_TLDS = new Set([\n 'com',\n 'cn',\n 'net',\n 'org',\n 'io',\n 'co',\n 'edu',\n 'gov',\n 'ai',\n 'app',\n 'dev',\n 'me',\n 'info',\n 'biz',\n 'tech',\n 'cc',\n 'tv',\n 'xyz',\n 'top',\n 'vip',\n 'pro',\n 'store',\n 'site',\n 'online',\n 'cloud',\n]);\n\nexport const websiteValidator = (\n url: string,\n needProtocol: boolean = true,\n needHost: boolean = true,\n allowedTlds?: string[]\n): boolean => {\n if (!url || typeof url !== 'string') return false;\n const trimmed = url.trim();\n if (!trimmed) return false;\n\n const hasProtocol = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(trimmed);\n if (needProtocol && !hasProtocol) return false;\n\n const normalized = hasProtocol ? trimmed : `https://${trimmed}`;\n\n try {\n const parsed = new URL(normalized);\n const protocol = parsed.protocol.toLowerCase();\n if (protocol !== 'http:' && protocol !== 'https:') return false;\n\n if (needHost) {\n const host = parsed.hostname.toLowerCase();\n if (!host) return false;\n if (host === 'localhost') return true;\n if (/^\\d{1,3}(\\.\\d{1,3}){3}$/.test(host)) {\n return host.split('.').every((segment) => {\n const num = Number(segment);\n return Number.isInteger(num) && num >= 0 && num <= 255;\n });\n }\n if (!DOMAIN_REGEX.test(host)) return false;\n const tld = host.split('.').pop() || '';\n const tldSet = allowedTlds\n ? new Set(allowedTlds.map((item) => item.toLowerCase()))\n : DEFAULT_ALLOWED_TLDS;\n if (!tldSet.has(tld)) return false;\n }\n return true;\n } catch {\n return false;\n }\n};\n\nconst trimTrailingPunctuation = (value: string): { core: string; suffix: string } => {\n const match = value.match(/^(.*?)([),.;!?]+)?$/);\n return {\n core: match?.[1] || value,\n suffix: match?.[2] || '',\n };\n};\n\nconst tokenizeText = (\n text: string,\n options?: LinkifyOptions\n): TextToken[] => {\n if (!text) return [];\n\n const tokens: TextToken[] = [];\n let lastIndex = 0;\n const regex = new RegExp(URL_CANDIDATE_REGEX);\n let match = regex.exec(text);\n\n while (match) {\n const matchedText = match[0];\n const start = match.index;\n const end = start + matchedText.length;\n\n if (start > lastIndex) {\n tokens.push({ type: 'text', text: text.slice(lastIndex, start) });\n }\n\n const { core, suffix } = trimTrailingPunctuation(matchedText);\n const href = /^[a-zA-Z][a-zA-Z\\d+\\-.]*:\\/\\//.test(core)\n ? core\n : `https://${core}`;\n const defaultIsValid = websiteValidator(\n core,\n options?.needProtocol ?? false,\n options?.needHost ?? true,\n options?.allowedTlds\n );\n const isValid = options?.validate ? options.validate(href) : defaultIsValid;\n\n if (isValid && core) {\n tokens.push({ type: 'url', text: core, href });\n if (suffix) {\n tokens.push({ type: 'text', text: suffix });\n }\n } else {\n tokens.push({ type: 'text', text: matchedText });\n }\n\n lastIndex = end;\n match = regex.exec(text);\n }\n\n if (lastIndex < text.length) {\n tokens.push({ type: 'text', text: text.slice(lastIndex) });\n }\n\n return tokens;\n};\n\nconst escapeHtml = (value: string): string =>\n value\n .replace(/&/g, '&amp;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&#39;');\n\nconst ZWSP = '\\u200B';\nconst stripEditorArtifacts = (value: string): string =>\n value.replace(new RegExp(ZWSP, 'g'), '');\n\nconst renderTokensAsHtml = (\n text: string,\n options?: LinkifyOptions,\n disabled?: boolean\n): string => {\n const tokens = tokenizeText(text, options);\n if (tokens.length === 0) return '';\n\n const html = tokens\n .map((token) => {\n if (token.type === 'text') {\n return escapeHtml(token.text);\n }\n\n const classAttr = options?.className ? ` class=\"${options.className}\"` : '';\n const pointerEvents = disabled ? 'pointer-events: none;' : '';\n return `<a href=\"${escapeHtml(token.href)}\" target=\"_blank\" rel=\"noopener noreferrer\"${classAttr} style=\"color: #2563EB; text-decoration: underline; ${pointerEvents}\">${escapeHtml(token.text)}</a>`;\n })\n .join('');\n\n // contentEditable 在末尾是换行时可能吞掉视觉换行,补一个零宽字符占位\n if (text.endsWith('\\n')) {\n return `${html}<span data-aha-zwsp=\"true\">${ZWSP}</span>`;\n }\n return html;\n};\n\nconst getCaretOffset = (container: HTMLElement): number => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return 0;\n\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer)) return 0;\n\n const preRange = range.cloneRange();\n preRange.selectNodeContents(container);\n preRange.setEnd(range.startContainer, range.startOffset);\n return stripEditorArtifacts(preRange.toString()).length;\n};\n\nconst setCaretOffset = (container: HTMLElement, offset: number): void => {\n const range = document.createRange();\n const selection = window.getSelection();\n if (!selection) return;\n\n let remaining = Math.max(0, offset);\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_TEXT);\n let currentNode = walker.nextNode();\n\n while (currentNode) {\n const rawText = currentNode.textContent || '';\n let visibleCount = 0;\n let targetOffsetInNode = -1;\n for (let i = 0; i < rawText.length; i += 1) {\n if (rawText[i] !== ZWSP) {\n visibleCount += 1;\n }\n if (visibleCount === remaining) {\n targetOffsetInNode = i + 1;\n break;\n }\n }\n\n if (remaining === 0) {\n range.setStart(currentNode, 0);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n if (targetOffsetInNode !== -1) {\n range.setStart(currentNode, targetOffsetInNode);\n range.collapse(true);\n selection.removeAllRanges();\n selection.addRange(range);\n return;\n }\n\n remaining -= visibleCount;\n currentNode = walker.nextNode();\n }\n\n range.selectNodeContents(container);\n range.collapse(false);\n selection.removeAllRanges();\n selection.addRange(range);\n};\n\nconst getSelectionOffsets = (\n container: HTMLElement\n): { start: number; end: number } | null => {\n const selection = window.getSelection();\n if (!selection || selection.rangeCount === 0) return null;\n const range = selection.getRangeAt(0);\n if (!container.contains(range.startContainer) || !container.contains(range.endContainer)) {\n return null;\n }\n\n const startRange = range.cloneRange();\n startRange.selectNodeContents(container);\n startRange.setEnd(range.startContainer, range.startOffset);\n\n const endRange = range.cloneRange();\n endRange.selectNodeContents(container);\n endRange.setEnd(range.endContainer, range.endOffset);\n\n return {\n start: stripEditorArtifacts(startRange.toString()).length,\n end: stripEditorArtifacts(endRange.toString()).length,\n };\n};\n\nconst Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>(\n (\n {\n disabled = false,\n error = false,\n readOnly = false,\n showCount = false,\n maxLength,\n className = '',\n style,\n placeholder,\n value,\n defaultValue,\n rows = 3,\n autoSize = false,\n onChange,\n onFocus,\n onBlur,\n linkify = false,\n linkifyOptions,\n label,\n required,\n hintText,\n helpIcon,\n ...restProps\n },\n ref\n ) => {\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const editableRef = useRef<HTMLDivElement>(null);\n const isComposingRef = useRef(false);\n const caretOffsetRef = useRef<number | null>(null);\n const [internalValue, setInternalValue] = React.useState(\n defaultValue || value || ''\n );\n const [focused, setFocused] = React.useState(false);\n const [height, setHeight] = React.useState<number | undefined>(undefined);\n\n // 合并 ref(仅原生 textarea 模式)\n useEffect(() => {\n if (typeof ref === 'function') {\n ref(linkify ? null : textareaRef.current);\n } else if (ref) {\n (ref as React.MutableRefObject<HTMLTextAreaElement | null>).current =\n linkify ? null : textareaRef.current;\n }\n }, [ref, linkify]);\n\n // 受控/非受控处理\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n const currentLength = String(currentValue || '').length;\n\n const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n if (!isControlled) {\n setInternalValue(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleFocus = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(true);\n onFocus?.(e);\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n setFocused(false);\n onBlur?.(e);\n };\n\n const getMaxLengthValue = useMemo(\n () => (typeof maxLength === 'number' ? maxLength : undefined),\n [maxLength]\n );\n\n // 自动调整高度(原生 textarea)\n useEffect(() => {\n if (!linkify && autoSize && textareaRef.current) {\n const textarea = textareaRef.current;\n const minRows =\n typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows =\n typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n // 重置高度以获取正确的 scrollHeight\n textarea.style.height = 'auto';\n const scrollHeight = textarea.scrollHeight;\n\n // 计算行高(假设每行约 22px,根据字体大小调整)\n const lineHeight = parseInt(\n window.getComputedStyle(textarea).lineHeight || '22',\n 10\n );\n const minHeight = minRows * lineHeight;\n const maxHeight = maxRows ? maxRows * lineHeight : undefined;\n\n let newHeight = Math.max(scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n\n textarea.style.height = `${newHeight}px`;\n setHeight(newHeight);\n }\n }, [currentValue, autoSize, linkify]);\n\n // 自动调整高度(linkify + contentEditable)\n useEffect(() => {\n if (!linkify || !autoSize || !editableRef.current) return;\n const editable = editableRef.current;\n const minRows = typeof autoSize === 'object' ? autoSize.minRows || 1 : 1;\n const maxRows = typeof autoSize === 'object' ? autoSize.maxRows : undefined;\n\n const lineHeight = parseInt(\n window.getComputedStyle(editable).lineHeight || '24',\n 10\n );\n const minHeight = minRows * lineHeight + 24;\n const maxHeight = maxRows ? maxRows * lineHeight + 24 : undefined;\n\n editable.style.height = 'auto';\n let newHeight = Math.max(editable.scrollHeight, minHeight);\n if (maxHeight) {\n newHeight = Math.min(newHeight, maxHeight);\n }\n editable.style.height = `${newHeight}px`;\n editable.style.overflowY = maxHeight && editable.scrollHeight > maxHeight ? 'auto' : 'hidden';\n setHeight(newHeight);\n }, [autoSize, currentValue, linkify]);\n\n useLayoutEffect(() => {\n if (!linkify || !editableRef.current || isComposingRef.current) return;\n const editable = editableRef.current;\n const isActive = document.activeElement === editable;\n const fallbackOffset = isActive ? getCaretOffset(editable) : 0;\n const caretOffset = caretOffsetRef.current ?? fallbackOffset;\n const nextHtml = renderTokensAsHtml(\n String(currentValue || ''),\n linkifyOptions,\n disabled\n );\n\n if (editable.innerHTML !== nextHtml) {\n editable.innerHTML = nextHtml;\n }\n\n if (isActive) {\n const maxOffset = String(currentValue || '').length;\n setCaretOffset(editable, Math.min(caretOffset, maxOffset));\n }\n caretOffsetRef.current = null;\n }, [currentValue, disabled, linkify, linkifyOptions]);\n\n const notifyChange = (nextValue: string) => {\n const syntheticEvent = {\n target: { value: nextValue },\n currentTarget: { value: nextValue },\n } as React.ChangeEvent<HTMLTextAreaElement>;\n onChange?.(syntheticEvent);\n };\n\n const handleEditableInput = () => {\n if (!editableRef.current || isComposingRef.current) return;\n caretOffsetRef.current = getCaretOffset(editableRef.current);\n const rawValue = stripEditorArtifacts(editableRef.current.textContent || '');\n const nextValue = getMaxLengthValue ? rawValue.slice(0, getMaxLengthValue) : rawValue;\n\n if (!isControlled) {\n setInternalValue(nextValue);\n }\n notifyChange(nextValue);\n };\n\n const handleEditablePaste = (e: React.ClipboardEvent<HTMLDivElement>) => {\n e.preventDefault();\n if (readOnly || disabled) return;\n\n const pastedText = e.clipboardData.getData('text/plain');\n const currentText = String(currentValue || '');\n const selection = window.getSelection();\n let nextText = `${currentText}${pastedText}`;\n let caretOffset = currentText.length + pastedText.length;\n\n if (\n selection &&\n selection.rangeCount > 0 &&\n editableRef.current?.contains(selection.anchorNode)\n ) {\n const startOffset = getCaretOffset(editableRef.current);\n const endOffset = (() => {\n const range = selection.getRangeAt(0);\n const preRange = range.cloneRange();\n preRange.selectNodeContents(editableRef.current);\n preRange.setEnd(range.endContainer, range.endOffset);\n return preRange.toString().length;\n })();\n nextText =\n currentText.slice(0, startOffset) +\n pastedText +\n currentText.slice(endOffset);\n caretOffset = startOffset + pastedText.length;\n }\n\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n caretOffset = Math.min(caretOffset, nextText.length);\n }\n caretOffsetRef.current = caretOffset;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const handleEditableKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n if (e.key !== 'Enter' || e.nativeEvent.isComposing) return;\n if (disabled || readOnly) return;\n if (!editableRef.current) return;\n\n e.preventDefault();\n const currentText = String(currentValue || '');\n const offsets = getSelectionOffsets(editableRef.current);\n const start = offsets?.start ?? currentText.length;\n const end = offsets?.end ?? start;\n\n let nextText = `${currentText.slice(0, start)}\\n${currentText.slice(end)}`;\n if (getMaxLengthValue) {\n nextText = nextText.slice(0, getMaxLengthValue);\n }\n\n const nextCaret = Math.min(start + 1, nextText.length);\n caretOffsetRef.current = nextCaret;\n\n if (!isControlled) {\n setInternalValue(nextText);\n }\n notifyChange(nextText);\n };\n\n const SHADOW_XS = 'var(--shadow-xs)';\n\n const getFocusStyles = (): React.CSSProperties => {\n if (disabled) return { border: '1px solid var(--color-border-disabled)', boxShadow: SHADOW_XS, outline: 'none' };\n if (error && focused) return { border: '1px solid var(--color-border-error)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-error)', outlineOffset: '-2px' };\n if (error) return { border: '1px solid var(--color-border-error_subtle)', boxShadow: SHADOW_XS, outline: 'none' };\n if (focused) return { border: '1px solid var(--color-border-brand)', boxShadow: SHADOW_XS, outline: '2px solid var(--color-border-brand)', outlineOffset: '-2px' };\n return { border: '1px solid var(--color-border-primary)', boxShadow: SHADOW_XS, outline: 'none' };\n };\n\n const baseStyles: React.CSSProperties = {\n width: '100%',\n boxSizing: 'border-box',\n fontFamily: 'var(--font-family-body)',\n borderRadius: 'var(--radius-md)',\n ...getFocusStyles(),\n backgroundColor:\n disabled || readOnly\n ? 'var(--color-bg-disabled_subtle)'\n : 'var(--color-bg-primary)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-primary)',\n fontSize: 'var(--font-size-text-md)',\n fontWeight: 400,\n lineHeight: 'var(--line-height-text-md)',\n padding: '12px 14px',\n transition: 'border-color 0.15s ease, box-shadow 0.15s ease, outline-color 0.15s ease',\n resize: autoSize || linkify ? 'none' : 'vertical',\n cursor: disabled ? 'not-allowed' : 'text',\n WebkitAppearance: 'none',\n appearance: 'none',\n ...(height !== undefined && autoSize ? { height: `${height}px` } : {}),\n ...style,\n };\n\n const placeholderStyles = `\n .aha-textarea-wrapper textarea::placeholder {\n color: var(--color-text-placeholder);\n font-size: var(--font-size-text-md);\n font-weight: 400;\n opacity: 1;\n }\n .aha-textarea-wrapper textarea::-webkit-input-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea::-moz-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea:-ms-input-placeholder { color: var(--color-text-placeholder); }\n .aha-textarea-wrapper textarea {\n -webkit-tap-highlight-color: transparent;\n -webkit-touch-callout: none;\n touch-action: manipulation;\n }\n .aha-textarea-wrapper .aha-textarea-editable {\n white-space: pre-wrap;\n word-break: break-word;\n }\n .aha-textarea-wrapper .aha-textarea-editable:empty::before {\n content: attr(data-placeholder);\n color: var(--color-text-placeholder);\n }\n .aha-textarea-wrapper .aha-textarea-editable a {\n color: #2563EB;\n }\n `;\n\n const textareaEl = (\n <>\n <style>{placeholderStyles}</style>\n <div\n className={`aha-textarea-wrapper ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n flexDirection: 'column',\n width: '100%',\n }}\n >\n {linkify ? (\n <div\n ref={editableRef}\n className=\"aha-textarea-editable\"\n contentEditable={!disabled && !readOnly}\n suppressContentEditableWarning\n role=\"textbox\"\n aria-multiline=\"true\"\n aria-disabled={disabled}\n data-placeholder={placeholder || ''}\n onInput={handleEditableInput}\n onPaste={handleEditablePaste}\n onKeyDown={handleEditableKeyDown}\n onFocus={(e) => handleFocus(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onBlur={(e) => handleBlur(e as unknown as React.FocusEvent<HTMLTextAreaElement>)}\n onCompositionStart={() => {\n isComposingRef.current = true;\n }}\n onCompositionEnd={() => {\n isComposingRef.current = false;\n handleEditableInput();\n }}\n style={{\n ...baseStyles,\n minHeight: autoSize ? undefined : `${rows * 24 + 24}px`,\n overflowY: autoSize ? 'hidden' : 'auto',\n }}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n />\n ) : (\n <textarea\n ref={textareaRef}\n value={currentValue}\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readOnly}\n rows={autoSize ? undefined : rows}\n maxLength={maxLength}\n onChange={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n style={baseStyles}\n autoComplete={restProps.autoComplete || 'off'}\n autoCorrect={restProps.autoCorrect || 'off'}\n autoCapitalize={restProps.autoCapitalize || 'off'}\n spellCheck={restProps.spellCheck || false}\n {...restProps}\n />\n )}\n {(showCount || maxLength) && (\n <div\n style={{\n display: 'flex',\n justifyContent: 'flex-end',\n marginTop: '4px',\n fontSize: 'var(--font-size-text-xs)',\n lineHeight: 'var(--line-height-text-xs)',\n color: disabled ? 'var(--color-text-disabled)' : 'var(--color-text-tertiary)',\n fontFamily: 'var(--font-family-body)',\n }}\n >\n {maxLength ? (\n <span>\n {currentLength} / {maxLength}\n </span>\n ) : (\n <span>{currentLength}</span>\n )}\n </div>\n )}\n </div>\n </>\n );\n\n if (!label && !hintText) return textareaEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={{\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n display: 'flex',\n alignItems: 'center',\n gap: '2px',\n }}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n {helpIcon && (\n <span style={{ marginLeft: '4px', display: 'inline-flex', alignItems: 'center', color: 'var(--color-fg-quaternary)' }}>\n {helpIcon}\n </span>\n )}\n </label>\n )}\n {textareaEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n }\n);\n\nTextarea.displayName = 'Textarea';\n\nexport default Textarea;\nexport { default as TextareaTags } from './TextareaTags';\nexport type { TextareaTagsProps } from './TextareaTags';\n\n","import React from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface SwitchProps {\n /** 是否选中 */\n checked?: boolean;\n /** 默认是否选中 */\n defaultChecked?: boolean;\n /** 是否禁用 */\n disabled?: boolean;\n /** 变化回调 */\n onChange?: (checked: boolean, event: React.MouseEvent) => void;\n /** 点击回调 */\n onClick?: (checked: boolean, event: React.MouseEvent) => void;\n /** 选中时的内容 */\n checkedChildren?: React.ReactNode;\n /** 非选中时的内容 */\n unCheckedChildren?: React.ReactNode;\n /** 尺寸 */\n size?: 'small' | 'default';\n /** 加载状态 */\n loading?: boolean;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n}\n\nconst Switch: React.FC<SwitchProps> = ({\n checked: controlledChecked,\n defaultChecked = false,\n disabled = false,\n onChange,\n onClick,\n checkedChildren,\n unCheckedChildren,\n size = 'default',\n loading = false,\n className = '',\n style,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const [internalChecked, setInternalChecked] = React.useState(defaultChecked);\n const isControlled = controlledChecked !== undefined;\n const checked = isControlled ? controlledChecked : internalChecked;\n\n const handleClick = (e: React.MouseEvent<HTMLButtonElement>) => {\n if (disabled || loading) return;\n\n const newChecked = !checked;\n if (!isControlled) {\n setInternalChecked(newChecked);\n }\n onChange?.(newChecked, e);\n onClick?.(newChecked, e);\n };\n\n // 尺寸配置\n const sizeConfig = {\n small: {\n width: '36px',\n height: '20px',\n thumbSize: '16px',\n thumbOffset: '2px',\n fontSize: '10px',\n },\n default: {\n width: '44px',\n height: '24px',\n thumbSize: '20px',\n thumbOffset: '2px',\n fontSize: '12px',\n },\n };\n\n const config = sizeConfig[size];\n const isChecked = checked || loading;\n\n // 背景色\n const backgroundColor = disabled\n ? '#E7E5E4'\n : isChecked\n ? primaryColor\n : '#F5F5F4';\n\n // 滑块位置 - 使用 left 定位更准确\n const thumbLeft = isChecked\n ? `calc(100% - ${config.thumbSize} - ${config.thumbOffset})`\n : config.thumbOffset;\n\n return (\n <button\n type=\"button\"\n role=\"switch\"\n aria-checked={checked}\n disabled={disabled || loading}\n onClick={handleClick}\n className={`aha-switch ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: isChecked ? 'flex-end' : 'flex-start',\n width: config.width,\n height: config.height,\n padding: '0',\n margin: '0',\n border: 'none',\n borderRadius: size === 'small' ? '10px' : '12px', // 圆角为高度的一半\n backgroundColor,\n cursor: disabled || loading ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n outline: 'none',\n boxSizing: 'border-box',\n ...style,\n }}\n >\n {/* 内容区域 */}\n {(checkedChildren || unCheckedChildren) && (\n <span\n style={{\n position: 'absolute',\n left: isChecked ? '6px' : 'auto',\n right: isChecked ? 'auto' : '6px',\n fontSize: config.fontSize,\n lineHeight: '1',\n color: '#FFFFFF',\n fontFamily: \"DM Sans, sans-serif\",\n fontWeight: 500,\n transition: 'opacity 0.2s',\n opacity: disabled ? 0.5 : 1,\n zIndex: 1,\n pointerEvents: 'none',\n }}\n >\n {isChecked ? checkedChildren : unCheckedChildren}\n </span>\n )}\n\n {/* 滑块 */}\n <span\n style={{\n position: 'absolute',\n left: thumbLeft,\n top: '50%',\n transform: 'translateY(-50%)',\n width: config.thumbSize,\n height: config.thumbSize,\n borderRadius: '50%',\n backgroundColor: '#FFFFFF',\n boxShadow: '0 2px 4px rgba(0, 0, 0, 0.2)',\n transition: 'left 0.2s, background-color 0.2s',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: 2,\n }}\n >\n {loading && (\n <svg\n width={size === 'small' ? '8' : '10'}\n height={size === 'small' ? '8' : '10'}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n style={{\n animation: 'spin 1s linear infinite',\n }}\n >\n <style>\n {`\n @keyframes spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n `}\n </style>\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"32\"\n opacity=\"0.3\"\n />\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeDasharray=\"32\"\n strokeDashoffset=\"24\"\n />\n </svg>\n )}\n </span>\n </button>\n );\n};\n\nSwitch.displayName = 'Switch';\n\nexport default Switch;\n\n","import React, { useState, useRef, useEffect, useCallback, useMemo } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useTheme } from '../../theme/ThemeContext';\n\n// 日期范围类型\nexport interface DateRange {\n startDate: Date | null;\n endDate: Date | null;\n}\n\n// 预设日期范围类型\nexport interface PresetRange {\n label: string;\n range: DateRange;\n}\n\n// 基础 Props(单个日期模式)\nexport interface DatePickerBaseProps {\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否显示错误状态 */\n error?: boolean;\n /** 占位符(单个日期模式) */\n placeholder?: string;\n /** 开始日期占位符(范围模式) */\n startPlaceholder?: string;\n /** 结束日期占位符(范围模式) */\n endPlaceholder?: string;\n /** 尺寸 */\n size?: 'small' | 'mediumSmall' | 'medium' | 'large';\n /** 是否允许清除 */\n allowClear?: boolean;\n /** 日期格式 */\n format?: string;\n /** 聚焦回调 */\n onFocus?: (e: React.FocusEvent) => void;\n /** 失焦回调 */\n onBlur?: (e: React.FocusEvent) => void;\n /** 下拉框打开回调 */\n onOpenChange?: (open: boolean) => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 下拉框类名 */\n dropdownClassName?: string;\n /** 下拉框样式 */\n dropdownStyle?: React.CSSProperties;\n /** 是否默认打开 */\n defaultOpen?: boolean;\n /** 是否打开(受控) */\n open?: boolean;\n /** 最小日期 */\n minDate?: Date;\n /** 最大日期 */\n maxDate?: Date;\n /** 分隔符(范围模式) */\n separator?: string;\n /** 预设日期范围列表(仅在范围模式下有效) */\n presetRanges?: PresetRange[] | boolean;\n /** 显示日历数量:1=单月,2=双月(仅在范围模式下有效,默认1) */\n calendarCount?: 1 | 2;\n /** 是否显示 Apply/Cancel 按钮(仅在范围模式下有效) */\n showApplyCancel?: boolean;\n /** Apply 按钮文本 */\n applyText?: string;\n /** Cancel 按钮文本 */\n cancelText?: string;\n /** Apply 按钮回调 */\n onApply?: (range: DateRange) => void;\n /** Cancel 按钮回调 */\n onCancel?: () => void;\n /** 是否显示选中的日期段(仅在范围模式下有效,默认false) */\n showSelectedRange?: boolean;\n /** 选中的开始日期段文本 */\n startSelectedRangeText?: string;\n /** 选中的结束日期段文本 */\n endSelectedRangeText?: string;\n /** 范围显示模式:'range'=显示两个输入框(xxx - xxx),'text'=显示一句话(仅在范围模式下有效,默认'range') */\n rangeDisplayMode?: 'range' | 'text';\n}\n\n// 单个日期模式 Props\nexport interface DatePickerSingleProps extends DatePickerBaseProps {\n /** 模式:单个日期 */\n mode?: 'date';\n /** 当前选中的值 */\n value?: Date | null;\n /** 默认选中的值 */\n defaultValue?: Date | null;\n /** 变化回调 */\n onChange?: (date: Date | null) => void;\n}\n\n// 日期范围模式 Props\nexport interface DatePickerRangeProps extends DatePickerBaseProps {\n /** 模式:日期范围 */\n mode: 'range';\n /** 当前选中的值 */\n value?: DateRange;\n /** 默认选中的值 */\n defaultValue?: DateRange;\n /** 变化回调 */\n onChange?: (range: DateRange) => void;\n}\n\n// 联合类型\nexport type DatePickerProps = DatePickerSingleProps | DatePickerRangeProps;\n\n// 月份名称\nconst monthNamesShort = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\nconst monthNamesFull = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\n\n// 格式化日期\nconst formatDate = (date: Date | null, format: string = 'YYYY-MM-DD'): string => {\n if (!date) return '';\n \n const year = date.getFullYear();\n const month = date.getMonth();\n const monthNum = String(month + 1).padStart(2, '0');\n const day = String(date.getDate()).padStart(2, '0');\n const dayNum = String(date.getDate());\n \n // 使用特殊占位符避免替换冲突\n // 使用不常见的 Unicode 私有区域字符作为占位符\n const PLACEHOLDER_YYYY = '\\uE000';\n const PLACEHOLDER_YY = '\\uE001';\n const PLACEHOLDER_MMMM = '\\uE002';\n const PLACEHOLDER_MMM = '\\uE003';\n const PLACEHOLDER_MM = '\\uE004';\n const PLACEHOLDER_M = '\\uE005';\n const PLACEHOLDER_DD = '\\uE006';\n const PLACEHOLDER_D = '\\uE007';\n \n // 按从长到短的顺序替换,使用占位符避免冲突\n let result = format\n // 先替换所有格式标记为占位符\n .replace(/YYYY/g, PLACEHOLDER_YYYY)\n .replace(/YY/g, PLACEHOLDER_YY)\n .replace(/MMMM/g, PLACEHOLDER_MMMM)\n .replace(/MMM/g, PLACEHOLDER_MMM)\n .replace(/MM/g, PLACEHOLDER_MM)\n .replace(/DD/g, PLACEHOLDER_DD)\n .replace(/D/g, PLACEHOLDER_D)\n .replace(/M/g, PLACEHOLDER_M)\n // 然后将占位符替换为实际值\n .replace(new RegExp(PLACEHOLDER_YYYY, 'g'), String(year))\n .replace(new RegExp(PLACEHOLDER_YY, 'g'), String(year).slice(-2))\n .replace(new RegExp(PLACEHOLDER_MMMM, 'g'), monthNamesFull[month])\n .replace(new RegExp(PLACEHOLDER_MMM, 'g'), monthNamesShort[month])\n .replace(new RegExp(PLACEHOLDER_MM, 'g'), monthNum)\n .replace(new RegExp(PLACEHOLDER_M, 'g'), String(month + 1))\n .replace(new RegExp(PLACEHOLDER_DD, 'g'), day)\n .replace(new RegExp(PLACEHOLDER_D, 'g'), dayNum);\n \n return result;\n};\n\n// 获取月份的第一天是星期几(0=周日, 1=周一, ...)\nconst getFirstDayOfMonth = (year: number, month: number): number => {\n return new Date(year, month, 1).getDay();\n};\n\n// 获取月份的天数\nconst getDaysInMonth = (year: number, month: number): number => {\n return new Date(year, month + 1, 0).getDate();\n};\n\n// 判断两个日期是否是同一天\nconst isSameDay = (date1: Date | null, date2: Date | null): boolean => {\n if (!date1 || !date2) return false;\n return (\n date1.getFullYear() === date2.getFullYear() &&\n date1.getMonth() === date2.getMonth() &&\n date1.getDate() === date2.getDate()\n );\n};\n\n// 判断日期是否在范围内\nconst isDateInRange = (date: Date, minDate?: Date, maxDate?: Date): boolean => {\n if (minDate && date < minDate) return false;\n if (maxDate && date > maxDate) return false;\n return true;\n};\n\n// 判断日期是否在选择的范围内\nconst isDateInSelectedRange = (date: Date, startDate: Date | null, endDate: Date | null): boolean => {\n if (!startDate || !endDate) return false;\n const dateTime = date.getTime();\n const startTime = startDate.getTime();\n const endTime = endDate.getTime();\n return dateTime >= startTime && dateTime <= endTime;\n};\n\n// 判断日期是否是范围的开始或结束\nconst isRangeEdge = (date: Date, startDate: Date | null, endDate: Date | null): 'start' | 'end' | 'both' | null => {\n if (!startDate || !endDate) return null;\n const isStart = isSameDay(date, startDate);\n const isEnd = isSameDay(date, endDate);\n if (isStart && isEnd) return 'both';\n if (isStart) return 'start';\n if (isEnd) return 'end';\n return null;\n};\n\nconst DatePicker: React.FC<DatePickerProps> = (props) => {\n const {\n mode = 'date',\n disabled = false,\n error = false,\n placeholder = 'Select date',\n startPlaceholder = 'Start date',\n endPlaceholder = 'End date',\n size = 'medium',\n allowClear = false,\n format = mode === 'range' ? 'MMM D, YYYY' : 'YYYY-MM-DD',\n onFocus,\n onBlur,\n onOpenChange,\n className = '',\n style,\n dropdownClassName = '',\n dropdownStyle,\n defaultOpen = false,\n open: controlledOpen,\n minDate,\n maxDate,\n separator = ' - ',\n presetRanges = false,\n calendarCount = 1,\n showApplyCancel = false,\n applyText = 'Apply',\n cancelText = 'Cancel',\n onApply,\n onCancel,\n showSelectedRange = false,\n startSelectedRangeText = 'Select dates',\n endSelectedRangeText = 'Select dates',\n rangeDisplayMode = 'range',\n } = props;\n\n const { primaryColor = '#FB6011' } = useTheme();\n const isRangeMode = mode === 'range';\n\n // 单个日期模式的状态\n const [internalSingleValue, setInternalSingleValue] = useState<Date | null>(() => {\n if (mode === 'date' && 'defaultValue' in props) {\n const val = props.defaultValue as Date | null | undefined;\n return val || null;\n }\n return null;\n });\n \n // 范围模式的状态\n const [internalRangeValue, setInternalRangeValue] = useState<DateRange>(() => {\n if (mode === 'range' && 'defaultValue' in props) {\n const val = props.defaultValue as DateRange | undefined;\n return val || { startDate: null, endDate: null };\n }\n return { startDate: null, endDate: null };\n });\n\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [selectingStart, setSelectingStart] = useState(true); // 范围模式:true=选择开始日期, false=选择结束日期\n const [tempRangeValue, setTempRangeValue] = useState<DateRange | null>(null); // 临时范围值(用于 Apply/Cancel)\n const [currentMonth, setCurrentMonth] = useState(() => {\n if (mode === 'date' && 'value' in props && props.value) {\n const date = props.value as Date | null;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n if (mode === 'range' && 'value' in props && props.value) {\n const range = props.value as DateRange;\n const date = range.startDate || range.endDate;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n if (mode === 'date' && 'defaultValue' in props && props.defaultValue) {\n const date = props.defaultValue as Date | null;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n if (mode === 'range' && 'defaultValue' in props && props.defaultValue) {\n const range = props.defaultValue as DateRange;\n const date = range.startDate || range.endDate;\n if (date) {\n return { year: date.getFullYear(), month: date.getMonth() };\n }\n }\n const now = new Date();\n return { year: now.getFullYear(), month: now.getMonth() };\n });\n \n // 第二个月份(用于双月显示)\n const [secondMonth, setSecondMonth] = useState<{ year: number; month: number } | null>(() => {\n if (calendarCount === 2 && isRangeMode) {\n const nextMonth = new Date(currentMonth.year, currentMonth.month + 1, 1);\n return { year: nextMonth.getFullYear(), month: nextMonth.getMonth() };\n }\n return null;\n });\n \n // 当第一个月份变化时,更新第二个月份\n useEffect(() => {\n if (calendarCount === 2 && isRangeMode) {\n const nextMonth = new Date(currentMonth.year, currentMonth.month + 1, 1);\n setSecondMonth({ year: nextMonth.getFullYear(), month: nextMonth.getMonth() });\n } else {\n setSecondMonth(null);\n }\n }, [currentMonth, calendarCount, isRangeMode]);\n\n const pickerRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const startInputRef = useRef<HTMLInputElement>(null);\n const endInputRef = useRef<HTMLInputElement>(null);\n const dropdownRef = useRef<HTMLDivElement>(null);\n const [dropdownPosition, setDropdownPosition] = useState<{ top: number; left: number; width: number; placement?: 'top' | 'bottom' } | null>(null);\n const hasOpenedRef = useRef(false); // 跟踪日历是否已经打开过\n const placementDeterminedRef = useRef(false); // 跟踪位置方向是否已确定\n const determinedPlacementRef = useRef<'top' | 'bottom' | null>(null); // 已确定的位置方向\n\n // 判断是否受控\n const isControlled = 'value' in props && props.value !== undefined;\n const isOpenControlled = controlledOpen !== undefined;\n \n // 当前值\n const currentSingleValue: Date | null = isRangeMode\n ? null\n : isControlled && mode === 'date' && 'value' in props\n ? (props.value as Date | null)\n : internalSingleValue;\n \n const currentRangeValue: DateRange = !isRangeMode\n ? { startDate: null, endDate: null }\n : isControlled && mode === 'range' && 'value' in props\n ? (props.value as DateRange) || { startDate: null, endDate: null }\n : internalRangeValue;\n\n const isOpen = isOpenControlled ? controlledOpen : internalOpen;\n\n // 当日历首次打开时,如果当前月份与选中日期月份不一致,才更新月份视图\n // 之后用户切换月份后,即使选择日期,也不应该自动更新月份\n useEffect(() => {\n if (isOpen && !hasOpenedRef.current) {\n // 首次打开时,根据选中日期设置月份\n if (isRangeMode) {\n const date = currentRangeValue.startDate || currentRangeValue.endDate;\n if (date) {\n const dateYear = date.getFullYear();\n const dateMonth = date.getMonth();\n setCurrentMonth({\n year: dateYear,\n month: dateMonth,\n });\n } else {\n // 如果没有选中日期,设置为当前月份\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n } else {\n if (currentSingleValue) {\n const dateYear = currentSingleValue.getFullYear();\n const dateMonth = currentSingleValue.getMonth();\n setCurrentMonth({\n year: dateYear,\n month: dateMonth,\n });\n } else {\n // 如果没有选中日期,设置为当前月份\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n hasOpenedRef.current = true;\n } else if (!isOpen) {\n // 日历关闭时,重置标记,下次打开时重新判断\n hasOpenedRef.current = false;\n }\n }, [isOpen, currentSingleValue, currentRangeValue, isRangeMode]);\n\n // 计算下拉框位置\n useEffect(() => {\n if (isOpen && pickerRef.current) {\n // 重置位置方向确定标记\n placementDeterminedRef.current = false;\n determinedPlacementRef.current = null;\n \n const updatePosition = () => {\n if (pickerRef.current) {\n const rect = pickerRef.current.getBoundingClientRect();\n const gap = 4; // 下拉框与输入框的间距\n \n // 如果位置方向已经确定,只更新坐标,不改变方向\n if (placementDeterminedRef.current && determinedPlacementRef.current !== null) {\n const placement = determinedPlacementRef.current;\n let top: number;\n \n if (dropdownRef.current) {\n const dropdownHeight = dropdownRef.current.offsetHeight;\n if (placement === 'top') {\n top = rect.top + window.scrollY - dropdownHeight - gap;\n } else {\n top = rect.bottom + window.scrollY + gap;\n }\n } else {\n // 如果下拉框还没渲染,使用默认计算\n top = placement === 'top' \n ? rect.top + window.scrollY - 400 - gap // 估算高度\n : rect.bottom + window.scrollY + gap;\n }\n \n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement,\n });\n return;\n }\n \n // 首次打开时,计算位置方向\n // 先设置为下方位置(默认)\n let top = rect.bottom + window.scrollY + gap;\n let placement: 'top' | 'bottom' = 'bottom';\n \n // 计算位置的函数\n const calculatePosition = () => {\n if (dropdownRef.current) {\n const dropdownHeight = dropdownRef.current.offsetHeight;\n const viewportHeight = window.innerHeight;\n const spaceBelow = viewportHeight - rect.bottom - gap;\n const spaceAbove = rect.top - gap;\n \n // 如果下方空间不够,但上方空间足够,则显示在上方\n if (spaceBelow < dropdownHeight && spaceAbove >= dropdownHeight) {\n top = rect.top + window.scrollY - dropdownHeight - gap;\n placement = 'top';\n } else if (spaceBelow < dropdownHeight && spaceAbove < dropdownHeight) {\n // 如果上下都不够,选择空间更大的那一侧\n if (spaceAbove > spaceBelow) {\n top = rect.top + window.scrollY - dropdownHeight - gap;\n placement = 'top';\n }\n // 否则保持下方(即使可能被裁剪,也比上方好)\n }\n \n // 确定位置方向\n placementDeterminedRef.current = true;\n determinedPlacementRef.current = placement;\n }\n \n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement,\n });\n };\n \n // 先设置默认位置,让下拉框先渲染\n setDropdownPosition({\n top,\n left: rect.left + window.scrollX,\n width: rect.width,\n placement,\n });\n \n // 等待下拉框渲染后,重新计算位置\n // 使用双重 requestAnimationFrame 确保 DOM 已完全渲染\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n calculatePosition();\n });\n });\n }\n };\n\n updatePosition();\n\n window.addEventListener('resize', updatePosition);\n window.addEventListener('scroll', updatePosition, true);\n\n return () => {\n window.removeEventListener('resize', updatePosition);\n window.removeEventListener('scroll', updatePosition, true);\n };\n } else {\n setDropdownPosition(null);\n // 关闭时重置标记\n placementDeterminedRef.current = false;\n determinedPlacementRef.current = null;\n }\n }, [isOpen]);\n\n // 点击外部关闭\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent | TouchEvent) => {\n const target = event.target as Node;\n if (\n pickerRef.current &&\n !pickerRef.current.contains(target) &&\n dropdownRef.current &&\n !dropdownRef.current.contains(target)\n ) {\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n };\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside, true);\n document.addEventListener('touchstart', handleClickOutside, true);\n return () => {\n document.removeEventListener('mousedown', handleClickOutside, true);\n document.removeEventListener('touchstart', handleClickOutside, true);\n };\n }\n }, [isOpen, isOpenControlled, onOpenChange]);\n\n // 处理日期选择(单个日期模式)\n const handleSelectSingleDate = useCallback((date: Date) => {\n if (!isDateInRange(date, minDate, maxDate)) return;\n\n if (!isControlled) {\n setInternalSingleValue(date);\n }\n if (mode === 'date' && 'onChange' in props) {\n (props.onChange as (date: Date | null) => void)?.(date);\n }\n\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }, [isControlled, isOpenControlled, mode, props, onOpenChange, minDate, maxDate]);\n\n // 处理日期选择(范围模式)\n const handleSelectRangeDate = useCallback((date: Date) => {\n if (!isDateInRange(date, minDate, maxDate)) return;\n\n // 使用临时值或当前值\n const workingRange = showApplyCancel && tempRangeValue ? tempRangeValue : currentRangeValue;\n let newRange: DateRange;\n\n // 如果已经有完整的日期范围(开始和结束日期都存在),重新点击日期时清空之前的选择\n if (workingRange.startDate && workingRange.endDate) {\n // 清空之前的选择,将新点击的日期作为新的开始日期\n newRange = {\n startDate: date,\n endDate: null,\n };\n setSelectingStart(false); // 下一步选择结束日期\n } else if (selectingStart) {\n // 选择开始日期\n if (workingRange.endDate && date > workingRange.endDate) {\n // 如果选择的开始日期大于结束日期,交换它们\n newRange = {\n startDate: workingRange.endDate,\n endDate: date,\n };\n setSelectingStart(false);\n } else {\n newRange = {\n startDate: date,\n endDate: workingRange.endDate,\n };\n // 如果已经有结束日期,完成选择\n if (workingRange.endDate) {\n setSelectingStart(true);\n if (!showApplyCancel) {\n // 如果没有 Apply/Cancel 按钮,直接关闭\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n } else {\n setSelectingStart(false);\n }\n }\n } else {\n // 选择结束日期\n if (workingRange.startDate && date < workingRange.startDate) {\n // 如果选择的结束日期小于开始日期,交换它们\n newRange = {\n startDate: date,\n endDate: workingRange.startDate,\n };\n setSelectingStart(false);\n } else {\n newRange = {\n startDate: workingRange.startDate,\n endDate: date,\n };\n // 完成选择\n setSelectingStart(true);\n if (!showApplyCancel) {\n // 如果没有 Apply/Cancel 按钮,直接关闭\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n }\n }\n\n if (showApplyCancel) {\n // 使用临时值\n setTempRangeValue(newRange);\n } else {\n // 直接更新\n if (!isControlled) {\n setInternalRangeValue(newRange);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(newRange);\n }\n }\n }, [selectingStart, currentRangeValue, tempRangeValue, showApplyCancel, isControlled, isOpenControlled, mode, props, onOpenChange, minDate, maxDate]);\n\n // 处理清除\n const handleClear = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (isRangeMode) {\n const newRange: DateRange = { startDate: null, endDate: null };\n if (!isControlled) {\n setInternalRangeValue(newRange);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(newRange);\n }\n setSelectingStart(true);\n } else {\n if (!isControlled) {\n setInternalSingleValue(null);\n }\n if (mode === 'date' && 'onChange' in props) {\n (props.onChange as (date: Date | null) => void)?.(null);\n }\n }\n // 清空后,只有在日历关闭时才重置月份为当前月份\n // 如果日历是打开的,保持当前显示的月份不变\n if (!isOpen) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n };\n\n // 切换下拉框\n const handleToggle = () => {\n if (disabled) return;\n const newOpen = !isOpen;\n if (!isOpenControlled) {\n setInternalOpen(newOpen);\n }\n onOpenChange?.(newOpen);\n if (newOpen) {\n // 打开日历时,如果没有选中日期,设置为当前月份\n if (isRangeMode) {\n setSelectingStart(!currentRangeValue.startDate);\n // 初始化临时值\n if (showApplyCancel) {\n setTempRangeValue(currentRangeValue);\n }\n // 如果没有选中日期,设置为当前月份\n if (!currentRangeValue.startDate && !currentRangeValue.endDate) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n } else {\n // 如果没有选中日期,设置为当前月份\n if (!currentSingleValue) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n } else if (!newOpen && showApplyCancel) {\n // 关闭时重置临时值\n setTempRangeValue(null);\n }\n };\n \n // 处理 Apply 按钮\n const handleApply = () => {\n if (tempRangeValue) {\n if (!isControlled) {\n setInternalRangeValue(tempRangeValue);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(tempRangeValue);\n }\n onApply?.(tempRangeValue);\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n setTempRangeValue(null);\n }\n };\n \n // 处理 Cancel 按钮\n const handleCancel = () => {\n setTempRangeValue(null);\n onCancel?.();\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n };\n \n // 默认预设日期范围\n const defaultPresetRanges = useMemo(() => {\n const today = new Date();\n today.setHours(0, 0, 0, 0);\n \n // Last week: 从当前日期往前推7天(包含今天,共7天)\n const lastWeekEnd = new Date(today);\n const lastWeekStart = new Date(today);\n lastWeekStart.setDate(today.getDate() - 6); // 往前推6天,加上今天共7天\n \n // Last month: 从当前日期往前推一个月\n const lastMonthEnd = new Date(today);\n const lastMonthStart = new Date(today);\n const originalDate = today.getDate();\n lastMonthStart.setMonth(today.getMonth() - 1);\n // 如果往前推一个月后日期被调整了(比如3月31日往前推一个月变成3月3日,因为2月没有31日),\n // 说明原日期在上个月不存在,需要取上个月的最后一天\n if (lastMonthStart.getDate() !== originalDate) {\n // 设置为上个月的最后一天\n lastMonthStart.setDate(0);\n }\n \n // Last year: 从当前日期往前推一年\n const lastYearEnd = new Date(today);\n const lastYearStart = new Date(today);\n lastYearStart.setFullYear(today.getFullYear() - 1);\n \n return [\n { label: 'Last week', range: { startDate: lastWeekStart, endDate: lastWeekEnd } },\n { label: 'Last month', range: { startDate: lastMonthStart, endDate: lastMonthEnd } },\n { label: 'Last year', range: { startDate: lastYearStart, endDate: lastYearEnd } },\n ];\n }, []);\n\n // 预设日期范围列表\n const presetRangesList = useMemo(() => {\n if (Array.isArray(presetRanges)) {\n // 如果传入的是数组,直接使用\n return presetRanges;\n } else if (presetRanges === true) {\n // 如果传入的是 true,使用默认值\n return defaultPresetRanges;\n } else {\n // 如果传入的是 false 或 undefined,返回空数组\n return [];\n }\n }, [presetRanges, defaultPresetRanges]);\n\n // 是否显示预设日期范围\n const hasPresetRanges = presetRangesList.length > 0;\n \n // 处理预设范围选择\n const handlePresetRangeSelect = (range: DateRange) => {\n // 更新日历显示为开始日期的月份\n if (range.startDate) {\n const startYear = range.startDate.getFullYear();\n const startMonth = range.startDate.getMonth();\n setCurrentMonth({\n year: startYear,\n month: startMonth,\n });\n }\n \n if (showApplyCancel) {\n setTempRangeValue(range);\n } else {\n if (!isControlled) {\n setInternalRangeValue(range);\n }\n if (mode === 'range' && 'onChange' in props) {\n (props.onChange as (range: DateRange) => void)?.(range);\n }\n if (!isOpenControlled) {\n setInternalOpen(false);\n }\n onOpenChange?.(false);\n }\n };\n\n // 处理输入框聚焦\n const handleFocus = (e: React.FocusEvent) => {\n onFocus?.(e);\n };\n\n // 处理输入框失焦\n const handleBlur = (e: React.FocusEvent) => {\n onBlur?.(e);\n };\n\n // 处理开始日期输入框点击\n const handleStartInputClick = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!disabled) {\n setSelectingStart(true);\n if (!isOpen) {\n handleToggle();\n } else {\n // 如果日历已经打开,检查是否需要重置月份\n if (!currentRangeValue.startDate && !currentRangeValue.endDate) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n }\n };\n\n // 处理结束日期输入框点击\n const handleEndInputClick = (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!disabled) {\n setSelectingStart(false);\n if (!isOpen) {\n handleToggle();\n } else {\n // 如果日历已经打开,检查是否需要重置月份\n if (!currentRangeValue.startDate && !currentRangeValue.endDate) {\n const now = new Date();\n setCurrentMonth({\n year: now.getFullYear(),\n month: now.getMonth(),\n });\n }\n }\n }\n };\n\n // 上一个月\n const handlePrevMonth = () => {\n setCurrentMonth((prev) => {\n if (prev.month === 0) {\n return { year: prev.year - 1, month: 11 };\n }\n return { year: prev.year, month: prev.month - 1 };\n });\n };\n\n // 下一个月\n const handleNextMonth = () => {\n setCurrentMonth((prev) => {\n if (prev.month === 11) {\n return { year: prev.year + 1, month: 0 };\n }\n return { year: prev.year, month: prev.month + 1 };\n });\n };\n\n // 生成日历数据的辅助函数\n const generateCalendarData = useCallback((year: number, month: number) => {\n const daysInMonth = getDaysInMonth(year, month);\n const days: (Date | null)[] = [];\n\n // 只生成当前月的日期\n for (let day = 1; day <= daysInMonth; day++) {\n days.push(new Date(year, month, day));\n }\n\n return days;\n }, []);\n\n // 生成日历数据\n const calendarData = useMemo(() => {\n return generateCalendarData(currentMonth.year, currentMonth.month);\n }, [currentMonth, generateCalendarData]);\n \n // 生成第二个月份的日历数据\n const secondCalendarData = useMemo(() => {\n if (calendarCount === 2 && isRangeMode && secondMonth) {\n return generateCalendarData(secondMonth.year, secondMonth.month);\n }\n return null;\n }, [calendarCount, isRangeMode, secondMonth, generateCalendarData]);\n \n // 处理第二个月份的导航\n const handleSecondPrevMonth = () => {\n if (secondMonth) {\n setSecondMonth((prev) => {\n if (!prev) return null;\n if (prev.month === 0) {\n return { year: prev.year - 1, month: 11 };\n }\n return { year: prev.year, month: prev.month - 1 };\n });\n }\n };\n \n const handleSecondNextMonth = () => {\n if (secondMonth) {\n setSecondMonth((prev) => {\n if (!prev) return null;\n if (prev.month === 11) {\n return { year: prev.year + 1, month: 0 };\n }\n return { year: prev.year, month: prev.month + 1 };\n });\n }\n };\n\n // 尺寸样式\n const sizeStyles = {\n small: {\n height: '32px',\n paddingTop: '3px',\n paddingBottom: '3px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n mediumSmall: {\n height: '36px',\n paddingTop: '5px',\n paddingBottom: '5px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n medium: {\n height: '40px',\n paddingTop: '7px',\n paddingBottom: '7px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n large: {\n height: '48px',\n paddingTop: '11px',\n paddingBottom: '11px',\n fontSize: '16px',\n lineHeight: '24px',\n },\n };\n\n const showClear = allowClear && !disabled && (\n isRangeMode\n ? (currentRangeValue.startDate || currentRangeValue.endDate)\n : currentSingleValue\n );\n \n const singleDisplayValue = currentSingleValue ? formatDate(currentSingleValue, format) : '';\n const startDisplayValue = currentRangeValue.startDate ? formatDate(currentRangeValue.startDate, format) : '';\n const endDisplayValue = currentRangeValue.endDate ? formatDate(currentRangeValue.endDate, format) : '';\n \n // 计算范围文本显示值(当 rangeDisplayMode === 'text' 时使用)\n const rangeTextValue = useMemo(() => {\n if (!isRangeMode || rangeDisplayMode !== 'text') return '';\n \n // 默认格式化:如果两个日期都有,显示 \"Jan 10, 2025 - Jan 20, 2025\"\n // 如果只有一个日期,显示该日期\n // 如果都没有,返回空字符串\n if (currentRangeValue.startDate && currentRangeValue.endDate) {\n const startText = formatDate(currentRangeValue.startDate, 'MMM D, YYYY');\n const endText = formatDate(currentRangeValue.endDate, 'MMM D, YYYY');\n return `${startText} ${separator} ${endText}`;\n } else if (currentRangeValue.startDate) {\n return formatDate(currentRangeValue.startDate, 'MMM D, YYYY');\n } else if (currentRangeValue.endDate) {\n return formatDate(currentRangeValue.endDate, 'MMM D, YYYY');\n }\n return '';\n }, [isRangeMode, rangeDisplayMode, currentRangeValue, separator]);\n\n // 日历图标\n const CalendarIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M12.6667 2.66667H12V2C12 1.63181 11.7015 1.33333 11.3333 1.33333C10.9651 1.33333 10.6667 1.63181 10.6667 2V2.66667H5.33333V2C5.33333 1.63181 5.03486 1.33333 4.66667 1.33333C4.29848 1.33333 4 1.63181 4 2V2.66667H3.33333C2.59695 2.66667 2 3.26362 2 4V13.3333C2 14.0697 2.59695 14.6667 3.33333 14.6667H12.6667C13.403 14.6667 14 14.0697 14 13.3333V4C14 3.26362 13.403 2.66667 12.6667 2.66667ZM12.6667 13.3333H3.33333V7.33333H12.6667V13.3333ZM12.6667 6H3.33333V4H12.6667V6Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n\n // 清除图标\n const ClearIcon = () => (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n onClick={handleClear}\n style={{\n cursor: 'pointer',\n flexShrink: 0,\n color: '#78716C',\n }}\n >\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n\n // 下拉框动画样式\n const dropdownAnimationStyles = `\n @keyframes dropdownFadeIn {\n from {\n opacity: 0;\n transform: translateY(-8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n @keyframes dropdownFadeInTop {\n from {\n opacity: 0;\n transform: translateY(8px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n `;\n\n // 周几名称(周一开始)\n const weekDays = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];\n\n return (\n <>\n <style>{dropdownAnimationStyles}</style>\n <div\n ref={pickerRef}\n className={`aha-date-picker ${className}`}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n boxSizing: 'border-box',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '8px',\n border: `1px solid ${error ? '#F04438' : isOpen ? primaryColor : '#D7D3D0'}`,\n backgroundColor: disabled ? '#FAFAF9' : '#FFFFFF',\n cursor: disabled ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n paddingLeft: '40px', // 为日历图标留出空间\n paddingRight: showClear ? '30px' : '12px', // 为清除按钮留出空间(如果有)\n paddingTop: sizeStyles[size].paddingTop,\n paddingBottom: sizeStyles[size].paddingBottom,\n fontSize: sizeStyles[size].fontSize,\n lineHeight: sizeStyles[size].lineHeight,\n fontWeight: 400,\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n touchAction: 'manipulation',\n userSelect: 'none',\n ...style,\n }}\n onClick={handleToggle}\n onFocus={handleFocus}\n onBlur={handleBlur}\n tabIndex={disabled ? -1 : 0}\n >\n {/* 日历图标 */}\n <span\n style={{\n position: 'absolute',\n left: '12px',\n display: 'flex',\n alignItems: 'center',\n color: disabled ? '#98A2B3' : '#78716C',\n zIndex: 1,\n pointerEvents: 'none',\n }}\n >\n <CalendarIcon />\n </span>\n\n {/* 输入框内容 */}\n {isRangeMode ? (\n rangeDisplayMode === 'text' ? (\n // 文本模式:显示单个输入框,显示格式化后的范围文本\n <input\n ref={inputRef}\n type=\"text\"\n value={rangeTextValue}\n readOnly\n placeholder={placeholder}\n disabled={disabled}\n onClick={(e) => {\n e.stopPropagation();\n if (!disabled) {\n handleToggle();\n }\n }}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : (currentRangeValue.startDate || currentRangeValue.endDate) ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n ) : (\n // 范围模式:显示两个输入框\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n flex: 1,\n gap: '8px',\n minWidth: 0,\n }}\n >\n {/* 开始日期输入框 */}\n <input\n ref={startInputRef}\n type=\"text\"\n value={startDisplayValue}\n readOnly\n placeholder={startPlaceholder}\n disabled={disabled}\n onClick={handleStartInputClick}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : currentRangeValue.startDate ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n\n {/* 分隔符 */}\n <span\n style={{\n color: disabled ? '#98A2B3' : '#78716C',\n fontSize: '16px',\n flexShrink: 0,\n }}\n >\n {separator}\n </span>\n\n {/* 结束日期输入框 */}\n <input\n ref={endInputRef}\n type=\"text\"\n value={endDisplayValue}\n readOnly\n placeholder={endPlaceholder}\n disabled={disabled}\n onClick={handleEndInputClick}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : currentRangeValue.endDate ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n </div>\n )\n ) : (\n <input\n ref={inputRef}\n type=\"text\"\n value={singleDisplayValue}\n readOnly\n placeholder={placeholder}\n disabled={disabled}\n onClick={(e) => {\n e.stopPropagation();\n if (!disabled) {\n handleToggle();\n }\n }}\n style={{\n flex: 1,\n border: 'none',\n outline: 'none',\n background: 'transparent',\n fontSize: '16px',\n lineHeight: '24px',\n fontWeight: 400,\n color: disabled ? '#98A2B3' : currentSingleValue ? '#1C1917' : '#79716B',\n fontFamily: \"DM Sans, sans-serif\",\n minWidth: 0,\n cursor: disabled ? 'not-allowed' : 'pointer',\n WebkitAppearance: 'none',\n appearance: 'none',\n }}\n />\n )}\n\n {/* 右侧图标 */}\n {showClear && (\n <div\n style={{\n position: 'absolute',\n right: '10px',\n display: 'flex',\n alignItems: 'center',\n gap: '4px',\n }}\n >\n <ClearIcon />\n </div>\n )}\n </div>\n\n {/* 日历下拉框 */}\n {isOpen && dropdownPosition && createPortal(\n <div\n ref={dropdownRef}\n className={`aha-date-picker-dropdown ${dropdownClassName}`}\n style={{\n position: 'absolute',\n top: `${dropdownPosition.top}px`,\n left: `${dropdownPosition.left}px`,\n zIndex: 1050,\n backgroundColor: '#FFFFFF',\n borderRadius: '8px',\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.15)',\n border: '1px solid #E7E5E4',\n padding: '0',\n opacity: 0,\n transform: (dropdownPosition.placement || 'bottom') === 'top' ? 'translateY(8px)' : 'translateY(-8px)',\n animation: (dropdownPosition.placement || 'bottom') === 'top' \n ? 'dropdownFadeInTop 0.2s ease-out forwards' \n : 'dropdownFadeIn 0.2s ease-out forwards',\n display: 'flex',\n flexDirection: 'column',\n ...dropdownStyle,\n }}\n >\n {/* 内容区域 */}\n <div\n style={{\n display: 'flex',\n flex: 1,\n minHeight: 0,\n flexDirection: isRangeMode && hasPresetRanges && calendarCount === 1 ? 'column' : 'row',\n }}\n >\n {/* 预设日期范围列表(左侧 - 仅双月模式) */}\n {isRangeMode && hasPresetRanges && calendarCount === 2 && (\n <div\n style={{\n width: '140px',\n borderRight: '1px solid #E7E5E4',\n padding: '12px 0',\n backgroundColor: '#FFFFFF',\n borderTopLeftRadius: '8px',\n borderBottomLeftRadius: showApplyCancel ? '0' : '8px',\n }}\n >\n {presetRangesList.map((preset, idx) => {\n const isSelected = tempRangeValue\n ? isSameDay(preset.range.startDate, tempRangeValue.startDate) &&\n isSameDay(preset.range.endDate, tempRangeValue.endDate)\n : isSameDay(preset.range.startDate, currentRangeValue.startDate) &&\n isSameDay(preset.range.endDate, currentRangeValue.endDate);\n \n return (\n <div\n key={idx}\n onClick={() => handlePresetRangeSelect(preset.range)}\n style={{\n padding: '8px 16px',\n cursor: 'pointer',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n color: isSelected ? primaryColor : '#1C1917',\n backgroundColor: isSelected ? '#FAFAF9' : 'transparent',\n fontWeight: isSelected ? 500 : 400,\n transition: 'all 0.2s',\n }}\n onMouseEnter={(e) => {\n if (!isSelected) {\n e.currentTarget.style.backgroundColor = '#F5F5F4';\n }\n }}\n onMouseLeave={(e) => {\n if (!isSelected) {\n e.currentTarget.style.backgroundColor = 'transparent';\n }\n }}\n >\n {preset.label}\n </div>\n );\n })}\n </div>\n )}\n <div>\n {/* 日历区域 */}\n <div\n style={{\n flex: 1,\n padding: '16px',\n display: 'flex',\n flexDirection: calendarCount === 2 ? 'row' : 'column',\n gap: calendarCount === 2 ? '24px' : '0',\n }}\n >\n \n {/* 渲染第一个日历 */}\n {(() => {\n const renderCalendar = (\n monthData: { year: number; month: number },\n calendarDays: (Date | null)[],\n onPrevMonth: () => void,\n onNextMonth: () => void,\n monthIndex: number = 0\n ) => (\n <div\n key={monthIndex}\n style={{\n flex: 1,\n display: 'flex',\n flexDirection: 'column',\n }}\n >\n {/* 月份导航 */}\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: calendarCount === 2 && isRangeMode ? 'center' : 'space-between',\n marginBottom: '16px',\n position: 'relative',\n }}\n >\n {/* 左侧月份(monthIndex === 0)在两个月模式下隐藏左箭头,右侧月份(monthIndex === 1)在两个月模式下隐藏左箭头 */}\n {!(calendarCount === 2 && isRangeMode && monthIndex === 1) && (\n <button\n type=\"button\"\n onClick={onPrevMonth}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '32px',\n height: '32px',\n border: 'none',\n background: 'transparent',\n cursor: 'pointer',\n borderRadius: '4px',\n color: '#78716C',\n transition: 'all 0.2s',\n position: calendarCount === 2 && isRangeMode ? 'absolute' : 'relative',\n left: calendarCount === 2 && isRangeMode ? 0 : undefined,\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'transparent';\n }}\n >\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path\n d=\"M10 12L6 8L10 4\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n )}\n\n <div\n style={{\n fontSize: '16px',\n fontWeight: 500,\n color: '#1C1917',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {monthNamesFull[monthData.month]} {monthData.year}\n </div>\n\n {/* 左侧月份(monthIndex === 0)在两个月模式下隐藏右箭头 */}\n {!(calendarCount === 2 && isRangeMode && monthIndex === 0) && (\n <button\n type=\"button\"\n onClick={onNextMonth}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '32px',\n height: '32px',\n border: 'none',\n background: 'transparent',\n cursor: 'pointer',\n borderRadius: '4px',\n color: '#78716C',\n transition: 'all 0.2s',\n position: calendarCount === 2 && isRangeMode ? 'absolute' : 'relative',\n right: calendarCount === 2 && isRangeMode ? 0 : undefined,\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'transparent';\n }}\n >\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path\n d=\"M6 4L10 8L6 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n )}\n </div>\n\n {/* 显示选中的日期段(单月模式,在月份导航下面) */}\n {isRangeMode && showSelectedRange && calendarCount === 1 && monthIndex === 0 && (() => {\n const workingRange = showApplyCancel && tempRangeValue ? tempRangeValue : currentRangeValue;\n \n // 使用固定的 \"MMM D, YYYY\" 格式显示日期(如 \"Jan 10, 2025\")\n const startText = workingRange.startDate ? formatDate(workingRange.startDate, 'MMM D, YYYY') : startSelectedRangeText;\n const endText = workingRange.endDate ? formatDate(workingRange.endDate, 'MMM D, YYYY') : endSelectedRangeText;\n \n return (\n <div\n className='flex items-center gap-2'\n style={{\n fontSize: '14px',\n marginBottom: '16px',\n }}\n >\n <div \n className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.startDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}\n >{startText}</div>\n <div>{separator}</div>\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.endDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{endText}</div>\n </div>\n );\n })()}\n\n {/* 预设日期范围列表(上方 - 仅单月模式) */}\n {isRangeMode && hasPresetRanges && calendarCount === 1 && (\n <div\n style={{\n width: '252px',\n display: 'flex',\n flexWrap: 'wrap',\n paddingBottom: '16px',\n }}\n >\n {presetRangesList.map((preset, idx) => {\n const isSelected = tempRangeValue\n ? isSameDay(preset.range.startDate, tempRangeValue.startDate) &&\n isSameDay(preset.range.endDate, tempRangeValue.endDate)\n : isSameDay(preset.range.startDate, currentRangeValue.startDate) &&\n isSameDay(preset.range.endDate, currentRangeValue.endDate);\n \n return (\n <button\n key={idx}\n type=\"button\"\n onClick={() => handlePresetRangeSelect(preset.range)}\n style={{\n padding: '4px 8px',\n cursor: 'pointer',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n color: isSelected ? primaryColor : '#1C1917',\n backgroundColor: isSelected ? '#FAFAF9' : 'transparent',\n border: 'none',\n fontWeight: isSelected ? 500 : 400,\n transition: 'all 0.2s',\n borderRadius: '4px',\n }}\n >\n {preset.label}\n </button>\n );\n })}\n </div>\n )}\n\n {/* 星期标题 */}\n <div\n style={{\n width: '252px',\n display: 'grid',\n gridTemplateColumns: 'repeat(7, 1fr)',\n marginBottom: '8px',\n }}\n >\n {weekDays.map((day) => (\n <div\n key={day}\n style={{\n width: '36px',\n textAlign: 'center',\n fontSize: '12px',\n fontWeight: 500,\n color: '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n padding: '4px',\n }}\n >\n {day}\n </div>\n ))}\n </div>\n\n {/* 日期网格 */}\n <div\n style={{\n width: '252px',\n display: 'grid',\n gridTemplateColumns: 'repeat(7, 1fr)',\n rowGap: '4px',\n columnGap: '0px',\n }}\n >\n {(() => {\n // 计算第一天是星期几(0=周日, 1=周一, ...)\n const firstDay = getFirstDayOfMonth(monthData.year, monthData.month);\n // 将周日(0)转换为7,使周一作为第一天\n const firstDayOfWeek = firstDay === 0 ? 7 : firstDay;\n const offset = firstDayOfWeek - 1; // 需要偏移的空格数\n \n const cells: React.ReactNode[] = [];\n \n // 添加前面的空单元格\n for (let i = 0; i < offset; i++) {\n cells.push(<div key={`empty-${i}`} />);\n }\n \n // 添加当前月的日期\n calendarDays.forEach((date, index) => {\n if (!date) return;\n \n const actualIndex = offset + index;\n const isCurrentMonth = date.getMonth() === monthData.month;\n const isToday = isSameDay(date, new Date());\n const isDisabled = !isDateInRange(date, minDate, maxDate);\n\n if (isRangeMode) {\n // 范围模式 - 使用临时值或当前值\n const workingRange = showApplyCancel && tempRangeValue ? tempRangeValue : currentRangeValue;\n const isStartDate = isSameDay(date, workingRange.startDate);\n const isEndDate = isSameDay(date, workingRange.endDate);\n const isInRange = isDateInSelectedRange(date, workingRange.startDate, workingRange.endDate);\n\n // 判断是否是行的第一个或最后一个(基于 actualIndex,包含空单元格)\n const isFirstInRow = actualIndex % 7 === 0;\n const isLastInRow = actualIndex % 7 === 6;\n \n const isRangeStart = isStartDate;\n const isRangeEnd = isEndDate;\n\n // 计算背景和圆角样式\n let buttonStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '36px',\n height: '36px',\n border: 'none',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n fontSize: '14px',\n fontFamily: \"DM Sans, sans-serif\",\n transition: 'all 0.2s',\n opacity: isDisabled ? 0.4 : 1,\n position: 'relative',\n padding: 0,\n margin: 0,\n };\n\n // 开始和结束日期:圆形背景,橙色\n if (isRangeStart || isRangeEnd) {\n buttonStyle.background = primaryColor;\n buttonStyle.borderRadius = '50%';\n buttonStyle.color = '#FFFFFF';\n buttonStyle.fontWeight = 500;\n } \n // 范围中间的日期:浅灰色矩形背景\n else if (isInRange) {\n buttonStyle.background = '#F5F5F4';\n buttonStyle.color = isCurrentMonth\n ? isDisabled\n ? '#D7D3D0'\n : '#1C1917'\n : '#78716C';\n buttonStyle.fontWeight = 400;\n \n // 判断是否是月份的第一天或最后一天\n const isFirstDayOfMonth = date.getDate() === 1;\n const daysInMonth = getDaysInMonth(monthData.year, monthData.month);\n const isLastDayOfMonth = date.getDate() === daysInMonth;\n \n // 判断是否需要左边圆角或右边圆角\n const needsLeftRadius = isFirstInRow || isFirstDayOfMonth;\n const needsRightRadius = isLastInRow || isLastDayOfMonth;\n \n // 设置圆角:每一行的第一个日期有左边圆角,最后一个日期有右边圆角\n // 每月的第一天和最后一天也要有圆角\n if (needsLeftRadius && needsRightRadius) {\n // 同时需要左边和右边圆角(单独一个日期或跨行的情况)\n buttonStyle.borderRadius = '18px';\n } else if (needsLeftRadius) {\n // 行的第一个或月份的第一天:添加左侧圆角(上下都有)\n buttonStyle.borderTopLeftRadius = '18px';\n buttonStyle.borderBottomLeftRadius = '18px';\n buttonStyle.borderTopRightRadius = '0';\n buttonStyle.borderBottomRightRadius = '0';\n } else if (needsRightRadius) {\n // 行的最后一个或月份的最后一天:添加右侧圆角(上下都有)\n buttonStyle.borderTopRightRadius = '18px';\n buttonStyle.borderBottomRightRadius = '18px';\n buttonStyle.borderTopLeftRadius = '0';\n buttonStyle.borderBottomLeftRadius = '0';\n } else {\n // 中间:无圆角,保持连续\n buttonStyle.borderRadius = '0';\n }\n } \n // 不在范围内的日期\n else {\n buttonStyle.background = 'transparent';\n buttonStyle.borderRadius = '50%';\n buttonStyle.color = isCurrentMonth\n ? isDisabled\n ? '#D7D3D0'\n : '#1C1917'\n : '#78716C';\n buttonStyle.fontWeight = 400;\n }\n\n cells.push(\n <button\n key={`date-${index}`}\n type=\"button\"\n disabled={isDisabled}\n onClick={() => handleSelectRangeDate(date)}\n style={buttonStyle}\n onMouseEnter={(e) => {\n if (!isDisabled && !isRangeStart && !isRangeEnd) {\n if (isInRange) {\n e.currentTarget.style.backgroundColor = '#E7E5E4';\n } else {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }\n }\n }}\n onMouseLeave={(e) => {\n if (!isRangeStart && !isRangeEnd) {\n if (isInRange) {\n e.currentTarget.style.backgroundColor = '#F5F5F4';\n } else {\n e.currentTarget.style.backgroundColor = 'transparent';\n }\n }\n }}\n >\n {date.getDate()}\n {isToday && (\n <div\n style={{\n position: 'absolute',\n bottom: '3px',\n left: '50%',\n transform: 'translateX(-50%)',\n width: '4px',\n height: '4px',\n borderRadius: '50%',\n backgroundColor: (isRangeStart || isRangeEnd) ? \"#FFFFFF\" : primaryColor,\n }}\n />\n )}\n </button>\n );\n } else {\n // 单个日期模式\n const isSelected = isSameDay(date, currentSingleValue);\n\n cells.push(\n <button\n key={`date-${index}`}\n type=\"button\"\n disabled={isDisabled}\n onClick={() => handleSelectSingleDate(date)}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '36px',\n height: '36px',\n border: 'none',\n background: isSelected ? primaryColor : 'transparent',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n borderRadius: '4px',\n fontSize: '14px',\n fontWeight: isSelected ? 500 : 400,\n color: isSelected\n ? '#FFFFFF'\n : isCurrentMonth\n ? isDisabled\n ? '#D7D3D0'\n : '#1C1917'\n : '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n transition: 'all 0.2s',\n opacity: isDisabled ? 0.4 : 1,\n position: 'relative',\n padding: 0,\n margin: 0,\n }}\n onMouseEnter={(e) => {\n if (!isDisabled && !isSelected) {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }\n }}\n onMouseLeave={(e) => {\n if (!isSelected) {\n e.currentTarget.style.backgroundColor = 'transparent';\n }\n }}\n >\n {date.getDate()}\n {isToday && !isSelected && (\n <div\n style={{\n position: 'absolute',\n bottom: '2px',\n left: '50%',\n transform: 'translateX(-50%)',\n width: '4px',\n height: '4px',\n borderRadius: '50%',\n backgroundColor: primaryColor,\n }}\n />\n )}\n </button>\n );\n }\n });\n \n return cells;\n })()}\n </div>\n </div>\n );\n\n return (\n <>\n {renderCalendar(currentMonth, calendarData, handlePrevMonth, handleNextMonth, 0)}\n {calendarCount === 2 && isRangeMode && secondMonth && secondCalendarData && (\n renderCalendar(secondMonth, secondCalendarData, handleSecondPrevMonth, handleSecondNextMonth, 1)\n )}\n \n </>\n );\n })()}\n </div>\n {/* 显示选中的日期段(双月模式,无按钮时) */}\n {isRangeMode && showSelectedRange && calendarCount === 2 && !showApplyCancel && (() => {\n const workingRange = currentRangeValue;\n \n // 使用固定的 \"MMM D, YYYY\" 格式显示日期(如 \"Jan 10, 2025\")\n const startText = workingRange.startDate ? formatDate(workingRange.startDate, 'MMM D, YYYY') : startSelectedRangeText;\n const endText = workingRange.endDate ? formatDate(workingRange.endDate, 'MMM D, YYYY') : endSelectedRangeText;\n \n return (\n <div\n className='flex items-center gap-2'\n style={{\n padding: '12px 16px',\n borderTop: '1px solid #E7E5E4',\n borderBottomLeftRadius: '8px',\n borderBottomRightRadius: '8px',\n }}\n >\n <div\n className='w-[260px] flex items-center gap-2'\n style={{\n fontSize: '14px',\n }}\n >\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.startDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{startText}</div>\n <div>{separator}</div>\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.endDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{endText}</div>\n </div>\n </div>\n );\n })()}\n {/* Apply/Cancel 按钮 */}\n {isRangeMode && showApplyCancel && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n gap: '8px',\n padding: '12px 16px',\n borderTop: '1px solid #E7E5E4',\n borderBottomLeftRadius: '8px',\n borderBottomRightRadius: '8px',\n }}\n >\n {/* 显示选中的日期段(双月模式,在按钮旁边) */}\n {showSelectedRange && calendarCount === 2 && (() => {\n const workingRange = tempRangeValue || currentRangeValue;\n \n // 使用固定的 \"MMM D, YYYY\" 格式显示日期(如 \"Jan 10, 2025\")\n const startText = workingRange.startDate ? formatDate(workingRange.startDate, 'MMM D, YYYY') : startSelectedRangeText;\n const endText = workingRange.endDate ? formatDate(workingRange.endDate, 'MMM D, YYYY') : endSelectedRangeText;\n \n return (\n <div\n className='w-[260px] flex items-center gap-2'\n style={{\n fontSize: '14px',\n }}\n >\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.startDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{startText}</div>\n <div>{separator}</div>\n <div className={`flex-1 text-center border border-[#D7D3D0] rounded-md px-2 py-[6px] ${workingRange.endDate ? 'text-[#44403C]' : 'text-[#79716B]'}`}>{endText}</div>\n </div>\n );\n })()}\n <div\n className={`${ calendarCount === 2 ? '' : 'w-full'}`}\n style={{ display: 'flex', gap: '8px', flexShrink: 0, marginLeft: 'auto' }}\n >\n <button\n type=\"button\"\n onClick={handleCancel}\n style={{\n flex: 1,\n padding: '8px 16px',\n border: '1px solid #E7E5E4',\n borderRadius: '8px',\n background: '#FFFFFF',\n color: '#1C1917',\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: \"DM Sans, sans-serif\",\n cursor: 'pointer',\n transition: 'all 0.2s',\n }}\n onMouseEnter={(e) => {\n e.currentTarget.style.backgroundColor = '#FAFAF9';\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = '#FFFFFF';\n }}\n >\n {cancelText}\n </button>\n <button\n type=\"button\"\n onClick={handleApply}\n disabled={!tempRangeValue || (!tempRangeValue.startDate || !tempRangeValue.endDate)}\n style={{\n flex: 1,\n padding: '8px 16px',\n border: 'none',\n borderRadius: '8px',\n background: (!tempRangeValue || !tempRangeValue.startDate || !tempRangeValue.endDate) ? '#D7D3D0' : primaryColor,\n color: '#FFFFFF',\n fontSize: '14px',\n fontWeight: 500,\n fontFamily: \"DM Sans, sans-serif\",\n cursor: (!tempRangeValue || !tempRangeValue.startDate || !tempRangeValue.endDate) ? 'not-allowed' : 'pointer',\n transition: 'all 0.2s',\n }}\n onMouseEnter={(e) => {\n if (tempRangeValue && tempRangeValue.startDate && tempRangeValue.endDate) {\n e.currentTarget.style.backgroundColor = '#FD843A';\n }\n }}\n onMouseLeave={(e) => {\n if (tempRangeValue && tempRangeValue.startDate && tempRangeValue.endDate) {\n e.currentTarget.style.backgroundColor = primaryColor;\n }\n }}\n >\n {applyText}\n </button>\n </div>\n </div>\n )}\n </div>\n </div>\n </div>,\n document.body\n )}\n </>\n );\n};\n\nDatePicker.displayName = 'DatePicker';\n\nexport default DatePicker;\n","import React, { createContext } from 'react';\n\nexport interface FieldData {\n value?: any;\n error?: string;\n touched?: boolean;\n validating?: boolean;\n rules?: any[];\n required?: boolean;\n}\n\nexport interface FormContextValue {\n // 字段管理\n fields: Record<string, FieldData>;\n // 获取字段值\n getFieldValue: (name: string) => any;\n // 设置字段值\n setFieldValue: (name: string, value: any) => void;\n // 获取字段错误\n getFieldError: (name: string) => string | undefined;\n // 设置字段错误\n setFieldError: (name: string, error: string | undefined) => void;\n // 是否字段被触摸\n isFieldTouched: (name: string) => boolean;\n // 设置字段触摸状态\n setFieldTouched: (name: string, touched: boolean) => void;\n // 是否字段正在校验\n isFieldValidating: (name: string) => boolean;\n // 设置字段校验状态\n setFieldValidating: (name: string, validating: boolean) => void;\n // 注册字段\n registerField: (name: string, options: { rules?: any[]; required?: boolean }) => void;\n // 注销字段\n unregisterField: (name: string) => void;\n // 校验字段\n validateField: (name: string) => Promise<string | undefined>;\n // 校验所有字段\n validateFields: (nameList?: string[]) => Promise<any>;\n // 重置字段\n resetFields: (nameList?: string[]) => void;\n // 获取所有字段值\n getFieldsValue: (nameList?: string[]) => any;\n // 设置所有字段值\n setFieldsValue: (values: Record<string, any>) => void;\n // 提交表单\n submit: () => Promise<any>;\n // 批量设置字段(值 + 错误),类似 antd setFields\n setFields: (fields: Array<{ name: string; value?: any; errors?: string[] }>) => void;\n // 滚动到指定字段,类似 antd scrollToField\n scrollToField: (name: string, options?: ScrollIntoViewOptions) => void;\n // 注册字段 DOM 节点(供 scrollToField 使用,FormItem 内部调用)\n registerFieldRef: (name: string, element: HTMLElement | null) => void;\n // 标签宽度\n labelWidth?: number | string;\n // 标签对齐\n labelAlign?: 'left' | 'right';\n}\n\nexport const FormContext = createContext<FormContextValue | null>(null);\n\n","import React, { useRef, useCallback, useState, useImperativeHandle, useEffect, useMemo } from 'react';\nimport { FormContext, FormContextValue, FieldData } from './FormContext';\nimport FormItem from './FormItem';\n\nexport interface FormProps {\n /** 表单初始值 */\n initialValues?: Record<string, any>;\n /** 表单值变化回调 */\n onValuesChange?: (changedValues: Record<string, any>, allValues: Record<string, any>) => void;\n /** 表单提交回调 */\n onFinish?: (values: Record<string, any>) => void;\n /** 表单提交失败回调 */\n onFinishFailed?: (errorInfo: { values: Record<string, any>; errorFields: Array<{ name: string; errors: string[] }> }) => void;\n /** 标签宽度 */\n labelWidth?: number | string;\n /** 标签对齐方式 */\n labelAlign?: 'left' | 'right';\n /** 布局方式 */\n layout?: 'horizontal' | 'vertical' | 'inline';\n /** 尺寸 */\n size?: 'small' | 'medium' | 'large';\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 子元素 */\n children?: React.ReactNode;\n}\n\n/** scrollToField 的选项,与 Element.scrollIntoView 一致 */\nexport type ScrollToFieldOptions = ScrollIntoViewOptions;\n\n/** 校验失败时抛出的错误,携带 values 和 errorFields,便于 catch 后使用 */\nexport class FormValidationError extends Error {\n /** 当前表单值 */\n values: Record<string, any>;\n /** 校验失败的字段列表 */\n errorFields: Array<{ name: string; errors: string[] }>;\n\n constructor(message: string, values: Record<string, any>, errorFields: Array<{ name: string; errors: string[] }>) {\n super(message);\n this.name = 'FormValidationError';\n this.values = values;\n this.errorFields = errorFields;\n Object.setPrototypeOf(this, FormValidationError.prototype);\n }\n}\n\nexport interface FormInstance {\n /** 获取字段值 */\n getFieldValue: (name: string) => any;\n /** 获取所有字段值 */\n getFieldsValue: (nameList?: string[]) => any;\n /** 设置字段值 */\n setFieldValue: (name: string, value: any) => void;\n /** 设置所有字段值 */\n setFieldsValue: (values: Record<string, any>) => void;\n /** 批量设置字段(值 + 错误),类似 antd 的 setFields */\n setFields: (fields: Array<{ name: string; value?: any; errors?: string[] }>) => void;\n /** 获取字段错误 */\n getFieldError: (name: string) => string | undefined;\n /** 校验字段 */\n validateField: (name: string) => Promise<string | undefined>;\n /** 校验所有字段 */\n validateFields: (nameList?: string[]) => Promise<any>;\n /** 重置字段 */\n resetFields: (nameList?: string[]) => void;\n /** 提交表单:校验通过时 resolve 表单值,校验失败时 reject 为 FormValidationError(需 await 或 .catch() 才能捕获) */\n submit: () => Promise<any>;\n /** 滚动到指定字段(如第一个报错项) */\n scrollToField: (name: string, options?: ScrollToFieldOptions) => void;\n}\n\nconst Form = React.forwardRef<FormInstance, FormProps>(\n (\n {\n initialValues = {},\n onValuesChange,\n onFinish,\n onFinishFailed,\n labelWidth = '120px',\n labelAlign = 'right',\n layout = 'horizontal',\n size = 'medium',\n className = '',\n style,\n children,\n },\n ref\n ) => {\n const [fields, setFieldsState] = useState<Record<string, FieldData>>(() => {\n const initialFields: Record<string, FieldData> = {};\n Object.keys(initialValues).forEach((key) => {\n initialFields[key] = {\n value: initialValues[key],\n error: undefined,\n touched: false,\n validating: false,\n };\n });\n return initialFields;\n });\n\n // 使用 ref 保存最新的 fields,避免闭包问题\n const fieldsRef = useRef(fields);\n useEffect(() => {\n fieldsRef.current = fields;\n }, [fields]);\n\n // 存储每个字段的 DOM 元素,供 scrollToField 使用\n const fieldElementsRef = useRef<Record<string, HTMLElement>>({});\n\n // 获取字段值 - 从 ref 读取,确保获取最新值\n const getFieldValue = useCallback((name: string) => {\n return fieldsRef.current[name]?.value;\n }, []);\n\n // 设置字段值\n const setFieldValue = useCallback((name: string, value: any) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value,\n error: undefined,\n touched: false,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n value,\n };\n }\n\n // 同步更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n value,\n };\n } else {\n fieldsRef.current[name] = {\n value,\n error: undefined,\n touched: false,\n validating: false,\n };\n }\n\n // 触发 onValuesChange\n if (onValuesChange) {\n const changedValues: Record<string, any> = {};\n changedValues[name] = value;\n const allValues: Record<string, any> = {};\n Object.keys(newFields).forEach((key) => {\n allValues[key] = newFields[key].value;\n });\n onValuesChange(changedValues, allValues);\n }\n\n return newFields;\n });\n }, [onValuesChange]);\n\n // 获取字段错误 - 从 ref 读取,确保获取最新值\n const getFieldError = useCallback((name: string) => {\n return fieldsRef.current[name]?.error;\n }, []);\n\n // 设置字段错误\n const setFieldError = useCallback((name: string, error: string | undefined) => {\n // 先更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n error,\n };\n }\n \n // 然后更新 state\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: undefined,\n error,\n touched: false,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n error,\n };\n }\n return newFields;\n });\n }, []);\n\n // 是否字段被触摸 - 从 ref 读取,确保获取最新值\n const isFieldTouched = useCallback((name: string) => {\n return fieldsRef.current[name]?.touched || false;\n }, []);\n\n // 设置字段触摸状态\n const setFieldTouched = useCallback((name: string, touched: boolean) => {\n // 先更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n touched,\n };\n }\n \n // 然后更新 state\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: undefined,\n error: undefined,\n touched,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n touched,\n };\n }\n return newFields;\n });\n }, []);\n\n // 是否字段正在校验 - 从 ref 读取,确保获取最新值\n const isFieldValidating = useCallback((name: string) => {\n return fieldsRef.current[name]?.validating || false;\n }, []);\n\n // 设置字段校验状态\n const setFieldValidating = useCallback((name: string, validating: boolean) => {\n // 先更新 ref\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n validating,\n };\n }\n \n // 然后更新 state\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: undefined,\n error: undefined,\n touched: false,\n validating,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n validating,\n };\n }\n return newFields;\n });\n }, []);\n\n // 使用 ref 存储 registerField 函数,避免依赖变化\n const registerFieldFnRef = useRef<(name: string, options: { rules?: any[]; required?: boolean }) => void>();\n \n registerFieldFnRef.current = (name: string, options: { rules?: any[]; required?: boolean }) => {\n setFieldsState((prev) => {\n // 如果字段已存在且 rules 和 required 没有变化,不更新\n if (prev[name]) {\n const existingRules = prev[name].rules || [];\n const newRules = options.rules || [];\n \n // 深度比较 rules\n let rulesEqual = existingRules.length === newRules.length;\n if (rulesEqual && existingRules.length > 0) {\n for (let i = 0; i < existingRules.length; i++) {\n const existingRule = existingRules[i];\n const newRule = newRules[i];\n if (\n existingRule?.required !== newRule?.required ||\n existingRule?.message !== newRule?.message ||\n existingRule?.type !== newRule?.type ||\n existingRule?.pattern !== newRule?.pattern ||\n existingRule?.min !== newRule?.min ||\n existingRule?.max !== newRule?.max ||\n existingRule?.len !== newRule?.len ||\n existingRule?.whitespace !== newRule?.whitespace\n ) {\n rulesEqual = false;\n break;\n }\n }\n }\n \n if (rulesEqual && prev[name].required === options.required) {\n return prev; // 没有变化,返回原对象,避免触发重新渲染\n }\n }\n \n const newFields = { ...prev };\n if (!newFields[name]) {\n newFields[name] = {\n value: initialValues[name],\n error: undefined,\n touched: false,\n validating: false,\n rules: options.rules,\n required: options.required,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n rules: options.rules,\n required: options.required,\n };\n }\n return newFields;\n });\n };\n\n const registerField = useCallback((name: string, options: { rules?: any[]; required?: boolean }) => {\n registerFieldFnRef.current?.(name, options);\n }, []);\n\n // 注销字段\n const unregisterField = useCallback((name: string) => {\n delete fieldElementsRef.current[name];\n setFieldsState((prev) => {\n const newFields = { ...prev };\n delete newFields[name];\n return newFields;\n });\n delete fieldsRef.current[name];\n }, []);\n\n // 校验单个字段\n const validateField = useCallback(async (name: string): Promise<string | undefined> => {\n // 使用 ref 获取最新的 fields 状态,避免闭包问题\n const field = fieldsRef.current[name];\n if (!field) {\n return undefined;\n }\n\n setFieldValidating(name, true);\n\n const rules = field.rules || [];\n let error: string | undefined;\n\n for (const rule of rules) {\n const value = field.value;\n\n // required 校验\n if (rule.required) {\n if (value === undefined || value === null || value === '') {\n error = rule.message || `${name} is required`;\n break;\n }\n }\n\n // type 校验\n if (rule.type && value !== undefined && value !== null && value !== '') {\n const typeMap: Record<string, (v: any) => boolean> = {\n string: (v) => typeof v === 'string',\n number: (v) => typeof v === 'number' && !isNaN(v),\n boolean: (v) => typeof v === 'boolean',\n email: (v) => /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(String(v)),\n url: (v) => {\n try {\n new URL(String(v));\n return true;\n } catch {\n return false;\n }\n },\n };\n\n const validator = typeMap[rule.type];\n if (validator && !validator(value)) {\n error = rule.message || `${name} must be a valid ${rule.type}`;\n break;\n }\n }\n\n // pattern 校验\n if (rule.pattern && value !== undefined && value !== null && value !== '') {\n if (!rule.pattern.test(String(value))) {\n error = rule.message || `${name} format is invalid`;\n break;\n }\n }\n\n // min 校验\n if (rule.min !== undefined && value !== undefined && value !== null && value !== '') {\n const numValue = typeof value === 'string' ? value.length : Number(value);\n if (numValue < rule.min) {\n error = rule.message || `${name} must be at least ${rule.min}`;\n break;\n }\n }\n\n // max 校验\n if (rule.max !== undefined && value !== undefined && value !== null && value !== '') {\n const numValue = typeof value === 'string' ? value.length : Number(value);\n if (numValue > rule.max) {\n error = rule.message || `${name} must be at most ${rule.max}`;\n break;\n }\n }\n\n // len 校验\n if (rule.len !== undefined && value !== undefined && value !== null && value !== '') {\n const lenValue = typeof value === 'string' ? value.length : Number(value);\n if (lenValue !== rule.len) {\n error = rule.message || `${name} must be exactly ${rule.len}`;\n break;\n }\n }\n\n // whitespace 校验\n if (rule.whitespace && typeof value === 'string' && value.trim() !== value) {\n error = rule.message || `${name} cannot be whitespace`;\n break;\n }\n\n // 自定义 validator\n if (rule.validator) {\n try {\n await rule.validator(rule, value);\n } catch (err: any) {\n error = err?.message || rule.message || `${name} validation failed`;\n break;\n }\n }\n }\n\n // 先同步更新 ref,确保立即可用\n if (fieldsRef.current[name]) {\n fieldsRef.current[name] = {\n ...fieldsRef.current[name],\n error,\n validating: false,\n touched: true,\n };\n } else {\n fieldsRef.current[name] = {\n value: field.value,\n error,\n touched: true,\n validating: false,\n rules: field.rules,\n required: field.required,\n };\n }\n\n // 然后更新 state - 使用函数式更新确保状态正确更新\n setFieldsState((prev) => {\n const newFields = { ...prev };\n if (newFields[name]) {\n newFields[name] = {\n ...newFields[name],\n error,\n validating: false,\n touched: true,\n };\n } else {\n // 如果字段不存在,创建一个新字段\n newFields[name] = {\n value: field.value,\n error,\n touched: true,\n validating: false,\n rules: field.rules,\n required: field.required,\n };\n }\n return newFields;\n });\n\n // 返回错误信息\n return error;\n }, []);\n\n // 获取所有字段值\n const getFieldsValue = useCallback((nameList?: string[]) => {\n const currentFields = fieldsRef.current;\n const values: Record<string, any> = {};\n const fieldsToGet = nameList || Object.keys(currentFields);\n\n fieldsToGet.forEach((name) => {\n values[name] = currentFields[name]?.value;\n });\n\n return values;\n }, []);\n\n // 校验所有字段\n const validateFields = useCallback(async (nameList?: string[]): Promise<any> => {\n // 使用 ref 获取最新的 fields 状态\n const currentFields = fieldsRef.current;\n const fieldsToValidate = nameList || Object.keys(currentFields);\n const errors: Array<{ name: string; errors: string[] }> = [];\n\n // 并行校验所有字段,并收集错误\n const validationResults = await Promise.all(\n fieldsToValidate.map(async (name) => {\n const field = currentFields[name];\n // 如果字段存在且有 rules,才进行校验\n if (field && field.rules && field.rules.length > 0) {\n const error = await validateField(name);\n return { name, error };\n }\n return { name, error: undefined };\n })\n );\n\n // 收集所有错误\n validationResults.forEach(({ name, error }) => {\n if (error) {\n errors.push({\n name,\n errors: [error],\n });\n }\n });\n\n // 等待状态更新完成 - 使用 requestAnimationFrame 确保 DOM 更新\n await new Promise((resolve) => requestAnimationFrame(() => {\n setTimeout(resolve, 0);\n }));\n\n if (errors.length > 0) {\n const values = getFieldsValue();\n const errorInfo = { values, errorFields: errors };\n onFinishFailed?.(errorInfo);\n // 抛出 Error 子类,保证可被 try/catch 和 Promise.catch 正常捕获,避免页面“挂掉”\n throw new FormValidationError('Form validation failed', values, errors);\n }\n\n return getFieldsValue();\n }, [validateField, getFieldsValue, onFinishFailed]);\n\n // 重置字段\n const resetFields = useCallback((nameList?: string[]) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n const fieldsToReset = nameList || Object.keys(newFields);\n\n fieldsToReset.forEach((name) => {\n if (newFields[name]) {\n newFields[name] = {\n ...newFields[name],\n value: initialValues[name],\n error: undefined,\n touched: false,\n validating: false,\n };\n fieldsRef.current[name] = { ...newFields[name] };\n }\n });\n\n return newFields;\n });\n }, [initialValues]);\n\n // 设置所有字段值\n const setFieldsValue = useCallback((values: Record<string, any>) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n Object.keys(values).forEach((name) => {\n if (!newFields[name]) {\n newFields[name] = {\n value: values[name],\n error: undefined,\n touched: false,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n value: values[name],\n };\n }\n fieldsRef.current[name] = { ...newFields[name] };\n });\n\n if (onValuesChange) {\n const allValues: Record<string, any> = {};\n Object.keys(newFields).forEach((key) => {\n allValues[key] = newFields[key].value;\n });\n onValuesChange(values, allValues);\n }\n\n return newFields;\n });\n }, [onValuesChange]);\n\n // 提交表单\n const submit = useCallback(async () => {\n try {\n const values = await validateFields();\n onFinish?.(values);\n return values;\n } catch (error) {\n throw error;\n }\n }, [validateFields, onFinish]);\n\n // 批量设置字段(值 + 错误),类似 antd setFields\n const setFields = useCallback((fieldsToSet: Array<{ name: string; value?: any; errors?: string[] }>) => {\n setFieldsState((prev) => {\n const newFields = { ...prev };\n fieldsToSet.forEach(({ name, value, errors }) => {\n const error = errors && errors.length > 0 ? errors[0] : undefined;\n if (!newFields[name]) {\n newFields[name] = {\n value: value !== undefined ? value : undefined,\n error,\n touched: true,\n validating: false,\n };\n } else {\n newFields[name] = {\n ...newFields[name],\n ...(value !== undefined && { value }),\n error,\n touched: true,\n };\n }\n fieldsRef.current[name] = { ...newFields[name] };\n });\n return newFields;\n });\n if (onValuesChange && fieldsToSet.some((f) => f.value !== undefined)) {\n const changedValues: Record<string, any> = {};\n fieldsToSet.forEach((f) => {\n if (f.value !== undefined) changedValues[f.name] = f.value;\n });\n setTimeout(() => onValuesChange(changedValues, getFieldsValue()), 0);\n }\n }, [onValuesChange, getFieldsValue]);\n\n // 注册字段 DOM 节点\n const registerFieldRef = useCallback((name: string, element: HTMLElement | null) => {\n if (element) {\n fieldElementsRef.current[name] = element;\n } else {\n delete fieldElementsRef.current[name];\n }\n }, []);\n\n // 滚动到指定字段\n const scrollToField = useCallback((name: string, options?: ScrollIntoViewOptions) => {\n const el = fieldElementsRef.current[name];\n el?.scrollIntoView({ behavior: 'smooth', block: 'center', ...options });\n }, []);\n\n // 暴露方法给 ref\n useImperativeHandle(ref, () => ({\n getFieldValue,\n getFieldsValue,\n setFieldValue,\n setFieldsValue,\n setFields,\n getFieldError,\n validateField,\n validateFields,\n resetFields,\n submit,\n scrollToField,\n }));\n\n // 使用 useMemo 缓存 contextValue,但 fields 必须包含在依赖中,以便 FormItem 能重新渲染\n const contextValue: FormContextValue = useMemo(() => ({\n fields,\n getFieldValue,\n setFieldValue,\n getFieldError,\n setFieldError,\n isFieldTouched,\n setFieldTouched,\n isFieldValidating,\n setFieldValidating,\n registerField,\n unregisterField,\n validateField,\n validateFields,\n resetFields,\n getFieldsValue,\n setFieldsValue,\n setFields,\n submit,\n scrollToField,\n registerFieldRef,\n labelWidth,\n labelAlign,\n }), [\n fields,\n getFieldValue,\n setFieldValue,\n getFieldError,\n setFieldError,\n isFieldTouched,\n setFieldTouched,\n isFieldValidating,\n setFieldValidating,\n registerField,\n unregisterField,\n validateField,\n validateFields,\n resetFields,\n getFieldsValue,\n setFieldsValue,\n setFields,\n submit,\n scrollToField,\n registerFieldRef,\n labelWidth,\n labelAlign,\n ]);\n\n const formStyle: React.CSSProperties = {\n ...style,\n };\n\n if (layout === 'vertical') {\n formStyle.display = 'flex';\n formStyle.flexDirection = 'column';\n } else if (layout === 'inline') {\n formStyle.display = 'inline-flex';\n formStyle.flexWrap = 'wrap';\n formStyle.gap = '16px';\n }\n\n return (\n <FormContext.Provider value={contextValue}>\n <form\n className={`aha-form ${className}`}\n style={formStyle}\n onSubmit={async (e) => {\n e.preventDefault();\n try {\n const values = await validateFields();\n // 只有校验通过才调用 onFinish\n onFinish?.(values);\n } catch (error) {\n // 校验失败,不调用 onFinish,错误信息已经通过 setFieldError 设置\n // 错误信息会显示在 FormItem 中\n // onFinishFailed 已经在 validateFields 中调用\n }\n }}\n >\n {children}\n </form>\n </FormContext.Provider>\n );\n }\n);\n\nForm.displayName = 'Form';\n\n/** 获取表单实例的 hook,用法与 antd Form.useForm() 一致,返回的 ref 传给 <Form ref={formRef} /> 后即可使用 formRef.current?.setFieldValue 等方法 */\nfunction useForm(): [React.RefObject<FormInstance | null>] {\n const formRef = useRef<FormInstance | null>(null);\n return [formRef];\n}\n\n// 导出 FormItem 作为 Form.Item,并挂载 useForm\nconst FormWithItem = Form as typeof Form & {\n Item: typeof FormItem;\n useForm: typeof useForm;\n};\nFormWithItem.Item = FormItem;\nFormWithItem.useForm = useForm;\n\nexport default FormWithItem;\nexport { useForm };\n\n","import React, { useContext, useEffect, useRef, useMemo, useCallback } from 'react';\nimport { FormContext } from './FormContext';\nimport { TooltipIcon } from '../../icons';\n\nexport interface FormItemProps {\n /** 字段名 */\n name?: string;\n /** 标签 */\n label?: React.ReactNode;\n /** 标签的 HTML for 属性 */\n htmlFor?: string;\n /** 标签布局 */\n labelCol?: { span?: number; offset?: number };\n /** 输入控件布局 */\n wrapperCol?: { span?: number; offset?: number };\n /** 是否必填(显示红色星号) */\n required?: boolean;\n /** 校验规则 */\n rules?: Array<{\n required?: boolean;\n message?: string;\n validator?: (rule: any, value: any) => Promise<void> | void;\n pattern?: RegExp;\n min?: number;\n max?: number;\n len?: number;\n type?: 'string' | 'number' | 'boolean' | 'method' | 'regexp' | 'integer' | 'float' | 'array' | 'object' | 'enum' | 'date' | 'url' | 'hex' | 'email';\n whitespace?: boolean;\n [key: string]: any;\n }>;\n /** 是否显示校验信息 */\n hasFeedback?: boolean;\n /** 校验状态 */\n validateStatus?: 'success' | 'warning' | 'error' | 'validating';\n /** 帮助信息 */\n help?: React.ReactNode;\n /** 额外的提示信息 */\n extra?: React.ReactNode;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 子元素 */\n children?: React.ReactNode;\n /** 标签对齐方式 */\n labelAlign?: 'left' | 'right';\n /** 标签宽度 */\n labelWidth?: number | string;\n /** 是否隐藏 */\n hidden?: boolean;\n /** 标签提示信息(tooltip) */\n tooltip?: React.ReactNode;\n}\n\nconst FormItem: React.FC<FormItemProps> = ({\n name,\n label,\n htmlFor,\n labelCol,\n wrapperCol,\n required = false,\n rules = [],\n hasFeedback = false,\n validateStatus,\n help,\n extra,\n className = '',\n style,\n children,\n labelAlign = 'right',\n labelWidth,\n hidden = false,\n tooltip,\n}) => {\n const formContext = useContext(FormContext);\n const itemRef = useRef<HTMLDivElement>(null);\n\n // 注册字段 DOM 节点,供 Form 的 scrollToField 使用\n const setItemRef = useCallback(\n (el: HTMLDivElement | null) => {\n (itemRef as React.MutableRefObject<HTMLDivElement | null>).current = el;\n if (name && formContext?.registerFieldRef) {\n formContext.registerFieldRef(name, el);\n }\n },\n [name, formContext]\n );\n\n // 从 Form 上下文获取字段值、错误信息等\n // 使用 formContext.fields 来触发重新渲染,当 fields 变化时组件会重新渲染\n const fields = formContext?.fields || {};\n const fieldValue = name && formContext ? formContext.getFieldValue(name) : undefined;\n const fieldError = name && formContext ? formContext.getFieldError(name) : undefined;\n const fieldTouched = name && formContext ? formContext.isFieldTouched(name) : false;\n const fieldValidating = name && formContext ? formContext.isFieldValidating(name) : false;\n \n // 使用 fields 来触发重新渲染,确保错误信息能显示\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const _ = name ? fields[name] : undefined; // 读取 fields[name] 来建立依赖关系\n\n // 计算校验状态\n // 如果有错误就显示错误状态,不管是否 touched(提交时会强制校验)\n const computedValidateStatus =\n validateStatus ||\n (fieldError\n ? 'error'\n : fieldValidating\n ? 'validating'\n : fieldTouched && !fieldError\n ? 'success'\n : undefined);\n\n // 计算帮助信息 - 如果有错误就显示,不管是否 touched\n const computedHelp = help !== undefined ? help : (fieldError || undefined);\n\n // 使用 useRef 存储上一次的 rules 和 required,避免不必要的更新\n const prevRulesRef = useRef(rules);\n const prevRequiredRef = useRef(required);\n const isMountedRef = useRef(false);\n\n // 计算是否必填\n const isRequired = required || rules.some((rule) => rule.required);\n\n // 检查 rules 是否真的变化了(深度比较)\n const rulesChanged = useMemo(() => {\n if (!isMountedRef.current) {\n isMountedRef.current = true;\n return true; // 首次挂载时注册\n }\n \n if (prevRulesRef.current.length !== rules.length) {\n return true;\n }\n // 简单比较:如果引用相同,肯定没变化\n if (prevRulesRef.current === rules) {\n return false;\n }\n // 深度比较关键属性\n for (let i = 0; i < rules.length; i++) {\n const prevRule = prevRulesRef.current[i];\n const currRule = rules[i];\n if (\n prevRule?.required !== currRule?.required ||\n prevRule?.message !== currRule?.message ||\n prevRule?.type !== currRule?.type ||\n prevRule?.pattern !== currRule?.pattern ||\n prevRule?.min !== currRule?.min ||\n prevRule?.max !== currRule?.max ||\n prevRule?.len !== currRule?.len ||\n prevRule?.whitespace !== currRule?.whitespace\n ) {\n return true;\n }\n }\n return false;\n }, [rules]);\n\n // 注册字段到 Form - 只在 name 变化时注册,rules 和 required 通过内部比较\n useEffect(() => {\n if (!name || !formContext) return;\n\n // 检查是否需要更新\n const shouldUpdate = \n !prevRulesRef.current || // 首次注册\n rulesChanged || \n prevRequiredRef.current !== required;\n\n if (shouldUpdate) {\n prevRulesRef.current = rules;\n prevRequiredRef.current = required;\n\n formContext.registerField(name, {\n rules,\n required: isRequired,\n });\n }\n\n return () => {\n if (name && formContext) {\n formContext.unregisterField(name);\n }\n };\n // 只依赖 name,formContext 是稳定的,rules 和 required 通过 ref 比较\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [name]);\n\n // 克隆子元素,注入 value、onChange、error 等 props\n const cloneChild = (child: React.ReactElement) => {\n if (!React.isValidElement(child)) return child;\n\n const childProps: any = {\n ...(child.props as Record<string, any>),\n };\n\n // 注入 value 和 onChange\n if (name && formContext) {\n const fieldValue = formContext.getFieldValue(name);\n const setFieldValue = formContext.setFieldValue;\n\n if (!setFieldValue) {\n // 如果没有 formContext,直接返回原组件\n return child;\n }\n\n // 处理不同类型的组件(函数组件 typeof 为 'function',React.memo 等为 'object')\n const childType = child.type as any;\n if (childType && (typeof childType === 'object' || typeof childType === 'function') && 'displayName' in childType) {\n const displayName = childType.displayName;\n\n // Input, Textarea\n if (displayName === 'Input' || displayName === 'Textarea') {\n childProps.value = fieldValue || '';\n const originalOnChange = (child.props as any)?.onChange;\n const originalOnBlur = (child.props as any)?.onBlur;\n childProps.onChange = (e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n setFieldValue(name, e.target.value);\n originalOnChange?.(e);\n // 值变化时立即触发校验\n if (name && formContext) {\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n childProps.onBlur = (e: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n formContext.validateField(name);\n }\n originalOnBlur?.(e);\n };\n childProps.error = computedValidateStatus === 'error';\n }\n // Select\n else if (displayName === 'Select') {\n childProps.value = fieldValue;\n const originalOnChange = (child.props as any)?.onChange;\n const originalOnBlur = (child.props as any)?.onBlur;\n childProps.onChange = (value: any, option: any) => {\n setFieldValue(name, value);\n originalOnChange?.(value, option);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n childProps.onBlur = (e: React.FocusEvent) => {\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n formContext.validateField(name);\n }\n originalOnBlur?.(e);\n };\n childProps.error = computedValidateStatus === 'error';\n }\n // Switch\n else if (displayName === 'Switch') {\n childProps.checked = fieldValue || false;\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (checked: boolean, event: any) => {\n setFieldValue(name, checked);\n originalOnChange?.(checked, event);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n }\n // Checkbox\n else if (displayName === 'Checkbox') {\n childProps.checked = fieldValue || false;\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setFieldValue(name, e.target.checked);\n originalOnChange?.(e);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n }\n // Radio\n else if (displayName === 'Radio') {\n // Radio 通常需要 Radio.Group,这里只处理单个 Radio\n const radioValue = (child.props as any)?.value;\n if (radioValue !== undefined) {\n childProps.checked = fieldValue === radioValue;\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setFieldValue(name, radioValue);\n originalOnChange?.(e);\n // 值变化时立即触发校验\n if (name && formContext) {\n formContext.setFieldTouched(name, true);\n // 使用 setTimeout 确保值已经更新\n setTimeout(() => {\n formContext.validateField(name);\n }, 0);\n }\n };\n }\n }\n } else {\n // 通用处理:尝试注入 value 和 onChange\n if (fieldValue !== undefined) {\n childProps.value = fieldValue;\n }\n const originalOnChange = (child.props as any)?.onChange;\n childProps.onChange = (e: any) => {\n const value = e?.target?.value ?? e;\n setFieldValue(name, value);\n originalOnChange?.(e);\n };\n }\n }\n\n // 注入 error 状态(如果组件支持)\n if (computedValidateStatus === 'error' && 'error' in childProps) {\n childProps.error = true;\n }\n\n return React.cloneElement(child, childProps);\n };\n\n if (hidden) return null;\n\n // Tooltip 组件(简单实现)\n const TooltipWrapper = ({ content }: { content: React.ReactNode }) => {\n const [showTooltip, setShowTooltip] = React.useState(false);\n const tooltipRef = React.useRef<HTMLDivElement>(null);\n\n React.useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (tooltipRef.current && !tooltipRef.current.contains(event.target as Node)) {\n setShowTooltip(false);\n }\n };\n\n if (showTooltip) {\n document.addEventListener('mousedown', handleClickOutside);\n return () => {\n document.removeEventListener('mousedown', handleClickOutside);\n };\n }\n }, [showTooltip]);\n\n return (\n <div style={{ position: 'relative', display: 'inline-block', marginLeft: '4px' }}>\n <div\n onClick={(e) => {\n e.stopPropagation();\n setShowTooltip(!showTooltip);\n }}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n cursor: 'pointer',\n color: '#A9A29D',\n }}\n >\n <TooltipIcon />\n </div>\n {showTooltip && (\n <div\n ref={tooltipRef}\n style={{\n position: 'absolute',\n top: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginTop: '4px',\n padding: '8px 12px',\n backgroundColor: '#1C1917',\n color: '#FFFFFF',\n fontSize: '12px',\n lineHeight: '18px',\n fontFamily: \"DM Sans, sans-serif\",\n borderRadius: '6px',\n whiteSpace: 'nowrap',\n zIndex: 1000,\n boxShadow: '0 4px 12px rgba(0, 0, 0, 0.15)',\n }}\n >\n {content}\n <div\n style={{\n position: 'absolute',\n top: '-4px',\n left: '50%',\n transform: 'translateX(-50%)',\n width: 0,\n height: 0,\n borderLeft: '4px solid transparent',\n borderRight: '4px solid transparent',\n borderBottom: '4px solid #1C1917',\n }}\n />\n </div>\n )}\n </div>\n );\n };\n\n return (\n <div\n ref={setItemRef}\n className={`aha-form-item ${className}`}\n style={{\n display: 'flex',\n flexDirection: 'column',\n marginBottom: '16px',\n ...style,\n }}\n >\n {label && (\n <label\n htmlFor={htmlFor}\n style={{\n display: 'flex',\n alignItems: 'center',\n marginBottom: '6px',\n fontSize: '14px', // text-sm\n lineHeight: '20px',\n color: '#44403C',\n fontFamily: \"DM Sans, sans-serif\",\n fontWeight: 500, // font-medium\n }}\n >\n {label}\n {isRequired && (\n <span\n style={{\n color: '#EC470A',\n marginLeft: '4px',\n }}\n >\n *\n </span>\n )}\n {tooltip && <TooltipWrapper content={tooltip} />}\n </label>\n )}\n <div style={{ width: '100%' }}>\n <div>\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return cloneChild(child);\n }\n return child;\n })}\n </div>\n {computedHelp && (\n <div\n style={{\n marginTop: '6px',\n fontSize: '14px', // text-sm\n lineHeight: '20px',\n fontWeight: 400, // font-normal\n color:\n computedValidateStatus === 'error'\n ? '#D92D20'\n : computedValidateStatus === 'warning'\n ? '#F59E0B'\n : '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {computedHelp}\n </div>\n )}\n {extra && !computedHelp && (\n <div\n style={{\n marginTop: '4px',\n fontSize: '12px',\n lineHeight: '18px',\n color: '#78716C',\n fontFamily: \"DM Sans, sans-serif\",\n }}\n >\n {extra}\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport default FormItem;\n\n","import React, { useState, useCallback, useRef, useEffect } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport interface MenuItemType {\n /** 唯一标识 */\n key: string;\n /** 菜单项标签 */\n label: React.ReactNode;\n /** 菜单项图标 */\n icon?: React.ReactNode;\n /** 菜单项右侧图标 */\n suffixIcon?: React.ReactNode;\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否危险项(红色) */\n danger?: boolean;\n /** 自定义渲染函数,如果提供则完全自定义该项的渲染 */\n render?: (item: MenuItemType, isSelected: boolean) => React.ReactNode;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 点击事件 */\n onClick?: (info: { key: string; keyPath: string[] }) => void;\n /** 是否跳过全局点击事件(MenuList 的 onClick),默认为 false */\n skipGlobalClick?: boolean;\n}\n\nexport interface MenuGroupType {\n /** 分组标题 */\n title?: React.ReactNode;\n /** 分组下的菜单项 */\n children: MenuItemType[];\n /** 自定义类名 */\n className?: string;\n}\n\nexport interface UserProfileType {\n /** 用户头像 */\n avatar?: React.ReactNode;\n /** 用户姓名 */\n name: React.ReactNode;\n /** 用户邮箱 */\n email?: React.ReactNode;\n /** 在线状态 */\n online?: boolean;\n /** 自定义渲染函数,如果提供则完全自定义用户资料的渲染 */\n render?: (profile: UserProfileType) => React.ReactNode;\n /** 点击事件 */\n onClick?: () => void;\n}\n\nexport interface MenuListProps {\n /** 菜单项数据 */\n items: (MenuItemType | MenuGroupType)[];\n /** 用户资料信息(显示在顶部) */\n userProfile?: UserProfileType;\n /** 当前选中的菜单项 key */\n selectedKeys?: string[];\n /** 默认选中的菜单项 key */\n defaultSelectedKeys?: string[];\n /** 选中项变化时的回调 */\n onSelect?: (info: { key: string; keyPath: string[]; selectedKeys: string[] }) => void;\n /** 取消选中时的回调 */\n onDeselect?: (info: { key: string; keyPath: string[]; selectedKeys: string[] }) => void;\n /** 统一的点击事件,无论点击哪个子项都会触发 */\n onClick?: (info: { key: string; keyPath: string[] }) => void;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 菜单宽度 */\n width?: number | string;\n}\n\nconst MenuList: React.FC<MenuListProps> = ({\n items = [],\n userProfile,\n selectedKeys: controlledSelectedKeys,\n defaultSelectedKeys = [],\n onSelect,\n onDeselect,\n onClick,\n className = '',\n style,\n width = 320,\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const menuRef = useRef<HTMLDivElement>(null);\n const itemRefs = useRef<{ [key: string]: HTMLDivElement | null }>({});\n\n // 受控/非受控逻辑\n const isSelectedKeysControlled = controlledSelectedKeys !== undefined;\n const [internalSelectedKeys, setInternalSelectedKeys] = useState<string[]>(defaultSelectedKeys);\n\n const selectedKeys = isSelectedKeysControlled ? controlledSelectedKeys : internalSelectedKeys;\n\n // 判断是否是分组\n const isGroup = (item: MenuItemType | MenuGroupType): item is MenuGroupType => {\n return 'children' in item && Array.isArray(item.children);\n };\n\n // 获取菜单项的完整路径\n const getKeyPath = useCallback(\n (key: string, items: (MenuItemType | MenuGroupType)[], path: string[] = []): string[] | null => {\n for (const item of items) {\n if (isGroup(item)) {\n // 是分组,递归查找子项\n const found = getKeyPath(key, item.children, path);\n if (found) return found;\n } else {\n const menuItem = item as MenuItemType;\n const currentPath = [...path, menuItem.key];\n if (menuItem.key === key) {\n return currentPath;\n }\n }\n }\n return null;\n },\n []\n );\n\n // 处理菜单项点击\n const handleItemClick = useCallback(\n (item: MenuItemType) => {\n if (item.disabled) return;\n\n const keyPath = getKeyPath(item.key, items) || [item.key];\n const isSelected = selectedKeys.includes(item.key);\n let newSelectedKeys: string[];\n\n if (isSelected) {\n newSelectedKeys = selectedKeys.filter((k) => k !== item.key);\n onDeselect?.({ key: item.key, keyPath, selectedKeys: newSelectedKeys });\n } else {\n newSelectedKeys = [item.key];\n onSelect?.({ key: item.key, keyPath, selectedKeys: newSelectedKeys });\n }\n\n if (!isSelectedKeysControlled) {\n setInternalSelectedKeys(newSelectedKeys);\n }\n\n // 先调用菜单项自己的 onClick\n item.onClick?.({ key: item.key, keyPath });\n \n // 再调用统一的 onClick(MenuList 级别的),除非该菜单项设置了 skipGlobalClick\n if (!item.skipGlobalClick) {\n onClick?.({ key: item.key, keyPath });\n }\n },\n [selectedKeys, isSelectedKeysControlled, onSelect, onDeselect, onClick, items, getKeyPath]\n );\n\n // 渲染用户资料\n const renderUserProfile = () => {\n if (!userProfile) return null;\n\n // 如果提供了自定义渲染函数,使用自定义渲染\n if (userProfile.render) {\n return userProfile.render(userProfile);\n }\n\n return (\n <div\n onClick={userProfile.onClick}\n style={{\n padding: '16px',\n cursor: userProfile.onClick ? 'pointer' : 'default',\n borderBottom: '1px solid #E7E5E4',\n }}\n >\n <div style={{ display: 'flex', alignItems: 'center', gap: '12px' }}>\n {/* 头像 */}\n <div style={{ position: 'relative', flexShrink: 0 }}>\n {userProfile.avatar || (\n <div\n style={{\n width: '40px',\n height: '40px',\n borderRadius: '50%',\n backgroundColor: '#F5F5F4',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n fontSize: '16px',\n color: '#78716C',\n }}\n >\n {typeof userProfile.name === 'string' ? userProfile.name.charAt(0).toUpperCase() : 'U'}\n </div>\n )}\n {/* 在线状态指示器 */}\n {userProfile.online !== undefined && (\n <div\n style={{\n position: 'absolute',\n bottom: '0',\n right: '0',\n width: '12px',\n height: '12px',\n borderRadius: '50%',\n backgroundColor: userProfile.online ? '#10B981' : '#9CA3AF',\n border: '2px solid #FFFFFF',\n }}\n />\n )}\n </div>\n {/* 用户信息 */}\n <div style={{ flex: 1, minWidth: 0 }}>\n <div\n style={{\n fontSize: '14px',\n fontWeight: 500,\n lineHeight: '20px',\n color: '#101828',\n fontFamily: 'DM Sans, sans-serif',\n marginBottom: '2px',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n >\n {userProfile.name}\n </div>\n {userProfile.email && (\n <div\n style={{\n fontSize: '14px',\n lineHeight: '20px',\n color: '#78716C',\n fontFamily: 'DM Sans, sans-serif',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n }}\n >\n {userProfile.email}\n </div>\n )}\n </div>\n </div>\n </div>\n );\n };\n\n // 渲染单个菜单项\n const renderMenuItem = (item: MenuItemType): React.ReactNode => {\n const isSelected = selectedKeys.includes(item.key);\n\n // 如果提供了自定义渲染函数,使用自定义渲染\n if (item.render) {\n return (\n <div key={item.key} className={item.className} style={item.style}>\n {item.render(item, isSelected)}\n </div>\n );\n }\n\n const itemStyle: React.CSSProperties = {\n display: 'flex',\n alignItems: 'center',\n padding: '10px 16px',\n cursor: item.disabled ? 'not-allowed' : 'pointer',\n fontSize: '14px',\n lineHeight: '20px',\n fontFamily: 'DM Sans, sans-serif',\n fontWeight: 600,\n color: item.disabled\n ? '#98A2B3'\n : item.danger\n ? '#DC2626'\n : '#44403C',\n backgroundColor: 'transparent',\n transition: 'background-color 0.15s',\n opacity: item.disabled ? 0.5 : 1,\n ...item.style,\n };\n\n return (\n <div\n key={item.key}\n ref={(el) => {\n itemRefs.current[item.key] = el;\n }}\n className={`aha-menu-item ${item.className || ''}`}\n style={itemStyle}\n onClick={() => handleItemClick(item)}\n onMouseEnter={(e) => {\n if (!item.disabled) {\n e.currentTarget.style.backgroundColor = '#F9FAFB';\n }\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.backgroundColor = 'transparent';\n }}\n >\n {/* 图标 - 可选,如果提供了icon则显示 */}\n {item.icon && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n marginRight: '12px',\n flexShrink: 0,\n color: item.disabled\n ? '#98A2B3'\n : item.danger\n ? '#DC2626'\n : '#101828',\n }}\n >\n {item.icon}\n </div>\n )}\n {/* 标签文本 */}\n <span style={{ flex: 1 }}>{item.label}</span>\n {/* 右侧图标 */}\n {item.suffixIcon && (\n <div\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '20px',\n height: '20px',\n marginLeft: '12px',\n flexShrink: 0,\n color: item.disabled\n ? '#98A2B3'\n : item.danger\n ? '#DC2626'\n : '#101828',\n }}\n >\n {item.suffixIcon}\n </div>\n )}\n </div>\n );\n };\n\n // 渲染菜单分组\n const renderGroup = (group: MenuGroupType): React.ReactNode => {\n return (\n <div key={`group-${group.title}`} className={`aha-menu-group ${group.className || ''}`}>\n {group.children.map((item) => renderMenuItem(item))}\n </div>\n );\n };\n\n // 主容器样式\n const containerStyle: React.CSSProperties = {\n width: typeof width === 'number' ? `${width}px` : width,\n backgroundColor: '#FFFFFF',\n borderRadius: '12px',\n boxShadow: '0px 10px 38px rgba(22, 23, 24, 0.35), 0px 10px 20px rgba(22, 23, 24, 0.2)',\n overflow: 'hidden',\n fontFamily: 'DM Sans, sans-serif',\n ...style,\n };\n\n // 计算是否需要显示分隔线\n const shouldShowDivider = (index: number, items: (MenuItemType | MenuGroupType)[]): boolean => {\n if (index === 0) return false;\n const currentItem = items[index];\n const prevItem = items[index - 1];\n \n // 如果前一项是分组,显示分隔线\n if (isGroup(prevItem)) {\n return true;\n }\n // 如果当前项是分组,且前一项不是分组,显示分隔线\n if (isGroup(currentItem) && !isGroup(prevItem)) {\n return true;\n }\n return false;\n };\n\n return (\n <div ref={menuRef} className={`aha-menu-list ${className}`} style={containerStyle}>\n {/* 用户资料 */}\n {userProfile && renderUserProfile()}\n \n {/* 菜单项 */}\n <div>\n {items.map((item, index) => (\n <React.Fragment key={index}>\n {/* 分隔线 */}\n {shouldShowDivider(index, items) && (\n <div\n style={{\n height: '1px',\n backgroundColor: '#E7E5E4',\n margin: '4px 0',\n }}\n />\n )}\n {/* 菜单项或分组 */}\n {isGroup(item)\n ? renderGroup(item)\n : renderMenuItem(item)}\n </React.Fragment>\n ))}\n </div>\n </div>\n );\n};\n\nMenuList.displayName = 'MenuList';\n\nexport default MenuList;\n","import React, { useState, useRef, useEffect, useCallback } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nexport type TooltipPosition = \n | \"top\" \n | \"bottom\" \n | \"left\" \n | \"right\"\n | \"top-left\"\n | \"top-right\"\n | \"bottom-left\"\n | \"bottom-right\";\n\nexport type TooltipTrigger = \"hover\" | \"click\";\n\nexport interface TooltipProps {\n /** Tooltip 内容 */\n content: React.ReactNode;\n /** 触发元素 */\n children: React.ReactNode;\n /** 显示位置 */\n position?: TooltipPosition;\n /** 触发方式 */\n trigger?: TooltipTrigger;\n /** 延迟显示时间(毫秒) */\n delay?: number;\n /** 是否禁用 */\n disabled?: boolean;\n /** 自定义样式类名 */\n className?: string;\n /** 自定义 tooltip 样式类名 */\n tooltipClassName?: string;\n /** Tooltip 与触发元素的间距(像素) */\n gap?: number;\n /** 是否显示箭头 */\n showArrow?: boolean;\n /** Tooltip 内容宽度(如 \"200px\"、\"50%\" 等),不设置则使用自动计算 */\n width?: string | number;\n /** 是否默认显示(非受控) */\n defaultVisible?: boolean;\n /** 是否显示(受控) */\n visible?: boolean;\n /** 显示/隐藏时的回调 */\n onVisibleChange?: (visible: boolean) => void;\n}\n\n// 箭头尺寸\nconst ARROW_SIZE = 6;\n// 默认间距\nconst GAP_DEFAULT = 6;\n\n// 计算箭头位置(相对于 tooltip 内容的位置)\nconst getArrowPosition = (\n position: TooltipPosition,\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n tooltipLeft: number,\n tooltipTop: number\n): React.CSSProperties => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n \n const triggerCenterX = triggerRect.left + (triggerRect.width - ARROW_SIZE) / 2;\n const triggerCenterY = triggerRect.top + (triggerRect.height - ARROW_SIZE) / 2;\n \n // 计算箭头相对于 tooltip 内容的位置\n const tooltipAbsoluteLeft = tooltipLeft - scrollX;\n const tooltipAbsoluteTop = tooltipTop - scrollY;\n \n switch (position) {\n case \"top\":\n return {\n bottom: -ARROW_SIZE,\n left: Math.min(Math.max(triggerCenterX - tooltipAbsoluteLeft, ARROW_SIZE), tooltipRect.width - ARROW_SIZE),\n };\n case \"bottom\":\n return {\n top: -ARROW_SIZE,\n left: Math.min(Math.max(triggerCenterX - tooltipAbsoluteLeft, ARROW_SIZE), tooltipRect.width - ARROW_SIZE),\n };\n case \"left\":\n return {\n right: -ARROW_SIZE,\n top: Math.min(Math.max(triggerCenterY - tooltipAbsoluteTop, ARROW_SIZE), tooltipRect.height - ARROW_SIZE),\n };\n case \"right\":\n return {\n left: -ARROW_SIZE,\n top: Math.min(Math.max(triggerCenterY - tooltipAbsoluteTop, ARROW_SIZE), tooltipRect.height - ARROW_SIZE),\n };\n case \"top-left\":\n return {\n bottom: -ARROW_SIZE,\n left: 12,\n };\n case \"top-right\":\n return {\n bottom: -ARROW_SIZE,\n right: 12,\n };\n case \"bottom-left\":\n return {\n top: -ARROW_SIZE,\n left: 12,\n };\n case \"bottom-right\":\n return {\n top: -ARROW_SIZE,\n right: 12,\n };\n default:\n return {};\n }\n};\n\n// 计算 tooltip 位置\nconst calculatePosition = (\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n position: TooltipPosition,\n gap: number = GAP_DEFAULT\n): { top: number; left: number } => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n \n const triggerCenterX = triggerRect.left + triggerRect.width / 2;\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n \n // 考虑箭头的高度\n const arrowOffset = ARROW_SIZE;\n const totalGap = gap + arrowOffset;\n \n let top = 0;\n let left = 0;\n \n switch (position) {\n case \"top\":\n top = triggerRect.top - tooltipRect.height - totalGap + scrollY;\n left = triggerCenterX - tooltipRect.width / 2 + scrollX;\n break;\n case \"bottom\":\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerCenterX - tooltipRect.width / 2 + scrollX;\n break;\n case \"left\":\n top = triggerCenterY - tooltipRect.height / 2 + scrollY;\n left = triggerRect.left - tooltipRect.width - totalGap + scrollX;\n break;\n case \"right\":\n top = triggerCenterY - tooltipRect.height / 2 + scrollY;\n left = triggerRect.right + totalGap + scrollX;\n break;\n case \"top-left\":\n top = triggerRect.top - tooltipRect.height - totalGap + scrollY;\n left = triggerRect.left + scrollX;\n break;\n case \"top-right\":\n top = triggerRect.top - tooltipRect.height - totalGap + scrollY;\n left = triggerRect.right - tooltipRect.width + scrollX;\n break;\n case \"bottom-left\":\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerRect.left + scrollX;\n break;\n case \"bottom-right\":\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerRect.right - tooltipRect.width + scrollX;\n break;\n default:\n top = triggerRect.bottom + totalGap + scrollY;\n left = triggerCenterX - tooltipRect.width / 2 + scrollX;\n }\n \n // 边界检测,确保 tooltip 不会超出视口\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const padding = 8;\n \n if (left < scrollX + padding) {\n left = scrollX + padding;\n } else if (left + tooltipRect.width > scrollX + viewportWidth - padding) {\n left = scrollX + viewportWidth - tooltipRect.width - padding;\n }\n \n if (top < scrollY + padding) {\n top = scrollY + padding;\n } else if (top + tooltipRect.height > scrollY + viewportHeight - padding) {\n top = scrollY + viewportHeight - tooltipRect.height - padding;\n }\n return { top, left };\n};\n\n// 检查指定位置是否会遮挡触发元素(使用实际计算后的位置)\nconst willOverlap = (\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n position: TooltipPosition,\n gap: number = GAP_DEFAULT\n): boolean => {\n // 使用 calculatePosition 计算实际位置(包含边界调整)\n const { top: calculatedTop, left: calculatedLeft } = calculatePosition(\n triggerRect,\n tooltipRect,\n position,\n gap\n );\n \n // 转换为视口坐标(不包含 scroll)\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n const top = calculatedTop - scrollY;\n const left = calculatedLeft - scrollX;\n \n // 检查 tooltip 和触发元素是否重叠\n const tooltipBottom = top + tooltipRect.height;\n const tooltipRight = left + tooltipRect.width;\n const tooltipTop = top;\n const tooltipLeft = left;\n \n // 计算重叠区域\n const overlapTop = Math.max(tooltipTop, triggerRect.top);\n const overlapBottom = Math.min(tooltipBottom, triggerRect.bottom);\n const overlapLeft = Math.max(tooltipLeft, triggerRect.left);\n const overlapRight = Math.min(tooltipRight, triggerRect.right);\n \n // 如果有重叠,返回 true\n return overlapBottom > overlapTop + 1 && overlapRight > overlapLeft + 1;\n};\n\n// 自动选择最佳位置:灵活尝试多个方向\nconst getAutoPosition = (\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n preferredPosition: TooltipPosition,\n gap: number = GAP_DEFAULT\n): TooltipPosition => {\n // 如果不会遮挡,直接返回指定位置\n if (!willOverlap(triggerRect, tooltipRect, preferredPosition, gap)) {\n return preferredPosition;\n }\n \n // 定义位置优先级列表\n const getPositionCandidates = (pos: TooltipPosition): TooltipPosition[] => {\n switch (pos) {\n case \"top\":\n return [\"bottom\", \"right\", \"left\"];\n case \"bottom\":\n return [\"top\", \"right\", \"left\"];\n case \"left\":\n return [\"right\", \"top\", \"bottom\"];\n case \"right\":\n return [\"left\", \"top\", \"bottom\"];\n case \"top-left\":\n return [\"bottom-left\", \"top-right\", \"bottom-right\", \"right\", \"left\"];\n case \"top-right\":\n return [\"bottom-right\", \"top-left\", \"bottom-left\", \"left\", \"right\"];\n case \"bottom-left\":\n return [\"top-left\", \"bottom-right\", \"top-right\", \"right\", \"left\"];\n case \"bottom-right\":\n return [\"top-right\", \"bottom-left\", \"top-left\", \"left\", \"right\"];\n default:\n return [];\n }\n };\n \n // 尝试候选位置,找到第一个不遮挡的\n const candidates = getPositionCandidates(preferredPosition);\n for (const candidate of candidates) {\n if (!willOverlap(triggerRect, tooltipRect, candidate, gap)) {\n return candidate;\n }\n }\n \n // 如果所有位置都遮挡,返回首选位置(至少保证功能可用)\n return preferredPosition;\n};\n\n// 渲染箭头\nconst renderArrow = (\n position: TooltipPosition,\n arrowStyle: React.CSSProperties\n) => {\n const baseArrowStyle: React.CSSProperties = {\n position: \"absolute\",\n width: 0,\n height: 0,\n borderStyle: \"solid\" as const,\n ...arrowStyle,\n };\n\n const arrowStyles: Record<TooltipPosition, React.CSSProperties> = {\n top: {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px 0 ${ARROW_SIZE}px`,\n borderColor: \"#0C0A09 transparent transparent transparent\",\n },\n bottom: {\n ...baseArrowStyle,\n borderWidth: `0 ${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent #0C0A09 transparent\",\n },\n left: {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px 0 ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent transparent #0C0A09\",\n },\n right: {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px 0`,\n borderColor: \"transparent #0C0A09 transparent transparent\",\n },\n \"top-left\": {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px 0 ${ARROW_SIZE}px`,\n borderColor: \"#0C0A09 transparent transparent transparent\",\n },\n \"top-right\": {\n ...baseArrowStyle,\n borderWidth: `${ARROW_SIZE}px ${ARROW_SIZE}px 0 ${ARROW_SIZE}px`,\n borderColor: \"#0C0A09 transparent transparent transparent\",\n },\n \"bottom-left\": {\n ...baseArrowStyle,\n borderWidth: `0 ${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent #0C0A09 transparent\",\n },\n \"bottom-right\": {\n ...baseArrowStyle,\n borderWidth: `0 ${ARROW_SIZE}px ${ARROW_SIZE}px ${ARROW_SIZE}px`,\n borderColor: \"transparent transparent #0C0A09 transparent\",\n },\n };\n return <div style={arrowStyles[position] as any} />;\n};\n\nconst Tooltip: React.FC<TooltipProps> = ({\n content,\n children,\n position = \"top\",\n trigger = \"hover\",\n delay = 200,\n disabled = false,\n className = \"\",\n tooltipClassName = \"\",\n gap = GAP_DEFAULT,\n showArrow = true,\n width,\n defaultVisible = false,\n visible,\n onVisibleChange,\n}) => {\n // 受控或非受控模式\n const isControlled = visible !== undefined;\n const [internalVisible, setInternalVisible] = useState(defaultVisible);\n const isVisible = isControlled ? visible : internalVisible;\n \n // 初始化 isAnimating 状态:受控模式用 visible,非受控模式用 defaultVisible\n const [isAnimating, setIsAnimating] = useState(isControlled ? (visible ?? false) : defaultVisible);\n \n const setIsVisible = useCallback((newVisible: boolean) => {\n if (!isControlled) {\n setInternalVisible(newVisible);\n }\n onVisibleChange?.(newVisible);\n }, [isControlled, onVisibleChange]);\n\n // 当受控模式的 visible 改变时,同步更新 isAnimating\n useEffect(() => {\n if (isControlled) {\n if (visible) {\n // 显示时,延迟一点再开始动画\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n } else {\n // 隐藏时,先停止动画,然后隐藏\n setIsAnimating(false);\n }\n }\n }, [isControlled, visible]);\n const [actualPosition, setActualPosition] = useState<TooltipPosition>(position);\n const [tooltipMaxWidth, setTooltipMaxWidth] = useState<string>(\"320px\");\n const [tooltipStyle, setTooltipStyle] = useState<React.CSSProperties>({\n position: \"absolute\",\n top: 0,\n left: 0,\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n });\n const [arrowStyle, setArrowStyle] = useState<React.CSSProperties>({});\n \n const triggerRef = useRef<HTMLDivElement>(null);\n const tooltipRef = useRef<HTMLDivElement>(null);\n const timeoutRef = useRef<NodeJS.Timeout | null>(null);\n const hideTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n \n const updatePosition = useCallback(() => {\n if (!triggerRef.current || !tooltipRef.current || !isVisible) return;\n \n // 如果正在隐藏动画中,不更新位置,避免移位\n if (!isAnimating) return;\n \n const triggerRect = triggerRef.current.getBoundingClientRect();\n const tooltipRect = tooltipRef.current.getBoundingClientRect();\n \n // 自动选择最佳位置,避免超出视口或被遮挡\n const finalPosition = getAutoPosition(triggerRect, tooltipRect, position, gap);\n setActualPosition(finalPosition);\n \n const { top, left } = calculatePosition(triggerRect, tooltipRect, finalPosition, gap);\n setTooltipStyle((prev) => ({\n ...prev,\n position: \"absolute\",\n top: `${top}px`,\n left: `${left}px`,\n // opacity 由 tooltipContainerStyle 控制,不在这里设置\n // hover 模式下允许鼠标事件,click 模式下禁用\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n zIndex: 9999,\n }));\n\n // 计算箭头位置\n if (showArrow) {\n const arrowPos = getArrowPosition(\n finalPosition,\n triggerRect,\n tooltipRect,\n left,\n top\n );\n setArrowStyle(arrowPos);\n }\n }, [isVisible, position, gap, showArrow, isAnimating, trigger]);\n \n const showTooltip = useCallback(() => {\n if (disabled) return;\n \n // 清除隐藏定时器\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n hideTimeoutRef.current = null;\n }\n \n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n \n timeoutRef.current = setTimeout(() => {\n setIsVisible(true);\n // 触发动画\n if (!isControlled) {\n // 非受控模式下,直接设置动画状态\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n }\n // 受控模式下,动画状态由 visible prop 变化触发的 useEffect 控制\n }, delay);\n }, [disabled, delay, setIsVisible, isControlled]);\n \n const hideTooltip = useCallback(() => {\n // 清除显示定时器\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = null;\n }\n \n // 清除隐藏定时器\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n }\n \n if (!isControlled) {\n // 非受控模式下,先停止动画,然后隐藏\n setIsAnimating(false);\n hideTimeoutRef.current = setTimeout(() => {\n setIsVisible(false);\n hideTimeoutRef.current = null;\n }, 150);\n } else {\n // 受控模式下,直接调用 setIsVisible(会触发 onVisibleChange)\n setIsVisible(false);\n }\n }, [setIsVisible, isControlled]);\n\n // 保持 tooltip 显示(当鼠标在 tooltip 内容上时)\n const keepTooltipVisible = useCallback(() => {\n if (trigger !== \"hover\") return;\n \n // 清除隐藏定时器\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n hideTimeoutRef.current = null;\n }\n \n // 确保 tooltip 可见\n if (!isVisible) {\n setIsVisible(true);\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n }\n }, [trigger, isVisible]);\n\n // 点击触发工具提示(click 模式)\n const handleClick = useCallback((e: React.MouseEvent) => {\n if (disabled || trigger !== \"click\") return;\n \n e.stopPropagation();\n \n // 如果已经显示,则隐藏\n if (isVisible) {\n hideTooltip();\n } else {\n // 清除延迟定时器,立即显示(click 模式不使用延迟)\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = null;\n }\n setIsVisible(true);\n requestAnimationFrame(() => {\n setIsAnimating(true);\n });\n }\n }, [disabled, trigger, isVisible, hideTooltip]);\n\n // 当 defaultVisible 为 true 时,确保初始位置正确计算\n useEffect(() => {\n if (defaultVisible && isVisible && isAnimating) {\n // 多次尝试更新位置,确保 DOM 已渲染\n const tryUpdatePosition = () => {\n if (triggerRef.current && tooltipRef.current) {\n updatePosition();\n } else {\n // 如果 DOM 还没准备好,再试一次\n setTimeout(() => {\n requestAnimationFrame(tryUpdatePosition);\n }, 10);\n }\n };\n \n // 延迟执行,确保 Portal 已渲染到 DOM\n setTimeout(() => {\n requestAnimationFrame(tryUpdatePosition);\n }, 0);\n }\n }, [defaultVisible, isVisible, isAnimating, updatePosition]); // 只在初始化时执行\n\n useEffect(() => {\n if (isVisible) {\n // 使用 requestAnimationFrame 确保 DOM 已更新\n requestAnimationFrame(() => {\n updatePosition();\n });\n \n // 监听滚动和窗口大小变化\n window.addEventListener(\"scroll\", updatePosition, true);\n window.addEventListener(\"resize\", updatePosition);\n \n return () => {\n window.removeEventListener(\"scroll\", updatePosition, true);\n window.removeEventListener(\"resize\", updatePosition);\n };\n }\n }, [isVisible, updatePosition]);\n\n // 点击外部区域关闭 tooltip(仅 click 模式)\n useEffect(() => {\n if (!isVisible || trigger !== \"click\") return;\n\n const handleClickOutside = (event: MouseEvent) => {\n if (\n triggerRef.current &&\n tooltipRef.current &&\n !triggerRef.current.contains(event.target as Node) &&\n !tooltipRef.current.contains(event.target as Node)\n ) {\n hideTooltip();\n }\n };\n\n // 使用捕获阶段确保在其他点击处理之前执行\n document.addEventListener(\"mousedown\", handleClickOutside, true);\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside, true);\n };\n }, [isVisible, trigger, hideTooltip]);\n \n useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n if (hideTimeoutRef.current) {\n clearTimeout(hideTimeoutRef.current);\n }\n };\n }, []);\n\n // Tooltip 容器样式\n const tooltipContainerStyle: React.CSSProperties = {\n position: \"absolute\",\n top: 0,\n left: 0,\n opacity: isAnimating ? 1 : 0,\n transform: isAnimating ? \"scale(1)\" : \"scale(0.95)\",\n transition: \"opacity 150ms ease-out, transform 150ms ease-out\",\n // hover 模式下允许鼠标事件,click 模式下禁用\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n zIndex: 9999,\n };\n\n // 计算 tooltip 最大宽度\n const calculateTooltipMaxWidth = useCallback((): string => {\n if (typeof window === \"undefined\") return \"320px\";\n const viewportWidth = window.innerWidth;\n // 移动端:使用 calc 确保不超出屏幕\n // 桌面端:最大宽度 320px\n return viewportWidth >= 768 ? \"320px\" : \"calc(100vw - 32px)\";\n }, []);\n\n // 更新 tooltip 最大宽度\n useEffect(() => {\n const updateMaxWidth = () => {\n setTooltipMaxWidth(calculateTooltipMaxWidth());\n };\n \n updateMaxWidth();\n window.addEventListener(\"resize\", updateMaxWidth);\n \n return () => {\n window.removeEventListener(\"resize\", updateMaxWidth);\n };\n }, [calculateTooltipMaxWidth]);\n\n // Tooltip 内容样式(符合设计系统)\n const tooltipContentStyle: React.CSSProperties = {\n backgroundColor: \"#0C0A09\",\n color: \"#FFFFFF\",\n padding: \"8px 12px\",\n borderRadius: \"6px\",\n fontSize: \"12px\",\n fontWeight: 400,\n fontFamily: \"DM Sans, sans-serif\",\n lineHeight: \"16px\",\n // 如果设置了 width,使用设置的宽度,但在移动端也要限制最大宽度;否则使用自动计算的最大宽度\n ...(width !== undefined\n ? {\n width: typeof width === \"number\" ? `${width}px` : width,\n // 移动端也要限制最大宽度,不能超出屏幕\n maxWidth: typeof window !== \"undefined\" && window.innerWidth < 768 \n ? \"calc(100vw - 32px)\" \n : undefined,\n }\n : {\n maxWidth: tooltipMaxWidth,\n width: \"max-content\",\n }),\n wordWrap: \"break-word\",\n boxShadow: \"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)\",\n whiteSpace: \"pre-wrap\",\n position: \"relative\",\n boxSizing: \"border-box\",\n };\n\n const tooltipContent = (\n <div\n style={{\n ...tooltipContainerStyle,\n ...tooltipStyle,\n // 确保 hover 模式下 pointerEvents 为 auto\n pointerEvents: trigger === \"hover\" ? \"auto\" : \"none\",\n } as any}\n className={`aha-tooltip-wrapper ${tooltipClassName}`}\n onMouseEnter={trigger === \"hover\" ? keepTooltipVisible : undefined}\n onMouseLeave={trigger === \"hover\" ? hideTooltip : undefined}\n >\n <div\n ref={tooltipRef}\n className={`aha-tooltip ${tooltipClassName}`}\n style={tooltipContentStyle as any}\n role=\"tooltip\"\n >\n {content}\n </div>\n {showArrow && renderArrow(actualPosition, arrowStyle)}\n </div>\n );\n \n // 延迟隐藏(用于从触发元素移动到 tooltip 内容的过渡)\n const handleTriggerMouseLeave = useCallback(() => {\n if (trigger !== \"hover\") return;\n \n // 延迟隐藏,给用户时间移动到 tooltip 内容上\n // 如果用户在延迟期间移动到 tooltip 内容上,keepTooltipVisible 会清除这个定时器\n hideTimeoutRef.current = setTimeout(() => {\n hideTooltip();\n }, 100);\n }, [trigger, hideTooltip]);\n\n // 根据触发模式设置事件处理器\n const triggerProps = trigger === \"click\" \n ? {\n onClick: handleClick,\n }\n : {\n onMouseEnter: showTooltip,\n onMouseLeave: handleTriggerMouseLeave,\n onFocus: showTooltip,\n onBlur: hideTooltip,\n };\n\n return (\n <>\n <div\n ref={triggerRef}\n className={`aha-tooltip-trigger ${className}`}\n style={{ display: \"inline-block\", cursor: trigger === \"click\" ? \"pointer\" : \"default\" }}\n {...triggerProps}\n >\n {children}\n </div>\n {isVisible && typeof document !== \"undefined\" && createPortal(tooltipContent, document.body)}\n </>\n );\n};\n\nexport default Tooltip;","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nexport type PopoverTrigger = \"click\" | \"hover\";\nexport type PopoverPlacement = \"top\" | \"right\" | \"bottom\" | \"left\";\n\nexport interface PopoverProps {\n /** 触发节点 */\n children: React.ReactNode;\n /** Popover 内容 */\n content: React.ReactNode;\n /** 触发模式 */\n trigger?: PopoverTrigger;\n /** 是否显示(受控) */\n open?: boolean;\n /** 默认是否显示(非受控) */\n defaultOpen?: boolean;\n /** 显示状态变化回调 */\n onOpenChange?: (open: boolean) => void;\n /** 展示方向 */\n placement?: PopoverPlacement;\n /** 内容宽度 */\n width?: string | number;\n /** 触发节点和 Popover 的间距 */\n offset?: number;\n /** 自定义容器类名 */\n className?: string;\n /** 自定义 Popover 类名 */\n popoverClassName?: string;\n /** 是否禁用 */\n disabled?: boolean;\n /** 关闭时是否销毁内容,默认 true */\n destroyOnHide?: boolean;\n /** antd 兼容参数:关闭时是否销毁内容 */\n destroyTooltipOnHide?: boolean;\n /** 是否显示箭头(兼容参数,当前不渲染箭头) */\n arrow?: boolean;\n}\n\nconst DEFAULT_OFFSET = 8;\nconst VIEWPORT_PADDING = 8;\n\nconst getOppositePlacement = (placement: PopoverPlacement): PopoverPlacement => {\n switch (placement) {\n case \"top\":\n return \"bottom\";\n case \"bottom\":\n return \"top\";\n case \"left\":\n return \"right\";\n case \"right\":\n default:\n return \"left\";\n }\n};\n\nconst hasEnoughSpace = (\n triggerRect: DOMRect,\n popoverRect: DOMRect,\n placement: PopoverPlacement,\n offset: number\n) => {\n switch (placement) {\n case \"top\":\n return triggerRect.top >= popoverRect.height + offset + VIEWPORT_PADDING;\n case \"bottom\":\n return window.innerHeight - triggerRect.bottom >= popoverRect.height + offset + VIEWPORT_PADDING;\n case \"left\":\n return triggerRect.left >= popoverRect.width + offset + VIEWPORT_PADDING;\n case \"right\":\n default:\n return window.innerWidth - triggerRect.right >= popoverRect.width + offset + VIEWPORT_PADDING;\n }\n};\n\nconst getAvailableSpace = (triggerRect: DOMRect, placement: PopoverPlacement) => {\n switch (placement) {\n case \"top\":\n return triggerRect.top;\n case \"bottom\":\n return window.innerHeight - triggerRect.bottom;\n case \"left\":\n return triggerRect.left;\n case \"right\":\n default:\n return window.innerWidth - triggerRect.right;\n }\n};\n\nconst getPlacementPosition = (\n triggerRect: DOMRect,\n popoverRect: DOMRect,\n placement: PopoverPlacement,\n offset: number\n) => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n const triggerCenterX = triggerRect.left + triggerRect.width / 2;\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n\n switch (placement) {\n case \"top\":\n return {\n top: triggerRect.top - popoverRect.height - offset + scrollY,\n left: triggerCenterX - popoverRect.width / 2 + scrollX,\n };\n case \"bottom\":\n return {\n top: triggerRect.bottom + offset + scrollY,\n left: triggerCenterX - popoverRect.width / 2 + scrollX,\n };\n case \"left\":\n return {\n top: triggerCenterY - popoverRect.height / 2 + scrollY,\n left: triggerRect.left - popoverRect.width - offset + scrollX,\n };\n case \"right\":\n default:\n return {\n top: triggerCenterY - popoverRect.height / 2 + scrollY,\n left: triggerRect.right + offset + scrollX,\n };\n }\n};\n\nconst clampToViewport = (top: number, left: number, popoverRect: DOMRect) => {\n const scrollX = window.scrollX || window.pageXOffset;\n const scrollY = window.scrollY || window.pageYOffset;\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const boundaryPadding = VIEWPORT_PADDING;\n\n let nextTop = top;\n let nextLeft = left;\n\n if (nextLeft < scrollX + boundaryPadding) {\n nextLeft = scrollX + boundaryPadding;\n }\n if (nextLeft + popoverRect.width > scrollX + viewportWidth - boundaryPadding) {\n nextLeft = scrollX + viewportWidth - popoverRect.width - boundaryPadding;\n }\n\n if (nextTop < scrollY + boundaryPadding) {\n nextTop = scrollY + boundaryPadding;\n }\n if (nextTop + popoverRect.height > scrollY + viewportHeight - boundaryPadding) {\n nextTop = scrollY + viewportHeight - popoverRect.height - boundaryPadding;\n }\n\n return { top: nextTop, left: nextLeft };\n};\n\nconst Popover: React.FC<PopoverProps> = ({\n children,\n content,\n trigger = \"click\",\n open,\n defaultOpen = false,\n onOpenChange,\n placement = \"right\",\n width,\n offset = DEFAULT_OFFSET,\n className = \"\",\n popoverClassName = \"\",\n disabled = false,\n destroyOnHide,\n destroyTooltipOnHide,\n}) => {\n const shouldDestroyOnHide =\n destroyOnHide ?? destroyTooltipOnHide ?? true;\n const isControlled = open !== undefined;\n const [internalVisible, setInternalVisible] = useState(defaultOpen);\n const visible = isControlled ? !!open : internalVisible;\n const [popoverStyle, setPopoverStyle] = useState<React.CSSProperties>({\n top: 0,\n left: 0,\n opacity: 0,\n });\n\n const triggerRef = useRef<HTMLDivElement>(null);\n const popoverRef = useRef<HTMLDivElement>(null);\n\n const setVisible = useCallback(\n (nextVisible: boolean) => {\n if (!isControlled) {\n setInternalVisible(nextVisible);\n }\n onOpenChange?.(nextVisible);\n },\n [isControlled, onOpenChange]\n );\n\n const updatePosition = useCallback(() => {\n if (!visible || !triggerRef.current || !popoverRef.current) {\n return;\n }\n\n const triggerRect = triggerRef.current.getBoundingClientRect();\n const popoverRect = popoverRef.current.getBoundingClientRect();\n const nextPlacement = (() => {\n if (hasEnoughSpace(triggerRect, popoverRect, placement, offset)) {\n return placement;\n }\n const oppositePlacement = getOppositePlacement(placement);\n if (hasEnoughSpace(triggerRect, popoverRect, oppositePlacement, offset)) {\n return oppositePlacement;\n }\n return getAvailableSpace(triggerRect, oppositePlacement) > getAvailableSpace(triggerRect, placement)\n ? oppositePlacement\n : placement;\n })();\n\n const { top, left } = getPlacementPosition(triggerRect, popoverRect, nextPlacement, offset);\n const clamped = clampToViewport(top, left, popoverRect);\n\n setPopoverStyle({\n top: clamped.top,\n left: clamped.left,\n opacity: 1,\n });\n }, [visible, placement, offset]);\n\n const openPopover = useCallback(() => {\n if (disabled) return;\n setVisible(true);\n }, [disabled, setVisible]);\n\n const closePopover = useCallback(() => {\n setVisible(false);\n }, [setVisible]);\n\n const togglePopover = useCallback(() => {\n if (disabled) return;\n setVisible(!visible);\n }, [disabled, visible, setVisible]);\n\n useEffect(() => {\n if (!visible) return;\n\n requestAnimationFrame(() => {\n updatePosition();\n });\n\n window.addEventListener(\"resize\", updatePosition);\n window.addEventListener(\"scroll\", updatePosition, true);\n\n return () => {\n window.removeEventListener(\"resize\", updatePosition);\n window.removeEventListener(\"scroll\", updatePosition, true);\n };\n }, [visible, updatePosition]);\n\n useEffect(() => {\n if (!visible || trigger !== \"click\") return;\n\n const handleClickOutside = (event: MouseEvent) => {\n const target = event.target as Node;\n if (\n triggerRef.current &&\n popoverRef.current &&\n !triggerRef.current.contains(target) &&\n !popoverRef.current.contains(target)\n ) {\n closePopover();\n }\n };\n\n document.addEventListener(\"mousedown\", handleClickOutside);\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n };\n }, [visible, trigger, closePopover]);\n\n const triggerEvents =\n trigger === \"hover\"\n ? {\n onMouseEnter: openPopover,\n onMouseLeave: closePopover,\n onFocus: openPopover,\n onBlur: closePopover,\n }\n : {\n onClick: (event: React.MouseEvent) => {\n event.stopPropagation();\n togglePopover();\n },\n };\n\n const shouldRenderPopoverNode = visible || !shouldDestroyOnHide;\n\n const popoverNode = shouldRenderPopoverNode ? (\n <div\n ref={popoverRef}\n className={`aha-popover ${popoverClassName}`}\n style={{\n position: \"absolute\",\n zIndex: 9999,\n top: popoverStyle.top,\n left: popoverStyle.left,\n opacity: visible ? popoverStyle.opacity : 0,\n visibility: visible ? \"visible\" : \"hidden\",\n pointerEvents: visible ? \"auto\" : \"none\",\n transition: \"opacity 120ms ease-out\",\n width: typeof width === \"number\" ? `${width}px` : width,\n maxWidth: `calc(100vw - ${VIEWPORT_PADDING * 2}px)`,\n backgroundColor: \"#FFFFFF\",\n border: \"1px solid #00000014\",\n borderRadius: \"12px\",\n padding: \"6px\",\n boxSizing: \"border-box\",\n boxShadow:\n \"0px 2px 2px -1px var(--ColorsEffectsShadowsshadow-lg03), 0px 4px 6px -2px var(--ColorsEffectsShadowsshadow-lg02), 0px 12px 16px -4px var(--ColorsEffectsShadowsshadow-lg01)\",\n }}\n onMouseEnter={trigger === \"hover\" ? openPopover : undefined}\n onMouseLeave={trigger === \"hover\" ? closePopover : undefined}\n onMouseDown={trigger === \"click\" ? (event) => event.stopPropagation() : undefined}\n >\n {content}\n </div>\n ) : null;\n\n return (\n <>\n <div\n ref={triggerRef}\n className={`aha-popover-trigger ${className}`}\n style={{ display: \"inline-block\", cursor: disabled ? \"not-allowed\" : \"pointer\" }}\n {...triggerEvents}\n >\n {children}\n </div>\n {popoverNode && typeof document !== \"undefined\" && createPortal(popoverNode, document.body)}\n </>\n );\n};\n\nPopover.displayName = \"Popover\";\n\nexport default Popover;\n","import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nexport type DrawerPlacement = \"left\" | \"right\" | \"top\" | \"bottom\";\n\nexport interface DrawerProps {\n /** 是否打开(受控) */\n open?: boolean;\n /** 默认是否打开(非受控) */\n defaultOpen?: boolean;\n /** 关闭回调 */\n onClose?: (e?: React.MouseEvent | React.KeyboardEvent) => void;\n /** 打开/关闭动画结束回调 */\n afterOpenChange?: (open: boolean) => void;\n /** 抽屉标题 */\n title?: React.ReactNode;\n /** 头部右侧内容 */\n extra?: React.ReactNode;\n /** 底部内容 */\n footer?: React.ReactNode;\n /** 内容 */\n children?: React.ReactNode;\n /** 打开方向 */\n placement?: DrawerPlacement;\n /** PC 端宽度(移动端始终使用 100vw) */\n width?: number | string;\n /** 高度(top/bottom 生效,移动端同样支持) */\n height?: number | string;\n /** 是否显示遮罩 */\n mask?: boolean;\n /** 点击遮罩是否关闭 */\n maskClosable?: boolean;\n /** 是否显示右上角关闭按钮 */\n closable?: boolean;\n /** 自定义关闭图标 */\n closeIcon?: React.ReactNode;\n /** 是否支持 Esc 关闭 */\n keyboard?: boolean;\n /** 是否在关闭后销毁内容 */\n destroyOnClose?: boolean;\n /** 层级 */\n zIndex?: number;\n /** 移动端断点 */\n mobileBreakpoint?: number;\n /** 容器类名 */\n className?: string;\n /** 容器样式 */\n style?: React.CSSProperties;\n /** 抽屉面板类名 */\n drawerStyle?: React.CSSProperties;\n /** 头部样式 */\n headerStyle?: React.CSSProperties;\n /** 内容样式 */\n bodyStyle?: React.CSSProperties;\n /** 底部样式 */\n footerStyle?: React.CSSProperties;\n /** 遮罩样式 */\n maskStyle?: React.CSSProperties;\n}\n\nconst ANIMATION_DURATION = 240;\n\nconst Drawer: React.FC<DrawerProps> = ({\n open,\n defaultOpen = false,\n onClose,\n afterOpenChange,\n title,\n extra,\n footer,\n children,\n placement = \"right\",\n width = 378,\n height = 378,\n mask = true,\n maskClosable = true,\n closable = true,\n closeIcon,\n keyboard = true,\n destroyOnClose = false,\n zIndex = 1000,\n mobileBreakpoint = 768,\n className = \"\",\n style,\n drawerStyle,\n headerStyle,\n bodyStyle,\n footerStyle,\n maskStyle,\n}) => {\n const isControlled = open !== undefined;\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const mergedOpen = isControlled ? !!open : internalOpen;\n const [shouldRender, setShouldRender] = useState(mergedOpen);\n const [animatedOpen, setAnimatedOpen] = useState(mergedOpen);\n const [mounted, setMounted] = useState(false);\n const [isMobile, setIsMobile] = useState(false);\n\n useEffect(() => {\n setMounted(true);\n }, []);\n\n useEffect(() => {\n const updateMobile = () => {\n setIsMobile(window.innerWidth < mobileBreakpoint);\n };\n\n updateMobile();\n window.addEventListener(\"resize\", updateMobile);\n return () => {\n window.removeEventListener(\"resize\", updateMobile);\n };\n }, [mobileBreakpoint]);\n\n useEffect(() => {\n if (mergedOpen) {\n setShouldRender(true);\n // 先在新方向的“关闭位置”渲染一帧,再执行打开动画,避免方向切换时动画起点错误\n setAnimatedOpen(false);\n const raf = requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n setAnimatedOpen(true);\n });\n });\n const timer = window.setTimeout(() => {\n afterOpenChange?.(true);\n }, ANIMATION_DURATION);\n return () => {\n cancelAnimationFrame(raf);\n window.clearTimeout(timer);\n };\n }\n\n setAnimatedOpen(false);\n const timer = window.setTimeout(() => {\n if (destroyOnClose) {\n setShouldRender(false);\n }\n afterOpenChange?.(false);\n }, ANIMATION_DURATION);\n\n return () => window.clearTimeout(timer);\n }, [mergedOpen, destroyOnClose, afterOpenChange]);\n\n useEffect(() => {\n if (!mergedOpen || !keyboard) return;\n\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onClose?.(event as unknown as React.KeyboardEvent);\n if (!isControlled) {\n setInternalOpen(false);\n }\n }\n };\n\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => {\n document.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [mergedOpen, keyboard, onClose, isControlled]);\n\n useEffect(() => {\n if (!mounted) return;\n if (!mergedOpen) return;\n\n const previousOverflow = document.body.style.overflow;\n document.body.style.overflow = \"hidden\";\n\n return () => {\n document.body.style.overflow = previousOverflow;\n };\n }, [mergedOpen, mounted]);\n\n const closeDrawer = useCallback(\n (e?: React.MouseEvent | React.KeyboardEvent) => {\n onClose?.(e);\n if (!isControlled) {\n setInternalOpen(false);\n }\n },\n [onClose, isControlled]\n );\n\n const resolvedWidth = useMemo(() => {\n if (isMobile) return \"100vw\";\n if (placement === \"left\" || placement === \"right\") {\n return typeof width === \"number\" ? `${width}px` : width;\n }\n return \"100vw\";\n }, [placement, isMobile, width]);\n\n const resolvedHeight = useMemo(() => {\n if (placement === \"top\" || placement === \"bottom\") {\n return typeof height === \"number\" ? `${height}px` : height;\n }\n return \"100vh\";\n }, [placement, height]);\n\n const effectivePlacement: DrawerPlacement = useMemo(() => {\n if (!isMobile) return placement;\n // 移动端仅支持 top / bottom,left / right 自动降级为 bottom\n if (placement === \"left\" || placement === \"right\") return \"bottom\";\n return placement;\n }, [isMobile, placement]);\n\n const drawerPositionStyle: React.CSSProperties = useMemo(() => {\n const base: React.CSSProperties = {\n position: \"fixed\",\n backgroundColor: \"#FFFFFF\",\n display: \"flex\",\n flexDirection: \"column\",\n boxSizing: \"border-box\",\n boxShadow: \"0 6px 16px rgba(0, 0, 0, 0.08), 0 3px 6px rgba(0, 0, 0, 0.12)\",\n transition: `transform ${ANIMATION_DURATION}ms cubic-bezier(0.2, 0, 0, 1)`,\n zIndex: zIndex + 1,\n };\n\n switch (effectivePlacement) {\n case \"left\":\n return {\n ...base,\n top: 0,\n left: 0,\n width: resolvedWidth,\n height: \"100vh\",\n transform: animatedOpen ? \"translateX(0)\" : \"translateX(-100%)\",\n };\n case \"right\":\n return {\n ...base,\n top: 0,\n right: 0,\n width: resolvedWidth,\n height: \"100vh\",\n transform: animatedOpen ? \"translateX(0)\" : \"translateX(100%)\",\n };\n case \"top\":\n return {\n ...base,\n top: 0,\n left: 0,\n width: \"100vw\",\n height: resolvedHeight,\n transform: animatedOpen ? \"translateY(0)\" : \"translateY(-100%)\",\n };\n case \"bottom\":\n default:\n return {\n ...base,\n bottom: 0,\n left: 0,\n width: \"100vw\",\n height: resolvedHeight,\n transform: animatedOpen ? \"translateY(0)\" : \"translateY(100%)\",\n };\n }\n }, [effectivePlacement, resolvedWidth, resolvedHeight, animatedOpen, zIndex]);\n\n if (!mounted || (!shouldRender && !mergedOpen)) {\n return null;\n }\n\n const node = (\n <div\n className={`aha-drawer-root ${className}`}\n style={{\n position: \"fixed\",\n inset: 0,\n zIndex,\n pointerEvents: mergedOpen || animatedOpen ? \"auto\" : \"none\",\n ...style,\n }}\n >\n {mask && (\n <div\n aria-hidden\n onClick={maskClosable ? (e) => closeDrawer(e) : undefined}\n style={{\n position: \"absolute\",\n inset: 0,\n background: \"rgba(0, 0, 0, 0.45)\",\n opacity: animatedOpen ? 1 : 0,\n transition: `opacity ${ANIMATION_DURATION}ms cubic-bezier(0.2, 0, 0, 1)`,\n ...maskStyle,\n }}\n />\n )}\n\n <div\n key={`${effectivePlacement}-${mergedOpen ? \"open\" : \"closed\"}`}\n role=\"dialog\"\n aria-modal=\"true\"\n style={{ ...drawerPositionStyle, ...drawerStyle }}\n >\n {(title !== undefined || closable || extra) && (\n <div\n style={{\n minHeight: \"56px\",\n padding: \"16px 24px\",\n borderBottom: \"1px solid #F0F0F0\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"space-between\",\n gap: \"12px\",\n ...headerStyle,\n }}\n >\n <div style={{ fontSize: \"16px\", fontWeight: 600, color: \"#1F2937\", flex: 1 }}>{title}</div>\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\n {extra}\n {closable && (\n <button\n type=\"button\"\n onClick={(e) => closeDrawer(e)}\n style={{\n border: \"none\",\n background: \"transparent\",\n padding: 0,\n margin: 0,\n width: \"24px\",\n height: \"24px\",\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n cursor: \"pointer\",\n color: \"#6B7280\",\n }}\n aria-label=\"Close\"\n >\n {closeIcon || (\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n <path\n d=\"M12 4L4 12M4 4L12 12\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )}\n </button>\n )}\n </div>\n </div>\n )}\n\n <div\n style={{\n padding: \"24px\",\n overflowY: \"auto\",\n flex: 1,\n boxSizing: \"border-box\",\n ...bodyStyle,\n }}\n >\n {children}\n </div>\n\n {footer !== undefined && (\n <div\n style={{\n borderTop: \"1px solid #F0F0F0\",\n padding: \"12px 16px\",\n ...footerStyle,\n }}\n >\n {footer}\n </div>\n )}\n </div>\n </div>\n );\n\n return createPortal(node, document.body);\n};\n\nDrawer.displayName = \"Drawer\";\n\nexport default Drawer;\n","import React, { useEffect, useRef, useState } from 'react';\n\nconst curve = {\n name: 'Thinking Five',\n tag: 'Custom Rose Trail',\n rotate: true,\n particleCount: 62,\n trailSpan: 0.38,\n durationMs: 3900,\n rotationDurationMs: 28000,\n pulseDurationMs: 3000,\n strokeWidth: 5.5,\n baseRadius: 7,\n detailAmplitude: 3,\n petalCount: 5,\n curveScale: 3,\n} as const;\n\ntype CurveConfig = typeof curve;\n\nfunction point(\n progress: number,\n detailScaleValue: number,\n config: CurveConfig\n): { x: number; y: number } {\n const t = progress * Math.PI * 2;\n const petals = Math.round(config.petalCount);\n const x =\n config.baseRadius * Math.cos(t) -\n config.detailAmplitude * detailScaleValue * Math.cos(petals * t);\n const y =\n config.baseRadius * Math.sin(t) -\n config.detailAmplitude * detailScaleValue * Math.sin(petals * t);\n return {\n x: 50 + x * config.curveScale,\n y: 50 + y * config.curveScale,\n };\n}\n\nfunction getDetailScale(elapsedMs: number, config: CurveConfig): number {\n const pulseProgress =\n (elapsedMs % config.pulseDurationMs) / config.pulseDurationMs;\n const pulseAngle = pulseProgress * Math.PI * 2;\n return 0.52 + ((Math.sin(pulseAngle + 0.55) + 1) / 2) * 0.48;\n}\n\nfunction normalizeProgress(progress: number): number {\n return ((progress % 1) + 1) % 1;\n}\n\nfunction buildPath(detailScaleValue: number, config: CurveConfig, steps = 480): string {\n const parts: string[] = [];\n for (let index = 0; index <= steps; index += 1) {\n const p = point(index / steps, detailScaleValue, config);\n parts.push(`${index === 0 ? 'M' : 'L'} ${p.x.toFixed(2)} ${p.y.toFixed(2)}`);\n }\n return parts.join(' ');\n}\n\nfunction getParticle(\n index: number,\n progress: number,\n detailScaleValue: number,\n config: CurveConfig\n): { x: number; y: number; radius: number; opacity: number } {\n const denom = Math.max(1, config.particleCount - 1);\n const tailOffset = index / denom;\n const p = point(\n normalizeProgress(progress - tailOffset * config.trailSpan),\n detailScaleValue,\n config\n );\n const fade = Math.pow(1 - tailOffset, 0.56);\n return {\n x: p.x,\n y: p.y,\n radius: 0.9 + fade * 2.7,\n opacity: 0.04 + fade * 0.96,\n };\n}\n\nfunction getRotationDeg(elapsedMs: number, config: CurveConfig): number {\n if (!config.rotate) return 0;\n return -(\n ((elapsedMs % config.rotationDurationMs) / config.rotationDurationMs) *\n 360\n );\n}\n\nexport interface LoadingProps {\n width?: number | string;\n height?: number | string;\n strokeWidth?: number;\n color?: string;\n className?: string;\n}\n\nconst Loading: React.FC<LoadingProps> = ({\n width = 80,\n height = 80,\n strokeWidth: strokeWidthProp,\n color = 'var(--theme-color, #5A31F0)',\n className,\n}) => {\n const [frame, setFrame] = useState(0);\n const startRef = useRef<number | null>(null);\n\n useEffect(() => {\n let id: number;\n const tick = (now: number) => {\n if (startRef.current === null) {\n startRef.current = now;\n }\n setFrame(now - startRef.current);\n id = requestAnimationFrame(tick);\n };\n id = requestAnimationFrame(tick);\n return () => cancelAnimationFrame(id);\n }, []);\n\n const elapsed = frame;\n const s = getDetailScale(elapsed, curve);\n const progress = (elapsed % curve.durationMs) / curve.durationMs;\n const rotationDeg = getRotationDeg(elapsed, curve);\n const lineWeight = strokeWidthProp ?? curve.strokeWidth;\n const strokeScale = lineWeight / curve.strokeWidth;\n\n const pathD = buildPath(s, curve);\n\n const particles: { cx: number; cy: number; opacity: number; r: number }[] =\n [];\n for (let i = 0; i < curve.particleCount; i += 1) {\n const pt = getParticle(i, progress, s, curve);\n particles.push({\n cx: pt.x,\n cy: pt.y,\n opacity: pt.opacity,\n r: pt.radius * strokeScale,\n });\n }\n\n return (\n <div\n className={className}\n style={{\n width,\n height,\n display: 'inline-block',\n color,\n }}\n role=\"status\"\n aria-label=\"Loading\"\n >\n <svg\n width=\"100%\"\n height=\"100%\"\n viewBox=\"0 0 100 100\"\n fill=\"none\"\n preserveAspectRatio=\"xMidYMid meet\"\n style={{ overflow: 'visible' }}\n >\n <title>Thinking Five</title>\n <g transform={curve.rotate ? `rotate(${rotationDeg} 50 50)` : undefined}>\n <path\n d={pathD}\n stroke=\"currentColor\"\n strokeWidth={lineWeight}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n fill=\"none\"\n opacity={0.1}\n />\n {particles.map((pt, i) => (\n <circle\n key={i}\n cx={pt.cx}\n cy={pt.cy}\n r={pt.r}\n fill=\"currentColor\"\n opacity={pt.opacity}\n />\n ))}\n </g>\n </svg>\n </div>\n );\n};\n\nexport default Loading;\n","import React, { useState } from 'react';\nimport type { MouseEventHandler, ReactNode } from 'react';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport type BadgeColor =\n | 'gray'\n | 'brand'\n | 'error'\n | 'warning'\n | 'success'\n | 'grayBlue'\n | 'blueLight'\n | 'blue'\n | 'indigo'\n | 'purple'\n | 'pink'\n | 'orange';\n\nexport type BadgeVariant = 'pill' | 'badge' | 'modern';\n\nexport type BadgeSize = 'sm' | 'md' | 'lg';\n\nexport type BadgeIconComponent = React.FC<{\n style?: React.CSSProperties;\n className?: string;\n}>;\n\n// ─── Color Tokens ─────────────────────────────────────────────────────────────\n\ninterface ColorTokens {\n bg: string;\n text: string;\n ring: string;\n dot: string;\n btnText: string;\n btnHoverBg: string;\n btnHoverText: string;\n}\n\nconst colorTokens: Record<BadgeColor, ColorTokens> = {\n gray: {\n bg: 'var(--color-gray-50)',\n text: 'var(--color-gray-700)',\n ring: 'var(--color-gray-200)',\n dot: 'var(--color-gray-500)',\n btnText: 'var(--color-gray-400)',\n btnHoverBg: 'var(--color-gray-100)',\n btnHoverText: 'var(--color-gray-500)',\n },\n brand: {\n bg: 'var(--color-brand-50)',\n text: 'var(--color-brand-700)',\n ring: 'var(--color-brand-200)',\n dot: 'var(--color-brand-500)',\n btnText: 'var(--color-brand-400)',\n btnHoverBg: 'var(--color-brand-100)',\n btnHoverText: 'var(--color-brand-500)',\n },\n error: {\n bg: 'var(--color-error-50)',\n text: 'var(--color-error-700)',\n ring: 'var(--color-error-200)',\n dot: 'var(--color-error-500)',\n btnText: 'var(--color-error-400)',\n btnHoverBg: 'var(--color-error-100)',\n btnHoverText: 'var(--color-error-500)',\n },\n warning: {\n bg: 'var(--color-warning-50)',\n text: 'var(--color-warning-700)',\n ring: 'var(--color-warning-200)',\n dot: 'var(--color-warning-500)',\n btnText: 'var(--color-warning-400)',\n btnHoverBg: 'var(--color-warning-100)',\n btnHoverText: 'var(--color-warning-500)',\n },\n success: {\n bg: 'var(--color-success-50)',\n text: 'var(--color-success-700)',\n ring: 'var(--color-success-200)',\n dot: 'var(--color-success-500)',\n btnText: 'var(--color-success-400)',\n btnHoverBg: 'var(--color-success-100)',\n btnHoverText: 'var(--color-success-500)',\n },\n grayBlue: {\n bg: 'var(--color-gray-blue-50)',\n text: 'var(--color-gray-blue-700)',\n ring: 'var(--color-gray-blue-200)',\n dot: 'var(--color-gray-blue-500)',\n btnText: 'var(--color-gray-blue-400)',\n btnHoverBg: 'var(--color-gray-blue-100)',\n btnHoverText: 'var(--color-gray-blue-500)',\n },\n blueLight: {\n bg: 'var(--color-blue-light-50)',\n text: 'var(--color-blue-light-700)',\n ring: 'var(--color-blue-light-200)',\n dot: 'var(--color-blue-light-500)',\n btnText: 'var(--color-blue-light-400)',\n btnHoverBg: 'var(--color-blue-light-100)',\n btnHoverText: 'var(--color-blue-light-500)',\n },\n blue: {\n bg: 'var(--color-blue-50)',\n text: 'var(--color-blue-700)',\n ring: 'var(--color-blue-200)',\n dot: 'var(--color-blue-500)',\n btnText: 'var(--color-blue-400)',\n btnHoverBg: 'var(--color-blue-100)',\n btnHoverText: 'var(--color-blue-500)',\n },\n indigo: {\n bg: 'var(--color-indigo-50)',\n text: 'var(--color-indigo-700)',\n ring: 'var(--color-indigo-200)',\n dot: 'var(--color-indigo-500)',\n btnText: 'var(--color-indigo-400)',\n btnHoverBg: 'var(--color-indigo-100)',\n btnHoverText: 'var(--color-indigo-500)',\n },\n purple: {\n bg: 'var(--color-purple-50)',\n text: 'var(--color-purple-700)',\n ring: 'var(--color-purple-200)',\n dot: 'var(--color-purple-500)',\n btnText: 'var(--color-purple-400)',\n btnHoverBg: 'var(--color-purple-100)',\n btnHoverText: 'var(--color-purple-500)',\n },\n pink: {\n bg: 'var(--color-pink-50)',\n text: 'var(--color-pink-700)',\n ring: 'var(--color-pink-200)',\n dot: 'var(--color-pink-500)',\n btnText: 'var(--color-pink-400)',\n btnHoverBg: 'var(--color-pink-100)',\n btnHoverText: 'var(--color-pink-500)',\n },\n orange: {\n bg: 'var(--color-orange-50)',\n text: 'var(--color-orange-700)',\n ring: 'var(--color-orange-200)',\n dot: 'var(--color-orange-500)',\n btnText: 'var(--color-orange-400)',\n btnHoverBg: 'var(--color-orange-100)',\n btnHoverText: 'var(--color-orange-500)',\n },\n};\n\n// ─── Size Configs ─────────────────────────────────────────────────────────────\n\nconst pillPadding: Record<BadgeSize, string> = {\n sm: '2px 8px',\n md: '2px 10px',\n lg: '4px 12px',\n};\nconst badgePadding: Record<BadgeSize, string> = {\n sm: '2px 6px',\n md: '2px 8px',\n lg: '4px 10px',\n};\nconst fontSize: Record<BadgeSize, string> = {\n sm: '12px',\n md: '14px',\n lg: '14px',\n};\n\n// ─── Helpers ──────────────────────────────────────────────────────────────────\n\nfunction getTokens(variant: BadgeVariant, color: BadgeColor) {\n if (variant === 'modern') {\n return {\n ...colorTokens[color],\n bg: 'var(--color-bg-primary)',\n text: 'var(--color-text-secondary)',\n ring: 'var(--color-border-secondary)',\n };\n }\n return colorTokens[color];\n}\n\nfunction getRootStyle(\n variant: BadgeVariant,\n color: BadgeColor,\n size: BadgeSize,\n extra?: React.CSSProperties,\n): React.CSSProperties {\n const t = getTokens(variant, color);\n const isPill = variant === 'pill';\n const isLg = size === 'lg' && !isPill;\n const ring = `inset 0 0 0 1px ${t.ring}`;\n const shadow =\n variant === 'modern'\n ? `${ring}, 0px 1px 2px 0px rgba(10, 13, 18, 0.05)`\n : ring;\n\n return {\n display: 'inline-flex',\n alignItems: 'center',\n whiteSpace: 'nowrap',\n width: 'max-content',\n borderRadius: isPill ? '9999px' : isLg ? '8px' : '6px',\n backgroundColor: t.bg,\n color: t.text,\n boxShadow: shadow,\n fontFamily: 'DM Sans, system-ui, sans-serif',\n fontWeight: 500,\n fontSize: fontSize[size],\n lineHeight: size === 'sm' ? '18px' : '20px',\n padding: isPill ? pillPadding[size] : badgePadding[size],\n ...extra,\n };\n}\n\n// ─── Dot ──────────────────────────────────────────────────────────────────────\n\nconst BadgeDot: React.FC<{ color: string }> = ({ color }) => (\n <svg\n width=\"8\"\n height=\"8\"\n viewBox=\"0 0 8 8\"\n fill=\"none\"\n style={{ flexShrink: 0 }}\n >\n <circle cx=\"4\" cy=\"4\" r=\"3\" fill={color} />\n </svg>\n);\n\n// ─── X Icon ───────────────────────────────────────────────────────────────────\n\nconst XIcon: React.FC<{ style?: React.CSSProperties }> = ({ style }) => (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n style={style}\n >\n <path d=\"M9 3L3 9M3 3l6 6\" />\n </svg>\n);\n\n// ─── Badge ────────────────────────────────────────────────────────────────────\n\nexport interface BadgeProps {\n variant?: BadgeVariant;\n size?: BadgeSize;\n color?: BadgeColor;\n children: ReactNode;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const Badge: React.FC<BadgeProps> = ({\n variant = 'pill',\n size = 'md',\n color = 'gray',\n children,\n style,\n className,\n}) => (\n <span\n style={{ ...getRootStyle(variant, color, size), ...style }}\n className={className}\n >\n {children}\n </span>\n);\n\n// ─── BadgeWithDot ─────────────────────────────────────────────────────────────\n\nexport interface BadgeWithDotProps {\n variant?: BadgeVariant;\n size?: BadgeSize;\n color?: BadgeColor;\n children: ReactNode;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const BadgeWithDot: React.FC<BadgeWithDotProps> = ({\n variant = 'pill',\n size = 'md',\n color = 'gray',\n children,\n style,\n className,\n}) => {\n const t = getTokens(variant, color);\n const dotColor = variant === 'modern' ? colorTokens[color].dot : t.dot;\n const gapMap: Record<BadgeSize, string> = { sm: '4px', md: '6px', lg: '6px' };\n const isPill = variant === 'pill';\n const dotPaddingLeft: Record<BadgeSize, string> = { sm: isPill ? '6px' : '6px', md: isPill ? '8px' : '8px', lg: isPill ? '10px' : '10px' };\n const dotPaddingRight: Record<BadgeSize, string> = { sm: isPill ? '8px' : '6px', md: isPill ? '10px' : '8px', lg: isPill ? '12px' : '10px' };\n\n return (\n <span\n style={{\n ...getRootStyle(variant, color, size),\n gap: gapMap[size],\n paddingLeft: dotPaddingLeft[size],\n paddingRight: dotPaddingRight[size],\n paddingTop: size === 'lg' ? '4px' : '2px',\n paddingBottom: size === 'lg' ? '4px' : '2px',\n ...style,\n }}\n className={className}\n >\n <BadgeDot color={dotColor} />\n {children}\n </span>\n );\n};\n\n// ─── BadgeWithIcon ────────────────────────────────────────────────────────────\n\nexport interface BadgeWithIconProps {\n variant?: BadgeVariant;\n size?: BadgeSize;\n color?: BadgeColor;\n iconLeading?: BadgeIconComponent;\n iconTrailing?: BadgeIconComponent;\n children: ReactNode;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const BadgeWithIcon: React.FC<BadgeWithIconProps> = ({\n variant = 'pill',\n size = 'md',\n color = 'gray',\n iconLeading: IconLeading,\n iconTrailing: IconTrailing,\n children,\n style,\n className,\n}) => {\n const t = getTokens(variant, color);\n const iconColor = variant === 'modern' ? colorTokens[color].dot : t.dot;\n const gapMap: Record<BadgeSize, string> = { sm: '2px', md: '4px', lg: '4px' };\n const iconSize: Record<BadgeSize, string> = { sm: '12px', md: '12px', lg: '14px' };\n\n const isPill = variant === 'pill';\n const hasLeading = !!IconLeading;\n\n const smPad = { pl: isPill ? (hasLeading ? '6px' : '8px') : (hasLeading ? '6px' : '8px'), pr: isPill ? (hasLeading ? '8px' : '6px') : (hasLeading ? '8px' : '6px') };\n const mdPad = { pl: isPill ? (hasLeading ? '8px' : '10px') : (hasLeading ? '8px' : '8px'), pr: isPill ? (hasLeading ? '10px' : '8px') : (hasLeading ? '8px' : '8px') };\n const lgPad = { pl: isPill ? (hasLeading ? '10px' : '12px') : (hasLeading ? '10px' : '10px'), pr: isPill ? (hasLeading ? '12px' : '10px') : (hasLeading ? '10px' : '10px') };\n const padMap: Record<BadgeSize, { pl: string; pr: string }> = { sm: smPad, md: mdPad, lg: lgPad };\n\n return (\n <span\n style={{\n ...getRootStyle(variant, color, size),\n gap: gapMap[size],\n paddingLeft: padMap[size].pl,\n paddingRight: padMap[size].pr,\n paddingTop: size === 'lg' ? '4px' : '2px',\n paddingBottom: size === 'lg' ? '4px' : '2px',\n ...style,\n }}\n className={className}\n >\n {IconLeading && (\n <IconLeading style={{ width: iconSize[size], height: iconSize[size], color: iconColor, flexShrink: 0 }} />\n )}\n {children}\n {IconTrailing && (\n <IconTrailing style={{ width: iconSize[size], height: iconSize[size], color: iconColor, flexShrink: 0 }} />\n )}\n </span>\n );\n};\n\n// ─── BadgeWithButton ──────────────────────────────────────────────────────────\n\nexport interface BadgeWithButtonProps {\n variant?: BadgeVariant;\n size?: BadgeSize;\n color?: BadgeColor;\n icon?: BadgeIconComponent;\n children: ReactNode;\n buttonLabel?: string;\n onButtonClick?: MouseEventHandler<HTMLButtonElement>;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const BadgeWithButton: React.FC<BadgeWithButtonProps> = ({\n variant = 'pill',\n size = 'md',\n color = 'gray',\n icon: Icon,\n buttonLabel,\n onButtonClick,\n children,\n style,\n className,\n}) => {\n const [hovered, setHovered] = useState(false);\n const t = getTokens(variant, color);\n const gapMap: Record<BadgeSize, string> = { sm: '2px', md: '2px', lg: '2px' };\n const isPill = variant === 'pill';\n const plMap: Record<BadgeSize, string> = { sm: isPill ? '8px' : '6px', md: isPill ? '10px' : '8px', lg: isPill ? '12px' : '10px' };\n const prMap: Record<BadgeSize, string> = { sm: isPill ? '3px' : '3px', md: isPill ? '4px' : '4px', lg: isPill ? '6px' : '6px' };\n const btnBorderRadius = isPill ? '9999px' : '3px';\n\n return (\n <span\n style={{\n ...getRootStyle(variant, color, size),\n gap: gapMap[size],\n paddingLeft: plMap[size],\n paddingRight: prMap[size],\n paddingTop: size === 'lg' ? '4px' : '2px',\n paddingBottom: size === 'lg' ? '4px' : '2px',\n ...style,\n }}\n className={className}\n >\n {children}\n <button\n type=\"button\"\n aria-label={buttonLabel}\n onClick={onButtonClick}\n onMouseEnter={() => setHovered(true)}\n onMouseLeave={() => setHovered(false)}\n style={{\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n padding: '2px',\n border: 'none',\n cursor: 'pointer',\n borderRadius: btnBorderRadius,\n backgroundColor: hovered ? t.btnHoverBg : 'transparent',\n color: hovered ? t.btnHoverText : t.btnText,\n transition: 'background-color 100ms linear, color 100ms linear',\n outline: 'none',\n flexShrink: 0,\n }}\n >\n {Icon ? (\n <Icon style={{ width: '12px', height: '12px' }} />\n ) : (\n <XIcon />\n )}\n </button>\n </span>\n );\n};\n\n// ─── BadgeIcon ────────────────────────────────────────────────────────────────\n\nexport interface BadgeIconProps {\n variant?: BadgeVariant;\n size?: BadgeSize;\n color?: BadgeColor;\n icon: BadgeIconComponent;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const BadgeIcon: React.FC<BadgeIconProps> = ({\n variant = 'pill',\n size = 'md',\n color = 'gray',\n icon: Icon,\n style,\n className,\n}) => {\n const t = getTokens(variant, color);\n const iconColor = variant === 'modern' ? colorTokens[color].dot : t.dot;\n const padMap: Record<BadgeSize, string> = { sm: '5px', md: '6px', lg: '8px' };\n const iconSize: Record<BadgeSize, string> = { sm: '12px', md: '12px', lg: '14px' };\n\n return (\n <span\n style={{\n ...getRootStyle(variant, color, size),\n padding: padMap[size],\n ...style,\n }}\n className={className}\n >\n <Icon style={{ width: iconSize[size], height: iconSize[size], color: iconColor }} />\n </span>\n );\n};\n\n// ─── BadgeWithImage ───────────────────────────────────────────────────────────\n\nexport interface BadgeWithImageProps {\n variant?: Exclude<BadgeVariant, 'modern'>;\n size?: BadgeSize;\n color?: BadgeColor;\n imgSrc: string;\n imgAlt?: string;\n children: ReactNode;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const BadgeWithImage: React.FC<BadgeWithImageProps> = ({\n variant = 'pill',\n size = 'md',\n color = 'gray',\n imgSrc,\n imgAlt = 'avatar',\n children,\n style,\n className,\n}) => {\n const isPill = variant === 'pill';\n const gapMap: Record<BadgeSize, string> = { sm: '4px', md: '6px', lg: '6px' };\n const plMap: Record<BadgeSize, string> = {\n sm: isPill ? '3px' : '4px',\n md: isPill ? '4px' : '6px',\n lg: isPill ? '6px' : '8px',\n };\n const prMap: Record<BadgeSize, string> = {\n sm: isPill ? '8px' : '6px',\n md: isPill ? '10px' : '8px',\n lg: isPill ? '12px' : '10px',\n };\n const imgSize: Record<BadgeSize, string> = { sm: '16px', md: '16px', lg: '18px' };\n\n return (\n <span\n style={{\n ...getRootStyle(variant, color, size),\n gap: gapMap[size],\n paddingLeft: plMap[size],\n paddingRight: prMap[size],\n paddingTop: size === 'lg' ? '4px' : '2px',\n paddingBottom: size === 'lg' ? '4px' : '2px',\n ...style,\n }}\n className={className}\n >\n <img\n src={imgSrc}\n alt={imgAlt}\n style={{\n width: imgSize[size],\n height: imgSize[size],\n borderRadius: '9999px',\n objectFit: 'cover',\n flexShrink: 0,\n }}\n />\n {children}\n </span>\n );\n};\n\nexport default Badge;\n","import React, { type FC, useState } from 'react';\n\n// ─── Types ─────────────────────────────────────────────────────────────────────\n\nexport type AvatarSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl';\n\nexport interface AvatarProps {\n size?: AvatarSize;\n src?: string | null;\n alt?: string;\n /** Two-letter initials displayed when no image is provided */\n initials?: string;\n /** Custom icon component displayed as placeholder */\n placeholderIcon?: FC<{ style?: React.CSSProperties }>;\n /** Online/offline status indicator dot */\n status?: 'online' | 'offline';\n /** Company logo badge displayed bottom-right */\n companyIcon?: { src: string; alt?: string };\n /** Blue verified checkmark badge */\n verified?: boolean;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport interface AvatarLabelGroupProps {\n size?: 'sm' | 'md' | 'lg' | 'xl';\n name: string;\n supportingText?: string;\n avatarSrc?: string | null;\n avatarInitials?: string;\n status?: 'online' | 'offline';\n companyIcon?: { src: string; alt?: string };\n verified?: boolean;\n style?: React.CSSProperties;\n className?: string;\n}\n\n// ─── Size Config ────────────────────────────────────────────────────────────────\n\ninterface SizeConfig {\n size: number;\n border: number;\n fontSize: string;\n lineHeight: string;\n iconSize: number;\n onlineIndicator: { size: number; offset: number };\n companyIcon: { size: number; offset: number; border: number };\n verifiedTick: { size: number; offset: number };\n}\n\nconst SIZE_CONFIG: Record<AvatarSize, SizeConfig> = {\n xs: {\n size: 24, border: 0.5, fontSize: 'var(--font-size-text-xs)', lineHeight: 'var(--line-height-text-xs)', iconSize: 16,\n onlineIndicator: { size: 6, offset: -0.5 },\n companyIcon: { size: 10, offset: -2.5, border: 1.5 },\n verifiedTick: { size: 10, offset: -1.5 },\n },\n sm: {\n size: 32, border: 0.75, fontSize: 'var(--font-size-text-sm)', lineHeight: 'var(--line-height-text-sm)', iconSize: 20,\n onlineIndicator: { size: 8, offset: -0.75 },\n companyIcon: { size: 12, offset: -2.75, border: 1.5 },\n verifiedTick: { size: 12, offset: -0.75 },\n },\n md: {\n size: 40, border: 1, fontSize: 'var(--font-size-text-md)', lineHeight: 'var(--line-height-text-md)', iconSize: 24,\n onlineIndicator: { size: 10, offset: -1 },\n companyIcon: { size: 14, offset: -3, border: 1.5 },\n verifiedTick: { size: 14, offset: -1 },\n },\n lg: {\n size: 48, border: 1, fontSize: 'var(--font-size-text-lg)', lineHeight: 'var(--line-height-text-lg)', iconSize: 28,\n onlineIndicator: { size: 12, offset: -1 },\n companyIcon: { size: 16, offset: -3, border: 1.5 },\n verifiedTick: { size: 16, offset: -1 },\n },\n xl: {\n size: 56, border: 1, fontSize: 'var(--font-size-text-xl)', lineHeight: 'var(--line-height-text-xl)', iconSize: 32,\n onlineIndicator: { size: 14, offset: -1 },\n companyIcon: { size: 18, offset: -3, border: 1.5 },\n verifiedTick: { size: 18, offset: -1 },\n },\n '2xl': {\n size: 64, border: 1, fontSize: 'var(--font-size-display-xs)', lineHeight: 'var(--line-height-display-xs)', iconSize: 32,\n onlineIndicator: { size: 16, offset: -1 },\n companyIcon: { size: 20, offset: -3, border: 1.667 },\n verifiedTick: { size: 20, offset: -1 },\n },\n};\n\n// ─── AvatarLabelGroup Size Config ───────────────────────────────────────────────\n\ninterface LabelGroupSizeConfig {\n gap: string;\n nameFontSize: string;\n nameLineHeight: string;\n subFontSize: string;\n subLineHeight: string;\n}\n\nconst LABEL_GROUP_SIZE_CONFIG: Record<'sm' | 'md' | 'lg' | 'xl', LabelGroupSizeConfig> = {\n sm: { gap: 'var(--spacing-md)', nameFontSize: 'var(--font-size-text-sm)', nameLineHeight: 'var(--line-height-text-sm)', subFontSize: 'var(--font-size-text-xs)', subLineHeight: 'var(--line-height-text-xs)' },\n md: { gap: 'var(--spacing-md)', nameFontSize: 'var(--font-size-text-sm)', nameLineHeight: 'var(--line-height-text-sm)', subFontSize: 'var(--font-size-text-sm)', subLineHeight: 'var(--line-height-text-sm)' },\n lg: { gap: 'var(--spacing-lg)', nameFontSize: 'var(--font-size-text-md)', nameLineHeight: 'var(--line-height-text-md)', subFontSize: 'var(--font-size-text-md)', subLineHeight: 'var(--line-height-text-md)' },\n xl: { gap: 'var(--spacing-xl)', nameFontSize: 'var(--font-size-text-lg)', nameLineHeight: 'var(--line-height-text-lg)', subFontSize: 'var(--font-size-text-md)', subLineHeight: 'var(--line-height-text-md)' },\n};\n\n// ─── Default User Icon ──────────────────────────────────────────────────────────\n\nconst UserIcon: FC<{ style?: React.CSSProperties }> = ({ style }) => (\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style={style}\n >\n <path\n d=\"M20 21C20 19.6044 20 18.9067 19.8278 18.3389C19.44 17.0605 18.4395 16.06 17.1611 15.6722C16.5933 15.5 15.8956 15.5 14.5 15.5H9.5C8.10444 15.5 7.40665 15.5 6.83886 15.6722C5.56045 16.06 4.56004 17.0605 4.17224 18.3389C4 18.9067 4 19.6044 4 21M16.5 7.5C16.5 9.98528 14.4853 12 12 12C9.51472 12 7.5 9.98528 7.5 7.5C7.5 5.01472 9.51472 3 12 3C14.4853 3 16.5 5.01472 16.5 7.5Z\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\n// ─── Verified Tick ─────────────────────────────────────────────────────────────\n\nconst VerifiedTickBadge: FC<{ size: number; offset: number }> = ({ size, offset }) => (\n <svg\n viewBox=\"0 0 10 10\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{\n position: 'absolute',\n bottom: offset,\n right: offset,\n width: size,\n height: size,\n flexShrink: 0,\n color: 'var(--color-blue-500)',\n overflow: 'hidden',\n zIndex: 1,\n }}\n >\n <path\n d=\"M7.72237 1.77098C7.81734 2.00068 7.99965 2.18326 8.2292 2.27858L9.03413 2.61199C9.26384 2.70714 9.44635 2.88965 9.5415 3.11936C9.63665 3.34908 9.63665 3.60718 9.5415 3.83689L9.20833 4.64125C9.11313 4.87106 9.113 5.12943 9.20863 5.35913L9.54122 6.16325C9.58839 6.27702 9.61268 6.39897 9.6127 6.52214C9.61272 6.6453 9.58847 6.76726 9.54134 6.88105C9.4942 6.99484 9.42511 7.09823 9.33801 7.18531C9.2509 7.27238 9.14749 7.34144 9.03369 7.38854L8.22934 7.72171C7.99964 7.81669 7.81706 7.99899 7.72174 8.22855L7.38833 9.03348C7.29318 9.26319 7.11067 9.4457 6.88096 9.54085C6.65124 9.636 6.39314 9.636 6.16343 9.54085L5.35907 9.20767C5.12935 9.11276 4.87134 9.11295 4.64177 9.20821L3.83684 9.54115C3.60725 9.63608 3.34937 9.636 3.11984 9.54092C2.89032 9.44585 2.70791 9.26356 2.6127 9.03409L2.27918 8.22892C2.18421 7.99923 2.0019 7.81665 1.77235 7.72133L0.967421 7.38792C0.737807 7.29281 0.555355 7.11041 0.460169 6.88083C0.364983 6.65125 0.364854 6.39327 0.45981 6.16359L0.792984 5.35924C0.8879 5.12952 0.887707 4.87151 0.792445 4.64193L0.459749 3.83642C0.41258 3.72265 0.388291 3.60069 0.388272 3.47753C0.388252 3.35436 0.412501 3.2324 0.459634 3.11861C0.506767 3.00482 0.57586 2.90144 0.662965 2.81436C0.75007 2.72728 0.853479 2.65822 0.967283 2.61113L1.77164 2.27795C2.00113 2.18306 2.1836 2.00099 2.27899 1.7717L2.6124 0.966768C2.70755 0.737054 2.89006 0.554547 3.11978 0.459397C3.34949 0.364246 3.60759 0.364246 3.83731 0.459397L4.64166 0.792571C4.87138 0.887487 5.12939 0.887293 5.35897 0.792031L6.16424 0.459913C6.39392 0.364816 6.65197 0.364836 6.88164 0.459968C7.11131 0.555099 7.29379 0.737554 7.38895 0.967208L7.72247 1.77238L7.72237 1.77098Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M6.95829 3.68932C7.02509 3.58439 7.04747 3.45723 7.02051 3.3358C6.99356 3.21437 6.91946 3.10862 6.81454 3.04182C6.70961 2.97502 6.58245 2.95264 6.46102 2.97959C6.33959 3.00655 6.23384 3.08064 6.16704 3.18557L4.33141 6.06995L3.49141 5.01995C3.41375 4.92281 3.30069 4.8605 3.17709 4.84673C3.05349 4.83296 2.92949 4.86885 2.83235 4.94651C2.73522 5.02417 2.67291 5.13723 2.65914 5.26083C2.64536 5.38443 2.68125 5.50843 2.75891 5.60557L4.00891 7.16807C4.0555 7.22638 4.11533 7.27271 4.18344 7.30323C4.25154 7.33375 4.32595 7.34757 4.40047 7.34353C4.47499 7.3395 4.54747 7.31773 4.61188 7.28004C4.67629 7.24234 4.73077 7.18981 4.77079 7.12682L6.95829 3.68932Z\"\n fill=\"white\"\n />\n </svg>\n);\n\n// ─── Avatar ─────────────────────────────────────────────────────────────────────\n\nconst Avatar: React.FC<AvatarProps> = ({\n size = 'md',\n src,\n alt,\n initials,\n placeholderIcon: PlaceholderIcon,\n status,\n companyIcon,\n verified,\n style,\n className,\n}) => {\n const [imgFailed, setImgFailed] = useState(false);\n const cfg = SIZE_CONFIG[size];\n const canShowImage = Boolean(src && !imgFailed);\n const isPlaceholder = !canShowImage;\n const hasBadge = Boolean(status || companyIcon || verified);\n\n const renderContent = () => {\n if (canShowImage) {\n return (\n <img\n src={src!}\n alt={alt}\n onError={() => setImgFailed(true)}\n style={{\n position: 'absolute',\n inset: 0,\n width: '100%',\n height: '100%',\n objectFit: 'cover',\n borderRadius: '50%',\n pointerEvents: 'none',\n }}\n />\n );\n }\n if (initials) {\n return (\n <span\n style={{\n fontSize: cfg.fontSize,\n lineHeight: cfg.lineHeight,\n fontWeight: 600,\n color: 'var(--color-text-quaternary)',\n fontFamily: 'var(--font-family-body)',\n userSelect: 'none',\n }}\n >\n {initials}\n </span>\n );\n }\n if (PlaceholderIcon) {\n return (\n <PlaceholderIcon\n style={{\n width: cfg.iconSize,\n height: cfg.iconSize,\n color: 'var(--color-fg-quaternary)',\n flexShrink: 0,\n }}\n />\n );\n }\n return (\n <UserIcon\n style={{\n width: cfg.iconSize,\n height: cfg.iconSize,\n color: 'var(--color-fg-quaternary)',\n flexShrink: 0,\n }}\n />\n );\n };\n\n const renderBadge = () => {\n if (status === 'online' || status === 'offline') {\n const { size: iSize, offset } = cfg.onlineIndicator;\n return (\n <span\n style={{\n position: 'absolute',\n bottom: offset,\n right: offset,\n width: iSize,\n height: iSize,\n borderRadius: '50%',\n backgroundColor:\n status === 'online'\n ? 'var(--color-fg-success-secondary)'\n : 'var(--color-fg-quaternary)',\n border: '1.5px solid var(--color-bg-primary)',\n flexShrink: 0,\n }}\n />\n );\n }\n if (companyIcon) {\n const { size: cSize, offset, border } = cfg.companyIcon;\n return (\n <img\n src={companyIcon.src}\n alt={companyIcon.alt}\n style={{\n position: 'absolute',\n bottom: offset,\n right: offset,\n width: cSize,\n height: cSize,\n borderRadius: '50%',\n border: `${border}px solid var(--color-bg-primary)`,\n objectFit: 'cover',\n pointerEvents: 'none',\n }}\n />\n );\n }\n if (verified) {\n return (\n <VerifiedTickBadge\n size={cfg.verifiedTick.size}\n offset={cfg.verifiedTick.offset}\n />\n );\n }\n return null;\n };\n\n return (\n <div\n className={className}\n style={{\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: cfg.size,\n height: cfg.size,\n borderRadius: '50%',\n border: `${cfg.border}px solid ${isPlaceholder ? 'var(--color-border-secondary)' : 'rgba(0, 0, 0, 0.08)'}`,\n backgroundColor: isPlaceholder ? 'var(--color-bg-tertiary)' : undefined,\n overflow: hasBadge ? undefined : 'hidden',\n flexShrink: 0,\n ...style,\n }}\n >\n {renderContent()}\n {renderBadge()}\n </div>\n );\n};\n\n// ─── AvatarLabelGroup ────────────────────────────────────────────────────────────\n\nexport const AvatarLabelGroup: React.FC<AvatarLabelGroupProps> = ({\n size = 'sm',\n name,\n supportingText,\n avatarSrc,\n avatarInitials,\n status,\n companyIcon,\n verified,\n style,\n className,\n}) => {\n const cfg = LABEL_GROUP_SIZE_CONFIG[size];\n\n return (\n <div\n className={className}\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n gap: cfg.gap,\n position: 'relative',\n ...style,\n }}\n >\n <Avatar\n size={size}\n src={avatarSrc}\n initials={avatarInitials}\n status={status}\n companyIcon={companyIcon}\n verified={verified}\n />\n <div\n style={{\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'flex-start',\n flexShrink: 0,\n whiteSpace: 'nowrap',\n }}\n >\n <span\n style={{\n fontSize: cfg.nameFontSize,\n lineHeight: cfg.nameLineHeight,\n fontWeight: 600,\n color: 'var(--color-text-primary)',\n fontFamily: 'var(--font-family-body)',\n }}\n >\n {name}\n </span>\n {supportingText && (\n <span\n style={{\n fontSize: cfg.subFontSize,\n lineHeight: cfg.subLineHeight,\n fontWeight: 400,\n color: 'var(--color-text-tertiary)',\n fontFamily: 'var(--font-family-body)',\n }}\n >\n {supportingText}\n </span>\n )}\n </div>\n </div>\n );\n};\n\nexport default Avatar;\n","import React, { useState } from \"react\";\nimport { AlertIcon, CloseIcon } from \"./icon\";\n\nexport interface AlertProps {\n title?: string;\n description?: string;\n className?: string;\n type?: \"success\" | \"error\" | \"warning\" | \"info\";\n icon?: React.ReactNode;\n showIcon?: boolean;\n closeable?: boolean;\n action?: React.ReactNode;\n children?: React.ReactNode;\n /** 关闭回调 */\n onClose?: () => void;\n}\n\nconst Alert: React.FC<AlertProps> = ({\n className = \"\",\n type = \"info\",\n title,\n description,\n icon = AlertIcon[type],\n showIcon = true,\n closeable = false,\n action,\n children,\n onClose\n}) => {\n const baseClasses = \"aha-alert px-4 py-3 rounded-md flex gap-2\";\n\n // 使用内联样式作为备选方案,确保样式始终生效\n const typeStyles = {\n success: { backgroundColor: '#ECFDF5' },\n error: { backgroundColor: '#FEF2F2' },\n warning: { backgroundColor: '#FFFBEB' },\n info: { backgroundColor: '#EFF6FF' },\n };\n\n const [visible, setVisible] = useState(true);\n const handleClose = () => {\n setVisible(false);\n onClose?.();\n };\n\n const hasRightSlot = action || closeable;\n\n if (!visible) return null;\n\n return (\n <div \n className={`${baseClasses} ${className}`}\n style={typeStyles[type]}\n >\n {showIcon && icon}\n <div\n className={`flex flex-col gap-1 ${hasRightSlot ? \"flex-1 min-w-0\" : \"\"}`}\n >\n {title && (\n <div className=\"justify-start text-[#292524] text-base font-semibold font-['DM_Sans'] leading-normal\">\n {title}\n </div>\n )}\n {description && (\n <div className=\"w-full justify-center text-[#57534D] text-sm font-normal font-['DM_Sans'] leading-snug\">\n {description}\n </div>\n )}\n {children && (\n <div className=\"w-full justify-center text-[#57534D] text-sm font-normal font-['DM_Sans'] leading-snug\">\n {children}\n </div>\n )}\n </div>\n {hasRightSlot && (\n <div className=\"ml-auto flex-shrink-0 self-center flex items-center gap-2\">\n {action}\n {closeable && (\n <div\n className=\"cursor-pointer relative top-[-12px]\"\n onClick={handleClose}\n onKeyDown={(e) => e.key === \"Enter\" && handleClose()}\n role=\"button\"\n tabIndex={0}\n aria-label=\"关闭\"\n >\n {CloseIcon}\n </div>\n )}\n </div>\n )}\n </div>\n );\n};\n\nexport default Alert;\n","import React, { useRef, useEffect, useState } from 'react';\nimport { useTheme } from '../../theme/ThemeContext';\n\nexport type ProgressType = 'circle' | 'semicircle' | string;\nexport type ProgressStatus = 'normal' | 'success' | 'exception' | 'active';\nexport type TitlePosition = 'inside' | 'outside';\n\nexport interface ProgressProps {\n /** 进度百分比,范围 0-100 */\n percent?: number;\n /** 进度条类型,目前支持 circle(圆形)和 semicircle(半圆) */\n type?: ProgressType;\n /** 进度条宽度(尺寸),单位 px */\n width?: number;\n /** 标题文本 */\n title?: string;\n /** 标题位置,圆内(inside)或圆外(outside),圆外时显示在圆下方 */\n titlePosition?: TitlePosition;\n /** 是否显示百分比 */\n showPercent?: boolean;\n /** 是否启用动画效果 */\n animated?: boolean;\n /** 进度条状态 */\n status?: ProgressStatus;\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 进度条颜色,不设置则使用主题色 */\n strokeColor?: string;\n /** 进度条轨道颜色 */\n trailColor?: string;\n [key: string]: any;\n}\n\n// 获取标题位置:默认圆内\nconst getTitlePosition = (userPosition?: TitlePosition): TitlePosition => {\n return userPosition || 'inside';\n};\n\n// 计算标题字体大小:统一使用 text-sm (14px)\nconst getTitleFontSize = () => {\n return '14px'; // text-sm\n};\n\n// 计算百分比字体大小:统一使用 text-xs (12px)\nconst getPercentFontSize = () => {\n return '12px'; // text-xs\n};\n\nconst Progress: React.FC<ProgressProps> = ({\n percent = 0,\n type = 'circle',\n width = 120,\n title,\n titlePosition: userTitlePosition,\n showPercent = true,\n animated = false,\n status = 'normal',\n className = '',\n style,\n strokeColor,\n trailColor = '#F5F5F4',\n ...rest\n}) => {\n const { primaryColor } = useTheme();\n \n // 确保 percent 在 0-100 范围内\n const normalizedPercent = Math.min(100, Math.max(0, percent));\n \n // 跟踪是否是首次渲染,动画只在首次渲染时执行一次\n const isFirstRender = useRef(true);\n const [shouldAnimate, setShouldAnimate] = useState(false);\n const [animatingPercent, setAnimatingPercent] = useState(0); // 动画中的百分比\n \n useEffect(() => {\n if (animated && isFirstRender.current && normalizedPercent > 0) {\n // 首次渲染且启用了动画且 percent > 0 时,启用动画\n isFirstRender.current = false;\n // 初始设置为 0,然后启用动画,让它过渡到目标值\n setAnimatingPercent(0);\n setShouldAnimate(true);\n // 使用 requestAnimationFrame 确保在下一个渲染周期更新到目标值\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n setAnimatingPercent(normalizedPercent);\n });\n });\n // 动画结束后(0.3s)禁用动画,确保只执行一次\n const timer = setTimeout(() => {\n setShouldAnimate(false);\n setAnimatingPercent(normalizedPercent); // 确保最终值是目标值\n }, 300);\n return () => clearTimeout(timer);\n } else if (isFirstRender.current) {\n // 首次渲染但不需要动画,直接标记为已渲染\n isFirstRender.current = false;\n setShouldAnimate(false);\n setAnimatingPercent(normalizedPercent);\n } else {\n // 非首次渲染,直接更新到目标值,无动画\n setAnimatingPercent(normalizedPercent);\n }\n }, [animated, normalizedPercent]);\n \n // 计算实际使用的颜色\n let finalStrokeColor = strokeColor || primaryColor || '#FB6011';\n \n // 根据状态调整颜色\n if (status === 'success') {\n finalStrokeColor = '#00BC7D';\n } else if (status === 'exception') {\n finalStrokeColor = '#FB2C36';\n }\n \n // 计算标题位置:默认圆内\n const titlePosition = getTitlePosition(userTitlePosition);\n \n // 计算圆环宽度(strokeWidth),根据 width 成比例,最小 4px\n const strokeWidth = Math.max(4, Math.round(width * 0.06));\n \n // 半径(用于 SVG 绘制)\n const radius = (width - strokeWidth) / 2;\n \n // 半圆的高度是宽度的一半\n const semicircleHeight = type === 'semicircle' ? width / 2 : width;\n \n // 标题字体大小:统一使用 14px (text-sm)\n const titleFontSize = getTitleFontSize();\n // 百分比字体大小:统一使用 12px (text-xs)\n const percentFontSize = getPercentFontSize();\n \n // 渲染圆形进度\n const renderCircleProgress = () => {\n // 计算容器高度\n const containerHeight = title && titlePosition === 'outside' \n ? width + 4 + 18 + 4\n : width;\n \n // 圆形进度计算\n const circumference = 2 * Math.PI * radius;\n // 如果正在动画,使用动画中的百分比,否则使用目标百分比\n const currentPercent = shouldAnimate ? animatingPercent : normalizedPercent;\n const offset = circumference - (currentPercent / 100) * circumference;\n \n return (\n <div\n style={{\n position: 'relative',\n width: width,\n height: containerHeight,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n }}\n >\n {/* SVG 绘制圆形进度,支持圆角 */}\n <svg\n width={width}\n height={width}\n style={{\n position: 'absolute',\n top: 0,\n left: 0,\n }}\n >\n {/* 背景轨道 */}\n <circle\n cx={width / 2}\n cy={width / 2}\n r={radius}\n fill=\"none\"\n stroke={trailColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n />\n {/* 进度条:从上方开始,顺时针 */}\n <circle\n cx={width / 2}\n cy={width / 2}\n r={radius}\n fill=\"none\"\n stroke={finalStrokeColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n strokeDasharray={circumference}\n strokeDashoffset={offset}\n transform={`rotate(-90 ${width / 2} ${width / 2})`}\n style={{\n transition: shouldAnimate ? 'stroke-dashoffset 0.3s ease' : 'none',\n }}\n />\n </svg>\n \n {/* 内容:百分比和标题 */}\n {title && titlePosition === 'inside' ? (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: '50%',\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: 6,\n }}\n >\n <div\n style={{\n fontSize: titleFontSize,\n color: '#292524',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {title}\n </div>\n {showPercent && (\n <div\n style={{\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n </div>\n ) : (\n <>\n {showPercent && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${width / 2}px`, // 相对于圆的位置,不是容器\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n {title && titlePosition === 'outside' && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${width}px`,\n transform: 'translateX(-50%)',\n marginTop: '4px',\n textAlign: 'center',\n fontSize: titleFontSize,\n color: '#57534E',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '18px',\n }}\n >\n {title}\n </div>\n )}\n </>\n )}\n </div>\n );\n };\n \n // 渲染半圆进度\n const renderSemicircleProgress = () => {\n // 半圆弧形的起始点和结束点\n // 为了确保上方不被裁剪,把半圆弧形往下移\n // 在 SVG 顶部留出圆角空间,让弧形从顶部向下偏移\n \n const topPadding = strokeWidth; // 顶部留出圆角空间\n const svgHeight = semicircleHeight + topPadding; // SVG 总高度(包含顶部空间)\n \n const startX = strokeWidth / 2;\n const endX = width - strokeWidth / 2;\n // 底部位置:往下移,底部在 svgHeight - strokeWidth / 2\n const bottomY = svgHeight - strokeWidth / 2;\n \n // 半圆的中心点(用于文字定位)- 文字也相应往下移\n // 为了让文字更居中,需要适当往下移一些\n const textCenterY = (semicircleHeight / 2) + topPadding / 2 + strokeWidth / 2; // 在弧形中心位置,适当往下移\n \n // 计算容器高度:半圆的标准高度(width / 2),加上顶部空间\n // 如果 title 在圆外,再加 title 空间\n const baseContainerHeight = svgHeight; // 容器高度包含完整的 SVG(包括顶部空间)\n const containerHeight = title && titlePosition === 'outside' \n ? baseContainerHeight + 4 + 18 + 4\n : baseContainerHeight;\n \n // 半圆进度计算\n const semicircleCircumference = Math.PI * radius;\n // 如果正在动画,使用动画中的百分比,否则使用目标百分比\n const currentPercent = shouldAnimate ? animatingPercent : normalizedPercent;\n const semicircleOffset = semicircleCircumference - (currentPercent / 100) * semicircleCircumference;\n \n return (\n <div\n style={{\n position: 'relative',\n width: width,\n height: containerHeight,\n overflow: 'hidden', // 最外层设置 overflow: hidden,只裁剪底部\n }}\n >\n {/* SVG 绘制半圆进度,支持圆角(包括底部两个端点) */}\n <svg\n width={width}\n height={svgHeight}\n viewBox={`0 0 ${width} ${svgHeight}`}\n style={{\n position: 'absolute',\n top: 0,\n left: 0,\n }}\n >\n {/* 背景轨道(半圆) */}\n <path\n d={`M ${startX} ${bottomY} A ${radius} ${radius} 0 0 1 ${endX} ${bottomY}`}\n fill=\"none\"\n stroke={trailColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n />\n {/* 进度条(半圆):从底部左侧开始,顺时针 */}\n <path\n d={`M ${startX} ${bottomY} A ${radius} ${radius} 0 0 1 ${endX} ${bottomY}`}\n fill=\"none\"\n stroke={finalStrokeColor}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n strokeDasharray={semicircleCircumference}\n strokeDashoffset={semicircleOffset}\n style={{\n transition: shouldAnimate ? 'stroke-dashoffset 0.3s ease' : 'none',\n }}\n />\n </svg>\n \n {/* 内容:百分比和标题 */}\n {title && titlePosition === 'inside' ? (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${textCenterY}px`,\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: 6,\n }}\n >\n <div\n style={{\n fontSize: titleFontSize,\n color: '#57534E',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {title}\n </div>\n {showPercent && (\n <div\n style={{\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n </div>\n ) : (\n <>\n {showPercent && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${textCenterY}px`, // 相对于半圆的位置,不是容器\n transform: 'translate(-50%, -50%)',\n textAlign: 'center',\n fontSize: percentFontSize,\n fontWeight: 600,\n color: '#1C1917',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: 1,\n }}\n >\n {`${Math.round(normalizedPercent)}%`}\n </div>\n )}\n {title && titlePosition === 'outside' && (\n <div\n style={{\n position: 'absolute',\n left: '50%',\n top: `${svgHeight}px`, // 相对于 SVG 底部的位置\n transform: 'translateX(-50%)',\n marginTop: '4px',\n textAlign: 'center',\n fontSize: titleFontSize,\n color: '#57534E',\n fontFamily: 'DM Sans, sans-serif',\n lineHeight: '18px',\n }}\n >\n {title}\n </div>\n )}\n </>\n )}\n </div>\n );\n };\n \n const containerStyle: React.CSSProperties = {\n display: 'inline-flex',\n flexDirection: 'column',\n alignItems: 'center',\n width: width,\n ...style,\n };\n \n // 根据类型渲染不同的进度条\n const renderProgress = () => {\n switch (type) {\n case 'circle':\n return renderCircleProgress();\n case 'semicircle':\n return renderSemicircleProgress();\n default:\n console.warn(`Progress type \"${type}\" is not supported yet, using \"circle\" as fallback`);\n return renderCircleProgress();\n }\n };\n \n return (\n <div\n className={`aha-progress aha-progress--${type} ${className}`}\n style={containerStyle}\n {...rest}\n >\n {renderProgress()}\n </div>\n );\n};\n\nexport default Progress;\n","import React from 'react';\nimport InputTags, { InputTagsProps } from '../Input/InputTags';\n\nexport interface TextareaTagsProps extends Omit<InputTagsProps, 'size'> {\n minHeight?: number;\n helpIcon?: React.ReactNode;\n}\n\nconst TextareaTags: React.FC<TextareaTagsProps> = ({\n minHeight = 120,\n style,\n label,\n required,\n hintText,\n helpIcon,\n error,\n ...props\n}) => {\n const tagsEl = (\n <InputTags\n error={error}\n style={{\n minHeight: `${minHeight}px`,\n alignItems: 'flex-start',\n overflow: 'auto',\n resize: 'vertical',\n ...style,\n }}\n {...props}\n />\n );\n\n if (!label && !hintText) return tagsEl;\n\n return (\n <div style={{ display: 'flex', flexDirection: 'column', gap: '6px', width: '100%' }}>\n {label && (\n <label style={{\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 500,\n lineHeight: '20px',\n color: 'var(--color-text-secondary)',\n display: 'flex',\n alignItems: 'center',\n }}>\n {label}\n {required && <span style={{ color: 'var(--color-error-600)', marginLeft: '2px' }}>*</span>}\n {helpIcon && (\n <span style={{ marginLeft: '4px', display: 'inline-flex', alignItems: 'center', color: 'var(--color-fg-quaternary)' }}>\n {helpIcon}\n </span>\n )}\n </label>\n )}\n {tagsEl}\n {hintText && (\n <p style={{\n margin: 0,\n fontFamily: 'var(--font-family-body)',\n fontSize: 'var(--font-size-text-sm)',\n fontWeight: 400,\n lineHeight: '20px',\n color: error ? 'var(--color-error-600)' : 'var(--color-text-tertiary)',\n }}>\n {hintText}\n </p>\n )}\n </div>\n );\n};\n\nexport default TextareaTags;\n"],"names":["extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__assign","assign","t","s","i","n","arguments","length","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","rejected","result","done","then","__generator","body","f","y","_","label","sent","trys","ops","g","create","Iterator","verb","Symbol","iterator","v","op","TypeError","pop","push","__spreadArray","to","from","pack","ar","l","slice","concat","SuppressedError","defaultTheme","primaryColor","ThemeContext","createContext","useTheme","context","useContext","SIZE_ALIAS","sm","md","lg","xl","small","mediumSmall","medium","large","HIERARCHY_ALIAS","primary","secondary","tertiary","default","SIZE_TOKENS","height","paddingX","paddingXLg","fontSize","lineHeight","iconSize","gap","iconOnlyPad","LoadingSpinner","_a","size","color","_jsxs","jsxs","_Fragment","Fragment","children","_jsx","jsx","width","viewBox","fill","style","animation","flexShrink","cx","cy","r","stroke","strokeWidth","opacity","strokeLinecap","Button","_b","type","_c","_d","disabled","_e","loading","iconOnly","_f","focused","onClick","_g","htmlType","_h","className","icon","_j","iconPosition","rest","_k","useState","isHovered","setIsHovered","_l","isPressed","setIsPressed","hierarchy","isIconOnly","isLink","isDisabled","showFocusRing","themeBrand","visuals","bg","iconColor","border","boxShadow","interactive","textDecoration","getVisuals","focusShadow","buttonStyle","position","display","alignItems","justifyContent","fontFamily","fontWeight","cursor","outline","transition","userSelect","WebkitTapHighlightColor","whiteSpace","backgroundColor","borderRadius","overflow","padding","paddingLeft","paddingRight","renderIcon","showLeftIcon","showRightIcon","filter","Boolean","join","preventDefault","onMouseEnter","onMouseLeave","onMouseDown","onMouseUp","displayName","AlertIcon","success","xmlns","error","warning","info","CloseIcon","ToastIcon","question","ToastManager","toasts","listeners","Set","addToast","props","id","Math","random","toString","toastInstance","console","log","notifyListeners","removeToast","toast","getToasts","subscribe","listener","_this","add","delete","forEach","clearAll","toastManager","ToastContainer","setToasts","useEffect","currentToasts","unsubscribe","map","topLeftToasts","topRightToasts","bottomLeftToasts","bottomRightToasts","top","left","zIndex","pointerEvents","flexDirection","ToastItem","right","bottom","isVisible","setIsVisible","isExiting","setIsExiting","message","duration","action","showClose","onClose","typeStyles","bgColor","defaultIcon","getTypeStyles","timer","setTimeout","clearTimeout","timer_1","handleClose","useCallback","handleClick","maxWidth","background","transform","marginRight","flex","minWidth","marginTop","stopPropagation","currentTarget","ensureToastContainer","toastContainerElement","toastContainerRoot","isInitializing","window","document","existingContainer","getElementById","createElement","appendChild","createRoot","require","render","import","catch","warn","COLOR_CONFIG","Green","light","text","Red","Orange","Cyan","Violet","Pink","Gray","Yellow","Blue","SIZE","basePx","basePy","plCheckbox","plAvatar","plDot","plIcon","prClose","prCount","avatarSize","checkboxSize","contentGap","rootGap","countPx","countFontSize","closeSize","closePad","TagAvatar","src","alt","failed","setFailed","onError","objectFit","Tag","variant","iconTypeProp","iconType","avatarSrc","dotColor","count","checkbox","checkedProp","checked","onCheckedChange","internalChecked","setInternalChecked","nSize","normalizeSize","isChecked","undefined","effectiveAction","pl","pr","containerStyle","paddingTop","paddingBottom","boxSizing","outlineOffset","colorConfig","config","startsWith","parseInt","getColorConfig","getOutlineColor","role","round","strokeLinejoin","React","cloneElement","marginLeft","SHADOW_XS","sizeMap","pt","pb","InputGroup","forwardRef","ref","readOnly","prefix","suffix","leadingText","trailingText","leadingAddon","trailingAddon","onFocus","onBlur","onKeyDown","onPressEnter","defaultValue","onChange","placeholder","required","hintText","restProps","inputRef","useRef","setFocused","internalValue","setInternalValue","current","isControlled","currentValue","dividerColor","hasPrefixIcon","hasSuffixIcon","iconSlotStyle","addonTextStyle","groupEl","borderRight","target","key","autoComplete","borderLeft","hintStyle","margin","containerPadding","tagSizeMap","InputTags","internalTags","setInternalTags","inputValue","setInputValue","tags","updateTags","addTag","tag","trimmed","trim","includes","removeTag","index","tagSize","tagsEl","focus","flexWrap","sizeStyles","ClearIcon","Input","allowClear","onClear","showClear","_m","baseStyles","WebkitAppearance","MozAppearance","appearance","inputEl","autoCorrect","autoCapitalize","spellCheck","Select","controlledValue","options","mode","showSearch","filterOption","onSelect","onDeselect","onSearch","onDropdownVisibleChange","dropdownClassName","dropdownStyle","_o","defaultOpen","controlledOpen","open","maxTagCount","tagRender","optionRender","_p","_q","_r","internalOpen","setInternalOpen","_s","searchValue","setSearchValue","_t","focusedIndex","setFocusedIndex","selectRef","dropdownRef","_u","dropdownPosition","setDropdownPosition","isOpenControlled","isOpen","isMultiple","getSelectedOptions","values","isArray","opt","getFilteredOptions","String","toLowerCase","search","filteredOptions","useMemo","updatePosition_1","rect","getBoundingClientRect","estimatedDropdownHeight","offsetHeight","min","max","spaceBelow","innerHeight","spaceAbove","shouldOpenUp","top_1","scrollY","scrollX","placement","requestAnimationFrame","addEventListener","removeEventListener","handleClickOutside","event","contains","handleKeyDown","prev","option","handleSelect","focusedItem","querySelectorAll","scrollIntoView","block","behavior","newValues_1","currentValues","selectedOptions_1","handleRemoveTag","newValues","find","handleClear","newValue","selectedOptions","hasValue","renderTags","tagsToShow","remainingCount","tagProps","closable","textOverflow","WebkitTouchCallout","touchAction","newOpen","onTouchStart","onTouchEnd","tabIndex","minHeight","val","createPortal","maxHeight","transformOrigin","WebkitOverflowScrolling","overscrollBehavior","textAlign","isSelected","isFocused","selected","SortIcon","SortDescIcon","SortAscIcon","LeftArrowIcon","RightArrowIcon","TooltipIcon","clipPath","Pagination","controlledCurrent","defaultCurrent","total","controlledPageSize","pageSize","defaultPageSize","showSizeChanger","pageSizeOptions","showQuickJumper","showTotal","onShowSizeChange","simple","hideOnSinglePage","responsive","showLessItems","itemRender","internalCurrent","setInternalCurrent","internalPageSize","setInternalPageSize","jumpToPage","setJumpToPage","totalPages","ceil","handlePageChange","page","handleJumpTo","start","end","pages","getPageNumbers","item","isActive","element","renderItem","Number","newPageSize","newTotalPages","newCurrent","goButton","Checkbox","indeterminate","hint","isFocusedProp","hovered","setHovered","showFocus","boxSize","hasLabel","TableLoadingSpinner","strokeDasharray","strokeDashoffset","TableLoadingOverlay","spinColor","content","inset","getValue","obj","path","reduce","acc","getRowKey","record","rowKey","SortIconComponent","order","Radio","name","dotSize","DOMAIN_REGEX","URL_CANDIDATE_REGEX","DEFAULT_ALLOWED_TLDS","websiteValidator","url","needProtocol","needHost","allowedTlds","hasProtocol","test","normalized","parsed","URL","protocol","host","hostname","split","every","segment","num","isInteger","tld","has","trimTrailingPunctuation","match","core","escapeHtml","replace","stripEditorArtifacts","RegExp","renderTokensAsHtml","tokens","lastIndex","regex","exec","matchedText","href","defaultIsValid","validate","tokenizeText","html","token","classAttr","endsWith","getCaretOffset","container","selection","getSelection","rangeCount","range","getRangeAt","startContainer","preRange","cloneRange","selectNodeContents","setEnd","startOffset","Textarea","showCount","maxLength","rows","autoSize","linkify","linkifyOptions","helpIcon","textareaRef","editableRef","isComposingRef","caretOffsetRef","setHeight","currentLength","handleFocus","handleBlur","getMaxLengthValue","textarea","minRows","maxRows","scrollHeight","getComputedStyle","newHeight","editable","overflowY","useLayoutEffect","activeElement","fallbackOffset","caretOffset","nextHtml","innerHTML","maxOffset","offset","createRange","remaining","walker","createTreeWalker","NodeFilter","SHOW_TEXT","currentNode","nextNode","rawText","textContent","visibleCount","targetOffsetInNode","setStart","collapse","removeAllRanges","addRange","setCaretOffset","notifyChange","nextValue","handleEditableInput","rawValue","resize","textareaEl","contentEditable","suppressContentEditableWarning","onInput","onPaste","pastedText","clipboardData","getData","currentText","nextText","anchorNode","endOffset","endContainer","nativeEvent","isComposing","offsets","startRange","endRange","getSelectionOffsets","nextCaret","onCompositionStart","onCompositionEnd","Switch","controlledChecked","defaultChecked","checkedChildren","unCheckedChildren","thumbSize","thumbOffset","thumbLeft","newChecked","monthNamesShort","monthNamesFull","formatDate","date","format","year","getFullYear","month","getMonth","monthNum","padStart","day","getDate","dayNum","getDaysInMonth","Date","isSameDay","date1","date2","isDateInRange","minDate","maxDate","DatePicker","startPlaceholder","endPlaceholder","onOpenChange","separator","presetRanges","calendarCount","showApplyCancel","applyText","cancelText","onApply","onCancel","showSelectedRange","_v","startSelectedRangeText","_w","endSelectedRangeText","_x","rangeDisplayMode","_y","isRangeMode","_z","internalSingleValue","setInternalSingleValue","_0","startDate","endDate","internalRangeValue","setInternalRangeValue","_1","_2","selectingStart","setSelectingStart","_3","tempRangeValue","setTempRangeValue","_4","now","currentMonth","setCurrentMonth","_5","nextMonth","secondMonth","setSecondMonth","pickerRef","startInputRef","endInputRef","_6","hasOpenedRef","placementDeterminedRef","determinedPlacementRef","currentSingleValue","currentRangeValue","dateYear","dateMonth","rect_1","placement_1","dropdownHeight","top_2","placement_2","calculatePosition_1","workingRange","startText","endText","renderCalendar","handleSelectSingleDate","handleSelectRangeDate","newRange","handleToggle","defaultPresetRanges","today","setHours","lastWeekEnd","lastWeekStart","setDate","lastMonthEnd","lastMonthStart","originalDate","setMonth","lastYearEnd","lastYearStart","setFullYear","presetRangesList","hasPresetRanges","handlePresetRangeSelect","startYear","startMonth","handlePrevMonth","handleNextMonth","generateCalendarData","daysInMonth","days","calendarData","secondCalendarData","handleSecondPrevMonth","handleSecondNextMonth","singleDisplayValue","startDisplayValue","endDisplayValue","rangeTextValue","weekDays","borderTopLeftRadius","borderBottomLeftRadius","preset","idx","monthData","calendarDays","onPrevMonth","onNextMonth","monthIndex","marginBottom","gridTemplateColumns","rowGap","columnGap","firstDay","getDay","cells","actualIndex","isCurrentMonth","isToday","isStartDate","isEndDate","isInRange_1","dateTime","getTime","startTime","endTime","isDateInSelectedRange","isFirstInRow","isLastInRow","isRangeStart_1","isRangeEnd_1","isFirstDayOfMonth","isLastDayOfMonth","needsLeftRadius","needsRightRadius","borderTopRightRadius","borderBottomRightRadius","isSelected_1","borderTop","FormContext","FormValidationError","_super","errorFields","__","constructor","__extends","Error","Form","initialValues","onValuesChange","onFinish","onFinishFailed","labelWidth","labelAlign","layout","initialFields","keys","touched","validating","fields","setFieldsState","fieldsRef","fieldElementsRef","getFieldValue","setFieldValue","newFields","changedValues","allValues_1","getFieldError","setFieldError","isFieldTouched","setFieldTouched","isFieldValidating","setFieldValidating","registerFieldFnRef","existingRules","rules","newRules","rulesEqual","existingRule","newRule","pattern","len","whitespace","registerField","unregisterField","validateField","field","_i","rules_1","rule","validator","string","number","isNaN","boolean","email","err_1","getFieldsValue","nameList","currentFields","validateFields","fieldsToValidate","errors","all","errorInfo","resetFields","setFieldsValue","allValues_2","submit","setFields","fieldsToSet","some","changedValues_1","registerFieldRef","scrollToField","el","useImperativeHandle","contextValue","formStyle","Provider","onSubmit","FormWithItem","Item","htmlFor","wrapperCol","hasFeedback","validateStatus","help","extra","hidden","tooltip","formContext","itemRef","setItemRef","fieldError","fieldTouched","fieldValidating","computedValidateStatus","computedHelp","prevRulesRef","prevRequiredRef","isMountedRef","isRequired","rulesChanged","prevRule","currRule","showTooltip","setShowTooltip","tooltipRef","borderBottom","Children","child","isValidElement","childProps","fieldValue_1","setFieldValue_1","childType","originalOnChange_1","originalOnBlur_1","originalOnChange_2","originalOnBlur_2","originalOnChange_3","originalOnChange_4","radioValue_1","originalOnChange_5","originalOnChange_6","cloneChild","useForm","MenuList","items","userProfile","controlledSelectedKeys","selectedKeys","defaultSelectedKeys","menuRef","itemRefs","isSelectedKeysControlled","internalSelectedKeys","setInternalSelectedKeys","isGroup","getKeyPath","items_1","found","menuItem","currentPath","handleItemClick","newSelectedKeys","keyPath","k","skipGlobalClick","renderMenuItem","itemStyle","danger","suffixIcon","shouldShowDivider","currentItem","prevItem","avatar","charAt","toUpperCase","online","group","title","calculatePosition","triggerRect","tooltipRect","pageXOffset","pageYOffset","triggerCenterX","triggerCenterY","totalGap","viewportWidth","innerWidth","viewportHeight","willOverlap","calculatedTop","calculatedLeft","tooltipBottom","tooltipRight","tooltipTop","tooltipLeft","overlapTop","overlapBottom","overlapLeft","overlapRight","renderArrow","arrowStyle","baseArrowStyle","borderStyle","arrowStyles","borderWidth","borderColor","hasEnoughSpace","popoverRect","getAvailableSpace","Popover","trigger","popoverClassName","destroyOnHide","destroyTooltipOnHide","shouldDestroyOnHide","internalVisible","setInternalVisible","visible","popoverStyle","setPopoverStyle","triggerRef","popoverRef","setVisible","nextVisible","updatePosition","nextPlacement","oppositePlacement","getOppositePlacement","getPlacementPosition","clamped","nextTop","nextLeft","clampToViewport","openPopover","closePopover","togglePopover","triggerEvents","popoverNode","visibility","VIEWPORT_PADDING","ANIMATION_DURATION","Drawer","afterOpenChange","footer","mask","maskClosable","closeIcon","keyboard","destroyOnClose","mobileBreakpoint","drawerStyle","headerStyle","bodyStyle","footerStyle","maskStyle","mergedOpen","shouldRender","setShouldRender","animatedOpen","setAnimatedOpen","mounted","setMounted","isMobile","setIsMobile","updateMobile","raf_1","cancelAnimationFrame","previousOverflow","closeDrawer","resolvedWidth","resolvedHeight","effectivePlacement","drawerPositionStyle","base","node","curve","rotate","particleCount","trailSpan","durationMs","rotationDurationMs","pulseDurationMs","baseRadius","detailAmplitude","petalCount","curveScale","point","progress","detailScaleValue","PI","petals","x","cos","sin","getParticle","tailOffset","normalizeProgress","fade","pow","radius","colorTokens","gray","ring","dot","btnText","btnHoverBg","btnHoverText","brand","grayBlue","blueLight","blue","indigo","purple","pink","orange","pillPadding","badgePadding","getTokens","getRootStyle","isPill","isLg","shadow","BadgeDot","XIcon","SIZE_CONFIG","xs","onlineIndicator","companyIcon","verifiedTick","LABEL_GROUP_SIZE_CONFIG","nameFontSize","nameLineHeight","subFontSize","subLineHeight","UserIcon","VerifiedTickBadge","fillRule","clipRule","Avatar","initials","PlaceholderIcon","placeholderIcon","status","verified","imgFailed","setImgFailed","cfg","canShowImage","isPlaceholder","hasBadge","iSize","cSize","renderBadge","description","showIcon","closeable","hasRightSlot","supportingText","avatarInitials","Icon","buttonLabel","onButtonClick","plMap","prMap","btnBorderRadius","dotPaddingLeft","dotPaddingRight","IconLeading","iconLeading","IconTrailing","iconTrailing","hasLeading","padMap","imgSrc","imgAlt","imgSize","strokeWidthProp","frame","setFrame","startRef","tick","pulseAngle","elapsed","rotationDeg","elapsedMs","getRotationDeg","lineWeight","strokeScale","pathD","steps","parts","toFixed","buildPath","particles","preserveAspectRatio","percent","userTitlePosition","titlePosition","showPercent","animated","strokeColor","trailColor","normalizedPercent","isFirstRender","shouldAnimate","setShouldAnimate","animatingPercent","setAnimatingPercent","finalStrokeColor","semicircleHeight","titleFontSize","percentFontSize","renderCircleProgress","containerHeight","circumference","startX","endX","bottomY","svgHeight","textCenterY","semicircleCircumference","semicircleOffset","renderProgress","scrollable","normalizedItems","firstItem","firstKey","findMatchingKey","exactMatch","itemNum","valueNum","initialValue","handleTabClick","returnValue","activeTabElement_1","tabRefs","getKeyString","container_1","containerRef","isScrollingRef","scrollTimeout_1","underlineRef","containerRect","tabRect","scrollLeft","setUnderlineStyle","handleScroll_1","passive","inline","activeItem","currentNum","activeColor","backgroundSliderRef","backgroundContainerRef","prevCurrentValueRef","underlineStyle","backgroundSliderStyle","setBackgroundSliderStyle","updateUnderlinePosition","activeTab","firstKey_1","newLeft","newWidth","updateBackgroundSliderPosition","firstKey_2","scrollTimeout_2","updatePosition_2","handleScroll_2","overflowX","scrollBehavior","scrollbarWidth","itemKey","itemKeyType","currentValueType","isReactElement","iconValue","badge","customElement","renderBackgroundStyle","columns","dataSource","rowSelection","pagination","bordered","locale","showHeader","summary","scroll","tableLayout","onSorterChange","onPaginationChange","onRow","innerClassName","expandable","rowClassName","onHeaderRow","sticky","loadingSpinColor","selectedRowKeys","defaultSelectedRowKeys","setSelectedRowKeys","Map","sorters","setSorters","defaultExpandedRowKeys","expandedRowKeys","setExpandedRowKeys","currentPage","setCurrentPage","setPageSize","draggedRowIndex","setDraggedRowIndex","dragOverRowIndex","setDragOverRowIndex","tableRef","headerRef","checkMobile","checkboxProps","getCheckboxProps","newSelectedRowKeys","selectedRows","Event","handleSelectAll","currentPageData","changeRows","onSelectAll","handleSort","column","columnKey","dataIndex","newSorters","set","sorterArray","entries","c","currentSorter","currentDataSource","expanded","newExpandedRowKeys","onExpand","onExpandedRowsChange","emptyContent","getProcessedData","processed","sort","a","_loop_1","col","compareResult","sorter","aVal","bVal","sorterEntries_1","state_1","processedData","isServerPagination","paginatedData","renderCell","getFixedOffset","columnIndex","fixed","isHeader","fixedDirection","columnWidth","renderHeader","enabledRows","enabledKeys","allSelected","someSelected","headerColumns","colIndex","sortOrder","get","fixedOffset","align","onHeaderCell","sortColumn","selectWidth","selectColumn","hideSelectAll","columnTitle","unshift","headerRowProps","handleDragStart","handleDragOver","handleDrop","dropIndex","newData","draggedItem","splice","handleDragEnd","renderEmpty","emptyText","colSpan","renderRows","isExpanded","rowProps","isLastRow","draggable","onDragStart","onDragOver","onDrop","onDragEnd","cellProps","onCell","rowSpan","expandedRowRender","renderPagination","hasFixedColumns","hasAllColumnWidths","totalWidth","sum","effectiveTableLayout","tableStyle","borderCollapse","borderSpacing","wrapperStyle","displayValue","scrollContainerStyle","theme","themeValue","delay","tooltipClassName","showArrow","defaultVisible","onVisibleChange","isAnimating","setIsAnimating","newVisible","actualPosition","setActualPosition","tooltipMaxWidth","setTooltipMaxWidth","tooltipStyle","setTooltipStyle","setArrowStyle","timeoutRef","hideTimeoutRef","finalPosition","preferredPosition","candidates_1","pos","getPositionCandidates","candidate","getAutoPosition","arrowPos","tooltipAbsoluteLeft","tooltipAbsoluteTop","getArrowPosition","hideTooltip","keepTooltipVisible","tryUpdatePosition_1","tooltipContainerStyle","calculateTooltipMaxWidth","updateMaxWidth","tooltipContentStyle","wordWrap","tooltipContent","handleTriggerMouseLeave","triggerProps"],"mappings":"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","x_google_ignoreList":[0]}