-
-
Notifications
You must be signed in to change notification settings - Fork 115
/
main.a79a4c7d.js.map
1 lines (1 loc) · 495 KB
/
main.a79a4c7d.js.map
1
{"version":3,"file":"static/js/main.a79a4c7d.js","mappings":"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,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW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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/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","../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 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/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, V>[][];\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 from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport Thead from './Thead';\nimport { getLevelItems, getAllColumnsKeys } from './util';\nimport './style/index.less';\n\nexport type TableColumns<T = any, V = any> = {\n title?: string | ((data: TableColumns<T, V>, rowNum: number, colNum: number) => JSX.Element) | JSX.Element;\n key?: string;\n width?: number;\n colSpan?: number;\n children?: TableColumns<T, V>[];\n ellipsis?: boolean;\n render?: (text: V, keyName: V, 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, V>[];\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, V>,\n rowNum: number,\n colNum: number,\n evn: React.MouseEvent<HTMLTableCellElement>,\n ) => void;\n}\n\nexport interface ICellOptions {\n rowNum: number;\n colNum: number;\n keyName: string;\n}\n\nexport default function Table<T extends { [key: string]: V }, V>(props: TableProps<T, V> = {}) {\n const {\n prefixCls = 'w-table',\n className,\n columns = [],\n data = [],\n title,\n footer,\n bordered,\n onCell = noop,\n onCellHead = noop,\n empty,\n children,\n ...other\n } = props;\n\n const cls = [prefixCls, className, bordered ? `${prefixCls}-bordered` : null].filter(Boolean).join(' ').trim();\n const { header, render, ellipsis } = getLevelItems(columns);\n const keys = getAllColumnsKeys<T>(columns);\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 {data.map((trData, rowNum) => (\n <tr key={rowNum}>\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 return (\n <td {...objs} key={colNum} onClick={(evn) => onCell(trData, { rowNum, colNum, keyName }, evn)} />\n );\n })}\n </tr>\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,\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 className={`${prefixCls}-switcher`} onClick={(evn) => onItemClick(item, evn)}>\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 result.push(item.key as string | number);\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","// 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\":\"89176117\",\"207\":\"891adb65\",\"221\":\"4eb5b9a2\",\"486\":\"fc977627\",\"643\":\"eeffe1e2\",\"694\":\"4a2552a3\",\"745\":\"3a86c62c\",\"747\":\"7519f1c0\",\"748\":\"398a6fc1\",\"766\":\"c8931dff\",\"875\":\"07cef8a0\",\"889\":\"b53bdc3b\",\"922\":\"b1f148e3\",\"1016\":\"a3866702\",\"1059\":\"01c5bbf5\",\"1061\":\"bebac0c1\",\"1127\":\"d65f8357\",\"1151\":\"3c560b1f\",\"1169\":\"d1e153ee\",\"1317\":\"da1c8179\",\"1358\":\"e579baca\",\"1584\":\"d121a58b\",\"1619\":\"df8eb08f\",\"1756\":\"87f583cc\",\"1820\":\"afa38704\",\"1892\":\"0f341f07\",\"1971\":\"d746cb8b\",\"2078\":\"53137233\",\"2156\":\"90e9be12\",\"2190\":\"e17088e2\",\"2230\":\"a30ce096\",\"2316\":\"de77050f\",\"2367\":\"ed50fdc3\",\"2411\":\"6aaa172c\",\"2448\":\"1d46904a\",\"2456\":\"624e63f5\",\"2582\":\"c0f03329\",\"2595\":\"e2263469\",\"2679\":\"0780e749\",\"2692\":\"db178ecc\",\"2737\":\"865b4f95\",\"2782\":\"bed382a4\",\"2795\":\"45c184a0\",\"2854\":\"ff43f045\",\"2926\":\"f11fdc77\",\"3151\":\"59d27efa\",\"3257\":\"5693b5c1\",\"3259\":\"80ff41ab\",\"3261\":\"d4120c57\",\"3313\":\"af8a3ed8\",\"3450\":\"bb5e6340\",\"3518\":\"7ff154b7\",\"3769\":\"535a1903\",\"3811\":\"ac38cada\",\"3812\":\"e343740f\",\"3917\":\"372e76e1\",\"3931\":\"088517c5\",\"4010\":\"ec3bfadc\",\"4036\":\"412a4652\",\"4098\":\"c09d6b35\",\"4128\":\"e1ee7a3d\",\"4188\":\"f168d0ce\",\"4396\":\"260bbb7a\",\"4405\":\"5fadd16f\",\"4503\":\"e0442423\",\"4648\":\"193ada33\",\"4781\":\"ce661c8a\",\"4877\":\"d0b1bed8\",\"4948\":\"db31f027\",\"5146\":\"76b73d7f\",\"5244\":\"ef2e1b10\",\"5253\":\"7a8716a8\",\"5308\":\"86cea331\",\"5364\":\"b95913d0\",\"5393\":\"b105bd5e\",\"5408\":\"c35692f5\",\"5468\":\"462bf55f\",\"5595\":\"c42c119f\",\"5821\":\"41b747c6\",\"5865\":\"8a49f1fb\",\"5930\":\"65ea3787\",\"6019\":\"add10037\",\"6036\":\"289c2eb8\",\"6510\":\"a2b3f3ae\",\"6536\":\"8d9d4af6\",\"6566\":\"511e95c6\",\"6659\":\"6790167d\",\"6715\":\"61d41218\",\"6730\":\"05b8be02\",\"6869\":\"38330ca9\",\"6878\":\"c6cec0d9\",\"6982\":\"a406ae54\",\"7079\":\"3aa94426\",\"7087\":\"e47a6fc3\",\"7104\":\"c26a2e9b\",\"7157\":\"d1d72e99\",\"7217\":\"1be488ae\",\"7266\":\"bba9c51f\",\"7313\":\"558b6522\",\"7390\":\"77d3c594\",\"7541\":\"709f6082\",\"7664\":\"f92b74f7\",\"7761\":\"58c5aac1\",\"7763\":\"444dce16\",\"7834\":\"e2cb2c9b\",\"7861\":\"757503f5\",\"7875\":\"aa16c85e\",\"7884\":\"f7d0ad92\",\"8023\":\"ba5cb853\",\"8073\":\"9afe01c2\",\"8312\":\"58a5729e\",\"8398\":\"cc6aa9ea\",\"8488\":\"148bfa75\",\"8566\":\"794b9a15\",\"8586\":\"9d605493\",\"8709\":\"44b46cf7\",\"8747\":\"04252521\",\"8768\":\"5facbb82\",\"8849\":\"d5dd1a61\",\"8898\":\"009bddd3\",\"8915\":\"82c6b45a\",\"9057\":\"b21f426b\",\"9121\":\"3b688f24\",\"9137\":\"f4e2b7b0\",\"9147\":\"d6a507a2\",\"9188\":\"b7ce0cf2\",\"9200\":\"0a1f7353\",\"9253\":\"2d1f2531\",\"9260\":\"54c1b5f6\",\"9384\":\"baf5b89a\",\"9429\":\"3b8debbf\",\"9503\":\"e79b06ea\",\"9673\":\"b6faf12a\",\"9763\":\"13bfd4a0\",\"9776\":\"19d5c339\",\"9777\":\"38948748\",\"9820\":\"1374775d\",\"9836\":\"8cd96a11\",\"9853\":\"08389818\",\"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\":\"dc5e9ddc\",\"221\":\"dc5e9ddc\",\"643\":\"dc5e9ddc\",\"694\":\"dc5e9ddc\",\"748\":\"dc5e9ddc\",\"875\":\"dc5e9ddc\",\"1059\":\"dc5e9ddc\",\"1061\":\"dc5e9ddc\",\"1169\":\"dc5e9ddc\",\"1317\":\"dc5e9ddc\",\"1584\":\"dc5e9ddc\",\"1619\":\"dc5e9ddc\",\"1820\":\"dc5e9ddc\",\"2156\":\"dc5e9ddc\",\"2190\":\"dc5e9ddc\",\"2230\":\"dc5e9ddc\",\"2316\":\"dc5e9ddc\",\"2367\":\"dc5e9ddc\",\"2411\":\"dc5e9ddc\",\"2582\":\"dc5e9ddc\",\"2595\":\"dc5e9ddc\",\"2737\":\"dc5e9ddc\",\"2782\":\"dc5e9ddc\",\"3313\":\"dc5e9ddc\",\"3518\":\"dc5e9ddc\",\"3812\":\"dc5e9ddc\",\"3917\":\"dc5e9ddc\",\"4010\":\"dc5e9ddc\",\"4098\":\"dc5e9ddc\",\"4128\":\"dc5e9ddc\",\"4188\":\"dc5e9ddc\",\"4396\":\"774af801\",\"4405\":\"dc5e9ddc\",\"4503\":\"dc5e9ddc\",\"4648\":\"dc5e9ddc\",\"4877\":\"6e864cd4\",\"4948\":\"dc5e9ddc\",\"5244\":\"dc5e9ddc\",\"5308\":\"dc5e9ddc\",\"5393\":\"dc5e9ddc\",\"5408\":\"dc5e9ddc\",\"5595\":\"dc5e9ddc\",\"5865\":\"dc5e9ddc\",\"6510\":\"dc5e9ddc\",\"6715\":\"dc5e9ddc\",\"6730\":\"dc5e9ddc\",\"7087\":\"dc5e9ddc\",\"7104\":\"dc5e9ddc\",\"7157\":\"dc5e9ddc\",\"7390\":\"dc5e9ddc\",\"7541\":\"dc5e9ddc\",\"7761\":\"dc5e9ddc\",\"7834\":\"dc5e9ddc\",\"7875\":\"dc5e9ddc\",\"7884\":\"dc5e9ddc\",\"8023\":\"dc5e9ddc\",\"8073\":\"dc5e9ddc\",\"8566\":\"dc5e9ddc\",\"8898\":\"dc5e9ddc\",\"9121\":\"dc5e9ddc\",\"9200\":\"14abaeb3\",\"9253\":\"dc5e9ddc\",\"9260\":\"dc5e9ddc\",\"9384\":\"dc5e9ddc\",\"9503\":\"dc5e9ddc\",\"9673\":\"dc5e9ddc\",\"9763\":\"dc5e9ddc\",\"9776\":\"dc5e9ddc\",\"9777\":\"dc5e9ddc\",\"9853\":\"dc5e9ddc\"}[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,\"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","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","onCell","empty","tableLayout","Thead","trData","objs","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","onExpand","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","treeProps","selectedValues","selectedValuesSet","selectedOptions","selectedOptionSet","isEmpty","isEmptySet","SearchTagInput","hiddenNodeForSeach","parentIsHide","isHide","_child$children2","isEmpt","__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","get","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","self","__webpack_exports__"],"sourceRoot":""}