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
@@ -1 +1 @@
1
- {"version":3,"file":"index.esm.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/index.tsx","../src/components/Alert/icon.tsx","../src/components/Alert/index.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/Progress/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"],"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","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","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, { 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, { 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"],"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","ThemeProvider","_a","theme","children","themeValue","useMemo","_jsx","Provider","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","size","color","_jsxs","_Fragment","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","Alert","title","description","showIcon","closeable","action","onClose","visible","setVisible","handleClose","hasRightSlot","onKeyDown","key","role","tabIndex","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","showClose","typeStyles","bgColor","defaultIcon","getTypeStyles","timer","setTimeout","clearTimeout","timer_1","useCallback","handleClick","maxWidth","background","transform","marginRight","flex","minWidth","marginTop","stopPropagation","currentTarget","Toast","ensureToastContainer","closeToast","clearAllToasts","debugToast","window","document","getElementById","toastContainerRoot","isInitializing","toastSuccess","options","toastError","toastInfo","toastQuestion","toastContainerElement","existingContainer","createElement","appendChild","createRoot","require","render","import","catch","warn","ToastProvider","mounted","setMounted","createPortal","COLOR_CONFIG","Green","light","text","Red","Orange","Cyan","Violet","Pink","Gray","Yellow","Blue","SIZE_CONFIG","textSize","Tag","variant","colorConfig","config","startsWith","hex","replace","parseInt","substr","getColorConfig","sizeConfig","baseStyle","outlineOffset","outlineColor","getOutlineColor","baseClasses","containerClasses","getIconColor","React","cloneElement","Input","forwardRef","ref","readOnly","prefix","suffix","allowClear","onClear","placeholder","defaultValue","onChange","onFocus","onBlur","onPressEnter","restProps","inputRef","useRef","internalValue","setInternalValue","setFocused","current","isControlled","undefined","currentValue","handleClear","target","focus","showClear","sizeStyles","paddingTop","paddingBottom","baseStyles","boxSizing","WebkitAppearance","MozAppearance","appearance","autoComplete","autoCorrect","autoCapitalize","spellCheck","strokeLinejoin","Select","controlledValue","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","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","Fragment","textOverflow","marginLeft","WebkitTouchCallout","touchAction","newOpen","onTouchStart","onTouchEnd","minHeight","val","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","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","inset","getValue","obj","path","reduce","acc","getRowKey","record","rowKey","SortIconComponent","order","Table","columns","dataSource","rowSelection","pagination","bordered","locale","showHeader","footer","summary","scroll","tableLayout","onSorterChange","onPaginationChange","onRow","innerClassName","expandable","rowClassName","onHeaderRow","sticky","loadingSpinColor","selectedRowKeys","defaultSelectedRowKeys","setSelectedRowKeys","Map","sorters","setSorters","defaultExpandedRowKeys","expandedRowKeys","setExpandedRowKeys","_v","currentPage","setCurrentPage","_w","setPageSize","_x","draggedRowIndex","setDraggedRowIndex","_y","dragOverRowIndex","setDragOverRowIndex","_z","isMobile","setIsMobile","tableRef","headerRef","checkMobile","innerWidth","checkboxProps","getCheckboxProps","newSelectedRowKeys","k","selectedRows","Event","handleSelectAll","currentPageData","keys","changeRows","onSelectAll","handleSort","column","columnKey","dataIndex","newSorters","set","sorterArray","entries","c","field","currentSorter","currentDataSource","expanded","newExpandedRowKeys","onExpand","onExpandedRowsChange","emptyContent","getProcessedData","processed","sort","a","_loop_1","col","compareResult","sorter","aVal","bVal","sorterEntries_1","_i","state_1","processedData","isServerPagination","paginatedData","renderCell","getFixedOffset","columnIndex","fixed","isHeader","fixedDirection","offset","columnWidth","renderHeader","enabledRows","enabledKeys","allSelected","someSelected","headerColumns","colIndex","sortOrder","get","fixedOffset","align","borderBottom","onHeaderCell","sortColumn","selectWidth","selectColumn","hideSelectAll","every","some","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","x","sum","effectiveTableLayout","tableStyle","borderCollapse","borderSpacing","wrapperStyle","marginBottom","displayValue","scrollContainerStyle","overflowX","overflowY","Radio","name","Tab","items","layout","scrollable","normalizedItems","firstItem","firstKey","findMatchingKey","exactMatch","itemNum","valueNum","isNaN","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","container","scrollTimeout_2","updatePosition_2","handleScroll_2","containerStyle","scrollBehavior","scrollbarWidth","itemKey","itemKeyType","currentValueType","iconType","isReactElement","isValidElement","iconValue","badge","customElement","itemStyle","renderBackgroundStyle","Progress","percent","userTitlePosition","titlePosition","showPercent","animated","status","strokeColor","trailColor","normalizedPercent","isFirstRender","shouldAnimate","setShouldAnimate","animatingPercent","setAnimatingPercent","finalStrokeColor","round","radius","semicircleHeight","titleFontSize","percentFontSize","renderCircleProgress","containerHeight","circumference","PI","startX","endX","bottomY","svgHeight","textCenterY","semicircleCircumference","semicircleOffset","renderProgress","DOMAIN_REGEX","URL_CANDIDATE_REGEX","DEFAULT_ALLOWED_TLDS","websiteValidator","url","needProtocol","needHost","allowedTlds","trimmed","trim","hasProtocol","test","normalized","parsed","URL","protocol","host","hostname","split","segment","num","isInteger","tld","has","trimTrailingPunctuation","match","core","escapeHtml","stripEditorArtifacts","RegExp","renderTokensAsHtml","tokens","lastIndex","regex","exec","matchedText","href","defaultIsValid","validate","tokenizeText","html","token","classAttr","endsWith","getCaretOffset","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","useLayoutEffect","activeElement","fallbackOffset","caretOffset","nextHtml","innerHTML","maxOffset","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","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","startSelectedRangeText","endSelectedRangeText","rangeDisplayMode","isRangeMode","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","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","initialFields","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","rules_1","rule","validator","string","number","boolean","email","err_1","getFieldsValue","nameList","currentFields","validateFields","fieldsToValidate","errors","all","errorInfo","resetFields","setFieldsValue","allValues_2","submit","setFields","fieldsToSet","changedValues_1","registerFieldRef","scrollToField","useImperativeHandle","contextValue","formStyle","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","Children","child","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","userProfile","controlledSelectedKeys","selectedKeys","defaultSelectedKeys","menuRef","itemRefs","isSelectedKeysControlled","internalSelectedKeys","setInternalSelectedKeys","isGroup","getKeyPath","items_1","found","menuItem","currentPath","handleItemClick","newSelectedKeys","keyPath","skipGlobalClick","renderMenuItem","danger","suffixIcon","shouldShowDivider","currentItem","prevItem","avatar","charAt","toUpperCase","online","group","calculatePosition","triggerRect","tooltipRect","pageXOffset","pageYOffset","triggerCenterX","triggerCenterY","totalGap","viewportWidth","viewportHeight","willOverlap","calculatedTop","calculatedLeft","tooltipBottom","tooltipRight","tooltipTop","tooltipLeft","overlapTop","overlapBottom","overlapLeft","overlapRight","renderArrow","arrowStyle","baseArrowStyle","borderStyle","arrowStyles","borderWidth","Tooltip","trigger","delay","tooltipClassName","showArrow","defaultVisible","onVisibleChange","internalVisible","setInternalVisible","isAnimating","setIsAnimating","newVisible","actualPosition","setActualPosition","tooltipMaxWidth","setTooltipMaxWidth","tooltipStyle","setTooltipStyle","setArrowStyle","triggerRef","timeoutRef","hideTimeoutRef","updatePosition","finalPosition","preferredPosition","candidates_1","pos","getPositionCandidates","candidate","getAutoPosition","arrowPos","tooltipAbsoluteLeft","tooltipAbsoluteTop","getArrowPosition","hideTooltip","keepTooltipVisible","tryUpdatePosition_1","tooltipContainerStyle","calculateTooltipMaxWidth","updateMaxWidth","tooltipContentStyle","wordWrap","tooltipContent","handleTriggerMouseLeave","triggerProps","hasEnoughSpace","popoverRect","getAvailableSpace","Popover","popoverClassName","destroyOnHide","destroyTooltipOnHide","shouldDestroyOnHide","popoverStyle","setPopoverStyle","popoverRef","nextVisible","nextPlacement","oppositePlacement","getOppositePlacement","getPlacementPosition","clamped","nextTop","nextLeft","clampToViewport","openPopover","closePopover","togglePopover","triggerEvents","popoverNode","visibility","VIEWPORT_PADDING","ANIMATION_DURATION","Drawer","afterOpenChange","mask","maskClosable","closeIcon","keyboard","destroyOnClose","mobileBreakpoint","drawerStyle","headerStyle","bodyStyle","footerStyle","maskStyle","mergedOpen","shouldRender","setShouldRender","animatedOpen","setAnimatedOpen","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","petals","cos","sin","getParticle","tailOffset","normalizeProgress","fade","pow","Loading","strokeWidthProp","frame","setFrame","startRef","tick","pulseAngle","elapsed","rotationDeg","elapsedMs","getRotationDeg","lineWeight","strokeScale","pathD","steps","parts","toFixed","buildPath","particles","pt","preserveAspectRatio"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"index.esm.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/index.tsx","../src/components/Alert/icon.tsx","../src/components/Alert/index.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/Progress/index.tsx","../src/components/Textarea/TextareaTags.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"],"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","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","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, { 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","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"],"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","ThemeProvider","_a","theme","children","themeValue","useMemo","_jsx","Provider","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","size","color","_jsxs","_Fragment","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","Alert","title","description","showIcon","closeable","action","onClose","visible","setVisible","handleClose","hasRightSlot","onKeyDown","key","role","tabIndex","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","showClose","typeStyles","bgColor","defaultIcon","getTypeStyles","timer","setTimeout","clearTimeout","timer_1","useCallback","handleClick","maxWidth","background","transform","marginRight","flex","minWidth","marginTop","stopPropagation","currentTarget","Toast","ensureToastContainer","closeToast","clearAllToasts","debugToast","window","document","getElementById","toastContainerRoot","isInitializing","toastSuccess","options","toastError","toastInfo","toastQuestion","toastContainerElement","existingContainer","createElement","appendChild","createRoot","require","render","import","catch","warn","ToastProvider","mounted","setMounted","createPortal","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","round","strokeLinejoin","React","cloneElement","marginLeft","SHADOW_XS","sizeMap","pt","pb","InputGroup","forwardRef","ref","readOnly","prefix","suffix","leadingText","trailingText","leadingAddon","trailingAddon","onFocus","onBlur","onPressEnter","defaultValue","onChange","placeholder","required","hintText","restProps","inputRef","useRef","setFocused","internalValue","setInternalValue","current","isControlled","currentValue","dividerColor","hasPrefixIcon","hasSuffixIcon","iconSlotStyle","addonTextStyle","groupEl","borderRight","target","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","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","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","Fragment","textOverflow","WebkitTouchCallout","touchAction","newOpen","onTouchStart","onTouchEnd","minHeight","val","maxHeight","transformOrigin","WebkitOverflowScrolling","overscrollBehavior","textAlign","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","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","Table","columns","dataSource","rowSelection","pagination","bordered","locale","showHeader","footer","summary","scroll","tableLayout","onSorterChange","onPaginationChange","onRow","innerClassName","expandable","rowClassName","onHeaderRow","sticky","loadingSpinColor","selectedRowKeys","defaultSelectedRowKeys","setSelectedRowKeys","Map","sorters","setSorters","defaultExpandedRowKeys","expandedRowKeys","setExpandedRowKeys","_v","currentPage","setCurrentPage","_w","setPageSize","_x","draggedRowIndex","setDraggedRowIndex","_y","dragOverRowIndex","setDragOverRowIndex","_z","isMobile","setIsMobile","tableRef","headerRef","checkMobile","innerWidth","checkboxProps","getCheckboxProps","newSelectedRowKeys","k","selectedRows","Event","handleSelectAll","currentPageData","keys","changeRows","onSelectAll","handleSort","column","columnKey","dataIndex","newSorters","set","sorterArray","entries","c","field","currentSorter","currentDataSource","expanded","newExpandedRowKeys","onExpand","onExpandedRowsChange","emptyContent","getProcessedData","processed","sort","a","_loop_1","col","compareResult","sorter","aVal","bVal","sorterEntries_1","_i","state_1","processedData","isServerPagination","paginatedData","renderCell","getFixedOffset","columnIndex","fixed","isHeader","fixedDirection","offset","columnWidth","renderHeader","enabledRows","enabledKeys","allSelected","someSelected","headerColumns","colIndex","sortOrder","get","fixedOffset","align","borderBottom","onHeaderCell","sortColumn","selectWidth","selectColumn","hideSelectAll","every","some","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","x","sum","replace","effectiveTableLayout","tableStyle","borderCollapse","borderSpacing","wrapperStyle","marginBottom","displayValue","scrollContainerStyle","overflowX","overflowY","Radio","name","dotSize","Tab","items","layout","scrollable","normalizedItems","firstItem","firstKey","findMatchingKey","exactMatch","itemNum","valueNum","isNaN","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","container","scrollTimeout_2","updatePosition_2","handleScroll_2","scrollBehavior","scrollbarWidth","itemKey","itemKeyType","currentValueType","el","isReactElement","isValidElement","iconValue","badge","customElement","itemStyle","renderBackgroundStyle","Progress","percent","userTitlePosition","titlePosition","showPercent","animated","status","strokeColor","trailColor","normalizedPercent","isFirstRender","shouldAnimate","setShouldAnimate","animatingPercent","setAnimatingPercent","finalStrokeColor","radius","semicircleHeight","titleFontSize","percentFontSize","renderCircleProgress","containerHeight","circumference","PI","startX","endX","bottomY","svgHeight","textCenterY","semicircleCircumference","semicircleOffset","renderProgress","TextareaTags","helpIcon","resize","DOMAIN_REGEX","URL_CANDIDATE_REGEX","DEFAULT_ALLOWED_TLDS","websiteValidator","url","needProtocol","needHost","allowedTlds","hasProtocol","test","normalized","parsed","URL","protocol","host","hostname","split","segment","num","isInteger","tld","has","trimTrailingPunctuation","match","core","escapeHtml","stripEditorArtifacts","RegExp","renderTokensAsHtml","tokens","lastIndex","regex","exec","matchedText","href","defaultIsValid","validate","tokenizeText","html","token","classAttr","endsWith","getCaretOffset","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","useLayoutEffect","activeElement","fallbackOffset","caretOffset","nextHtml","innerHTML","maxOffset","createRange","remaining","walker","createTreeWalker","NodeFilter","SHOW_TEXT","currentNode","nextNode","rawText","textContent","visibleCount","targetOffsetInNode","setStart","collapse","removeAllRanges","addRange","setCaretOffset","notifyChange","nextValue","handleEditableInput","rawValue","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","startSelectedRangeText","endSelectedRangeText","rangeDisplayMode","isRangeMode","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","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","initialFields","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","rules_1","rule","validator","string","number","boolean","email","err_1","getFieldsValue","nameList","currentFields","validateFields","fieldsToValidate","errors","all","errorInfo","resetFields","setFieldsValue","allValues_2","submit","setFields","fieldsToSet","changedValues_1","registerFieldRef","scrollToField","useImperativeHandle","contextValue","formStyle","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","Children","child","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","userProfile","controlledSelectedKeys","selectedKeys","defaultSelectedKeys","menuRef","itemRefs","isSelectedKeysControlled","internalSelectedKeys","setInternalSelectedKeys","isGroup","getKeyPath","items_1","found","menuItem","currentPath","handleItemClick","newSelectedKeys","keyPath","skipGlobalClick","renderMenuItem","danger","suffixIcon","shouldShowDivider","currentItem","prevItem","avatar","charAt","toUpperCase","online","group","calculatePosition","triggerRect","tooltipRect","pageXOffset","pageYOffset","triggerCenterX","triggerCenterY","totalGap","viewportWidth","viewportHeight","willOverlap","calculatedTop","calculatedLeft","tooltipBottom","tooltipRight","tooltipTop","tooltipLeft","overlapTop","overlapBottom","overlapLeft","overlapRight","renderArrow","arrowStyle","baseArrowStyle","borderStyle","arrowStyles","borderWidth","borderColor","Tooltip","trigger","delay","tooltipClassName","showArrow","defaultVisible","onVisibleChange","internalVisible","setInternalVisible","isAnimating","setIsAnimating","newVisible","actualPosition","setActualPosition","tooltipMaxWidth","setTooltipMaxWidth","tooltipStyle","setTooltipStyle","setArrowStyle","triggerRef","timeoutRef","hideTimeoutRef","updatePosition","finalPosition","preferredPosition","candidates_1","pos","getPositionCandidates","candidate","getAutoPosition","arrowPos","tooltipAbsoluteLeft","tooltipAbsoluteTop","getArrowPosition","hideTooltip","keepTooltipVisible","tryUpdatePosition_1","tooltipContainerStyle","calculateTooltipMaxWidth","updateMaxWidth","tooltipContentStyle","wordWrap","tooltipContent","handleTriggerMouseLeave","triggerProps","hasEnoughSpace","popoverRect","getAvailableSpace","Popover","popoverClassName","destroyOnHide","destroyTooltipOnHide","shouldDestroyOnHide","popoverStyle","setPopoverStyle","popoverRef","nextVisible","nextPlacement","oppositePlacement","getOppositePlacement","getPlacementPosition","clamped","nextTop","nextLeft","clampToViewport","openPopover","closePopover","togglePopover","triggerEvents","popoverNode","visibility","VIEWPORT_PADDING","ANIMATION_DURATION","Drawer","afterOpenChange","mask","maskClosable","closeIcon","keyboard","destroyOnClose","mobileBreakpoint","drawerStyle","headerStyle","bodyStyle","footerStyle","maskStyle","mergedOpen","shouldRender","setShouldRender","animatedOpen","setAnimatedOpen","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","petals","cos","sin","getParticle","tailOffset","normalizeProgress","fade","pow","Loading","strokeWidthProp","frame","setFrame","startRef","tick","pulseAngle","elapsed","rotationDeg","elapsedMs","getRotationDeg","lineWeight","strokeScale","pathD","steps","parts","toFixed","buildPath","particles","preserveAspectRatio","colorTokens","gray","ring","dot","btnText","btnHoverBg","btnHoverText","brand","grayBlue","blueLight","blue","indigo","purple","pink","orange","pillPadding","badgePadding","getTokens","getRootStyle","isPill","isLg","shadow","BadgeDot","XIcon","Badge","BadgeWithDot","dotPaddingLeft","dotPaddingRight","BadgeWithIcon","IconLeading","iconLeading","IconTrailing","iconTrailing","hasLeading","padMap","BadgeWithButton","Icon","buttonLabel","onButtonClick","plMap","prMap","btnBorderRadius","BadgeIcon","BadgeWithImage","imgSrc","imgAlt","imgSize","SIZE_CONFIG","xs","onlineIndicator","companyIcon","verifiedTick","LABEL_GROUP_SIZE_CONFIG","nameFontSize","nameLineHeight","subFontSize","subLineHeight","UserIcon","VerifiedTickBadge","fillRule","clipRule","Avatar","initials","PlaceholderIcon","placeholderIcon","verified","imgFailed","setImgFailed","cfg","canShowImage","isPlaceholder","hasBadge","iSize","cSize","renderBadge","AvatarLabelGroup","supportingText","avatarInitials"],"mappings":"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","x_google_ignoreList":[0]}