-
-
Notifications
You must be signed in to change notification settings - Fork 115
/
main.43a096bb.js.map
1 lines (1 loc) · 560 KB
/
main.43a096bb.js.map
1
{"version":3,"file":"static/js/main.43a096bb.js","mappings":"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","sources":["components/icons/logo.tsx","components/NoMatch/index.tsx","components/Loading/index.tsx","components/VersionSelect/index.module.less","components/VersionSelect/index.tsx","webpack://website/./src/layouts/index.module.less?ec2c","webpack://website/./src/components/SiderMenu/index.module.less?215c","components/icons/nav.tsx","components/SiderMenu/index.tsx","webpack://website/./src/components/Nav/index.module.less?d89d","contexts/index.ts","components/icons/menu.tsx","components/Nav/index.tsx","layouts/BaseLayout.tsx","routers.tsx","index.tsx","../../packages/utils/src/noop.ts","../../packages/utils/src/getScroll.ts","../../packages/react-affix/src/utils.ts","../../packages/react-affix/src/index.tsx","../../packages/react-portal/src/index.tsx","../../packages/react-overlay/src/index.tsx","../../packages/react-icon/src/index.tsx","../../packages/react-button/src/index.tsx","../../packages/react-modal/src/index.tsx","../../packages/react-alert/src/index.tsx","../../packages/react-auto-link/src/index.tsx","../../packages/react-avatar/src/index.tsx","../../packages/react-back-top/src/utils.ts","../../packages/react-back-top/src/index.tsx","../../packages/react-badge/src/index.tsx","../../packages/react-breadcrumb/src/Item.tsx","../../packages/react-breadcrumb/src/Breadcrumb.tsx","../../packages/react-breadcrumb/src/index.ts","../../packages/react-button-group/src/index.tsx","../../packages/react-overlay-trigger/src/utils.ts","../../packages/react-overlay-trigger/src/util/getBordersSize.ts","../../packages/react-overlay-trigger/src/util/isBrowser.ts","../../packages/react-overlay-trigger/src/util/isIE.ts","../../packages/react-overlay-trigger/src/util/getWindowSizes.ts","../../packages/react-overlay-trigger/src/util/getBoundingClientRect.ts","../../packages/react-overlay-trigger/src/util/getClientRect.ts","../../packages/react-overlay-trigger/src/util/getStyleComputedProperty.ts","../../packages/react-overlay-trigger/src/util/getOuterSizes.ts","../../packages/react-overlay-trigger/src/getStyle.ts","../../packages/react-overlay-trigger/src/index.tsx","../../packages/react-popover/src/index.tsx","../../packages/react-input/src/index.tsx","../../packages/react-time-picker/src/Panel.tsx","../../packages/react-time-picker/src/Time.tsx","../../packages/react-time-picker/src/index.tsx","../../packages/react-date-picker/src/DatePickerDay.tsx","../../packages/react-date-picker/src/DatePickerMonth.tsx","../../packages/react-date-picker/src/DatePickerYear.tsx","../../packages/react-date-picker/src/DatePickerCaption.tsx","../../packages/react-date-picker/src/index.tsx","../../packages/react-calendar/src/DayLabel.tsx","../../packages/react-calendar/src/index.tsx","../../packages/react-card/src/index.tsx","../../packages/react-carousel/src/index.tsx","../../packages/react-dropdown/src/index.tsx","../../packages/react-menu/src/MenuItem.tsx","../../packages/react-menu/src/Divider.tsx","../../packages/react-menu/src/SubMenu.tsx","../../packages/react-menu/src/Menu.tsx","../../packages/react-menu/src/index.ts","../../packages/react-cascader/src/index.tsx","../../packages/react-radio/src/RadioAbstract.tsx","../../packages/react-radio/src/Radio.tsx","../../packages/react-radio/src/RadioGroup.tsx","../../packages/react-checkbox/src/Group.tsx","../../packages/react-checkbox/src/Checkbox.tsx","../../packages/react-checkbox/src/index.ts","../../packages/react-collapse/src/Collapse.tsx","../../packages/react-collapse/src/Panel.tsx","../../packages/react-collapse/src/index.ts","../../packages/react-copy-to-clipboard/src/index.tsx","../../packages/react-date-input/src/DateInputRange.tsx","../../packages/react-date-input/src/index.tsx","../../packages/react-descriptions/src/DescriptionsItem.tsx","../../packages/react-descriptions/src/Cell.tsx","../../packages/react-descriptions/src/Row.tsx","../../packages/react-descriptions/src/index.tsx","../../packages/react-divider/src/index.tsx","../../packages/react-drawer/src/index.tsx","../../packages/react-empty/src/index.tsx","../../packages/react-file-input/src/Input.tsx","../../packages/react-file-input/src/List.tsx","../../packages/react-file-input/src/Card.tsx","../../packages/react-file-input/src/utils.ts","../../packages/react-file-input/src/FileList.tsx","../../packages/react-file-input/src/index.tsx","../../packages/react-grid/src/Col.tsx","../../packages/react-grid/src/Row.tsx","../../packages/react-form/src/FormItem.tsx","../../packages/react-form/src/Form.tsx","../../packages/react-form/src/index.ts","../../packages/react-list/src/Item.tsx","../../packages/react-list/src/index.tsx","../../packages/react-loader/src/index.tsx","../../packages/react-message/src/index.tsx","../../packages/react-month-picker/src/index.tsx","../../packages/react-notify/src/Container.tsx","../../packages/react-notify/src/index.tsx","../../packages/utils/src/randomid.ts","../../packages/react-select/src/Option.tsx","../../packages/react-select/src/Group.tsx","../../packages/react-select/src/index.tsx","../../packages/react-pagination/src/index.tsx","../../packages/react-pin-code/src/index.tsx","../../packages/react-progress/src/utils.tsx","../../packages/react-progress/src/Circle.tsx","../../packages/react-progress/src/Line.tsx","../../packages/react-progress/src/index.ts","../../packages/react-rate/src/index.tsx","../../packages/react-tag/src/index.tsx","../../packages/react-search-select/src/index.tsx","../../packages/react-steps/src/Steps.tsx","../../packages/react-steps/src/Step.tsx","../../packages/react-steps/src/index.ts","../../packages/react-slider/src/Dots.tsx","../../packages/react-slider/src/index.tsx","../../packages/react-switch/src/index.tsx","../../packages/react-table/src/util.ts","../../packages/react-table/src/ThComponent.tsx","../../packages/react-table/src/Thead.tsx","../../packages/react-table/src/Expandable.tsx","../../packages/react-table/src/TableTr.tsx","../../packages/react-table/src/index.tsx","../../packages/react-tabs/src/index.tsx","../../packages/react-tabs/src/Pane.tsx","../../packages/react-textarea/src/index.tsx","../../packages/react-tooltip/src/index.tsx","../../packages/react-tree/src/TreeNode.tsx","../../packages/react-tree/src/index.tsx","../../packages/react-tree-checked/src/index.tsx","../../packages/react-search-tree/src/SearchTagInput.tsx","../../packages/react-search-tree/src/index.tsx","../../packages/react-transfer/src/index.tsx","../webpack/bootstrap","../webpack/runtime/chunk loaded","../webpack/runtime/compat get default export","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/publicPath","../webpack/runtime/css loading","../webpack/runtime/jsonp chunk loading","../webpack/startup"],"sourcesContent":["import React from 'react';\n\nconst logo = (\n <svg viewBox=\"0 0 20 20\" width=\"23\" height=\"23\" version=\"1.1\">\n <g stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <path\n d=\"M5.70480219,0 L10.4096044,3.41834667 L8.61252986,8.94934776 L2.79707453,8.94934776 L1,3.41834667 L5.70480219,0 Z M5.70480219,20 L1,16.5816533 L2.79707453,11.0506522 L8.61252986,11.0506522 L10.4096044,16.5816533 L5.70480219,20 Z M18.8709653,12.9678909 L13.3400514,14.7649021 L9.92167142,10.0599974 L13.3399103,5.35519519 L18.8708781,7.15237223 L18.8709653,12.9678909 Z\"\n fill=\"#FFFFFF\"\n />\n </g>\n </svg>\n);\n\nconst dark = logo;\n\nconst light = (\n <svg viewBox=\"0 0 20 20\" version=\"1.1\">\n <g stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <path\n d=\"M5.70480219,0 L10.4096044,3.41834667 L8.61252986,8.94934776 L2.79707453,8.94934776 L1,3.41834667 L5.70480219,0 Z M5.70480219,20 L1,16.5816533 L2.79707453,11.0506522 L8.61252986,11.0506522 L10.4096044,16.5816533 L5.70480219,20 Z M18.8709653,12.9678909 L13.3400514,14.7649021 L9.92167142,10.0599974 L13.3399103,5.35519519 L18.8708781,7.15237223 L18.8709653,12.9678909 Z\"\n fill=\"#FFFFFF\"\n />\n </g>\n </svg>\n);\n\nexport default {\n dark,\n light,\n};\n","import { Link } from 'react-router-dom';\n\nexport default function NoMatch() {\n return (\n <div>\n <h2>It looks like you're lost...</h2>\n <p>\n <Link to=\"/\">Go to the home page</Link>\n </p>\n </div>\n );\n}\n","import { Loader, Icon } from 'uiw';\n\nexport default function De() {\n return (\n <Loader tip=\"Loading...\" indicator={<Icon type=\"loading\" spin={true} style={{ verticalAlign: 'text-top' }} />} />\n );\n}\n","// extracted by mini-css-extract-plugin\nexport default {};","import React, { useMemo } from 'react';\nimport { Select } from 'uiw';\nimport pkg from 'uiw/package.json';\nimport styles from './index.module.less';\n\ntype OptionsProps = {\n version?: string;\n};\n\nfunction Options(props = {} as OptionsProps) {\n return useMemo(() => <Select.Option value={props.version}>{props.version}</Select.Option>, [props.version]);\n}\n\nexport type VersionSelectProps = {\n data: string[];\n};\n\nconst VersionSelect = (props = {} as VersionSelectProps) => {\n function onChange(e: React.ChangeEvent<HTMLSelectElement>) {\n const version = e.target.value;\n const isV1 = version.split('.')[0] === '1';\n if (isV1) {\n window.location.href = `https://unpkg.com/uiw@${version}/dist/index.html`;\n } else {\n window.location.href = `https://unpkg.com/@uiw/doc@${version}/web/index.html`;\n }\n }\n // @ts-ignore\n // eslint-disable-next-line no-undef\n const currentVersion = pkg.version;\n const versionList = props.data;\n const firstVersion = versionList[0];\n if (firstVersion !== currentVersion) {\n versionList.unshift(currentVersion);\n }\n return useMemo(\n () => (\n <div className={styles.nav}>\n <Select defaultValue={versionList[0]} onChange={onChange}>\n {versionList.map((version, idx) => {\n return <Options key={idx} version={version} />;\n })}\n </Select>\n </div>\n ),\n [versionList],\n );\n};\n\nexport default VersionSelect;\n","// extracted by mini-css-extract-plugin\nexport default {\"sider\":\"index_sider__vrASx\",\"menuWarpper\":\"index_menuWarpper__asOzy\",\"subMenu\":\"index_subMenu__c4Mvo\",\"layoutWrap\":\"index_layoutWrap__6CE3D\",\"layoutSider\":\"index_layoutSider__1t-SG\"};","// extracted by mini-css-extract-plugin\nexport default {\"title\":\"index_title__O5TzH\",\"menu\":\"index_menu__9HE8I\",\"divider\":\"index_divider__1cINS\"};","import React from 'react';\n\nexport default {\n home: (\n <svg width=\"23\" height=\"24\" viewBox=\"0 0 23 24\">\n <path\n fill=\"#555\"\n d=\"M7.95808665,21.4797568 L7.95808665,14.2926972 C7.95808665,13.872855 8.29729322,13.5325056 8.71572573,13.5325056 L14.7768383,13.5325056 C15.1952708,13.5325056 15.5344774,13.872855 15.5344774,14.2926972 L15.5344774,21.4800639 L18.3333605,21.4801773 C18.4412665,21.4760176 18.5251665,21.4671569 18.58271,21.4596448 C18.588514,21.3995182 18.5915777,21.3235793 18.5907536,21.2318213 L18.5909124,14.2893672 C18.590922,13.869525 18.9301364,13.5291834 19.3485689,13.5291931 C19.7670014,13.5292027 20.1062001,13.8695599 20.1061905,14.2894021 L20.1059996,21.2248359 C20.1119888,21.8771673 19.9896563,22.3494462 19.5993559,22.6516032 C19.3010239,22.8825616 18.9057568,22.9796164 18.3624477,23 L4.48346492,22.9997015 C3.86961191,22.9824374 3.38486601,22.8118189 3.07125061,22.4182996 C2.79329968,22.0695315 2.68322544,21.5965073 2.68425496,20.9934992 L2.68424909,14.2893853 C2.68424872,13.8695431 3.02345499,13.5291934 3.4418875,13.5291931 C3.86032001,13.5291927 4.19952687,13.8695418 4.19952724,14.289384 L4.199532,20.9947994 C4.19904359,21.2811808 4.23526541,21.4410529 4.2538782,21.4676906 C4.24030246,21.4480656 4.31738234,21.474056 4.50469304,21.4796169 L7.95808665,21.4797568 Z M9.4733648,21.4798183 L14.0191993,21.4800025 L14.0191993,15.0528888 L9.4733648,15.0528888 L9.4733648,21.4798183 Z M2.28332829,11.4133771 C1.98200714,11.7046849 1.50237937,11.6957445 1.21204968,11.3934082 C0.921719999,11.0910719 0.930630346,10.6098283 1.2319515,10.3185205 L10.4507678,1.41136668 C10.7833916,1.14885042 11.1310579,1 11.4999998,1 C11.9102569,1 12.2738276,1.19453217 12.5845816,1.51087139 L21.7658664,10.3164197 C22.0683439,10.6065186 22.0791684,11.0877227 21.7900436,11.3912192 C21.5009189,11.6947157 21.0213305,11.7055767 20.718853,11.4154779 L11.5218713,2.5944308 C11.4545418,2.52599021 11.4440624,2.52038312 11.4999998,2.52038312 C11.514622,2.52038312 11.4750696,2.53731716 11.4448602,2.55629655 L2.28332829,11.4133771 Z\"\n />\n </svg>\n ),\n component: (\n <svg viewBox=\"0 0 1041 1024\" width=\"20\" height=\"20\">\n <path\n d=\"M133.498105 661.882904h31.175644v195.047619a34.373146 34.373146 0 0 0 34.373146 34.373146h109.514441a34.373146 34.373146 0 1 0 0-68.746292h-75.141295V627.509758a35.172521 35.172521 0 0 0-34.373146-35.172521h-65.54879a63.950039 63.950039 0 0 1 0-127.900079h65.54879a35.172521 35.172521 0 0 0 34.373146-35.172521V233.417642h195.846994a35.172521 35.172521 0 0 0 35.172522-34.373146v-65.54879a63.950039 63.950039 0 0 1 127.900078 0v65.54879a35.172521 35.172521 0 0 0 35.172521 34.373146h195.047619v74.341921a34.373146 34.373146 0 0 0 68.746292 0V199.044496a34.373146 34.373146 0 0 0-34.373146-34.373145H661.885302v-31.175645a133.495706 133.495706 0 0 0-266.991413 0v31.175645H199.046895a34.373146 34.373146 0 0 0-34.373146 34.373145v195.846995h-31.175644A132.696331 132.696331 0 0 0 0.002398 527.587822a133.495706 133.495706 0 0 0 133.495707 134.295082z\"\n fill=\"#6F737E\"\n />\n <path\n d=\"M1004.817386 840.943013a79.937549 79.937549 0 1 1 0-159.875097 34.373146 34.373146 0 0 0 34.373146-32.774395V533.982826a34.373146 34.373146 0 0 0-34.373146-34.373146H879.315435v-10.391881a103.119438 103.119438 0 1 0-206.238876 0v10.391881H549.972734a35.172521 35.172521 0 0 0-35.172522 34.373146v124.702576h-10.391881a103.119438 103.119438 0 1 0 0 206.238876h10.391881v124.702576a35.172521 35.172521 0 0 0 35.172522 34.373146H663.484053a34.373146 34.373146 0 0 0 34.373146-34.373146 79.937549 79.937549 0 0 1 159.875098 0 34.373146 34.373146 0 0 0 34.373146 34.373146h114.310694a34.373146 34.373146 0 0 0 34.373146-34.373146V879.313037a34.373146 34.373146 0 0 0-35.971897-38.370024z\"\n fill=\"#6F737E\"\n />\n </svg>\n ),\n github: (\n <svg viewBox=\"0 0 1049 1024\" width=\"20\" height=\"20\">\n <path\n d=\"M524.979332 0C234.676191 0 0 234.676191 0 524.979332c0 232.068678 150.366597 428.501342 358.967656 498.035028 26.075132 5.215026 35.636014-11.299224 35.636014-25.205961 0-12.168395-0.869171-53.888607-0.869171-97.347161-146.020741 31.290159-176.441729-62.580318-176.441729-62.580318-23.467619-60.841976-58.234462-76.487055-58.234463-76.487055-47.804409-32.15933 3.476684-32.15933 3.476685-32.15933 53.019436 3.476684 80.83291 53.888607 80.83291 53.888607 46.935238 79.963739 122.553122 57.365291 152.97411 43.458554 4.345855-33.897672 18.252593-57.365291 33.028501-70.402857-116.468925-12.168395-239.022047-57.365291-239.022047-259.012982 0-57.365291 20.860106-104.300529 53.888607-140.805715-5.215026-13.037566-23.467619-66.926173 5.215027-139.067372 0 0 44.327725-13.906737 144.282399 53.888607 41.720212-11.299224 86.917108-17.383422 131.244833-17.383422s89.524621 6.084198 131.244833 17.383422C756.178839 203.386032 800.506564 217.29277 800.506564 217.29277c28.682646 72.1412 10.430053 126.029806 5.215026 139.067372 33.897672 36.505185 53.888607 83.440424 53.888607 140.805715 0 201.64769-122.553122 245.975415-239.891218 259.012982 19.121764 16.514251 35.636014 47.804409 35.636015 97.347161 0 70.402857-0.869171 126.898978-0.869172 144.282399 0 13.906737 9.560882 30.420988 35.636015 25.205961 208.601059-69.533686 358.967656-265.96635 358.967655-498.035028C1049.958663 234.676191 814.413301 0 524.979332 0z\"\n fill=\"#191717\"\n />\n <path\n d=\"M199.040177 753.571326c-0.869171 2.607513-5.215026 3.476684-8.691711 1.738342s-6.084198-5.215026-4.345855-7.82254c0.869171-2.607513 5.215026-3.476684 8.691711-1.738342s5.215026 5.215026 4.345855 7.82254z m-6.953369-4.345856M219.900283 777.038945c-2.607513 2.607513-7.82254 0.869171-10.430053-2.607514-3.476684-3.476684-4.345855-8.691711-1.738342-11.299224 2.607513-2.607513 6.953369-0.869171 10.430053 2.607514 3.476684 4.345855 4.345855 9.560882 1.738342 11.299224z m-5.215026-5.215027M240.760389 807.459932c-3.476684 2.607513-8.691711 0-11.299224-4.345855-3.476684-4.345855-3.476684-10.430053 0-12.168395 3.476684-2.607513 8.691711 0 11.299224 4.345855 3.476684 4.345855 3.476684 9.560882 0 12.168395z m0 0M269.443034 837.011749c-2.607513 3.476684-8.691711 2.607513-13.906737-1.738342-4.345855-4.345855-6.084198-10.430053-2.607513-13.037566 2.607513-3.476684 8.691711-2.607513 13.906737 1.738342 4.345855 3.476684 5.215026 9.560882 2.607513 13.037566z m0 0M308.555733 853.526c-0.869171 4.345855-6.953369 6.084198-13.037566 4.345855-6.084198-1.738342-9.560882-6.953369-8.691711-10.430053 0.869171-4.345855 6.953369-6.084198 13.037566-4.345855 6.084198 1.738342 9.560882 6.084198 8.691711 10.430053z m0 0M351.145116 857.002684c0 4.345855-5.215026 7.82254-11.299224 7.82254-6.084198 0-11.299224-3.476684-11.299224-7.82254s5.215026-7.82254 11.299224-7.82254c6.084198 0 11.299224 3.476684 11.299224 7.82254z m0 0M391.126986 850.049315c0.869171 4.345855-3.476684 8.691711-9.560882 9.560882-6.084198 0.869171-11.299224-1.738342-12.168395-6.084197-0.869171-4.345855 3.476684-8.691711 9.560881-9.560882 6.084198-0.869171 11.299224 1.738342 12.168396 6.084197z m0 0\"\n fill=\"#191717\"\n />\n </svg>\n ),\n issue: (\n <svg className=\"issue\" viewBox=\"0 0 1024 1024\" width=\"23\" height=\"23\">\n <path\n d=\"M1022.976 698.368c0-58.88-24.064-113.664-64.512-155.648-44.544 175.616-223.744 307.2-438.784 310.784 51.712 55.296 131.072 90.624 219.648 90.624 21.504 0 41.984-2.048 61.952-6.144 54.784 75.776 121.856 72.192 121.856 72.192-24.064-14.848-27.136-69.632-26.112-108.032 76.288-44.032 125.952-119.296 125.952-203.776z m0 0\"\n fill=\"#558EFF\"\n ></path>\n <path\n d=\"M458.24 13.824C205.312 13.824 0 191.488 0 410.624c0 137.216 80.384 258.048 202.24 329.216 1.536 61.44-3.584 150.016-41.984 174.592 0 0 108.544 5.632 197.12-116.736 32.256 6.144 66.048 9.728 100.352 9.728H465.92c215.04-3.584 394.24-135.168 438.784-310.784 7.168-27.648 10.752-56.32 10.752-86.016 0.512-219.136-204.288-396.8-457.216-396.8zM256 462.848c-33.792 0-60.928-27.136-60.928-60.928 0-33.792 27.136-60.928 60.928-60.928 33.792 0 60.928 27.136 60.928 60.928 0 33.792-27.136 60.928-60.928 60.928z m202.24 0c-33.792 0-60.928-27.136-60.928-60.928 0-33.792 27.136-60.928 60.928-60.928 33.792 0 60.928 27.136 60.928 60.928 0 33.792-27.136 60.928-60.928 60.928z m202.24 0c-33.792 0-60.928-27.136-60.928-60.928 0-33.792 27.136-60.928 60.928-60.928 33.792 0 60.928 27.136 60.928 60.928 0 33.792-27.136 60.928-60.928 60.928z m0 0\"\n fill=\"#549EFF\"\n ></path>\n </svg>\n ),\n gitee: (\n <svg className=\"gitee\" viewBox=\"0 0 1024 1024\" width=\"200\" height=\"200\">\n <path\n d=\"M512 1024C229.222 1024 0 794.778 0 512S229.222 0 512 0s512 229.222 512 512-229.222 512-512 512z m259.149-568.883h-290.74a25.293 25.293 0 0 0-25.292 25.293l-0.026 63.206c0 13.952 11.315 25.293 25.267 25.293h177.024c13.978 0 25.293 11.315 25.293 25.267v12.646a75.853 75.853 0 0 1-75.853 75.853h-240.23a25.293 25.293 0 0 1-25.267-25.293V417.203a75.853 75.853 0 0 1 75.827-75.853h353.946a25.293 25.293 0 0 0 25.267-25.292l0.077-63.207a25.293 25.293 0 0 0-25.268-25.293H417.152a189.62 189.62 0 0 0-189.62 189.645V771.15c0 13.977 11.316 25.293 25.294 25.293h372.94a170.65 170.65 0 0 0 170.65-170.65V480.384a25.293 25.293 0 0 0-25.293-25.267z\"\n fill=\"#C71D23\"\n ></path>\n </svg>\n ),\n plugin: (\n <svg viewBox=\"0 0 1024 1024\" width=\"24\" height=\"24\">\n <path d=\"M937.6 251.3L538 69.7c-11.5-5.1-24.6-5.1-36.1 0L102.4 251.3c-22.4 9.9-32.5 32.2-22.6 54.6 4.5 10.1 12.5 15.1 22.6 19.6L502 506.1c11.5 5.1 24.6 5.1 36.1 0l399.6-180.6c22.4-9.9 32.5-33.2 22.6-55.6-4.6-10.1-12.6-14.1-22.7-18.6zM497.6 723.4l-398.7-165c-18.4-7.6-27.1-28.7-19.5-47 7.6-18.4 28.7-27.1 47-19.5l398.7 165c18.4 7.6 27.1 28.7 19.5 47-7.6 18.3-28.6 27.1-47 19.5z\" />\n <path d=\"M526.4 723.4l398.7-165c18.4-7.6 27.1-28.7 19.5-47-7.6-18.4-28.7-27.1-47-19.5l-398.7 165c-18.4 7.6-27.1 28.7-19.5 47 7.6 18.3 28.6 27.1 47 19.5z\" />\n <path d=\"M497.6 955.4l-398.7-165c-18.4-7.6-27.1-28.7-19.5-47 7.6-18.4 28.7-27.1 47-19.5l398.7 165c18.4 7.6 27.1 28.7 19.5 47-7.6 18.3-28.6 27.1-47 19.5z\" />\n <path d=\"M526.4 955.4l398.7-165c18.4-7.6 27.1-28.7 19.5-47-7.6-18.4-28.7-27.1-47-19.5l-398.7 165c-18.4 7.6-27.1 28.7-19.5 47 7.6 18.3 28.6 27.1 47 19.5z\" />\n </svg>\n ),\n};\n","import { NavLink } from 'react-router-dom';\nimport { useLocation } from 'react-router-dom';\nimport styles from './index.module.less';\nimport menu from '../../menu.json';\nimport nav from '../icons/nav';\n\nexport default function SiderMenu() {\n const location = useLocation();\n const data = menu.find((item) => new RegExp(`^${item.path || ''}`).test(location.pathname));\n\n if (!data?.children) {\n return null;\n }\n return (\n <div className={styles.wapper}>\n <h2 className={styles.title}>\n {(nav as any)[data.icon]}\n <span>{data.name}</span>\n </h2>\n <div className={styles.menu}>\n {data.children &&\n data.children.map((item, idx) => {\n if (item.divider) {\n return (\n <div key={idx} className={styles.divider}>\n {item.name}\n </div>\n );\n }\n if (/^http(?:|s):\\/\\//.test(item.path || '')) {\n return (\n <a key={idx} href={item.path} target=\"__blank\">\n {item.name}\n <svg viewBox=\"0 0 1024 1024\" width={14}>\n <path d=\"M821.1456 276.8384c-235.9296 25.1392-449.1776 226.7136-490.5472 452.352a38.4 38.4 0 1 1-75.5712-13.824c45.568-248.576 269.312-468.48 526.6944-510.6688l-117.8112-69.1712a38.4 38.4 0 0 1 38.912-66.2528l223.3344 131.1744a38.4 38.4 0 0 1 10.1376 57.6l-170.752 206.6432a38.4 38.4 0 1 1-59.1872-48.9472l114.7904-138.9056z\" />\n <path d=\"M832 620.0832a38.4 38.4 0 0 1 76.8 0v158.208c0 85.9648-61.5936 157.8496-140.8 157.8496H204.8c-79.2064 0-140.8-71.8848-140.8-157.9008V300.3904c0-86.016 61.5936-157.8496 140.8-157.8496h220.2112a38.4 38.4 0 1 1 0 76.8H204.8c-33.8944 0-64 35.072-64 81.0496V778.24c0 45.9776 30.1056 81.1008 64 81.1008h563.2c33.8944 0 64-35.1232 64-81.1008v-158.1568z\" />\n </svg>\n </a>\n );\n }\n return (\n <NavLink key={idx} to={item.path || ''} replace>\n {item.name}\n </NavLink>\n );\n })}\n </div>\n </div>\n );\n}\n","// extracted by mini-css-extract-plugin\nexport default {\"logo\":\"index_logo__kUQOi\",\"top\":\"index_top__DLxV-\",\"nav\":\"index_nav__SdXbb\",\"navTop\":\"index_navTop__08yh1\",\"btn\":\"index_btn__YYGUe\",\"btnTop\":\"index_btnTop__PlNw6\"};","import React from 'react';\n\ntype InitialState = {\n layout: 'top' | 'left' | 'mix';\n};\n\nexport const initialState: InitialState = {\n layout: 'top',\n};\n\nexport const reducer = (state: InitialState, action: InitialState) => {\n return {\n ...state,\n ...action,\n };\n};\n\nexport interface Context {\n state: InitialState;\n dispatch: React.Dispatch<InitialState>;\n}\n\nexport const ThemeContext = React.createContext<Context>({\n state: initialState,\n dispatch: () => null,\n});\n","import React from 'react';\n\nexport default {\n menu: (\n <svg width=\"19\" height=\"19\" viewBox=\"0 0 26 26\">\n <g fill=\"none\" fillRule=\"evenodd\">\n <rect width=\"26\" height=\"26\" fill=\"#9E9E9E\" rx=\"4\" />\n <rect width=\"5\" height=\"20\" x=\"3\" y=\"3\" fill=\"#202224\" rx=\"2.5\" />\n <rect width=\"12\" height=\"20\" x=\"11\" y=\"3\" fill=\"#FFF\" fillOpacity=\".657\" rx=\"2\" />\n </g>\n </svg>\n ),\n menutop: (\n <svg width=\"19\" height=\"19\" viewBox=\"0 0 26 26\">\n <g fill=\"none\" fillRule=\"evenodd\">\n <rect width=\"26\" height=\"26\" fill=\"#9E9E9E\" rx=\"4\" />\n <rect width=\"20\" height=\"5\" x=\"3\" y=\"3\" fill=\"#202224\" rx=\"2.5\" />\n <rect width=\"20\" height=\"12\" x=\"3\" y=\"11\" fill=\"#FFF\" fillOpacity=\".66\" rx=\"2\" />\n </g>\n </svg>\n ),\n china: (\n <svg className=\"flag\" width=\"19\" height=\"19\" viewBox=\"0 0 512 512\">\n <defs>\n <path id=\"a\" fill=\"#ffde00\" d=\"M1-.3L-.7.8 0-1 .6.8-1-.3z\" />\n </defs>\n <path fill=\"#de2910\" d=\"M0 0h512v512H0z\" />\n <use width=\"30\" height=\"20\" transform=\"matrix(76.8 0 0 76.8 128 128)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"rotate(-121 142.6 -47) scale(25.5827)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"rotate(-98.1 198 -82) scale(25.6)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"rotate(-74 272.4 -114) scale(25.6137)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"matrix(16 -19.968 19.968 16 256 230.4)\" xlinkHref=\"#a\" />\n </svg>\n ),\n};\n","import { Fragment, useContext } from 'react';\nimport { Tooltip } from 'uiw';\nimport { NavLink, Link } from 'react-router-dom';\nimport styles from './index.module.less';\nimport data from '../../menu.json';\nimport { ThemeContext } from '../../contexts';\nimport nav from '../icons/nav';\nimport logo from '../icons/logo';\nimport menu from '../icons/menu';\nimport pkg from 'uiw/package.json';\n\nexport default function Nav() {\n const { state, dispatch } = useContext(ThemeContext);\n return (\n <Fragment>\n <div className={[styles.logo, state.layout === 'left' ? null : styles.top].filter(Boolean).join(' ').trim()}>\n <Link to=\"/\">\n {logo.dark}\n {state.layout === 'top' && (\n <span>\n UIW<sup>{pkg.version}</sup>\n </span>\n )}\n </Link>\n </div>\n <div className={[styles.nav, state.layout === 'left' ? null : styles.navTop].filter(Boolean).join(' ').trim()}>\n {data.map(({ path, name, icon }, idx) => {\n if (Object.keys(nav).includes(icon)) {\n icon = (nav as any)[icon];\n }\n if (/^https?:(?:\\/\\/)?/.test(path)) {\n if (state.layout === 'top') {\n return (\n <a key={idx} target=\"__blank\" href={path} className={styles.outerUrl}>\n {icon} <span>{name}</span>\n </a>\n );\n }\n return (\n <Tooltip\n usePortal={false}\n key={idx}\n placement={state.layout === 'left' ? 'right' : 'bottom'}\n content={<span style={{ whiteSpace: 'nowrap' }}>{name}</span>}\n >\n <a target=\"__blank\" href={path} className={styles.outerUrl}>\n {icon}\n </a>\n </Tooltip>\n );\n }\n let activeStyle: React.CSSProperties = {\n color: '#fff',\n };\n if (state.layout === 'top') {\n return (\n <NavLink\n to={path}\n key={idx}\n // @ts-ignore\n style={({ isActive }) => (isActive ? activeStyle : undefined)}\n >\n {icon} <span>{name}</span>\n </NavLink>\n );\n }\n\n return (\n <Tooltip\n usePortal={false}\n key={idx}\n placement={state.layout === 'left' ? 'right' : 'bottom'}\n content={<span style={{ whiteSpace: 'nowrap' }}>{name}</span>}\n >\n <NavLink\n to={path}\n // @ts-ignore\n style={({ isActive }) => (isActive ? activeStyle : undefined)}\n >\n {icon}\n </NavLink>\n </Tooltip>\n );\n })}\n </div>\n <div className={[styles.btn, state.layout === 'left' ? null : styles.btnTop].filter(Boolean).join(' ').trim()}>\n <Tooltip placement={state.layout === 'left' ? 'right' : 'bottom'} content=\"国内镜像站点\">\n <a href=\"http://uiw.gitee.io\" rel=\"noopener noreferrer\" target=\"_blank\">\n {menu.china}\n </a>\n </Tooltip>\n <button onClick={() => dispatch({ layout: state.layout === 'left' ? 'top' : 'left' })}>\n {state.layout === 'left' ? menu.menu : menu.menutop}\n </button>\n </div>\n </Fragment>\n );\n}\n","import { Fragment, useContext } from 'react';\nimport { Outlet } from 'react-router-dom';\nimport { Layout, Affix } from 'uiw';\nimport VersionSelect from '../components/VersionSelect';\nimport styles from './index.module.less';\nimport version from '../version.json';\nimport SiderMenu from '../components/SiderMenu';\nimport Nav from '../components/Nav';\nimport { ThemeContext } from '../contexts';\n\nconst { Header, Sider, Content } = Layout;\nexport interface ComponentsProps {\n siderMenu?: boolean;\n}\n\nexport default function Components(props: ComponentsProps) {\n const { siderMenu = true } = props;\n const { state } = useContext(ThemeContext);\n return (\n <Layout className={styles.layout}>\n {state.layout === 'top' ? (\n <Fragment>\n <Affix offsetTop={0} style={{ zIndex: 999 }}>\n <Header style={{ display: 'flex', alignItems: 'center' }}>\n <Nav />\n </Header>\n </Affix>\n <Layout className={styles.layoutWrap}>\n <Sider width={siderMenu ? 260 : 0} className={styles.layoutSider}>\n <div style={{ width: siderMenu ? 260 : 0, height: 'calc(100vh - 53px)' }}>\n <SiderMenu />\n </div>\n </Sider>\n <Content style={{ padding: 20 }} className={styles.layoutContent}>\n <Outlet />\n </Content>\n </Layout>\n </Fragment>\n ) : (\n <Fragment>\n <Sider width={siderMenu ? 330 : 64}>\n <Layout className={styles.sider}>\n <Sider className={styles.menuWarpper} width={64}>\n <Nav />\n </Sider>\n <Layout\n style={{\n position: 'fixed',\n width: siderMenu ? 330 : 64,\n zIndex: 1,\n left: 0,\n top: 0,\n bottom: 0,\n overflow: 'auto',\n }}\n >\n <Content className={styles.subMenu} style={{ paddingLeft: 64 }}>\n <SiderMenu />\n </Content>\n </Layout>\n </Layout>\n </Sider>\n <Layout style={{ position: 'relative' }}>\n <Header\n style={{\n height: 'inherit',\n lineHeight: '32px',\n position: 'absolute',\n padding: '5px 10px',\n width: '100%',\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'flex-end',\n backgroundColor: 'transparent',\n zIndex: 99,\n }}\n >\n <VersionSelect data={version} />\n </Header>\n <Content style={{ padding: 20 }} className={styles.layoutContent}>\n <Outlet />\n </Content>\n </Layout>\n </Fragment>\n )}\n </Layout>\n );\n}\n","import { lazy, Suspense } from 'react';\nimport { RouteObject } from 'react-router-dom';\nimport NoMatch from './components/NoMatch';\nimport Loading from './components/Loading';\nimport BaseLayout from './layouts/BaseLayout';\n\nconst Loadable = (Component: any) => (props: any) =>\n (\n <Suspense fallback={<Loading />}>\n <Component {...props} />\n </Suspense>\n );\n\nconst Home = Loadable(lazy(() => import('./routes/home')));\nconst Extensions = Loadable(lazy(() => import('./routes/extensions')));\n\nconst GuideQuickStart = Loadable(lazy(() => import('./routes/guide/quick-start')));\nconst GuideImport = Loadable(lazy(() => import('./routes/guide/import')));\nconst GuideCreateReactApp = Loadable(lazy(() => import('./routes/guide/create-react-app')));\nconst GuideKKT = Loadable(lazy(() => import('./routes/guide/kkt')));\nconst GuideDocs = Loadable(lazy(() => import('./routes/guide/docs')));\nconst GuideVscode = Loadable(lazy(() => import('./routes/guide/vscode')));\nconst GuideRecommendation = Loadable(lazy(() => import('./routes/guide/recommendation')));\n\nconst Overview = Loadable(lazy(() => import('./routes/overview')));\nconst Colors = Loadable(lazy(() => import('./routes/components/colors')));\nconst Alert = Loadable(lazy(() => import('./routes/components/alert')));\nconst AutoLink = Loadable(lazy(() => import('./routes/components/auto-link')));\nconst ResetCss = Loadable(lazy(() => import('./routes/components/reset-css')));\nconst Avatar = Loadable(lazy(() => import('./routes/components/avatar')));\nconst Affix = Loadable(lazy(() => import('./routes/components/affix')));\nconst Calendar = Loadable(lazy(() => import('./routes/components/calendar')));\nconst Cascader = Loadable(lazy(() => import('./routes/components/cascader')));\nconst Checkbox = Loadable(lazy(() => import('./routes/components/checkbox')));\nconst CopyToClipboard = Loadable(lazy(() => import('./routes/components/copy-to-clipboard')));\nconst Collapse = Loadable(lazy(() => import('./routes/components/collapse')));\nconst Card = Loadable(lazy(() => import('./routes/components/card')));\nconst Carousel = Loadable(lazy(() => import('./routes/components/carousel')));\nconst Descriptions = Loadable(lazy(() => import('./routes/components/descriptions')));\nconst Loader = Loadable(lazy(() => import('./routes/components/loader')));\nconst Icon = Loadable(lazy(() => import('./routes/components/icon')));\nconst Divider = Loadable(lazy(() => import('./routes/components/divider')));\nconst Drawer = Loadable(lazy(() => import('./routes/components/drawer')));\nconst DatePicker = Loadable(lazy(() => import('./routes/components/date-picker')));\nconst DateInput = Loadable(lazy(() => import('./routes/components/date-input')));\nconst Dropdown = Loadable(lazy(() => import('./routes/components/dropdown')));\nconst Badge = Loadable(lazy(() => import('./routes/components/badge')));\nconst Progress = Loadable(lazy(() => import('./routes/components/progress')));\nconst Pagination = Loadable(lazy(() => import('./routes/components/pagination')));\nconst PinCode = Loadable(lazy(() => import('./routes/components/pin-code')));\nconst Input = Loadable(lazy(() => import('./routes/components/input')));\nconst Button = Loadable(lazy(() => import('./routes/components/button')));\nconst Radio = Loadable(lazy(() => import('./routes/components/radio')));\nconst Select = Loadable(lazy(() => import('./routes/components/select')));\nconst SearchSelect = Loadable(lazy(() => import('./routes/components/search-select')));\nconst Split = Loadable(lazy(() => import('./routes/components/split')));\nconst Switch = Loadable(lazy(() => import('./routes/components/switch')));\nconst Slider = Loadable(lazy(() => import('./routes/components/slider')));\nconst Grid = Loadable(lazy(() => import('./routes/components/grid')));\nconst Form = Loadable(lazy(() => import('./routes/components/form')));\nconst FileInput = Loadable(lazy(() => import('./routes/components/file-input')));\nconst Breadcrumb = Loadable(lazy(() => import('./routes/components/breadcrumb')));\nconst List = Loadable(lazy(() => import('./routes/components/list')));\nconst Layout = Loadable(lazy(() => import('./routes/components/layout')));\nconst Notify = Loadable(lazy(() => import('./routes/components/notify')));\nconst Tree = Loadable(lazy(() => import('./routes/components/tree')));\nconst TreeChecked = Loadable(lazy(() => import('./routes/components/tree-checked')));\nconst SearchTree = Loadable(lazy(() => import('./routes/components/search-tree')));\nconst Transfer = Loadable(lazy(() => import('./routes/components/transfer')));\nconst Tag = Loadable(lazy(() => import('./routes/components/tag')));\nconst Tabs = Loadable(lazy(() => import('./routes/components/tabs')));\nconst Tooltip = Loadable(lazy(() => import('./routes/components/tooltip')));\nconst Table = Loadable(lazy(() => import('./routes/components/table')));\nconst TimePicker = Loadable(lazy(() => import('./routes/components/time-picker')));\nconst Rate = Loadable(lazy(() => import('./routes/components/rate')));\nconst Overlay = Loadable(lazy(() => import('./routes/components/overlay')));\nconst BackTop = Loadable(lazy(() => import('./routes/components/back-top')));\nconst Portal = Loadable(lazy(() => import('./routes/components/portal')));\nconst OverlayTrigger = Loadable(lazy(() => import('./routes/components/overlay-trigger')));\nconst Popover = Loadable(lazy(() => import('./routes/components/popover')));\nconst Message = Loadable(lazy(() => import('./routes/components/message')));\nconst MonthPicker = Loadable(lazy(() => import('./routes/components/month-picker')));\nconst Textarea = Loadable(lazy(() => import('./routes/components/textarea')));\nconst Modal = Loadable(lazy(() => import('./routes/components/modal')));\nconst Formatter = Loadable(lazy(() => import('./routes/components/formatter')));\nconst Steps = Loadable(lazy(() => import('./routes/components/steps')));\nconst Menu = Loadable(lazy(() => import('./routes/components/menu')));\nconst Empty = Loadable(lazy(() => import('./routes/components/empty')));\n\nexport const routes: RouteObject[] = [\n {\n path: '/extensions',\n element: <BaseLayout siderMenu={false} />,\n children: [\n { index: true, element: <Extensions /> },\n { path: '*', element: <NoMatch /> },\n ],\n },\n {\n path: '/guide',\n element: <BaseLayout />,\n children: [\n { index: true, element: <GuideQuickStart /> },\n { path: '/guide/quick-start', element: <GuideQuickStart /> },\n { path: '/guide/import', element: <GuideImport /> },\n { path: '/guide/create-react-app', element: <GuideCreateReactApp /> },\n { path: '/guide/kkt', element: <GuideKKT /> },\n { path: '/guide/vscode', element: <GuideVscode /> },\n { path: '/guide/docs', element: <GuideDocs /> },\n { path: '/guide/recommendation', element: <GuideRecommendation /> },\n { path: '*', element: <NoMatch /> },\n ],\n },\n {\n path: '/components',\n element: <BaseLayout />,\n children: [\n { index: true, element: <Overview /> },\n { path: '/components/overview', element: <Overview /> },\n { path: '/components/colors', element: <Colors /> },\n { path: '/components/reset-css', element: <ResetCss /> },\n { path: '/components/alert', element: <Alert /> },\n { path: '/components/auto-link', element: <AutoLink /> },\n { path: '/components/avatar', element: <Avatar /> },\n { path: '/components/affix', element: <Affix /> },\n { path: '/components/calendar', element: <Calendar /> },\n { path: '/components/checkbox', element: <Checkbox /> },\n { path: '/components/copy-to-clipboard', element: <CopyToClipboard /> },\n { path: '/components/collapse', element: <Collapse /> },\n { path: '/components/card', element: <Card /> },\n { path: '/components/carousel', element: <Carousel /> },\n { path: '/components/cascader', element: <Cascader /> },\n { path: '/components/descriptions', element: <Descriptions /> },\n { path: '/components/loader', element: <Loader /> },\n { path: '/components/icon', element: <Icon /> },\n { path: '/components/divider', element: <Divider /> },\n { path: '/components/drawer', element: <Drawer /> },\n { path: '/components/date-picker', element: <DatePicker /> },\n { path: '/components/date-input', element: <DateInput /> },\n { path: '/components/dropdown', element: <Dropdown /> },\n { path: '/components/badge', element: <Badge /> },\n { path: '/components/progress', element: <Progress /> },\n { path: '/components/pagination', element: <Pagination /> },\n { path: '/components/pin-code', element: <PinCode /> },\n { path: '/components/input', element: <Input /> },\n { path: '/components/button', element: <Button /> },\n { path: '/components/radio', element: <Radio /> },\n { path: '/components/select', element: <Select /> },\n { path: '/components/search-select', element: <SearchSelect /> },\n { path: '/components/split', element: <Split /> },\n { path: '/components/switch', element: <Switch /> },\n { path: '/components/slider', element: <Slider /> },\n { path: '/components/grid', element: <Grid /> },\n { path: '/components/form', element: <Form /> },\n { path: '/components/file-input', element: <FileInput /> },\n { path: '/components/breadcrumb', element: <Breadcrumb /> },\n { path: '/components/list', element: <List /> },\n { path: '/components/layout', element: <Layout /> },\n { path: '/components/notify', element: <Notify /> },\n { path: '/components/tree', element: <Tree /> },\n { path: '/components/tree-checked', element: <TreeChecked /> },\n { path: '/components/search-tree', element: <SearchTree /> },\n { path: '/components/transfer', element: <Transfer /> },\n { path: '/components/tag', element: <Tag /> },\n { path: '/components/tabs', element: <Tabs /> },\n { path: '/components/tooltip', element: <Tooltip /> },\n { path: '/components/table', element: <Table /> },\n { path: '/components/time-picker', element: <TimePicker /> },\n { path: '/components/rate', element: <Rate /> },\n { path: '/components/overlay', element: <Overlay /> },\n { path: '/components/back-top', element: <BackTop /> },\n { path: '/components/portal', element: <Portal /> },\n { path: '/components/overlay-trigger', element: <OverlayTrigger /> },\n { path: '/components/popover', element: <Popover /> },\n { path: '/components/message', element: <Message /> },\n { path: '/components/month-picker', element: <MonthPicker /> },\n { path: '/components/textarea', element: <Textarea /> },\n { path: '/components/modal', element: <Modal /> },\n { path: '/components/formatter', element: <Formatter /> },\n { path: '/components/steps', element: <Steps /> },\n { path: '/components/menu', element: <Menu /> },\n { path: '/components/empty', element: <Empty /> },\n { path: '*', element: <NoMatch /> },\n ],\n },\n {\n path: '/',\n element: <Home />,\n },\n];\n","import React, { useReducer } from 'react';\nimport ReactDOM from 'react-dom';\nimport { useRoutes, HashRouter } from 'react-router-dom';\nimport '@uiw/reset.css';\nimport { routes } from './routers';\nimport './styles/index.less';\nimport { ThemeContext, reducer, initialState } from './contexts';\n\nconst App = () => useRoutes(routes);\nexport const Provider = ({ children }: { children: React.ReactNode }) => {\n const [state, dispatch] = useReducer(reducer, initialState);\n return <ThemeContext.Provider value={{ state, dispatch }}>{children}</ThemeContext.Provider>;\n};\n\nReactDOM.render(\n <HashRouter>\n <Provider>\n <App />\n </Provider>\n </HashRouter>,\n document.getElementById('root'),\n);\n","export function noop() {}\n","/**\n * Gets the scroll value of the given element in the given side (top and left)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @argument {String} top `true` or `false`\n * @returns {number} amount of scrolled pixels\n */\nexport function getScroll(target: HTMLElement | Window | null, top?: boolean) {\n if (typeof window === 'undefined') {\n return 0;\n }\n\n const prop = top ? 'pageYOffset' : 'pageXOffset';\n const method = top ? 'scrollTop' : 'scrollLeft';\n const isWindow: boolean = target === window;\n\n let ret = isWindow ? (target as Window)[prop] : (target as HTMLElement)[method];\n if (isWindow && typeof ret !== 'number') {\n ret = document.documentElement[method];\n }\n\n return ret;\n}\n","import { getScroll } from '@uiw/utils';\n\nexport const getTargetRect = (target: HTMLElement | Window | null) => {\n return target !== window\n ? (target as HTMLElement).getBoundingClientRect()\n : ({ top: 0, left: 0, bottom: 0 } as ClientRect);\n};\n\nexport const getOffset = (element: HTMLElement, target: HTMLElement | Window | null) => {\n const elemRect = element.getBoundingClientRect();\n const targetRect = getTargetRect(target);\n const scrollTop = getScroll(target, true);\n const scrollLeft = getScroll(target);\n\n const docElem = window.document.body;\n const clientTop = docElem.clientTop || 0;\n const clientLeft = docElem.clientLeft || 0;\n\n return {\n top: elemRect.top - targetRect.top + scrollTop - clientTop,\n left: elemRect.left - targetRect.left + scrollLeft - clientLeft,\n width: elemRect.width,\n height: elemRect.height,\n };\n};\n\nexport const getDefaultTarget = () => (typeof window !== 'undefined' ? window : null);\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport { getDefaultTarget, getOffset } from './utils';\n\nexport interface AffixProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n /**\n * 距离窗口顶部达到指定偏移量后触发\n */\n offsetTop?: number;\n /**\n * 距离窗口底部达到指定偏移量后触发\n */\n offsetBottom?: number;\n target?: () => Window | HTMLElement | null;\n /**\n * 固定状态改变时触发的回调函数\n */\n onChange?: (affixed?: boolean) => void;\n}\n\nexport interface AffixState {\n affixStyle?: React.CSSProperties;\n placeholderStyle?: React.CSSProperties;\n}\n\nexport default class Affix extends React.Component<AffixProps, AffixState> {\n public static defaultProps: AffixProps = {\n prefixCls: 'w-affix',\n onChange: noop,\n };\n public state: AffixState = {\n placeholderStyle: undefined,\n affixStyle: undefined,\n };\n private box: any;\n private target!: Window | HTMLElement | null;\n private readonly events = ['resize', 'scroll', 'touchstart', 'touchmove', 'touchend', 'pageshow', 'load'];\n private eventHandlers: Record<string, any> = {};\n private timeout?: number;\n constructor(props: AffixProps & HTMLDivProps) {\n super(props);\n this.updatePosition = this.updatePosition.bind(this);\n }\n componentDidMount() {\n const target = this.props.target || getDefaultTarget;\n // Wait for parent component ref has its value\n this.timeout = window.setTimeout(() => {\n this.target = target();\n this.setTargetEventListeners();\n });\n }\n componentWillUnmount() {\n this.clearEventListeners();\n clearTimeout(this.timeout);\n }\n updatePosition() {\n let { offsetTop } = this.props;\n const { offsetBottom } = this.props;\n if (!this.box || !this.box.offsetParent) {\n return;\n }\n\n const elemSize = {\n width: this.box.clientWidth,\n height: this.box.clientHeight,\n };\n const offsetMode = { top: true, bottom: false };\n if (typeof offsetTop !== 'number' && typeof offsetBottom !== 'number') {\n offsetMode.top = true;\n offsetTop = 0;\n }\n\n if (typeof offsetBottom === 'number') {\n offsetMode.top = false;\n offsetMode.bottom = true;\n }\n\n const elemOffset = getOffset(this.box, this.target);\n const box = this.box.getBoundingClientRect();\n const bottom = document.documentElement.clientHeight - box.y - elemOffset.height;\n\n if (offsetMode.top && box.y < 0) {\n this.setPlaceholderStyle({ ...elemSize });\n this.setAffixStyle({\n position: 'fixed',\n top: offsetTop || 0,\n left: elemOffset.left,\n width: elemOffset.width,\n });\n } else if (offsetMode.bottom && bottom < 0) {\n this.setPlaceholderStyle({ ...elemSize });\n this.setAffixStyle({\n position: 'fixed',\n bottom: offsetBottom || 0,\n left: elemOffset.left,\n width: elemOffset.width,\n });\n } else {\n this.setPlaceholderStyle();\n this.setAffixStyle();\n }\n }\n setAffixStyle(affixStyle?: React.CSSProperties) {\n const { onChange } = this.props;\n const affixed = !!this.state.affixStyle;\n this.setState({ affixStyle }, () => {\n onChange && onChange(affixed);\n });\n }\n setPlaceholderStyle(placeholderStyle?: React.CSSProperties) {\n this.setState({ placeholderStyle });\n }\n // 设置监听事件\n setTargetEventListeners() {\n this.clearEventListeners();\n this.events.forEach((eventName) => {\n this.eventHandlers[eventName] = this.updatePosition;\n this.target && this.target.addEventListener(eventName, this.updatePosition, false);\n });\n }\n clearEventListeners() {\n this.events.forEach((eventName) => {\n const handler = this.eventHandlers[eventName];\n this.target && this.target.removeEventListener(eventName, handler, false);\n });\n }\n getInstance = (node: HTMLDivElement) => {\n if (node) {\n this.box = node;\n }\n };\n public render() {\n const { prefixCls, className, children, offsetTop, offsetBottom, target, onChange, ...resetProps } = this.props;\n const cls = [className, prefixCls].filter(Boolean).join(' ').trim();\n return (\n <div {...resetProps} ref={this.getInstance} style={{ ...this.state.placeholderStyle, ...this.props.style }}>\n <div className={cls} style={this.state.affixStyle}>\n {children}\n </div>\n </div>\n );\n }\n}\n","import React, { useEffect, useRef } from 'react';\nimport ReactDOM from 'react-dom';\n\nexport const canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\nexport interface PortalProps {\n children?: React.ReactNode;\n /**\n * The HTML element that children will be mounted to.\n * @default document.body\n */\n container?: HTMLElement;\n /**\n * Callback invoked when the children of this `Portal` have been added to the DOM.\n * @deprecated v4.9.0+\n */\n onChildrenMount?: (portalElement: HTMLElement) => void;\n /** @deprecated v4.9.0+ */\n visible?: boolean;\n}\n\nexport default function Portal(props: PortalProps) {\n const { container } = props;\n const defaultNode = useRef<HTMLDivElement>();\n const containerRef = useRef<HTMLElement | undefined>(container);\n\n useEffect(() => {\n return () => {\n if (defaultNode.current && containerRef.current) {\n containerRef.current.removeChild(defaultNode.current);\n defaultNode.current = undefined;\n }\n };\n }, []);\n\n if (!canUseDOM) {\n return null;\n }\n if (!containerRef.current) {\n containerRef.current = document.body;\n }\n if (!defaultNode.current) {\n defaultNode.current = document.createElement('div');\n containerRef.current.appendChild(defaultNode.current);\n }\n return ReactDOM.createPortal(props.children, defaultNode.current);\n}\n","/**\n * Overlay 组件\n * ---------------\n * 动画库 react-transition-group 文档\n * 老的文档\n * https://facebook.github.io/react/docs/animation.html\n * 新的文档\n * https://reactcommunity.org/react-transition-group/\n * 动画效果\n * https://daneden.github.io/animate.css/\n */\nimport React, { cloneElement, useEffect, useRef, useState } from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport { TransitionProps } from 'react-transition-group/Transition';\nimport Portal, { PortalProps } from '@uiw/react-portal';\nimport { IProps, noop } from '@uiw/utils';\n\nimport './style/index.less';\n\nexport interface OverlayProps extends IProps, Omit<TransitionProps, 'timeout'> {\n timeout?: TransitionProps['timeout'];\n isOpen?: boolean;\n usePortal?: boolean;\n maskClosable?: boolean;\n dialogProps?: React.HTMLProps<HTMLElement>;\n backdropProps?: React.HTMLProps<HTMLDivElement>;\n portalProps?: PortalProps;\n hasBackdrop?: boolean;\n unmountOnExit?: boolean;\n transitionName?: string;\n onEnter?: (node: HTMLElement, isAppearing: boolean) => void;\n onOpening?: (node: HTMLElement, isAppearing: boolean) => void;\n onOpened?: (node: HTMLElement, isAppearing: boolean) => void;\n onClosing?: (node: HTMLElement) => void;\n onClosed?: (node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;\n onClose?: (evn: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n}\n\nexport default function Overlay(props: OverlayProps) {\n const {\n className,\n style,\n isOpen: _ = false,\n prefixCls = 'w-overlay',\n usePortal = true,\n maskClosable = true,\n backdropProps = {},\n portalProps = {},\n hasBackdrop = true,\n unmountOnExit = true, // 设置 true 销毁根节点\n timeout = 300,\n transitionName = 'w-overlay',\n // onEnter = noop,\n onOpening = noop,\n onOpened = noop,\n onClosing = noop,\n onClosed = noop,\n onClose = noop,\n children,\n dialogProps = {},\n ...otherProps\n } = props;\n\n const [isOpen, setIsOpen] = useState(props.isOpen || false);\n const [visible, setVisible] = useState(false);\n const container = useRef<HTMLDivElement>(null);\n const overlay = useRef<HTMLDivElement>(null);\n useEffect(() => {\n if (isOpen !== props.isOpen && props.isOpen) {\n setVisible(true);\n }\n if (isOpen !== props.isOpen && !props.isOpen) {\n overlayWillClose();\n setIsOpen(false);\n }\n }, [props.isOpen]);\n\n useEffect(() => {\n if (visible) {\n overlayWillOpen();\n setIsOpen(true);\n }\n }, [visible]);\n\n const decoratedChild =\n typeof children === 'object' ? (\n cloneElement(children, {\n ...dialogProps,\n style: { ...children.props.style, ...dialogProps.style },\n className: [children.props.className, `${prefixCls}-content`].filter(Boolean).join(' ').trim(),\n tabIndex: 0,\n })\n ) : (\n <span {...dialogProps} className={`${prefixCls}-content`}>\n {children}\n </span>\n );\n\n function handleClosed(node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>) {\n setVisible(false);\n onClosed && onClosed(node);\n }\n\n function handleBackdropMouseDown(e: React.MouseEvent<HTMLDivElement, MouseEvent>) {\n if (e.target !== container.current && usePortal) {\n return;\n }\n if (maskClosable && hasBackdrop) {\n overlayWillClose();\n setIsOpen(false);\n onClose && onClose(e);\n }\n backdropProps && backdropProps.onMouseDown && backdropProps.onMouseDown(e);\n }\n\n function overlayWillOpen() {\n if (hasBackdrop && usePortal) {\n document.body.classList.add(`${prefixCls}-open`);\n }\n }\n\n function overlayWillClose() {\n if (hasBackdrop && usePortal) {\n document.body.classList.remove(`${prefixCls}-open`);\n }\n // if (unmountOnExit) {\n // setVisible(false)\n // }\n }\n\n const TransitionGroupComp = (\n <CSSTransition\n classNames={transitionName}\n unmountOnExit={unmountOnExit}\n timeout={timeout!}\n in={isOpen}\n onEntering={onOpening}\n onEntered={onOpened}\n onExiting={onClosing}\n onExited={handleClosed}\n {...otherProps}\n >\n {(status) => {\n return (\n <div\n style={style}\n ref={overlay}\n className={[\n prefixCls,\n className,\n !usePortal ? `${prefixCls}-inline` : null,\n isOpen ? `${prefixCls}-enter-done` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {hasBackdrop &&\n cloneElement(<div />, {\n ...backdropProps,\n onMouseDown: handleBackdropMouseDown,\n className: [`${prefixCls}-backdrop`, backdropProps.className].filter(Boolean).join(' ').trim(),\n tabIndex: maskClosable ? 0 : null,\n })}\n {usePortal ? (\n <div ref={container} onMouseDown={handleBackdropMouseDown} className={`${prefixCls}-container`}>\n {cloneElement(decoratedChild, { 'data-status': status })}\n </div>\n ) : (\n cloneElement(decoratedChild, { 'data-status': status })\n )}\n </div>\n );\n }}\n </CSSTransition>\n );\n if (visible && usePortal) {\n return <Portal {...{ ...portalProps }}>{TransitionGroupComp}</Portal>;\n } else {\n return TransitionGroupComp;\n }\n}\n","import React from 'react';\nimport svgPaths from '@uiw/icons/fonts/w-icon.json';\nimport './style/index.less';\n\nexport type IconsName = keyof typeof svgPaths;\ntype TagType = React.ComponentType | keyof JSX.IntrinsicElements;\n\nexport interface IconProps<Tag extends TagType = 'span', E = React.ReactElement> extends React.HTMLAttributes<Tag> {\n style?: React.CSSProperties;\n className?: string;\n prefixCls?: string;\n /**\n * HTML tag to use for the rendered element.\n * @default \"span\"\n */\n tagName?: Tag;\n type?: IconsName | null | E;\n spin?: boolean;\n color?: string;\n verticalAlign?: 'middle' | 'baseline';\n}\n\nexport default function Icon<Tag extends TagType = 'span'>(props: IconProps<Tag>) {\n const {\n className,\n prefixCls = 'w-icon',\n verticalAlign = 'middle',\n tagName: TagName = 'span',\n color,\n type,\n spin = false,\n ...others\n } = props;\n\n let svg = null;\n if (typeof type === 'string') {\n svg = (\n <svg fill={color} viewBox=\"0 0 20 20\">\n {(svgPaths[type] || []).map((d, i) => (\n <path key={i} d={d} fillRule=\"evenodd\" />\n ))}\n </svg>\n );\n } else if (React.isValidElement(type)) {\n svg = React.cloneElement(type, {\n fill: color,\n });\n } else {\n return null;\n }\n others.style = { fill: 'currentColor', ...others.style };\n const propps = {\n ...others,\n className: [\n prefixCls,\n className,\n prefixCls && verticalAlign ? `${prefixCls}-${verticalAlign}` : null,\n spin && prefixCls ? `${prefixCls}-spin` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n };\n\n return React.createElement(TagName, { ...propps } as any, svg);\n}\n","import React from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLButtonProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport type ButtonType = 'primary' | 'success' | 'warning' | 'danger' | 'light' | 'dark' | 'link';\nexport type ButtonSize = 'large' | 'default' | 'small';\n\nexport interface ButtonProps extends IProps, Omit<HTMLButtonProps, 'size'> {\n basic?: boolean;\n disabled?: boolean;\n active?: boolean;\n loading?: boolean;\n block?: boolean;\n icon?: IconProps['type'];\n type?: ButtonType;\n size?: ButtonSize;\n htmlType?: 'button' | 'submit' | 'reset';\n onClick?: (e: React.MouseEvent<HTMLButtonElement> & MouseEvent) => void;\n}\n\nexport default React.forwardRef<HTMLButtonElement, ButtonProps>((props, ref) => {\n const {\n prefixCls = 'w-btn',\n disabled = false,\n active = false,\n loading = false,\n block = false,\n basic = false,\n htmlType = 'button',\n type = 'light',\n size = 'default',\n icon,\n className,\n children,\n ...others\n } = props;\n const cls = [\n className,\n prefixCls,\n size ? `${prefixCls}-size-${size}` : null,\n type ? `${prefixCls}-${type}` : null,\n basic ? `${prefixCls}-basic` : null,\n loading ? `${prefixCls}-loading` : null,\n disabled || loading ? 'disabled' : null,\n active ? 'active' : null,\n block ? 'block' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n return (\n <button {...others} ref={ref} type={htmlType} disabled={disabled || loading} className={cls}>\n {icon && <Icon type={icon} />}\n {children &&\n React.Children.map(children, (child: React.ReactNode) => {\n if (!child) return child;\n if (React.isValidElement(child)) return child;\n return <span>{child}</span>;\n })}\n </button>\n );\n});\n","import React, { useState, useEffect } from 'react';\nimport Overlay, { OverlayProps } from '@uiw/react-overlay';\nimport Button, { ButtonType, ButtonProps } from '@uiw/react-button';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, noop } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface ModalProps extends IProps, OverlayProps {\n type?: ButtonType;\n cancelText?: string;\n confirmButtonProps?: Omit<ButtonProps, 'ref'>;\n cancelButtonProps?: Omit<ButtonProps, 'ref'>;\n content?: React.ReactNode;\n confirmText?: string;\n title?: string;\n icon?: IconProps['type'];\n useButton?: boolean;\n usePortal?: boolean;\n autoFocus?: boolean;\n isCloseButtonShown?: boolean;\n isOpen?: boolean;\n bodyStyle?: React.CSSProperties;\n maxWidth?: number;\n minWidth?: number;\n width?: number;\n onCancel?: (evn: React.MouseEvent<HTMLButtonElement> & MouseEvent) => void;\n onConfirm?: (evn: React.MouseEvent<HTMLButtonElement> & MouseEvent) => void;\n}\n\nexport default React.forwardRef<OverlayProps, ModalProps>((props, ref) => {\n const {\n prefixCls = 'w-modal',\n className,\n children,\n useButton = true,\n usePortal = true,\n autoFocus = false,\n isOpen: _ = false,\n title,\n cancelText,\n cancelButtonProps,\n confirmButtonProps,\n content,\n confirmText = '确认',\n type = 'light',\n icon,\n maxWidth = 500,\n minWidth = 320,\n width,\n isCloseButtonShown = true,\n onCancel = noop,\n onConfirm = noop,\n bodyStyle,\n ...other\n } = props;\n const [isOpen, setIsOpen] = useState(props.isOpen);\n useEffect(() => {\n if (props.isOpen !== isOpen) {\n setIsOpen(props.isOpen);\n }\n }, [props.isOpen]);\n\n const [loading, setLoading] = useState(false);\n const cls = [prefixCls, className, type ? `${type}` : null].filter(Boolean).join(' ').trim();\n function onClose() {\n setIsOpen(false);\n }\n async function handleCancel(e: React.MouseEvent<HTMLButtonElement, MouseEvent> & MouseEvent) {\n setLoading(true);\n try {\n onCancel && (await onCancel(e));\n } catch (e) {}\n setIsOpen(false);\n setLoading(false);\n }\n async function handleConfirm(e: React.MouseEvent<HTMLButtonElement, MouseEvent> & MouseEvent) {\n setLoading(true);\n try {\n onConfirm && (await onConfirm(e));\n } catch (e) {}\n setIsOpen(false);\n setLoading(false);\n }\n return (\n <Overlay usePortal={usePortal} isOpen={isOpen} {...other} onClose={onClose} className={cls}>\n <div className={`${prefixCls}-container`}>\n <div\n className={[\n `${prefixCls}-inner`,\n title ? `${prefixCls}-shown-title` : null,\n icon ? `${prefixCls}-shown-icon` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n style={{ maxWidth, minWidth, width }}\n >\n {(title || icon) && (\n <div className={`${prefixCls}-header`}>\n {icon && <Icon type={icon} />}\n {title && <h4>{title}</h4>}\n {isCloseButtonShown && <Button basic onClick={(e) => handleCancel(e)} icon=\"close\" type=\"light\" />}\n </div>\n )}\n <div className={`${prefixCls}-body`} style={bodyStyle}>\n {children || content}\n </div>\n {useButton && (\n <div className={`${prefixCls}-footer`}>\n <Button\n autoFocus={autoFocus}\n type={type}\n loading={loading}\n disabled={loading}\n {...confirmButtonProps}\n onClick={(e) => handleConfirm(e)}\n >\n {confirmText}\n </Button>\n {cancelText && (\n <Button {...cancelButtonProps} onClick={(e) => handleCancel(e)}>\n {cancelText}\n </Button>\n )}\n </div>\n )}\n </div>\n </div>\n </Overlay>\n );\n});\n","import React from 'react';\nimport Modal, { ModalProps } from '@uiw/react-modal';\nimport { IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface AlertProps extends IProps, ModalProps {\n width?: number;\n}\n\nexport default (props: AlertProps = {}) => {\n const { prefixCls = 'w-alert', className, width = 400, ...other } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return (\n <Modal {...other} width={width} className={cls}>\n {props.children}\n </Modal>\n );\n};\n","import React, { Fragment } from 'react';\n\nconst delimiter =\n /((?:https?:\\/\\/)?(?:(?:[a-z0-9]?(?:[a-z0-9\\-]{1,61}[a-z0-9])?\\.[^\\.|\\s])+[a-z\\.]*[a-z]+|(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3})(?::\\d{1,5})*[a-z0-9.,_\\/~#&=;%+?\\-\\\\(\\\\)]*)/gi;\n\nexport type AutoLinkProps = {\n text?: string;\n} & React.AnchorHTMLAttributes<HTMLAnchorElement>;\n\nexport default (props: AutoLinkProps = {}) => {\n const { text = '', ...other } = props;\n return (\n <Fragment>\n {text.split(delimiter).map((word, idx) => {\n const match = word.match(delimiter);\n if (match && match[0]) {\n const url = match[0];\n return (\n <a {...other} key={idx} href={url.startsWith('http') ? url : `http://${url}`}>\n {url}\n </a>\n );\n }\n return <Fragment key={idx}>{word}</Fragment>;\n })}\n </Fragment>\n );\n};\n","import React from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { HTMLSpanProps, noop } from '@uiw/utils';\nimport './style/index.less';\nimport { useState } from 'react';\nimport { useEffect } from 'react';\n\nexport interface AvatarProps extends HTMLSpanProps {\n style?: React.CSSProperties;\n className?: string;\n prefixCls?: string;\n icon?: IconProps['type'];\n alt?: string;\n src?: string;\n size?: 'large' | 'default' | 'small' | 'mini';\n shape?: 'square' | 'circle';\n onError?: (event: React.SyntheticEvent<HTMLImageElement, Event>) => boolean;\n}\n\nexport default React.forwardRef<HTMLSpanElement, AvatarProps>((props, ref) => {\n const {\n prefixCls = 'w-avatar',\n shape = 'circle',\n size = 'default',\n className,\n src,\n alt,\n icon,\n onError = noop,\n ...resetProps\n } = props;\n let children = props.children;\n const [isImgExist, setIsImgExist] = useState(true);\n const cls = [\n prefixCls,\n className,\n size ? `${prefixCls}-${size}` : null,\n shape ? `${prefixCls}-${shape}` : null,\n src ? `${prefixCls}-image` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n useEffect(() => {\n setIsImgExist(true);\n }, [props.src]);\n\n if (isImgExist && src) {\n children = (\n <img\n src={src}\n alt={alt}\n onError={(evn) => {\n const errorFlag = onError ? onError(evn) : undefined;\n if (errorFlag !== false) {\n setIsImgExist(false);\n }\n }}\n />\n );\n } else if (icon && typeof icon === 'string') {\n children = <Icon type={icon} />;\n } else if (icon && React.isValidElement(icon)) {\n children = icon;\n }\n return (\n <span {...resetProps} className={cls} ref={ref}>\n {children}\n </span>\n );\n});\n","/**\n * 获取当前滚动条所在位置\n */\nexport function getScrollTop() {\n let scrollTop = 0;\n if (document && document.documentElement && document.documentElement.scrollTop) {\n scrollTop = document.documentElement.scrollTop;\n } else if (document.body) {\n scrollTop = document.body.scrollTop;\n }\n return scrollTop;\n}\n\n/**\n * TODO\n * @param {*} position 滚动到何处\n * @param {*} step 步长\n * @param {*} current 滚动条当前位置\n */\nexport function scrollToAnimate(position: number = 0, step: number = 100, current: number = 0) {\n let start = 0;\n const timer = setInterval(() => {\n if (current - start >= position) {\n start += step;\n if (current - start >= position) {\n window.scrollTo(0, current - start);\n } else {\n window.scrollTo(0, position);\n }\n } else {\n clearInterval(timer);\n }\n }, 0);\n}\n/**\n * 获取滚动条位置百分比\n */\nexport function getScrollPercent(offsetTop: number = 0) {\n let percent = 0;\n if (offsetTop < getScrollTop()) {\n percent = Math.round(\n ((getScrollTop() - offsetTop) / (document.body.scrollHeight - offsetTop - window.innerHeight)) * 100,\n );\n }\n return percent > 100 ? 100 : percent;\n}\n","import React, { useState, useEffect } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport { getScrollPercent, getScrollTop, scrollToAnimate } from './utils';\nimport './style/index.less';\n\nexport interface BackTopProps extends IProps, HTMLDivProps {\n offsetTop?: number;\n clickable?: boolean;\n content?: JSX.Element | string;\n fixed?: boolean;\n /**\n * 滚动距离多少时显示组件\n */\n showBelow?: number;\n speed?: number;\n}\n\nexport interface IBackTopState {\n percent: number;\n current: number;\n}\n\nexport default React.forwardRef<HTMLDivElement, BackTopProps>((props, ref) => {\n const {\n prefixCls = 'w-back-top',\n className,\n content,\n children,\n offsetTop = 0,\n fixed = true,\n speed = 100,\n showBelow = 1,\n clickable = true,\n ...other\n } = props;\n const topShowBelow = !fixed ? 0 : showBelow || 0;\n const [percent, setPercent] = useState(0);\n const [current, setCurrent] = useState(0);\n const visible = percent >= topShowBelow;\n const cls = [\n prefixCls,\n className,\n !fixed ? 'no-fixed' : null,\n visible ? `${prefixCls}-show` : null,\n !visible ? `${prefixCls}-hide` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n useEffect(() => {\n window && window.addEventListener('scroll', onScroll);\n return function () {\n window && window.removeEventListener('scroll', onScroll);\n };\n });\n function onScroll() {\n setPercent(getScrollPercent(offsetTop));\n setCurrent(getScrollTop());\n }\n function scrollToTop() {\n if (typeof offsetTop === 'number' && typeof speed === 'number' && typeof current === 'number') {\n scrollToAnimate(offsetTop, speed, current);\n }\n }\n return (\n <div onClick={() => clickable && scrollToTop()} className={cls} {...other} ref={ref}>\n {content}\n {typeof children !== 'function' ? children : children({ percent, current, scrollToTop: scrollToTop })}\n </div>\n );\n});\n","import React from 'react';\nimport { IProps, HTMLSpanProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface BadgeProps extends IProps, HTMLSpanProps {\n color?: string;\n dot?: boolean;\n processing?: boolean;\n max?: number;\n count?: number;\n}\n\nexport default React.forwardRef<HTMLSpanElement, BadgeProps>((props, ref) => {\n const {\n prefixCls = 'w-badge',\n className,\n style = {},\n color,\n max = 99,\n dot = false,\n processing = false,\n count,\n children,\n ...other\n } = props;\n const supProps = {\n className: [!dot ? `${prefixCls}-count` : null, dot ? 'dot' : null].filter(Boolean).join(' ').trim(),\n style: {},\n };\n const cls = [\n className,\n prefixCls,\n !children ? 'nowrap' : null,\n !children ? `${prefixCls}-status` : null,\n processing ? `${prefixCls}-processing` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const warpperProps: HTMLSpanProps = {};\n if (count || count === 0) {\n supProps.style = { backgroundColor: color, ...style };\n } else {\n warpperProps.style = style || {};\n }\n return (\n <span className={cls} {...other} {...warpperProps} ref={ref}>\n {color && <span className={`${prefixCls}-dot`} style={{ backgroundColor: color }} />}\n {children}\n {count !== 0 && !color && <sup {...supProps}>{!dot && count && max && count > max ? `${max}+` : count}</sup>}\n </span>\n );\n});\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\nimport './style/item.less';\n\ntype ElementTag<T = any> = T extends HTMLElement ? React.HTMLAttributes<T> : T;\n\nexport interface BreadcrumbItemProps<T = any> extends IProps, ElementTag {\n tagName?: T extends HTMLElement ? keyof JSX.IntrinsicElements : T;\n separator?: JSX.Element | string;\n active?: boolean;\n 'data-separator'?: JSX.Element | string;\n}\n\ntype RefElement<T = HTMLSpanElement> = T extends HTMLElement ? T : never;\n\nconst BreadcrumbItem = React.forwardRef<RefElement, BreadcrumbItemProps>((props, ref) => {\n const { prefixCls = 'w-breadcrumb', className, tagName: TagName = 'span', active, separator, ...other } = props;\n const isElm = React.isValidElement(separator);\n const cls = [\n `${prefixCls}-item`,\n className,\n active ? 'active' : null,\n !separator ? 'no-separator' : null,\n isElm ? 'no-before' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const otherProps = { className: cls, ...other };\n if (!isElm) {\n otherProps['data-separator'] = separator;\n }\n return React.createElement(\n TagName,\n {\n ...otherProps,\n ref,\n },\n <Fragment>\n {isElm && <span className={`${prefixCls}-separator`}>{separator}</span>}\n {props.children}\n </Fragment>,\n );\n});\n\nexport default BreadcrumbItem;\n","import React from 'react';\nimport { HTMLDivProps } from '@uiw/utils';\nimport Item from './Item';\nimport './style/index.less';\n\nexport interface BreadcrumbProps extends HTMLDivProps {\n style?: React.CSSProperties;\n className?: string;\n prefixCls?: string;\n separator?: JSX.Element | string;\n}\n\nconst Breadcrumb = React.forwardRef<HTMLDivElement, BreadcrumbProps>((props, ref) => {\n const { prefixCls = 'w-breadcrumb', className, separator = '/', ...other } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return (\n <div {...{ className: cls, ...other }} ref={ref}>\n {React.Children.map(props.children, (element: any) => {\n return React.cloneElement(element, Object.assign({ separator }, element.props, {}));\n })}\n </div>\n );\n});\ntype Breadcrumb = typeof Breadcrumb & {\n Item: typeof Item;\n};\n\n(Breadcrumb as Breadcrumb).Item = Item;\n\nexport default Breadcrumb as Breadcrumb;\n","import Breadcrumb from './Breadcrumb';\n\nexport * from './Item';\nexport * from './Breadcrumb';\n\nexport default Breadcrumb;\n","import React from 'react';\nimport { HTMLDivProps, IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface ButtonGroupProps extends IProps, HTMLDivProps {\n vertical?: boolean;\n}\n\nexport default React.forwardRef<HTMLDivElement, ButtonGroupProps>((props, ref) => {\n const { prefixCls = 'w-btn-group', vertical = false, children, className, ...resetProps } = props;\n\n const cls = [prefixCls, className, vertical && `${prefixCls}-vertical`].filter(Boolean).join(' ').trim();\n\n return (\n <div className={cls} {...resetProps} ref={ref}>\n {children}\n </div>\n );\n});\n","const canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\nfunction fallback(context: HTMLElement, node: HTMLElement) {\n if (node) {\n do {\n if (node === context) return true;\n } while ((node = node.parentNode as HTMLElement));\n }\n\n return false;\n}\n\nfunction isDOM(item: Node) {\n return typeof HTMLElement === 'function'\n ? item instanceof HTMLElement\n : item && typeof item === 'object' && item.nodeType === 1 && typeof item.nodeName === 'string';\n}\n\nconst contains = (() => {\n // HTML DOM and SVG DOM may have different support levels,\n // so we need to check on context instead of a document root element.\n return canUseDOM\n ? function (context: HTMLElement, node: HTMLElement) {\n if (context && context.contains && typeof context.contains === 'function' && isDOM(node)) {\n return context.contains(node);\n }\n if (context && context.compareDocumentPosition && isDOM(node)) {\n return context === node || !!(context.compareDocumentPosition(node) && 16);\n }\n return fallback(context, node);\n }\n : fallback;\n})();\n\nexport default contains;\n","export interface BordersSize extends CSSStyleDeclaration {\n [key: string]: any;\n}\n\n/*\n * Helper to detect borders of a given element\n * @method\n * @memberof Popper.Utils\n * @param {CSSStyleDeclaration} styles\n * Result of `getStyleComputedProperty` on the given element\n * @param {String} axis - `x` or `y`\n * @return {number} borders - The borders size of the given axis\n */\n\nexport default function getBordersSize(styles: BordersSize, axis: 'x' | 'y'): number {\n const sideA: string = axis === 'x' ? 'Left' : 'Top';\n const sideB: string = sideA === 'Left' ? 'Right' : 'Bottom';\n return parseFloat(styles[`border${sideA}Width`]) + parseFloat(styles[`border${sideB}Width`]);\n}\n","export default typeof window !== 'undefined' && typeof document !== 'undefined';\n","import isBrowser from './isBrowser';\n\ninterface Document {\n documentMode?: any;\n}\n\ninterface Window {\n MSInputMethodContext?: any;\n}\n\nconst isIE11 = isBrowser && !!((window as Window).MSInputMethodContext && (document as Document).documentMode);\nconst isIE10 = isBrowser && /MSIE 10/.test(navigator.userAgent);\n\n/**\n * Determines if the browser is Internet Explorer\n * @method\n * @memberof Popper.Utils\n * @param {Number} version to check\n * @returns {Boolean} isIE\n */\nexport default function isIE(version: number) {\n if (version === 11) {\n return isIE11;\n }\n if (version === 10) {\n return isIE10;\n }\n return isIE11 || isIE10;\n}\n","import isIE from './isIE';\n\ninterface BodyElement extends HTMLBodyElement {\n [key: string]: any;\n}\n\ninterface IHTMLElement extends HTMLElement {\n [key: string]: any;\n}\n\ninterface ComputedStyle extends CSSStyleDeclaration {\n [key: string]: any;\n}\n\nfunction getSize(axis: 'Height' | 'Width', body: BodyElement, html: IHTMLElement, computedStyle: ComputedStyle) {\n return Math.max(\n body[`offset${axis}`],\n body[`scroll${axis}`],\n html[`client${axis}`],\n html[`offset${axis}`],\n html[`scroll${axis}`],\n isIE(10)\n ? parseInt(html[`offset${axis}`], 10) +\n parseInt(computedStyle[`margin${axis === 'Height' ? 'Top' : 'Left'}`], 10) +\n parseInt(computedStyle[`margin${axis === 'Height' ? 'Bottom' : 'Right'}`], 10)\n : 0,\n );\n}\n\nexport type WindowSize = { height?: number; width?: number };\n\nexport default function getWindowSizes(document: HTMLDocument): WindowSize {\n const body = document.body as HTMLBodyElement;\n const html = document.documentElement as HTMLElement;\n const computedStyle = getComputedStyle(html) as CSSStyleDeclaration;\n\n return {\n height: getSize('Height', body, html, computedStyle),\n width: getSize('Width', body, html, computedStyle),\n };\n}\n","import { getScroll } from '@uiw/utils';\nimport getStyleComputedProperty from './getStyleComputedProperty';\nimport getBordersSize from './getBordersSize';\nimport getWindowSizes, { WindowSize } from './getWindowSizes';\nimport getClientRect from './getClientRect';\nimport isIE from './isIE';\n\nexport interface IBoundingClientRect {\n left: number;\n right: number;\n top: number;\n bottom: number;\n width: number;\n height: number;\n offsetLeft?: number;\n offsetTop?: number;\n}\n\n/**\n * Get bounding client rect of given element\n * @method\n * @memberof Popper.Utils\n * @param {HTMLElement} element\n * @return {Object} client rect\n */\nexport default function getBoundingClientRect(element: HTMLElement) {\n let rect = {} as IBoundingClientRect;\n\n // IE10 10 FIX: Please, don't ask, the element isn't\n // considered in DOM in some circumstances...\n // This isn't reproducible in IE10 compatibility mode of IE11\n try {\n if (isIE(10)) {\n rect = element.getBoundingClientRect();\n const scrollTop = getScroll(element, true);\n const scrollLeft = getScroll(element);\n rect.top += scrollTop;\n rect.left += scrollLeft;\n rect.bottom += scrollTop;\n rect.right += scrollLeft;\n } else {\n rect = element.getBoundingClientRect();\n }\n // eslint-disable-next-line\n } catch (e) {}\n\n const result = {\n left: rect.left,\n top: rect.top,\n width: rect.right - rect.left,\n height: rect.bottom - rect.top,\n } as IBoundingClientRect;\n\n // subtract scrollbar size from sizes\n const sizes: WindowSize = element.nodeName === 'HTML' ? getWindowSizes(element.ownerDocument!) : {};\n const width = sizes.width || element.clientWidth || result.right - result.left;\n const height = sizes.height || element.clientHeight || result.bottom - result.top;\n\n let horizScrollbar = element.offsetWidth - width;\n let vertScrollbar = element.offsetHeight - height;\n\n result.offsetLeft = element.offsetLeft || element.scrollLeft || 0;\n result.offsetTop = element.offsetTop || element.offsetTop || 0;\n\n // if an hypothetical scrollbar is detected, we must be sure it's not a `border`\n // we make this check conditional for performance reasons\n if (horizScrollbar || vertScrollbar) {\n const styles = getStyleComputedProperty(element);\n horizScrollbar -= getBordersSize(styles, 'x');\n vertScrollbar -= getBordersSize(styles, 'y');\n\n result.width -= horizScrollbar;\n result.height -= vertScrollbar;\n }\n\n return getClientRect(result) as IBoundingClientRect;\n}\n","/**\n * Given element offsets, generate an output similar to getBoundingClientRect\n * @method\n * @memberof Popper.Utils\n * @argument {Object} offsets\n * @returns {Object} ClientRect like output\n */\nexport default function getClientRect(offsets: ClientRect): ClientRect {\n return {\n ...offsets,\n right: offsets.left + offsets.width,\n bottom: offsets.top + offsets.height,\n };\n}\n","/**\n * Get CSS computed property of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Eement} element\n * @argument {String} property\n */\nexport default function getStyleComputedProperty(\n element: HTMLElement,\n property?: keyof CSSStyleDeclaration,\n): CSSStyleDeclaration | any {\n if (element.nodeType !== 1) {\n return [];\n }\n // NOTE: 1 DOM access here\n const window = element.ownerDocument!.defaultView;\n const css: CSSStyleDeclaration = (window as Window).getComputedStyle(element, null);\n return property ? css[property] : css;\n}\n","export type Sizes = {\n width: number;\n height: number;\n};\n\n/**\n * Get the outer sizes of the given element (offset size + margins)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Object} object containing width and height properties\n */\nexport default function getOuterSizes(element: HTMLElement): Sizes {\n let rect = element.getBoundingClientRect();\n // const window = element.ownerDocument.defaultView;\n // const styles = window.getComputedStyle(element);\n // const x = parseFloat(styles.marginTop || 0) + parseFloat(styles.marginBottom || 0);\n // const y = parseFloat(styles.marginLeft || 0) + parseFloat(styles.marginRight || 0);\n const result: Sizes = {\n width: element.offsetWidth || element.scrollWidth || rect.width || 0,\n height: element.offsetHeight || element.scrollHeight || rect.height || 0,\n };\n return result;\n}\n","import { getScroll } from '@uiw/utils';\nimport getBoundingClientRect, { IBoundingClientRect } from './util/getBoundingClientRect';\nimport getOuterSizes from './util/getOuterSizes';\nimport { OverlayStyl, OverlayTriggerProps, Placement } from './';\n\ntype GetStyleOptions = {\n trigger: HTMLElement | IBoundingClientRect;\n popup: HTMLElement | IBoundingClientRect;\n placement: OverlayStyl['placement'];\n usePortal: OverlayTriggerProps['usePortal'];\n autoAdjustOverflow: OverlayTriggerProps['autoAdjustOverflow'];\n};\n\nexport function getStyle(options: GetStyleOptions) {\n let { trigger: triggerDom, popup: popupDom, placement, usePortal, autoAdjustOverflow } = options || {};\n const sty = {\n left: 0,\n top: 0,\n placement,\n } as OverlayStyl;\n\n if (!triggerDom || !popupDom || !document) {\n return sty;\n }\n\n const winSizeHeight = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n const winSizeWidth = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n\n sty.placement = placement;\n const scrollTop = getScroll((triggerDom as HTMLElement).ownerDocument!.documentElement, true);\n const scrollLeft = getScroll((triggerDom as HTMLElement).ownerDocument!.documentElement);\n const trigger = {\n ...getBoundingClientRect(triggerDom as HTMLElement),\n ...getOuterSizes(triggerDom as HTMLElement),\n };\n const popup = {\n ...getBoundingClientRect(popupDom as HTMLElement),\n ...getOuterSizes(popupDom as HTMLElement),\n };\n\n const bottom = winSizeHeight - trigger.bottom;\n const right = winSizeWidth - trigger.left - trigger.width;\n\n sty.top = trigger.top + scrollTop;\n sty.left = trigger.left;\n\n if (!usePortal) {\n sty.top = trigger.offsetTop as number;\n sty.left = trigger.offsetLeft as number;\n }\n\n if (placement && /^(top)/.test(placement)) {\n sty.top -= popup.height;\n }\n if (placement && /^(right)/.test(placement)) {\n sty.left += trigger.width;\n }\n if (placement && /^(bottom)/.test(placement)) {\n sty.top += trigger.height;\n }\n if (placement && /^(left)/.test(placement)) {\n sty.left -= popup.width;\n }\n switch (sty.placement) {\n case 'bottomLeft':\n case 'topLeft':\n break;\n case 'bottom':\n // eslint-disable-next-line\n case 'top':\n sty.left = sty.left - (popup.width - trigger.width) / 2;\n break;\n case 'bottomRight':\n case 'topRight':\n sty.left = sty.left + scrollLeft + trigger.width - popup.width;\n break;\n case 'rightTop':\n case 'leftTop':\n break;\n case 'right':\n // eslint-disable-next-line\n case 'left':\n sty.top = sty.top - (popup.height - trigger.height) / 2;\n break;\n case 'rightBottom':\n case 'leftBottom':\n sty.top = sty.top - popup.height + trigger.height;\n break;\n default:\n break;\n }\n if (autoAdjustOverflow) {\n if (placement && /^(top)/.test(placement) && trigger.top < popup.height && bottom > popup.height) {\n sty.placement = placement.replace(/^top/, 'bottom') as Placement;\n sty.top = sty.top + popup.height + trigger.height;\n }\n if (placement && /^(bottom)/.test(placement) && bottom < popup.height && trigger.top > popup.height) {\n sty.placement = placement.replace(/^bottom/, 'top') as Placement;\n sty.top = sty.top - popup.height - trigger.height;\n }\n if (placement && /^(right)/.test(placement) && right < popup.width) {\n sty.placement = placement.replace(/^right/, 'left') as Placement;\n sty.left = sty.left - trigger.width - popup.width;\n }\n if (placement && /^(left)/.test(placement) && trigger.left < popup.width) {\n sty.placement = placement.replace(/^left/, 'right') as Placement;\n sty.left = sty.left + trigger.width + popup.width;\n }\n\n if (placement && /^(left|right)/.test(placement) && usePortal) {\n // Top\n if (\n (/(Top)$/.test(placement) && trigger.top < 0) ||\n (/(right|left)$/.test(placement) && trigger.top + trigger.height / 2 < popup.height / 2) ||\n (/(Bottom)$/.test(placement) && trigger.top + trigger.height < popup.height)\n ) {\n sty.top = scrollTop;\n }\n } else {\n // Top\n if (placement && /(Top)$/.test(placement) && trigger.top < 0) {\n sty.top -= trigger.top;\n }\n if (placement && /(Bottom)$/.test(placement) && trigger.bottom < popup.height) {\n // eslint-disable-next-line\n sty.top = sty.top + (popup.height - trigger.bottom);\n }\n if (placement && /(right|left)$/.test(placement) && trigger.bottom - trigger.height / 2 < popup.height / 2) {\n sty.top = sty.top + popup.height / 2 - (trigger.bottom - trigger.height / 2);\n }\n }\n // Bottom Public Part\n if (placement && /^(left|right)/.test(placement)) {\n if (/(Top)$/.test(placement) && bottom + trigger.height < popup.height) {\n sty.top = sty.top - (popup.height - bottom - trigger.height); // eslint-disable-line\n }\n if (/(right|left)$/.test(placement) && bottom + trigger.height / 2 < popup.height / 2) {\n sty.top = sty.top - (popup.height / 2 - bottom - trigger.height / 2); // eslint-disable-line\n }\n if (/(Bottom)$/.test(placement) && bottom < 0) {\n sty.top = sty.top + bottom; // eslint-disable-line\n }\n }\n\n if (placement && /^(top|bottom)/.test(placement) && usePortal) {\n // left\n if (\n (/(Left)$/.test(placement) && trigger.left < 0) ||\n (/(top|bottom)$/.test(placement) && trigger.left + trigger.width / 2 < popup.width / 2) ||\n (/(Right)$/.test(placement) && trigger.left + trigger.width < popup.width)\n ) {\n sty.left = scrollLeft;\n }\n // right\n if (/(top|bottom)$/.test(placement) && right + trigger.width / 2 < popup.width / 2) {\n sty.left = trigger.left + trigger.width + right - popup.width;\n }\n } else if (placement && /(top|bottom)$/.test(placement) && right + trigger.width / 2 < popup.width / 2) {\n sty.left = sty.left + (right + trigger.width / 2 - popup.width / 2); // eslint-disable-line\n }\n if (placement && /^(top|bottom)/.test(placement)) {\n if (/(Left)$/.test(placement) && trigger.width + right < popup.width) {\n sty.left = sty.left - (popup.width - trigger.width - right);\n }\n if (/(Right)$/.test(placement) && right < 0) {\n sty.left = sty.left + right; // eslint-disable-line\n }\n }\n }\n return sty;\n}\n","import React, { cloneElement, useEffect, useRef, useState, useImperativeHandle } from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport Overlay, { OverlayProps } from '@uiw/react-overlay';\nimport contains from './utils';\nimport { IBoundingClientRect } from './util/getBoundingClientRect';\nimport { getStyle } from './getStyle';\nimport './style/index.less';\n\nexport interface OverlayTriggerProps extends IProps, OverlayProps {\n onVisibleChange?: (isVisbale: boolean) => void;\n onEnter?: (node: HTMLElement, isAppearing: boolean) => void;\n overlay?: React.ReactNode | any;\n trigger?: 'click' | 'hover' | 'focus';\n usePortal?: boolean;\n isOpen?: boolean;\n disabled?: boolean;\n isOutside?: boolean;\n isClickOutside?: boolean;\n autoAdjustOverflow?: boolean;\n placement?: Placement;\n delay?: Delay;\n}\n\nexport interface OverlayTriggerState {\n show: boolean;\n trigger: OverlayTriggerProps['trigger'];\n overlayStyl: OverlayStyl;\n transitionName: OverlayProps['transitionName'];\n}\n\nexport type Delay =\n | number\n | {\n show?: number;\n hide?: number;\n };\n\nexport type Placement =\n | 'top'\n | 'topLeft'\n | 'topRight'\n | 'left'\n | 'leftTop'\n | 'leftBottom'\n | 'right'\n | 'rightTop'\n | 'rightBottom'\n | 'bottom'\n | 'bottomLeft'\n | 'bottomRight';\n\nexport type OverlayStyl = {\n placement: Placement;\n top: number;\n bottom: number;\n left: number;\n right: number;\n zIndex: number;\n};\n\ninterface ITriggerProps {\n onClick?: (e: MouseEvent) => void;\n onFocus?: (e: MouseEvent) => void;\n onMouseOver?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n onMouseOut?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n onMouseEnter?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n onMouseLeave?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n}\n\nconst normalizeDelay = (delay?: Delay) => (delay && typeof delay === 'object' ? delay : { show: delay, hide: delay });\n\nexport type OverlayTriggerRef = {\n hide: () => void;\n show: () => void;\n};\n\nexport default React.forwardRef<OverlayTriggerRef, OverlayTriggerProps>((props, ref) => {\n const {\n className,\n\n prefixCls = 'w-overlay-trigger',\n usePortal = true,\n isOutside = false,\n isClickOutside = true,\n disabled = false,\n isOpen: _ = false,\n trigger = 'hover',\n placement = 'top',\n\n autoAdjustOverflow,\n transitionName,\n\n children,\n overlay,\n onVisibleChange = noop,\n onEnter = noop,\n ...other\n } = props;\n\n const zIndex = useRef<number>(999);\n const triggerRef = useRef<HTMLElement>();\n const popupRef = useRef<HTMLElement>();\n const timeoutRef = useRef<number[]>([]);\n const hoverStateRef = useRef<'show' | 'hide' | null>(null);\n const [isOpen, setIsOpen] = useState(!!props.isOpen);\n const [overlayStyl, setOverlayStyl] = useState<OverlayStyl>({\n placement,\n top: 0,\n bottom: 0,\n left: 0,\n right: 0,\n zIndex: zIndex.current,\n });\n useImperativeHandle(ref, () => ({\n hide: () => hide(),\n show: () => show(),\n }));\n\n const child: any = React.Children.only(children);\n const overlayProps: OverlayProps = {\n ...other,\n placement,\n isOpen,\n dialogProps: {},\n };\n const triggerProps: ITriggerProps = {};\n\n function getChildProps() {\n if (child && React.isValidElement(child)) {\n return child.props;\n }\n return {};\n }\n\n useEffect(() => {\n if (isClickOutside) {\n document && document.addEventListener('mousedown', handleClickOutside);\n window.addEventListener('resize', handleResize);\n }\n return () => {\n document && isClickOutside && document.removeEventListener('mousedown', handleClickOutside);\n window.removeEventListener('resize', handleResize);\n };\n }, []);\n\n useEffect(() => {\n if (props.isOpen !== isOpen) {\n setIsOpen(!!props.isOpen);\n }\n }, [props.isOpen]);\n\n useEffect(() => {\n const styls = getStyle({\n placement: overlayStyl.placement || placement,\n trigger: triggerRef.current as HTMLElement | IBoundingClientRect,\n popup: popupRef.current as HTMLElement | IBoundingClientRect,\n usePortal,\n autoAdjustOverflow,\n });\n setOverlayStyl({ ...styls, zIndex: zIndex.current });\n onVisibleChange(isOpen);\n }, [isOpen]);\n\n const handleResize = () => {\n zIndex.current -= 1;\n setIsOpen(false);\n onVisibleChange && onVisibleChange(false);\n };\n\n const handleClickOutside = (e: MouseEvent) => {\n const popNode = popupRef.current;\n const childNode = triggerRef.current;\n if (\n popNode &&\n childNode &&\n e.target &&\n !contains(popNode, e.target as HTMLElement) &&\n !contains(childNode, e.target as HTMLElement)\n ) {\n zIndex.current -= 1;\n setIsOpen(false);\n onVisibleChange && onVisibleChange(false);\n }\n };\n\n function clearTimeouts() {\n if (timeoutRef.current.length > 0) {\n for (const timeoutId of timeoutRef.current) {\n window.clearTimeout(timeoutId);\n }\n timeoutRef.current = [];\n }\n }\n function handleShow() {\n clearTimeouts();\n hoverStateRef.current = 'show';\n\n const delay = normalizeDelay(props.delay);\n\n if (!delay.show) {\n show();\n return;\n }\n const handle = window.setTimeout(() => {\n if (hoverStateRef.current === 'show') show();\n }, delay.show);\n timeoutRef.current.push(handle);\n }\n\n function handleHide(isOutside: boolean) {\n clearTimeouts();\n if (!isOutside && props.isOutside) return;\n hoverStateRef.current = 'hide';\n\n const delay = normalizeDelay(props.delay);\n\n if (!delay.hide) {\n hide();\n return;\n }\n\n const handle = window.setTimeout(() => {\n if (hoverStateRef.current === 'hide') hide();\n }, delay.hide);\n\n timeoutRef.current.push(handle);\n }\n\n // Simple implementation of mouseEnter and mouseLeave.\n // React's built version is broken: https://github.com/facebook/react/issues/4251\n // for cases when the trigger is disabled and mouseOut/Over can cause flicker\n // moving from one child element to another.\n function handleMouseOverOut(handler: Function, e: React.MouseEvent, relatedNative: 'fromElement' | 'toElement') {\n const target = e.currentTarget as HTMLElement;\n const related = (e.relatedTarget || (e.nativeEvent as any)[relatedNative]) as HTMLElement;\n let isOutside = true;\n if (\n (popupRef.current && contains(popupRef.current, related)) ||\n (triggerRef.current && contains(triggerRef.current, related))\n ) {\n isOutside = false;\n }\n if ((!related || related !== target) && !contains(target, related)) {\n handler(isOutside, e);\n }\n }\n\n function hide() {\n if (!isOpen) return;\n zIndex.current -= 1;\n setIsOpen(false);\n }\n\n function show() {\n if (isOpen) return;\n zIndex.current += 1;\n setIsOpen(true);\n }\n\n function handleEnter(node: HTMLElement, isAppearing: boolean) {\n onEnter && onEnter(node, isAppearing);\n const styls = getStyle({\n placement: overlayStyl.placement || placement,\n trigger: triggerRef.current as HTMLElement | IBoundingClientRect,\n popup: popupRef.current as HTMLElement | IBoundingClientRect,\n usePortal,\n autoAdjustOverflow,\n });\n setOverlayStyl({ ...styls, zIndex: zIndex.current });\n }\n\n if (trigger === 'click' && !disabled) {\n triggerProps.onClick = (e) => {\n const { onClick } = getChildProps() as any;\n isOpen ? hide() : show();\n if (onClick) onClick(e, !isOpen);\n };\n }\n if (trigger === 'focus' && !disabled) {\n triggerProps.onFocus = () => handleShow();\n }\n\n if (trigger === 'hover' && !disabled) {\n triggerProps.onMouseOver = triggerProps.onMouseEnter = (e) => {\n handleMouseOverOut(handleShow, e, 'fromElement');\n };\n triggerProps.onMouseOut = triggerProps.onMouseLeave = (e) => {\n handleMouseOverOut(handleHide, e, 'toElement');\n };\n if (overlayProps.dialogProps) {\n overlayProps.dialogProps!.onMouseLeave = (e) => {\n handleMouseOverOut(handleHide, e, 'toElement');\n };\n }\n }\n overlayProps.style = { ...overlayProps.style, ...overlayStyl };\n return (\n <React.Fragment>\n {cloneElement(\n child,\n Object.assign({}, child.props, {\n ...triggerProps,\n ref: triggerRef,\n className: [child.props.className, disabled ? `${prefixCls}-disabled` : null]\n .filter(Boolean)\n .join(' ')\n .trim(),\n }),\n )}\n <Overlay\n {...overlayProps}\n style={{ ...overlayProps.style, ...overlayStyl }}\n onEnter={handleEnter}\n className={[prefixCls, className, overlayStyl.placement].filter(Boolean).join(' ').trim()}\n usePortal={usePortal}\n transitionName={transitionName}\n isOpen={isOpen}\n hasBackdrop={false}\n >\n {cloneElement(\n overlay,\n Object.assign({\n ...overlay.props,\n ref: popupRef,\n className: [overlay.props && overlay.props.className, placement].filter(Boolean).join(' ').trim(),\n }),\n )}\n </Overlay>\n </React.Fragment>\n );\n});\n","import React from 'react';\nimport OverlayTrigger, { OverlayTriggerProps } from '@uiw/react-overlay-trigger';\nimport './style/index.less';\n\nexport interface PopoverProps extends OverlayTriggerProps {\n content?: React.ReactNode;\n visibleArrow?: boolean;\n}\n\nexport default class Popover extends React.Component<PopoverProps> {\n public static defaultProps: PopoverProps = {\n prefixCls: 'w-popover',\n placement: 'top',\n usePortal: true,\n isOpen: false,\n visibleArrow: true,\n };\n renderArrow = () => {\n const { prefixCls } = this.props;\n return (\n <div className={`${prefixCls}-arrow`}>\n <svg viewBox=\"0 0 30 30\">\n <path\n fillOpacity=\"0.2\"\n d=\"M8.11 6.302c1.015-.936 1.887-2.922 1.887-4.297v26c0-1.378-.868-3.357-1.888-4.297L.925 17.09c-1.237-1.14-1.233-3.034 0-4.17L8.11 6.302z\"\n />\n <path\n fill=\"#fff\"\n d=\"M8.787 7.036c1.22-1.125 2.21-3.376 2.21-5.03V0v30-2.005c0-1.654-.983-3.9-2.21-5.03l-7.183-6.616c-.81-.746-.802-1.96 0-2.7l7.183-6.614z\"\n />\n </svg>\n </div>\n );\n };\n render() {\n const { prefixCls, className, content, visibleArrow, ...other } = this.props;\n const cls = [prefixCls, className, !visibleArrow ? 'no-arrow' : null].filter(Boolean).join(' ').trim();\n return (\n <OverlayTrigger\n {...other}\n overlay={\n <div className={cls}>\n {visibleArrow && this.renderArrow()}\n <div className={`${prefixCls}-inner`}>{this.props.content}</div>\n </div>\n }\n >\n {typeof this.props.children === 'object' && (this.props.children as JSX.Element).type.name !== 'Icon' ? (\n this.props.children\n ) : (\n <span style={{ display: 'block', writingMode: 'vertical-rl' }}>{this.props.children}</span>\n )}\n </OverlayTrigger>\n );\n }\n}\n","import React, { useEffect, useImperativeHandle } from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLInputProps } from '@uiw/utils';\nimport './style/input.less';\n\nexport interface InputProps extends IProps, Omit<HTMLInputProps, 'size'> {\n preIcon?: IconProps['type'];\n addonAfter?: React.ReactNode;\n size?: 'large' | 'default' | 'small';\n}\n\nexport default React.forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n const {\n prefixCls = 'w-input',\n className,\n style,\n size = 'default',\n type = 'text',\n preIcon = null,\n addonAfter,\n ...otherProps\n } = props;\n const inputRef = React.useRef<HTMLInputElement>(null);\n const addonRef = React.useRef<HTMLSpanElement>(null);\n useImperativeHandle<HTMLInputElement | null, HTMLInputElement | null>(ref, () => inputRef.current);\n const cls = [\n prefixCls,\n className,\n size ? `${prefixCls}-${size}` : null,\n addonAfter ? `${prefixCls}-addon` : null,\n props.disabled ? 'disabled' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n useEffect(() => {\n computedInputPadding();\n });\n\n function computedInputPadding() {\n if (addonRef.current && inputRef.current) {\n const input = window && window.getComputedStyle(addonRef.current, null);\n inputRef.current.style.paddingRight = `${\n addonRef.current.clientWidth + parseInt(input.right as string, 10) * 2\n }px`;\n }\n }\n return (\n <div className={cls} style={style}>\n <Icon type={preIcon} />\n <input ref={inputRef} type={type} autoComplete=\"off\" {...otherProps} className={`${prefixCls}-inner`} />\n {addonAfter && (\n <span className={`${prefixCls}-addon-after`} ref={addonRef}>\n {addonAfter}\n </span>\n )}\n </div>\n );\n});\n","import React, { useMemo, useRef } from 'react';\nimport { IProps, HTMLDivProps, HTMLLiProps } from '@uiw/utils';\nimport './style/time-picker.less';\n\nexport interface TimePickerPanelProps extends IProps, HTMLDivProps {\n onSelected?: (\n type: TimePickerPanelProps['type'],\n num: number,\n disableds: number[],\n date: TimePickerPanelProps['date'],\n ) => void;\n count?: number;\n hideDisabled?: boolean;\n disabledHours?: (\n num: number,\n type: TimePickerPanelProps['type'],\n date: TimePickerPanelProps['date'],\n ) => boolean | undefined;\n disabledMinutes?: (\n num: number,\n type: TimePickerPanelProps['type'],\n date: TimePickerPanelProps['date'],\n ) => boolean | undefined;\n disabledSeconds?: (\n num: number,\n type: TimePickerPanelProps['type'],\n date: TimePickerPanelProps['date'],\n ) => boolean | undefined;\n type?: 'Hours' | 'Minutes' | 'Seconds';\n date?: Date;\n}\n\nexport default function TimePickerPanel(props: TimePickerPanelProps) {\n const {\n prefixCls = 'w-timepicker',\n className,\n count = 24,\n date,\n type = 'Hours',\n disabledHours,\n disabledMinutes,\n disabledSeconds,\n hideDisabled,\n onSelected,\n ...other\n } = props;\n const disableds = useRef<number[]>([]);\n function getMaybeNumber() {\n if (date && type) {\n return new Date(date)[`get${type}` as 'getHours' | 'getMinutes' | 'getSeconds']();\n }\n return 0;\n }\n function handleClick(num: number, e: React.MouseEvent<HTMLLIElement>) {\n if (!date) return;\n const currentDate = new Date(date);\n currentDate[`set${type}` as 'setHours' | 'setMinutes' | 'setSeconds'](num);\n onSelected && onSelected(type, num, disableds.current, currentDate);\n }\n function getDisabledItem(num: number) {\n const disabled = props[`disabled${type}` as 'disabledHours' | 'disabledMinutes' | 'disabledSeconds'];\n if (disabled) {\n return disabled(num, type, new Date(date!));\n }\n return false;\n }\n function getItemInstance(tag: HTMLLIElement) {\n if (tag && tag.parentNode && tag.dataset['index']) {\n const offsetTop = Number(tag.dataset['index']) * tag.clientHeight;\n if (tag.parentNode.parentNode) {\n (tag.parentNode.parentNode as HTMLDivElement).scrollTop = offsetTop;\n }\n }\n }\n const data = useMemo(() => {\n return [...Array(count)]\n .map((_, idx) => {\n const disabled = getDisabledItem(idx);\n if (disabled) disableds.current.push(idx);\n return {\n count: idx,\n disabled: getDisabledItem(idx),\n };\n })\n .filter((item) => (hideDisabled && item.disabled ? false : true));\n }, [hideDisabled]);\n\n return (\n <div className={`${prefixCls}-spinner`} {...other}>\n <ul>\n {data.map((item, idx) => {\n const liProps = {} as HTMLLiProps;\n if (!item.disabled) {\n liProps.onClick = (e) => handleClick(item.count, e);\n }\n const currentCount = getMaybeNumber();\n return (\n <li\n key={idx}\n data-index={currentCount === item.count ? idx : undefined}\n ref={(tag) => tag && getItemInstance(tag)}\n {...liProps}\n className={[\n item.disabled ? 'disabled' : null,\n currentCount === item.count ? 'selected' : null,\n hideDisabled && item.disabled ? 'hide' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {item.count < 10 ? `0${item.count}` : item.count}\n </li>\n );\n })}\n </ul>\n </div>\n );\n}\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\nimport TimePanel, { TimePickerPanelProps } from './Panel';\nimport './style/time-picker.less';\n\nexport interface TimePickerTimeProps extends IProps, TimePickerPanelProps {\n precision?: Precision;\n}\n\nexport type Precision = 'hour' | 'minute' | 'second';\n\nexport function TimePickerTime(props: TimePickerTimeProps) {\n const { prefixCls = 'w-timepicker', className, precision = 'second', ...other } = props;\n return (\n <div className={[prefixCls, className].filter(Boolean).join(' ').trim()}>\n {/^(second|minute|hour)$/.test(precision as Precision) && <TimePanel type=\"Hours\" count={24} {...other} />}\n {/^(second|minute)$/.test(precision as Precision) && <TimePanel type=\"Minutes\" count={60} {...other} />}\n {/^(second)$/.test(precision as Precision) && <TimePanel type=\"Seconds\" count={60} {...other} />}\n </div>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Button from '@uiw/react-button';\nimport { IProps } from '@uiw/utils';\nimport formatter from '@uiw/formatter';\nimport { TimePickerTime, TimePickerTimeProps } from './Time';\nimport './style/index.less';\n\nexport * from './Panel';\nexport * from './Time';\n\nexport interface TimePickerProps extends IProps, Omit<InputProps, 'onChange' | 'value'> {\n value?: Date;\n format?: string;\n popoverProps?: PopoverProps;\n disabledHours?: TimePickerTimeProps['disabledHours'];\n precision?: TimePickerTimeProps['precision'];\n disabledMinutes?: TimePickerTimeProps['disabledMinutes'];\n disabledSeconds?: TimePickerTimeProps['disabledSeconds'];\n hideDisabled?: TimePickerTimeProps['hideDisabled'];\n allowClear?: boolean;\n disabled?: boolean;\n onChange?: (\n dataStr?: string,\n date?: Date | '',\n type?: TimePickerTimeProps['type'],\n num?: number,\n disableds?: number[],\n ) => void;\n}\n\nexport default function TimePicker(props: TimePickerProps) {\n const {\n prefixCls = 'w-timepicker',\n className,\n disabled,\n value,\n format = 'HH:mm:ss',\n popoverProps,\n allowClear = true,\n onChange,\n disabledHours,\n disabledMinutes,\n disabledSeconds,\n hideDisabled,\n precision,\n ...inputProps\n } = props;\n const [date, setDate] = useState(props.value);\n useEffect(() => setDate(props.value), [props.value]);\n const timeProps = {\n disabledHours,\n disabledMinutes,\n disabledSeconds,\n hideDisabled,\n precision,\n };\n const inputValue = date ? formatter(format, new Date(date)) : '';\n const datePickerTime = date || new Date();\n const _props: InputProps = { ...inputProps, value: inputValue };\n if (allowClear && inputValue !== '' && !!inputValue) {\n _props.addonAfter = (\n <Button\n className={`${prefixCls}-close-btn`}\n icon=\"close\"\n disabled={props.disabled}\n onClick={() => {\n setDate(undefined);\n onChange && onChange();\n }}\n size={props.size}\n basic\n type=\"light\"\n />\n );\n }\n return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n visibleArrow={false}\n {...popoverProps}\n content={\n <TimePickerTime\n className={`${prefixCls}-popover`}\n {...timeProps}\n date={datePickerTime}\n onSelected={(type, num, disableds, currentDate) => {\n setDate(new Date(currentDate!));\n const dataStr = currentDate ? formatter(format, currentDate) : '';\n onChange && onChange(dataStr, currentDate, type, num, disableds);\n }}\n />\n }\n >\n <Input\n placeholder=\"请选择时间\"\n readOnly\n disabled={disabled}\n {..._props}\n className={[`${prefixCls}-input`, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/day.less';\n\nfunction isValidDate(date: Date) {\n return date instanceof Date && !isNaN(date.getTime());\n}\n\nexport interface DatePickerDayDateSource {\n day?: number;\n month?: number;\n year?: number;\n}\n\nfunction classnames(obj: Record<string, boolean>) {\n return Object.keys(obj || {})\n .map((keyName) => (obj[keyName] ? keyName : null))\n .filter(Boolean)\n .join(' ')\n .trim();\n}\n\nexport interface DatePickerDayProps extends IProps, HTMLDivProps {\n weekday?: string[];\n weekTitle?: string[];\n panelDate?: Date;\n date?: Date;\n today?: Date;\n prefixCls?: string;\n onSelectDay?: (selectedDate?: Date, dateSource?: DatePickerDayDateSource) => void;\n renderDay?: (day: number, props: DatePickerDayRenderDay & DatePickerDayRenderDayProps) => React.ReactNode;\n disabledDate?: (cellDate: Date, props: DatePickerDayRenderDay & DatePickerDayRenderDayProps) => boolean;\n}\n\nexport interface PickerDayState {\n selected?: Date;\n panelDate?: Date;\n}\n\nexport type DatePickerDayRenderDay = {\n end: boolean;\n prev: boolean;\n today: boolean;\n selected: boolean;\n next: boolean;\n disabled: boolean;\n date?: Date;\n};\n\nexport type DatePickerDayRenderDayProps = {\n key?: number;\n date?: Date;\n onClick?: (cellDate: Date, event: React.MouseEvent<HTMLDivProps>) => void;\n};\n\nexport type DayRectProps = {\n col: number;\n row: number;\n index: number;\n date?: DatePickerDayProps['date'];\n today?: DatePickerDayProps['today'];\n disabledDate?: DatePickerDayProps['disabledDate'];\n renderDay?: DatePickerDayProps['renderDay'];\n panelDate?: DatePickerDayProps['panelDate'];\n onSelectDay?: DatePickerDayProps['onSelectDay'];\n};\n\nexport function DayRect(props: DayRectProps) {\n const {\n date: selectedDate,\n row,\n col,\n index,\n today,\n panelDate,\n disabledDate,\n renderDay,\n onSelectDay,\n ...other\n } = props;\n const cls: Omit<DatePickerDayRenderDay, 'date'> = {\n end: col === 0 || col === 6,\n prev: false,\n today: false,\n selected: false,\n next: false,\n disabled: false,\n };\n let date = panelDate;\n if (!date || !isValidDate(date)) date = new Date();\n const year = date.getFullYear();\n const month = date.getMonth();\n const week = useMemo(() => new Date(new Date(date!).setDate(1)).getDay(), [date.toDateString()]);\n const lastDay = useMemo(() => new Date(year, month === 0 ? 12 : month + 1, 0).getDate(), [date.toDateString()]);\n let day = index;\n if (date) {\n day = day - week + 1;\n if (day < 1) {\n cls.prev = true;\n }\n if (day > lastDay) {\n cls.next = true;\n }\n }\n let cellDate = new Date(new Date(date!).setDate(day));\n if (today && today.toDateString() === cellDate.toDateString()) {\n cls.today = true;\n }\n if (selectedDate && selectedDate.toDateString() === cellDate.toDateString()) {\n cls.selected = true;\n }\n const divProps: React.HTMLAttributes<HTMLDivElement> = {\n onClick: () => {\n const cellMonth = cellDate.getMonth();\n onSelectDay &&\n onSelectDay!(cellDate, {\n year: cellDate.getFullYear(),\n month: cellMonth === 0 ? 12 : cellMonth + 1,\n day: cellDate.getDate(),\n });\n },\n };\n if (disabledDate && disabledDate(cellDate, { ...props, ...cls })) {\n cls.disabled = true;\n delete divProps.onClick;\n }\n return (\n <div className={classnames(cls)} {...other} {...divProps}>\n {renderDay ? (\n renderDay(cellDate.getDate(), { ...props, ...cls, date: cellDate })\n ) : (\n <div>{cellDate.getDate()}</div>\n )}\n </div>\n );\n}\n\nconst WEEKTITLE = ['星期天', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];\nconst WEEKDAY = ['日', '一', '二', '三', '四', '五', '六'];\n\nexport function DatePickerDay(props: DatePickerDayProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n weekday = WEEKDAY,\n weekTitle = WEEKTITLE,\n date,\n today,\n panelDate,\n disabledDate,\n renderDay,\n onSelectDay,\n ...other\n } = props;\n\n const weekdayLabel = useMemo(\n () => (\n <div className={`${prefixCls}-weekday`}>\n {(weekday || []).map((week, idx) => (\n <div key={idx} className={classnames({ end: idx === 0 || idx === 6 })} title={weekTitle && weekTitle[idx]}>\n {week}\n </div>\n ))}\n </div>\n ),\n [prefixCls, weekday, weekTitle],\n );\n\n return (\n <div {...other} className={[prefixCls ? `${prefixCls}-body` : null, className].filter(Boolean).join(' ').trim()}>\n {weekdayLabel}\n <div className={[prefixCls ? `${prefixCls}-day-body` : null].filter(Boolean).join(' ').trim()}>\n {[...Array(6)].map((_, idx) => (\n <div key={idx} className={`${prefixCls}-week`}>\n {[...Array(7)].map((_, col) => (\n <DayRect\n date={date}\n today={today}\n disabledDate={disabledDate}\n renderDay={renderDay}\n panelDate={panelDate}\n key={col}\n col={col}\n row={idx}\n onSelectDay={(curDate, data) => {\n onSelectDay && onSelectDay(curDate, data);\n }}\n index={idx * 7 + col}\n />\n ))}\n </div>\n ))}\n </div>\n </div>\n );\n}\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport './style/year-month.less';\n\nexport interface DatePickerMonthProps extends IProps, HTMLDivProps {\n panelDate?: Date;\n onSelected?: (month: number, paging?: boolean) => void;\n monthLabel?: React.ReactNode[];\n}\n\nexport function DatePickerMonth(props: DatePickerMonthProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n panelDate = new Date(),\n monthLabel,\n onSelected = noop,\n ...other\n } = props;\n return (\n <div className={[prefixCls ? `${prefixCls}-month` : null, className].filter(Boolean).join(' ').trim()} {...other}>\n {[...Array(12)].map((_, idx) => {\n const selectedMonth = panelDate!.getMonth();\n return (\n <div key={idx} className={[selectedMonth === idx ? 'selected' : null].filter(Boolean).join(' ').trim()}>\n <span onClick={() => onSelected(idx, false)}>{(monthLabel && monthLabel[idx]) || idx}</span>\n </div>\n );\n })}\n </div>\n );\n}\n","import React, { useState } from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport './style/year-month.less';\n\nexport interface DatePickerYearProps extends IProps, HTMLDivProps {\n panelDate?: Date;\n panelNum?: number[];\n onSelected?: (year: number, paging?: boolean) => void;\n}\n\nexport function DatePickerYear(props: DatePickerYearProps) {\n const {\n prefixCls = 'w-datepicker',\n panelNum = [-7, -6, -5, -4, -3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10],\n className,\n panelDate,\n onSelected = noop,\n ...other\n } = props;\n const [activeYear, setActiveYear] = useState(props.panelDate);\n function handleSelected(year: number, idx: number) {\n if (idx === 0 || idx === panelNum!.length - 1) {\n const date = new Date(activeYear!);\n date.setFullYear(year);\n setActiveYear(date);\n onSelected!(year, true);\n } else {\n onSelected!(year);\n }\n }\n return (\n <div className={[prefixCls ? `${prefixCls}-year` : null, className].filter(Boolean).join(' ').trim()} {...other}>\n {panelNum &&\n panelNum.map((_, idx) => {\n const selectedYear = activeYear!.getFullYear();\n const year = selectedYear + panelNum[idx];\n return (\n <div\n key={idx}\n className={[\n selectedYear === year ? 'selected' : null,\n idx === 0 || idx === panelNum.length - 1 ? 'paging' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n <span onClick={() => handleSelected(year, idx)}>{year}</span>\n </div>\n );\n })}\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport './style/caption.less';\n\nfunction classnames(...arg: (string | null | undefined)[]) {\n return [...arg].filter(Boolean).join(' ').trim();\n}\n\nexport type DatePickerCaptionType = 'prev' | 'month' | 'year' | 'today' | 'next';\n\nexport interface DatePickerCaptionProps extends IProps, HTMLDivProps {\n panelDate?: Date;\n monthLabel?: React.ReactNode[];\n todayButton?: string;\n onSelected?: (captionType: DatePickerCaptionType) => void;\n}\n\nexport function DatePickerCaption(props: DatePickerCaptionProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n panelDate = new Date(),\n monthLabel,\n onSelected = noop,\n todayButton,\n ...other\n } = props;\n\n const renderMonth = useMemo(() => {\n const month = panelDate.getMonth();\n return (monthLabel && monthLabel[month]) || month + 1;\n }, [panelDate.toDateString(), monthLabel]);\n return (\n <div className={classnames(prefixCls ? `${prefixCls}-caption` : null, className)} {...other}>\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'prev')}\n onClick={() => onSelected('prev')}\n />\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'month')}\n onClick={() => onSelected('month')}\n >\n {renderMonth}\n </div>\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'year')}\n onClick={() => onSelected('year')}\n >\n {panelDate!.getFullYear()}\n </div>\n {todayButton && (\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-today` : null)}\n onClick={() => onSelected('today')}\n title={todayButton}\n />\n )}\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'next')}\n onClick={() => onSelected('next')}\n />\n </div>\n );\n}\n","import React, { useEffect, useMemo, useState } from 'react';\nimport formatter from '@uiw/formatter';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport { TimePickerTime, TimePickerPanelProps } from '@uiw/react-time-picker';\nimport { DatePickerDay, DatePickerDayProps, DatePickerDayDateSource } from './DatePickerDay';\nimport { DatePickerMonth } from './DatePickerMonth';\nimport { DatePickerYear } from './DatePickerYear';\nimport { DatePickerCaption, DatePickerCaptionType } from './DatePickerCaption';\nimport './style/index.less';\n\nexport * from './DatePickerDay';\nexport * from './DatePickerMonth';\nexport * from './DatePickerYear';\nexport * from './DatePickerCaption';\n\nconst MONTH_LABEL = [\n '一月',\n '二月',\n '三月',\n '四月',\n '五月',\n '六月',\n '七月',\n '八月',\n '九月',\n '十月',\n '十一月',\n '十二月',\n];\n\nexport interface DatePickerShowTimeProps extends TimePickerPanelProps {\n format?: string;\n}\nexport interface DatePickerProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n onChange?: (selectedDate?: Date, dateSource?: DatePickerDayDateSource) => void;\n renderDay?: DatePickerDayProps['renderDay'];\n disabledDate?: DatePickerDayProps['disabledDate'];\n showTime?: DatePickerShowTimeProps | boolean;\n monthLabel?: React.ReactNode[];\n weekday?: string[];\n weekTitle?: string[];\n date?: Date;\n panelDate?: Date;\n today?: Date;\n todayButton?: string;\n onPanelChange?: (date?: Date, mode?: 'next' | 'prev') => void;\n}\nexport interface DatePickerState {\n panelDate?: Date;\n date?: Date;\n type?: 'day' | 'time' | DatePickerCaptionType;\n}\n\nexport default function DatePicker(props: DatePickerProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n weekday,\n weekTitle,\n monthLabel = MONTH_LABEL,\n date,\n today = new Date(),\n todayButton,\n panelDate = new Date(),\n disabledDate,\n renderDay,\n onChange = noop,\n onPanelChange = noop,\n showTime,\n ...other\n } = props;\n const [type, setType] = useState<DatePickerState['type']>('day');\n const [selectDate, setSelectDate] = useState(date);\n const [selectPanelDate, setSelectPanelDate] = useState(panelDate);\n\n useEffect(() => {\n if (date) {\n setSelectDate(date);\n setSelectPanelDate(date);\n }\n }, [date]);\n\n const format = useMemo(\n () =>\n showTime && (showTime as DatePickerShowTimeProps).format\n ? (showTime as DatePickerShowTimeProps).format\n : 'HH:mm:ss',\n [showTime],\n );\n function handleSelected(curType: DatePickerState['type']) {\n if (curType && /^(year|month|time)$/.test(curType)) {\n if (type === 'time') {\n curType = 'day';\n }\n setType(curType);\n } else {\n let currentDate = new Date(selectPanelDate);\n let month = currentDate.getMonth();\n if (curType === 'prev') {\n month -= 1;\n }\n if (curType === 'next') {\n month += 1;\n }\n currentDate.setMonth(month);\n if (curType === 'prev' || curType === 'next') {\n onPanelChange && onPanelChange(new Date(currentDate), curType);\n }\n setSelectPanelDate(curType === 'today' ? today : currentDate);\n curType === 'today' && setSelectDate(today);\n\n setType('day');\n }\n }\n\n function onSelectedTime(type: TimePickerPanelProps['type'], num: number) {\n (selectPanelDate || new Date())[`set${type}` as 'setHours'](num);\n setSelectPanelDate(new Date(selectPanelDate));\n onChange && onChange(new Date(selectPanelDate));\n }\n\n function onSelectedDate(type: 'setMonth' | 'setFullYear', month: number, paging?: boolean) {\n (selectPanelDate || new Date())[type](month);\n setSelectPanelDate(new Date(selectPanelDate));\n setType('day');\n onChange && onChange(new Date(selectPanelDate));\n }\n return (\n <div className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...other}>\n <DatePickerCaption\n todayButton={todayButton}\n panelDate={selectPanelDate}\n monthLabel={monthLabel}\n onSelected={handleSelected}\n />\n {type === 'day' && (\n <DatePickerDay\n prefixCls={prefixCls}\n disabledDate={disabledDate}\n onSelectDay={(selectedDate, dateSource) => {\n setSelectPanelDate(selectedDate!);\n onChange(selectedDate, dateSource);\n }}\n renderDay={renderDay}\n date={selectDate}\n today={today || new Date()}\n panelDate={selectPanelDate}\n weekday={weekday}\n weekTitle={weekTitle}\n />\n )}\n {type === 'month' && (\n <DatePickerMonth\n panelDate={selectPanelDate}\n monthLabel={monthLabel}\n prefixCls={prefixCls}\n onSelected={(num) => onSelectedDate('setMonth', num)}\n />\n )}\n {type === 'year' && (\n <DatePickerYear\n prefixCls={prefixCls}\n panelDate={selectDate || selectPanelDate}\n onSelected={(num) => onSelectedDate('setFullYear', num)}\n />\n )}\n {type === 'time' && (\n <TimePickerTime\n date={selectPanelDate}\n {...showTime}\n className={`${prefixCls}-timepicker`}\n onSelected={onSelectedTime}\n />\n )}\n {showTime && format && (\n <div className={`${prefixCls}-time-btn`} onClick={() => handleSelected('time')}>\n {formatter(format!, selectDate || selectPanelDate)}\n </div>\n )}\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { CalendarProps } from './';\n\nexport type RenderDayProps = {\n prefixCls?: string;\n day?: number;\n data?: CalendarProps['data'];\n currentDate?: Date;\n};\n\nexport default function RenderDay(props: RenderDayProps) {\n const { prefixCls, day, data, currentDate } = props;\n\n const dayData = useMemo(\n () =>\n (data || []).filter((item) => {\n let arr: number[] = ((item.date && item.date.split('/')) || []).map((num) => Number(num));\n if (arr.length === 1) {\n return day === arr[0];\n }\n if (currentDate && arr.length === 2) {\n return currentDate.getMonth() + 1 === arr[0] && day === arr[1];\n }\n if (currentDate && arr.length === 3) {\n return currentDate.getFullYear() === arr[0] && currentDate.getMonth() + 1 === arr[1] && day === arr[2];\n }\n return false;\n }),\n [currentDate, day, data],\n );\n\n return useMemo(\n () => (\n <div className={`${prefixCls}-inner`}>\n <div className={`${prefixCls}-day`}>{day}</div>\n <div className={`${prefixCls}-panel`}>\n {dayData &&\n dayData.length > 0 &&\n dayData.map((item, idx) => {\n const { date, label, ...other } = item;\n return (\n <div key={idx} {...other}>\n {label}\n </div>\n );\n })}\n </div>\n </div>\n ),\n [dayData, day],\n );\n}\n","import React, { useEffect, useMemo, useState } from 'react';\nimport { DatePickerDay, DatePickerDayProps, DatePickerDayDateSource } from '@uiw/react-date-picker';\nimport Icon from '@uiw/react-icon';\nimport formatter from '@uiw/formatter';\nimport { IProps } from '@uiw/utils';\nimport RenderDay from './DayLabel';\nimport './style/index.less';\n\nexport interface CalendarProps extends IProps, DatePickerDayProps {\n /**\n * 设置日历面板上面的日期标题。\n */\n titleFormat?: string;\n /**\n * 点击选择日期回调\n */\n onSelectDay?: (selectDay?: Date, dateSource?: DatePickerDayDateSource) => void;\n /**\n * 日历面板默认展示哪一页\n */\n panelDate?: Date;\n /**\n * 默认高亮当天日期\n */\n today?: Date;\n /**\n * 在日历面板上面添加通知,数组中的对象可以设置 `ElementProps`,如:`style`, `onClick` 等属性。\n */\n data?: ICalendarData[];\n /**\n * 选中的日期\n */\n date?: Date;\n /**\n * `今天` 按钮的文本设置\n */\n todayLabel?: string;\n /**\n * 月份显示文本\n */\n monthLabel?: string[];\n /** 翻页触发事件 */\n onPaging?: (type: 'prev' | 'next' | 'today', month: number, panelDate?: Date) => void;\n}\n\nexport interface ICalendarData {\n label?: React.ReactNode;\n date?: string;\n [key: string]: any;\n}\n\nconst MONTH_LABEL = [\n '一月',\n '二月',\n '三月',\n '四月',\n '五月',\n '六月',\n '七月',\n '八月',\n '九月',\n '十月',\n '十一月',\n '十二月',\n];\n\nexport default function Calendar(props: CalendarProps) {\n const {\n prefixCls = 'w-calendar',\n className,\n style,\n today = new Date(),\n date,\n data,\n monthLabel = MONTH_LABEL,\n titleFormat = 'YYYY/MM',\n todayLabel = '今天',\n panelDate: _,\n onPaging,\n onSelectDay,\n ...otherProps\n } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const [panelDate, setPanelDate] = useState<Date>(props.panelDate || new Date());\n\n useEffect(() => {\n if (props.panelDate !== panelDate) {\n setPanelDate(panelDate);\n }\n }, [props.panelDate]);\n\n function handlePaging(type: 'prev' | 'next' | 'today') {\n let currentDate = new Date();\n if (type === 'today') {\n currentDate = today || new Date();\n } else {\n const month = panelDate.getMonth();\n if (panelDate && type === 'prev') {\n panelDate.setMonth(month - 1);\n }\n if (panelDate && type === 'next') {\n panelDate.setMonth(month + 1);\n }\n currentDate = panelDate;\n }\n setPanelDate(new Date(currentDate));\n onPaging && onPaging(type, currentDate!.getMonth() + 1, currentDate);\n }\n\n const titleLable = useMemo(\n () => <div className={`${prefixCls}-title`}>{formatter(titleFormat, panelDate)}</div>,\n [prefixCls, titleFormat, panelDate],\n );\n\n const btngroup = useMemo(\n () => (\n <div className={`${prefixCls}-btn-group`}>\n <Icon type=\"down\" onClick={() => handlePaging('prev')} />\n <span className={`${prefixCls}-btn`} onClick={() => handlePaging('today')}>\n {todayLabel}\n </span>\n <Icon type=\"down\" onClick={() => handlePaging('next')} />\n </div>\n ),\n [prefixCls, todayLabel],\n );\n\n return (\n <div className={cls} style={style}>\n <div className={`${prefixCls}-caption`}>\n {titleLable}\n {btngroup}\n </div>\n <DatePickerDay\n onSelectDay={(currentDate, dateSource) => {\n setPanelDate(currentDate!);\n onSelectDay && onSelectDay(currentDate, dateSource);\n }}\n renderDay={(day, propsNext) => (\n <RenderDay prefixCls={prefixCls} day={day} data={data} currentDate={propsNext.date} />\n )}\n date={date}\n today={today}\n panelDate={panelDate || new Date()}\n {...otherProps}\n />\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface CardProps extends IProps, Omit<HTMLDivProps, 'title'> {\n active?: boolean;\n bordered?: boolean;\n bodyStyle?: React.CSSProperties;\n bodyClassName?: string;\n title?: React.ReactNode;\n noHover?: boolean;\n extra?: React.ReactNode;\n footer?: React.ReactNode;\n}\n\nexport default React.forwardRef<HTMLDivElement, CardProps>((props, ref) => {\n const {\n prefixCls = 'w-card',\n className,\n title,\n extra,\n footer,\n bordered = true,\n noHover = false,\n active = false,\n bodyStyle,\n bodyClassName,\n children,\n ...resetProps\n } = props;\n const cls = useMemo(\n () =>\n [\n prefixCls,\n className,\n bordered ? `${prefixCls}-bordered` : null,\n noHover ? `${prefixCls}-no-hover` : null,\n active ? 'active' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n [prefixCls, className, bordered, noHover],\n );\n\n return (\n <div {...resetProps} className={cls} ref={ref}>\n {(title || extra) && (\n <div className={`${prefixCls}-head`}>\n {title && <div className={`${prefixCls}-head-title`}>{title}</div>}\n {extra && <div className={`${prefixCls}-extra`}>{extra}</div>}\n </div>\n )}\n {children && (\n <div className={[`${prefixCls}-body`, bodyClassName].filter(Boolean).join(' ').trim()} style={bodyStyle}>\n {children}\n </div>\n )}\n {footer && <div className={`${prefixCls}-footer`}>{footer}</div>}\n </div>\n );\n});\n","import React, { useEffect, useMemo, useRef, useState } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface CarouselProps extends IProps, HTMLDivProps {\n width?: number;\n height?: number;\n position?: number;\n palyTime?: number;\n scrollTime?: number;\n autoPlay?: boolean;\n direction?: 'horizontal' | 'vertical';\n afterChange?: (current: number) => void;\n beforeChange?: (current: number) => void;\n}\n\nexport interface CarouselRef {\n gotoSlide: (slide: number, dontAnimate?: boolean) => void;\n prevSlide: () => void;\n nextSlide: () => void;\n stopPlay: () => void;\n}\n\nfunction Carousel(props: CarouselProps, ref: React.ForwardedRef<CarouselRef>) {\n const {\n position = 0,\n direction = 'horizontal',\n width = 400,\n height = 200,\n palyTime = 2000,\n scrollTime = 200,\n autoPlay = true,\n afterChange,\n beforeChange,\n\n prefixCls = 'w-carousel',\n className,\n style,\n } = props;\n\n const cls = useMemo(() => [prefixCls, className].filter(Boolean).join(' ').trim(), [prefixCls, className]);\n\n const [currentPosition, currentPositionSet] = useState(position);\n const [transitionInner, transitionInnerSet] = useState(`${scrollTime * 0.001}s ease-in-out`);\n const positionRef = useRef(currentPosition);\n const childCount = React.Children.count(props.children) + 1;\n const stopPlay = useRef({ stop: () => {}, after: afterChange, before: beforeChange });\n\n React.useImperativeHandle(\n ref,\n () => ({\n gotoSlide,\n prevSlide: () => gotoSlide(positionRef.current - 1),\n nextSlide: () => gotoSlide(positionRef.current + 1),\n stopPlay: () => stopPlay.current.stop(),\n }),\n [ref],\n );\n\n const gotoSlide = (slidNumber: number) => {\n stopPlay.current.stop();\n const maxSlid = childCount - 1;\n let slidNumberTemp = slidNumber > maxSlid ? maxSlid : slidNumber;\n slidNumberTemp = slidNumber < 0 ? 0 : slidNumberTemp;\n positionRef.current = slidNumberTemp;\n currentPositionSet(slidNumberTemp);\n play();\n };\n\n const play = (ms: number = palyTime) => {\n if (autoPlay) {\n const time = setInterval(() => {\n stopPlay.current.after?.(positionRef.current);\n positionRef.current++;\n if (positionRef.current >= childCount) {\n positionRef.current = 0;\n }\n currentPositionSet(positionRef.current);\n stopPlay.current.before?.(positionRef.current);\n }, ms);\n stopPlay.current.stop = () => {\n clearInterval(time);\n };\n }\n };\n\n useEffect(() => {\n play();\n return () => {\n stopPlay.current.stop();\n };\n }, [autoPlay]);\n\n useEffect(() => {\n let time: NodeJS.Timeout;\n if (childCount === currentPosition + 1) {\n time = setTimeout(() => {\n stopPlay.current.before = () => {\n transitionInnerSet(`${scrollTime * 0.001}s ease-in-out`);\n stopPlay.current.before = props.beforeChange;\n };\n transitionInnerSet('none');\n gotoSlide(0);\n }, scrollTime);\n }\n return () => {\n clearTimeout(time);\n };\n }, [currentPosition]);\n\n const childrens = React.Children.map(props.children, (child) => {\n return <div style={{ width, height, ...style }}>{child}</div>;\n });\n\n const innerStyle = useMemo(() => {\n const style = { transform: '', display: '' };\n switch (direction) {\n case 'horizontal':\n style.transform = `translate3d(${-(currentPosition * width)}px, 0px, 0px)`;\n style.display = 'flex';\n break;\n case 'vertical':\n style.transform = `translate3d(0px, ${-(currentPosition * height)}px, 0px)`;\n style.display = 'block';\n break;\n default:\n break;\n }\n return style;\n }, [direction, currentPosition, width, height]);\n\n return (\n <div className={cls} style={{ width, height }}>\n <div\n className={`${cls}-content`}\n style={{ width: width * childCount, transition: transitionInner, ...innerStyle }}\n >\n {childrens}\n <div style={{ width, height, ...style }}>{childrens?.[0]}</div>\n </div>\n </div>\n );\n}\n\nexport default React.forwardRef<CarouselRef, CarouselProps>(Carousel);\n","import React from 'react';\nimport OverlayTrigger, { OverlayTriggerProps } from '@uiw/react-overlay-trigger';\nimport { IProps } from '@uiw/utils';\nimport { useMemo } from 'react';\n\nexport interface DropdownProps extends IProps, OverlayTriggerProps {\n menu?: React.ReactNode;\n}\n\nexport default function Dropdown(props: DropdownProps) {\n const { prefixCls = 'w-dropdown', placement = 'bottomLeft', className, menu, children, disabled, ...other } = props;\n\n const cls = useMemo(() => [prefixCls, className].filter(Boolean).join(' ').trim(), [prefixCls, className]);\n\n return (\n <OverlayTrigger\n isOutside\n autoAdjustOverflow\n className={cls}\n disabled={disabled}\n placement={placement}\n {...other}\n overlay={menu}\n >\n {React.cloneElement(children, Object.assign({}, children.props))}\n </OverlayTrigger>\n );\n}\n","import React, { Fragment } from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport './style/item.less';\n\nconst disabledProps = {\n href: undefined,\n onClick: undefined,\n onMouseDown: undefined,\n onMouseEnter: undefined,\n onMouseLeave: undefined,\n tabIndex: -1,\n};\n\nexport type TagType = React.ComponentType | keyof JSX.IntrinsicElements;\n\nexport interface MenuItemProps<Tag extends TagType> extends IProps, React.HTMLProps<Tag> {\n text?: React.ReactNode;\n addonAfter?: React.ReactNode;\n tagName?: Tag;\n multiline?: boolean;\n isSubMenuItem?: boolean;\n disabled?: boolean;\n active?: boolean;\n icon?: IconProps['type'];\n children?: React.ReactNode;\n}\n\nfunction Internal<Tag extends TagType = 'a'>(props: MenuItemProps<Tag>, ref: React.Ref<React.HTMLProps<Tag>>) {\n const {\n prefixCls = 'w-menu-item',\n className,\n tagName: TagName = 'a',\n children,\n disabled = false,\n multiline = false,\n icon,\n text,\n active = false,\n addonAfter,\n isSubMenuItem,\n ...htmlProps\n } = props;\n const anchorCls = [prefixCls, active ? 'active' : null, disabled ? 'w-disabled' : null, className]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const tagComp = React.createElement(\n TagName,\n {\n ...htmlProps,\n ...(disabled ? disabledProps : {}),\n className: anchorCls,\n ref,\n } as any,\n <Fragment>\n <Icon className={`${prefixCls}-icon`} type={icon} />\n <div\n className={[prefixCls && `${prefixCls}-text`, !multiline && `${prefixCls}-multiline`]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {text}\n </div>\n {addonAfter}\n </Fragment>,\n );\n if (isSubMenuItem) {\n return tagComp;\n }\n return <li> {tagComp} </li>;\n}\n\nexport const MenuItem = React.forwardRef(Internal);\n\nMenuItem.displayName = 'uiw.MenuItem';\n","import React from 'react';\nimport { IProps, HTMLLiProps } from '@uiw/utils';\n\nexport interface MenuDividerProps extends IProps, Omit<HTMLLiProps, 'title'> {\n title?: React.ReactNode;\n}\n\nexport const MenuDivider = React.forwardRef<HTMLLIElement, MenuDividerProps>((props, ref) => {\n const { prefixCls = 'w-menu-divider', className, title, ...htmlProps } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n if (!title) {\n return <li {...htmlProps} ref={ref} className={cls} />;\n }\n return (\n <li {...htmlProps} ref={ref} className={cls} data-menu=\"divider\">\n <strong>{title}</strong>\n </li>\n );\n});\n\nMenuDivider.displayName = 'uiw.MenuDivider';\n","import React, { useMemo, useState } from 'react';\nimport { CSSTransitionProps } from 'react-transition-group/CSSTransition';\nimport OverlayTrigger, { OverlayTriggerProps, OverlayTriggerRef } from '@uiw/react-overlay-trigger';\nimport Icon from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport { MenuItem, MenuItemProps, TagType } from './MenuItem';\nimport Menu, { MenuProps } from './Menu';\nimport './style/submenu.less';\n\nexport interface SubMenuProps<T extends TagType> extends IProps, MenuItemProps<T> {\n overlayProps?: OverlayTriggerProps;\n collapse?: boolean;\n disabled?: boolean;\n inlineCollapsed?: boolean;\n inlineIndent?: number;\n}\n\nfunction checkedMenuItem(node?: HTMLElement) {\n let isCheck = false;\n if (node) {\n // eslint-disable-next-line\n do {\n if (!node.dataset.menu) {\n isCheck = true;\n }\n if (node.dataset.menu && /^(subitem|divider)$/.test(node.dataset.menu)) {\n isCheck = false;\n }\n } while (!node.dataset.menu && (node = node.parentNode as HTMLElement));\n }\n return isCheck;\n}\n\nfunction IconView({ prefixCls, collapse, isOpen }: { prefixCls?: string; collapse?: boolean; isOpen: boolean }) {\n return useMemo(\n () => (\n <Icon\n type=\"caret-right\"\n className={[\n prefixCls ? `${prefixCls}-collapse-icon` : null,\n !collapse && isOpen ? 'w-open' : null,\n !collapse && !isOpen ? 'w-close' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n />\n ),\n [prefixCls, collapse, isOpen],\n );\n}\nexport const SubMenu = React.forwardRef(function <Tag extends TagType = 'a'>(\n props: SubMenuProps<Tag>,\n ref: React.Ref<HTMLLIElement>,\n) {\n const {\n prefixCls = 'w-menu-subitem',\n className,\n disabled,\n overlayProps = {},\n children,\n collapse = false,\n inlineIndent,\n inlineCollapsed,\n ...other\n } = props;\n const overlayTriggerProps = {} as OverlayTriggerProps & CSSTransitionProps;\n const menuProps: MenuProps = {\n bordered: true,\n children,\n inlineIndent,\n className: [prefixCls ? `${prefixCls}-overlay` : null].filter(Boolean).join(' ').trim(),\n };\n const popupRef = React.useRef<OverlayTriggerRef>(null);\n const [isOpen, setIsOpen] = useState(!!overlayProps.isOpen);\n useMemo(() => {\n if (collapse) setIsOpen(false);\n }, [collapse]);\n\n function onClick(e: React.MouseEvent<HTMLUListElement, MouseEvent>) {\n const target = e.currentTarget;\n const related = (e.relatedTarget || e.nativeEvent.target) as HTMLElement;\n if (target.children.length < 1) return;\n if (checkedMenuItem(related)) {\n if (popupRef.current) {\n popupRef.current!.hide();\n }\n }\n }\n function onExit(node: HTMLElement) {\n node.style.height = `${node.scrollHeight}px`;\n setIsOpen(false);\n }\n function onExiting(node: HTMLElement) {\n node.style.height = '0px';\n }\n function onEnter(node: HTMLElement) {\n node.style.height = '1px';\n setIsOpen(true);\n }\n function onEntering(node: HTMLElement) {\n node.style.height = `${node.scrollHeight}px`;\n }\n function onEntered(node: HTMLElement) {\n node.style.height = 'initial';\n }\n\n if (!collapse) {\n delete menuProps.onClick;\n menuProps.bordered = false;\n overlayTriggerProps.className = `${prefixCls}-collapse`;\n overlayTriggerProps.appear = false;\n overlayTriggerProps.isOutside = true;\n overlayTriggerProps.isClickOutside = false;\n overlayTriggerProps.unmountOnExit = false;\n overlayTriggerProps.trigger = 'click';\n overlayTriggerProps.transitionName = `${prefixCls}`;\n overlayTriggerProps.onExit = onExit;\n overlayTriggerProps.onExiting = onExiting;\n overlayTriggerProps.onEnter = onEnter;\n overlayTriggerProps.onEntered = onEntered;\n overlayTriggerProps.onEntering = onEntering;\n } else {\n overlayTriggerProps.className = `${prefixCls}-popup`;\n overlayTriggerProps.trigger = 'hover';\n overlayTriggerProps.usePortal = true;\n menuProps.onClick = onClick;\n }\n return (\n <li data-menu=\"subitem\" ref={ref}>\n <OverlayTrigger\n placement=\"rightTop\"\n autoAdjustOverflow\n disabled={disabled}\n isOpen={isOpen}\n usePortal={false}\n isOutside\n {...overlayTriggerProps}\n {...overlayProps}\n ref={popupRef}\n overlay={<Menu {...menuProps} style={!collapse ? { paddingLeft: inlineIndent } : {}} />}\n >\n <MenuItem\n {...other}\n ref={null}\n disabled={disabled}\n isSubMenuItem\n addonAfter={<IconView collapse={collapse} prefixCls={prefixCls} isOpen={isOpen} />}\n className={[\n prefixCls ? `${prefixCls}-title` : null,\n !collapse ? `${prefixCls}-collapse-title` : null,\n className,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n />\n </OverlayTrigger>\n </li>\n );\n});\n\nSubMenu.displayName = 'uiw.SubMenu';\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport { MenuItem } from './MenuItem';\nimport { MenuDivider } from './Divider';\nimport { SubMenu } from './SubMenu';\nimport './style/menu.less';\n\nexport interface MenuProps extends IProps, HTMLUlProps {\n /** 主题颜色 */\n theme?: 'light' | 'dark';\n /**\n * 垂直是否收起菜单\n * Default: `false`\n */\n inlineCollapsed?: boolean;\n /**\n * 菜单缩进宽度 Default: `10`\n */\n inlineIndent?: number;\n bordered?: boolean;\n}\n\nconst Menu = React.forwardRef<HTMLUListElement, MenuProps>((props, ref) => {\n const {\n prefixCls = 'w-menu',\n className,\n children,\n bordered,\n theme = 'light',\n inlineIndent = 10,\n inlineCollapsed,\n ...htmlProps\n } = props;\n const cls = useMemo(\n () =>\n [\n prefixCls,\n bordered ? 'w-bordered' : null,\n inlineCollapsed ? `${prefixCls}-inline-collapsed` : null,\n theme ? `${prefixCls}-${theme}` : null,\n className,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n [prefixCls, bordered, inlineCollapsed, theme, className],\n );\n\n return (\n <ul {...htmlProps} ref={ref} className={cls} data-menu=\"menu\">\n {React.Children.map(children, (child: React.ReactNode, key) => {\n if (!React.isValidElement(child)) return child;\n const props: { inlineIndent?: number; inlineCollapsed?: boolean } = {};\n // Sub Menu\n if (child.props.children && child.type === (SubMenu as any)) {\n props.inlineIndent = inlineIndent;\n }\n return React.cloneElement(child, Object.assign({ ...props }, child.props, { key: `${key}` }));\n })}\n </ul>\n );\n});\n\nMenu.displayName = 'uiw.Menu';\n\ntype Menu = typeof Menu & {\n Item: typeof MenuItem;\n SubMenu: typeof SubMenu;\n Divider: typeof MenuDivider;\n};\n\n(Menu as Menu).Item = MenuItem;\n(Menu as Menu).SubMenu = SubMenu;\n(Menu as Menu).Divider = MenuDivider;\n\nexport default Menu as Menu;\n","import Menu from './Menu';\n\nexport * from './Menu';\nexport * from './MenuItem';\nexport * from './SubMenu';\nexport * from './Divider';\n\nexport default Menu;\n","import React, { useState, useEffect, useMemo } from 'react';\nimport Input from '@uiw/react-input';\nimport { IProps } from '@uiw/utils';\nimport Dropdown, { DropdownProps } from '@uiw/react-dropdown';\nimport Menu from '@uiw/react-menu';\nimport Icon from '@uiw/react-icon';\nimport './style/index.less';\n\ntype ValueType = Array<string | number>;\ntype OptionType = { value: string | number; label: React.ReactNode; children?: Array<OptionType> };\ntype SearchOptionType = { label: string; options: Array<OptionType> };\n\nexport interface CascaderProps extends IProps, DropdownProps {\n option?: Array<OptionType>;\n value?: ValueType;\n onChange?: (isSeleted: boolean, value: ValueType, selectedOptions: Array<OptionType>) => void;\n onSearch?: boolean | ((searchText: string) => void);\n allowClear?: boolean;\n placeholder?: string;\n disabled?: boolean;\n}\n\nfunction Cascader(props: CascaderProps) {\n const {\n value,\n onChange,\n onSearch,\n\n disabled,\n allowClear,\n placeholder,\n prefixCls = 'w-cascader',\n className,\n style = { width: 200 },\n option = [],\n others,\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const [innerIsOpen, setInnerIsOpen] = useState(false);\n const [selectedValue, setSelectedValue] = useState<Array<OptionType>>([]);\n const [selectIconType, setSelectIconType] = useState('');\n const [searchText, setSearchText] = useState<string>('');\n const [searchOn, setSearchOn] = useState(false);\n const [inputValue, setInputValue] = useState('');\n const [searchOption, setSearchOption] = useState<Array<SearchOptionType>>();\n\n useEffect(() => {\n if (onSearch) {\n const tempOptions: Array<SearchOptionType> = [];\n iteratorOption(option, (opt) => {\n const label = opt.map((m) => m.label).join(' / ');\n tempOptions.push({ label, options: opt });\n });\n setSearchOption(tempOptions);\n }\n }, [onSearch]);\n\n const iteratorOption = (\n options: Array<OptionType>,\n cb: (opt: Array<OptionType>) => void,\n opts: Array<OptionType> = [],\n ) => {\n options.map((opt) => {\n const optsTemp = [...opts, opt];\n if (opt.children) {\n iteratorOption(opt.children, cb, optsTemp);\n } else {\n cb?.(optsTemp);\n }\n });\n };\n\n useEffect(() => {\n if (value) {\n const valueTemp: Array<OptionType> = [];\n let optChildren = option;\n value?.map((item) => {\n const findOpt = optChildren.find((opt) => opt.value === item);\n optChildren = findOpt?.children || [];\n valueTemp.push({ label: item, value: item, ...findOpt });\n });\n setSelectedValue(valueTemp);\n }\n }, [value]);\n\n function onVisibleChange(isOpen: boolean) {\n setInnerIsOpen(isOpen);\n }\n\n function renderSelectIcon(type: string) {\n let selectIconType;\n if (type === 'enter' && allowClear && selectedValue.length > 0) {\n selectIconType = 'close';\n } else {\n selectIconType = '';\n }\n setSelectIconType(selectIconType);\n }\n\n const searchItemClick = (options: Array<OptionType>) => {\n setSearchText('');\n setInnerIsOpen(false);\n handelChange(false, options);\n };\n\n const handleItemClick = (optionsItem: OptionType, level: number) => {\n selectedValue.splice(level, selectedValue.length - level, optionsItem);\n\n handelChange(true, selectedValue);\n };\n\n const handelChange = (isSeleted: boolean, selectedValue: Array<OptionType>) => {\n setSelectedValue([...selectedValue]);\n const value = selectedValue.map((item) => item.value);\n onChange?.(isSeleted, value, selectedValue);\n };\n\n const onClear = (e: React.MouseEvent<any, MouseEvent>) => {\n e.stopPropagation();\n handelChange(false, []);\n };\n\n const handelSearch = (searchText: string) => {\n setSearchText(searchText);\n };\n\n const inputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!innerIsOpen) {\n setInnerIsOpen(!innerIsOpen);\n }\n const value = e.target.value;\n onSearch && handelSearch(value);\n };\n\n const widths = (style?.width as number) * 0.7 || undefined;\n\n const OptionIter = (option: Array<OptionType>, level: number = 0) => {\n if (!option) return;\n\n return (\n <Menu\n key={level}\n bordered\n style={{\n minHeight: 25,\n minWidth: widths,\n overflowY: 'scroll',\n width: widths,\n }}\n >\n {!option || option.length === 0 ? (\n <div style={{ color: '#c7c7c7', fontSize: 12 }}>{'没有数据'}</div>\n ) : (\n option.map((opt, index) => {\n const active = selectedValue[level]?.value === opt.value;\n return (\n <Menu.Item\n active={active}\n key={index}\n text={opt.label}\n addonAfter={opt.children ? <Icon type=\"right\" /> : undefined}\n onClick={() => handleItemClick(opt, level)}\n />\n );\n })\n )}\n </Menu>\n ) as JSX.Element;\n };\n\n useEffect(() => {\n const inputValue = selectedValue.map((opt) => opt.label).join(' / ');\n setInputValue(inputValue);\n }, [selectedValue]);\n\n return (\n <Dropdown\n className={cls}\n trigger=\"click\"\n style={{ marginTop: 5, ...style }}\n overlayStyl={{ width: 100 }}\n disabled={disabled}\n {...others}\n onVisibleChange={onVisibleChange}\n isOpen={innerIsOpen}\n menu={\n !searchText ? (\n <div style={{ display: 'flex' }}>\n {new Array(selectedValue.length + 1)\n .fill(0)\n .map((_, index) => {\n const options = index ? selectedValue[index - 1]?.children! : option;\n return OptionIter(options, index);\n })\n .filter((m) => !!m)}\n </div>\n ) : (\n <Menu\n bordered\n style={{\n minHeight: 25,\n minWidth: style?.width,\n overflowY: 'scroll',\n width: style?.width,\n }}\n >\n {!searchOption || searchOption.length === 0 ? (\n <div style={{ color: '#c7c7c7', fontSize: 12 }}>{'没有数据'}</div>\n ) : (\n searchOption\n .filter((opt) => opt.label.includes(searchText.trim()))\n .map((opt, index) => {\n return (\n <Menu.Item\n key={index}\n text={opt.label}\n onClick={() => searchItemClick(opt.options)} //\n />\n );\n })\n )}\n </Menu>\n )\n }\n >\n <span onMouseLeave={() => renderSelectIcon('leave')} onMouseOver={() => renderSelectIcon('enter')}>\n <Input\n value={searchOn ? searchText : inputValue}\n onChange={inputChange}\n disabled={disabled}\n placeholder={searchOn ? inputValue : placeholder}\n style={{ width: style?.width }}\n onFocus={() => onSearch && setSearchOn(true)}\n onBlur={() => onSearch && setSearchOn(false)}\n readOnly={!onSearch}\n addonAfter={\n <span style={{ width: 'auto' }}>\n {!disabled && selectIconType === 'close' && (\n <Icon type={selectIconType} onClick={onClear} className={`${prefixCls}-close`} />\n )}\n </span>\n }\n />\n </span>\n </Dropdown>\n );\n}\n\nexport default Cascader;\n","import React, { useState, useMemo } from 'react';\nimport { IProps, HTMLInputProps } from '@uiw/utils';\n\n/**\n * Constructs a type by picking all properties from `HTMLInputProps` and then removing `size`.\n * Omit: https://www.typescriptlang.org/docs/handbook/utility-types.html#omittk\n */\nexport interface RadioAbstractProps extends IProps, Omit<HTMLInputProps, 'size'> {\n size?: 'large' | 'default' | 'small';\n checked?: boolean;\n disabled?: boolean;\n onChange?: (even: React.ChangeEvent<HTMLInputElement>) => void;\n}\n\nexport const RadioAbstract = React.forwardRef<HTMLInputElement, RadioAbstractProps>((props, ref) => {\n const {\n prefixCls = 'w-radio',\n type = 'radio',\n disabled = false,\n value = '',\n className,\n style,\n children,\n size,\n checked: prChecked = false,\n onChange,\n ...other\n } = props;\n\n const [checked, setChecked] = useState(prChecked);\n const [prevChecked, setPrevChecked] = useState<boolean>();\n if (prChecked !== prevChecked) {\n setPrevChecked(prChecked);\n }\n useMemo(() => {\n if (prChecked !== prevChecked) {\n setChecked(prChecked);\n }\n }, [prevChecked]);\n\n const cls = [prefixCls, className, disabled ? 'disabled' : null, size ? `${prefixCls}-${size}` : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n useMemo(() => {\n if (checked !== props.checked) {\n setChecked(!!props.checked);\n }\n }, [props.checked]);\n\n function handleChange(e: React.ChangeEvent<HTMLInputElement>) {\n e.persist();\n setChecked(e.target.checked);\n onChange && onChange(e);\n }\n\n const label = children || value;\n return (\n <label {...{ className: cls, style }}>\n <input {...{ ...other, type, disabled, value }} checked={checked} onChange={handleChange} ref={ref} />\n {label && <div className={`${prefixCls}-text`}>{label}</div>}\n </label>\n );\n});\n","import React from 'react';\nimport { RadioAbstract, RadioAbstractProps } from './RadioAbstract';\nimport './style/index.less';\n\nexport interface RadioProps extends RadioAbstractProps {}\n\nexport default React.forwardRef<HTMLInputElement, RadioProps>((props, ref) => {\n return <RadioAbstract ref={ref} {...props} />;\n});\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport { RadioProps } from './Radio';\nimport './style/group.less';\n\nexport interface RadioGroupProps extends IProps, HTMLDivProps {\n name?: RadioProps['name'];\n value?: RadioProps['value'];\n onChange?: RadioProps['onChange'];\n}\n\nexport default React.forwardRef<HTMLDivElement, RadioGroupProps>((props, ref) => {\n const { prefixCls = 'w-radio-group', className, name, value, onChange, children, ...other } = props;\n return (\n <div {...other} ref={ref} className={[prefixCls, className].filter(Boolean).join(' ').trim()}>\n {React.Children.toArray(children).map((child) => {\n if (!child) return;\n if (!React.isValidElement(child)) return child;\n return React.cloneElement(child, {\n ...(child.props || {}),\n ...{\n checked: child.props.value === value,\n name,\n onChange,\n },\n });\n })}\n </div>\n );\n});\n","import React, { useMemo, useRef } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/group.less';\n\nexport type Value = string | number;\nexport interface CheckboxGroupPorps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n value?: Value[];\n name?: string;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>, values: Value[]) => void;\n}\n\nexport const CheckboxGroup = React.forwardRef<HTMLDivElement, CheckboxGroupPorps>((props, ref) => {\n const { prefixCls = 'w-checkbox-group', className, name, value, onChange, ...other } = props;\n const valueRef = useRef<Value[]>([]);\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const childs = React.Children.toArray(props.children);\n useMemo(() => (valueRef.current = value || []), [value]);\n return (\n <div {...other} className={cls} ref={ref}>\n {React.Children.map(childs, (element: React.ReactNode) => {\n if (!React.isValidElement(element)) return;\n if (\n Array.isArray(value) &&\n element &&\n element.props &&\n element.props.value &&\n value.includes(element.props.value)\n ) {\n if (!valueRef.current.includes(element.props.value)) {\n valueRef.current.push(element.props.value);\n }\n }\n return React.cloneElement(\n element,\n Object.assign({}, element.props, {\n name,\n checked: valueRef.current.includes(element.props.value),\n onChange: (e: React.ChangeEvent<HTMLInputElement>) => {\n if (e.target.type && e.target.type !== 'checkbox') return;\n const checked = e.target.checked;\n const include = valueRef.current.includes(element.props.value);\n if (!include && checked) {\n valueRef.current.push(element.props.value);\n } else if (include && !checked) {\n valueRef.current = valueRef.current.filter((val) => val !== element.props.value);\n }\n onChange && onChange(e, valueRef.current);\n },\n }),\n );\n })}\n </div>\n );\n});\n","import React from 'react';\nimport { RadioAbstract, RadioAbstractProps } from '@uiw/react-radio';\nimport { CheckboxGroup } from './Group';\nimport './style/index.less';\n\nexport interface CheckboxProps extends RadioAbstractProps {\n indeterminate?: boolean;\n}\n\nfunction InternalCheckbox(props: CheckboxProps, ref: React.ForwardedRef<HTMLInputElement>) {\n const {\n className,\n prefixCls = 'w-checkbox',\n type = 'checkbox',\n indeterminate = false,\n disabled = false,\n value = '',\n ...other\n } = props;\n\n const cls = [className, indeterminate && 'indeterminate'].filter(Boolean).join(' ').trim();\n return (\n <RadioAbstract\n ref={ref}\n {...other}\n type={type}\n prefixCls={prefixCls}\n disabled={disabled}\n value={value}\n className={cls}\n />\n );\n}\n\nconst Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(InternalCheckbox);\ntype Checkbox = typeof Checkbox & {\n Group: typeof CheckboxGroup;\n};\n\n(Checkbox as Checkbox).Group = CheckboxGroup;\n\nexport default Checkbox as Checkbox;\n","import Checkbox from './Checkbox';\n\nexport * from './Checkbox';\nexport * from './Group';\nexport default Checkbox;\n","import React, { useState, useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Panel from './Panel';\nimport './style/index.less';\n\nexport interface CollapseProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n accordion?: boolean;\n activeKey?: string | string[];\n bordered?: boolean;\n showArrow?: boolean;\n onChange?: (activeKey: string[]) => void;\n}\n\nexport interface CollapseState {\n activeKey: string[];\n}\n\nfunction toArray(activeKey: CollapseProps['activeKey']) {\n let currentActiveKey = activeKey;\n if (!Array.isArray(currentActiveKey)) {\n currentActiveKey = currentActiveKey ? [currentActiveKey] : [];\n }\n return currentActiveKey;\n}\n\nfunction InternalCollapse(props: CollapseProps, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-collapse',\n className,\n children,\n accordion = false,\n bordered,\n showArrow = true,\n activeKey: propsActiveKey,\n onChange,\n ...resetProps\n } = props;\n const [activeKey, setActiveKey] = useState(toArray(propsActiveKey));\n const cls = [prefixCls, className, bordered ? 'w-noborder' : null].filter(Boolean).join(' ').trim();\n function onItemClick(key: string) {\n let keys = activeKey;\n if (accordion) {\n keys = keys[0] === key ? [] : [key];\n } else {\n keys = [...keys];\n const index = keys.indexOf(key);\n const isActive = index > -1;\n if (isActive) {\n keys.splice(index, 1);\n } else {\n keys.push(key);\n }\n }\n setActiveKey(keys);\n }\n useMemo(() => {\n if (propsActiveKey !== activeKey) {\n setActiveKey(toArray(propsActiveKey));\n }\n }, [propsActiveKey]);\n useMemo(() => {\n if (propsActiveKey !== activeKey) {\n onChange && onChange(activeKey);\n }\n }, [activeKey, propsActiveKey]);\n return (\n <div className={cls} {...resetProps} ref={ref}>\n {React.Children.map(children, (child: any, index) => {\n // 如果没有密钥提供,请使用面板顺序作为默认密钥\n const key = child.key || String(index);\n const { disabled } = child.props;\n let isActive = false;\n if (accordion) {\n // 手风琴模式下默认选择第一个\n isActive = activeKey[0] === key;\n } else {\n isActive = activeKey.indexOf(key) > -1;\n }\n const childProps = {\n prefixCls,\n isActive,\n disabled,\n showArrow,\n onItemClick: disabled ? () => {} : () => onItemClick(key),\n ...child.props,\n };\n return React.cloneElement(child, childProps);\n })}\n </div>\n );\n}\n\nconst Collapse = React.forwardRef<HTMLDivElement, CollapseProps>(InternalCollapse);\ntype Collapse = typeof Collapse & {\n Panel: typeof Panel;\n};\n\n(Collapse as Collapse).Panel = Panel;\n\nexport default Collapse as Collapse;\n","import React from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport { TransitionStatus } from 'react-transition-group/Transition';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Icon, { IconProps } from '@uiw/react-icon';\n\nexport interface CollapsePanelProps extends IProps, HTMLDivProps {\n disabled?: boolean;\n showArrow?: boolean;\n isActive?: boolean;\n header?: React.ReactNode;\n icon?: IconProps['type'];\n extra?: React.ReactNode;\n onItemClick?: (evn: React.MouseEvent<HTMLDivElement>) => void;\n}\n\nexport default function Panel(props: CollapsePanelProps) {\n const {\n prefixCls = 'w-collapse',\n className,\n icon = 'down',\n children,\n isActive,\n onItemClick,\n disabled = false,\n showArrow,\n header,\n extra,\n ...resetProps\n } = props;\n const cls = [\n prefixCls ? `${prefixCls}-item` : null,\n className,\n isActive ? `${prefixCls}-active` : null,\n disabled ? `${prefixCls}-disabled` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const iconRender = typeof icon === 'string' ? <Icon type={icon} /> : icon;\n\n const childStyle = (child: React.ReactElement) => {\n return Object.assign({}, child && child.props ? child.props.style : {}, {\n transitionDuration: '300ms',\n });\n };\n function getInstance(status: TransitionStatus, instance: any) {\n if (!instance) {\n return;\n }\n if (status === 'exited' || status === 'exiting') {\n instance.style.height = '1px';\n }\n if (status === 'entered' || status === 'entering') {\n instance.style.height = `${instance.scrollHeight}px`;\n }\n }\n return (\n <div className={cls} {...resetProps}>\n <div className={`${prefixCls}-header`} onClick={onItemClick}>\n {showArrow && iconRender}\n <span className={`${prefixCls}-title`}>{header}</span>\n {extra && <div className={`${prefixCls}-extra`}>{extra}</div>}\n </div>\n <CSSTransition in={isActive} unmountOnExit={false} timeout={300} classNames={`${prefixCls}-panel`}>\n {(status: TransitionStatus) =>\n React.cloneElement(<div>{children}</div>, {\n className: `${prefixCls}-panel`,\n style: childStyle(children as React.ReactElement),\n ref: (e: any) => getInstance(status, e),\n })\n }\n </CSSTransition>\n </div>\n );\n}\n","import Collapse from './Collapse';\n\nexport * from './Collapse';\nexport * from './Panel';\n\nexport default Collapse;\n","import React from 'react';\nimport copy from '@uiw/copy-to-clipboard';\nimport { IProps, HTMLSpanProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface CopyToClipboardProps extends IProps, Omit<HTMLSpanProps, 'onClick'> {\n text?: string;\n onClick?: (text: string, isCopy: boolean, event: React.MouseEvent<HTMLElement>) => void;\n}\n\nexport default function CopyToClipboard<T>(props: CopyToClipboardProps & T) {\n const {\n prefixCls = 'w-copy-to-clipboard',\n className,\n text = '',\n children,\n onClick = () => null,\n ...resetProps\n } = props;\n function handleClick(e: React.MouseEvent<HTMLElement>) {\n if (!text) {\n return onClick('', false, e);\n }\n copy(text, (isCopy: boolean) => {\n onClick(text, isCopy, e);\n });\n }\n const otherProps = {\n ...resetProps,\n className: [prefixCls, className].filter(Boolean).join(' ').trim(),\n onClick: handleClick,\n };\n return (\n <span {...otherProps}>\n <span className={`${prefixCls}-select`}>{text}</span>\n {children}\n </span>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport DatePicker, { DatePickerProps } from '@uiw/react-date-picker';\nimport Icon from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport formatter from '@uiw/formatter';\nimport './style/date-input-range.less';\n\nexport interface DateInputRangeProps<V> extends IProps, Omit<InputProps, 'onChange' | 'value'> {\n popoverProps?: PopoverProps;\n datePickerProps?: DatePickerProps;\n value?: Array<V>;\n format?: string;\n allowClear?: boolean;\n bodyStyle?: object;\n onChange?: (selectedDate?: Date, dateRange?: Array<Date | undefined>) => void;\n}\n\nexport function DateInputRange<V extends string | Date>(props: DateInputRangeProps<V>) {\n const {\n prefixCls = 'w-dateinputrange',\n bodyStyle = undefined,\n className,\n popoverProps,\n datePickerProps,\n allowClear = true,\n format = 'YYYY/MM/DD',\n onChange,\n value,\n ...inputProps\n } = props;\n\n const [dateRange, setDateRange] = useState<Array<Date | undefined>>([]);\n useEffect(() => {\n let valueTemp: Array<Date> = [];\n const propsValue = value;\n if (Array.isArray(propsValue) && !!propsValue?.length) {\n propsValue.forEach((date, index) => {\n valueTemp[index] = typeof propsValue[index] === 'string' ? new Date(date) : (date as Date);\n });\n }\n setDateRange(valueTemp);\n }, [JSON.stringify(value)]);\n\n function handleChange(cdate: Date | undefined, idx?: number) {\n const changeValue = [...dateRange];\n changeValue[idx!] = cdate;\n setDateRange(changeValue);\n onChange && onChange(cdate, changeValue);\n }\n\n return (\n <div\n className={[`${prefixCls}-contents`, `${prefixCls}-inner`].filter(Boolean).join(' ').trim()}\n style={{ width: 300, ...bodyStyle }}\n >\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n {...popoverProps}\n content={\n <DatePicker\n date={dateRange[0]}\n className={`${prefixCls}-popover`}\n {...datePickerProps}\n onChange={(selectedDate) => handleChange(selectedDate, 0)}\n />\n }\n >\n <Input\n placeholder=\"请选择日期\"\n readOnly\n {...(inputProps as InputProps)}\n // onChange={(v) => console.log('v', v)}\n value={dateRange[0] ? formatter(format, dateRange[0]) : ''}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n\n <Icon type=\"swap-right\" verticalAlign=\"baseline\" style={{ fontSize: 21, top: -1, margin: '0px 8px 0px 5px' }} />\n\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n {...popoverProps}\n content={\n <DatePicker\n date={dateRange[1]}\n className={`${prefixCls}-popover`}\n {...datePickerProps}\n onChange={(selectedDate) => handleChange(selectedDate, 1)}\n />\n }\n >\n <Input\n placeholder=\"请选择日期\"\n readOnly\n {...(inputProps as InputProps)}\n value={dateRange[1] ? formatter(format, dateRange[1]) : ''}\n // onChange={(v) => console.log('v2', v)}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n {allowClear && dateRange.length > 0 && (\n <Icon className={`${prefixCls}-close-btn`} color=\"#ccc\" onClick={() => setDateRange([])} type=\"close\" />\n )}\n </div>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport DatePicker, { DatePickerProps } from '@uiw/react-date-picker';\nimport Icon from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport formatter from '@uiw/formatter';\nexport * from './DateInputRange';\nimport './style/index.less';\n\nexport interface DateInputProps extends IProps, Omit<InputProps, 'onChange' | 'value'> {\n popoverProps?: PopoverProps;\n datePickerProps?: DatePickerProps;\n value?: Date | string;\n format?: string;\n allowClear?: boolean;\n onChange?: (selectedDate?: Date) => void;\n autoClose?: boolean;\n}\n\nexport default function DateInput(props: DateInputProps) {\n const {\n prefixCls = 'w-dateinput',\n className,\n popoverProps,\n datePickerProps,\n allowClear = true,\n autoClose = false,\n format = 'YYYY/MM/DD',\n onChange,\n ...inputProps\n } = props;\n const [date, setDate] = useState(props.value);\n\n const value = date || '';\n inputProps.value = typeof value === 'string' ? value : formatter(format, value);\n\n useEffect(() => {\n if (props.value !== date) {\n setDate(props.value);\n }\n }, [props.value]);\n\n function handleChange(cdate?: Date) {\n autoClose && setIsOpen(false);\n setDate(cdate);\n onChange && onChange(cdate);\n }\n if (allowClear && inputProps.value) {\n inputProps.addonAfter = (\n <Icon className={`${prefixCls}-close-btn`} onClick={() => handleChange(undefined)} type=\"close\" />\n );\n }\n\n const [isOpen, setIsOpen] = useState(false);\n\n return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n isOpen={isOpen}\n onVisibleChange={(open) => setIsOpen(open)}\n {...popoverProps}\n content={\n <DatePicker\n date={(value && new Date(value)) || undefined}\n className={`${prefixCls}-popover`}\n {...datePickerProps}\n onChange={(selectedDate) => handleChange(selectedDate!)}\n />\n }\n >\n <Input\n placeholder=\"请选择日期\"\n readOnly\n {...(inputProps as InputProps)}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n );\n}\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\n\nexport interface DescriptionsItemProps extends IProps {\n label?: React.ReactNode;\n children: React.ReactNode;\n span?: number;\n}\n\nconst DescriptionsItem: React.FC<DescriptionsItemProps> = ({ children }) => children as JSX.Element;\n\nexport default DescriptionsItem;\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\nimport { DescriptionsItemProps } from './DescriptionsItem';\nimport { RowProps } from './Row';\n\nexport interface CellProps\n extends Omit<RowProps, 'children'>,\n Omit<DescriptionsItemProps, 'children'>,\n React.HTMLAttributes<HTMLTableCellElement>,\n IProps {\n children?: React.ReactElement<DescriptionsItemProps> | React.ReactNode;\n tagName?: 'td' | 'th';\n /**\n * 是否为一行的最后一个\n */\n isLastCell?: boolean;\n}\n\nfunction Cell(props: CellProps = {}) {\n const {\n prefixCls,\n className,\n tagName: TagName = 'td',\n layout,\n bordered,\n label,\n isLastCell,\n colon,\n span,\n children,\n column,\n ...other\n } = props;\n\n const labelProps: React.HTMLAttributes<HTMLSpanElement> = {\n className: [\n prefixCls ? `${prefixCls}-item-label` : null,\n className,\n colon ? `${prefixCls}-item-colon` : null,\n !label ? `${prefixCls}-item-no-label` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n };\n if (layout === 'horizontal') {\n if (!bordered) {\n return (\n <TagName {...other} colSpan={span}>\n <span {...labelProps}>{label}</span>\n <span className={prefixCls ? `${prefixCls}-item-content` : ''}>{children}</span>\n </TagName>\n );\n }\n return (\n <Fragment>\n <th {...labelProps}>{label}</th>\n <TagName\n {...other}\n colSpan={span ? span * 2 - 1 : span}\n className={prefixCls ? `${prefixCls}-item-content` : ''}\n >\n {children}\n </TagName>\n </Fragment>\n );\n }\n return (\n <TagName colSpan={span} className={`${prefixCls}-item-${TagName === 'td' ? 'content' : 'label'}`}>\n {children}\n </TagName>\n );\n}\n\nexport default Cell;\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\nimport { DescriptionsItemProps } from './DescriptionsItem';\nimport Cell from './Cell';\n\nexport interface RowProps extends IProps {\n children?: React.ReactElement<DescriptionsItemProps>[];\n bordered?: boolean;\n layout?: 'horizontal' | 'vertical';\n colon?: boolean;\n column?: number;\n}\n\nexport default function Row(props: RowProps = {}) {\n const { prefixCls, layout, bordered, column, colon, children = [] } = props;\n function handleCell(isHead?: boolean) {\n return children.map((child, index) => (\n <Cell\n {...child.props}\n prefixCls={prefixCls}\n key={index}\n column={column}\n tagName={isHead ? 'th' : 'td'}\n isLastCell={children.length - 1 === index}\n layout={layout}\n colon={colon}\n bordered={bordered}\n >\n {isHead ? child.props.label : child.props.children}\n </Cell>\n ));\n }\n const cls = prefixCls ? `${prefixCls}-row` : '';\n return (\n <Fragment>\n {layout === 'vertical' && <tr className={cls}>{handleCell(true)}</tr>}\n <tr className={cls}>{handleCell()}</tr>\n </Fragment>\n );\n}\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\nimport DescriptionsItem, { DescriptionsItemProps } from './DescriptionsItem';\nimport Row, { RowProps } from './Row';\nimport './style/index.less';\n\nexport * from './DescriptionsItem';\n\nexport interface DescriptionsProps extends IProps {\n column?: number;\n title?: React.ReactNode;\n children?: React.ReactNode;\n bordered?: boolean;\n colon?: boolean;\n size?: 'large' | 'small' | 'default';\n layout?: RowProps['layout'];\n}\n\nconst generateChildrenRows = (\n children: React.ReactElement<DescriptionsItemProps>[],\n column: number,\n): Array<React.ReactElement<DescriptionsItemProps>[]> => {\n const rows: React.ReactElement<DescriptionsItemProps>[][] = [];\n let columns: React.ReactElement<DescriptionsItemProps>[] | null = null;\n let leftSpans: number;\n\n children.forEach((node: React.ReactElement<DescriptionsItemProps>, index: number) => {\n let itemNode = node;\n\n if (!columns) {\n leftSpans = column;\n columns = [];\n rows.push(columns);\n }\n\n // Always set last span to align the end of Descriptions\n const lastItem = index === children.length - 1;\n if (lastItem) {\n itemNode = React.cloneElement(itemNode, {\n span: leftSpans,\n });\n }\n // Calculate left fill span\n const { span = 1 } = itemNode.props;\n columns.push(itemNode);\n leftSpans -= span;\n\n if (leftSpans <= 0) {\n columns = null;\n }\n });\n\n return rows;\n};\n\nfunction InternalDescriptions(props: DescriptionsProps, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-descriptions',\n className,\n title,\n bordered,\n column = 3,\n size,\n colon = true,\n children,\n layout = 'horizontal',\n ...other\n } = props;\n const cls = [\n prefixCls,\n className,\n prefixCls && layout ? `${prefixCls}-${layout}` : null,\n bordered ? `${prefixCls}-bordered` : null,\n size ? `${prefixCls}-${size}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const cloneChildren = React.Children.toArray(children) as JSX.Element[];\n const childs: Array<React.ReactElement<DescriptionsItemProps>[]> = generateChildrenRows(cloneChildren, column!);\n\n return (\n <div className={cls} ref={ref}>\n <table {...other}>\n {title && <caption className={`${prefixCls}-title`}>{title}</caption>}\n <tbody className={`${prefixCls}-tbody`}>\n {childs.map((child, index) => (\n <Row key={index} prefixCls={prefixCls} bordered={bordered} colon={colon} column={column} layout={layout}>\n {child}\n </Row>\n ))}\n </tbody>\n </table>\n </div>\n );\n}\n\nconst Descriptions = React.forwardRef<HTMLDivElement, DescriptionsProps>(InternalDescriptions);\ntype Descriptions = typeof Descriptions & {\n Item: typeof DescriptionsItem;\n};\n\n(Descriptions as Descriptions).Item = DescriptionsItem;\n\nexport default Descriptions as Descriptions;\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface DividerProps extends IProps, HTMLDivProps {\n dashed?: boolean;\n type?: 'horizontal' | 'vertical';\n align?: 'left' | 'right' | 'center';\n}\n\nexport default React.forwardRef<HTMLDivElement, DividerProps>((props, ref) => {\n const {\n prefixCls = 'w-divider',\n className,\n children,\n dashed = false,\n type = 'horizontal',\n align = 'center',\n ...restProps\n } = props;\n const cls = [\n className,\n prefixCls,\n prefixCls && type ? `${prefixCls}-${type}` : null,\n prefixCls && align ? `${prefixCls}-${align}` : null,\n children ? `${prefixCls}-with-text` : null,\n !!dashed ? `${prefixCls}-dashed` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n return (\n <div className={cls} {...restProps} ref={ref}>\n {children && <span className={`${prefixCls}-inner-text`}>{children}</span>}\n </div>\n );\n});\n","import React, { useMemo } from 'react';\nimport Overlay, { OverlayProps } from '@uiw/react-overlay';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport Button from '@uiw/react-button';\nimport { HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface DrawerProps extends OverlayProps {\n footer?: React.ReactNode;\n icon?: IconProps['type'];\n title?: React.ReactNode;\n bodyProps?: HTMLDivProps;\n placement?: 'top' | 'right' | 'bottom' | 'left';\n size?: number;\n isCloseButtonShown?: boolean;\n onClose?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n}\n\nexport default (props: DrawerProps = {}) => {\n const {\n prefixCls = 'w-drawer',\n className,\n style,\n placement = 'right',\n size = 260,\n title,\n footer,\n icon,\n isCloseButtonShown = true,\n bodyProps,\n timeout = 300,\n isOpen = false,\n maskClosable = true,\n ...overlayProps\n } = props;\n const cls = [className, prefixCls, placement].filter(Boolean).join(' ').trim();\n const bodyCls = [bodyProps ? bodyProps.className : null, prefixCls ? `${prefixCls}-body-inner` : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n const styl = {\n ...style,\n [/^(top|bottom)$/.test(placement!) ? 'height' : 'width']: size,\n };\n const footerView = useMemo(() => (footer ? <div className={`${prefixCls}-footer`}>{footer}</div> : null), [footer]);\n const iconView = useMemo(() => (icon ? <Icon type={icon} /> : null), [icon]);\n const titleView = useMemo(() => (title ? <h4>{title}</h4> : null), [title]);\n return (\n <Overlay className={cls} timeout={timeout} isOpen={isOpen} maskClosable={maskClosable} {...overlayProps}>\n <div className={`${prefixCls}-wrapper`} style={styl}>\n {(title || icon) && (\n <div className={`${prefixCls}-header`}>\n {iconView}\n {titleView}\n {title && isCloseButtonShown && <Button basic onClick={props.onClose} icon=\"close\" type=\"light\" />}\n </div>\n )}\n <div className={`${prefixCls}-body`}>\n <div {...bodyProps} className={bodyCls}>\n {props.children}\n </div>\n </div>\n {footerView}\n </div>\n </Overlay>\n );\n};\n","import React from 'react';\nimport './style/index.less';\n\nexport interface EmptyProps extends React.HTMLAttributes<HTMLDivElement> {\n prefixCls?: string;\n icon?: React.ReactNode;\n size?: number | string;\n iconProps?: React.SVGProps<SVGSVGElement>;\n /** 自定义描述内容 */\n description?: React.ReactNode;\n}\n\nconst Empty = (props: EmptyProps) => {\n const {\n prefixCls = 'w-empty',\n className,\n icon,\n iconProps,\n size = 64,\n description = '暂无数据',\n children,\n ...other\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return (\n <div className={cls} {...other}>\n <div className={`${prefixCls}-icon`}>\n {icon ? (\n icon\n ) : (\n <svg viewBox=\"0 0 1024 1024\" width={size} height={size} {...iconProps}>\n <path d=\"M20.48 860.16a491.52 102.4 0 1 0 983.04 0 491.52 102.4 0 1 0-983.04 0Z\" fill=\"#F5F5F5\" />\n <path d=\"M225.28 409.6l573.44-8.06912 112.78336 183.296H102.4z\" fill=\"#C4C5C7\" />\n <path\n d=\"M266.24 61.44h491.52a40.96 40.96 0 0 1 40.96 40.96v532.48a40.96 40.96 0 0 1-40.96 40.96H266.24a40.96 40.96 0 0 1-40.96-40.96V102.4a40.96 40.96 0 0 1 40.96-40.96z\"\n fill=\"#F5F5F7\"\n />\n <path\n d=\"M348.16 143.36h327.68a40.96 40.96 0 0 1 40.96 40.96v122.88a40.96 40.96 0 0 1-40.96 40.96H348.16a40.96 40.96 0 0 1-40.96-40.96V184.32a40.96 40.96 0 0 1 40.96-40.96zM327.68 409.6h368.64a20.48 20.48 0 0 1 0 40.96H327.68a20.48 20.48 0 0 1 0-40.96zM327.68 491.52h368.64a20.48 20.48 0 0 1 0 40.96H327.68a20.48 20.48 0 0 1 0-40.96z\"\n fill=\"#EBECEC\"\n />\n <path\n d=\"M673.44384 607.58016v13.43488c0 25.14944-20.0704 45.52704-44.8512 45.52704H382.95552l-2.2528-0.06144c-23.7568-1.16736-42.63936-21.07392-42.63936-45.4656v-13.45536c0-12.55424-10.0352-22.7328-22.44608-22.7328H102.4v250.30656C102.4 860.2624 122.49088 880.64 147.29216 880.64h719.31904c24.7808 0 44.89216-20.3776 44.89216-45.50656V584.82688H695.88992c-12.3904 0-22.44608 10.17856-22.44608 22.7328z\"\n fill=\"#E0E0E0\"\n />\n </svg>\n )}\n </div>\n {description && <div className={`${prefixCls}-description`}>{description}</div>}\n {children && <div className={`${prefixCls}-footer`}>{children}</div>}\n </div>\n );\n};\n\nexport default Empty;\n","import React from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport { FileInputProps } from './';\n\nexport interface InputUploadProps extends FileInputProps, InputProps {}\n\nexport default React.forwardRef<HTMLInputElement, InputUploadProps>((props, ref) => {\n const { className, dataLabel = 'Browse', prefixCls = 'w-fileinput', ...other } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return <Input ref={ref} data-label={dataLabel} className={cls} {...other} type=\"file\" />;\n});\n","import React from 'react';\nimport Icon from '@uiw/react-icon';\nimport { FileInputListProps } from './';\nimport './style/index.less';\n\nconst Picture = (props: FileInputListProps) => {\n const {\n className,\n prefixCls = 'w-fileinput-list',\n dataList = [],\n uploadType,\n size = 'middle',\n shape = 'round',\n readonly,\n children,\n showFileIcon = {\n showPreviewIcon: true,\n showRemoveIcon: true,\n },\n onPreview,\n onAdd,\n onRemove,\n } = props;\n\n const cls = [prefixCls, `${prefixCls}-size-${size}`, `${prefixCls}-shape-${shape}`, className]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n return (\n <div className={cls}>\n {children &&\n !readonly &&\n React.isValidElement(children) &&\n React.cloneElement(children, {\n onClick: onAdd,\n })}\n <div>\n {dataList.map((item, index) => (\n <div className={`${prefixCls}-${uploadType}`} key={index}>\n {uploadType === 'picture' && (\n <div className={`${prefixCls}-info ${prefixCls}-${uploadType}-info`}>\n <img src={item['dataURL']} alt=\"\" />\n {showFileIcon?.showPreviewIcon && (\n <div className={`${prefixCls}-actions`}>\n <span className={`${prefixCls}-actions-search`} onClick={() => onPreview?.(item)}>\n <Icon type=\"search\" style={{ color: '#fff', fontSize: 16 }} />\n </span>\n </div>\n )}\n </div>\n )}\n <div className={`${prefixCls}-${uploadType}-text`}>{item.name}</div>\n {showFileIcon?.showRemoveIcon && (\n <div className={`${prefixCls}-${uploadType}-icon`} onClick={() => onRemove?.(index)}>\n <Icon type=\"delete\" style={{ color: '#999' }} />\n </div>\n )}\n </div>\n ))}\n </div>\n </div>\n );\n};\n\nexport default Picture;\n","import React from 'react';\nimport Icon from '@uiw/react-icon';\nimport { FileInputListProps } from './';\nimport './style/index.less';\n\nconst Card = (props: FileInputListProps) => {\n const {\n className,\n prefixCls = 'w-fileinput-card',\n dataList = [],\n maxNumber = 3,\n shape = 'round',\n size = 'middle',\n readonly,\n children,\n showFileIcon = {\n showPreviewIcon: true,\n showRemoveIcon: true,\n },\n onAdd,\n onPreview,\n onRemove,\n } = props;\n const cls = [prefixCls, `${prefixCls}-size-${size}`, `${prefixCls}-shape-${shape}`, className]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const isAction = showFileIcon.showPreviewIcon || showFileIcon.showRemoveIcon ? true : false;\n\n return (\n <div className={cls}>\n {dataList.map((item, index) => (\n <div className={`${prefixCls}-box`} key={index}>\n <div className={`${prefixCls}-box-info`}>\n <img src={item['dataURL']} alt=\"\" />\n </div>\n\n <div className={isAction ? `${prefixCls}-actions` : ''}>\n {showFileIcon?.showPreviewIcon && (\n <span className={`${prefixCls}-actions-remove`} onClick={() => onPreview?.(item)}>\n <Icon type=\"search\" style={{ color: '#fff', fontSize: 16 }} />\n </span>\n )}\n {showFileIcon?.showRemoveIcon && (\n <span className={`${prefixCls}-actions-remove`} onClick={() => onRemove?.(index)}>\n <Icon type=\"delete\" style={{ color: '#fff', fontSize: 16 }} />\n </span>\n )}\n </div>\n </div>\n ))}\n {maxNumber > dataList.length && !readonly && (\n <div className={`${prefixCls}-box ${prefixCls}-btn`} onClick={onAdd}>\n {children}\n </div>\n )}\n </div>\n );\n};\n\nexport default Card;\n","import { FileInputValue } from './';\n\nexport const openFileDialog = (inputRef: any): void => {\n if (inputRef.current) inputRef.current.click();\n};\n\nexport const getAcceptTypeString = (accept?: Array<string>) => {\n return accept && accept.length > 0 ? accept.map((item) => `.${item}`).join(', ') : 'image/*';\n};\n\nexport const getBase64 = (file: File): Promise<string> => {\n const reader = new FileReader();\n return new Promise((resolve) => {\n reader.addEventListener('load', () => resolve(String(reader.result)));\n reader.readAsDataURL(file);\n });\n};\n\nexport const getListFiles = (files: FileList, dataURLKey: string): Promise<FileInputValue[]> => {\n const promiseFiles: Array<Promise<string>> = [];\n for (let i = 0; i < files.length; i += 1) {\n promiseFiles.push(getBase64(files[i]));\n }\n return Promise.all(promiseFiles).then((fileListBase64: Array<string>) => {\n const fileList: FileInputValue[] = fileListBase64.map((base64, index) => ({\n [dataURLKey]: base64,\n file: files[index],\n name: files[index].name,\n }));\n return fileList;\n });\n};\n\nexport const isUploadType = (type: string) => {\n return ['picture', 'text', 'card'].includes(type);\n};\n","import React, { useRef, useCallback, useEffect, useState } from 'react';\nimport List from './List';\nimport Card from './Card';\nimport { FileInputValue, FileInputListProps } from './';\nimport { FileInputUploadProps } from './types';\nimport { openFileDialog, getListFiles } from './utils';\n\nexport const FileList = (props: FileInputUploadProps) => {\n const { uploadType, value = [], multiple = false, maxNumber = 3, onChange } = props;\n const inputRef = useRef<HTMLInputElement>(null);\n const inValue: FileInputValue[] = value || [];\n const [fileList, setFileList] = useState<FileInputValue[]>([]);\n\n useEffect(() => {\n setFileList(inValue);\n }, []);\n\n const handleClickInput = useCallback(() => openFileDialog(inputRef), [inputRef]);\n\n const onFileUpload = useCallback((): void => {\n if (inputRef.current) inputRef.current.value = '';\n handleClickInput();\n }, [handleClickInput]);\n\n const onInputChange = async (e: React.ChangeEvent<HTMLInputElement>) => {\n const files = e.target.files;\n if (!files) return;\n const updatedFileList = await getListFiles(files, 'dataURL');\n let updatedList = [...fileList, ...updatedFileList];\n if (maxNumber < updatedList.length) {\n updatedList = updatedList.slice(0, maxNumber);\n }\n setFileList(updatedList);\n onChange?.(updatedList);\n };\n\n const onRemove = (index: number) => {\n const updatedList = [...fileList];\n updatedList.splice(index, 1);\n setFileList(updatedList);\n onChange?.(updatedList);\n };\n\n let Comp: ((props: FileInputListProps) => JSX.Element) | undefined;\n\n if (uploadType === 'card') {\n Comp = Card;\n }\n if (uploadType === 'picture' || uploadType === 'text') {\n Comp = List;\n }\n\n return (\n <React.Fragment>\n <input type=\"file\" ref={inputRef} multiple={multiple} style={{ display: 'none' }} onChange={onInputChange} />\n {Comp && (\n <Comp {...props} maxNumber={maxNumber || 3} dataList={fileList} onAdd={onFileUpload} onRemove={onRemove} />\n )}\n </React.Fragment>\n );\n};\n\nexport default FileList;\n","import React from 'react';\nimport Input from './Input';\nimport FileList from './FileList';\nimport { isUploadType } from './utils';\nimport { InputProps } from '@uiw/react-input';\nimport { UploadType, FileInputBaseProps, FileInputUploadProps, FileInputShowIconProps } from './types';\nimport './style/index.less';\nexport interface FileInputValue {\n dataURL?: string;\n file?: File;\n name?: string;\n [key: string]: any;\n}\nexport interface FileInputProps extends FileInputBaseProps, InputProps {\n dataLabel?: string;\n}\nexport interface FileInputListProps extends FileInputUploadProps {\n shape?: 'circle' | 'round';\n size?: 'large' | 'middle' | 'small';\n showFileIcon?: FileInputShowIconProps;\n dataList: FileInputValue[];\n onAdd?: () => void;\n onRemove?: (index: number) => void;\n}\n\ninterface Props {\n uploadType?: UploadType;\n [key: string]: any;\n}\n\nfunction Upload(props: Props) {\n const { uploadType = 'input' } = props;\n\n if (uploadType === 'input') {\n return <Input {...props} />;\n }\n\n if (isUploadType(uploadType)) {\n return <FileList {...props} />;\n }\n return null;\n}\n\nexport default Upload;\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/col.less';\n\nexport interface ColProps extends IProps, HTMLDivProps {\n fixed?: boolean;\n span?: number | string;\n grow?: number | string;\n align?: 'top' | 'middle' | 'bottom' | 'baseline';\n}\n\nexport function Col(props: ColProps = {}) {\n const { prefixCls = 'w-col', className, fixed, span, grow, align, ...other } = props;\n const cls = [\n prefixCls,\n className,\n span ? `${prefixCls}-${span}` : null,\n fixed ? `${prefixCls}-fixed` : null,\n align ? `${prefixCls}-align-${align}` : null,\n fixed ? `${prefixCls}-grow-${grow}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n return (\n <div className={cls} {...other}>\n {props.children}\n </div>\n );\n}\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/row.less';\n\nexport interface RowProps extends IProps, HTMLDivProps {\n fixed?: boolean;\n gutter?: number;\n justify?: 'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around' | 'space-evenly';\n align?: 'top' | 'middle' | 'bottom' | 'baseline';\n}\n\nexport function Row(props: RowProps = {}) {\n const { prefixCls = 'w-row', className, gutter = 0, justify, align, ...other } = props;\n const cls = [\n prefixCls,\n className,\n align ? `${prefixCls}-align-${align}` : null,\n justify ? `${prefixCls}-justify-${justify}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const gutterStyl = !gutter ? {} : { paddingLeft: gutter / 2, paddingRight: gutter / 2 };\n return (\n <div {...other} className={cls}>\n {React.Children.toArray(props.children).map((child) => {\n if (!React.isValidElement(child)) return child;\n return React.cloneElement(\n child,\n Object.assign({}, child.props, {\n style: { ...child.props.style, ...gutterStyl },\n }),\n );\n })}\n </div>\n );\n}\n","import React from 'react';\nimport { Col, Row } from '@uiw/react-grid';\nimport { IProps, HTMLInputProps } from '@uiw/utils';\nimport { FormFieldsProps } from './Form';\nimport './style/form-item.less';\n\nexport interface FormItemProps<T> extends IProps, HTMLInputProps {\n inline?: boolean;\n hasError?: boolean;\n label?: React.ReactNode;\n required?: boolean;\n labelFor?: string;\n labelClassName?: string;\n help?: React.ReactNode;\n labelStyle?: React.CSSProperties;\n initialValue?: string | number | T;\n validator?: FormFieldsProps<T>['validator'];\n}\n\nexport default class FormItem<T> extends React.PureComponent<FormItemProps<T>> {\n public static defaultProps = {\n prefixCls: 'w-form-item',\n };\n render() {\n const {\n prefixCls,\n className,\n required,\n style,\n label,\n labelFor,\n labelClassName,\n labelStyle,\n help,\n inline,\n initialValue,\n validator,\n hasError,\n ...otherProps\n } = this.props;\n\n const cls = [prefixCls, className, hasError ? `${prefixCls}-error` : null].filter(Boolean).join(' ').trim();\n const labelCls = ['w-form-label', labelClassName].filter(Boolean).join(' ').trim();\n if (inline) {\n return (\n <div className={cls} style={style} {...otherProps}>\n <Row>\n <Col fixed className={labelCls}>\n {required && <label style={{ color: 'red' }}>*</label>}\n <label style={labelStyle} htmlFor={labelFor}>\n {label}\n </label>\n </Col>\n <Col className=\"w-form-row\">{this.props.children}</Col>\n </Row>\n {help && (\n <Row>\n <Col className=\"w-form-help\">{help}</Col>\n </Row>\n )}\n </div>\n );\n }\n return (\n <div className={cls} style={style} {...otherProps}>\n {label && (\n <React.Fragment>\n {required && <label style={{ color: 'red' }}>*</label>}\n <label className={labelCls} style={labelStyle} htmlFor={labelFor}>\n {label}\n </label>\n </React.Fragment>\n )}\n <Col className=\"w-form-row\">{this.props.children}</Col>\n {help && <div className=\"w-form-help\">{help}</div>}\n </div>\n );\n }\n}\n","import React, { useState, useImperativeHandle, useMemo } from 'react';\nimport { IProps } from '@uiw/utils';\nimport FormItem, { FormItemProps } from './FormItem';\nimport './style/form.less';\n\nexport interface FormProps<T> extends IProps, Omit<React.FormHTMLAttributes<HTMLFormElement>, 'onChange' | 'onSubmit'> {\n prefixCls?: string;\n fields?: Record<string, FormFieldsProps<T>>;\n onSubmit?: (state: FormSubmitProps, event: React.FormEvent) => any;\n afterSubmit?: (result: FormAfterSubmitProps) => any;\n onChange?: (state: FormState) => void;\n onSubmitError?: (evn: any) => any;\n resetOnSubmit?: boolean;\n children?: (handle: FormChildrenProps) => JSX.Element | JSX.Element | undefined;\n}\n\nexport interface FormState {\n submitting: boolean;\n initial: Record<string, any>;\n current: FormState['initial'];\n errors: Record<string, any>;\n}\n\nexport interface FormFieldsProps<T> extends FormItemProps<T> {\n name?: string;\n children?: React.ReactNode;\n help?: React.ReactNode;\n labelFor?: string;\n inline?: boolean;\n checked?: boolean;\n initialValue?: string | number | T;\n required?: boolean;\n validator?: (currentValue: any) => any;\n}\n\nexport interface FormSubmitProps {\n initial: FormState['initial'];\n current: FormState['current'];\n}\n\nexport interface FormAfterSubmitProps {\n state: FormState;\n response: any;\n reset: () => void;\n}\n\nexport interface FormChildrenProps {\n fields: Record<string, React.ReactElement>;\n resetForm: () => void;\n canSubmit: () => boolean;\n state: FormState;\n}\n\nexport type FormElementProps = {\n id?: string;\n name?: string;\n value?: string | boolean;\n checked?: boolean;\n onChange?: (env: React.BaseSyntheticEvent<HTMLInputElement>, list?: string[]) => void;\n};\n\nexport type FormRefType = Record<'onSubmit' | 'resetForm' | 'getFieldValues' | 'setFields', Function>;\n\nfunction newFormState<T>(\n fields: FormProps<T>['fields'],\n cb: (porps: FormFieldsProps<T>) => {\n initialValue: FormFieldsProps<T>['initialValue'];\n currentValue: FormFieldsProps<T>['initialValue'];\n },\n): FormState {\n const state: FormState = {\n initial: {},\n current: {},\n submitting: false,\n errors: {},\n };\n for (const name in fields) {\n const props = fields[name];\n if (!props) continue;\n const { initialValue, currentValue } = cb({ ...props, name });\n state.initial[name] = Array.isArray(initialValue) ? [...initialValue] : initialValue;\n state.current[name] = currentValue;\n }\n return state;\n}\n\nfunction newInitialValue<T>(value: FormFieldsProps<T>['initialValue']) {\n return value === null || value === undefined ? '' : value;\n}\n\nconst isPromise = (promise: Promise<any>) => promise && typeof promise.then === 'function';\n\nfunction Form<T>(\n {\n prefixCls = 'w-form',\n className,\n fields,\n children,\n resetOnSubmit,\n onSubmitError,\n onChange,\n onSubmit,\n afterSubmit,\n ...others\n }: FormProps<T>,\n ref: React.ForwardedRef<FormRefType | undefined>, //| React.RefObject<FormRefType>,\n) {\n const initData = useMemo(\n () =>\n newFormState(fields, ({ initialValue }) => {\n initialValue = newInitialValue(initialValue);\n return { initialValue, currentValue: initialValue };\n }),\n [],\n );\n const [data, setData] = useState<FormState>(initData);\n\n useImperativeHandle(\n ref,\n () => ({\n onSubmit: handleSubmit,\n resetForm: handleReset,\n getFieldValues: () => data.current,\n getError: () => data.errors,\n setFields: setFields,\n setFieldValue: setFieldValue,\n }),\n [data],\n );\n\n const formUnits: FormChildrenProps['fields'] = {};\n for (const name in fields) {\n const props = fields[name];\n if (!props) continue;\n const error = data.errors[name];\n if (typeof props.initialValue === 'boolean') {\n props.checked = props.initialValue;\n }\n const childField: FormFieldsProps<T> = controlField({\n ...props,\n name,\n });\n const help = error || props.help;\n const labelFor = props.labelFor;\n formUnits[name] = (\n <FormItem\n {...{\n ...props,\n key: name,\n children: childField,\n help,\n labelFor,\n state: data,\n name,\n hasError: !!error,\n }}\n />\n );\n }\n\n function setFields(fields: FormState['current']) {\n const tempData = { ...data, current: fields };\n setData(tempData);\n }\n\n function setFieldValue<V>(fieldName: string, value: V) {\n const tempData = { ...data, current: { ...data.current, [fieldName]: value } };\n setData(tempData);\n }\n\n function handleChange(\n name: string,\n validator: FormFieldsProps<T>['validator'],\n element?: React.ReactElement,\n cb?: (env: React.BaseSyntheticEvent<HTMLInputElement>) => void,\n ) {\n return (env: React.BaseSyntheticEvent<HTMLInputElement>, list?: string[]) => {\n let value = env && env.target && 'value' in env.target ? env.target.value : env;\n // 控件 Checkbox.Group 多选值的处理\n value = list || value;\n // 控件 Checkbox 值的处理\n if (!list && element && env && env.target && /(radio)/.test(env.target.type)) {\n // 控件 Switch/Radio/Checkbox 值的处理\n value = env.target.value ? env.target.value : env.target.checked;\n }\n if (!list && element && env && env.target && /(checkbox)/.test(env.target.type)) {\n // 控件 Switch/Radio/Checkbox 值的处理\n value = env.target.checked;\n }\n const nextState = {\n current: { ...data.current, [name]: value },\n } as FormState;\n const error = validator && validator(value);\n if (!error) {\n nextState.errors = { ...data.errors };\n delete nextState.errors[name];\n }\n if (env && env.persist && typeof env.persist === 'function') env.persist();\n setData({ ...data, ...nextState });\n if (cb) {\n cb(env);\n }\n onChange && onChange({ ...data, ...nextState });\n };\n }\n\n function handleSubmit(e: React.FormEvent) {\n e && e.preventDefault();\n const { initial, current } = data;\n setData({ ...data, submitting: true });\n const nextState = { submitting: false } as FormState;\n const onError = (evn: unknown) =>\n setData({\n ...data,\n ...nextState,\n errors: (onSubmitError && onSubmitError(evn)) || {},\n });\n const onSuccess = (response: any) => {\n if (resetOnSubmit) {\n nextState.current = initial;\n }\n setData({ ...data, ...nextState, errors: {} });\n afterSubmit && afterSubmit({ state: data, response, reset: handleReset });\n };\n try {\n const afterSubmitPromise = onSubmit ? onSubmit({ initial, current }, e) : undefined;\n if (afterSubmitPromise && isPromise(afterSubmitPromise)) {\n return afterSubmitPromise.then(onSuccess).catch(onError);\n } else {\n return onSuccess(afterSubmitPromise);\n }\n } catch (evn) {\n onError(evn);\n }\n }\n\n function canSubmit() {\n const { submitting, current = {} } = data;\n let passesValidators = true;\n for (const name in fields) {\n if (Object.prototype.hasOwnProperty.call(fields, name)) {\n const props: FormFieldsProps<T> = fields[name];\n if (!props) continue;\n if (props.validator && props.validator(current[name])) {\n passesValidators = false;\n break;\n }\n }\n }\n return !submitting && passesValidators;\n }\n\n function handleReset() {\n let { initial } = data;\n const initials = { ...initial };\n Object.entries(initials).map(([key, value]) => {\n if (Array.isArray(value)) {\n initials[key] = [...value];\n }\n });\n setData({ ...data, initial, current: initials, errors: {} });\n }\n\n function controlField({\n children,\n validator,\n name,\n help,\n label,\n labelFor,\n labelClassName,\n labelStyle,\n inline,\n initialValue,\n ...other\n }: FormFieldsProps<T>) {\n const element =\n typeof children !== 'function'\n ? children\n : children({\n onChange: handleChange(name!, validator),\n onSubmit: handleSubmit,\n canSubmit: canSubmit,\n });\n if (!element || React.Children.count(element) !== 1 || !name) return element;\n const props = {\n name: element.props.name || name,\n ...other,\n } as FormElementProps;\n const hasCurrentValue = Object.prototype.hasOwnProperty.call(data.current, name);\n props.id = element.props.id;\n props.value = hasCurrentValue ? data.current && data.current[name] : props.value;\n // : element.props.value;\n\n const type = element.props.type;\n // console.log('type', element)\n if (type === 'checkbox' || type === 'switch' || typeof props.value === 'boolean') {\n props.checked = !!props.value;\n delete props.value;\n }\n props.onChange = handleChange(name, validator, element, element.props.onChange) as FormElementProps['onChange'];\n return React.cloneElement(element, props as FormElementProps);\n }\n\n return (\n <form\n {...{\n ...others,\n className: [prefixCls, className].filter(Boolean).join(' ').trim(),\n onSubmit: handleSubmit,\n }}\n >\n <fieldset {...{ disabled: data.submitting }}>\n {typeof children === 'function'\n ? children({\n fields: formUnits,\n state: data,\n resetForm: handleReset,\n canSubmit: canSubmit,\n })\n : children}\n </fieldset>\n </form>\n );\n}\n\nexport default React.forwardRef<FormRefType | undefined, FormProps<{}>>(Form);\n","import Form from './Form';\n\nexport * from './Form';\nexport * from './FormItem';\nexport { default as FormItem } from './FormItem';\n\nexport default Form;\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\n\nexport type TagType = React.ComponentType | keyof JSX.IntrinsicElements;\n\nexport interface ListItemProps<Tag extends TagType> extends IProps, React.HTMLProps<Tag> {\n disabled?: boolean;\n active?: boolean;\n extra?: React.ReactNode;\n href?: string;\n tagName?: Tag;\n}\n\nexport const ListItem = React.forwardRef(\n <Tag extends TagType = 'div'>(props: ListItemProps<Tag>, ref: React.Ref<React.HTMLProps<Tag>>) => {\n const {\n prefixCls = 'w-list-item',\n className,\n children,\n extra,\n tagName = 'div',\n active = false,\n ...resetProps\n } = props;\n const cls = [prefixCls, className, props.disabled ? 'w-disabled' : null, active ? 'w-active' : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n const TagName = props.href && typeof tagName === 'string' ? 'a' : tagName;\n return React.createElement(\n TagName,\n {\n ...resetProps,\n className: cls,\n ref,\n } as any,\n !extra || resetProps.href ? (\n children\n ) : (\n <Fragment>\n <div className={`${prefixCls}-main`}>{children}</div>\n <div className={`${prefixCls}-extra`}>{extra}</div>\n </Fragment>\n ),\n );\n },\n);\n\nListItem.displayName = 'List.Item';\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport { ListItem } from './Item';\nimport './style/index.less';\n\nexport * from './Item';\n\nexport interface ListProps<T> extends IProps, HTMLDivProps {\n bordered?: boolean;\n striped?: boolean;\n noHover?: boolean;\n active?: boolean;\n header?: React.ReactNode;\n footer?: React.ReactNode;\n size?: 'small' | 'default' | 'large';\n renderItem?: (item: any, idx: number) => React.ReactNode;\n dataSource?: T[];\n}\n\nfunction InternalList<T>(props: ListProps<T>, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-list',\n bordered = true,\n striped = false,\n noHover = false,\n active = false,\n size = 'default',\n renderItem = noop,\n className,\n children,\n header,\n footer,\n dataSource = [],\n ...resetProps\n } = props;\n let items: React.ReactNode;\n if (dataSource && dataSource.length > 0) {\n items = dataSource.map((item: any, index: number) => renderItem!(item, index));\n } else {\n items = children;\n }\n let childrenList = React.Children.map(\n items,\n (child: React.ReactNode, index) =>\n React.isValidElement(child) &&\n React.cloneElement(child, {\n key: index,\n }),\n );\n const classString = [\n prefixCls,\n className,\n striped ? `${prefixCls}-striped` : null,\n noHover ? `${prefixCls}-no-hover` : null,\n active ? `${prefixCls}-active` : null,\n bordered ? `${prefixCls}-bordered` : null,\n size && size !== 'default' ? `${prefixCls}-size-${size}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n return (\n <div className={classString} {...resetProps} ref={ref}>\n {header && <div className={`${prefixCls}-header`}>{header}</div>}\n {childrenList}\n {footer && <div className={`${prefixCls}-footer`}>{footer}</div>}\n </div>\n );\n}\n\nconst List = React.forwardRef<HTMLDivElement, ListProps<any>>(InternalList);\ntype List = typeof List & {\n Item: typeof ListItem;\n};\n\n(List as List).Item = ListItem;\n\nexport default List as List;\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface LoaderProps extends IProps, HTMLDivProps {\n size?: 'small' | 'default' | 'large';\n loading?: boolean;\n fullscreen?: boolean;\n color?: string;\n bgColor?: string;\n vertical?: boolean;\n tip?: React.ReactNode;\n indicator?: React.ReactNode;\n children?: any | React.ReactNode;\n}\n\nexport default (props: LoaderProps = {}) => {\n const {\n prefixCls = 'w-loader',\n className,\n size = 'default',\n loading = true,\n tip,\n vertical,\n color,\n bgColor,\n children,\n indicator,\n fullscreen = false,\n ...otherProps\n } = props;\n const cls = [prefixCls, className, size ? `${prefixCls}-${size}` : null].filter(Boolean).join(' ').trim();\n\n const indicatorView = useMemo(\n () => (\n <svg viewBox=\"25 25 50 50\">\n <circle cx=\"50\" cy=\"50\" r=\"20\" fill=\"none\" strokeWidth=\"5\" strokeMiterlimit=\"10\" />\n </svg>\n ),\n [],\n );\n\n const tipsView = useMemo(\n () => (\n <div\n className={[`${prefixCls}-tips`, fullscreen ? `${prefixCls}-fullscreen` : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n style={{ color, backgroundColor: bgColor }}\n >\n <div className={`${prefixCls}-tips-nested`}>\n {indicator || indicatorView}\n {tip && (\n <div\n className={[`${prefixCls}-text`, vertical ? `${prefixCls}-vertical` : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {tip}\n </div>\n )}\n </div>\n </div>\n ),\n [fullscreen, bgColor, prefixCls, vertical, tip],\n );\n\n return (\n <div className={cls} {...otherProps}>\n {(loading || fullscreen) && tipsView}\n {children &&\n React.cloneElement(\n children,\n Object.assign({}, children.props, {\n className: [`${prefixCls}-warp`, loading ? `${prefixCls}-blur` : null].filter(Boolean).join(' ').trim(),\n }),\n )}\n </div>\n );\n};\n","import React from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport Button from '@uiw/react-button';\nimport './style/index.less';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\n\nexport interface MessageProps extends IProps, Omit<HTMLDivProps, 'title'> {\n title?: React.ReactNode;\n icon?: IconProps['type'];\n type?: 'success' | 'warning' | 'info' | 'error';\n description?: React.ReactNode;\n showIcon?: boolean;\n isCloseButtonShown?: boolean;\n rounded?: boolean;\n onClose?: (e: React.MouseEvent<HTMLButtonElement>) => void;\n}\n\nexport interface IMessageState {\n isOpen: boolean;\n}\n\nexport default class Message extends React.Component<MessageProps, IMessageState> {\n public static defaultProps: MessageProps = {\n prefixCls: 'w-message',\n rounded: true,\n isCloseButtonShown: false,\n };\n constructor(props: MessageProps) {\n super(props);\n this.state = {\n isOpen: true,\n };\n }\n handleClosed = (e: React.MouseEvent<HTMLButtonElement>) => {\n const { onClose } = this.props;\n this.setState({ isOpen: false });\n onClose && onClose(e);\n };\n renderIcon = () => {\n const { type, showIcon } = this.props;\n let icon = this.props.icon;\n if (!icon && showIcon) {\n switch (type) {\n case 'success':\n icon = 'circle-check';\n break;\n case 'warning':\n icon = 'warning';\n break;\n case 'info':\n icon = 'information';\n break;\n case 'error':\n icon = 'circle-close';\n break;\n default:\n break;\n }\n }\n return icon;\n };\n render() {\n const {\n prefixCls,\n className,\n type,\n title,\n description,\n showIcon,\n icon,\n rounded,\n isCloseButtonShown,\n ...elementProps\n } = this.props;\n const children = description || this.props.children;\n const cls = [\n prefixCls,\n className,\n `${prefixCls}-${type}`,\n rounded ? `${prefixCls}-rounded` : null,\n showIcon ? `${prefixCls}-icon` : null,\n showIcon ? `${prefixCls}${title ? '-title' : ''}${children ? '-description' : ''}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const Child = (\n <div className={cls} {...elementProps}>\n {isCloseButtonShown && <Button basic onClick={this.handleClosed} icon=\"close\" type=\"light\" />}\n {showIcon && <Icon type={this.renderIcon()} />}\n <span className={`${prefixCls}-title`}>{title}</span>\n <span className={`${prefixCls}-description`}>{children}</span>\n </div>\n );\n if (!isCloseButtonShown) {\n return Child;\n }\n return (\n <CSSTransition in={this.state.isOpen} unmountOnExit timeout={300} classNames={prefixCls}>\n {Child}\n </CSSTransition>\n );\n }\n}\n","import React, { useEffect, useMemo, useState } from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport { IProps } from '@uiw/utils';\nimport Button from '@uiw/react-button';\nimport formatter from '@uiw/formatter';\nimport { DatePickerMonth, DatePickerYear, DatePickerCaption, DatePickerCaptionProps } from '@uiw/react-date-picker';\nimport './style/index.less';\n\nexport interface MonthPickerProps extends IProps, Omit<InputProps, 'value' | 'onChange'> {\n popoverProps?: PopoverProps;\n pickerCaptionProps?: DatePickerCaptionProps;\n value?: Date | string;\n format?: string;\n monthLabel?: string[];\n allowClear?: boolean;\n onChange?: (date?: Date, formatDate?: string) => void;\n}\n\nconst MONTH_LABEL = [\n '一月',\n '二月',\n '三月',\n '四月',\n '五月',\n '六月',\n '七月',\n '八月',\n '九月',\n '十月',\n '十一月',\n '十二月',\n];\n\nexport default function MonthPicker(props: MonthPickerProps) {\n const {\n prefixCls = 'w-monthpicker',\n format = 'YYYY/MM',\n onChange = () => {},\n className,\n popoverProps,\n pickerCaptionProps = {},\n allowClear = true,\n monthLabel = MONTH_LABEL,\n ...inputProps\n } = props;\n\n const [isOpen, setIsOpen] = useState(false);\n const [panelDate, setPanelDate] = useState(new Date());\n const [type, setType] = useState('month');\n const [date, setDate] = useState(props.value);\n\n useEffect(() => setDate(props.value), [props.value]);\n\n inputProps.value = useMemo(\n () => (typeof date === 'string' ? date : date ? formatter(format, date) : ''),\n [format, date],\n );\n\n if (allowClear && inputProps.value) {\n inputProps.addonAfter = (\n <Button\n className={`${prefixCls}-close-btn`}\n icon=\"close\"\n onClick={() => {\n setDate('');\n onChange && onChange();\n }}\n size={inputProps.size}\n basic\n type=\"light\"\n />\n );\n }\n\n function handleSelectedDate(type: 'setMonth' | 'setFullYear', num: number, paging?: boolean) {\n const curPanelDate = new Date(new Date(panelDate)[type](num));\n if (!paging) {\n setType('month');\n }\n const curDate = formatter(format, new Date(curPanelDate));\n setDate(curDate);\n setPanelDate(curPanelDate);\n onChange && onChange(curPanelDate, curDate);\n if (type === 'setMonth') {\n setIsOpen(false);\n }\n }\n\n return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n isOpen={isOpen}\n {...popoverProps}\n onVisibleChange={(open) => setIsOpen(open)}\n content={\n <div className={`${prefixCls}-popover`}>\n <DatePickerCaption\n panelDate={panelDate}\n monthLabel={monthLabel}\n {...pickerCaptionProps}\n onSelected={(captionType) => {\n if (/^(month|year)$/.test(captionType as string)) {\n setType(captionType);\n } else {\n const year = new Date(panelDate).getFullYear();\n const curPanelDate = new Date(new Date(panelDate).setFullYear(type === 'next' ? year + 1 : year - 1));\n setPanelDate(curPanelDate);\n }\n }}\n />\n {type === 'month' && (\n <DatePickerMonth\n panelDate={panelDate}\n monthLabel={monthLabel}\n onSelected={(month, paging) => handleSelectedDate('setMonth', month, paging)}\n />\n )}\n {type === 'year' && (\n <DatePickerYear\n panelDate={panelDate}\n onSelected={(year, paging) => handleSelectedDate('setFullYear', year, paging)}\n />\n )}\n </div>\n }\n >\n <Input\n placeholder=\"请输入日期\"\n readOnly\n {...(inputProps as any)}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n );\n}\n","import React from 'react';\nimport Alert, { AlertProps } from '@uiw/react-alert';\nimport { IProps } from '@uiw/utils';\nimport { NotificationCreateProps } from './index';\n\nexport type Placement = 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight';\n\nexport interface ContainerProps extends IProps {\n placement?: Placement;\n}\nexport interface ContainerState {\n placement?: Placement;\n notifys: ContainerNotifys;\n}\n\nexport type ContainerNotifys = {\n [placement: string]: {\n [key: string]: NotificationCreateProps;\n };\n};\n\nconst notifys: ContainerNotifys = {};\nconst timer: { [key: string]: any } = {};\n\nexport default class Container extends React.Component<ContainerProps, ContainerState> {\n public static defaultProps: ContainerProps = {\n prefixCls: 'w-notify',\n placement: 'topRight',\n };\n public state: ContainerState = {\n notifys: {},\n };\n public create(props: NotificationCreateProps) {\n const { placement, key } = props;\n if (!notifys[placement as Placement]) {\n notifys[placement as Placement] = {};\n }\n props.isOpen = false;\n notifys[placement as Placement][key as string] = props;\n if (props.duration) {\n timer[key as string] = setTimeout(() => {\n this.closed(key as string, placement);\n }, props.duration);\n }\n this.setState(\n {\n notifys,\n placement,\n },\n () => {\n notifys[placement as Placement][key as string].isOpen = true;\n this.setState({ notifys });\n },\n );\n }\n public closed(key: string, placement?: Placement) {\n if (!key || !placement || !notifys[placement][key]) {\n return;\n }\n notifys[placement][key].isOpen = false;\n const props: NotificationCreateProps = notifys[placement][key];\n this.setState({ notifys }, () => {\n clearTimeout(timer[key]);\n delete timer[key];\n delete notifys[placement][key];\n if (props && props.willUnmount) {\n props.willUnmount(props, notifys);\n }\n });\n }\n render() {\n const { prefixCls } = this.props;\n const { placement } = this.state;\n return (\n <React.Fragment>\n {placement &&\n Object.keys(this.state.notifys[placement]).map((key) => {\n const { description, isOpen, ...alertProps } = this.state.notifys[placement][key];\n if (alertProps.type === 'open') {\n delete alertProps.type;\n }\n return (\n <Alert\n className={prefixCls}\n key={key}\n useButton={false}\n width={320}\n {...(alertProps as AlertProps)}\n usePortal={false}\n hasBackdrop={false}\n isOpen={isOpen}\n content={description}\n />\n );\n })}\n </React.Fragment>\n );\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { AlertProps } from '@uiw/react-alert';\nimport { randomid } from '@uiw/utils';\nimport Container, { Placement, ContainerNotifys } from './Container';\nimport './style/index.less';\n\nexport interface NotificationCreateProps extends Omit<AlertProps, 'type'> {\n placement?: Placement;\n description?: React.ReactNode;\n type?: 'primary' | 'danger' | 'open' | 'success' | 'warning' | 'info' | 'error';\n duration?: number;\n key?: string;\n willUnmount?: (props: NotificationCreateProps, notifys: ContainerNotifys) => void;\n}\n\nexport type Notifys = { [key: string]: any };\nexport type NotifysDom = { [key: string]: HTMLDivElement };\n\nconst notifys: Notifys = {};\nconst notifysDom: NotifysDom = {};\n\nexport interface NotificationProps {\n (props: NotificationCreateProps, type: NotificationCreateProps['type']): void;\n [key: string]: () => void;\n}\n\nfunction NotificationCreate(props: NotificationCreateProps, type: NotificationCreateProps['type'] = 'open') {\n if (!props.placement) {\n props.placement = 'topRight';\n }\n props.type = type as NotificationCreateProps['type'];\n if (!props.icon && props.icon !== null) {\n switch (props.type) {\n case 'success':\n props.icon = 'circle-check';\n break;\n case 'warning':\n props.icon = 'warning';\n break;\n case 'info':\n props.icon = 'information';\n break;\n case 'error':\n props.icon = 'circle-close';\n break;\n default:\n break;\n }\n }\n switch (props.type) {\n case 'info':\n props.type = 'primary';\n break;\n case 'error':\n props.type = 'danger';\n break;\n default:\n break;\n }\n\n if (props.placement && !notifys[props.placement]) {\n const div = document.createElement('div');\n document.body.appendChild(div);\n div.className = ['w-notify-warpper', props.placement].filter(Boolean).join(' ').trim();\n notifysDom[props.placement] = div;\n notifys[props.placement] = ReactDOM.render(<Container />, div);\n }\n\n if (props.duration !== null) {\n props.duration = (props.duration || 4.5) * 1000;\n }\n\n if (notifys[props.placement]) {\n notifys[props.placement].create({\n ...props,\n duration: props.duration,\n key: randomid(),\n willUnmount(nprops: any, notifysChild: ContainerNotifys) {\n if (!nprops) return;\n nprops.onClose && nprops.onClose();\n const keys = Object.keys(notifysChild[props.placement as Placement]);\n if (keys.length === 0 && notifys[props.placement as Placement]) {\n delete notifys[props.placement as Placement];\n if (notifysDom[props.placement as Placement]) {\n document.body.removeChild(notifysDom[props.placement as Placement]);\n }\n }\n },\n });\n }\n}\n\n['open', 'success', 'warning', 'info', 'error'].forEach((type) => {\n (NotificationCreate as NotificationProps)[type] = (options: NotificationCreateProps = {}) => {\n return NotificationCreate(options, type as NotificationCreateProps['type']);\n };\n});\n\nexport interface NotificationApi {\n open(option: NotificationCreateProps): void;\n success(option: NotificationCreateProps): void;\n warning(option: NotificationCreateProps): void;\n info(option: NotificationCreateProps): void;\n error(option: NotificationCreateProps): void;\n}\n\nexport default NotificationCreate as unknown as NotificationApi;\n","/**\n * Returns a random text\n */\nexport function randomid(): string {\n return parseInt(String(Math.random() * 1e15), 10).toString(36);\n}\n","import React from 'react';\n\nexport default React.forwardRef<HTMLOptionElement, React.InputHTMLAttributes<HTMLOptionElement>>((props, ref) => (\n <option {...props} ref={ref} />\n));\n","import React from 'react';\n\nexport default React.forwardRef<HTMLOptGroupElement, React.InputHTMLAttributes<HTMLOptGroupElement>>((props, ref) => (\n <optgroup {...props} ref={ref} />\n));\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\nimport Option from './Option';\nimport Group from './Group';\nimport './style/index.less';\n\nexport interface SelectProps extends IProps, Omit<React.SelectHTMLAttributes<HTMLSelectElement>, 'size'> {\n size?: 'large' | 'default' | 'small';\n}\n\nconst Select = React.forwardRef<HTMLSelectElement, SelectProps>((props, ref) => {\n const { prefixCls = 'w-select', className, size = 'default', ...other } = props;\n return (\n <select\n {...other}\n ref={ref}\n className={[prefixCls, className, size ? `${prefixCls}-${size}` : null].filter(Boolean).join(' ').trim()}\n />\n );\n});\n\ntype Select = typeof Select & {\n Option: typeof Option;\n Group: typeof Group;\n};\n\n(Select as Select).Option = Option;\n(Select as Select).Group = Group;\n\nexport default Select as Select;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport Select from '@uiw/react-select';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface PaginationProps extends IProps, Omit<HTMLUlProps, 'onChange'> {\n prefixCls?: string;\n alignment?: 'left' | 'center' | 'right';\n size?: 'default' | 'small';\n pageSizeOptions?: number[];\n total?: number;\n pageSize?: number;\n divider?: boolean;\n current?: number;\n onChange?: (current: number, total: number, pageSize: number) => void;\n onShowSizeChange?: (current: number, pageSize: number) => void;\n}\n\nexport interface PaginationState {\n current: number;\n}\n\nexport interface PaginationItemSourceData {\n type?: string;\n disabled?: boolean;\n active?: boolean;\n label?: number | string;\n goto?: number;\n}\n\nexport default function Pagination(props: PaginationProps) {\n const {\n className,\n style,\n prefixCls = 'w-pagination',\n alignment = 'left',\n size = 'default',\n total = 0,\n pageSize = 10, // The number of pages displayed.\n pageSizeOptions = [],\n current: currentNumber = 1,\n onChange = () => null,\n onShowSizeChange,\n divider,\n ...other\n } = props;\n\n const [current, setCurrent] = useState(currentNumber);\n useEffect(() => setCurrent(currentNumber), [currentNumber]);\n\n const cls = [prefixCls, className, divider ? 'divider' : null, size].filter(Boolean).join(' ').trim();\n\n const initPageSoure = useMemo(() => {\n const data: PaginationItemSourceData[] = [{ type: 'prev', disabled: current === 1 }];\n const count = Math.ceil(total / pageSize);\n const itemCount = count <= 5 ? count : 5;\n let num = 0;\n let basic = 0;\n if (current > 3 && count > 5) {\n data.push({ label: 1 });\n }\n if (current > 4 && count > 6) {\n data.push({ type: 'jumpPrev', label: '•••', goto: 5 });\n }\n while (num < itemCount) {\n num += 1;\n if (current > 3 && count > 5) {\n basic = current - 3;\n }\n let label = num + basic;\n if (count - current === 0 && count > 5) {\n label -= 2;\n }\n if (count - current === 1 && count > 5) {\n label -= 1;\n }\n if (label <= count) {\n data.push({ label, active: current === label });\n }\n }\n if (current + 3 < count && count > 6) {\n data.push({ type: 'jumpNext', label: '•••', goto: 5 });\n }\n if (current + 2 < count && count > 5) {\n data.push({ label: count });\n }\n data.push({ type: 'next', disabled: current === count });\n return data;\n // return [\n // { type: 'prev', disabled: true },\n // { type: 'jumpPrev', label: '•••', goto: 5 },\n // { label: 1 },\n // { label: 2, active: true },\n // { label: 3 },\n // { label: 4 },\n // { type: 'jumpPrev', label: '•••', goto: 5 },\n // { type: 'next' },\n // ];\n }, [current, total, pageSize]);\n\n function handleClick(item: PaginationItemSourceData) {\n if (item.active || item.disabled) {\n return;\n }\n const count = Math.ceil(total / pageSize);\n const state = {} as PaginationState;\n if (item.label) {\n state.current = item.label as number;\n }\n if (item.type === 'prev') {\n state.current = current - 1 > 0 ? current - 1 : 1;\n }\n if (item.type === 'next') {\n state.current = current + 1 <= count ? current + 1 : count;\n }\n if (/^(jumpPrev|jumpNext)/.test(item.type as string) && item.goto) {\n state.current = item.type === 'jumpPrev' ? current - item.goto : current + item.goto;\n if (state.current > count) {\n state.current = count;\n }\n if (state.current < 1) {\n state.current = 1;\n }\n }\n\n setCurrent(state.current);\n onChange && onChange(state.current, total as number, pageSize as number);\n }\n\n const onSizeChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const sizeCount: number = Number(e.target.value);\n const count = Math.ceil(total / sizeCount);\n const newCurrent: number = current > count ? count : current;\n onShowSizeChange && onShowSizeChange(newCurrent, sizeCount);\n };\n\n return (\n <ul className={cls} style={{ ...style, textAlign: alignment }} {...other}>\n {initPageSoure.map((item: PaginationItemSourceData, idx) => {\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\n let label = <a>{item.label}</a>;\n if (/^(prev|next)$/.test(item.type as string)) {\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\n label = <a className={`arrow ${item.type}`} />;\n }\n return (\n <li\n className={[item.active ? 'active' : null, item.disabled ? 'disabled' : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n onClick={() => handleClick(item)}\n key={idx}\n >\n {label}\n </li>\n );\n })}\n {pageSizeOptions.length > 0 && (\n <li className={`${prefixCls}-options`}>\n <Select size={size} defaultValue={pageSize} onChange={onSizeChange}>\n {pageSizeOptions.map((item: number, index: number) => (\n <Select.Option value={item} key={index}>\n {item}条/页\n </Select.Option>\n ))}\n </Select>\n </li>\n )}\n </ul>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport Input, { InputProps } from '@uiw/react-input';\nimport './style/input.less';\n\nexport interface PinCodeProps extends IProps {\n value?: string[];\n disabled?: boolean;\n onChange?: (value: string[]) => void;\n onBlur?: InputProps['onBlur'];\n onFocus?: InputProps['onFocus'];\n autoFocus?: boolean;\n size?: InputProps['size'];\n placeholder?: string;\n}\n\nfunction InternalPinCode(props: PinCodeProps = {}, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-pin-code',\n placeholder = '○',\n value = [],\n autoFocus,\n className,\n size = 'default',\n style,\n disabled,\n onChange = noop,\n onBlur = noop,\n onFocus = noop,\n ...otherProps\n } = props;\n const [input] = useState<{\n [key: string]: HTMLInputElement;\n }>({});\n const [placehold, setPlacehold] = useState(placeholder);\n const [values, setValues] = useState(value);\n const cls = [prefixCls, className, size ? `${prefixCls}-${size}` : null, disabled ? 'disabled' : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n function handleChange(e: React.ChangeEvent<HTMLInputElement>, idx: number) {\n let val = e.target.value;\n val = val.charAt(val.length - 1);\n const arr = [...values];\n if (Number(val) > -1 && val) {\n e.currentTarget.value = val;\n arr[idx] = val;\n if (input[idx + 1]) {\n input[idx + 1].focus();\n }\n setValues(arr);\n } else if (!val) {\n arr[idx] = '';\n setValues(arr);\n }\n }\n function handleKeyDown(e: React.KeyboardEvent<HTMLInputElement>, idx: number) {\n let val = e.currentTarget.value;\n const key = e.key.toLocaleLowerCase();\n if (!val && input[idx - 1] && /(backspace|delete)/.test(key)) {\n input[idx - 1].focus();\n }\n }\n useEffect(() => {\n if (values !== value) {\n onChange(values);\n }\n }, [values]);\n\n function handleBlur(event: React.FocusEvent<HTMLInputElement>) {\n setPlacehold(placeholder);\n onBlur(event);\n }\n function handleFocus(event: React.FocusEvent<HTMLInputElement>) {\n setPlacehold('');\n onFocus(event);\n }\n\n return (\n <div className={cls} style={style} {...otherProps} ref={ref}>\n {[...values].map((val, key) => {\n const inpProps: InputProps = {\n min: 0,\n type: 'text',\n inputMode: 'numeric',\n autoComplete: 'off',\n value: val,\n onChange: (e) => handleChange(e, key),\n onKeyDown: (e) => handleKeyDown(e, key),\n onBlur: (e) => handleBlur(e),\n onFocus: (e) => handleFocus(e),\n className: `${prefixCls}-inner`,\n placeholder: placehold,\n disabled,\n size,\n };\n if (autoFocus && key === 0) {\n inpProps.autoFocus = true;\n }\n const child = (\n <Input\n ref={(instance) => {\n if (instance) {\n input[key] = instance;\n }\n }}\n {...inpProps}\n key={key}\n />\n );\n return child;\n })}\n </div>\n );\n}\n\nexport default React.forwardRef<HTMLDivElement, PinCodeProps>(InternalPinCode);\n","import React from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\n\nexport function IconProgress<T>(props: { type: IconProps<T>['type'] }): JSX.Element {\n return <Icon type={props.type} />;\n}\n","import React from 'react';\nimport { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport { IconProgress } from './utils';\nimport './style/index.less';\nimport './style/circle.less';\n\nexport type Status = 'success' | 'active' | 'exception';\nexport interface ProgressCircleProps<T> extends IProps, HTMLDivProps {\n type?: IconProps<T>['type'];\n status?: Status;\n showText?: boolean; // 是否显示进度条文字内容\n percent?: number; // 百分比(必填)\n width?: number; // 圆圈进度条画布宽度\n strokeWidth?: number; // 进度条大小设置\n format?: (percent: number) => React.ReactNode;\n}\n\nexport default class Circle<T> extends React.Component<ProgressCircleProps<T>> {\n public static defaultProps: ProgressCircleProps<{}> = {\n prefixCls: 'w-progress',\n showText: true,\n percent: 0, // 百分比(必填)\n width: 126, // 圆圈进度条画布宽度\n strokeWidth: 6, // 进度条大小设置\n };\n relativeStrokeWidth(type: 'track' | 'bg' | undefined, elm: SVGPathElement) {\n const { strokeWidth, percent } = this.props;\n if (elm && elm.parentNode) {\n const { width } = (elm.parentNode as SVGAElement).getBoundingClientRect();\n const _strokeWidth: string = (((strokeWidth as number) / width) * 100).toFixed(1);\n const radius = parseInt((50 - parseFloat(_strokeWidth) / 2).toString(), 10);\n elm.setAttribute('stroke-width', _strokeWidth);\n elm.setAttribute(\n 'd',\n `M 50 50 m 0 -${radius} a ${radius} ${radius} 0 1 1 0 ${radius * 2} a ${radius} ${radius} 0 1 1 0 -${\n radius * 2\n }`,\n );\n if (type === 'track') {\n // 计算周长\n const perimeter = 2 * Math.PI * radius;\n elm.setAttribute(\n 'style',\n `stroke-dasharray:${perimeter}px,${perimeter}px;stroke-dashoffset:${\n (1 - (percent as number) / 100) * perimeter\n }px;transition: stroke-dashoffset 0.6s ease 0s, stroke 0.6s ease;`,\n );\n }\n }\n }\n render() {\n const { prefixCls, style, type, className, showText, percent, format, strokeWidth, width, status, ...resetProps } =\n this.props;\n const cls = [\n prefixCls,\n className,\n `${prefixCls}-circle`,\n showText ? `${prefixCls}-show-text` : null,\n status ? `${prefixCls}-status-${status}` : null,\n parseInt((percent as number).toString(), 10) >= 100 ? `${prefixCls}-status-success` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n let progressInfo;\n const progressStatus =\n parseInt((percent as number).toString(), 10) >= 100 && !('status' in this.props) ? 'success' : status;\n if (showText) {\n let percentView: React.ReactNode = `${percent}%`;\n if (progressStatus === 'exception') {\n percentView = <IconProgress type=\"close\" />;\n } else if (progressStatus === 'success') {\n percentView = <IconProgress type=\"check\" />;\n }\n progressInfo = (\n <span className={`${prefixCls}-text`} style={{ fontSize: (width as number) * 0.16 + 6 }}>\n {format ? format(percent as number) : percentView}\n </span>\n );\n }\n return (\n <div className={cls} style={style} {...resetProps}>\n <svg viewBox=\"0 0 100 100\" width={`${width}`}>\n <path ref={this.relativeStrokeWidth.bind(this, 'bg')} className={`${prefixCls}-trail`} fill=\"none\" />\n <path\n ref={this.relativeStrokeWidth.bind(this, 'track')}\n strokeLinecap=\"round\"\n className={`${prefixCls}-stroke`}\n fill=\"none\"\n />\n </svg>\n {progressInfo}\n </div>\n );\n }\n}\n","import React from 'react';\nimport { IconProgress } from './utils';\nimport { ProgressCircleProps } from './Circle';\nimport './style/index.less';\nimport './style/line.less';\n\nexport interface ProgressLineProp<T> extends ProgressCircleProps<T> {}\n\nexport default class Line<T> extends React.Component<ProgressLineProp<T>> {\n public static defaultProps: ProgressLineProp<{}> = {\n prefixCls: 'w-progress',\n showText: true, // 是否显示进度条文字内容\n percent: 0, // 百分比(必填)\n width: 126, // 圆圈进度条画布宽度\n strokeWidth: 6, // 进度条大小设置\n };\n render() {\n const { prefixCls, style, className, showText, percent, format, strokeWidth, width, status, ...resetProps } =\n this.props;\n const cls = [\n prefixCls,\n className,\n `${prefixCls}-line`,\n showText ? `${prefixCls}-show-text` : null,\n status ? `${prefixCls}-status-${status}` : null,\n parseInt((percent as number).toString(), 10) >= 100 ? `${prefixCls}-status-success` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n let progressInfo;\n if (showText) {\n const progressStatus =\n parseInt((percent as number).toString(), 10) >= 100 && !('status' in this.props) ? 'success' : status;\n let percentView: React.ReactNode = `${percent}%`;\n if (progressStatus === 'exception') {\n percentView = <IconProgress type=\"circle-close\" />;\n } else if (progressStatus === 'success') {\n percentView = <IconProgress type=\"circle-check\" />;\n }\n progressInfo = <span className={`${prefixCls}-text`}>{format ? format(percent as number) : percentView}</span>;\n }\n const percentStyle = {\n width: `${percent}%`,\n height: strokeWidth,\n };\n return (\n <div className={cls} style={style} {...resetProps}>\n <div className={`${prefixCls}-bar`}>\n <div className={`${prefixCls}-inner`}>\n <div className={`${prefixCls}-bg`} style={percentStyle} />\n </div>\n </div>\n {progressInfo}\n </div>\n );\n }\n}\n","import Circle from './Circle';\nimport Line from './Line';\n\nexport * from './Circle';\nexport * from './Line';\n\nexport default {\n Line,\n Circle,\n};\n","import React, { useState, useMemo } from 'react';\nimport { IProps, HTMLDivProps, HTMLSpanProps, noop } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface RateProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n value?: number;\n readOnly?: boolean;\n allowHalf?: boolean;\n count?: number;\n color?: string;\n disabled?: boolean;\n character?: React.ReactNode;\n onChange?: (key: number) => void;\n onHoverChange?: (key: number) => void;\n}\n\nexport default function Rate(props: RateProps = {}) {\n const {\n prefixCls = 'w-rate',\n count = 5,\n value: defValue = 0,\n className,\n allowHalf,\n character = '★',\n readOnly = false,\n disabled,\n onChange = noop,\n onHoverChange = noop,\n color,\n ...other\n } = props;\n const [value, setValue] = useState(defValue);\n const [hoverCount, setHoverCount] = useState(-1);\n const cls = [prefixCls, className, disabled ? 'disabled' : null].filter(Boolean).join(' ').trim();\n const [prevValue, setPrevValue] = useState<number>();\n if (defValue !== prevValue) {\n setPrevValue(defValue);\n }\n\n useMemo(() => {\n if (value !== prevValue) {\n setValue(defValue);\n }\n }, [prevValue]);\n\n function onMouseLeave() {\n setHoverCount(-1);\n }\n\n function getValue(e: React.MouseEvent<HTMLElement>, key: number) {\n e.persist();\n let currentValue = key;\n const isLeft =\n e.clientX - e.currentTarget.getBoundingClientRect().left <= e.currentTarget.getBoundingClientRect().width / 2;\n if (allowHalf) {\n e.persist();\n currentValue = isLeft ? key + 0.5 : key + 1;\n } else {\n currentValue = key + 1;\n }\n return currentValue;\n }\n\n function onMouseMove(e: React.MouseEvent<HTMLElement>, key: number) {\n const currentValue = getValue(e, key);\n if (hoverCount !== currentValue) {\n setHoverCount(currentValue);\n onHoverChange(currentValue);\n }\n }\n function onClick(e: React.MouseEvent<HTMLElement>, key: number) {\n if (readOnly) return;\n const currentValue = getValue(e, key);\n setValue(currentValue);\n onChange(currentValue);\n }\n return (\n <div {...other} className={cls} onMouseLeave={() => onMouseLeave()}>\n {[...Array(count)].map((_, idx) => {\n const halfon =\n (value <= idx + 0.5 && Math.ceil(value) - 1 === idx && hoverCount === -1) || hoverCount === idx + 0.5;\n const activeCls = [\n `${prefixCls}-hight`,\n idx + 1 <= value && hoverCount === -1 ? 'star-on' : null,\n idx + 1 <= hoverCount ? 'hover-on' : null,\n halfon ? 'half-on' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const props: HTMLSpanProps = {};\n if (!readOnly) {\n props.onClick = (e) => onClick(e, idx);\n props.onMouseMove = (e) => onMouseMove(e, idx);\n }\n return (\n <span key={idx} {...props}>\n <span style={{ color }} className={activeCls}>\n {character}\n </span>\n <span className={`${prefixCls}-bg`}>{character}</span>\n </span>\n );\n })}\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLSpanProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface TagProps extends IProps, Omit<HTMLSpanProps, 'title'> {\n color?: string;\n disabled?: boolean;\n visible?: boolean;\n bordered?: boolean;\n light?: boolean;\n closable?: boolean;\n title?: React.ReactNode;\n onClose?: (e: React.MouseEvent<SVGSVGElement, MouseEvent>) => void;\n}\n\nexport default (props: TagProps = {}) => {\n const {\n prefixCls = 'w-tag',\n className,\n style,\n title = '',\n children,\n visible = true,\n color = '#6E6E6E',\n disabled = false,\n bordered = true,\n closable,\n light = false,\n onClose,\n ...other\n } = props;\n const cls = [prefixCls, className, light ? `${prefixCls}-light` : null, disabled ? 'disabled' : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n const styl: React.CSSProperties = { ...style };\n if (!light) {\n styl.color = '#fff';\n styl.backgroundColor = color;\n } else {\n styl.color = color;\n styl.borderColor = color;\n if (bordered && light) {\n styl.boxShadow = `inset 0 0 0 1px ${color}`;\n }\n }\n if (!visible) {\n return null;\n }\n\n return (\n <span className={cls} style={styl} {...other}>\n {title || children}\n {!disabled && closable ? (\n <svg onClick={onClose} className={`${prefixCls}-close`} width=\"15\" height=\"15\" viewBox=\"0 0 16 16\">\n <path d=\"M9.41 8l2.29-2.29c.19-.18.3-.43.3-.71a1.003 1.003 0 0 0-1.71-.71L8 6.59l-2.29-2.3a1.003 1.003 0 0 0-1.42 1.42L6.59 8 4.3 10.29c-.19.18-.3.43-.3.71a1.003 1.003 0 0 0 1.71.71L8 9.41l2.29 2.29c.18.19.43.3.71.3a1.003 1.003 0 0 0 .71-1.71L9.41 8z\" />\n </svg>\n ) : null}\n </span>\n );\n};\n","import React, { useMemo } from 'react';\nimport Dropdown, { DropdownProps } from '@uiw/react-dropdown';\nimport Icon from '@uiw/react-icon';\nimport Menu from '@uiw/react-menu';\nimport Input from '@uiw/react-input';\nimport Tag, { TagProps } from '@uiw/react-tag';\nimport { IProps } from '@uiw/utils';\nimport { useState } from 'react';\nimport { useRef } from 'react';\nimport { useEffect } from 'react';\nimport './style/index.less';\n\ntype ValueType = string | number;\nexport interface SearchSelectProps extends IProps, DropdownProps {\n mode?: 'single' | 'multiple';\n size?: 'large' | 'default' | 'small';\n maxTagCount?: number;\n valueAmount?: number;\n labelInValue?: boolean;\n loading?: boolean;\n showSearch?: boolean;\n allowClear?: boolean;\n defaultValue?: ValueType | Array<ValueType>;\n tagProps?: TagProps;\n value?: ValueType | Array<ValueType>;\n option: SearchSelectOptionData[];\n onSelect?: (value: ValueType | Array<ValueType> | Array<SearchSelectOptionData>) => void;\n onSearch?: (value: string) => void;\n onChange?: (value: ValueType | Array<ValueType> | Array<SearchSelectOptionData>) => void;\n}\n\nexport interface SearchSelectOptionData {\n label: string;\n value: string | number;\n [keyName: string]: any;\n}\n\nexport default function SearchSelect(props: SearchSelectProps) {\n const {\n allowClear = false,\n disabled = false,\n valueAmount,\n size = 'default',\n option = [],\n maxTagCount,\n loading = false,\n labelInValue = false,\n prefixCls = 'w-search-select',\n className,\n mode = 'single',\n style,\n isOpen,\n value,\n defaultValue,\n showSearch,\n tagProps = {},\n placeholder,\n onSearch,\n onChange,\n onSelect,\n ...others\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const isMultiple = useMemo(() => mode === 'multiple', [mode]);\n const [innerIsOpen, setInnerIsOpen] = useState(false);\n const [selectedValue, setSelectedValue] = useState<Array<SearchSelectOptionData>>([]);\n const [selectedLabel, setSelectedLabel] = useState<string>('');\n const [selectIconType, setSelectIconType] = useState('');\n const inputRef = useRef<HTMLInputElement>(null);\n const omitTagCount = useMemo(\n () => (maxTagCount && selectedValue.length > maxTagCount ? selectedValue.length - maxTagCount : 0),\n [selectedValue.length],\n );\n const divRef = useRef<HTMLDivElement>(null);\n\n const valueVerify = (value: ValueType | Array<ValueType> | undefined) => {\n return value !== undefined && value !== '';\n };\n\n const valueRef = useRef<Array<SearchSelectOptionData>>();\n valueRef.current = useMemo(() => selectedValue, [selectedValue]);\n\n useEffect(() => {\n if (!valueVerify(value) && valueVerify(defaultValue)) {\n selectedValueChange(defaultValue!);\n }\n }, []);\n\n useEffect(() => {\n if (disabled) {\n setInnerIsOpen(false);\n }\n }, [disabled]);\n\n useEffect(() => {\n if (valueVerify(value)) {\n selectedValueChange(value!);\n }\n }, [JSON.stringify(value)]);\n\n const getSelectOption = (option: Array<SearchSelectOptionData>, value: ValueType) => {\n const findResult = option.find((item) => item.value === value);\n return findResult;\n };\n\n function selectedValueChange(\n changeValue: ValueType | Array<ValueType> | SearchSelectOptionData | Array<SearchSelectOptionData>,\n ) {\n let opts: Array<SearchSelectOptionData> = [];\n if (labelInValue) {\n if (Array.isArray(changeValue)) {\n opts = changeValue as Array<SearchSelectOptionData>;\n } else {\n opts.push(changeValue as SearchSelectOptionData);\n }\n } else {\n if (Array.isArray(changeValue)) {\n opts = changeValue.map((v) => getSelectOption(option, v as ValueType)!).filter((m) => !!m);\n } else {\n const findResult = getSelectOption(option, changeValue as ValueType);\n if (findResult) {\n setSelectedLabel(findResult.label);\n opts.push(findResult);\n }\n }\n }\n\n if (!isMultiple && opts.length > 0) setSelectedLabel(opts[0].label || '');\n setSelectedValue(opts.slice(0, valueAmount));\n }\n\n function removeSelectItem(index: number) {\n const selectedValue = valueRef.current as SearchSelectOptionData[];\n selectedValue.splice(index, 1);\n const values = [...selectedValue];\n return values;\n }\n\n const selectedLabelChange = (value: string) => {\n setSelectedLabel(value);\n showSearch && onSearch?.(value);\n };\n\n function handleItemClick(item: SearchSelectOptionData) {\n setInnerIsOpen(false);\n const values = [item];\n setSelectedLabel(item.label);\n const resultValue = item.value;\n handleChange(resultValue, values);\n }\n\n function handleItemsClick(index: number, item?: SearchSelectOptionData) {\n let values: SearchSelectOptionData[] =\n index !== -1\n ? removeSelectItem(index)\n : [...selectedValue.slice(0, valueAmount ? valueAmount - 1 : undefined), item!];\n const resultValue = values.map((item) => item.value);\n handleChange(resultValue, values);\n }\n\n function handleChange(resultValue: ValueType | Array<ValueType>, values: SearchSelectOptionData[]) {\n setSelectedLabel('');\n onSelect && onSelect(resultValue);\n handleSelectChange(resultValue, values); // 支持form组件\n\n value === undefined && setSelectedValue(values); // 如果受控于父组件则不需要内部维护状态\n }\n\n // 渲染icon\n function renderSelectIcon(type: string) {\n let selectIconType;\n if (type === 'enter' && allowClear && (selectedValue.length > 0 || selectedLabel)) {\n selectIconType = 'close';\n } else {\n selectIconType = '';\n }\n setSelectIconType(selectIconType);\n }\n // handle change\n function handleInputChange(value: string) {\n setInnerIsOpen(true);\n setSelectIconType(showSearch && value ? 'loading' : '');\n // setSelectedLabel(value);\n // showSearch && onSearch && onSearch(value);\n selectedLabelChange(value);\n }\n // 清除选中的值\n function resetSelectedValue(e: React.MouseEvent<any, MouseEvent>) {\n e.stopPropagation();\n inputRef.current?.focus();\n setSelectedValue([]);\n handleInputChange('');\n setInnerIsOpen(false);\n handleSelectChange('', []);\n }\n function handleSelectChange(value: ValueType | Array<ValueType>, options: Array<SearchSelectOptionData>) {\n if (!onChange) return;\n\n onChange(labelInValue ? options : value);\n }\n\n function inputKeyDown(e: any) {\n if (isMultiple && selectedValue.length > 0 && !selectedLabel && e.keyCode === 8) {\n handleItemsClick(selectedValue.length - 1);\n }\n }\n\n function onVisibleChange(isOpen: boolean) {\n const selectedValue = valueRef.current as SearchSelectOptionData[];\n setInnerIsOpen(isOpen);\n if (!isOpen) selectedLabelChange('');\n if (!isMultiple && selectedValue.length > 0) {\n setSelectedLabel(selectedValue[0].label);\n }\n }\n\n return (\n <Dropdown\n className={cls}\n trigger=\"click\"\n style={{ marginTop: 5 }}\n overlayStyl={{ width: 100 }}\n disabled={disabled}\n {...others}\n onVisibleChange={onVisibleChange}\n isOpen={innerIsOpen}\n menu={\n <Menu\n bordered\n style={{\n minHeight: 25,\n maxHeight: 280,\n minWidth: style?.width ?? 200,\n overflowY: 'scroll',\n width: style?.width,\n }}\n >\n {!option || option.length === 0 ? (\n <div style={{ color: '#c7c7c7', fontSize: 12 }}>{loading ? '正在加载数据...' : '没有数据'}</div>\n ) : (\n option.map((item) => {\n const index = selectedValue.findIndex((finds) => finds.value === item.value);\n return (\n <Menu.Item\n active={index !== -1}\n key={index}\n text={item.label}\n onClick={() => (isMultiple ? handleItemsClick(index, item) : handleItemClick(item))}\n />\n );\n })\n )}\n </Menu>\n }\n >\n <div\n ref={divRef}\n onMouseOver={() => renderSelectIcon('enter')}\n onMouseLeave={() => renderSelectIcon('leave')}\n onClick={() => inputRef.current?.focus()}\n style={{ width: '100%', maxWidth: 'none', ...style }}\n >\n {isMultiple ? (\n <div className={`${prefixCls}-inner`}>\n <div style={{ display: 'flex', flexFlow: 'wrap', width: '100%' }}>\n {isMultiple &&\n selectedValue.slice(0, maxTagCount).map((item, index) => {\n return (\n <Tag\n style={{ height: 20, margin: 1, display: 'flex', alignItems: 'center', ...tagProps.style }}\n className={`${prefixCls}-tag`}\n key={index}\n color=\"#393E48\"\n {...tagProps}\n closable\n disabled={disabled}\n onClose={(e) => {\n e.stopPropagation();\n handleItemsClick(index, item);\n }}\n >\n {item.label}\n </Tag>\n );\n })}\n {!!omitTagCount && (\n <Tag style={{ height: 20, margin: 1, display: 'flex', alignItems: 'center' }} disabled={true}>\n +{omitTagCount} …{' '}\n </Tag>\n )}\n <Input\n style={{ flex: 1 }}\n className={`${prefixCls}-input-contents`}\n readOnly={!showSearch}\n size={size}\n ref={inputRef}\n disabled={disabled}\n onKeyDown={inputKeyDown}\n onChange={(e) => handleInputChange(e.target.value)}\n value={selectedLabel}\n placeholder={selectedValue.length ? '' : placeholder}\n />\n </div>\n {!disabled && (selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon\n className={`${prefixCls}-multiple-colse`}\n type={selectIconType}\n spin={loading && selectIconType === 'loading'}\n onClick={resetSelectedValue}\n />\n )}\n </div>\n ) : (\n <Input\n readOnly={!showSearch}\n size={size}\n ref={inputRef}\n disabled={disabled}\n onChange={(e) => handleInputChange(e.target.value)}\n value={selectedLabel}\n placeholder={placeholder}\n addonAfter={\n !disabled &&\n (selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon\n type={selectIconType}\n className={`${prefixCls}-singe-colse`}\n color=\"#393e48\"\n spin={loading && selectIconType === 'loading'}\n onClick={resetSelectedValue}\n />\n )\n }\n />\n )}\n </div>\n </Dropdown>\n );\n}\n","import React, { useEffect, useRef, useState } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Step, { StepProps } from './Step';\n\nexport interface StepsProps<T> extends IProps, HTMLDivProps {\n status?: StepProps['status'];\n progressDot?: StepProps['progressDot'];\n direction?: 'horizontal' | 'vertical';\n /**\n * 指定当前步骤,从 `0` 开始记数。\n */\n current?: number;\n}\n\nfunction InternalSteps<T>(props: StepsProps<T>) {\n const {\n prefixCls = 'w-steps',\n style = {},\n className,\n children,\n current,\n status = 'process',\n progressDot = false,\n direction = 'horizontal',\n ...resetProps\n } = props;\n\n const warpRef = useRef<HTMLDivElement>(null);\n const [lastStepOffsetWidth, setLastStepOffsetWidth] = useState(0);\n const filteredChildren = React.Children.toArray(children).filter((c) => !!c);\n const lastIndex = filteredChildren.length - 1; // 最后一个节点的索引数字\n const classString = [prefixCls, `${prefixCls}-${direction}`, !!progressDot ? `${prefixCls}-dot` : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n useEffect(() => calcStepOffsetWidth());\n\n // 计算每一步的宽度\n function calcStepOffsetWidth() {\n const domNode = warpRef.current;\n if (domNode && domNode.lastChild) {\n const width = ((domNode.lastChild as HTMLElement).offsetWidth || 0) + 1;\n if (width === lastStepOffsetWidth || Math.abs(width - lastStepOffsetWidth) <= 3) {\n return;\n }\n setLastStepOffsetWidth(width);\n }\n }\n\n return (\n <div className={classString} style={style} {...resetProps} ref={warpRef}>\n {React.Children.map(children, (child: any, index) => {\n const childProps = {\n stepNumber: `${index + 1}`,\n prefixCls,\n progressDot,\n ...child.props,\n };\n if (index !== lastIndex && direction !== 'vertical') {\n childProps.itemWidth = `${100 / lastIndex}%`;\n childProps.adjustMarginRight = -Math.round(lastStepOffsetWidth / lastIndex + 1);\n }\n\n if (progressDot && direction !== 'vertical') {\n childProps.itemWidth = `${100 / filteredChildren.length}%`;\n childProps.adjustMarginRight = 0;\n }\n // 错误前面\n if (status === 'error' && index === (current as number) - 1) {\n childProps.className = `${prefixCls}-next-error`;\n }\n if (!child.props.status) {\n if (index === current!) {\n childProps.status = status;\n } else if (index < (current as number)) {\n childProps.status = 'finish';\n } else {\n childProps.status = 'wait';\n }\n }\n return React.cloneElement(child, childProps);\n })}\n </div>\n );\n}\n\ntype Steps = typeof InternalSteps & {\n Step: typeof Step;\n};\n\n(InternalSteps as Steps).Step = Step;\n\nexport default InternalSteps as Steps;\n","import React, { CSSProperties } from 'react';\nimport Icon, { IconProps, IconsName } from '@uiw/react-icon';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface StepProps extends IProps, Omit<HTMLDivProps, 'title'> {\n title?: React.ReactNode;\n description?: React.ReactNode;\n status?: 'wait' | 'process' | 'finish' | 'error' | 'success';\n progressDot?: boolean;\n itemWidth?: number;\n stepNumber?: string;\n adjustMarginRight?: number;\n icon?: IconProps['type'];\n}\n\nexport default function Step(props: StepProps) {\n const {\n prefixCls = 'w-steps',\n className,\n style,\n status,\n itemWidth,\n icon,\n adjustMarginRight,\n stepNumber,\n title,\n description,\n progressDot,\n ...restProps\n } = props;\n const classString = [\n `${prefixCls}-item`,\n `${prefixCls}-item-${status}`,\n className,\n icon ? `${prefixCls}-custom` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const stepItemStyle: CSSProperties = { ...style };\n const stepItemDotStyle: CSSProperties = {};\n if (itemWidth) {\n stepItemStyle.width = itemWidth;\n }\n if (adjustMarginRight) {\n stepItemStyle.marginRight = adjustMarginRight;\n if (progressDot) {\n stepItemDotStyle.paddingRight = Math.abs(adjustMarginRight);\n }\n }\n let iconNode = null;\n if (progressDot) {\n iconNode = <span className={`${prefixCls}-dot`} />;\n } else if (icon && typeof icon !== 'string') {\n iconNode = <span className={`${prefixCls}-icon`}>{icon}</span>;\n } else if ((icon && typeof icon === 'string') || status === 'finish' || status === 'error') {\n iconNode = (\n <Icon\n type={\n [\n icon && typeof icon === 'string' ? `${icon}` : null,\n !icon && status === 'finish' ? 'check' : null,\n !icon && status === 'error' ? 'close' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim() as IconsName | null\n }\n />\n );\n } else {\n iconNode = <span className={`${prefixCls}-icon`}>{stepNumber}</span>;\n }\n return (\n <div {...restProps} className={classString} style={stepItemStyle}>\n <div className={`${prefixCls}-item-tail`} style={stepItemDotStyle}>\n <i style={{ paddingRight: '100%' }} />\n </div>\n <div className={`${prefixCls}-item-head`}>\n <div className={[`${prefixCls}-item-inner`, !!icon && 'is-icon'].filter(Boolean).join(' ').trim()}>\n {iconNode}\n </div>\n </div>\n <div className={`${prefixCls}-item-main`}>\n <div className={`${prefixCls}-item-title`}>{title}</div>\n {description && <div className={`${prefixCls}-item-description`}>{description}</div>}\n </div>\n </div>\n );\n}\n","import Steps from './Steps';\n\nexport * from './Steps';\nexport * from './Step';\n\nexport default Steps;\n","import React from 'react';\nimport { HTMLDivProps } from '@uiw/utils';\nimport { SliderProps, SliderMarks } from './index';\n\ninterface TooltipProps extends HTMLDivProps {\n prefixCls: string;\n data: number[];\n step: number;\n min: number;\n vertical: boolean;\n marks: SliderProps['marks'];\n markRender: (stepValue: number, mark?: SliderMarks) => React.ReactNode;\n}\n\nexport default function Dots(props: TooltipProps) {\n const { prefixCls, data, step, min, vertical, marks, markRender } = props;\n return (\n <div className={`${prefixCls}-dots`}>\n {data.map((val, idx) => {\n const stepValue = idx * step + min;\n return (\n <div\n key={idx}\n style={{\n [vertical ? 'top' : 'left']: `${val}%`,\n }}\n className={[`${prefixCls}-mark`, marks && marks !== true && !marks[stepValue] ? 'no-marks' : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {marks === true && markRender && markRender(stepValue)}\n {marks !== true && marks && marks[stepValue] && markRender && markRender(stepValue, marks[stepValue])}\n </div>\n );\n })}\n </div>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Dots from './Dots';\nimport './style/index.less';\n\nexport type SliderMarks = {\n style?: React.CSSProperties;\n label?: React.ReactNode;\n};\n\nexport interface SliderProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n value?: number | number[];\n min?: number;\n max?: number;\n marks?: boolean | Record<number, SliderMarks>;\n dots?: boolean;\n range?: boolean;\n vertical?: boolean;\n step?: number;\n disabled?: boolean;\n tooltip?: boolean;\n progress?: boolean | string;\n renderMarks?: (value: number) => JSX.Element;\n onChange?: (value: number | number[]) => void;\n onClick?: (e: React.MouseEvent<HTMLElement>) => void;\n}\n\nexport default function Slider(props: SliderProps) {\n const {\n prefixCls = 'w-slider',\n value = 0,\n min = 0,\n max = 100,\n dots = false,\n step = 1,\n disabled = false,\n progress = true,\n tooltip = false,\n className,\n marks,\n renderMarks,\n vertical,\n onChange,\n ...other\n } = props;\n\n const bar = React.useRef<HTMLDivElement>(null);\n const slider = React.useRef<HTMLDivElement>(null);\n const indexBar = React.useRef<number>();\n const startX = React.useRef<number>();\n const curValue = React.useRef<number | number[]>();\n const barWidth = React.useRef<number>();\n const barOffsetLeft = React.useRef<number>();\n const move = React.useRef<boolean>();\n const [arrValue, setArrValue] = useState(Array.isArray(value) ? value : [value]);\n\n useEffect(() => setArrValue(Array.isArray(value) ? value : [value]), [value]);\n\n other.onClick = (evn: React.MouseEvent<HTMLElement>) => {\n if (move.current !== undefined) {\n return;\n }\n const markOffset = slider.current!.getBoundingClientRect();\n const vals = getWidthToValue(evn[vertical ? 'clientY' : 'clientX'] - markOffset[vertical ? 'y' : 'x']);\n const curr = getRangeValue(vals);\n handleChange(curr);\n };\n\n function getRangeValue(val: number | number[]) {\n if (!Array.isArray(value)) {\n return Array.isArray(val) ? val : [val];\n }\n const newData = [...arrValue];\n const val1 = newData[0];\n const val2 = newData[1];\n if ((val1 < val2 && val1 > val) || (val1 > val2 && val1 < val)) {\n newData[0] = val as number;\n }\n if ((val1 < val2 && val2 < val) || (val1 > val2 && val2 > val)) {\n newData[1] = val as number;\n }\n\n if (val1 > val && val2 < val) {\n const half = val2 + (val1 - val2) / 2;\n if (half >= val) {\n newData[1] = val as number;\n }\n if (half < val) {\n newData[0] = val as number;\n }\n }\n if (val2 > val && val1 < val) {\n const half = val1 + (val2 - val1) / 2;\n if (half >= val) {\n newData[0] = val as number;\n }\n if (half < val) {\n newData[1] = val as number;\n }\n }\n return newData;\n }\n\n function handleChange(val: number[]) {\n setArrValue([...val]);\n onChange && onChange(arrValue.length === 1 ? val[0] : val);\n }\n\n function getWidthToValue(width: number) {\n const equal = (max - min) / step;\n let percent = 0;\n if (slider.current) {\n percent = (width / slider.current[vertical ? 'clientHeight' : 'clientWidth']) * 100;\n }\n\n if (percent <= 0) {\n percent = 0;\n }\n if (percent >= 100) {\n percent = 100;\n }\n\n const num = equal * (percent / 100) + 0.5;\n const numFloor = Math.floor(num);\n const vals = numFloor * step + min;\n return vals;\n }\n\n function onHandleBtnDown(idx: number, env: React.MouseEvent<HTMLElement>) {\n if (disabled) {\n return;\n }\n indexBar.current = idx;\n move.current = true;\n startX.current = env[vertical ? 'clientY' : 'clientX'];\n if (bar.current) {\n barWidth.current = bar.current[vertical ? 'clientHeight' : 'clientWidth'];\n barOffsetLeft.current = bar.current[vertical ? 'offsetTop' : 'offsetLeft'];\n }\n const vals = [...arrValue];\n if (Array.isArray(value)) {\n barWidth.current =\n (indexBar.current === 1 && vals[1] > vals[0]) || (indexBar.current !== 1 && vals[0] > vals[1])\n ? barWidth.current! + barOffsetLeft.current!\n : barOffsetLeft.current;\n }\n window.addEventListener('mousemove', onDragging);\n window.addEventListener('mouseup', onDragEnd);\n }\n function onDragging(env: MouseEvent | React.MouseEvent<HTMLButtonElement, MouseEvent>) {\n if (!move.current) {\n return;\n }\n const vals = [...arrValue];\n const valueToWidth = getWidthToValue(env[vertical ? 'clientY' : 'clientX'] - startX.current! + barWidth.current!);\n if (valueToWidth !== curValue.current) {\n vals[indexBar.current!] = valueToWidth;\n const barStyl = getStyle(vals);\n if (bar.current) {\n bar.current.style[vertical ? 'top' : 'left'] = barStyl.left;\n bar.current.style[vertical ? 'bottom' : 'right'] = barStyl.right;\n }\n handleChange(vals);\n curValue.current = valueToWidth;\n }\n }\n function onDragEnd() {\n move.current = undefined;\n window.removeEventListener('mousemove', onDragging, false);\n window.removeEventListener('mouseup', onDragEnd, false);\n }\n\n const stepArray = () => {\n const equal = (max - min) / step;\n const stepWidth = (100 * step) / (max - min);\n const result = [0];\n for (let i = 1; i < equal; i += 1) {\n result.push(i * stepWidth);\n }\n result.push(100);\n return result;\n };\n function getValueToPercent(vals: number) {\n return ((vals - min) * 100) / (max - min);\n }\n\n function getStyle(val?: number[]) {\n val = val || arrValue;\n const barStyl = { left: '0%', right: '100%' };\n if (!Array.isArray(value)) {\n barStyl.right = `${100 - getValueToPercent(val[0])}%`;\n } else {\n const leftValue = val[0] > val[1] ? val[1] : val[0];\n const rightValue = val[0] > val[1] ? val[0] : val[1];\n barStyl.left = `${getValueToPercent(leftValue)}%`;\n barStyl.right = `${100 - getValueToPercent(rightValue)}%`;\n }\n return barStyl;\n }\n\n function getLabelValue(val: number) {\n if (marks && marks !== true && marks[val] && marks[val].label) {\n return marks[val].label;\n } else if (marks && marks !== true && marks[val] && typeof marks[val] === 'string') {\n return marks[val];\n } else if (renderMarks && typeof renderMarks === 'function' && renderMarks(val)) {\n return renderMarks(val);\n }\n return val;\n }\n\n const barStyl = getStyle();\n if (disabled) {\n delete other.onClick;\n }\n return (\n <div\n ref={slider}\n className={[\n prefixCls,\n className,\n disabled ? 'disabled' : null,\n marks ? `${prefixCls}-with-marks` : null,\n vertical ? `${prefixCls}-vertical` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n {...other}\n >\n <div\n ref={bar}\n className={`${prefixCls}-bar`}\n style={{\n [vertical ? 'top' : 'left']: barStyl.left,\n [vertical ? 'bottom' : 'right']: barStyl.right,\n ...(progress !== true ? { backgroundColor: progress || 'initial' } : {}),\n }}\n />\n {[...arrValue].map((item, idx) => {\n const lleftPostion = getValueToPercent(item);\n return (\n <div\n key={idx}\n className={`${prefixCls}-handle`}\n onMouseDown={(evn) => onHandleBtnDown(idx, evn)}\n style={{ [vertical ? 'top' : 'left']: `${lleftPostion}%` }}\n >\n {(tooltip || tooltip === false) && (\n <div className={[`${prefixCls}-tooltip`, tooltip ? 'open' : null].filter(Boolean).join(' ').trim()}>\n {getLabelValue(item)}\n </div>\n )}\n </div>\n );\n })}\n {dots && (\n <Dots\n prefixCls={prefixCls}\n min={min}\n step={step}\n marks={marks}\n vertical={!!vertical}\n data={stepArray()}\n markRender={(stepValue, mark = {}) => {\n if (!mark) {\n return <div> {getLabelValue(stepValue)} </div>;\n }\n const other = typeof mark === 'object' ? mark : {};\n delete other.label;\n return <div {...other}> {getLabelValue(stepValue)} </div>;\n }}\n />\n )}\n </div>\n );\n}\n","import React from 'react';\nimport { RadioAbstract, RadioAbstractProps } from '@uiw/react-radio';\nimport './style/index.less';\n\nexport interface SwitchProps extends RadioAbstractProps {}\n\nexport default React.forwardRef<HTMLInputElement, SwitchProps>((props, ref) => {\n const { prefixCls = 'w-switch', ...other } = props;\n return <RadioAbstract prefixCls={prefixCls} {...{ ...other, type: 'checkbox' }} ref={ref} />;\n});\n","import { TableColumns, LocationWidth } from './';\nimport React from 'react';\n\n/**\n * Get colspan number\n * @param {Array} date\n */\nfunction getColspanNum<T>(data: TableColumns<T>[] = [], num = 1) {\n let childs: TableColumns<T>[] = [];\n for (let i = 0; i < data.length; i += 1) {\n if (data[i].children) {\n childs = childs.concat(data[i].children || []);\n }\n }\n if (childs && childs.length > 0) {\n num = getColspanNum(childs, num + 1);\n }\n return num;\n}\n\n/**\n * Get rowspan number\n * @param {Array} date\n */\nfunction getRowspanNum<T>(data: TableColumns<T>[] = [], child = []) {\n let childs: TableColumns<T>[] = [];\n for (let i = 0; i < data.length; i += 1) {\n if (!data[i].children) {\n childs.push(data[i]);\n } else if (data[i].children && data[i].children!.length > 0) {\n childs = childs.concat(getRowspanNum(data[i].children, child));\n }\n }\n return childs;\n}\n\nexport interface ILevelItems<T> {\n header: TableColumns<T>[][];\n ellipsis?: Record<string, boolean>;\n render: {\n [key: string]: any;\n };\n}\n\n/**\n * JSON Array => Array\n * @param {Array} date\n */\nexport function getLevelItems<T>(data: TableColumns<T>[], result?: ILevelItems<T>): ILevelItems<T> {\n if (!result) {\n result = { header: [], render: {} };\n }\n if (result && !result.header) {\n result.header = [];\n }\n if (result && !result.render) {\n result.render = {};\n }\n let child: TableColumns<T>[] = [];\n const levelTop: TableColumns<T>[] = [];\n for (let i = 0; i < data.length; i += 1) {\n if (data[i].render && data[i].key) {\n result.render[data[i].key as string] = data[i].render;\n }\n if (data[i].ellipsis && data[i].key) {\n if (!result.ellipsis) result.ellipsis = {};\n result.ellipsis[data[i].key!] = true;\n }\n if (result.header.length === 0) {\n // Calculation rowspan\n if (data[i].children && data[i].children && data[i].children!.length > 0) {\n data[i].colSpan = getRowspanNum(data[i].children as TableColumns<T>[]).length;\n }\n levelTop.push(data[i]);\n }\n if (data[i] && data[i].children) {\n child = child.concat(\n data[i].children!.map((item: TableColumns<T>) => {\n // Calculation rowspan\n if (item.children && item.children.length > 0) {\n item.colSpan = getRowspanNum(item.children).length;\n }\n return item;\n }),\n );\n }\n }\n // level 1\n if (result.header.length === 0) {\n const num = getColspanNum(levelTop);\n result.header.push(\n levelTop.map((item) => {\n if (num === 1) return item;\n if (!item.children || (item.children && item.children.length === 0)) {\n item.rowSpan = num;\n }\n return item;\n }),\n );\n }\n if (child && child.length > 0) {\n const num = getColspanNum(child);\n result.header.push(\n child.map((item: TableColumns<T>) => {\n if (num === 1) return item;\n if (!item.children || (item.children && item.children.length === 0)) {\n item.rowSpan = num;\n }\n return item;\n }),\n );\n result = getLevelItems(child, result);\n }\n return result;\n}\n\n/**\n * Get all columns keys\n * @param {Array} data\n */\nexport function getAllColumnsKeys<T>(data: TableColumns<T>[], keys: TableColumns<T>[] = []): TableColumns<T>[] {\n for (let i = 0; i < data.length; i += 1) {\n if (data[i].children) {\n keys = keys.concat(getAllColumnsKeys(data[i].children || []));\n } else if (data[i].key) {\n keys.push(data[i]);\n }\n }\n return keys;\n}\n\nexport function locationFixed(\n fixed: boolean | 'left' | 'right',\n location: { [key: string]: LocationWidth },\n index: string,\n): React.CSSProperties {\n if (!fixed) return {};\n if (fixed === 'right') return { right: location[index]?.right };\n return { left: location[index]?.left };\n}\n","import React, { Component } from 'react';\nimport ReactDOM from 'react-dom';\nimport { TableColumns, TableProps, LocationWidth } from './';\nimport { locationFixed } from './util';\n\ninterface ThComponentProps<T> {\n colNum: number;\n item: TableColumns<T>;\n prefixCls: string;\n titleNode: JSX.Element;\n onCellHead: TableProps<T>['onCellHead'];\n rowNum: number;\n locationWidth: { [key: string]: LocationWidth };\n updateLocation: (params: LocationWidth, index: string, key: string, colSpan?: number) => void;\n}\nexport default class ThComponent<T> extends Component<ThComponentProps<T>> {\n componentDidMount() {\n const rect = ReactDOM.findDOMNode(this) as Element;\n this.props.updateLocation(\n { width: rect.getBoundingClientRect().width },\n `${this.props.rowNum}${this.props.colNum}`,\n this.props.item.key!,\n this.props.item.colSpan,\n );\n }\n\n render() {\n const { colNum, prefixCls, item, titleNode, onCellHead, rowNum, locationWidth } = this.props;\n const { title, key, render, children, ellipsis, fixed = false, ...thProps } = item;\n let cls = '';\n if (fixed) {\n if (fixed === 'right') {\n cls = prefixCls + '-fixed-right';\n } else {\n cls = prefixCls + '-fixed-true';\n }\n }\n return (\n <th\n key={colNum}\n {...thProps}\n style={{ ...thProps.style, ...locationFixed(fixed, locationWidth, `${rowNum}${colNum}`) }}\n className={`${prefixCls}-tr-children-${item?.align || 'left'} ${item.className || ''} ${cls}`}\n onClick={(evn) => onCellHead?.(item, colNum, rowNum!, evn)}\n >\n {titleNode}\n </th>\n );\n }\n}\n","import React from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport { TableProps, TableColumns, LocationWidth } from './';\nimport './style/index.less';\nimport ThComponentProps from './ThComponent';\n\nexport interface TheadProps<T extends { [key: string]: V }, V = any> extends IProps {\n data?: TableColumns<T>[][];\n onCellHead?: TableProps<T, V>['onCellHead'];\n align?: TableColumns['align'];\n className?: TableColumns['className'];\n locationWidth?: { [key: string]: LocationWidth };\n updateLocation?: (params: LocationWidth, index: string, key: string, colSpan?: number) => void;\n}\n\nexport default function TheadComponent<T extends { [key: string]: V }, V>(\n props: TheadProps<T, V> & React.HTMLAttributes<HTMLTableSectionElement> = {},\n) {\n const {\n prefixCls = 'w-table',\n className,\n data = [],\n onCellHead = noop,\n locationWidth,\n updateLocation,\n ...other\n } = props;\n return (\n <thead className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...other}>\n {data &&\n data.length > 0 &&\n data.map((tds?: TableColumns<T>[], rowNum?: number) => (\n <tr key={rowNum}>\n {(tds || []).map((item, colNum) => {\n const { title, key, render, children, ellipsis, fixed = false, ...thProps } = item;\n const titleNode: TableColumns<T>['title'] = (\n <span className={ellipsis ? `${thProps.className || ''} ${prefixCls}-ellipsis` : undefined}>\n {typeof title === 'function' ? title(item, colNum, rowNum!) : title}\n </span>\n );\n if (thProps.colSpan === 0) {\n return null;\n }\n return (\n <ThComponentProps\n colNum={colNum}\n item={item}\n key={colNum}\n prefixCls={prefixCls}\n onCellHead={onCellHead}\n rowNum={rowNum!}\n titleNode={titleNode}\n locationWidth={locationWidth!}\n updateLocation={updateLocation!}\n />\n );\n })}\n </tr>\n ))}\n </thead>\n );\n}\n","import React, { useState } from 'react';\n\ninterface ExpandableProps<T> {\n onClick: (expand: boolean) => void;\n expandIcon: (expanded: boolean) => React.ReactNode;\n defaultExpand: boolean;\n}\n/**\n * 可展开配置\n */\nexport default function ExpandableComponent<T>({ defaultExpand, onClick, expandIcon }: ExpandableProps<T>) {\n const [expand, setExpand] = useState<boolean>(defaultExpand);\n return (\n <div\n style={{ display: 'flex', justifyContent: 'center', alignItems: 'center' }}\n onClick={() => {\n setExpand(!expand);\n onClick(expand);\n // record: T, index: number, expanded: boolean\n }}\n children={expandIcon(expand)}\n />\n );\n}\n","import React, { useMemo, useState, useEffect } from 'react';\nimport Icon from '@uiw/react-icon';\nimport { LocationWidth, TableColumns, TableProps } from './';\nimport './style/index.less';\nimport { noop } from '@uiw/utils';\nimport { locationFixed } from './util';\n\ninterface TableTrProps<T> {\n rowKey?: keyof T;\n header: TableColumns<T>[][];\n data: T[];\n keys: TableProps['columns'];\n render: { [key: string]: any };\n ellipsis?: Record<string, boolean>;\n prefixCls: string;\n onCell: TableProps['onCell'];\n isExpandedDom: (record: T, index: number) => false | JSX.Element;\n // 控制树形结构每一层的缩进宽度\n indentSize: number;\n // 层级\n hierarchy: number;\n childrenColumnName: string;\n locationWidth: { [key: string]: LocationWidth };\n}\n\nexport default function TableTr<T extends { [key: string]: any }>(props: TableTrProps<T>) {\n const {\n rowKey,\n data,\n keys,\n render,\n ellipsis,\n prefixCls,\n onCell = noop,\n isExpandedDom,\n hierarchy,\n indentSize,\n childrenColumnName,\n locationWidth,\n header,\n } = props;\n const [isOpacity, setIsOpacity] = useState(false);\n const [childrenIndex, setChildrenIndex] = useState(0);\n const [expandIndex, setExpandIndex] = useState<Array<T[keyof T] | number>>([]);\n useEffect(() => {\n setIsOpacity(!!data?.find((it) => it[childrenColumnName]));\n setChildrenIndex(keys?.findIndex((it) => it.key === 'uiw-expanded') === -1 ? 0 : 1);\n }, [data]);\n\n const IconDom = useMemo(() => {\n return (key: T[keyof T] | number, isOpacity: boolean) => {\n const flag = expandIndex.includes(key);\n return (\n <Icon\n type={flag ? 'minus-square-o' : 'plus-square-o'}\n style={{\n marginRight: 10,\n opacity: isOpacity ? 1 : 0,\n marginLeft: hierarchy * indentSize,\n float: 'left',\n marginTop: 3.24,\n }}\n onClick={() => {\n setExpandIndex(flag ? expandIndex.filter((it) => it !== key) : [...expandIndex, key]);\n }}\n />\n );\n };\n }, [expandIndex]);\n const getIndex = (key: string) => {\n let j = 0;\n const i = header.findIndex((it) => {\n j = it.findIndex((item) => item.key === key);\n return j > -1;\n });\n return `${i}${j}`;\n };\n if (!Array.isArray(data) || !data.length) {\n return null;\n }\n return (\n <React.Fragment>\n {data.map((trData, rowNum) => {\n const key = rowKey ? trData[rowKey] : rowNum;\n return (\n <React.Fragment key={rowNum}>\n <tr key={key}>\n {keys!.map((keyName, colNum) => {\n let objs: React.TdHTMLAttributes<HTMLTableDataCellElement> = {\n children: trData[keyName.key!],\n };\n if (render[keyName.key!]) {\n const child = render[keyName.key!](trData[keyName.key!], keyName.key, trData, rowNum, colNum);\n if (React.isValidElement(child)) {\n objs.children = child;\n } else {\n if (child.props) {\n objs = { ...child.props, children: objs.children };\n if (child.props.rowSpan === 0 || child.props.colSpan === 0) return null;\n }\n if (child.children) {\n objs.children = child.children;\n }\n }\n }\n const isHasChildren = Array.isArray(trData[childrenColumnName]);\n if (colNum === childrenIndex && (isOpacity || hierarchy || isHasChildren)) {\n objs.children = (\n <>\n {IconDom(key, isHasChildren)}\n <span style={{ paddingLeft: hierarchy * indentSize }}></span>\n {objs.children}\n </>\n );\n }\n if (keyName.fixed) {\n if (keyName.fixed === 'right') {\n objs.className = `${objs.className} ${prefixCls}-fixed-right`;\n } else {\n objs.className = `${objs.className} ${prefixCls}-fixed-true`;\n }\n }\n return (\n <td\n {...objs}\n style={\n keyName.fixed\n ? { ...locationFixed(keyName.fixed!, locationWidth, `${getIndex(keyName.key || 'undefined')}`) }\n : {}\n }\n children={\n <span className={ellipsis && ellipsis[keyName.key!] ? `${prefixCls}-ellipsis` : undefined}>\n {objs.children}\n </span>\n }\n key={colNum}\n className={`${prefixCls}-tr-children-${keyName.align || 'left'} ${keyName.className || ''} ${\n objs.className || ''\n }`}\n onClick={(evn) => onCell(trData, { rowNum, colNum, keyName: keyName.key! }, evn)}\n />\n );\n })}\n </tr>\n {isExpandedDom(trData, rowNum)}\n {expandIndex.includes(key) && (\n <TableTr {...props} data={trData[childrenColumnName]} hierarchy={hierarchy + 1} />\n )}\n </React.Fragment>\n );\n })}\n </React.Fragment>\n );\n}\n","import React, { useMemo, useState, useEffect, useRef } from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport Icon from '@uiw/react-icon';\nimport Thead from './Thead';\nimport { getLevelItems, getAllColumnsKeys } from './util';\nimport ExpandableComponent from './Expandable';\nimport TableTr from './TableTr';\nimport './style/index.less';\n\n// 展开配置\nexport interface ExpandableType<T> {\n // 展开行\n expandedRowRender?: (record: T, index: number, expanded: boolean) => React.ReactNode;\n // 自定义图标\n expandIcon?: (expanded: boolean, record: T, index: number) => React.ReactNode;\n // 是否允许展开\n rowExpandable?: (record: T) => boolean;\n // 初始时,是否展开所有行\n defaultExpandAllRows?: boolean;\n // 默认展开的行 rowKey数组\n defaultExpandedRowKeys?: Array<T[keyof T] | number>;\n // 控制展开的行 rowKey数组\n expandedRowKeys?: Array<T[keyof T] | number>;\n // 展开的行变化触发\n onExpandedRowsChange?: (expandedRows: Array<T[keyof T] | number>) => void;\n // 点击展开图标触发\n onExpand?: (expanded: boolean, record: T, index: number) => void;\n // 控制树形结构每一层的缩进宽度\n indentSize?: number;\n // 指定树形结构的列名\n childrenColumnName?: string;\n}\n\nexport type TableColumns<T = any> = {\n title?: string | ((data: TableColumns<T>, rowNum: number, colNum: number) => JSX.Element) | JSX.Element;\n key?: string;\n width?: number;\n colSpan?: number;\n children?: TableColumns<T>[];\n ellipsis?: boolean;\n render?: (text: string, keyName: string, rowData: T, rowNumber: number, columnNumber: number) => React.ReactNode;\n style?: React.CSSProperties;\n align?: 'left' | 'center' | 'right';\n className?: string;\n fixed?: boolean | 'left' | 'right';\n [key: string]: any;\n};\n\nexport interface TableProps<T extends { [key: string]: V } = any, V = any> extends IProps, Omit<HTMLDivProps, 'title'> {\n prefixCls?: string;\n columns?: TableColumns<T>[];\n data?: Array<T>;\n title?: React.ReactNode;\n footer?: React.ReactNode;\n bordered?: boolean;\n empty?: React.ReactNode;\n onCell?: (\n data: { [key: string]: any },\n options: ICellOptions,\n evn: React.MouseEvent<HTMLTableCellElement>,\n ) => void | React.ReactNode;\n onCellHead?: (\n data: TableColumns<T>,\n rowNum: number,\n colNum: number,\n evn: React.MouseEvent<HTMLTableCellElement>,\n ) => void;\n expandable?: ExpandableType<T>;\n rowKey?: keyof T;\n scroll?: { x?: React.CSSProperties['width']; y?: React.CSSProperties['height'] };\n}\n\nexport interface LocationWidth {\n left?: number;\n right?: number;\n width: number;\n key?: string;\n colSpan?: number;\n}\nexport interface ICellOptions {\n rowNum: number;\n colNum: number;\n keyName: string;\n}\n\nexport default function Table<T extends { [key: string]: V }, V>(props: TableProps<T, V> = {}) {\n const {\n prefixCls = 'w-table',\n className,\n columns = [],\n data = [],\n title,\n footer,\n bordered,\n onCell = noop,\n onCellHead = noop,\n empty,\n children,\n expandable,\n rowKey,\n scroll,\n ...other\n } = props;\n const [expandIndex, setExpandIndex] = useState<Array<T[keyof T] | number>>([]);\n const [locationWidth, setLocationWidth] = useState<{ [key: string]: LocationWidth }>({});\n const finalLocationWidth = useRef<{ [key: string]: LocationWidth }>({});\n const updateLocation = (params: LocationWidth, index: string, key: string, colSpan: number = 0) => {\n finalLocationWidth.current = {\n ...finalLocationWidth.current,\n [index]: {\n ...finalLocationWidth.current[index],\n ...params,\n key: key,\n colSpan,\n },\n };\n if (index === `${header.length - 1}${header[header.length - 1].length - 1}`) {\n setLocationWidth(computed());\n }\n };\n const deepClumnsLocation = (\n params: Array<TableColumns<T> | number>,\n fistIndex: number,\n leftOrRight: 'left' | 'right',\n isReverse: boolean,\n ) => {\n let initialValue = 0,\n lastIndex = isReverse ? 0 : params.length - 1,\n deepParams: Array<TableColumns<T> | number> = [];\n params.forEach(() => {\n let abs = Math.abs(lastIndex);\n const i = `${fistIndex}${abs}`;\n if (isReverse) {\n lastIndex += 1;\n } else {\n lastIndex -= 1;\n }\n if (typeof params[abs] === 'number') {\n initialValue = (params[abs] as number) + initialValue;\n deepParams.push(params[abs]);\n return;\n }\n if (finalLocationWidth.current[i]) {\n finalLocationWidth.current[i][leftOrRight] = initialValue;\n initialValue = finalLocationWidth.current[i].width + initialValue;\n }\n if (Array.isArray((params[abs] as TableColumns<T>).children)) {\n deepParams.push(...(params[abs] as TableColumns<T>).children!);\n return;\n }\n if (finalLocationWidth.current[i]) {\n deepParams.push(finalLocationWidth.current[i].width);\n } else {\n const parent = header.find((it) => it.find((it) => it.key === (params[abs] as TableColumns<T>).key)) || [];\n const sub = parent.findIndex((it) => it.key === (params[abs] as TableColumns<T>).key);\n if (finalLocationWidth.current[`${i[0]}${sub}`]) {\n // 合并单元格\n deepParams.push(finalLocationWidth.current[`${i[0]}${sub}`].width);\n }\n }\n });\n if (deepParams.filter((it) => typeof it !== 'number').length)\n deepClumnsLocation(deepParams, fistIndex + 1, leftOrRight, isReverse);\n };\n\n const computed = () => {\n deepClumnsLocation(columns, 0, 'left', true);\n deepClumnsLocation(columns, 0, 'right', false);\n return finalLocationWidth.current;\n };\n useEffect(() => {\n const childKey = expandable?.childrenColumnName || 'children';\n const deep = (params: TableColumns<T>) => {\n const arr1: Array<T[keyof T] | number> = [];\n const arr = params.map((it: T, index: number) => {\n if (Array.isArray(it[childKey])) {\n arr1.push(...deep(it[childKey]));\n }\n return rowKey ? it[rowKey] : index;\n });\n return [...arr1, ...arr];\n };\n if (expandable) {\n if (expandable.defaultExpandAllRows) {\n setExpandIndex(deep(data));\n return;\n }\n if (expandable.defaultExpandedRowKeys) {\n setExpandIndex(expandable.defaultExpandedRowKeys);\n return;\n }\n }\n }, []);\n useEffect(() => {\n if (expandable) {\n if (expandable.expandedRowKeys && JSON.stringify(expandable.expandedRowKeys) !== JSON.stringify(expandIndex)) {\n setExpandIndex(expandable.expandedRowKeys);\n }\n }\n }, [expandable?.expandedRowKeys]);\n\n const isExpandedDom = useMemo(() => {\n return (record: T, index: number) => {\n if (!expandable) {\n return false;\n }\n if (!expandable.expandedRowRender) {\n return false;\n }\n let flag = true;\n if (expandable.rowExpandable) {\n flag = expandable.rowExpandable(record);\n }\n return (\n flag && (\n <tr style={expandIndex.includes(rowKey ? record[rowKey] : index) ? {} : { display: 'none' }}>\n <td style={{ paddingLeft: 16 }} colSpan={columns.length + 1}>\n {expandable.expandedRowRender(record, index, true)}\n </td>\n </tr>\n )\n );\n };\n }, [expandable, expandIndex]);\n\n const self = useMemo(() => {\n let keys = getAllColumnsKeys<T>(columns);\n let selfColumns: TableColumns<T>[] = [];\n if (expandable?.expandedRowRender) {\n keys = [{ key: 'uiw-expanded', align: 'center' }, ...keys];\n selfColumns = [\n {\n title: '',\n key: 'uiw-expanded',\n width: 50,\n align: 'center',\n render: (text, key, record, index) => {\n return (\n <ExpandableComponent\n defaultExpand={\n expandable.defaultExpandAllRows === undefined\n ? !!expandable.defaultExpandedRowKeys?.includes(rowKey ? record[rowKey] : index)\n : !!expandable.defaultExpandAllRows\n }\n onClick={(expand) => {\n expandable.onExpand?.(expand, record, index);\n if (expand) {\n const result = expandIndex.filter((it) => (rowKey ? it !== record[rowKey] : it !== index));\n expandable.onExpandedRowsChange ? expandable.onExpandedRowsChange(result) : setExpandIndex(result);\n } else {\n const result = [...expandIndex, rowKey ? record[rowKey] : index];\n expandable.onExpandedRowsChange ? expandable.onExpandedRowsChange(result) : setExpandIndex(result);\n }\n }}\n expandIcon={(expand) => {\n if (expandable.rowExpandable && !expandable.rowExpandable?.(record)) {\n return null;\n }\n if (expandable.expandIcon) {\n return expandable.expandIcon(expand, record, index);\n }\n return expand ? <Icon type=\"minus-square-o\" /> : <Icon type=\"plus-square-o\" />;\n }}\n />\n );\n },\n },\n ...columns,\n ];\n } else {\n selfColumns = [...columns];\n }\n return {\n keys,\n selfColumns,\n };\n }, [columns, expandIndex]);\n const style: { table: React.CSSProperties; div: React.CSSProperties } = useMemo(() => {\n const style: { table: React.CSSProperties; div: React.CSSProperties } = {\n table: {},\n div: {},\n };\n if (scroll) {\n if (scroll.x !== undefined) {\n style.table.minWidth = '100%';\n style.table.width = scroll.x;\n style.div.overflowX = 'auto';\n style.div.overflowY = 'hidden';\n }\n if (scroll.y !== undefined) {\n style.div.maxHeight = scroll.y;\n style.div.overflowY = 'scroll';\n }\n }\n return style;\n }, [scroll]);\n const cls = [prefixCls, className, bordered ? `${prefixCls}-bordered` : null].filter(Boolean).join(' ').trim();\n const { header, render, ellipsis } = getLevelItems(self.selfColumns);\n return (\n <React.Fragment>\n <div className={cls} {...other} style={{ ...other.style, ...style.div }}>\n <table style={{ tableLayout: ellipsis ? 'fixed' : 'auto', ...style.table }}>\n {title && <caption>{title}</caption>}\n {columns && columns.length > 0 && (\n <Thead\n onCellHead={onCellHead}\n data={header}\n locationWidth={locationWidth}\n updateLocation={updateLocation}\n />\n )}\n {data && data.length > 0 && (\n <tbody>\n <TableTr\n rowKey={rowKey}\n locationWidth={locationWidth}\n data={data}\n header={header}\n keys={self.keys}\n render={render}\n ellipsis={ellipsis}\n prefixCls={prefixCls}\n onCell={onCell}\n hierarchy={0}\n isExpandedDom={isExpandedDom}\n indentSize={typeof expandable?.indentSize === 'number' ? expandable?.indentSize : 16}\n childrenColumnName={expandable?.childrenColumnName || 'children'}\n />\n </tbody>\n )}\n {data && data.length === 0 && empty && (\n <tbody>\n <tr>\n <td colSpan={columns.length} style={{ position: 'relative', left: 0 }}>\n {empty}\n </td>\n </tr>\n </tbody>\n )}\n {props.children}\n </table>\n </div>\n {footer && <div className={`${prefixCls}-footer`}>{footer}</div>}\n </React.Fragment>\n );\n}\n","import React, { useEffect, useState, useRef, useCallback, useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Pane from './Pane';\nimport './style/index.less';\nimport Popover from '@uiw/react-popover';\n\nexport * from './Pane';\n\nTabs.Pane = Pane;\n\nlet labelWidth: number = 0;\nexport interface TabsProps extends IProps, HTMLDivProps {\n prefixCls?: string;\n activeKey?: string;\n type?: 'default' | 'line' | 'card';\n children?: React.ReactNode;\n onTabClick?: (key: string, item: React.ReactElement, e: React.MouseEvent) => void;\n}\n\ntype FlowNavType = {\n content: number;\n nav: Array<Record<'index' | 'width' | 'curWidth', number>>;\n flowLeft: number;\n displayStart: number;\n displayEnd: number;\n};\n\nexport default function Tabs(props: TabsProps) {\n const {\n prefixCls = 'w-tabs',\n className,\n children,\n type = 'default',\n activeKey: _,\n onTabClick,\n ...elementProps\n } = props;\n\n const [activeKey, setActiveKey] = useState(props.activeKey);\n const [slideStyle, setSlideStyle] = useState({ width: 0, left: 0 });\n const activeItem = useRef<HTMLDivElement | undefined>();\n const cls = [prefixCls, className, type ? `${prefixCls}-${type}` : null].filter(Boolean).join(' ').trim();\n\n const [flowNav, flowNavSet] = useState<FlowNavType>({\n content: 0,\n nav: [],\n flowLeft: -1,\n displayStart: 0,\n displayEnd: 0,\n });\n const [hiddenNav, hiddenNavSet] = useState<Array<number>>([]);\n const deviation = 15;\n\n const [nodes, nodesSet] = useState<any>();\n const divContentRef = useCallback((node) => {\n if (node !== null) {\n nodesSet(nodes);\n node.addEventListener('scroll', (e: any) => {\n const { clientWidth, scrollLeft } = e.target;\n flowNav.displayStart = scrollLeft;\n flowNav.displayEnd = clientWidth + scrollLeft;\n flowNavSet({ ...flowNav });\n });\n flowNav.displayEnd = node.getBoundingClientRect().width;\n flowNavSet({ ...flowNav });\n }\n }, []);\n\n const divNavRef = useCallback((node, key: number, itemKey: React.Key | null) => {\n if (node !== null) {\n node.addEventListener('click', (e: any) => {\n activeItem.current = node;\n });\n divNavWidthChange(node.getBoundingClientRect().width, key);\n\n if (itemKey === props.activeKey && type === 'line' && labelWidth === 0) {\n activeItem.current = node;\n }\n }\n }, []);\n\n const divNavWidthChange = (width: number, index: number) => {\n let curWidth = 0;\n flowNav.nav.slice(0, index + 1).forEach((nav) => (curWidth += nav.width));\n flowNav.nav[index] = { width, curWidth: Math.floor(curWidth), index };\n flowNavSet(flowNav);\n };\n\n useEffect(() => {\n showHideenNav();\n }, [flowNav.displayEnd > flowNav.nav[flowNav.nav.length - 1]?.curWidth]);\n\n const showHideenNav = () => {\n const hiddenNav: Array<number> = [];\n if (flowNav.nav.length > 0) {\n flowNav.nav.forEach((item) => {\n const curWidth = item.curWidth - deviation;\n if (curWidth < flowNav.displayStart || curWidth > flowNav.displayEnd) {\n hiddenNav.push(item.index);\n }\n });\n hiddenNavSet(hiddenNav);\n }\n };\n\n useEffect(() => setActiveKey(props.activeKey), [props.activeKey]);\n useEffect(() => calcSlideStyle(), [activeKey]);\n\n function calcSlideStyle() {\n if (activeItem.current && type === 'line') {\n labelWidth = activeItem.current.clientWidth;\n setSlideStyle({\n width: activeItem.current.clientWidth,\n left: activeItem.current.offsetLeft,\n });\n }\n }\n\n return (\n <div className={cls} {...elementProps}>\n <div style={{ display: 'flex' }}>\n <div style={{ overflow: 'hidden' }}>\n <div className={`${prefixCls}-bar`} ref={divContentRef}>\n <div className={`${prefixCls}-nav`} style={{ width: 'max-content' }}>\n {renderNav(children)}\n <div style={slideStyle} className={`${prefixCls}-slide`} />\n </div>\n </div>\n </div>\n {hiddenNav.length > 0 && (\n <Popover\n trigger=\"click\"\n placement=\"bottomRight\"\n visibleArrow={false}\n content={\n <div className={`${prefixCls}-nav-hidden`}>\n {renderNav(hiddenNav.map((idx) => (children as Array<React.ReactElement>)[idx]))}\n </div>\n }\n >\n <div onClick={showHideenNav} className={`${prefixCls}-flow-content`}>\n <span>…</span>\n </div>\n </Popover>\n )}\n </div>\n {React.Children.map(children, (item: any) => {\n if (!item || activeKey !== item.key) {\n return null;\n }\n return React.cloneElement(item, Object.assign({}, item.props, {}));\n })}\n </div>\n );\n\n function renderNav(children: React.ReactNode): React.ReactNode {\n return React.Children.map(children as React.ReactElement[], (item: React.ReactElement, key: number) => {\n if (!item) {\n return null;\n }\n const divProps: HTMLDivProps = {\n className: [\n `${prefixCls}-item`,\n item.key === activeKey ? 'active' : null,\n item.props.disabled ? 'disabled' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n children: item.props.label,\n };\n if (!item.props.disabled) {\n divProps.onClick = (e: React.MouseEvent) => {\n setActiveKey(item.key as string);\n onTabClick && onTabClick(item.key as string, item, e);\n calcSlideStyle();\n };\n }\n return <div key={key} ref={(ref) => divNavRef(ref, key, item.key)} {...divProps} />;\n });\n }\n}\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\n\nexport interface TabsPaneProps extends IProps, HTMLDivProps {\n label?: React.ReactNode;\n disabled?: boolean;\n}\n\nexport default (props: TabsPaneProps = {}) => {\n const { prefixCls = 'w-tabs-pane', className, label: _, ...resetProps } = props;\n return <div className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...resetProps} />;\n};\n","import React from 'react';\nimport { IProps, HTMLTextProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface TextareaProps extends IProps, HTMLTextProps {}\n\nexport default React.forwardRef<HTMLTextAreaElement, TextareaProps>((props, ref) => {\n const { prefixCls = 'w-textarea', className, ...restProps } = props;\n return (\n <textarea className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...restProps} ref={ref}>\n {props.children}\n </textarea>\n );\n});\n","import React from 'react';\nimport OverlayTrigger, { OverlayTriggerProps } from '@uiw/react-overlay-trigger';\nimport { IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface TooltipProps extends IProps, OverlayTriggerProps {\n visibleArrow?: boolean;\n content?: React.ReactNode;\n}\n\nexport default (props: TooltipProps = {}) => {\n const {\n prefixCls = 'w-tooltip',\n className,\n placement = 'top',\n isOpen = false,\n trigger,\n delay,\n usePortal = true,\n visibleArrow = true,\n onVisibleChange,\n ...other\n } = props;\n const cls = [prefixCls, className, !visibleArrow ? 'no-arrow' : null].filter(Boolean).join(' ').trim();\n return (\n <OverlayTrigger\n usePortal={usePortal}\n isOpen={isOpen}\n trigger={trigger}\n delay={delay}\n onVisibleChange={onVisibleChange}\n placement={placement}\n {...other}\n overlay={\n <div className={cls}>\n {visibleArrow && <div className={`${prefixCls}-arrow`} />}\n <div className={`${prefixCls}-inner`}>{props.content}</div>\n </div>\n }\n >\n {typeof props.children === 'object' ? props.children : <span>{props.children}</span>}\n </OverlayTrigger>\n );\n};\n","import React, { useCallback, useMemo } from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, noop } from '@uiw/utils';\nimport { TreeData, TreeProps, getChildKeys } from './';\n\ninterface TreeNodeIconProps {\n isOpen: boolean;\n noChild: boolean;\n openKeys: TreeNodeProps['openKeys'];\n selectedKeys: TreeNodeProps['selectedKeys'];\n}\n\ninterface TreeNodeProps<T = (data: TreeData, props: TreeNodeIconProps) => IconProps['type']> extends IProps {\n data: TreeData[];\n level: number;\n parent?: TreeData;\n icon?: T;\n iconAnimation?: boolean;\n isSelected?: boolean;\n renderTitle?: TreeProps['renderTitle'];\n\n openKeys?: TreeData['key'][];\n selectedKeys?: TreeData['key'][];\n\n onItemClick?: (item: TreeData, evn: React.MouseEvent<HTMLElement>) => void;\n onItemSelected?: (item: TreeData, evn: React.MouseEvent<HTMLElement>) => void;\n}\n\nconst Label = ({ label }: { label: React.ReactNode }) => useMemo(() => <span>{label}</span>, [label]);\n\nexport default function TreeNode<T>(props: TreeNodeProps<T>) {\n const {\n prefixCls,\n renderTitle,\n icon,\n iconAnimation,\n isSelected,\n openKeys,\n selectedKeys,\n\n data,\n level,\n parent,\n\n onItemClick = noop,\n onItemSelected = noop,\n ...other\n } = props;\n let isOpen = false;\n\n if (parent && (parent.key || parent.key === 0)) {\n isOpen = !!(openKeys && openKeys.indexOf(parent.key) > -1);\n }\n const onExit = useCallback((node: HTMLElement) => {\n node.style.height = `${node.scrollHeight}px`;\n }, []);\n const onExiting = useCallback((node: HTMLElement) => {\n node.style.height = '1px';\n }, []);\n const onEnter = useCallback((node: HTMLElement, isAppearing: boolean) => {\n node.style.height = '1px';\n }, []);\n const onEntering = useCallback((node: HTMLElement, isAppearing: boolean) => {\n node.style.height = `${node.scrollHeight}px`;\n }, []);\n const onEntered = useCallback((node: HTMLElement, isAppearing: boolean) => {\n node.style.height = 'initial';\n }, []);\n return (\n <CSSTransition\n classNames={prefixCls}\n in={isOpen}\n timeout={200}\n onExit={onExit}\n onExiting={onExiting}\n onEnter={onEnter}\n onEntered={onEntered}\n onEntering={onEntering}\n >\n <ul\n className={[\n level !== 1 && isOpen ? [`${prefixCls}-open`] : null,\n level !== 1 && !isOpen ? [`${prefixCls}-close`] : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {data.map((item, idx: number) => {\n item.parent = parent;\n const selected = !!(selectedKeys && selectedKeys.indexOf(item.key) > -1);\n const noChild = !item.children;\n const itemIsOpen = openKeys && openKeys.indexOf(item.key) > -1 && !!item.children;\n const iconItem =\n typeof icon === 'function'\n ? icon(item, {\n isOpen: !!itemIsOpen,\n noChild,\n openKeys,\n selectedKeys,\n })\n : icon;\n const childKeys = noChild ? [] : getChildKeys(item.children);\n const checkedKeys = selectedKeys ? selectedKeys.filter((key) => childKeys.indexOf(key) > -1) : [];\n const isHalfChecked = checkedKeys.length > 0 && childKeys.length !== checkedKeys.length;\n return (\n <li key={idx} style={{ display: item.hideNode ? 'none' : 'block' }}>\n <div className={`${prefixCls}-label`}>\n <span\n style={{ display: noChild ? 'none' : 'auto' }}\n className={`${prefixCls}-switcher`}\n onClick={(evn) => onItemClick(item, evn)}\n >\n <Icon\n type={iconItem || 'caret-right'}\n className={[\n typeof icon === 'function' ? `${prefixCls}-switcher-noop` : null,\n noChild ? 'no-child' : null,\n !iconAnimation ? 'no-animation' : null,\n itemIsOpen ? 'open' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n />\n </span>\n <div\n onClick={(evn) => onItemSelected(item, evn)}\n className={[\n `${prefixCls}-title`,\n selected && isSelected ? 'selected' : null,\n item.disabled ? 'disabled' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {renderTitle ? (\n renderTitle(item, {\n selected,\n noChild,\n openKeys,\n isHalfChecked,\n selectedKeys,\n })\n ) : (\n <Label label={item.label} />\n )}\n </div>\n </div>\n {item.children && (\n <TreeNode\n {...other}\n {...{\n prefixCls,\n icon,\n iconAnimation,\n isSelected,\n openKeys,\n selectedKeys,\n onItemClick,\n onItemSelected,\n renderTitle,\n }}\n prefixCls={prefixCls}\n data={item.children}\n level={level + 1}\n parent={item}\n />\n )}\n </li>\n );\n })}\n </ul>\n </CSSTransition>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport TreeNode from './TreeNode';\nimport './style/index.less';\n\nexport type TreeRenderTitleNode = {\n selected?: boolean;\n noChild?: boolean;\n isHalfChecked?: boolean;\n openKeys?: TreeProps['openKeys'];\n selectedKeys?: TreeProps['selectedKeys'];\n};\n\nexport interface TreeProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n icon?: IconProps['type'];\n data?: TreeData[];\n openKeys?: TreeData['key'][];\n selectedKeys?: TreeData['key'][];\n defaultExpandAll?: boolean;\n /**\n * 是否自动展开父节点\n */\n autoExpandParent?: boolean;\n /**\n * 是否展示连接线\n */\n showLine?: boolean;\n iconAnimation?: boolean;\n isSelected?: boolean;\n /**\n * 子节点受父节点控制设置 `true`,需要配合 `multiple` 参数使用。\n */\n checkStrictly?: boolean;\n /**\n * 支持点选多个节点\n */\n multiple?: boolean;\n renderTitle?: (item: TreeData, node: TreeRenderTitleNode) => React.ReactElement;\n onExpand?: (key: TreeData['key'], expanded: boolean, item: TreeData, evn: React.MouseEvent<HTMLElement>) => void;\n onSelected?: (\n keys: TreeData['key'][],\n key: TreeData['key'],\n selected: boolean,\n item: TreeData,\n evn: React.MouseEvent<HTMLElement>,\n ) => void;\n onChange?: (key: string | number | undefined, eys: (string | number | undefined)[]) => void;\n value?: TreeData['key'][];\n}\n\nexport interface TreeData {\n label?: React.ReactNode;\n children?: TreeData[];\n hideNode?: boolean;\n key?: string | number;\n [keyName: string]: any;\n}\n\n/**\n * a contains b\n * @param {Array} a\n * @param {Array} b\n */\nconst isContained = (a: any[], b: any[]) => {\n if (!(a instanceof Array) || !(b instanceof Array)) return false;\n if (a.length < b.length) return false;\n const aStr = a.toString();\n for (let i = 0, len = b.length; i < len; i += 1) {\n if (aStr.indexOf(b[i]) === -1) return false;\n }\n return true;\n};\n\nexport const getChildKeys = (\n childs: TreeData[] = [],\n result: TreeData['key'][] = [],\n depth?: number,\n): TreeData['key'][] => {\n childs.forEach((item) => {\n if (!item.hideNode) {\n result.push(item.key as string | number);\n }\n if (typeof depth === 'number' && !(depth - 1)) return;\n\n if (item.children && item.children.length > 0) {\n result = result.concat(getChildKeys(item.children, undefined, depth ? depth - 1 : undefined));\n }\n });\n return result;\n};\n\nconst getParentKeys = (childs: TreeData = {}, result: TreeData['key'][] = []) => {\n if (childs.key) {\n result.push(childs.key);\n }\n if (childs.parent) {\n result = getParentKeys(childs.parent, result);\n }\n return result;\n};\n\nconst getParentSelectKeys = (\n childs: TreeData = {},\n selectedKeys: TreeData['key'][] = [],\n result: TreeData['key'][] = [],\n) => {\n if (childs.key && childs.children && isContained(selectedKeys, getChildKeys(childs.children, undefined, 1))) {\n result.push(childs.key);\n if (childs.parent && !childs.parent.parent) {\n if (isContained(selectedKeys, getChildKeys(childs.children))) {\n selectedKeys = selectedKeys.concat(result);\n }\n if (isContained(selectedKeys, getChildKeys(childs.parent.children))) {\n result.push(childs.parent.key);\n }\n }\n }\n if (childs.parent) {\n result = getParentSelectKeys(childs.parent, selectedKeys, result);\n }\n return result;\n};\n\nexport default function Tree(props: TreeProps) {\n const {\n prefixCls = 'w-tree',\n icon = 'caret-right',\n data = [],\n openKeys = [],\n selectedKeys = [],\n defaultExpandAll = false,\n showLine = false,\n iconAnimation = true,\n isSelected = true,\n checkStrictly = false,\n multiple = false,\n onExpand = noop,\n onSelected = noop,\n\n className,\n autoExpandParent = true,\n renderTitle,\n onChange,\n value,\n ...elementProps\n } = props;\n\n const [curOpenKeys, setCurOpenKeys] = useState(openKeys);\n const [curSelectedKeys, setCurSelectedKeys] = useState(value || selectedKeys);\n\n useEffect(() => {\n setCurSelectedKeys(props.value || props.selectedKeys || []);\n }, [JSON.stringify(props.selectedKeys), JSON.stringify(props.value)]);\n\n useEffect(() => {\n let arrOpenKeys: TreeData['key'][] = [...curOpenKeys];\n if (defaultExpandAll) {\n arrOpenKeys = getChildKeys(data);\n } else if (autoExpandParent) {\n arrOpenKeys.push(...getChildKeys(data || [], undefined, 1));\n }\n setCurOpenKeys(arrOpenKeys);\n }, []);\n\n const cls = [className, prefixCls, showLine ? `${prefixCls}-line` : null].filter(Boolean).join(' ').trim();\n\n function onItemClick(item: TreeData, evn: React.MouseEvent<HTMLElement>) {\n if (!item.children) {\n return;\n }\n // const { onExpand } = this.props;\n // const { openKeys } = this.state;\n let currentKeys = [...(curOpenKeys as TreeData['key'][])];\n const key = currentKeys.find((v) => v === item.key);\n const cls = evn.currentTarget.className.replace(/(\\s)open/g, '');\n let expanded = false;\n if (!key && item.key) {\n currentKeys.push(item.key);\n evn.currentTarget.className = [cls, 'open'].filter(Boolean).join(' ').trim();\n expanded = true;\n } else {\n currentKeys = currentKeys.filter((v) => v !== item.key);\n evn.currentTarget.className = cls;\n }\n setCurOpenKeys(currentKeys);\n onExpand && onExpand(item.key, expanded, item, evn);\n }\n function onItemSelected(item: TreeData, evn: React.MouseEvent<HTMLElement>) {\n // const { onSelected, multiple, checkStrictly } = this.props;\n let selKeys = [...(curSelectedKeys as TreeData['key'][])];\n const findKey = selKeys.find((v) => v === item.key);\n let selected = false;\n if (!findKey && findKey !== 0) {\n selected = true;\n selKeys.push(item.key);\n } else {\n selKeys = selKeys.filter((v) => v !== item.key);\n }\n if (checkStrictly) {\n if (!findKey) {\n selKeys = selKeys.concat(getChildKeys(item.children).filter((val) => selKeys.indexOf(val) === -1));\n selKeys = selKeys.concat(getParentSelectKeys(item, selKeys));\n selKeys = Array.from(new Set(selKeys)); // Remove duplicates.\n } else {\n selKeys = selKeys.filter((val) => getChildKeys(item.children).indexOf(val) === -1);\n selKeys = selKeys.filter((val) => getParentKeys(item.parent).indexOf(val) === -1);\n }\n }\n if (!multiple) {\n selKeys = !findKey ? [item.key] : [];\n }\n setCurSelectedKeys(selKeys);\n onSelected && onSelected(selKeys, item.key, selected, item, evn);\n onChange?.(item.key, selKeys);\n }\n return (\n <div className={cls} {...elementProps}>\n <TreeNode\n {...{\n icon,\n iconAnimation,\n isSelected,\n openKeys: curOpenKeys,\n selectedKeys: curSelectedKeys,\n prefixCls,\n renderTitle,\n }}\n onItemClick={onItemClick}\n onItemSelected={onItemSelected}\n data={data}\n level={1}\n />\n </div>\n );\n}\n","import React, { Fragment } from 'react';\nimport Tree, { TreeProps, TreeRenderTitleNode, TreeData } from '@uiw/react-tree';\nimport Checkbox, { CheckboxProps } from '@uiw/react-checkbox';\nimport './style/index.less';\n\nexport interface TreeCheckedProps extends TreeProps {}\n\nexport default function TreeChecked({ prefixCls = 'w-treechecked', ...props }: TreeCheckedProps): JSX.Element {\n props.className = [prefixCls, props.className].filter(Boolean).join(' ').trim();\n props.checkStrictly = true;\n props.isSelected = false;\n props.multiple = true;\n return (\n <Tree\n renderTitle={(item: TreeData, node: TreeRenderTitleNode) => {\n const checkedProps: CheckboxProps = {};\n if (node.isHalfChecked) {\n checkedProps.indeterminate = true;\n }\n if (node.selected) {\n checkedProps.checked = true;\n } else {\n checkedProps.checked = false;\n }\n return (\n <Fragment>\n <Checkbox className={`${prefixCls}-checked`} {...checkedProps} />\n {item.label && <span>{item.label}</span>}\n </Fragment>\n );\n }}\n {...props}\n />\n );\n}\n","import React, { useMemo, useState, useRef, useEffect, ReactElement } from 'react';\nimport Dropdown, { DropdownProps } from '@uiw/react-dropdown';\nimport Icon from '@uiw/react-icon';\nimport Input from '@uiw/react-input';\nimport Tag from '@uiw/react-tag';\nimport Card from '@uiw/react-card';\nimport Empty from '@uiw/react-empty';\nimport { IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface DropContent<V> {\n values: Array<V>;\n onSelected?: (selectedAll: Array<V>, selectd: V, isChecked: boolean) => void;\n options?: Array<any>;\n}\n\nexport interface SearchTagInputOption {\n label: string;\n key: string | number;\n}\n\nexport interface SearchTagInputProps<V> extends IProps, DropdownProps, DropContent<V> {\n allowClear?: boolean;\n content: ReactElement<DropContent<V>>;\n size?: 'large' | 'default' | 'small';\n onChange: (selectedAll: Array<V>, selectd: V, isChecked: boolean) => void;\n onSearch?: (seachValue: string) => void;\n loading?: boolean;\n placeholder?: string;\n emptyOption?: boolean | React.ReactNode;\n selectCloseDrop?: boolean;\n}\n\nfunction SearchTagInput<V extends SearchTagInputOption>(props: SearchTagInputProps<V>) {\n const {\n prefixCls = 'w-search-tree',\n size = 'default',\n disabled = false,\n allowClear = false,\n loading = false,\n selectCloseDrop = false,\n className,\n style,\n placeholder,\n\n content,\n options,\n values,\n onChange,\n onSearch,\n emptyOption,\n // ...others\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const [innerIsOpen, setInnerIsOpen] = useState(false);\n const [selectedOption, setSelectedOption] = useState<Array<V>>(values);\n const optionRef = useRef<Array<V>>();\n const [searchValue, searchValueSet] = useState<string>('');\n optionRef.current = useMemo(() => selectedOption, [selectedOption]);\n const [selectIconType, setSelectIconType] = useState('');\n const inputRef = useRef<HTMLInputElement>(null);\n\n useEffect(() => {\n setSelectedOption(values);\n }, [JSON.stringify(values)]);\n\n function renderSelectIcon(type: string) {\n const selectIconType = type === 'enter' && allowClear && (!!selectedOption.length || searchValue) ? 'close' : '';\n setSelectIconType(selectIconType);\n }\n\n const handleSelectChange = (selectedAll: Array<V>, selectd?: V, isChecked: boolean = true) => {\n setSelectedOption(selectedAll);\n\n searchValueChange('');\n onChange?.(selectedAll, selectd!, isChecked);\n };\n\n const removeSelectItem = (index: number) => {\n const selectedOption = optionRef.current as Array<V>;\n const curreentItem = selectedOption[index];\n selectedOption.splice(index, 1);\n handleSelectChange([...selectedOption], curreentItem, false);\n };\n\n function handleInputChange(value: string) {\n setInnerIsOpen(true);\n searchValueChange(value);\n setSelectIconType(value ? 'loading' : '');\n }\n\n const searchValueChange = (value: string) => {\n searchValueSet(value);\n onSearch?.(value);\n };\n\n // 清除选中的值\n function resetSelectedValue(e: any) {\n e.stopPropagation();\n inputRef.current?.focus();\n handleInputChange('');\n setInnerIsOpen(false);\n setSelectedOption([]);\n handleSelectChange([]);\n }\n\n function inputKeyDown(e: any) {\n if (selectedOption.length > 0 && !searchValue && e.keyCode === 8) {\n removeSelectItem(selectedOption.length - 1);\n }\n }\n\n const newContent = useMemo(() => {\n if (emptyOption) {\n return typeof emptyOption === 'boolean' ? <Empty style={{ minWidth: 200, width: style?.width }} /> : emptyOption;\n }\n\n const newProps = {\n ...content.props,\n onSelected: (selectedAll: Array<V>, selectd?: V, isChecked: boolean = true) => {\n setInnerIsOpen(!selectCloseDrop);\n handleSelectChange(selectedAll, selectd, isChecked);\n },\n values: selectedOption,\n options,\n };\n return React.cloneElement(content as JSX.Element, newProps);\n }, [JSON.parse(JSON.stringify(selectedOption)), options, emptyOption]);\n\n return (\n <Dropdown\n className={cls}\n trigger=\"click\"\n onVisibleChange={(isOpen: boolean) => {\n setInnerIsOpen(isOpen);\n if (!isOpen) searchValueChange('');\n }}\n disabled={disabled}\n isOpen={innerIsOpen}\n menu={<Card bodyStyle={emptyOption === true ? { padding: 0 } : undefined}>{newContent}</Card>}\n >\n <div\n onMouseOver={() => renderSelectIcon('enter')}\n onMouseLeave={() => renderSelectIcon('leave')}\n onClick={() => inputRef.current?.focus()}\n style={{ minWidth: 200, maxWidth: 'none', ...style }}\n >\n <div className={`${prefixCls}-inner`}>\n <div style={{ display: 'flex', flexFlow: 'wrap', width: '100%' }}>\n {selectedOption.map((item, index) => {\n return (\n <Tag\n style={{ height: 20, margin: 1, display: 'flex', alignItems: 'center' }}\n className={`${prefixCls}-tag`}\n key={index}\n closable\n disabled={disabled}\n color=\"#393E48\"\n onClose={(e) => {\n e.stopPropagation();\n removeSelectItem(index);\n }}\n >\n {item.label}\n </Tag>\n );\n })}\n <Input\n ref={inputRef}\n style={{}}\n className={`${prefixCls}-input-contents`}\n size={size}\n disabled={disabled}\n onKeyDown={inputKeyDown}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => handleInputChange(e.target.value)}\n value={searchValue}\n placeholder={selectedOption.length ? '' : placeholder}\n />\n </div>\n {!disabled && (\n <span style={{ height: 25, width: 14 }} className={`${prefixCls}-close-tag-contents`}>\n {(selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon\n type={selectIconType}\n spin={loading && selectIconType === 'loading'}\n onClick={resetSelectedValue}\n />\n )}\n </span>\n )}\n </div>\n </div>\n </Dropdown>\n );\n}\n\nexport default SearchTagInput;\n","import React, { useState, useEffect } from 'react';\nimport SearchTagInput, { DropContent, SearchTagInputOption } from './SearchTagInput';\nimport Tree, { TreeData, TreeProps } from '@uiw/react-tree';\nimport TreeChecked, { TreeCheckedProps } from '@uiw/react-tree-checked';\n\ntype SelectOtpion = Record<string | number, string>;\n\n// type TreeCheckedsProps = TreeCheckedProps & Partial<DropContent<SearchTagInputOption>>\nfunction TreeCheckeds<V extends SearchTagInputOption>(\n props: Omit<TreeCheckedProps, 'onSelected'> & Partial<DropContent<V>>,\n) {\n const [selectOption, selectOptionSet] = useState<SelectOtpion>({});\n const [keys, keysSet] = useState<Array<string | number>>([]);\n\n useEffect(() => {\n let selectOption: SelectOtpion = {};\n const keys = props.values?.map((opt) => {\n selectOption[opt.key] = opt.label;\n return opt.key;\n });\n selectOptionSet(selectOption);\n keysSet(keys || []);\n }, [props.values]);\n\n const onSelected = (_: any, item: any, isChecked: boolean, evn: TreeData) => {\n const curSelectOption: SelectOtpion = getOptionsRecursion([evn], selectOption, isChecked);\n let isNumberKey = false;\n if (typeof item === 'number') isNumberKey = true;\n const option = Object.entries(curSelectOption).map(\n ([key, label]) => ({ key: isNumberKey ? Number.parseInt(key) : key, label } as V),\n );\n props.onSelected?.(option, { key: evn.key, label: evn.label as string } as V, isChecked);\n };\n\n const getOptionsRecursion = (childrens: TreeData[], selectOption: SelectOtpion, isAdd: boolean) => {\n const addOrDel = (key: string | number, label: string, isAdd: boolean) => {\n if (isAdd) {\n selectOption[key] = label;\n } else {\n delete selectOption[key!];\n }\n };\n const iteratorParent = (child: TreeData) => {\n // 向上迭代\n if (child.parent) {\n const selectCount = child.parent.children.filter((child: TreeData) => !selectOption[child.key!]).length;\n addOrDel(child.parent.key, child.parent.label, selectCount === 0);\n iteratorParent(child.parent);\n }\n };\n\n childrens.forEach((child: TreeData) => {\n if (!!child.children?.length) {\n selectOption = getOptionsRecursion(child.children, selectOption, isAdd);\n }\n addOrDel(child.key!, child.label?.toString()!, isAdd);\n iteratorParent(child);\n });\n return selectOption;\n };\n\n return (\n <TreeChecked defaultExpandAll={true} {...props} data={props.options} selectedKeys={keys} onSelected={onSelected} />\n );\n}\n\nfunction SingeTree<V extends SearchTagInputOption>(props: Omit<TreeProps, 'onSelected'> & Partial<DropContent<V>>) {\n const [keys, keysSet] = useState<Array<string | number>>([]);\n\n useEffect(() => {\n const keys: Array<string | number> = [];\n if (props.values?.length) keys[0] = props.values[0].key;\n keysSet(keys);\n }, [props.values]);\n\n const onSelected = (_1: any, _2: any, isChecked: boolean, evn: TreeData) => {\n const { key, label } = evn;\n const cur = { key, label } as V;\n props.onSelected?.(isChecked ? [cur] : [], cur, isChecked);\n };\n\n return (\n <Tree\n defaultExpandAll={true}\n {...props}\n multiple={false}\n data={props.options}\n selectedKeys={keys}\n onSelected={onSelected}\n />\n );\n}\n\nexport interface SearchTreeProps<V> {\n onChange?: (selectd: V, selectedAll: Array<V>, isChecked: boolean) => void;\n onSearch?: (seachValue: string) => void;\n value?: Array<V>;\n options?: TreeData[];\n treeProps?: Omit<TreeCheckedProps, 'onSelected'> & Partial<DropContent<V>>;\n emptyOption?: React.ReactNode;\n multiple?: boolean;\n}\n\nfunction SearchTree<V extends SearchTagInputOption>(props: SearchTreeProps<V>) {\n const {\n onChange,\n onSearch,\n multiple = true,\n options = [],\n value = [],\n emptyOption = !options.length,\n treeProps,\n ...other\n } = props;\n const [selectedValues, selectedValuesSet] = useState<Array<V>>(Array.isArray(value) ? value : [value]);\n const [selectedOptions, selectedOptionSet] = useState<Array<TreeData>>(options);\n const [isEmpty, isEmptySet] = useState(emptyOption);\n\n useEffect(() => {\n selectedValuesSet(Array.isArray(value) ? value : []);\n }, [JSON.stringify(value)]);\n\n const selectedChange = (resultValue: Array<V>, cur: V, isChecked: boolean) => {\n selectedValuesSet(resultValue);\n onChange?.(cur, resultValue, isChecked);\n };\n\n // 防抖\n const debounce = (fn: Function, ms: number) => {\n let timeoutId: NodeJS.Timeout;\n return (searchValue: string) => {\n onSearch?.(searchValue);\n clearTimeout(timeoutId);\n timeoutId = setTimeout(() => {\n fn(searchValue);\n }, ms);\n };\n };\n\n const selectedSearch = (searchValue: string) => {\n const hiddenNodeForSeach = (childrens: TreeData[], parentIsHide: boolean = true) => {\n childrens.forEach((child: TreeData) => {\n const isHide = !(child.label as string).includes(searchValue.trim()) && parentIsHide;\n if (!!child.children?.length) {\n hiddenNodeForSeach(child.children, isHide);\n const find = child.children.find((item) => !item.hideNode);\n child.hideNode = isHide && !find;\n } else {\n child.hideNode = isHide;\n }\n });\n };\n hiddenNodeForSeach(options);\n selectedOptionSet([...options]);\n\n let isEmpt = true;\n options.forEach((opt) => (isEmpt = isEmpt && !!opt.hideNode));\n isEmptySet(typeof emptyOption === 'boolean' && isEmpt ? isEmpt : emptyOption);\n };\n\n return (\n <SearchTagInput\n {...other}\n emptyOption={isEmpty}\n selectCloseDrop={!multiple}\n onSearch={selectedSearch}\n onChange={selectedChange}\n values={selectedValues}\n options={selectedOptions}\n content={multiple ? <TreeCheckeds {...treeProps} /> : <SingeTree {...treeProps} />}\n />\n );\n}\n\nexport default SearchTree;\n","import React, { useEffect, useRef, useState } from 'react';\nimport { IProps } from '@uiw/utils';\nimport Card from '@uiw/react-card';\nimport Icon from '@uiw/react-icon';\nimport Input from '@uiw/react-input';\nimport TreeChecked from '@uiw/react-tree-checked';\nimport { TreeData } from '@uiw/react-tree';\nimport './style/index.less';\nimport Checkbox from '@uiw/react-checkbox';\n\nexport interface TransferOptionType {\n key: string | number;\n label: string;\n}\n\nenum CheckedStatus {\n UnChecked = 0,\n AllChecked = 1,\n Indeterminate = 2,\n}\n\ninterface TransferProps extends IProps {\n placeholder?: string;\n bodyStyle?: React.CSSProperties;\n\n onChange?: (transfer: string, selectedAll: Array<TransferOptionType>) => void;\n onSearch?: (transfer: string, seachValue: string) => void;\n showSearch?: boolean;\n selectedAll?: boolean;\n value?: Array<TransferOptionType>;\n options?: TreeData[];\n // emptyOption?: React.ReactNode;\n}\n\nfunction Transfer(props: TransferProps) {\n const {\n placeholder,\n options,\n value = [],\n showSearch = false,\n selectedAll = false,\n\n bodyStyle,\n style,\n className,\n prefixCls = 'w-transfer',\n } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n\n const [searchValueLeft, searchValueLeftSet] = useState('');\n const [searchValueRight, searchValueRightSet] = useState('');\n const [selectedOptions, selectedOptionSet] = useState<Array<TreeData>>(options || []);\n const selectedOptionsShowCount = useRef<number>(0);\n const [selectOption, selectOptionSet] = useState<Map<string | number, string>>(new Map());\n const [leftSelectOption, leftSelectOptionSet] = useState<Map<string | number, string>>(new Map());\n const [leftSelectedKeys, leftSelectedKeySet] = useState<Array<string | number | undefined>>([]);\n const [rightSelectedKeys, rightSelectedKeySet] = useState<Array<string | number | undefined>>([]);\n const [rightOpions, rightOpionSet] = useState<Array<TreeData>>([]);\n const [selectAllChecked, selectAllCheckedSet] = useState<{ left: CheckedStatus; right: CheckedStatus }>({\n left: CheckedStatus.UnChecked,\n right: CheckedStatus.UnChecked,\n });\n\n useEffect(() => {\n if (value) {\n rightOpionSet(value || []);\n\n value?.forEach((selectd) => selectOption.set(selectd.key, selectd.label));\n hiddenNode((child) => !!value?.find((selectd) => child.key === selectd.key));\n }\n }, [JSON.stringify(value)]);\n\n const hiddenNode = (callBackfn: (child: TreeData) => boolean) => {\n selectedOptionsShowCount.current = 0;\n const hiddenNodeForSeach = (childrens: TreeData[]) => {\n childrens.forEach((child: TreeData) => {\n const isHide = callBackfn(child); // && parentIsHide;\n if (!!child.children?.length) {\n hiddenNodeForSeach(child.children);\n const find = child.children.find((item: TreeData) => !item.hideNode);\n child.hideNode = isHide && !find;\n } else {\n child.hideNode = isHide;\n }\n if (!child.hideNode) {\n selectedOptionsShowCount.current++;\n }\n });\n };\n hiddenNodeForSeach(selectedOptions);\n selectedOptionSet([...selectedOptions]);\n };\n\n const getOptionsRecursion = (childrens: TreeData[], selectOption: Map<string | number, string>, isAdd: boolean) => {\n const addOrDel = (key: string | number, label: string, isAdd: boolean) => {\n if (isAdd) {\n selectOption.set(key, label);\n } else {\n selectOption.delete(key);\n }\n };\n const iteratorParent = (child: TreeData) => {\n if (child.parent) {\n const selectCount = child.parent.children.filter(\n (child: TreeData) => !selectOption.get(child.key!) && !child.hideNode,\n ).length;\n addOrDel(child.parent.key, child.parent.label, selectCount === 0);\n iteratorParent(child.parent);\n }\n };\n\n childrens.forEach((child: TreeData) => {\n if (!!child.children?.length) {\n selectOption = getOptionsRecursion(child.children, selectOption, isAdd);\n }\n addOrDel(child.key!, child.label?.toString()!, isAdd);\n iteratorParent(child);\n });\n return selectOption;\n };\n\n const leftTreeOnSelected = (\n selectedKeys: Array<string | number | undefined>,\n _1: any,\n isChecked: boolean,\n evn: TreeData,\n ) => {\n leftSelectedKeySet(selectedKeys);\n const selectOptionTemp = getOptionsRecursion([evn], leftSelectOption, isChecked);\n leftSelectOptionSet(selectOptionTemp);\n };\n\n const rightTreeOnSelected = (selectedKeys: Array<string | number | undefined>) => {\n rightSelectedKeySet(selectedKeys);\n };\n\n const transferClick = (transferType: 'left' | 'right') => {\n if (transferType === 'left') {\n leftSelectOption.forEach((value, key) => {\n selectOption.set(key, value);\n });\n leftSelectOptionSet(new Map());\n leftSelectedKeySet([]);\n } else {\n rightSelectedKeys.forEach((key) => {\n selectOption.delete(key!);\n });\n rightSelectedKeySet([]);\n }\n\n selectOptionSet(selectOption);\n const option: Array<TransferOptionType> = [];\n selectOption.forEach((label, key) => option.push({ key, label }));\n props.onChange?.(transferType, option);\n };\n\n const searchValueLeftChange = (searchValue: string) => {\n hiddenNode((child: TreeData) => {\n let searchIsMatch = !(child.label as string).includes(searchValue.trim());\n if (!searchIsMatch) {\n const isSekected = rightOpions.find((selected) => selected.key === child.key);\n searchIsMatch = !!isSekected;\n }\n return searchIsMatch;\n });\n\n searchValueLeftSet(searchValue);\n\n props.onSearch?.('left', searchValue);\n };\n\n const searchValueRightChange = (searchValue: string) => {\n searchValueRightSet(searchValue);\n\n rightOpions.forEach((option) => {\n const isHide = !(option.label as string).includes(searchValue.trim());\n option.hideNode = isHide;\n });\n rightOpionSet(rightOpions);\n\n props.onSearch?.('right', searchValue);\n };\n\n const selectAllLeftChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const isChecked = e.target.checked;\n\n selectAllChecked.left = isChecked ? 1 : 0;\n if (isChecked) {\n const keys: Array<string | number> = [];\n const selectedOptionsRecursion = (selectedOptions: Array<TreeData>) => {\n selectedOptions.forEach((child) => {\n if (child.children?.length) {\n selectedOptionsRecursion(child.children);\n }\n if (!child.hideNode) {\n leftSelectOption.set(child.key!, child.label as string);\n keys.push(child.key!);\n }\n });\n };\n selectedOptionsRecursion(selectedOptions);\n\n leftSelectOptionSet(leftSelectOption);\n leftSelectedKeySet(keys);\n } else {\n leftSelectedKeySet([]);\n leftSelectOptionSet(new Map());\n }\n selectAllCheckedSet(selectAllChecked);\n };\n\n const selectAllRightChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const isChecked = e.target.checked;\n\n selectAllChecked.right = isChecked ? 1 : 0;\n if (isChecked) {\n const keys = rightOpions.map((child) => child.key);\n rightSelectedKeySet(keys);\n } else {\n rightSelectedKeySet([]);\n }\n selectAllCheckedSet(selectAllChecked);\n };\n\n const Arrow = (props: { click: () => void; style: React.CSSProperties }) => (\n <Icon\n onClick={() => props.click()}\n type=\"down-square-o\"\n className={`${prefixCls}-arrow`}\n style={{ fontSize: 20, stroke: '#e9e9e9', fill: '#333', ...props.style }}\n />\n );\n\n return (\n <div className={cls} style={{ width: 400, ...style }}>\n <Card\n bodyStyle={{ padding: '5px 9px' }}\n title={\n <div>\n {selectedAll && (\n <Checkbox\n indeterminate={leftSelectedKeys.length < selectedOptionsShowCount.current && !!leftSelectedKeys.length}\n checked={leftSelectedKeys.length >= selectedOptionsShowCount.current && !!leftSelectedKeys.length}\n onChange={selectAllLeftChange}\n />\n )}\n <label style={{ marginLeft: 3 }}>\n {leftSelectedKeys.length}/{selectedOptionsShowCount.current}\n </label>\n </div>\n }\n className={`${prefixCls}-card`}\n >\n {showSearch && (\n <Input\n placeholder={placeholder}\n value={searchValueLeft}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => searchValueLeftChange(e.target.value)}\n />\n )}\n <div className={`${prefixCls}-cheked-content`}>\n <TreeChecked\n defaultExpandAll={true}\n placeholder={placeholder || '搜索选项'}\n data={selectedOptions}\n selectedKeys={leftSelectedKeys}\n onSelected={leftTreeOnSelected}\n />\n </div>\n </Card>\n <div className={`${prefixCls}-arrow-content`}>\n <Arrow\n click={() => transferClick('left')}\n style={{ transform: 'rotate(-90deg)', background: leftSelectedKeys.length > 0 ? '#393E48' : 'none' }}\n />\n <Arrow\n click={() => transferClick('right')}\n style={{ transform: 'rotate(90deg)', background: rightSelectedKeys.length > 0 ? '#393E48' : 'none' }}\n />\n </div>\n <Card\n bodyStyle={{ padding: '5px 9px' }}\n className={`${prefixCls}-card`}\n title={\n <div>\n {selectedAll && (\n <Checkbox\n indeterminate={rightSelectedKeys.length < rightOpions.length && !!rightSelectedKeys.length}\n checked={rightSelectedKeys.length === rightOpions.length && !!rightSelectedKeys.length}\n onChange={selectAllRightChange}\n />\n )}\n <label style={{ marginLeft: 3 }}>\n {rightSelectedKeys.length}/{rightOpions.length}\n </label>\n </div>\n }\n >\n {showSearch && (\n <Input\n placeholder={placeholder}\n value={searchValueRight}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => searchValueRightChange(e.target.value)}\n />\n )}\n <div className={`${prefixCls}-cheked-content`} style={bodyStyle}>\n <TreeChecked data={rightOpions} selectedKeys={rightSelectedKeys} onSelected={rightTreeOnSelected} />\n </div>\n </Card>\n </div>\n );\n}\n\nexport default Transfer;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","var deferred = [];\n__webpack_require__.O = function(result, chunkIds, fn, priority) {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + ({\"889\":\"vendors-prismjs\",\"6982\":\"vendors-standalone\"}[chunkId] || chunkId) + \".\" + {\"163\":\"60d7dfd0\",\"207\":\"891adb65\",\"221\":\"e5281da2\",\"433\":\"7bd8beab\",\"486\":\"fc977627\",\"643\":\"6180554b\",\"694\":\"ee606ced\",\"745\":\"3a86c62c\",\"747\":\"7519f1c0\",\"748\":\"1a34c974\",\"766\":\"254f786a\",\"782\":\"9ec6f1b3\",\"875\":\"5e32c556\",\"889\":\"b53bdc3b\",\"922\":\"b1f148e3\",\"1016\":\"a3866702\",\"1059\":\"6491b507\",\"1061\":\"343e86f3\",\"1127\":\"d65f8357\",\"1151\":\"3c560b1f\",\"1169\":\"1ecb7cff\",\"1317\":\"40ef64c0\",\"1358\":\"e579baca\",\"1584\":\"c79fea2e\",\"1619\":\"490c4644\",\"1756\":\"87f583cc\",\"1820\":\"91de173a\",\"1892\":\"0f341f07\",\"1971\":\"d746cb8b\",\"2078\":\"53137233\",\"2156\":\"9e4a9aad\",\"2190\":\"f6759a84\",\"2230\":\"3fea0ff3\",\"2316\":\"17cf440d\",\"2367\":\"f02613a4\",\"2411\":\"64a94b36\",\"2448\":\"1d46904a\",\"2456\":\"624e63f5\",\"2582\":\"b4e4b02b\",\"2595\":\"3918e355\",\"2679\":\"0780e749\",\"2692\":\"db178ecc\",\"2737\":\"514088d8\",\"2782\":\"e9a225b8\",\"2795\":\"45c184a0\",\"2926\":\"f11fdc77\",\"3151\":\"59d27efa\",\"3257\":\"5693b5c1\",\"3259\":\"80ff41ab\",\"3261\":\"d4120c57\",\"3313\":\"84e7d8c8\",\"3450\":\"812a2002\",\"3518\":\"0932e263\",\"3769\":\"535a1903\",\"3811\":\"ac38cada\",\"3812\":\"5a956589\",\"3917\":\"b7c20507\",\"3931\":\"088517c5\",\"4010\":\"e810a27a\",\"4036\":\"412a4652\",\"4098\":\"42dfa715\",\"4128\":\"57b5df0c\",\"4188\":\"af2072cf\",\"4396\":\"f408da76\",\"4405\":\"c878210e\",\"4503\":\"10002c32\",\"4648\":\"020a8ba8\",\"4663\":\"3af03860\",\"4781\":\"ce661c8a\",\"4877\":\"ff8d6c5f\",\"4948\":\"64bfa5c8\",\"5146\":\"76b73d7f\",\"5244\":\"6d892b74\",\"5253\":\"7a8716a8\",\"5263\":\"3f93670f\",\"5308\":\"e7bc3bd1\",\"5364\":\"b95913d0\",\"5393\":\"78e10b91\",\"5408\":\"245385b9\",\"5468\":\"aef3688e\",\"5595\":\"edf11bc3\",\"5821\":\"41b747c6\",\"5865\":\"e35903d3\",\"5930\":\"65ea3787\",\"5933\":\"5ead180b\",\"6019\":\"2d06a6af\",\"6036\":\"289c2eb8\",\"6510\":\"ca9a0753\",\"6536\":\"e713d674\",\"6566\":\"511e95c6\",\"6659\":\"32d92089\",\"6715\":\"6fa01148\",\"6730\":\"2fd6957b\",\"6869\":\"5433df9b\",\"6878\":\"c6cec0d9\",\"6982\":\"00edacc6\",\"7079\":\"3aa94426\",\"7087\":\"6b5dade8\",\"7104\":\"82c7839e\",\"7157\":\"3061bc55\",\"7217\":\"1be488ae\",\"7266\":\"bba9c51f\",\"7313\":\"e4afef69\",\"7390\":\"3186cda7\",\"7541\":\"c230d256\",\"7664\":\"f92b74f7\",\"7761\":\"0418b05d\",\"7763\":\"444dce16\",\"7834\":\"d0be3711\",\"7861\":\"757503f5\",\"7875\":\"43ceac1d\",\"7884\":\"fc756073\",\"7970\":\"2adbe6f1\",\"8023\":\"8ac702c4\",\"8073\":\"166fef3c\",\"8312\":\"58a5729e\",\"8398\":\"cc6aa9ea\",\"8488\":\"148bfa75\",\"8566\":\"99e7e5a0\",\"8586\":\"9d605493\",\"8709\":\"44b46cf7\",\"8747\":\"04252521\",\"8768\":\"5facbb82\",\"8849\":\"d5dd1a61\",\"8898\":\"423c19d9\",\"8915\":\"82c6b45a\",\"9057\":\"b21f426b\",\"9121\":\"2aff309b\",\"9137\":\"fdbcd423\",\"9147\":\"d6a507a2\",\"9188\":\"b7ce0cf2\",\"9200\":\"0a1f7353\",\"9253\":\"79f1c9ea\",\"9260\":\"8b954f3a\",\"9384\":\"2221f70e\",\"9429\":\"3b8debbf\",\"9503\":\"b6e64ac7\",\"9636\":\"279db5c1\",\"9673\":\"7d7c1a3a\",\"9763\":\"7087765d\",\"9776\":\"e2d9ef54\",\"9777\":\"5ceff998\",\"9820\":\"1374775d\",\"9836\":\"8cd96a11\",\"9853\":\"91f01ff6\",\"9900\":\"2d8ffaaf\",\"9961\":\"9db8f620\"}[chunkId] + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/css/\" + chunkId + \".\" + {\"163\":\"296853db\",\"221\":\"296853db\",\"433\":\"296853db\",\"643\":\"296853db\",\"694\":\"296853db\",\"748\":\"296853db\",\"875\":\"296853db\",\"1059\":\"296853db\",\"1061\":\"296853db\",\"1169\":\"296853db\",\"1317\":\"296853db\",\"1584\":\"296853db\",\"1619\":\"296853db\",\"1820\":\"296853db\",\"2156\":\"296853db\",\"2190\":\"296853db\",\"2230\":\"296853db\",\"2316\":\"296853db\",\"2367\":\"296853db\",\"2411\":\"296853db\",\"2582\":\"296853db\",\"2595\":\"296853db\",\"2737\":\"296853db\",\"2782\":\"296853db\",\"3313\":\"296853db\",\"3518\":\"296853db\",\"3812\":\"296853db\",\"3917\":\"296853db\",\"4010\":\"296853db\",\"4098\":\"296853db\",\"4128\":\"296853db\",\"4188\":\"296853db\",\"4396\":\"774af801\",\"4405\":\"296853db\",\"4503\":\"296853db\",\"4648\":\"296853db\",\"4877\":\"6e864cd4\",\"4948\":\"296853db\",\"5244\":\"296853db\",\"5263\":\"296853db\",\"5308\":\"296853db\",\"5393\":\"296853db\",\"5408\":\"296853db\",\"5595\":\"296853db\",\"5865\":\"296853db\",\"5933\":\"296853db\",\"6510\":\"296853db\",\"6715\":\"296853db\",\"6730\":\"296853db\",\"7087\":\"296853db\",\"7104\":\"296853db\",\"7157\":\"296853db\",\"7390\":\"296853db\",\"7541\":\"296853db\",\"7761\":\"296853db\",\"7834\":\"296853db\",\"7875\":\"296853db\",\"7884\":\"296853db\",\"8023\":\"296853db\",\"8073\":\"296853db\",\"8566\":\"296853db\",\"8898\":\"296853db\",\"9121\":\"296853db\",\"9200\":\"14abaeb3\",\"9253\":\"296853db\",\"9260\":\"296853db\",\"9384\":\"296853db\",\"9503\":\"296853db\",\"9673\":\"296853db\",\"9763\":\"296853db\",\"9776\":\"296853db\",\"9777\":\"296853db\",\"9853\":\"296853db\"}[chunkId] + \".chunk.css\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"website:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\t;\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"./\";","var createStylesheet = function(chunkId, fullhref, resolve, reject) {\n\tvar linkTag = document.createElement(\"link\");\n\n\tlinkTag.rel = \"stylesheet\";\n\tlinkTag.type = \"text/css\";\n\tvar onLinkComplete = function(event) {\n\t\t// avoid mem leaks.\n\t\tlinkTag.onerror = linkTag.onload = null;\n\t\tif (event.type === 'load') {\n\t\t\tresolve();\n\t\t} else {\n\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\tvar realHref = event && event.target && event.target.href || fullhref;\n\t\t\tvar err = new Error(\"Loading CSS chunk \" + chunkId + \" failed.\\n(\" + realHref + \")\");\n\t\t\terr.code = \"CSS_CHUNK_LOAD_FAILED\";\n\t\t\terr.type = errorType;\n\t\t\terr.request = realHref;\n\t\t\tlinkTag.parentNode.removeChild(linkTag)\n\t\t\treject(err);\n\t\t}\n\t}\n\tlinkTag.onerror = linkTag.onload = onLinkComplete;\n\tlinkTag.href = fullhref;\n\n\tdocument.head.appendChild(linkTag);\n\treturn linkTag;\n};\nvar findStylesheet = function(href, fullhref) {\n\tvar existingLinkTags = document.getElementsByTagName(\"link\");\n\tfor(var i = 0; i < existingLinkTags.length; i++) {\n\t\tvar tag = existingLinkTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\") || tag.getAttribute(\"href\");\n\t\tif(tag.rel === \"stylesheet\" && (dataHref === href || dataHref === fullhref)) return tag;\n\t}\n\tvar existingStyleTags = document.getElementsByTagName(\"style\");\n\tfor(var i = 0; i < existingStyleTags.length; i++) {\n\t\tvar tag = existingStyleTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\");\n\t\tif(dataHref === href || dataHref === fullhref) return tag;\n\t}\n};\nvar loadStylesheet = function(chunkId) {\n\treturn new Promise(function(resolve, reject) {\n\t\tvar href = __webpack_require__.miniCssF(chunkId);\n\t\tvar fullhref = __webpack_require__.p + href;\n\t\tif(findStylesheet(href, fullhref)) return resolve();\n\t\tcreateStylesheet(chunkId, fullhref, resolve, reject);\n\t});\n}\n// object to store loaded CSS chunks\nvar installedCssChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.miniCss = function(chunkId, promises) {\n\tvar cssChunks = {\"163\":1,\"221\":1,\"433\":1,\"643\":1,\"694\":1,\"748\":1,\"875\":1,\"1059\":1,\"1061\":1,\"1169\":1,\"1317\":1,\"1584\":1,\"1619\":1,\"1820\":1,\"2156\":1,\"2190\":1,\"2230\":1,\"2316\":1,\"2367\":1,\"2411\":1,\"2582\":1,\"2595\":1,\"2737\":1,\"2782\":1,\"3313\":1,\"3518\":1,\"3812\":1,\"3917\":1,\"4010\":1,\"4098\":1,\"4128\":1,\"4188\":1,\"4396\":1,\"4405\":1,\"4503\":1,\"4648\":1,\"4877\":1,\"4948\":1,\"5244\":1,\"5263\":1,\"5308\":1,\"5393\":1,\"5408\":1,\"5595\":1,\"5865\":1,\"5933\":1,\"6510\":1,\"6715\":1,\"6730\":1,\"7087\":1,\"7104\":1,\"7157\":1,\"7390\":1,\"7541\":1,\"7761\":1,\"7834\":1,\"7875\":1,\"7884\":1,\"8023\":1,\"8073\":1,\"8566\":1,\"8898\":1,\"9121\":1,\"9200\":1,\"9253\":1,\"9260\":1,\"9384\":1,\"9503\":1,\"9673\":1,\"9763\":1,\"9776\":1,\"9777\":1,\"9853\":1};\n\tif(installedCssChunks[chunkId]) promises.push(installedCssChunks[chunkId]);\n\telse if(installedCssChunks[chunkId] !== 0 && cssChunks[chunkId]) {\n\t\tpromises.push(installedCssChunks[chunkId] = loadStylesheet(chunkId).then(function() {\n\t\t\tinstalledCssChunks[chunkId] = 0;\n\t\t}, function(e) {\n\t\t\tdelete installedCssChunks[chunkId];\n\t\t\tthrow e;\n\t\t}));\n\t}\n};\n\n// no hmr","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkwebsite\"] = self[\"webpackChunkwebsite\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [9896,5183], function() { return __webpack_require__(52744); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["dark","viewBox","width","height","version","stroke","strokeWidth","fill","fillRule","d","light","NoMatch","to","De","Loader","tip","indicator","Icon","type","spin","style","verticalAlign","Options","props","useMemo","Select","value","onChange","e","target","isV1","split","window","location","href","currentVersion","pkg","versionList","data","firstVersion","unshift","className","styles","defaultValue","map","idx","home","component","github","issue","gitee","plugin","SiderMenu","useLocation","menu","find","item","RegExp","path","test","pathname","children","nav","icon","name","divider","replace","initialState","layout","reducer","state","action","ThemeContext","React","dispatch","rx","x","y","fillOpacity","menutop","china","id","transform","xlinkHref","Nav","useContext","Fragment","filter","Boolean","join","trim","logo","Object","keys","includes","Tooltip","usePortal","placement","content","whiteSpace","activeStyle","color","isActive","undefined","rel","onClick","Header","Layout","Sider","Content","Components","siderMenu","Affix","offsetTop","zIndex","display","alignItems","padding","position","left","top","bottom","overflow","paddingLeft","lineHeight","flexDirection","justifyContent","backgroundColor","Loadable","Component","Suspense","fallback","Home","lazy","Extensions","GuideQuickStart","GuideImport","GuideCreateReactApp","GuideKKT","GuideDocs","GuideVscode","GuideRecommendation","Overview","Colors","Alert","AutoLink","ResetCss","Avatar","Calendar","Cascader","Checkbox","CopyToClipboard","Collapse","Card","Carousel","Descriptions","Divider","Drawer","DatePicker","DateInput","Dropdown","Badge","Progress","Pagination","PinCode","Input","Button","Radio","SearchSelect","Split","Switch","Slider","Grid","Form","FileInput","Breadcrumb","List","Notify","Tree","TreeChecked","SearchTree","Transfer","Tag","Tabs","Table","TimePicker","Rate","Overlay","BackTop","Portal","OverlayTrigger","Popover","Message","MonthPicker","Textarea","Modal","Formatter","Steps","Menu","Empty","routes","element","index","App","useRoutes","Provider","useReducer","ReactDOM","document","getElementById","noop","getScroll","method","isWindow","ret","documentElement","getOffset","elemRect","getBoundingClientRect","targetRect","getTargetRect","scrollTop","scrollLeft","docElem","body","clientTop","clientLeft","getDefaultTarget","constructor","placeholderStyle","affixStyle","box","events","eventHandlers","timeout","getInstance","node","updatePosition","bind","componentDidMount","this","setTimeout","setTargetEventListeners","componentWillUnmount","clearEventListeners","clearTimeout","offsetBottom","offsetParent","elemSize","clientWidth","clientHeight","offsetMode","elemOffset","setPlaceholderStyle","setAffixStyle","affixed","setState","forEach","eventName","addEventListener","handler","removeEventListener","render","prefixCls","resetProps","cls","_jsx","ref","defaultProps","canUseDOM","createElement","container","defaultNode","useRef","containerRef","useEffect","current","removeChild","appendChild","isOpen","maskClosable","backdropProps","portalProps","hasBackdrop","unmountOnExit","transitionName","onOpening","onOpened","onClosing","onClosed","onClose","dialogProps","otherProps","useState","setIsOpen","visible","setVisible","overlay","overlayWillClose","classList","add","decoratedChild","cloneElement","tabIndex","handleBackdropMouseDown","onMouseDown","remove","TransitionGroupComp","CSSTransition","classNames","in","onEntering","onEntered","onExiting","onExited","status","_jsxs","tagName","TagName","others","svg","svgPaths","i","propps","disabled","active","loading","block","basic","htmlType","size","child","useButton","autoFocus","title","cancelText","cancelButtonProps","confirmButtonProps","confirmText","maxWidth","minWidth","isCloseButtonShown","onCancel","onConfirm","bodyStyle","other","setLoading","handleCancel","_handleCancel","_handleConfirm","handleConfirm","delimiter","text","word","match","url","_createElement","key","startsWith","shape","src","alt","onError","isImgExist","setIsImgExist","evn","getScrollTop","fixed","speed","showBelow","clickable","topShowBelow","percent","setPercent","setCurrent","onScroll","Math","round","scrollHeight","innerHeight","getScrollPercent","scrollToTop","step","start","timer","setInterval","scrollTo","clearInterval","scrollToAnimate","max","dot","processing","count","supProps","warpperProps","separator","isElm","assign","Item","vertical","context","parentNode","isDOM","HTMLElement","nodeType","nodeName","contains","compareDocumentPosition","getBordersSize","axis","sideA","sideB","parseFloat","isIE11","isBrowser","MSInputMethodContext","documentMode","isIE10","navigator","userAgent","isIE","getSize","html","computedStyle","parseInt","rect","right","offsets","result","sizes","getComputedStyle","getWindowSizes","ownerDocument","horizScrollbar","offsetWidth","vertScrollbar","offsetHeight","offsetLeft","property","css","defaultView","getStyleComputedProperty","getOuterSizes","scrollWidth","getStyle","options","triggerDom","trigger","popupDom","popup","autoAdjustOverflow","sty","winSizeHeight","winSizeWidth","innerWidth","normalizeDelay","delay","show","hide","isOutside","isClickOutside","onVisibleChange","onEnter","triggerRef","popupRef","timeoutRef","hoverStateRef","overlayStyl","setOverlayStyl","useImperativeHandle","overlayProps","triggerProps","handleClickOutside","handleResize","styls","popNode","childNode","clearTimeouts","length","timeoutId","handleShow","handle","push","handleHide","handleMouseOverOut","relatedNative","currentTarget","related","relatedTarget","nativeEvent","onFocus","onMouseOver","onMouseEnter","onMouseOut","onMouseLeave","isAppearing","renderArrow","visibleArrow","writingMode","preIcon","addonAfter","inputRef","addonRef","input","paddingRight","computedInputPadding","autoComplete","TimePickerPanel","date","hideDisabled","onSelected","disableds","getDisabledItem","num","Date","Array","_","liProps","currentDate","handleClick","currentCount","tag","dataset","Number","getItemInstance","TimePickerTime","precision","TimePanel","format","popoverProps","allowClear","disabledHours","disabledMinutes","disabledSeconds","inputProps","setDate","timeProps","inputValue","formatter","datePickerTime","_props","dataStr","placeholder","readOnly","classnames","obj","keyName","DayRect","selectedDate","col","today","panelDate","disabledDate","renderDay","onSelectDay","end","prev","selected","next","isNaN","getTime","isValidDate","year","getFullYear","month","getMonth","week","getDay","toDateString","lastDay","getDate","day","cellDate","divProps","cellMonth","WEEKTITLE","WEEKDAY","DatePickerDay","weekday","weekTitle","weekdayLabel","row","curDate","DatePickerMonth","monthLabel","selectedMonth","DatePickerYear","panelNum","activeYear","setActiveYear","selectedYear","setFullYear","handleSelected","arg","arguments","DatePickerCaption","todayButton","renderMonth","MONTH_LABEL","onPanelChange","showTime","setType","selectDate","setSelectDate","selectPanelDate","setSelectPanelDate","curType","setMonth","onSelectedDate","paging","dateSource","RenderDay","dayData","arr","label","_objectWithoutPropertiesLoose","titleFormat","todayLabel","onPaging","setPanelDate","handlePaging","titleLable","btngroup","propsNext","extra","footer","bordered","noHover","bodyClassName","direction","palyTime","scrollTime","autoPlay","afterChange","beforeChange","currentPosition","currentPositionSet","transitionInner","transitionInnerSet","positionRef","childCount","stopPlay","stop","after","before","gotoSlide","prevSlide","nextSlide","slidNumber","maxSlid","slidNumberTemp","play","ms","time","childrens","innerStyle","transition","disabledProps","Internal","multiline","isSubMenuItem","htmlProps","anchorCls","tagComp","MenuItem","displayName","MenuDivider","IconView","collapse","SubMenu","inlineIndent","overlayTriggerProps","menuProps","isCheck","checkedMenuItem","appear","onExit","theme","inlineCollapsed","onSearch","option","innerIsOpen","setInnerIsOpen","selectedValue","setSelectedValue","selectIconType","setSelectIconType","searchText","setSearchText","searchOn","setSearchOn","setInputValue","searchOption","setSearchOption","tempOptions","iteratorOption","opt","m","cb","opts","optsTemp","renderSelectIcon","valueTemp","optChildren","findOpt","handelChange","isSeleted","widths","OptionIter","level","minHeight","overflowY","optionsItem","splice","handleItemClick","fontSize","marginTop","_selectedValue","handelSearch","onBlur","stopPropagation","RadioAbstract","checked","prChecked","setChecked","prevChecked","setPrevChecked","persist","CheckboxGroup","valueRef","childs","isArray","include","val","InternalCheckbox","indeterminate","Group","toArray","activeKey","currentActiveKey","InternalCollapse","accordion","showArrow","propsActiveKey","setActiveKey","String","indexOf","childProps","onItemClick","Panel","header","iconRender","transitionDuration","instance","copy","isCopy","DateInputRange","datePickerProps","dateRange","setDateRange","handleChange","cdate","changeValue","propsValue","JSON","stringify","margin","autoClose","open","colon","span","labelProps","colSpan","Row","column","handleCell","isHead","Cell","isLastCell","InternalDescriptions","leftSpans","rows","columns","itemNode","generateChildrenRows","DescriptionsItem","dashed","align","restProps","bodyProps","bodyCls","styl","footerView","iconView","titleView","iconProps","description","dataLabel","dataList","uploadType","readonly","showFileIcon","showPreviewIcon","showRemoveIcon","onPreview","onAdd","onRemove","maxNumber","isAction","getBase64","file","reader","FileReader","Promise","resolve","readAsDataURL","getListFiles","files","dataURLKey","promiseFiles","all","then","fileListBase64","base64","multiple","inValue","fileList","setFileList","Comp","handleClickInput","useCallback","click","openFileDialog","onFileUpload","onInputChange","updatedFileList","updatedList","slice","FileList","Col","grow","gutter","justify","gutterStyl","FormItem","required","labelFor","labelClassName","labelStyle","help","inline","hasError","labelCls","htmlFor","fields","resetOnSubmit","onSubmitError","onSubmit","afterSubmit","initData","initial","submitting","errors","initialValue","currentValue","newFormState","setData","handleSubmit","resetForm","handleReset","getFieldValues","getError","setFields","setFieldValue","formUnits","error","childField","controlField","tempData","fieldName","validator","env","list","nextState","preventDefault","promise","onSuccess","response","reset","afterSubmitPromise","catch","canSubmit","passesValidators","prototype","hasOwnProperty","call","initials","entries","hasCurrentValue","ListItem","InternalList","items","striped","renderItem","dataSource","childrenList","classString","bgColor","fullscreen","indicatorView","cx","cy","r","strokeMiterlimit","tipsView","handleClosed","renderIcon","showIcon","rounded","elementProps","Child","pickerCaptionProps","handleSelectedDate","curPanelDate","captionType","notifys","Container","create","duration","closed","willUnmount","alertProps","notifysDom","NotificationCreate","div","random","toString","nprops","notifysChild","Option","alignment","total","pageSize","pageSizeOptions","currentNumber","onShowSizeChange","initPageSoure","ceil","itemCount","goto","textAlign","sizeCount","InternalPinCode","placehold","setPlacehold","values","setValues","handleBlur","event","handleFocus","inpProps","min","inputMode","charAt","focus","onKeyDown","toLocaleLowerCase","handleKeyDown","IconProgress","Circle","relativeStrokeWidth","elm","_strokeWidth","toFixed","radius","setAttribute","perimeter","PI","progressInfo","showText","progressStatus","percentView","strokeLinecap","Line","percentStyle","defValue","allowHalf","character","onHoverChange","setValue","hoverCount","setHoverCount","prevValue","setPrevValue","getValue","isLeft","clientX","halfon","activeCls","onMouseMove","closable","borderColor","boxShadow","valueAmount","maxTagCount","labelInValue","mode","showSearch","tagProps","onSelect","isMultiple","selectedLabel","setSelectedLabel","omitTagCount","divRef","valueVerify","selectedValueChange","getSelectOption","findResult","v","selectedLabelChange","handleItemsClick","removeSelectItem","resultValue","handleSelectChange","handleInputChange","resetSelectedValue","maxHeight","findIndex","finds","_inputRef$current2","flexFlow","flex","keyCode","InternalSteps","progressDot","warpRef","lastStepOffsetWidth","setLastStepOffsetWidth","filteredChildren","c","lastIndex","domNode","lastChild","abs","calcStepOffsetWidth","stepNumber","itemWidth","adjustMarginRight","Step","stepItemStyle","stepItemDotStyle","marginRight","iconNode","Dots","marks","markRender","stepValue","dots","progress","tooltip","renderMarks","bar","slider","indexBar","startX","curValue","barWidth","barOffsetLeft","move","arrValue","setArrValue","getWidthToValue","equal","floor","onDragging","vals","valueToWidth","barStyl","onDragEnd","markOffset","newData","val1","val2","half","getRangeValue","getValueToPercent","leftValue","rightValue","getLabelValue","lleftPostion","onHandleBtnDown","stepWidth","stepArray","mark","getColspanNum","concat","getRowspanNum","getLevelItems","levelTop","ellipsis","rowSpan","getAllColumnsKeys","locationFixed","_location$index","_location$index2","ThComponent","updateLocation","rowNum","colNum","titleNode","onCellHead","locationWidth","thProps","TheadComponent","tds","ThComponentProps","ExpandableComponent","defaultExpand","expandIcon","expand","setExpand","TableTr","rowKey","onCell","isExpandedDom","hierarchy","indentSize","childrenColumnName","isOpacity","setIsOpacity","childrenIndex","setChildrenIndex","expandIndex","setExpandIndex","it","IconDom","flag","opacity","marginLeft","float","getIndex","j","trData","objs","isHasChildren","empty","expandable","scroll","setLocationWidth","finalLocationWidth","deepClumnsLocation","params","fistIndex","leftOrRight","isReverse","deepParams","sub","computed","childKey","defaultExpandAllRows","deep","arr1","defaultExpandedRowKeys","expandedRowKeys","record","expandedRowRender","rowExpandable","self","selfColumns","_expandable$defaultEx","onExpand","onExpandedRowsChange","table","overflowX","tableLayout","Thead","_extends","Pane","labelWidth","onTabClick","slideStyle","setSlideStyle","activeItem","flowLeft","displayStart","displayEnd","flowNav","flowNavSet","hiddenNav","hiddenNavSet","nodes","nodesSet","divContentRef","divNavRef","itemKey","divNavWidthChange","curWidth","showHideenNav","_flowNav$nav","calcSlideStyle","renderNav","Label","TreeNode","renderTitle","iconAnimation","isSelected","openKeys","selectedKeys","parent","onItemSelected","noChild","itemIsOpen","iconItem","childKeys","getChildKeys","checkedKeys","isHalfChecked","hideNode","isContained","a","b","aStr","len","depth","getParentKeys","getParentSelectKeys","defaultExpandAll","showLine","checkStrictly","autoExpandParent","curOpenKeys","setCurOpenKeys","curSelectedKeys","setCurSelectedKeys","arrOpenKeys","currentKeys","expanded","selKeys","findKey","from","Set","checkedProps","selectCloseDrop","emptyOption","selectedOption","setSelectedOption","optionRef","searchValue","searchValueSet","selectedAll","selectd","isChecked","searchValueChange","curreentItem","newContent","newProps","parse","TreeCheckeds","selectOption","selectOptionSet","keysSet","_props$values","getOptionsRecursion","isAdd","addOrDel","iteratorParent","selectCount","_child$children","_child$label","curSelectOption","isNumberKey","SingeTree","_props$values2","_1","_2","cur","CheckedStatus","treeProps","selectedValues","selectedValuesSet","selectedOptions","selectedOptionSet","isEmpty","isEmptySet","SearchTagInput","hiddenNodeForSeach","parentIsHide","isHide","_child$children2","isEmpt","searchValueLeft","searchValueLeftSet","searchValueRight","searchValueRightSet","selectedOptionsShowCount","Map","leftSelectOption","leftSelectOptionSet","leftSelectedKeys","leftSelectedKeySet","rightSelectedKeys","rightSelectedKeySet","rightOpions","rightOpionSet","UnChecked","selectAllChecked","selectAllCheckedSet","set","hiddenNode","callBackfn","delete","get","transferClick","transferType","Arrow","selectedOptionsRecursion","_child$children3","searchIsMatch","selectOptionTemp","background","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","__webpack_modules__","deferred","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","every","n","getter","__esModule","definition","o","defineProperty","enumerable","f","chunkId","reduce","promises","u","miniCssF","g","globalThis","Function","prop","inProgress","dataWebpackPrefix","l","done","script","needAttach","scripts","getElementsByTagName","s","getAttribute","charset","nc","onScriptComplete","onerror","onload","doneFns","head","Symbol","toStringTag","p","loadStylesheet","reject","fullhref","existingLinkTags","dataHref","existingStyleTags","findStylesheet","linkTag","errorType","realHref","err","Error","code","request","createStylesheet","installedCssChunks","miniCss","installedChunks","installedChunkData","realSrc","message","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","__webpack_exports__"],"sourceRoot":""}