-
-
Notifications
You must be signed in to change notification settings - Fork 115
/
main.d44eb427.js.map
1 lines (1 loc) · 525 KB
/
main.d44eb427.js.map
1
{"version":3,"file":"static/js/main.d44eb427.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-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-dropdown/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-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-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/Thead.tsx","../../packages/react-table/src/util.ts","../../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 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 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/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>{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, { 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}\n\nexport default function DateInput(props: DateInputProps) {\n const {\n prefixCls = 'w-dateinput',\n className,\n popoverProps,\n datePickerProps,\n allowClear = true,\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 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 return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\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>\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 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 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, { 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(false);\n useMemo(() => {\n 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 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 {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 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 size = 'default',\n maxTagCount,\n option = [],\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 (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);\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[] = index !== -1 ? removeSelectItem(index) : [...selectedValue, 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 disabled={option && option.length > 0 ? false : true}\n {...others}\n onVisibleChange={onVisibleChange}\n isOpen={innerIsOpen}\n menu={\n <Menu\n bordered\n style={{\n minHeight: 25,\n maxHeight: 280,\n minWidth: 200,\n overflowY: 'scroll',\n width: divRef.current ? divRef.current.offsetWidth : 'auto',\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 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 {(selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon type={selectIconType} spin={loading && selectIconType === 'loading'} onClick={resetSelectedValue} />\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 (selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon\n type={selectIconType}\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 React from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport { TableProps, TableColumns } from './';\nimport './style/index.less';\n\nexport interface TheadProps<T extends { [key: string]: V }, V = any> extends IProps {\n data?: TableColumns<T>[][];\n onCellHead?: TableProps<T, V>['onCellHead'];\n}\n\nexport default function TheadComponent<T extends { [key: string]: V }, V>(\n props: TheadProps<T, V> & React.HTMLAttributes<HTMLTableSectionElement> = {},\n) {\n const { prefixCls = 'w-table', className, data = [], onCellHead = noop, ...other } = 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, ...thProps } = item;\n const titleNode: TableColumns<T>['title'] =\n typeof title === 'function' ? title(item, colNum, rowNum!) : title;\n if (thProps.colSpan === 0) {\n return null;\n }\n if (ellipsis) {\n thProps.className = `${thProps.className || ''} ${prefixCls}-ellipsis`;\n }\n return (\n <th key={colNum} onClick={(evn) => onCellHead(item, colNum, rowNum!, evn)} {...thProps}>\n {titleNode}\n </th>\n );\n })}\n </tr>\n ))}\n </thead>\n );\n}\n","import { TableColumns } from './';\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: any[] = []): string[] {\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].key);\n }\n }\n return keys;\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 } from 'react';\nimport Icon from '@uiw/react-icon';\nimport { TableProps } from './';\nimport './style/index.less';\nimport { noop } from '@uiw/utils';\n\ninterface TableTrProps<T> {\n rowKey?: keyof T;\n data: T[];\n keys: string[];\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}\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 } = props;\n\n const [expandIndex, setExpandIndex] = useState<Array<T[keyof T] | number>>([]);\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={{ marginRight: 10, opacity: isOpacity ? 1 : 0, marginLeft: hierarchy * indentSize }}\n onClick={() => {\n setExpandIndex(flag ? expandIndex.filter((it) => it !== key) : [...expandIndex, key]);\n }}\n />\n );\n };\n }, [expandIndex]);\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],\n };\n if (render[keyName]) {\n const child = render[keyName](trData[keyName], keyName, 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 if (ellipsis && ellipsis[keyName]) {\n objs.className = `${prefixCls}-ellipsis`;\n }\n const isHasChildren = Array.isArray(trData[childrenColumnName]);\n if (colNum === 0 && (hierarchy || isHasChildren)) {\n objs.className = `${objs.className} ${prefixCls}-has-children`;\n objs.children = (\n <>\n {IconDom(key, isHasChildren)}\n {objs.children}\n </>\n );\n }\n return (\n <td {...objs} key={colNum} onClick={(evn) => onCell(trData, { rowNum, colNum, keyName }, evn)} />\n );\n })}\n </tr>\n {expandIndex.includes(key) && (\n <TableTr {...props} data={trData[childrenColumnName]} hierarchy={hierarchy + 1} />\n )}\n {isExpandedDom(trData, rowNum)}\n </React.Fragment>\n );\n })}\n </React.Fragment>\n );\n}\n","import React, { useMemo, useState, useEffect } 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 [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}\n\nexport interface ICellOptions {\n rowNum: number;\n colNum: number;\n keyName: string;\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 ...other\n } = props;\n const [expandIndex, setExpandIndex] = useState<Array<T[keyof T] | number>>([]);\n useEffect(() => {\n if (expandable) {\n if (expandable.defaultExpandAllRows) {\n setExpandIndex(data.map((it, index) => (rowKey ? it[rowKey] : index)));\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 = ['uiw-expanded', ...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\n const cls = [prefixCls, className, bordered ? `${prefixCls}-bordered` : null].filter(Boolean).join(' ').trim();\n const { header, render, ellipsis } = getLevelItems(self.selfColumns);\n\n return (\n <div>\n <div style={{ overflowY: 'scroll' }} className={cls} {...other}>\n <table style={ellipsis ? { tableLayout: 'fixed' } : {}}>\n {title && <caption>{title}</caption>}\n {columns && columns.length > 0 && <Thead onCellHead={onCellHead} data={header} />}\n {data && data.length > 0 && (\n <tbody>\n <TableTr\n rowKey={rowKey}\n data={data}\n keys={self.keys}\n render={render}\n ellipsis={ellipsis}\n prefixCls={prefixCls}\n onCell={onCell}\n hierarchy={0}\n isExpandedDom={isExpandedDom}\n indentSize={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 </div>\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\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) => {\n if (node !== null) {\n node.addEventListener('click', (e: any) => {\n activeItem.current = node;\n });\n divNavWidthChange(node.getBoundingClientRect().width, key);\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 setSlideStyle({\n width: activeItem.current.clientWidth,\n left: activeItem.current.offsetLeft + 15,\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>\n </div>\n </div>\n <div style={slideStyle} className={`${prefixCls}-slide`} />\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)} {...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 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 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={{ flex: 1, minWidth: 30 }}\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 <span style={{ height: 25, width: 14 }} className={`${prefixCls}-close-tag-contents`}>\n {(selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon type={selectIconType} spin={loading && selectIconType === 'loading'} onClick={resetSelectedValue} />\n )}\n </span>\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 leftSelectedKeySet([]);\n rightSelectedKeySet([]);\n\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 }, [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 let selectOptionTemp = selectOption;\n if (transferType === 'left') {\n leftSelectOption.forEach((value, key) => {\n selectOptionTemp.set(key, value);\n });\n leftSelectOptionSet(selectOptionTemp);\n } else {\n rightSelectedKeys.forEach((key) => {\n selectOption.delete(key!);\n });\n }\n selectOptionSet(selectOptionTemp);\n const option: Array<TransferOptionType> = [];\n selectOptionTemp.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 selectOption.set(child.key!, child.label as string);\n keys.push(child.key!);\n }\n });\n };\n selectedOptionsRecursion(selectedOptions);\n leftSelectedKeySet(keys);\n } else {\n leftSelectedKeySet([]);\n }\n selectOptionSet(selectOption);\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) => {\n selectOption.delete(child.key!);\n return child.key;\n });\n rightSelectedKeySet(keys);\n } else {\n rightSelectedKeySet([]);\n }\n selectOptionSet(selectOption);\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\":\"c21be8c4\",\"207\":\"891adb65\",\"221\":\"9ce44a8a\",\"433\":\"f4c15f04\",\"486\":\"fc977627\",\"643\":\"e25a44e9\",\"694\":\"bc628baa\",\"745\":\"3a86c62c\",\"747\":\"7519f1c0\",\"748\":\"d9662281\",\"766\":\"c8931dff\",\"782\":\"b7fa1e08\",\"875\":\"3fbf3e1b\",\"889\":\"b53bdc3b\",\"922\":\"b1f148e3\",\"1016\":\"a3866702\",\"1059\":\"394ca46b\",\"1061\":\"3ad0b052\",\"1127\":\"d65f8357\",\"1151\":\"3c560b1f\",\"1169\":\"35e0b4d9\",\"1317\":\"8d4696fe\",\"1358\":\"e579baca\",\"1584\":\"db3bfd44\",\"1619\":\"de0aed50\",\"1756\":\"87f583cc\",\"1820\":\"d7e5cecb\",\"1892\":\"0f341f07\",\"1971\":\"d746cb8b\",\"2078\":\"53137233\",\"2156\":\"8897c384\",\"2190\":\"a9587418\",\"2230\":\"6f415357\",\"2316\":\"4e735325\",\"2367\":\"37920af3\",\"2411\":\"648cd481\",\"2448\":\"1d46904a\",\"2456\":\"624e63f5\",\"2582\":\"0936495a\",\"2595\":\"cd723bd0\",\"2679\":\"0780e749\",\"2692\":\"db178ecc\",\"2737\":\"b956e215\",\"2782\":\"2e1a10e5\",\"2795\":\"45c184a0\",\"2926\":\"f11fdc77\",\"3151\":\"59d27efa\",\"3257\":\"5693b5c1\",\"3259\":\"80ff41ab\",\"3261\":\"d4120c57\",\"3313\":\"4498d6d2\",\"3450\":\"812a2002\",\"3518\":\"581a0482\",\"3769\":\"535a1903\",\"3811\":\"ac38cada\",\"3812\":\"53f8f35e\",\"3917\":\"f23be8f7\",\"3931\":\"088517c5\",\"4010\":\"d9d10ad8\",\"4036\":\"412a4652\",\"4098\":\"07a8dc11\",\"4128\":\"3ffbc312\",\"4188\":\"46cd00c3\",\"4396\":\"0b56199f\",\"4405\":\"07956c6d\",\"4503\":\"c07c440f\",\"4648\":\"986c84a4\",\"4781\":\"ce661c8a\",\"4877\":\"652ec3de\",\"4948\":\"6d575bd2\",\"5146\":\"76b73d7f\",\"5244\":\"07be951b\",\"5253\":\"7a8716a8\",\"5308\":\"09878484\",\"5364\":\"b95913d0\",\"5393\":\"b3f91a94\",\"5408\":\"b3b0cdbb\",\"5468\":\"aef3688e\",\"5595\":\"0f6bfe34\",\"5821\":\"41b747c6\",\"5865\":\"d106bd2d\",\"5930\":\"65ea3787\",\"6019\":\"add10037\",\"6036\":\"289c2eb8\",\"6510\":\"ac7a7cc1\",\"6536\":\"8d9d4af6\",\"6566\":\"511e95c6\",\"6659\":\"cfc5b1fb\",\"6715\":\"7b8b59d4\",\"6730\":\"2d4b7239\",\"6869\":\"38330ca9\",\"6878\":\"c6cec0d9\",\"6982\":\"bfa6c797\",\"7079\":\"3aa94426\",\"7087\":\"b7c93ae6\",\"7104\":\"dbead7a2\",\"7157\":\"2bfb40d8\",\"7217\":\"1be488ae\",\"7266\":\"bba9c51f\",\"7313\":\"558b6522\",\"7390\":\"45faeca0\",\"7541\":\"55a7bd10\",\"7664\":\"f92b74f7\",\"7761\":\"0852cd26\",\"7763\":\"444dce16\",\"7834\":\"2085e31c\",\"7861\":\"757503f5\",\"7875\":\"890af61a\",\"7884\":\"5cf4143c\",\"7970\":\"2adbe6f1\",\"8023\":\"8981ca3a\",\"8073\":\"0eb17514\",\"8312\":\"58a5729e\",\"8398\":\"cc6aa9ea\",\"8488\":\"148bfa75\",\"8566\":\"67ab59b4\",\"8586\":\"9d605493\",\"8709\":\"44b46cf7\",\"8747\":\"04252521\",\"8768\":\"5facbb82\",\"8849\":\"d5dd1a61\",\"8898\":\"1065c308\",\"8915\":\"82c6b45a\",\"9057\":\"b21f426b\",\"9121\":\"387afd1f\",\"9137\":\"f4e2b7b0\",\"9147\":\"d6a507a2\",\"9188\":\"b7ce0cf2\",\"9200\":\"0a1f7353\",\"9253\":\"4c043cd5\",\"9260\":\"e8e6620e\",\"9384\":\"19ccf715\",\"9429\":\"3b8debbf\",\"9503\":\"e82696f3\",\"9673\":\"d490504c\",\"9763\":\"74094338\",\"9776\":\"8ee4a819\",\"9777\":\"6b56b56e\",\"9820\":\"1374775d\",\"9836\":\"8cd96a11\",\"9853\":\"9196452f\",\"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\":\"4d268428\",\"221\":\"4d268428\",\"433\":\"4d268428\",\"643\":\"4d268428\",\"694\":\"4d268428\",\"748\":\"4d268428\",\"875\":\"4d268428\",\"1059\":\"4d268428\",\"1061\":\"4d268428\",\"1169\":\"4d268428\",\"1317\":\"4d268428\",\"1584\":\"4d268428\",\"1619\":\"4d268428\",\"1820\":\"4d268428\",\"2156\":\"4d268428\",\"2190\":\"4d268428\",\"2230\":\"4d268428\",\"2316\":\"4d268428\",\"2367\":\"4d268428\",\"2411\":\"4d268428\",\"2582\":\"4d268428\",\"2595\":\"4d268428\",\"2737\":\"4d268428\",\"2782\":\"4d268428\",\"3313\":\"4d268428\",\"3518\":\"4d268428\",\"3812\":\"4d268428\",\"3917\":\"4d268428\",\"4010\":\"4d268428\",\"4098\":\"4d268428\",\"4128\":\"4d268428\",\"4188\":\"4d268428\",\"4396\":\"774af801\",\"4405\":\"4d268428\",\"4503\":\"4d268428\",\"4648\":\"4d268428\",\"4877\":\"6e864cd4\",\"4948\":\"4d268428\",\"5244\":\"4d268428\",\"5308\":\"4d268428\",\"5393\":\"4d268428\",\"5408\":\"4d268428\",\"5595\":\"4d268428\",\"5865\":\"4d268428\",\"6510\":\"4d268428\",\"6715\":\"4d268428\",\"6730\":\"4d268428\",\"7087\":\"4d268428\",\"7104\":\"4d268428\",\"7157\":\"4d268428\",\"7390\":\"4d268428\",\"7541\":\"4d268428\",\"7761\":\"4d268428\",\"7834\":\"4d268428\",\"7875\":\"4d268428\",\"7884\":\"4d268428\",\"8023\":\"4d268428\",\"8073\":\"4d268428\",\"8566\":\"4d268428\",\"8898\":\"4d268428\",\"9121\":\"4d268428\",\"9200\":\"14abaeb3\",\"9253\":\"4d268428\",\"9260\":\"4d268428\",\"9384\":\"4d268428\",\"9503\":\"4d268428\",\"9673\":\"4d268428\",\"9763\":\"4d268428\",\"9776\":\"4d268428\",\"9777\":\"4d268428\",\"9853\":\"4d268428\"}[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,\"5308\":1,\"5393\":1,\"5408\":1,\"5595\":1,\"5865\":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","Checkbox","CopyToClipboard","Collapse","Card","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","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","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","splice","Panel","header","iconRender","transitionDuration","instance","copy","isCopy","DateInputRange","datePickerProps","dateRange","setDateRange","handleChange","cdate","changeValue","valueTemp","propsValue","JSON","stringify","fontSize","margin","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","cb","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","displayName","InternalList","items","striped","renderItem","dataSource","childrenList","classString","bgColor","fullscreen","indicatorView","cx","cy","r","strokeMiterlimit","tipsView","disabledProps","Internal","multiline","isSubMenuItem","htmlProps","anchorCls","tagComp","MenuItem","MenuDivider","IconView","collapse","SubMenu","inlineIndent","overlayTriggerProps","menuProps","isCheck","checkedMenuItem","appear","onExit","theme","inlineCollapsed","handleClosed","renderIcon","showIcon","rounded","elementProps","Child","pickerCaptionProps","handleSelectedDate","curPanelDate","open","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","onBlur","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","maxTagCount","option","labelInValue","mode","showSearch","tagProps","onSearch","onSelect","isMultiple","innerIsOpen","setInnerIsOpen","selectedValue","setSelectedValue","selectedLabel","setSelectedLabel","selectIconType","setSelectIconType","omitTagCount","divRef","valueVerify","selectedValueChange","getSelectOption","findResult","opts","v","m","selectedLabelChange","handleItemsClick","removeSelectItem","resultValue","handleSelectChange","renderSelectIcon","handleInputChange","resetSelectedValue","stopPropagation","marginTop","minHeight","maxHeight","overflowY","findIndex","finds","handleItemClick","_inputRef$current2","flexFlow","flex","keyCode","InternalSteps","progressDot","direction","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","TheadComponent","onCellHead","tds","rowNum","colNum","ellipsis","thProps","titleNode","getColspanNum","concat","getRowspanNum","getLevelItems","levelTop","rowSpan","getAllColumnsKeys","ExpandableComponent","defaultExpand","expandIcon","expand","setExpand","TableTr","rowKey","onCell","isExpandedDom","hierarchy","indentSize","childrenColumnName","expandIndex","setExpandIndex","IconDom","isOpacity","flag","opacity","marginLeft","it","trData","objs","isHasChildren","empty","expandable","defaultExpandAllRows","defaultExpandedRowKeys","expandedRowKeys","record","expandedRowRender","rowExpandable","self","selfColumns","_expandable$defaultEx","onExpand","onExpandedRowsChange","tableLayout","Thead","onTabClick","slideStyle","setSlideStyle","activeItem","flowLeft","displayStart","displayEnd","flowNav","flowNavSet","hiddenNav","hiddenNavSet","nodes","nodesSet","divContentRef","divNavRef","divNavWidthChange","curWidth","showHideenNav","_flowNav$nav","calcSlideStyle","renderNav","Pane","Label","TreeNode","renderTitle","iconAnimation","isSelected","openKeys","selectedKeys","level","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","opt","getOptionsRecursion","childrens","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","selectOptionTemp","Arrow","selectedOptionsRecursion","_child$children3","searchIsMatch","background","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","__webpack_modules__","deferred","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","j","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":""}