aha-components 1.5.6 → 1.5.7

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.
@@ -1 +1 @@
1
- {"version":3,"file":"Pagination.js","sources":["../node_modules/tslib/tslib.es6.js","../src/theme/ThemeContext.tsx","../src/components/Button/index.tsx","../src/icons/index.tsx","../src/components/Pagination/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 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 { 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 = (\n item: number | string,\n index: number\n ): 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=\"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: \"none\",\n background: isActive ? \"#FAFAF9\" : \"white\",\n backgroundColor: isActive ? \"#FAFAF9\" : \"white\",\n color: isActive ? primaryColor : \"#79716B\",\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, index) => renderItem(item, index))}\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 onChange={(e) => handlePageSizeChange(Number(e.target.value))}\n disabled={disabled}\n style={{\n padding: size === \"small\" ? \"6px 12px\" : \"8px 12px\",\n border: \"1px solid #EAECF0\",\n borderRadius: \"8px\",\n fontSize: size === \"small\" ? \"12px\" : \"14px\",\n lineHeight: size === \"small\" ? \"18px\" : \"20px\",\n color: \"#101828\",\n fontFamily: \"DM Sans, sans-serif\",\n cursor: disabled ? \"not-allowed\" : \"pointer\",\n backgroundColor: \"white\",\n outline: \"none\",\n transition: \"all 0.2s\",\n }}\n onMouseEnter={(e) => {\n if (!disabled) {\n e.currentTarget.style.borderColor = primaryColor;\n }\n }}\n onMouseLeave={(e) => {\n e.currentTarget.style.borderColor = \"#EAECF0\";\n }}\n >\n {pageSizeOptions.map((size) => (\n <option key={size} value={size}>\n {size} 条/页\n </option>\n ))}\n </select>\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 跳至\n </span>\n <input\n type=\"number\"\n min=\"1\"\n value={jumpToPage}\n onChange={(e) => setJumpToPage(e.target.value)}\n onKeyPress={(e) => e.key === \"Enter\" && handleJumpTo()}\n disabled={disabled}\n style={{\n width: \"56px\",\n height: size === \"small\" ? \"28px\" : \"36px\",\n padding: \"0 8px\",\n border: \"1px solid #EAECF0\",\n borderRadius: \"8px\",\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#101828\",\n fontFamily: \"DM Sans, sans-serif\",\n outline: \"none\",\n transition: \"all 0.2s\",\n }}\n onFocus={(e) => {\n e.currentTarget.style.borderColor = primaryColor;\n }}\n onBlur={(e) => {\n e.currentTarget.style.borderColor = \"#EAECF0\";\n }}\n />\n <span\n style={{\n fontSize: \"14px\",\n lineHeight: \"20px\",\n color: \"#475467\",\n }}\n >\n 页\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 确定\n </Button>\n )}\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport default Pagination;\n"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","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","jsxs","_Fragment","children","_jsx","width","viewBox","fill","style","animation","jsx","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","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__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","concat","preventDefault","onMouseEnter","onMouseLeave","onMouseDown","onMouseUp","displayName","LeftArrowIcon","xmlns","d","strokeLinejoin","RightArrowIcon","controlledCurrent","current","defaultCurrent","total","controlledPageSize","pageSize","defaultPageSize","showSizeChanger","pageSizeOptions","showQuickJumper","showTotal","onChange","onShowSizeChange","simple","hideOnSinglePage","_m","_o","responsive","showLessItems","itemRender","_q","_r","internalCurrent","setInternalCurrent","_s","internalPageSize","setInternalPageSize","_t","jumpToPage","setJumpToPage","totalPages","useMemo","Math","ceil","useEffect","undefined","handlePageChange","page","handleJumpTo","marginRight","margin","marginLeft","start","end","min","flexWrap","Fragment","padding","Array","from","_","pages","push","getPageNumbers","map","item","index","isActive","element","minWidth","background","max","renderItem","value","newPageSize","Number","target","newTotalPages","newCurrent","currentTarget","borderColor","onKeyPress","key","onFocus","onBlur","goButton"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"Pagination.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"],"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<{ top: number; left: number; width: number } | 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 setDropdownPosition({\n top: rect.bottom + window.scrollY + 4,\n left: rect.left + window.scrollX,\n width: rect.width,\n });\n }\n };\n\n updatePosition();\n\n // 监听窗口大小变化和滚动,更新位置\n window.addEventListener('resize', updatePosition);\n window.addEventListener('scroll', updatePosition, true);\n\n return () => {\n window.removeEventListener('resize', updatePosition);\n window.removeEventListener('scroll', updatePosition, true);\n };\n } else {\n setDropdownPosition(null);\n }\n }, [isOpen]);\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: 'translateY(-8px)',\n animation: 'dropdownFadeIn 0.2s ease-out forwards',\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 = (\n item: number | string,\n index: number\n ): 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=\"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: \"none\",\n background: isActive ? \"#FAFAF9\" : \"white\",\n backgroundColor: isActive ? \"#FAFAF9\" : \"white\",\n color: isActive ? primaryColor : \"#79716B\",\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, index) => renderItem(item, index))}\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"],"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","jsxs","_Fragment","children","_jsx","width","viewBox","fill","style","animation","jsx","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","top","bottom","window","scrollY","scrollX","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","WebkitOverflowScrolling","overscrollBehavior","textAlign","index","isSelected","isFocused","selected","body","LeftArrowIcon","RightArrowIcon","controlledCurrent","defaultCurrent","total","controlledPageSize","pageSize","defaultPageSize","showSizeChanger","pageSizeOptions","showQuickJumper","showTotal","onShowSizeChange","simple","hideOnSinglePage","responsive","showLessItems","itemRender","internalCurrent","setInternalCurrent","internalPageSize","setInternalPageSize","jumpToPage","setJumpToPage","totalPages","Math","ceil","handlePageChange","page","handleJumpTo","marginRight","margin","start","end","min","_","pages","push","getPageNumbers","item","isActive","element","max","renderItem","Number","newPageSize","newTotalPages","newCurrent","goButton"],"mappings":"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","x_google_ignoreList":[0]}