aha-components 1.6.2 → 1.6.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Tab.esm.js +1 -1
- package/dist/Tab.esm.js.map +1 -1
- package/dist/Tab.js +1 -1
- package/dist/Tab.js.map +1 -1
- package/dist/Table.esm.js +1 -1
- package/dist/Table.esm.js.map +1 -1
- package/dist/Table.js +1 -1
- package/dist/Table.js.map +1 -1
- package/dist/components/Table/Table.stories.d.ts +2 -0
- package/dist/index.esm.js +1 -1
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/Table.esm.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Table.esm.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/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"],"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\nexport type ButtonType = 'default' | 'primary';\nexport type ButtonSize = 'small' | 'mediumSmall' | 'medium' | 'large';\n\nexport interface ButtonProps {\n /** 按钮内容 */\n children?: React.ReactNode;\n /** 按钮类型 */\n type?: ButtonType;\n /** 按钮尺寸 */\n size?: ButtonSize;\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否加载中 */\n loading?: boolean;\n /** 点击事件 */\n onClick?: (e: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;\n /** 按钮原生type */\n htmlType?: 'button' | 'submit' | 'reset';\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 图标 */\n icon?: React.ReactNode;\n /** 图标位置 */\n iconPosition?: 'left' | 'right';\n [key: string]: any;\n}\n\n// 尺寸配置:高度分别为 32、36、40、48px\nconst SIZE_CONFIG = {\n small: {\n height: '32px',\n paddingLeft: '12px',\n paddingRight: '12px',\n fontSize: '14px',\n lineHeight: '20px',\n iconSize: '16px',\n gap: '6px',\n },\n mediumSmall: {\n height: '36px',\n paddingLeft: '14px',\n paddingRight: '14px',\n fontSize: '14px',\n lineHeight: '20px',\n iconSize: '16px',\n gap: '6px',\n },\n medium: {\n height: '40px',\n paddingLeft: '16px',\n paddingRight: '16px',\n fontSize: '14px',\n lineHeight: '20px',\n iconSize: '18px',\n gap: '8px',\n },\n large: {\n height: '48px',\n paddingLeft: '20px',\n paddingRight: '20px',\n fontSize: '16px',\n lineHeight: '24px',\n iconSize: '20px',\n gap: '8px',\n },\n};\n\n// Loading 图标组件\nconst LoadingIcon: React.FC<{ size: number; color: string }> = ({ size, color }) => {\n // 使用 React 方式注入样式,避免在模块顶层操作 DOM\n const loadingStyles = `\n @keyframes aha-button-spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n `;\n\n return (\n <>\n <style>{loadingStyles}</style>\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n style={{\n animation: 'aha-button-spin 1s linear infinite',\n }}\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};\n\nconst Button: React.FC<ButtonProps> = ({\n children,\n type = 'default',\n size = 'medium',\n disabled = false,\n loading = false,\n onClick,\n htmlType = 'button',\n className = '',\n style,\n icon,\n iconPosition = 'left',\n ...rest\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const [isHovered, setIsHovered] = useState(false);\n const [isPressed, setIsPressed] = useState(false);\n\n const sizeConfig = SIZE_CONFIG[size];\n const isDisabled = disabled || loading;\n\n // 计算按钮样式\n const getButtonStyles = (): React.CSSProperties => {\n const baseStyle: React.CSSProperties = {\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: sizeConfig.gap,\n height: sizeConfig.height,\n paddingLeft: sizeConfig.paddingLeft,\n paddingRight: sizeConfig.paddingRight,\n fontSize: sizeConfig.fontSize,\n lineHeight: sizeConfig.lineHeight,\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n borderRadius: '8px',\n border: 'none',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n outline: 'none',\n transition: 'all 0.2s',\n userSelect: 'none',\n WebkitTapHighlightColor: 'transparent',\n ...style,\n };\n\n if (type === 'primary') {\n // Primary 按钮:使用主题色,所有状态下文字都是白色\n baseStyle.color = '#FFFFFF';\n baseStyle.backgroundColor = primaryColor;\n if (disabled) {\n // disabled状态:保持primary样式,通过降低透明度表示禁用\n baseStyle.opacity = 0.4;\n baseStyle.cursor = 'not-allowed';\n } else if (loading) {\n // loading状态:保持primary样式(主题色背景)\n baseStyle.backgroundColor = primaryColor;\n } else if (isPressed) {\n baseStyle.backgroundColor = '#EC470A'; // 按下时的深色\n } else if (isHovered) {\n baseStyle.backgroundColor = '#FD843A'; // hover时的浅色\n }\n } else {\n // Default 按钮:白色背景,灰色边框\n if (disabled) {\n // disabled状态:灰色背景,灰色文字\n baseStyle.backgroundColor = '#FAFAF9';\n baseStyle.color = '#D6D3D1';\n baseStyle.border = '1px solid #E7E5E4';\n } else if (loading) {\n // loading状态:保持default样式(白色背景+边框)\n baseStyle.backgroundColor = '#FFFFFF';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #E7E5E4';\n baseStyle.boxShadow = '0px 1px 2px 0px rgba(12, 10, 9, 0.05)';\n } else if (isPressed) {\n baseStyle.backgroundColor = '#F5F5F4';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #D7D3D0';\n baseStyle.boxShadow = '0px 1px 2px 0px rgba(12, 10, 9, 0.05)';\n } else if (isHovered) {\n // Hover 状态:浅灰色背景,边框稍微变深,增强阴影\n baseStyle.backgroundColor = '#FAFAF9';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #D7D3D0';\n baseStyle.boxShadow = '0px 2px 4px 0px rgba(12, 10, 9, 0.08)';\n } else {\n baseStyle.backgroundColor = '#FFFFFF';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #E7E5E4';\n baseStyle.boxShadow = '0px 1px 2px 0px rgba(12, 10, 9, 0.05)';\n }\n }\n\n return baseStyle;\n };\n\n // 处理点击事件\n const handleClick = (e: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {\n if (isDisabled) {\n e.preventDefault();\n return;\n }\n onClick?.(e);\n };\n\n // 渲染图标\n const renderIcon = () => {\n if (loading) {\n // loading时,根据按钮类型确定颜色\n // primary按钮:白色图标;default按钮:黑色图标\n const iconColor = type === 'primary' ? '#FFFFFF' : '#101828';\n const iconSize = parseInt(sizeConfig.iconSize.replace('px', ''));\n return <LoadingIcon size={iconSize} color={iconColor} />;\n }\n if (icon) {\n return (\n <span\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: sizeConfig.iconSize,\n height: sizeConfig.iconSize,\n flexShrink: 0,\n }}\n >\n {icon}\n </span>\n );\n }\n return null;\n };\n\n const buttonStyle = getButtonStyles();\n\n return (\n <button\n type={htmlType}\n className={`aha-button aha-button--${type} aha-button--${size} ${isDisabled ? 'aha-button--disabled' : ''} ${loading ? 'aha-button--loading' : ''} ${className}`}\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 {/* loading时,图标总是在左侧显示,忽略iconPosition */}\n {loading && renderIcon()}\n {!loading && iconPosition === 'left' && renderIcon()}\n {children && <span style={{ display: 'inline-block' }}>{children}</span>}\n {!loading && iconPosition === 'right' && renderIcon()}\n </button>\n );\n};\n\nButton.displayName = 'Button';\n\nexport default Button;\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// ==================== 类型定义 ====================\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 // ==================== 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 ref={tableRef} className={`aha-table aha-table-mobile-wrapper ${className}`} style={wrapperStyle} {...rest}>\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 </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 ref={tableRef} className={`aha-table ${className}`} style={wrapperStyle} {...rest}>\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 </div>\n );\n};\n\nexport default Table;\n\n"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__spreadArray","to","from","pack","ar","l","Array","slice","concat","SuppressedError","defaultTheme","primaryColor","ThemeContext","createContext","useTheme","context","useContext","SIZE_CONFIG","small","height","paddingLeft","paddingRight","fontSize","lineHeight","iconSize","gap","mediumSmall","medium","large","LoadingIcon","_a","size","color","_jsxs","_Fragment","children","_jsx","width","viewBox","fill","style","animation","cx","cy","r","stroke","strokeWidth","strokeLinecap","strokeDasharray","strokeDashoffset","opacity","Button","baseStyle","_b","type","_c","_d","disabled","_e","loading","onClick","_f","htmlType","_g","className","icon","_h","iconPosition","rest","_j","_k","useState","isHovered","setIsHovered","_l","isPressed","setIsPressed","sizeConfig","isDisabled","renderIcon","iconColor","parseInt","replace","display","alignItems","justifyContent","flexShrink","buttonStyle","position","fontWeight","fontFamily","borderRadius","border","cursor","outline","transition","userSelect","WebkitTapHighlightColor","backgroundColor","boxShadow","preventDefault","onMouseEnter","onMouseLeave","onMouseDown","onMouseUp","displayName","Input","forwardRef","ref","error","readOnly","prefix","suffix","allowClear","onClear","placeholder","value","defaultValue","onChange","onFocus","onBlur","onPressEnter","restProps","inputRef","useRef","React","internalValue","setInternalValue","focused","setFocused","useEffect","current","isControlled","undefined","currentValue","handleClear","stopPropagation","target","currentTarget","focus","showClear","sizeStyles","paddingTop","paddingBottom","baseStyles","boxSizing","WebkitAppearance","MozAppearance","appearance","left","zIndex","pointerEvents","onKeyDown","key","autoComplete","autoCorrect","autoCapitalize","spellCheck","right","xmlns","d","strokeLinejoin","Select","controlledValue","options","mode","showSearch","filterOption","onSelect","onDeselect","onSearch","onDropdownVisibleChange","_m","dropdownClassName","dropdownStyle","_o","defaultOpen","controlledOpen","open","maxTagCount","tagRender","optionRender","_p","_q","_r","internalOpen","setInternalOpen","_s","searchValue","setSearchValue","_t","focusedIndex","setFocusedIndex","selectRef","dropdownRef","_u","dropdownPosition","setDropdownPosition","isOpenControlled","isOpen","isMultiple","getSelectedOptions","useCallback","values","isArray","filter","opt","includes","getFilteredOptions","label","String","toLowerCase","search","filteredOptions","useMemo","updatePosition_1","rect","getBoundingClientRect","estimatedDropdownHeight","offsetHeight","Math","min","max","spaceBelow","window","innerHeight","bottom","spaceAbove","top","shouldOpenUp","top_1","scrollY","scrollX","placement","requestAnimationFrame","addEventListener","removeEventListener","handleClickOutside","event","contains","document","handleKeyDown","prev","option","handleSelect","focusedItem","querySelectorAll","scrollIntoView","block","behavior","newValues_1","currentValues","v","selectedOptions_1","handleRemoveTag","newValues","find","newValue","selectedOptions","hasValue","renderTags","tagsToShow","remainingCount","flexWrap","flex","minWidth","map","tagProps","closable","onClose","Fragment","padding","maxWidth","overflow","textOverflow","whiteSpace","marginLeft","WebkitTouchCallout","touchAction","newOpen","setTimeout","onTouchStart","onTouchEnd","tabIndex","minHeight","val","background","transform","createPortal","maxHeight","transformOrigin","WebkitOverflowScrolling","overscrollBehavior","textAlign","index","isSelected","isFocused","selected","body","CheckIcon","MinusIcon","SortIcon","SortDescIcon","SortAscIcon","LeftArrowIcon","RightArrowIcon","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","marginRight","margin","start","end","_","pages","push","getPageNumbers","item","isActive","element","renderItem","Number","newPageSize","newTotalPages","newCurrent","goButton","Checkbox","checked","indeterminate","isChecked","borderColor","el","getValue","obj","path","reduce","acc","getRowKey","record","rowKey","SortIconComponent","order","Table","columns","dataSource","rowSelection","pagination","bordered","locale","showHeader","title","footer","summary","scroll","tableLayout","onSorterChange","onPaginationChange","onRow","innerClassName","expandable","rowClassName","onHeaderRow","sticky","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","join","newSorters","delete","set","sorterArray","entries","c","field","currentSorter","currentDataSource","action","expanded","newExpandedRowKeys","onExpand","onExpandedRowsChange","emptyContent","getProcessedData","processed","sort","a","b","_loop_1","col","compareResult","sorter","aVal","bVal","sorterEntries_1","_i","state_1","processedData","isServerPagination","Boolean","paginatedData","renderCell","render","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","content","colSpan","renderRows","isExpanded","rowProps","isLastRow","draggable","onDragStart","onDragOver","onDrop","onDragEnd","cellProps","onCell","rowSpan","expandedRowRender","renderPagination","marginTop","hasFixedColumns","hasAllColumnWidths","totalWidth","x","sum","effectiveTableLayout","tableStyle","borderCollapse","borderSpacing","wrapperStyle","y","marginBottom","startsWith","displayValue","scrollContainerStyle","overflowX","overflowY"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"Table.esm.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/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"],"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\nexport type ButtonType = 'default' | 'primary';\nexport type ButtonSize = 'small' | 'mediumSmall' | 'medium' | 'large';\n\nexport interface ButtonProps {\n /** 按钮内容 */\n children?: React.ReactNode;\n /** 按钮类型 */\n type?: ButtonType;\n /** 按钮尺寸 */\n size?: ButtonSize;\n /** 是否禁用 */\n disabled?: boolean;\n /** 是否加载中 */\n loading?: boolean;\n /** 点击事件 */\n onClick?: (e: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;\n /** 按钮原生type */\n htmlType?: 'button' | 'submit' | 'reset';\n /** 自定义类名 */\n className?: string;\n /** 自定义样式 */\n style?: React.CSSProperties;\n /** 图标 */\n icon?: React.ReactNode;\n /** 图标位置 */\n iconPosition?: 'left' | 'right';\n [key: string]: any;\n}\n\n// 尺寸配置:高度分别为 32、36、40、48px\nconst SIZE_CONFIG = {\n small: {\n height: '32px',\n paddingLeft: '12px',\n paddingRight: '12px',\n fontSize: '14px',\n lineHeight: '20px',\n iconSize: '16px',\n gap: '6px',\n },\n mediumSmall: {\n height: '36px',\n paddingLeft: '14px',\n paddingRight: '14px',\n fontSize: '14px',\n lineHeight: '20px',\n iconSize: '16px',\n gap: '6px',\n },\n medium: {\n height: '40px',\n paddingLeft: '16px',\n paddingRight: '16px',\n fontSize: '14px',\n lineHeight: '20px',\n iconSize: '18px',\n gap: '8px',\n },\n large: {\n height: '48px',\n paddingLeft: '20px',\n paddingRight: '20px',\n fontSize: '16px',\n lineHeight: '24px',\n iconSize: '20px',\n gap: '8px',\n },\n};\n\n// Loading 图标组件\nconst LoadingIcon: React.FC<{ size: number; color: string }> = ({ size, color }) => {\n // 使用 React 方式注入样式,避免在模块顶层操作 DOM\n const loadingStyles = `\n @keyframes aha-button-spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n `;\n\n return (\n <>\n <style>{loadingStyles}</style>\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n style={{\n animation: 'aha-button-spin 1s linear infinite',\n }}\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};\n\nconst Button: React.FC<ButtonProps> = ({\n children,\n type = 'default',\n size = 'medium',\n disabled = false,\n loading = false,\n onClick,\n htmlType = 'button',\n className = '',\n style,\n icon,\n iconPosition = 'left',\n ...rest\n}) => {\n const { primaryColor = '#FB6011' } = useTheme();\n const [isHovered, setIsHovered] = useState(false);\n const [isPressed, setIsPressed] = useState(false);\n\n const sizeConfig = SIZE_CONFIG[size];\n const isDisabled = disabled || loading;\n\n // 计算按钮样式\n const getButtonStyles = (): React.CSSProperties => {\n const baseStyle: React.CSSProperties = {\n position: 'relative',\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: sizeConfig.gap,\n height: sizeConfig.height,\n paddingLeft: sizeConfig.paddingLeft,\n paddingRight: sizeConfig.paddingRight,\n fontSize: sizeConfig.fontSize,\n lineHeight: sizeConfig.lineHeight,\n fontWeight: 500,\n fontFamily: 'DM Sans, sans-serif',\n borderRadius: '8px',\n border: 'none',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n outline: 'none',\n transition: 'all 0.2s',\n userSelect: 'none',\n WebkitTapHighlightColor: 'transparent',\n ...style,\n };\n\n if (type === 'primary') {\n // Primary 按钮:使用主题色,所有状态下文字都是白色\n baseStyle.color = '#FFFFFF';\n baseStyle.backgroundColor = primaryColor;\n if (disabled) {\n // disabled状态:保持primary样式,通过降低透明度表示禁用\n baseStyle.opacity = 0.4;\n baseStyle.cursor = 'not-allowed';\n } else if (loading) {\n // loading状态:保持primary样式(主题色背景)\n baseStyle.backgroundColor = primaryColor;\n } else if (isPressed) {\n baseStyle.backgroundColor = '#EC470A'; // 按下时的深色\n } else if (isHovered) {\n baseStyle.backgroundColor = '#FD843A'; // hover时的浅色\n }\n } else {\n // Default 按钮:白色背景,灰色边框\n if (disabled) {\n // disabled状态:灰色背景,灰色文字\n baseStyle.backgroundColor = '#FAFAF9';\n baseStyle.color = '#D6D3D1';\n baseStyle.border = '1px solid #E7E5E4';\n } else if (loading) {\n // loading状态:保持default样式(白色背景+边框)\n baseStyle.backgroundColor = '#FFFFFF';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #E7E5E4';\n baseStyle.boxShadow = '0px 1px 2px 0px rgba(12, 10, 9, 0.05)';\n } else if (isPressed) {\n baseStyle.backgroundColor = '#F5F5F4';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #D7D3D0';\n baseStyle.boxShadow = '0px 1px 2px 0px rgba(12, 10, 9, 0.05)';\n } else if (isHovered) {\n // Hover 状态:浅灰色背景,边框稍微变深,增强阴影\n baseStyle.backgroundColor = '#FAFAF9';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #D7D3D0';\n baseStyle.boxShadow = '0px 2px 4px 0px rgba(12, 10, 9, 0.08)';\n } else {\n baseStyle.backgroundColor = '#FFFFFF';\n baseStyle.color = '#101828';\n baseStyle.border = '1px solid #E7E5E4';\n baseStyle.boxShadow = '0px 1px 2px 0px rgba(12, 10, 9, 0.05)';\n }\n }\n\n return baseStyle;\n };\n\n // 处理点击事件\n const handleClick = (e: React.MouseEvent<HTMLButtonElement, MouseEvent>) => {\n if (isDisabled) {\n e.preventDefault();\n return;\n }\n onClick?.(e);\n };\n\n // 渲染图标\n const renderIcon = () => {\n if (loading) {\n // loading时,根据按钮类型确定颜色\n // primary按钮:白色图标;default按钮:黑色图标\n const iconColor = type === 'primary' ? '#FFFFFF' : '#101828';\n const iconSize = parseInt(sizeConfig.iconSize.replace('px', ''));\n return <LoadingIcon size={iconSize} color={iconColor} />;\n }\n if (icon) {\n return (\n <span\n style={{\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: sizeConfig.iconSize,\n height: sizeConfig.iconSize,\n flexShrink: 0,\n }}\n >\n {icon}\n </span>\n );\n }\n return null;\n };\n\n const buttonStyle = getButtonStyles();\n\n return (\n <button\n type={htmlType}\n className={`aha-button aha-button--${type} aha-button--${size} ${isDisabled ? 'aha-button--disabled' : ''} ${loading ? 'aha-button--loading' : ''} ${className}`}\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 {/* loading时,图标总是在左侧显示,忽略iconPosition */}\n {loading && renderIcon()}\n {!loading && iconPosition === 'left' && renderIcon()}\n {children && <span style={{ display: 'inline-block' }}>{children}</span>}\n {!loading && iconPosition === 'right' && renderIcon()}\n </button>\n );\n};\n\nButton.displayName = 'Button';\n\nexport default Button;\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"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__spreadArray","to","from","pack","ar","l","Array","slice","concat","SuppressedError","defaultTheme","primaryColor","ThemeContext","createContext","useTheme","context","useContext","SIZE_CONFIG","small","height","paddingLeft","paddingRight","fontSize","lineHeight","iconSize","gap","mediumSmall","medium","large","LoadingIcon","_a","size","color","_jsxs","_Fragment","children","_jsx","width","viewBox","fill","style","animation","cx","cy","r","stroke","strokeWidth","strokeLinecap","strokeDasharray","strokeDashoffset","opacity","Button","baseStyle","_b","type","_c","_d","disabled","_e","loading","onClick","_f","htmlType","_g","className","icon","_h","iconPosition","rest","_j","_k","useState","isHovered","setIsHovered","_l","isPressed","setIsPressed","sizeConfig","isDisabled","renderIcon","iconColor","parseInt","replace","display","alignItems","justifyContent","flexShrink","buttonStyle","position","fontWeight","fontFamily","borderRadius","border","cursor","outline","transition","userSelect","WebkitTapHighlightColor","backgroundColor","boxShadow","preventDefault","onMouseEnter","onMouseLeave","onMouseDown","onMouseUp","displayName","Input","forwardRef","ref","error","readOnly","prefix","suffix","allowClear","onClear","placeholder","value","defaultValue","onChange","onFocus","onBlur","onPressEnter","restProps","inputRef","useRef","React","internalValue","setInternalValue","focused","setFocused","useEffect","current","isControlled","undefined","currentValue","handleClear","stopPropagation","target","currentTarget","focus","showClear","sizeStyles","paddingTop","paddingBottom","baseStyles","boxSizing","WebkitAppearance","MozAppearance","appearance","left","zIndex","pointerEvents","onKeyDown","key","autoComplete","autoCorrect","autoCapitalize","spellCheck","right","xmlns","d","strokeLinejoin","Select","controlledValue","options","mode","showSearch","filterOption","onSelect","onDeselect","onSearch","onDropdownVisibleChange","_m","dropdownClassName","dropdownStyle","_o","defaultOpen","controlledOpen","open","maxTagCount","tagRender","optionRender","_p","_q","_r","internalOpen","setInternalOpen","_s","searchValue","setSearchValue","_t","focusedIndex","setFocusedIndex","selectRef","dropdownRef","_u","dropdownPosition","setDropdownPosition","isOpenControlled","isOpen","isMultiple","getSelectedOptions","useCallback","values","isArray","filter","opt","includes","getFilteredOptions","label","String","toLowerCase","search","filteredOptions","useMemo","updatePosition_1","rect","getBoundingClientRect","estimatedDropdownHeight","offsetHeight","Math","min","max","spaceBelow","window","innerHeight","bottom","spaceAbove","top","shouldOpenUp","top_1","scrollY","scrollX","placement","requestAnimationFrame","addEventListener","removeEventListener","handleClickOutside","event","contains","document","handleKeyDown","prev","option","handleSelect","focusedItem","querySelectorAll","scrollIntoView","block","behavior","newValues_1","currentValues","v","selectedOptions_1","handleRemoveTag","newValues","find","newValue","selectedOptions","hasValue","renderTags","tagsToShow","remainingCount","flexWrap","flex","minWidth","map","tagProps","closable","onClose","Fragment","padding","maxWidth","overflow","textOverflow","whiteSpace","marginLeft","WebkitTouchCallout","touchAction","newOpen","setTimeout","onTouchStart","onTouchEnd","tabIndex","minHeight","val","background","transform","createPortal","maxHeight","transformOrigin","WebkitOverflowScrolling","overscrollBehavior","textAlign","index","isSelected","isFocused","selected","body","CheckIcon","MinusIcon","SortIcon","SortDescIcon","SortAscIcon","LeftArrowIcon","RightArrowIcon","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","marginRight","margin","start","end","_","pages","push","getPageNumbers","item","isActive","element","renderItem","Number","newPageSize","newTotalPages","newCurrent","goButton","Checkbox","checked","indeterminate","isChecked","borderColor","el","TableLoadingSpinner","TableLoadingOverlay","spinColor","content","role","inset","getValue","obj","path","reduce","acc","getRowKey","record","rowKey","SortIconComponent","order","Table","columns","dataSource","rowSelection","pagination","bordered","locale","showHeader","title","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","join","newSorters","delete","set","sorterArray","entries","c","field","currentSorter","currentDataSource","action","expanded","newExpandedRowKeys","onExpand","onExpandedRowsChange","emptyContent","getProcessedData","processed","sort","a","b","_loop_1","col","compareResult","sorter","aVal","bVal","sorterEntries_1","_i","state_1","processedData","isServerPagination","Boolean","paginatedData","renderCell","render","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","marginTop","hasFixedColumns","hasAllColumnWidths","totalWidth","x","sum","effectiveTableLayout","tableStyle","borderCollapse","borderSpacing","wrapperStyle","y","marginBottom","startsWith","displayValue","scrollContainerStyle","overflowX","overflowY"],"mappings":"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","x_google_ignoreList":[0]}
|