@_tc/template-core 0.0.1-bate.9 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1108 -0
- package/cjs/_virtual/_rolldown/runtime.js +1 -0
- package/cjs/app/controller/base.js +1 -21
- package/cjs/app/controller/project.js +1 -50
- package/cjs/app/controller/view.js +1 -14
- package/cjs/app/data/signKey.js +1 -4
- package/cjs/app/extend/$fetch.js +1 -0
- package/cjs/app/extend/db.js +1 -12
- package/cjs/app/extend/generateErrorMessage.js +1 -14
- package/cjs/app/extend/logger.js +1 -72
- package/cjs/app/extend/parsingParamsOnUrl.js +1 -22
- package/cjs/app/extend/render-view.js +1 -21
- package/cjs/app/middleware/api-params-verify.js +1 -63
- package/cjs/app/middleware/api-sign-verify.js +1 -28
- package/cjs/app/middleware/error-handle.js +1 -33
- package/cjs/app/middleware/project-handler.js +1 -21
- package/cjs/app/middleware.js +1 -60
- package/cjs/app/router/project.js +1 -8
- package/cjs/app/router/view.js +1 -5
- package/cjs/app/router-schema/project.js +1 -33
- package/cjs/app/service/base.js +1 -0
- package/cjs/app/service/project.js +1 -42
- package/cjs/app/type.js +1 -2
- package/cjs/app/typings.js +1 -2
- package/cjs/bundler/defaultAlias.js +1 -0
- package/cjs/bundler/dev.js +1 -68
- package/cjs/bundler/index.js +1 -18
- package/cjs/bundler/prod.js +1 -19
- package/cjs/bundler/state.js +1 -0
- package/cjs/bundler/utils.js +1 -127
- package/cjs/index.js +1 -21
- package/cjs/packages/common/LRUCache.js +1 -0
- package/cjs/packages/common/array/index.js +1 -0
- package/cjs/packages/common/cache/LRUCache.js +1 -0
- package/cjs/packages/common/cache/index.js +1 -0
- package/cjs/packages/common/guards/index.js +1 -0
- package/cjs/packages/common/http/index.js +1 -0
- package/cjs/packages/common/i18n/default.js +1 -0
- package/cjs/packages/common/i18n/en-US.js +1 -0
- package/cjs/packages/common/i18n/index.js +1 -0
- package/cjs/packages/common/i18n/locales.js +1 -0
- package/cjs/packages/common/i18n/types.js +1 -0
- package/cjs/packages/common/index.js +1 -0
- package/cjs/packages/common/log/index.js +2 -0
- package/cjs/packages/common/number/index.js +1 -0
- package/cjs/packages/common/object/filterEmpty.js +1 -0
- package/cjs/packages/common/object/filtereEmpty.js +1 -0
- package/cjs/packages/common/object/index.js +1 -0
- package/cjs/packages/common/string/index.js +1 -0
- package/cjs/packages/common/types/index.js +1 -0
- package/cjs/packages/core/env.js +1 -25
- package/cjs/packages/core/index.js +1 -116
- package/cjs/packages/core/loader/config.js +1 -45
- package/cjs/packages/core/loader/controller.js +1 -40
- package/cjs/packages/core/loader/extend.js +1 -41
- package/cjs/packages/core/loader/middleware.js +1 -38
- package/cjs/packages/core/loader/model.js +1 -132
- package/cjs/packages/core/loader/router-schema.js +1 -35
- package/cjs/packages/core/loader/router.js +1 -62
- package/cjs/packages/core/loader/service.js +1 -30
- package/cjs/packages/core/paths.js +1 -10
- package/cjs/packages/core/types.js +1 -2
- package/cjs/packages/utils/getAllFilesInFolder.js +1 -45
- package/cjs/packages/utils/getAllFnReturnValue.js +1 -6
- package/cjs/packages/utils/index.js +1 -20
- package/cjs/packages/utils/loadFile.js +1 -65
- package/cjs/packages/utils/path.js +1 -64
- package/cjs/packages/utils/runFileFn.js +1 -5
- package/esm/_virtual/_rolldown/runtime.js +20 -0
- package/esm/app/controller/base.js +26 -21
- package/esm/app/controller/project.js +52 -42
- package/esm/app/controller/view.js +23 -12
- package/esm/app/data/signKey.js +8 -1
- package/esm/app/extend/$fetch.js +15 -0
- package/esm/app/extend/db.js +5 -8
- package/esm/app/extend/generateErrorMessage.js +6 -11
- package/esm/app/extend/logger.js +25 -36
- package/esm/app/extend/parsingParamsOnUrl.js +13 -19
- package/esm/app/extend/render-view.js +18 -15
- package/esm/app/middleware/api-params-verify.js +55 -57
- package/esm/app/middleware/api-sign-verify.js +17 -22
- package/esm/app/middleware/error-handle.js +23 -30
- package/esm/app/middleware/project-handler.js +14 -18
- package/esm/app/middleware.js +17 -54
- package/esm/app/router/project.js +6 -5
- package/esm/app/router/view.js +6 -2
- package/esm/app/router-schema/project.js +14 -30
- package/esm/app/service/base.js +14 -0
- package/esm/app/service/project.js +23 -34
- package/esm/app/type.js +0 -1
- package/esm/app/typings.js +0 -1
- package/esm/bundler/defaultAlias.js +4 -0
- package/esm/bundler/dev.js +11 -28
- package/esm/bundler/index.js +17 -13
- package/esm/bundler/prod.js +13 -15
- package/esm/bundler/state.js +10 -0
- package/esm/bundler/utils.js +191 -82
- package/esm/index.js +15 -12
- package/esm/packages/common/LRUCache.js +2 -0
- package/esm/packages/common/array/index.js +27 -0
- package/esm/packages/common/cache/LRUCache.js +39 -0
- package/esm/packages/common/cache/index.js +2 -0
- package/esm/packages/common/guards/index.js +8 -0
- package/esm/packages/common/http/index.js +256 -0
- package/esm/packages/common/i18n/default.js +88 -0
- package/esm/packages/common/i18n/en-US.js +88 -0
- package/esm/packages/common/i18n/index.js +91 -0
- package/esm/packages/common/i18n/locales.js +9 -0
- package/esm/packages/common/index.js +14 -0
- package/esm/packages/common/log/index.js +93 -0
- package/esm/packages/common/number/index.js +10 -0
- package/esm/packages/common/object/filterEmpty.js +23 -0
- package/esm/packages/common/object/filtereEmpty.js +2 -0
- package/esm/packages/common/object/index.js +17 -0
- package/esm/packages/common/string/index.js +4 -0
- package/esm/packages/common/types/index.js +0 -0
- package/esm/packages/core/env.js +24 -23
- package/esm/packages/core/index.js +51 -108
- package/esm/packages/core/loader/config.js +26 -42
- package/esm/packages/core/loader/controller.js +12 -37
- package/esm/packages/core/loader/extend.js +22 -38
- package/esm/packages/core/loader/middleware.js +15 -35
- package/esm/packages/core/loader/model.js +65 -124
- package/esm/packages/core/loader/router-schema.js +18 -32
- package/esm/packages/core/loader/router.js +35 -56
- package/esm/packages/core/loader/service.js +12 -27
- package/esm/packages/core/paths.js +7 -4
- package/esm/packages/core/types.js +0 -1
- package/esm/packages/utils/getAllFilesInFolder.js +8 -7
- package/esm/packages/utils/getAllFnReturnValue.js +0 -6
- package/esm/packages/utils/index.js +5 -4
- package/esm/packages/utils/loadFile.js +33 -62
- package/esm/packages/utils/path.js +14 -25
- package/esm/packages/utils/runFileFn.js +45 -1
- package/fe/frontend/apps/dash/Dashboard.d.ts +6 -0
- package/fe/frontend/apps/dash/Dashboard.js +75 -0
- package/fe/frontend/apps/dash/dash.entry.d.ts +2 -0
- package/fe/frontend/apps/dash/dash.entry.js +80 -0
- package/fe/frontend/apps/dash/types.d.ts +17 -0
- package/fe/frontend/apps/testPage/index.d.ts +3 -0
- package/fe/frontend/apps/testPage/index.js +6 -0
- package/fe/frontend/apps/testPage/testPage.entry.d.ts +2 -0
- package/fe/frontend/apps/testPage/testPage.entry.js +6 -0
- package/fe/frontend/extended/SchemaForm/data.d.ts +13 -0
- package/fe/frontend/extended/SchemaForm/data.js +8 -0
- package/fe/frontend/src/api/baseInfo.d.ts +31 -0
- package/fe/frontend/src/api/baseInfo.js +15 -0
- package/fe/frontend/src/common/CRUD/CRUD.d.ts +3 -0
- package/fe/frontend/src/common/CRUD/CRUD.js +2 -0
- package/fe/frontend/src/common/CRUD/index.d.ts +2 -0
- package/fe/frontend/src/common/CRUD/index.js +1 -0
- package/fe/frontend/src/common/auth/index.d.ts +7 -0
- package/fe/frontend/src/common/auth/index.js +20 -0
- package/fe/frontend/src/common/fetchErrorShow.d.ts +3 -0
- package/fe/frontend/src/common/fetchErrorShow.js +8 -0
- package/fe/frontend/src/common/generateMenuData.d.ts +4 -0
- package/fe/frontend/src/common/generateMenuData.js +12 -0
- package/fe/frontend/src/common/importComponent.d.ts +5 -0
- package/fe/frontend/src/common/importComponent.js +8 -0
- package/fe/frontend/src/common/language.d.ts +2 -0
- package/fe/frontend/src/common/language.js +9 -0
- package/fe/frontend/src/common/logFn/index.d.ts +5 -0
- package/fe/frontend/src/common/logFn/index.js +9 -0
- package/fe/frontend/src/common/menu.d.ts +34 -0
- package/fe/frontend/src/common/menu.js +101 -0
- package/fe/frontend/src/common/request.d.ts +37 -0
- package/fe/frontend/src/common/request.js +217 -0
- package/fe/frontend/src/components/AsyncSelect/AsyncSelect.d.ts +8 -0
- package/fe/frontend/src/components/AsyncSelect/AsyncSelect.js +32 -0
- package/fe/frontend/src/components/AsyncSelect/index.d.ts +4 -0
- package/fe/frontend/src/components/AsyncSelect/index.js +3 -0
- package/fe/frontend/src/components/BasePage/HeaderView.d.ts +9 -0
- package/fe/frontend/src/components/BasePage/HeaderView.js +14 -0
- package/fe/frontend/src/components/Router/index.d.ts +9 -0
- package/fe/frontend/src/components/Router/index.js +11 -0
- package/fe/frontend/src/components/Router/type.d.ts +2 -0
- package/fe/frontend/src/components/Router/type.js +1 -0
- package/fe/frontend/src/defaultPages/Iframe/index.d.ts +3 -0
- package/fe/frontend/src/defaultPages/Iframe/index.js +14 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/DetailPanel.d.ts +7 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/DetailPanel.js +94 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/PopFrom.d.ts +13 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/PopFrom.js +124 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/builtIn.d.ts +44 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/builtIn.js +7 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/data.d.ts +4 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/CallCom/data.js +6 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/SchemaSearch/index.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/SchemaSearch/index.js +63 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/SchemaTable/index.d.ts +11 -0
- package/fe/frontend/src/defaultPages/SchemaPage/components/SchemaTable/index.js +188 -0
- package/fe/frontend/src/defaultPages/SchemaPage/data/eventInfo.d.ts +8 -0
- package/fe/frontend/src/defaultPages/SchemaPage/data/eventInfo.js +6 -0
- package/fe/frontend/src/defaultPages/SchemaPage/data/index.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SchemaPage/data/index.js +1 -0
- package/fe/frontend/src/defaultPages/SchemaPage/hooks/useComConfig.d.ts +10 -0
- package/fe/frontend/src/defaultPages/SchemaPage/hooks/useComConfig.js +14 -0
- package/fe/frontend/src/defaultPages/SchemaPage/index.css +167 -0
- package/fe/frontend/src/defaultPages/SchemaPage/index.d.ts +4 -0
- package/fe/frontend/src/defaultPages/SchemaPage/index.js +75 -0
- package/fe/frontend/src/defaultPages/SchemaPage/schemaType.d.ts +51 -0
- package/fe/frontend/src/defaultPages/SchemaPage/schemaType.js +4 -0
- package/fe/frontend/src/defaultPages/SchemaPage/utils/permissions.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SchemaPage/utils/permissions.js +3 -0
- package/fe/frontend/src/defaultPages/SchemaPage/utils/schemaConversion.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SchemaPage/utils/schemaConversion.js +115 -0
- package/fe/frontend/src/defaultPages/SchemaPage/utils/validator.d.ts +7 -0
- package/fe/frontend/src/defaultPages/SchemaPage/utils/validator.js +36 -0
- package/fe/frontend/src/defaultPages/SidebarSlotPage/SidebarSlotContainer.d.ts +10 -0
- package/fe/frontend/src/defaultPages/SidebarSlotPage/SidebarSlotContainer.js +38 -0
- package/fe/frontend/src/defaultPages/SidebarSlotPage/index.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SidebarSlotPage/index.js +16 -0
- package/fe/frontend/src/defaultPages/SidebarSlotPageTmp.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SidebarSlotPageTmp.js +17 -0
- package/fe/frontend/src/defaultPages/SlotPage/index.d.ts +3 -0
- package/fe/frontend/src/defaultPages/SlotPage/index.js +26 -0
- package/fe/frontend/src/exportStore.d.ts +17 -0
- package/fe/frontend/src/exportStore.js +16 -0
- package/fe/frontend/src/hooks/useCurrentMenuData.d.ts +19 -0
- package/fe/frontend/src/hooks/useCurrentMenuData.js +28 -0
- package/fe/frontend/src/hooks/useRouterParams.d.ts +5 -0
- package/fe/frontend/src/hooks/useRouterParams.js +11 -0
- package/fe/frontend/src/index.d.ts +16 -0
- package/fe/frontend/src/index.js +13 -0
- package/fe/frontend/src/main.css +96 -0
- package/fe/frontend/src/main.d.ts +27 -0
- package/fe/frontend/src/main.js +72 -0
- package/fe/frontend/src/stores/apiFreezer.d.ts +93 -0
- package/fe/frontend/src/stores/apiFreezer.js +49 -0
- package/fe/frontend/src/stores/mode.d.ts +19 -0
- package/fe/frontend/src/stores/mode.js +37 -0
- package/fe/frontend/src/stores/schemaEventBus.d.ts +42 -0
- package/fe/frontend/src/stores/schemaEventBus.js +70 -0
- package/fe/frontend/src/stores/schemaStore.d.ts +47 -0
- package/fe/frontend/src/stores/schemaStore.js +26 -0
- package/fe/frontend/src/typing/scalability.d.ts +47 -0
- package/fe/frontend/src/typing/scalability.js +1 -0
- package/fe/frontend/src/typing/window.d.ts +7 -0
- package/fe/frontend/src/typing/window.js +1 -0
- package/fe/model/types/data/button.d.ts +32 -0
- package/fe/model/types/data/button.js +16 -0
- package/fe/model/types/data/component.d.ts +40 -0
- package/fe/model/types/data/component.js +11 -0
- package/fe/model/types/data/fetchInfo.d.ts +20 -0
- package/fe/model/types/data/fetchInfo.js +1 -0
- package/fe/model/types/data/schema.d.ts +98 -0
- package/fe/model/types/data/schema.js +1 -0
- package/fe/model/types/data/search.d.ts +7 -0
- package/fe/model/types/data/search.js +1 -0
- package/fe/model/types/menuType.d.ts +73 -0
- package/fe/model/types/menuType.js +1 -0
- package/fe/model/types/model.d.ts +33 -0
- package/fe/model/types/model.js +1 -0
- package/fe/packages/common/array/index.d.ts +7 -0
- package/fe/packages/common/array/index.js +40 -0
- package/fe/packages/common/cache/LRUCache.d.ts +13 -0
- package/fe/packages/common/cache/LRUCache.js +47 -0
- package/fe/packages/common/cache/index.d.ts +2 -0
- package/fe/packages/common/cache/index.js +1 -0
- package/fe/packages/common/guards/index.d.ts +9 -0
- package/fe/packages/common/guards/index.js +24 -0
- package/fe/packages/common/http/index.d.ts +90 -0
- package/fe/packages/common/http/index.js +310 -0
- package/fe/packages/common/i18n/default.d.ts +92 -0
- package/fe/packages/common/i18n/default.js +90 -0
- package/fe/packages/common/i18n/en-US.d.ts +92 -0
- package/fe/packages/common/i18n/en-US.js +90 -0
- package/fe/packages/common/i18n/index.d.ts +43 -0
- package/fe/packages/common/i18n/index.js +173 -0
- package/fe/packages/common/i18n/locales.d.ts +8 -0
- package/fe/packages/common/i18n/locales.js +10 -0
- package/fe/packages/common/i18n/types.d.ts +71 -0
- package/fe/packages/common/i18n/types.js +1 -0
- package/fe/packages/common/index.d.ts +11 -0
- package/fe/packages/common/index.js +10 -0
- package/fe/packages/common/log/index.d.ts +33 -0
- package/fe/packages/common/log/index.js +176 -0
- package/fe/packages/common/number/index.d.ts +3 -0
- package/fe/packages/common/number/index.js +10 -0
- package/fe/packages/common/object/filterEmpty.d.ts +3 -0
- package/fe/packages/common/object/filterEmpty.js +33 -0
- package/fe/packages/common/object/index.d.ts +5 -0
- package/fe/packages/common/object/index.js +25 -0
- package/fe/packages/common/string/index.d.ts +4 -0
- package/fe/packages/common/string/index.js +17 -0
- package/fe/packages/common/types/index.d.ts +4 -0
- package/fe/packages/common/types/index.js +1 -0
- package/fe/packages/ui/react/components/Button/Button.d.ts +29 -10
- package/fe/packages/ui/react/components/Button/Button.js +53 -23
- package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +2 -2
- package/fe/packages/ui/react/components/Button/SumbitButton.js +3 -10
- package/fe/packages/ui/react/components/Button/index.d.ts +1 -1
- package/fe/packages/ui/react/components/Checkbox/Checkbox.d.ts +1 -1
- package/fe/packages/ui/react/components/Checkbox/Checkbox.js +5 -3
- package/fe/packages/ui/react/components/ConfirmDialog/ConfirmDialog.js +11 -0
- package/fe/packages/ui/react/components/ConfirmDialog/index.d.ts +2 -0
- package/fe/packages/ui/react/components/ConfirmDialog/index.js +1 -0
- package/fe/packages/ui/react/components/DataTable/ActionBtn.d.ts +3 -1
- package/fe/packages/ui/react/components/DataTable/ActionBtn.js +87 -4
- package/fe/packages/ui/react/components/DataTable/{data-table.d.ts → index.d.ts} +12 -4
- package/fe/packages/ui/react/components/DataTable/index.js +187 -0
- package/fe/packages/ui/react/components/Date/Calendar.js +4 -3
- package/fe/packages/ui/react/components/Date/Date.d.ts +5 -3
- package/fe/packages/ui/react/components/Date/Date.js +71 -48
- package/fe/packages/ui/react/components/Date/TimePicker.js +3 -1
- package/fe/packages/ui/react/components/Date/dropdownPositioning.d.ts +3 -0
- package/fe/packages/ui/react/components/Date/dropdownPositioning.js +12 -0
- package/fe/packages/ui/react/components/Date/locales.d.ts +1 -0
- package/fe/packages/ui/react/components/Date/locales.js +7 -38
- package/fe/packages/ui/react/components/Drawer/Drawer.d.ts +29 -0
- package/fe/packages/ui/react/components/Drawer/Drawer.js +100 -0
- package/fe/packages/ui/react/components/Drawer/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Drawer/index.js +1 -0
- package/fe/packages/ui/react/components/Dropdown/Dropdown.d.ts +26 -0
- package/fe/packages/ui/react/components/Dropdown/Dropdown.js +49 -0
- package/fe/packages/ui/react/components/Dropdown/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Dropdown/index.js +1 -0
- package/fe/packages/ui/react/components/Form/Form.js +1 -1
- package/fe/packages/ui/react/components/Form/FormItem.js +1 -1
- package/fe/packages/ui/react/components/Form/SchemaForm/data.d.ts +40 -0
- package/fe/packages/ui/react/components/Form/SchemaForm/data.js +18 -0
- package/fe/packages/ui/react/components/Form/{SchemeForm → SchemaForm}/index.d.ts +15 -14
- package/fe/packages/ui/react/components/Form/SchemaForm/index.js +79 -0
- package/fe/packages/ui/react/components/Form/index.d.ts +1 -1
- package/fe/packages/ui/react/components/Form/index.js +1 -1
- package/fe/packages/ui/react/components/ImagePreview/ImagePreview.js +15 -12
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +5 -2
- package/fe/packages/ui/react/components/Input/Input.d.ts +5 -1
- package/fe/packages/ui/react/components/Input/Input.js +5 -4
- package/fe/packages/ui/react/components/InputNumber/InputNumber.d.ts +28 -0
- package/fe/packages/ui/react/components/InputNumber/InputNumber.js +144 -0
- package/fe/packages/ui/react/components/InputNumber/index.d.ts +2 -0
- package/fe/packages/ui/react/components/InputNumber/index.js +1 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.d.ts +30 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.js +63 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.test.d.ts +2 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.test.js +27 -0
- package/fe/packages/ui/react/components/Label/Label.js +2 -2
- package/fe/packages/ui/react/components/Menu/Menu.d.ts +18 -0
- package/fe/packages/ui/react/components/Menu/Menu.js +102 -0
- package/fe/packages/ui/react/components/Menu/MenuContext.d.ts +39 -0
- package/fe/packages/ui/react/components/Menu/MenuContext.js +97 -0
- package/fe/packages/ui/react/components/Menu/MenuItem.d.ts +3 -0
- package/fe/packages/ui/react/components/Menu/MenuItem.js +33 -0
- package/fe/packages/ui/react/components/Menu/SubMenu.d.ts +10 -0
- package/fe/packages/ui/react/components/Menu/SubMenu.js +169 -0
- package/fe/packages/ui/react/components/Menu/index.d.ts +9 -0
- package/fe/packages/ui/react/components/Menu/index.js +5 -0
- package/fe/packages/ui/react/components/Menu/menuTypes.d.ts +59 -0
- package/fe/packages/ui/react/components/Menu/menuTypes.js +1 -0
- package/fe/packages/ui/react/components/Menu/utils.d.ts +2 -0
- package/fe/packages/ui/react/components/Menu/utils.js +7 -0
- package/fe/packages/ui/react/components/Message/Message.js +4 -1
- package/fe/packages/ui/react/components/Modal/Modal.d.ts +3 -1
- package/fe/packages/ui/react/components/Modal/Modal.js +6 -43
- package/fe/packages/ui/react/components/Modal/ModalManager.js +4 -3
- package/fe/packages/ui/react/components/Overlay/Overlay.d.ts +23 -0
- package/fe/packages/ui/react/components/Overlay/Overlay.js +53 -0
- package/fe/packages/ui/react/components/Overlay/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Overlay/index.js +1 -0
- package/fe/packages/ui/react/components/{Pagination.js → Pagination/Pagination.js} +4 -4
- package/fe/packages/ui/react/components/Pagination/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Pagination/index.js +1 -0
- package/fe/packages/ui/react/components/Popup/Popup.d.ts +26 -0
- package/fe/packages/ui/react/components/Popup/Popup.js +81 -0
- package/fe/packages/ui/react/components/Popup/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Popup/index.js +1 -0
- package/fe/packages/ui/react/components/Search/Search.d.ts +2 -2
- package/fe/packages/ui/react/components/Search/Search.js +3 -3
- package/fe/packages/ui/react/components/Select/Select.d.ts +5 -0
- package/fe/packages/ui/react/components/Select/Select.js +52 -109
- package/fe/packages/ui/react/components/Select/dropdownPositioning.d.ts +3 -0
- package/fe/packages/ui/react/components/Select/dropdownPositioning.js +13 -0
- package/fe/packages/ui/react/components/Skeleton/Skeleton.js +2 -2
- package/fe/packages/ui/react/components/Switch/Switch.js +3 -1
- package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +5 -4
- package/fe/packages/ui/react/components/TableSearch/TableSearch.js +23 -21
- package/fe/packages/ui/react/components/TableSearch/lang.js +5 -14
- package/fe/packages/ui/react/components/{Textarea.d.ts → Textarea/Textarea.d.ts} +11 -3
- package/fe/packages/ui/react/components/Textarea/Textarea.js +37 -0
- package/fe/packages/ui/react/components/Textarea/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Textarea/index.js +1 -0
- package/fe/packages/ui/react/components/{Tooltip.d.ts → Tooltip/Tooltip.d.ts} +2 -2
- package/fe/packages/ui/react/components/Tooltip/Tooltip.js +79 -0
- package/fe/packages/ui/react/components/Tooltip/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Tooltip/index.js +1 -0
- package/fe/packages/ui/react/components/{TreeSelect.js → TreeSelect/TreeSelect.js} +9 -11
- package/fe/packages/ui/react/components/TreeSelect/index.d.ts +2 -0
- package/fe/packages/ui/react/components/TreeSelect/index.js +1 -0
- package/fe/packages/ui/react/components/Upload/ImageUpload.js +18 -6
- package/fe/packages/ui/react/components/Upload/Upload.js +2 -1
- package/fe/packages/ui/react/components/{breadcrumb.js → breadcrumb/breadcrumb.js} +15 -12
- package/fe/packages/ui/react/components/breadcrumb/index.d.ts +2 -0
- package/fe/packages/ui/react/components/breadcrumb/index.js +1 -0
- package/fe/packages/ui/react/components/hooks/useDropdownPositioning.d.ts +49 -0
- package/fe/packages/ui/react/components/hooks/useDropdownPositioning.js +137 -0
- package/fe/packages/ui/react/components/index.d.ts +7 -1
- package/fe/packages/ui/react/components/index.js +7 -1
- package/fe/packages/ui/react/components/table/index.d.ts +2 -0
- package/fe/packages/ui/react/components/table/index.js +1 -0
- package/fe/packages/ui/react/components/{table.d.ts → table/table.d.ts} +12 -2
- package/fe/packages/ui/react/components/table/table.js +116 -0
- package/fe/packages/ui/react/components/testPage/MenuTestPage.d.ts +2 -0
- package/fe/packages/ui/react/components/testPage/MenuTestPage.js +104 -0
- package/fe/packages/ui/react/components/testPage/index.js +300 -81
- package/fe/packages/ui/react/hooks/useExecuteOnce.d.ts +30 -0
- package/fe/packages/ui/react/hooks/useExecuteOnce.js +57 -0
- package/fe/packages/ui/react/hooks/useInit.d.ts +1 -1
- package/fe/packages/ui/react/hooks/useInit.js +1 -1
- package/fe/packages/ui/react/hooks/useLanguage.d.ts +1 -6
- package/fe/packages/ui/react/hooks/useRefState.d.ts +30 -0
- package/fe/packages/ui/react/hooks/useRefState.js +29 -0
- package/fe/packages/ui/react/hooks/useWatch.d.ts +23 -0
- package/fe/packages/ui/react/hooks/useWatch.js +87 -0
- package/fe/packages/ui/react/hooks/useWatch.test.d.ts +2 -0
- package/fe/packages/ui/react/hooks/useWatch.test.js +22 -0
- package/fe/packages/ui/react/i18n/I18nProvider.d.ts +31 -0
- package/fe/packages/ui/react/i18n/I18nProvider.js +25 -0
- package/fe/packages/ui/react/i18n/index.d.ts +4 -0
- package/fe/packages/ui/react/i18n/index.js +3 -0
- package/fe/packages/ui/react/i18n/useI18n.d.ts +13 -0
- package/fe/packages/ui/react/i18n/useI18n.js +18 -0
- package/fe/packages/ui/react/index.css +238 -0
- package/fe/packages/ui/react/index.d.ts +2 -0
- package/fe/packages/ui/react/index.js +2 -0
- package/fe/packages/ui/react/lib/createStoreHook.d.ts +9 -0
- package/fe/packages/ui/react/lib/createStoreHook.js +6 -0
- package/fe/packages/ui/react/lib/export.d.ts +2 -2
- package/fe/packages/ui/react/stores/language.d.ts +3 -12
- package/fe/packages/ui/react/stores/language.js +2 -51
- package/fe/typings/type.d.ts +5 -0
- package/fe/typings/type.js +1 -0
- package/model/index.d.ts +2 -0
- package/model/test.d.ts +2 -0
- package/model/types/data/button.d.ts +32 -0
- package/model/types/data/component.d.ts +40 -0
- package/model/types/data/fetchInfo.d.ts +20 -0
- package/model/types/data/schema.d.ts +98 -0
- package/model/types/data/search.d.ts +7 -0
- package/model/types/index.d.ts +3 -0
- package/model/types/menuType.d.ts +73 -0
- package/model/types/model.d.ts +33 -0
- package/package.json +36 -17
- package/{cjs → types}/app/controller/base.d.ts +4 -5
- package/types/app/controller/project.d.ts +22 -0
- package/{cjs → types}/app/controller/view.d.ts +1 -2
- package/types/app/extend/$fetch.d.ts +8 -0
- package/{cjs → types}/app/extend/db.d.ts +1 -1
- package/{cjs → types}/app/extend/logger.d.ts +1 -1
- package/{cjs → types}/app/extend/render-view.d.ts +1 -2
- package/{cjs → types}/app/middleware/api-params-verify.d.ts +1 -2
- package/{cjs → types}/app/middleware/api-sign-verify.d.ts +1 -2
- package/{esm/app/middleware/api-sign-verify.d.ts → types/app/middleware/error-handle.d.ts} +1 -3
- package/{cjs → types}/app/middleware/project-handler.d.ts +2 -2
- package/{cjs → types}/app/middleware.d.ts +0 -2
- package/{cjs/app/router/view.d.ts → types/app/router/project.d.ts} +1 -1
- package/types/app/router/view.d.ts +3 -0
- package/{cjs → types}/app/router-schema/project.d.ts +1 -1
- package/types/app/service/base.d.ts +9 -0
- package/types/app/service/project.d.ts +57 -0
- package/types/app/type.d.ts +5 -0
- package/{cjs → types}/app/typings.d.ts +17 -23
- package/types/bundler/defaultAlias.d.ts +3 -0
- package/types/bundler/index.d.ts +2 -0
- package/types/bundler/state.d.ts +18 -0
- package/types/bundler/utils.d.ts +9 -0
- package/types/config/config.default.d.ts +14 -0
- package/types/index.d.ts +28 -0
- package/types/packages/common/LRUCache.d.ts +1 -0
- package/types/packages/common/array/index.d.ts +6 -0
- package/types/packages/common/cache/LRUCache.d.ts +12 -0
- package/types/packages/common/cache/index.d.ts +1 -0
- package/types/packages/common/guards/index.d.ts +8 -0
- package/types/packages/common/http/index.d.ts +89 -0
- package/types/packages/common/i18n/default.d.ts +91 -0
- package/types/packages/common/i18n/en-US.d.ts +91 -0
- package/types/packages/common/i18n/index.d.ts +42 -0
- package/types/packages/common/i18n/locales.d.ts +7 -0
- package/types/packages/common/i18n/types.d.ts +70 -0
- package/types/packages/common/index.d.ts +10 -0
- package/types/packages/common/log/index.d.ts +32 -0
- package/types/packages/common/number/index.d.ts +2 -0
- package/types/packages/common/object/filterEmpty.d.ts +2 -0
- package/types/packages/common/object/filtereEmpty.d.ts +1 -0
- package/types/packages/common/object/index.d.ts +4 -0
- package/types/packages/common/string/index.d.ts +3 -0
- package/types/packages/common/types/index.d.ts +3 -0
- package/{cjs → types}/packages/core/index.d.ts +1 -1
- package/{cjs → types}/packages/core/loader/config.d.ts +1 -1
- package/{cjs → types}/packages/core/loader/controller.d.ts +2 -2
- package/{cjs → types}/packages/core/loader/middleware.d.ts +1 -1
- package/{esm → types}/packages/core/loader/model.d.ts +2 -3
- package/{cjs → types}/packages/core/loader/router-schema.d.ts +2 -2
- package/{cjs → types}/packages/core/loader/router.d.ts +1 -1
- package/{cjs → types}/packages/core/loader/service.d.ts +2 -2
- package/{cjs → types}/packages/core/types.d.ts +42 -3
- package/types/packages/utils/getAllFnReturnValue.d.ts +0 -0
- package/types/packages/utils/runFileFn.d.ts +7 -0
- package/types/typings/type.d.ts +4 -0
- package/cjs/app/controller/project.d.ts +0 -11
- package/cjs/app/middleware/error-handle.d.ts +0 -5
- package/cjs/app/router/project.d.ts +0 -4
- package/cjs/app/service/bese.d.ts +0 -10
- package/cjs/app/service/bese.js +0 -17
- package/cjs/app/service/project.d.ts +0 -27
- package/cjs/app/type.d.ts +0 -2
- package/cjs/bundler/index.d.ts +0 -1
- package/cjs/bundler/utils.d.ts +0 -7
- package/cjs/index.d.ts +0 -28
- package/cjs/packages/core/loader/model.d.ts +0 -36
- package/cjs/packages/utils/runFileFn.d.ts +0 -5
- package/cjs/typings/type.d.ts +0 -4
- package/cjs/typings/type.js +0 -2
- package/esm/app/controller/base.d.ts +0 -14
- package/esm/app/controller/project.d.ts +0 -12
- package/esm/app/controller/view.d.ts +0 -9
- package/esm/app/data/signKey.d.ts +0 -2
- package/esm/app/extend/db.d.ts +0 -3
- package/esm/app/extend/generateErrorMessage.d.ts +0 -8
- package/esm/app/extend/logger.d.ts +0 -12
- package/esm/app/extend/parsingParamsOnUrl.d.ts +0 -3
- package/esm/app/extend/render-view.d.ts +0 -5
- package/esm/app/middleware/api-params-verify.d.ts +0 -6
- package/esm/app/middleware/error-handle.d.ts +0 -6
- package/esm/app/middleware/project-handler.d.ts +0 -5
- package/esm/app/middleware.d.ts +0 -6
- package/esm/app/router/project.d.ts +0 -5
- package/esm/app/router/view.d.ts +0 -5
- package/esm/app/router-schema/project.d.ts +0 -4
- package/esm/app/service/bese.d.ts +0 -11
- package/esm/app/service/bese.js +0 -12
- package/esm/app/service/project.d.ts +0 -28
- package/esm/app/type.d.ts +0 -3
- package/esm/app/typings.d.ts +0 -50
- package/esm/bundler/dev.d.ts +0 -2
- package/esm/bundler/index.d.ts +0 -2
- package/esm/bundler/prod.d.ts +0 -2
- package/esm/bundler/utils.d.ts +0 -8
- package/esm/index.d.ts +0 -29
- package/esm/packages/core/env.d.ts +0 -16
- package/esm/packages/core/index.d.ts +0 -7
- package/esm/packages/core/loader/config.d.ts +0 -10
- package/esm/packages/core/loader/controller.d.ts +0 -18
- package/esm/packages/core/loader/extend.d.ts +0 -9
- package/esm/packages/core/loader/middleware.d.ts +0 -12
- package/esm/packages/core/loader/router-schema.d.ts +0 -19
- package/esm/packages/core/loader/router.d.ts +0 -9
- package/esm/packages/core/loader/service.d.ts +0 -18
- package/esm/packages/core/paths.d.ts +0 -12
- package/esm/packages/core/types.d.ts +0 -75
- package/esm/packages/utils/getAllFilesInFolder.d.ts +0 -10
- package/esm/packages/utils/getAllFnReturnValue.d.ts +0 -1
- package/esm/packages/utils/index.d.ts +0 -5
- package/esm/packages/utils/loadFile.d.ts +0 -21
- package/esm/packages/utils/path.d.ts +0 -25
- package/esm/packages/utils/runFileFn.d.ts +0 -6
- package/esm/typings/type.d.ts +0 -5
- package/fe/frontend/main.d.ts +0 -3
- package/fe/frontend/main.js +0 -6
- package/fe/packages/ui/react/components/ConfirmDialog.js +0 -9
- package/fe/packages/ui/react/components/DataTable/data-table.js +0 -141
- package/fe/packages/ui/react/components/Dropdown.d.ts +0 -16
- package/fe/packages/ui/react/components/Dropdown.js +0 -54
- package/fe/packages/ui/react/components/Form/SchemeForm/data.d.ts +0 -51
- package/fe/packages/ui/react/components/Form/SchemeForm/data.js +0 -8
- package/fe/packages/ui/react/components/Form/SchemeForm/index.js +0 -69
- package/fe/packages/ui/react/components/Textarea.js +0 -35
- package/fe/packages/ui/react/components/Tooltip.js +0 -118
- package/fe/packages/ui/react/components/table.js +0 -20
- package/fe/packages/ui/react/locales/index.d.ts +0 -8
- package/fe/packages/ui/react/locales/index.js +0 -6
- /package/{cjs/packages/utils/getAllFnReturnValue.d.ts → esm/packages/common/i18n/types.js} +0 -0
- /package/{esm/typings/type.js → fe/frontend/apps/dash/types.js} +0 -0
- /package/fe/packages/ui/react/components/{ConfirmDialog.d.ts → ConfirmDialog/ConfirmDialog.d.ts} +0 -0
- /package/fe/packages/ui/react/components/{Pagination.d.ts → Pagination/Pagination.d.ts} +0 -0
- /package/fe/packages/ui/react/components/{TreeSelect.d.ts → TreeSelect/TreeSelect.d.ts} +0 -0
- /package/fe/packages/ui/react/components/{breadcrumb.d.ts → breadcrumb/breadcrumb.d.ts} +0 -0
- /package/{cjs → types}/app/data/signKey.d.ts +0 -0
- /package/{cjs → types}/app/extend/generateErrorMessage.d.ts +0 -0
- /package/{cjs → types}/app/extend/parsingParamsOnUrl.d.ts +0 -0
- /package/{cjs → types}/bundler/dev.d.ts +0 -0
- /package/{cjs → types}/bundler/prod.d.ts +0 -0
- /package/{cjs → types}/packages/core/env.d.ts +0 -0
- /package/{cjs → types}/packages/core/loader/extend.d.ts +0 -0
- /package/{cjs → types}/packages/core/paths.d.ts +0 -0
- /package/{cjs → types}/packages/utils/getAllFilesInFolder.d.ts +0 -0
- /package/{cjs → types}/packages/utils/index.d.ts +0 -0
- /package/{cjs → types}/packages/utils/loadFile.d.ts +0 -0
- /package/{cjs → types}/packages/utils/path.d.ts +0 -0
|
@@ -1,40 +1,307 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Button, Form, FormItem, ImageUpload, Input, Label,
|
|
3
|
-
import { useRef, useState } from 'react';
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Breadcrumb, BreadcrumbItem, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, Button, Checkbox, ConfirmDialog, DataTable, Drawer, Dropdown, Form, FormItem, ImageUpload, Input, InputNumber, Label, message, Modal, modal, Pagination, PreviewImage, SchemaForm, Search, Select, Skeleton, Switch, Table, TableBody, TableCell, TableHead, TableHeader, TableRow, TableSearch, Textarea, Tooltip, TreeSelect, useForm, } from '../../components';
|
|
3
|
+
import React, { useEffect, useRef, useState } from 'react';
|
|
4
4
|
import DateTestPage from '../Date/DateTestPage';
|
|
5
|
-
import
|
|
5
|
+
import MenuTestPage from './MenuTestPage';
|
|
6
|
+
function ThemeSwitcher() {
|
|
7
|
+
const [mode, setMode] = useState('dark');
|
|
8
|
+
const [theme, setTheme] = useState('default');
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
const root = document.documentElement;
|
|
11
|
+
const previousTheme = root.getAttribute('data-theme');
|
|
12
|
+
const previousDark = root.classList.contains('dark');
|
|
13
|
+
root.classList.toggle('dark', mode === 'dark');
|
|
14
|
+
if (theme === 'default') {
|
|
15
|
+
root.removeAttribute('data-theme');
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
root.setAttribute('data-theme', theme);
|
|
19
|
+
}
|
|
20
|
+
return () => {
|
|
21
|
+
root.classList.toggle('dark', previousDark);
|
|
22
|
+
if (previousTheme) {
|
|
23
|
+
root.setAttribute('data-theme', previousTheme);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
root.removeAttribute('data-theme');
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
}, [mode, theme]);
|
|
30
|
+
return (_jsx(Section, { title: "Theme", children: _jsxs("div", { className: "flex w-full flex-wrap items-center gap-6 rounded-xl border border-border bg-background p-4", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "text-sm text-muted-foreground", children: "\u6A21\u5F0F" }), _jsx(Button, { variant: mode === 'light' ? 'primary' : 'default', size: "sm", onClick: () => setMode('light'), children: "Light" }), _jsx(Button, { variant: mode === 'dark' ? 'primary' : 'default', size: "sm", onClick: () => setMode('dark'), children: "Dark" })] }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "text-sm text-muted-foreground", children: "\u4E3B\u9898" }), _jsx(Button, { variant: theme === 'default' ? 'primary' : 'default', size: "sm", onClick: () => setTheme('default'), children: "Default" }), _jsx(Button, { variant: theme === 'green' ? 'primary' : 'default', size: "sm", onClick: () => setTheme('green'), children: "Green" }), _jsx(Button, { variant: theme === 'gray' ? 'primary' : 'default', size: "sm", onClick: () => setTheme('gray'), children: "Gray" })] }), _jsxs("div", { className: "text-sm text-muted-foreground", children: ["\u5F53\u524D: ", mode, " / ", theme] })] }) }));
|
|
31
|
+
}
|
|
32
|
+
// ─── Section wrapper ────────────────────────────────────────────────────────
|
|
33
|
+
function Section({ title, children }) {
|
|
34
|
+
return (_jsxs("div", { className: "mb-8", children: [_jsx("h2", { className: "text-lg font-semibold mb-3 border-b pb-1", children: title }), _jsx("div", { className: "flex flex-wrap gap-3 items-start", children: children })] }));
|
|
35
|
+
}
|
|
36
|
+
// ─── Button ─────────────────────────────────────────────────────────────────
|
|
37
|
+
function ButtonDemo() {
|
|
38
|
+
const [loading, setLoading] = useState(false);
|
|
39
|
+
return (_jsxs(Section, { title: "Button", children: [_jsx(Button, { children: "default" }), _jsx(Button, { variant: "primary", children: "primary" }), _jsx(Button, { variant: "dashed", children: "dashed" }), _jsx(Button, { variant: "text", children: "text" }), _jsx(Button, { variant: "link", href: "#button", children: "link" }), _jsx(Button, { state: "danger", children: "danger" }), _jsx(Button, { variant: "primary", state: "danger", children: "primary danger" }), _jsx("div", { className: " bg-red-300 p-1.5", children: _jsx(Button, { state: "ghost", children: "ghost" }) }), _jsx(Button, { variant: "primary", state: "ghost", children: "primary ghost" }), _jsx(Button, { disabled: true, children: "disabled" }), _jsx(Button, { loading: loading, onClick: () => {
|
|
40
|
+
setLoading(true);
|
|
41
|
+
setTimeout(() => setLoading(false), 2000);
|
|
42
|
+
}, children: "loading (click)" }), _jsx(Button, { size: "sm", children: "sm" }), _jsx(Button, { size: "md", children: "md" }), _jsx(Button, { size: "lg", children: "lg" })] }));
|
|
43
|
+
}
|
|
44
|
+
// ─── Input ───────────────────────────────────────────────────────────────────
|
|
45
|
+
function InputDemo() {
|
|
46
|
+
return (_jsxs(Section, { title: "Input", children: [_jsx(Input, { placeholder: "\u666E\u901A\u8F93\u5165\u6846" }), _jsx(Input, { type: "password", placeholder: "\u5BC6\u7801\u8F93\u5165\u6846" }), _jsx(Input, { disabled: true, placeholder: "\u7981\u7528\u72B6\u6001" })] }));
|
|
47
|
+
}
|
|
48
|
+
function InputNumberDemo() {
|
|
49
|
+
const [price, setPrice] = useState(12.5);
|
|
50
|
+
const [ratio, setRatio] = useState(0.25);
|
|
51
|
+
return (_jsxs(Section, { title: "InputNumber", children: [_jsx(InputNumber, { placeholder: "\u57FA\u7840\u6570\u5B57\u8F93\u5165", className: "w-48" }), _jsx(InputNumber, { value: price, onChange: setPrice, precision: 2, min: 0, max: 9999, placeholder: "\u4EF7\u683C", addonAfter: _jsx("span", { className: "text-xs text-muted-foreground", children: "CNY" }), className: "w-56" }), _jsx(InputNumber, { value: ratio, onChange: setRatio, precision: 2, step: 0.05, min: 0, max: 1, allowStep: true, placeholder: "\u6BD4\u4F8B", className: "w-48" }), _jsx(InputNumber, { defaultValue: 10, step: 0.5, precision: 1, allowStep: true, allowClear: true, className: "w-48" }), _jsx(InputNumber, { disabled: true, defaultValue: 88.8, precision: 1, className: "w-48" })] }));
|
|
52
|
+
}
|
|
53
|
+
// ─── Textarea ────────────────────────────────────────────────────────────────
|
|
54
|
+
function TextareaDemo() {
|
|
55
|
+
const [val, setVal] = useState('');
|
|
56
|
+
return (_jsxs(Section, { title: "Textarea", children: [_jsx(Textarea, { placeholder: "\u8BF7\u8F93\u5165\u5185\u5BB9\uFF08\u6700\u591A 500 \u5B57\uFF09", value: val, onChange: (v) => setVal(v), className: "w-80" }), _jsx(Textarea, { placeholder: "\u4E0D\u663E\u793A\u8BA1\u6570", showCount: false, className: "w-80" })] }));
|
|
57
|
+
}
|
|
58
|
+
// ─── Select ──────────────────────────────────────────────────────────────────
|
|
59
|
+
function SelectDemo() {
|
|
60
|
+
const [val, setVal] = useState(undefined);
|
|
61
|
+
const options = [
|
|
62
|
+
{ label: '选项 A', value: 'a' },
|
|
63
|
+
{ label: '选项 B', value: 'b' },
|
|
64
|
+
{ label: '选项 C', value: 'c' },
|
|
65
|
+
];
|
|
66
|
+
return (_jsxs(Section, { title: "Select", children: [_jsx(Select, { options: options, value: val, onChange: setVal, placeholder: "\u8BF7\u9009\u62E9", className: "w-40" }), _jsx(Select, { options: options, placeholder: "\u4E0D\u53EF\u641C\u7D22", searchable: false, className: "w-40" }), _jsx(Select, { options: options, placeholder: "\u4E0D\u53EF\u6E05\u9664", clearable: false, className: "w-40" }), _jsx(Select, { options: options, disabled: true, placeholder: "\u7981\u7528", className: "w-40" }), _jsxs("div", { className: "relative w-64 rounded-lg border border-border bg-muted/30 p-4", children: [_jsx("div", { className: "mb-2 text-sm text-muted-foreground", children: "parent popup container" }), _jsx(Select, { options: options, placeholder: "\u6302\u8F7D\u5230\u7236\u5143\u7D20", getPopupContainer: "parent", className: "w-full" })] })] }));
|
|
67
|
+
}
|
|
68
|
+
// ─── Checkbox ────────────────────────────────────────────────────────────────
|
|
69
|
+
function CheckboxDemo() {
|
|
70
|
+
const [checked, setChecked] = useState(false);
|
|
71
|
+
return (_jsxs(Section, { title: "Checkbox", children: [_jsxs("label", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx(Checkbox, { checked: checked, onChange: (c) => setChecked(c) }), _jsxs("span", { children: ["\u53D7\u63A7: ", checked ? '选中' : '未选中'] })] }), _jsxs("label", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx(Checkbox, { defaultChecked: true }), _jsx("span", { children: "\u975E\u53D7\u63A7\u9ED8\u8BA4\u9009\u4E2D" })] }), _jsxs("label", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx(Checkbox, { indeterminate: true }), _jsx("span", { children: "\u534A\u9009\u72B6\u6001" })] }), _jsxs("label", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx(Checkbox, { disabled: true }), _jsx("span", { children: "\u7981\u7528" })] })] }));
|
|
72
|
+
}
|
|
73
|
+
// ─── Switch ──────────────────────────────────────────────────────────────────
|
|
74
|
+
function SwitchDemo() {
|
|
75
|
+
const [on, setOn] = useState(false);
|
|
76
|
+
return (_jsxs(Section, { title: "Switch", children: [_jsx(Switch, { checked: on, onChange: setOn }), _jsx("span", { className: "self-center text-sm", children: on ? 'ON' : 'OFF' }), _jsx(Switch, { defaultChecked: true }), _jsx(Switch, { disabled: true }), _jsx(Switch, { disabled: true, checked: true })] }));
|
|
77
|
+
}
|
|
78
|
+
// ─── Tooltip ─────────────────────────────────────────────────────────────────
|
|
79
|
+
function TooltipDemo() {
|
|
80
|
+
return (_jsx(Section, { title: "Tooltip", children: ['top', 'bottom', 'left', 'right'].map((p) => (_jsx(Tooltip, { content: `placement: ${p}`, placement: p, children: _jsx(Button, { children: p }) }, p))) }));
|
|
81
|
+
}
|
|
82
|
+
// ─── Dropdown ────────────────────────────────────────────────────────────────
|
|
83
|
+
function DropdownDemo() {
|
|
84
|
+
const items = [
|
|
85
|
+
{ key: 'edit', label: '编辑', onClick: () => console.log('edit') },
|
|
86
|
+
{ key: 'copy', label: '复制', onClick: () => console.log('copy') },
|
|
87
|
+
{ key: 'delete', label: '删除', danger: true, onClick: () => console.log('delete') },
|
|
88
|
+
];
|
|
89
|
+
return (_jsxs(Section, { title: "Dropdown", children: [_jsx(Dropdown, { items: items, children: _jsx(Button, { children: "\u64CD\u4F5C \u25BE" }) }), _jsx(Dropdown, { items: items, placement: "bottom-start", children: _jsx(Button, { variant: "text", children: "bottom-start \u25BE" }) })] }));
|
|
90
|
+
}
|
|
91
|
+
// ─── Message ─────────────────────────────────────────────────────────────────
|
|
92
|
+
function MessageDemo() {
|
|
93
|
+
return (_jsxs(Section, { title: "Message (imperative)", children: [_jsx(Button, { onClick: () => message.success('操作成功'), children: "success" }), _jsx(Button, { onClick: () => message.error('操作失败'), children: "error" }), _jsx(Button, { onClick: () => message.warning('警告信息'), children: "warning" }), _jsx(Button, { onClick: () => message.info('提示信息'), children: "info" }), _jsx(Button, { onClick: () => {
|
|
94
|
+
const id = message.success('5秒后关闭', { duration: 5000 });
|
|
95
|
+
setTimeout(() => message.close(id), 2000);
|
|
96
|
+
}, children: "\u63D0\u524D\u5173\u95ED" })] }));
|
|
97
|
+
}
|
|
98
|
+
// ─── Modal ───────────────────────────────────────────────────────────────────
|
|
99
|
+
function ModalDemo() {
|
|
100
|
+
const [open, setOpen] = useState(false);
|
|
101
|
+
return (_jsxs(Section, { title: "Modal", children: [_jsx(Button, { onClick: () => setOpen(true), children: "JSX Modal" }), _jsx(Button, { onClick: () => modal.open({
|
|
102
|
+
title: '命令式弹窗',
|
|
103
|
+
content: _jsx("p", { children: "\u8FD9\u662F\u547D\u4EE4\u5F0F\u6253\u5F00\u7684\u5F39\u7A97\u5185\u5BB9\u3002" }),
|
|
104
|
+
}), children: "modal.open" }), _jsx(Button, { onClick: () => modal.confirm({
|
|
105
|
+
title: '确认操作',
|
|
106
|
+
content: '确定要执行此操作吗?',
|
|
107
|
+
onOk: () => {
|
|
108
|
+
message.success('已确认');
|
|
109
|
+
},
|
|
110
|
+
onCancel: () => {
|
|
111
|
+
message.info('已取消');
|
|
112
|
+
},
|
|
113
|
+
}), children: "modal.confirm" }), _jsxs(Modal, { open: open, onClose: () => setOpen(false), title: "JSX \u5F39\u7A97", children: [_jsx("p", { children: "\u8FD9\u662F\u4E00\u4E2A\u4F7F\u7528 JSX \u63A7\u5236\u7684\u5F39\u7A97\u3002" }), _jsx("div", { className: "mt-4 flex justify-end gap-2", children: _jsx(Button, { onClick: () => setOpen(false), children: "\u5173\u95ED" }) })] })] }));
|
|
114
|
+
}
|
|
115
|
+
// ─── Drawer ──────────────────────────────────────────────────────────────────
|
|
116
|
+
function DrawerDemo() {
|
|
117
|
+
const [placement, setPlacement] = useState('right');
|
|
118
|
+
const [open, setOpen] = useState(false);
|
|
119
|
+
const openDrawer = (nextPlacement) => {
|
|
120
|
+
setPlacement(nextPlacement);
|
|
121
|
+
setOpen(true);
|
|
122
|
+
};
|
|
123
|
+
return (_jsxs(Section, { title: "Drawer", children: [_jsx(Button, { onClick: () => openDrawer('left'), children: "left" }), _jsx(Button, { onClick: () => openDrawer('right'), children: "right" }), _jsx(Button, { onClick: () => openDrawer('top'), children: "top" }), _jsx(Button, { onClick: () => openDrawer('bottom'), children: "bottom" }), _jsx(Button, { onClick: () => openDrawer('right'), variant: "primary", children: "\u6253\u5F00\u8BE6\u60C5" }), _jsx(Drawer, { open: open, onClose: () => setOpen(false), title: `Drawer ${placement}`, placement: placement, width: 420, height: 320, footer: _jsxs("div", { className: "flex justify-end gap-2", children: [_jsx(Button, { onClick: () => setOpen(false), children: "\u53D6\u6D88" }), _jsx(Button, { variant: "primary", onClick: () => {
|
|
124
|
+
message.success('已保存');
|
|
125
|
+
setOpen(false);
|
|
126
|
+
}, children: "\u4FDD\u5B58" })] }), children: _jsxs("div", { className: "space-y-4", children: [_jsxs("div", { children: [_jsx("div", { className: "mb-1 text-sm font-medium text-foreground", children: "\u5916\u90E8 children" }), _jsx("p", { className: "text-sm leading-6 text-muted-foreground", children: "\u8FD9\u91CC\u7684\u5185\u5BB9\u5B8C\u5168\u7531\u8C03\u7528\u65B9\u5B9A\u4E49\uFF0C\u53EF\u4EE5\u653E\u8868\u5355\u3001\u5217\u8868\u3001\u8BE6\u60C5\u6216\u4EFB\u610F JSX\u3002" })] }), _jsxs("div", { className: "grid gap-3", children: [_jsx(Label, { label: "\u540D\u79F0", layout: "vertical", children: _jsx(Input, { placeholder: "\u8BF7\u8F93\u5165\u540D\u79F0" }) }), _jsx(Label, { label: "\u72B6\u6001", layout: "vertical", children: _jsx(Select, { placeholder: "\u8BF7\u9009\u62E9\u72B6\u6001", options: [
|
|
127
|
+
{ label: '启用', value: 'enabled' },
|
|
128
|
+
{ label: '停用', value: 'disabled' },
|
|
129
|
+
] }) })] })] }) })] }));
|
|
130
|
+
}
|
|
131
|
+
// ─── ConfirmDialog ───────────────────────────────────────────────────────────
|
|
132
|
+
function ConfirmDialogDemo() {
|
|
133
|
+
const [open, setOpen] = useState(false);
|
|
134
|
+
return (_jsxs(Section, { title: "ConfirmDialog", children: [_jsx(Button, { onClick: () => setOpen(true), children: "\u6253\u5F00\u786E\u8BA4\u6846" }), _jsx(ConfirmDialog, { open: open, title: "\u5220\u9664\u786E\u8BA4", content: "\u786E\u5B9A\u8981\u5220\u9664\u6B64\u6761\u6570\u636E\u5417\uFF1F\u6B64\u64CD\u4F5C\u4E0D\u53EF\u64A4\u9500\u3002", onOk: () => {
|
|
135
|
+
message.success('已删除');
|
|
136
|
+
setOpen(false);
|
|
137
|
+
}, onCancel: () => setOpen(false) })] }));
|
|
138
|
+
}
|
|
139
|
+
// ─── Pagination ───────────────────────────────────────────────────────────────
|
|
140
|
+
function PaginationDemo() {
|
|
141
|
+
const [page, setPage] = useState(1);
|
|
142
|
+
const [pageSize, setPageSize] = useState(10);
|
|
143
|
+
return (_jsx(Section, { title: "Pagination", children: _jsxs("div", { className: "w-full", children: [_jsxs("p", { className: "text-sm mb-2", children: ["\u5F53\u524D\u9875: ", page, " / \u6BCF\u9875: ", pageSize] }), _jsx(Pagination, { current: page, pageSize: pageSize, total: 238, onChange: setPage, onPageSizeChange: setPageSize })] }) }));
|
|
144
|
+
}
|
|
145
|
+
// ─── Table (低层组件) ─────────────────────────────────────────────────────────
|
|
146
|
+
function TableDemo() {
|
|
147
|
+
const rows = [
|
|
148
|
+
{ id: 1, name: '张三', role: '管理员', status: '正常' },
|
|
149
|
+
{ id: 2, name: '李四', role: '用户', status: '禁用' },
|
|
150
|
+
{ id: 3, name: '王五', role: '审计员', status: '正常' },
|
|
151
|
+
];
|
|
152
|
+
return (_jsx(Section, { title: "Table (\u4F4E\u5C42)", children: _jsx("div", { className: "w-full", children: _jsxs(Table, { children: [_jsx(TableHeader, { children: _jsxs("tr", { children: [_jsx(TableHead, { children: "ID" }), _jsx(TableHead, { children: "\u59D3\u540D" }), _jsx(TableHead, { children: "\u89D2\u8272" }), _jsx(TableHead, { children: "\u72B6\u6001" }), _jsx(TableHead, { isAction: true, children: "\u64CD\u4F5C" })] }) }), _jsx(TableBody, { children: rows.map((row) => (_jsxs(TableRow, { children: [_jsx(TableCell, { children: row.id }), _jsx(TableCell, { children: row.name }), _jsx(TableCell, { children: row.role }), _jsx(TableCell, { children: row.status }), _jsx(TableCell, { isAction: true, children: _jsx(Button, { variant: "link", size: "sm", children: "\u7F16\u8F91" }) })] }, row.id))) })] }) }) }));
|
|
153
|
+
}
|
|
154
|
+
function DataTableDemo() {
|
|
155
|
+
const [selectedKeys, setSelectedKeys] = useState([]);
|
|
156
|
+
const columns = [
|
|
157
|
+
{ key: 'id', title: 'ID', width: '60px' },
|
|
158
|
+
{ key: 'name', title: '姓名' },
|
|
159
|
+
{ key: 'role', title: '角色1', fixed: 'left' },
|
|
160
|
+
{ key: 'status', title: '状态1', fixed: 'left' },
|
|
161
|
+
{ key: 'role', title: '角色2s' },
|
|
162
|
+
{ key: 'status', title: '状态2' },
|
|
163
|
+
{ key: 'role', title: '角色1' },
|
|
164
|
+
{ key: 'status', title: '状态1' },
|
|
165
|
+
{ key: 'role', title: '角色2s' },
|
|
166
|
+
{ key: 'status', title: '状态2' },
|
|
167
|
+
{ key: 'role', title: '角色1' },
|
|
168
|
+
{ key: 'status', title: '状态1' },
|
|
169
|
+
{ key: 'role', title: '角色2s' },
|
|
170
|
+
{ key: 'status', title: '状态2' },
|
|
171
|
+
{ key: 'role', title: '角色', fixed: 'right' },
|
|
172
|
+
{ key: 'status', title: '状态' },
|
|
173
|
+
{
|
|
174
|
+
key: 'action',
|
|
175
|
+
title: '操作',
|
|
176
|
+
width: '96px',
|
|
177
|
+
actionOverflow: 'dropdown',
|
|
178
|
+
actions: (_, record) => [
|
|
179
|
+
{ key: 'edit', label: '修改', onClick: () => console.log('edit', record.id) },
|
|
180
|
+
{ key: 'view', label: '查看', onClick: () => console.log('view', record.id) },
|
|
181
|
+
{ key: 'delete', label: '删除', danger: true, onClick: () => console.log('delete', record.id) },
|
|
182
|
+
],
|
|
183
|
+
},
|
|
184
|
+
];
|
|
185
|
+
const data = [
|
|
186
|
+
{ id: 1, name: '张三', role: '管理员', status: '正常' },
|
|
187
|
+
{ id: 2, name: '李四', role: '用户', status: '禁用' },
|
|
188
|
+
{ id: 3, name: '王五', role: '审计员', status: '正常' },
|
|
189
|
+
{ id: 4, name: '赵六', role: '用户', status: '正常' },
|
|
190
|
+
{ id: 5, name: '孙七', role: '用户', status: '正常' },
|
|
191
|
+
];
|
|
192
|
+
return (_jsx(Section, { title: "DataTable", children: _jsxs("div", { className: "w-full", children: [_jsxs("p", { className: "text-sm mb-2", children: ["\u5DF2\u9009: ", JSON.stringify(selectedKeys)] }), _jsx(DataTable, { columns: columns, data: data, rowKey: "id", rowSelection: {
|
|
193
|
+
selectedRowKeys: selectedKeys,
|
|
194
|
+
onChange: (keys) => setSelectedKeys(keys),
|
|
195
|
+
} })] }) }));
|
|
196
|
+
}
|
|
197
|
+
// ─── Search ───────────────────────────────────────────────────────────────────
|
|
198
|
+
function SearchDemo() {
|
|
199
|
+
return (_jsx(Section, { title: "Search", children: _jsx("div", { className: "w-full", children: _jsxs(Search, { schemas: [
|
|
200
|
+
{ type: 'input', key: 'keyword', label: '关键字', fieldProps: { placeholder: '请输入' } },
|
|
201
|
+
{
|
|
202
|
+
type: 'select',
|
|
203
|
+
key: 'status',
|
|
204
|
+
label: '状态',
|
|
205
|
+
fieldProps: {
|
|
206
|
+
options: [
|
|
207
|
+
{ label: '正常', value: 'active' },
|
|
208
|
+
{ label: '禁用', value: 'disabled' },
|
|
209
|
+
],
|
|
210
|
+
placeholder: '请选择',
|
|
211
|
+
},
|
|
212
|
+
},
|
|
213
|
+
], children: [_jsx(Button, { type: "submit", variant: "primary", children: "\u641C\u7D22" }), _jsx(Button, { type: "reset", children: "\u91CD\u7F6E" })] }) }) }));
|
|
214
|
+
}
|
|
215
|
+
// ─── Breadcrumb ───────────────────────────────────────────────────────────────
|
|
216
|
+
function BreadcrumbDemo() {
|
|
217
|
+
const [items, setItems] = useState([
|
|
218
|
+
{ id: 'home', label: '首页' },
|
|
219
|
+
{ id: 'list', label: '用户列表' },
|
|
220
|
+
{ id: 'detail', label: '用户详情', active: true },
|
|
221
|
+
]);
|
|
222
|
+
return (_jsx(Section, { title: "Breadcrumb", children: _jsx(Breadcrumb, { children: _jsx(BreadcrumbList, { children: items.map((item, idx) => (_jsxs(React.Fragment, { children: [_jsx(BreadcrumbItem, { children: _jsx(BreadcrumbPage, { active: item.active, onClose: () => setItems((prev) => prev.filter((i) => i.id !== item.id)), onClick: () => setItems((prev) => prev.map((i) => ({ ...i, active: i.id === item.id }))), className: "cursor-pointer", children: item.label }) }), idx < items.length - 1 && _jsx(BreadcrumbSeparator, {})] }, item.id))) }) }) }));
|
|
223
|
+
}
|
|
224
|
+
// ─── Label ────────────────────────────────────────────────────────────────────
|
|
225
|
+
function LabelDemo() {
|
|
226
|
+
return (_jsxs(Section, { title: "Label", children: [_jsx(Label, { label: "\u6C34\u5E73\u5E03\u5C40", layout: "horizontal", children: _jsx("span", { className: "text-sm", children: "\u5185\u5BB9\u533A\u57DF" }) }), _jsx(Label, { label: "\u5782\u76F4\u5E03\u5C40", layout: "vertical", children: _jsx("span", { className: "text-sm", children: "\u5185\u5BB9\u533A\u57DF" }) })] }));
|
|
227
|
+
}
|
|
228
|
+
// ─── Form ─────────────────────────────────────────────────────────────────────
|
|
229
|
+
function FormDemo() {
|
|
230
|
+
const [form] = useForm();
|
|
231
|
+
return (_jsx(Section, { title: "Form", children: _jsxs(Form, { form: form, onFinish: (v) => console.log('表单值:', v), children: [_jsx(FormItem, { name: "username", label: "\u7528\u6237\u540D", required: true, rules: [{ required: true, message: '请输入用户名' }], children: _jsx(Input, { placeholder: "\u8BF7\u8F93\u5165\u7528\u6237\u540D" }) }), _jsx(FormItem, { name: "password", label: "\u5BC6\u7801", required: true, rules: [{ required: true, message: '请输入密码' }], children: _jsx(Input, { type: "password", placeholder: "\u8BF7\u8F93\u5165\u5BC6\u7801" }) }), _jsx(Button, { type: "submit", children: "\u63D0\u4EA4" })] }) }));
|
|
232
|
+
}
|
|
233
|
+
// ─── SchemaForm ───────────────────────────────────────────────────────────────
|
|
234
|
+
function SchemaFormDemo() {
|
|
235
|
+
const form = useRef(undefined);
|
|
236
|
+
return (_jsx(Section, { title: "SchemaForm", children: _jsx(SchemaForm, { layout: "horizontal", getForm: (f) => {
|
|
237
|
+
form.current = f;
|
|
238
|
+
}, schemas: [
|
|
239
|
+
{
|
|
240
|
+
key: 'username',
|
|
241
|
+
label: '用户名',
|
|
242
|
+
type: 'input',
|
|
243
|
+
required: true,
|
|
244
|
+
rules: [{ required: true, message: '请输入用户名' }],
|
|
245
|
+
fieldProps: { placeholder: '请输入用户名' },
|
|
246
|
+
},
|
|
247
|
+
{
|
|
248
|
+
key: 'role',
|
|
249
|
+
label: '角色',
|
|
250
|
+
type: 'select',
|
|
251
|
+
fieldProps: {
|
|
252
|
+
placeholder: '请选择',
|
|
253
|
+
options: [
|
|
254
|
+
{ label: '管理员', value: 'admin' },
|
|
255
|
+
{ label: '用户', value: 'user' },
|
|
256
|
+
],
|
|
257
|
+
},
|
|
258
|
+
},
|
|
259
|
+
], onFinish: (values) => console.log(values) }) }));
|
|
260
|
+
}
|
|
261
|
+
// ─── TableSearch ─────────────────────────────────────────────────────────────
|
|
262
|
+
function TableSearchDemo() {
|
|
263
|
+
return (_jsx(Section, { title: "TableSearch", children: _jsx(TableSearch, { onSearch: (v) => console.log(v), schemas: [
|
|
264
|
+
{ type: 'input', key: 'q1', label: '字段1', fieldProps: {} },
|
|
265
|
+
{ type: 'select', key: 'q2', label: '状态', fieldProps: { options: [{ value: 'a', label: 'A' }] } },
|
|
266
|
+
{ type: 'switch', key: 'q3', label: '开关', fieldProps: {} },
|
|
267
|
+
{ type: 'date', key: 'q4', label: '日期', fieldProps: {} },
|
|
268
|
+
{ type: 'date', key: 'q5', label: '范围', fieldProps: { mode: 'range' } },
|
|
269
|
+
{ type: 'textarea', key: 'q6', label: '文本', fieldProps: {} },
|
|
270
|
+
{ type: 'input', key: 'q7', label: '字段7', fieldProps: {} },
|
|
271
|
+
{ type: 'input', key: 'q8', label: '字段8', fieldProps: {} },
|
|
272
|
+
] }) }));
|
|
273
|
+
}
|
|
274
|
+
// ─── Skeleton ─────────────────────────────────────────────────────────────────
|
|
275
|
+
function SkeletonDemo() {
|
|
276
|
+
return (_jsx(Section, { title: "Skeleton", children: _jsxs("div", { className: "w-full space-y-4", children: [_jsxs("div", { children: [_jsx("p", { className: "text-xs text-gray-500 mb-1", children: "pageloading" }), _jsx(Skeleton, { mode: "pageloading", rows: 3, showTitle: true, showActions: true })] }), _jsxs("div", { children: [_jsx("p", { className: "text-xs text-gray-500 mb-1", children: "tableloading" }), _jsx(Skeleton, { mode: "tableloading", rows: 4 })] }), _jsxs("div", { children: [_jsx("p", { className: "text-xs text-gray-500 mb-1", children: "componentsloading" }), _jsx(Skeleton, { mode: "componentsloading", rows: 2 })] })] }) }));
|
|
277
|
+
}
|
|
278
|
+
// ─── TreeSelect ───────────────────────────────────────────────────────────────
|
|
6
279
|
function TreeSelectDemo() {
|
|
7
280
|
const [value, setValue] = useState(['1.1.1', '1.1.2']);
|
|
8
281
|
const [indeterminate, setIndeterminate] = useState([]);
|
|
9
282
|
const treeData = [
|
|
10
283
|
{
|
|
11
284
|
id: '1',
|
|
12
|
-
name: '1',
|
|
285
|
+
name: '节点 1',
|
|
13
286
|
children: [
|
|
14
287
|
{
|
|
15
288
|
id: '1.1',
|
|
16
|
-
name: '1.1',
|
|
289
|
+
name: '节点 1.1',
|
|
17
290
|
children: [
|
|
18
291
|
{
|
|
19
292
|
id: '1.1.1',
|
|
20
|
-
name: '1.1.1',
|
|
293
|
+
name: '节点 1.1.1',
|
|
21
294
|
children: [
|
|
22
|
-
{
|
|
23
|
-
|
|
24
|
-
name: '1.1.1.1',
|
|
25
|
-
},
|
|
26
|
-
{
|
|
27
|
-
id: '1.1.1.2',
|
|
28
|
-
name: '1.1.1.2',
|
|
29
|
-
},
|
|
295
|
+
{ id: '1.1.1.1', name: '1.1.1.1' },
|
|
296
|
+
{ id: '1.1.1.2', name: '1.1.1.2' },
|
|
30
297
|
],
|
|
31
298
|
},
|
|
32
|
-
{ id: '1.1.2', name: '1.1.2' },
|
|
299
|
+
{ id: '1.1.2', name: '节点 1.1.2' },
|
|
33
300
|
],
|
|
34
301
|
},
|
|
35
302
|
{
|
|
36
303
|
id: '1.2',
|
|
37
|
-
name: '1.2',
|
|
304
|
+
name: '节点 1.2',
|
|
38
305
|
children: [
|
|
39
306
|
{ id: '1.2.1', name: '1.2.1' },
|
|
40
307
|
{ id: '1.2.2', name: '1.2.2' },
|
|
@@ -43,76 +310,28 @@ function TreeSelectDemo() {
|
|
|
43
310
|
],
|
|
44
311
|
},
|
|
45
312
|
];
|
|
46
|
-
return (_jsxs("div", { children: [_jsxs("div", { className: "mb-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
313
|
+
return (_jsx(Section, { title: "TreeSelect", children: _jsxs("div", { children: [_jsxs("div", { className: "text-sm mb-2", children: [_jsxs("span", { children: ["\u9009\u4E2D: ", JSON.stringify(value)] }), _jsxs("span", { className: "ml-4", children: ["\u534A\u9009: ", JSON.stringify(indeterminate)] })] }), _jsx(TreeSelect, { data: treeData, value: value, onChange: ({ checked, indeterminate }) => {
|
|
314
|
+
setValue(checked);
|
|
315
|
+
setIndeterminate(indeterminate);
|
|
316
|
+
} })] }) }));
|
|
50
317
|
}
|
|
318
|
+
// ─── PreviewImage ─────────────────────────────────────────────────────────────
|
|
51
319
|
function PreviewImageDemo() {
|
|
52
320
|
const images = [
|
|
53
|
-
'https://
|
|
54
|
-
'https://
|
|
321
|
+
'https://images.unsplash.com/photo-1778512828600-4a6540a1a115?w=900&auto=format&fit=crop&q=60&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxmZWF0dXJlZC1waG90b3MtZmVlZHw0fHx8ZW58MHx8fHx8',
|
|
322
|
+
'https://images.unsplash.com/photo-1778392120781-a6b2b55dc12a?w=900&auto=format&fit=crop&q=60&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxmZWF0dXJlZC1waG90b3MtZmVlZHwyNnx8fGVufDB8fHx8fA%3D%3D',
|
|
55
323
|
];
|
|
56
|
-
return (_jsx(
|
|
324
|
+
return (_jsx(Section, { title: "PreviewImage", children: _jsx(PreviewImage, { images: images, initialIndex: 0 }) }));
|
|
57
325
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
326
|
+
// ─── ImageUpload ─────────────────────────────────────────────────────────────
|
|
327
|
+
function ImageUploadDemo() {
|
|
328
|
+
return (_jsx(Section, { title: "ImageUpload", children: _jsx(ImageUpload, { accept: ".jpg,.png", maxCount: 4, beforeChange: (f) => {
|
|
329
|
+
console.log(f);
|
|
330
|
+
return parseInt(Math.random() * 10 + '') % 2 === 0;
|
|
331
|
+
} }) }));
|
|
64
332
|
}
|
|
333
|
+
// ─── Main ─────────────────────────────────────────────────────────────────────
|
|
65
334
|
const TestPage = () => {
|
|
66
|
-
|
|
67
|
-
return (_jsxs("div", { children: [_jsx("h1", { children: "button" }), _jsx(Button, { onClick: () => console.log(form), children: "click" }), _jsx("h2", { children: "text" }), _jsx(Button, { variant: "text", onClick: () => console.log(form), children: "click" }), _jsx(Button, { disabled: true, variant: "text", onClick: () => console.log(form), children: "click" }), _jsx("h1", { children: "input" }), _jsx(Input, {}), _jsx("h1", { children: "form" }), _jsx(MyForm, {}), _jsx("h1", { children: "schemeform" }), _jsx(SchemeForm, { layout: "horizontal", getForm: (f) => {
|
|
68
|
-
form.current = f;
|
|
69
|
-
}, schemes: [
|
|
70
|
-
{
|
|
71
|
-
name: 'username',
|
|
72
|
-
label: '用户名',
|
|
73
|
-
type: 'input',
|
|
74
|
-
required: true,
|
|
75
|
-
rules: [{ required: true, message: '请输入用户名' }],
|
|
76
|
-
fieldProps: {
|
|
77
|
-
placeholder: '请输入用户名',
|
|
78
|
-
},
|
|
79
|
-
},
|
|
80
|
-
{
|
|
81
|
-
name: 'role',
|
|
82
|
-
label: '角色',
|
|
83
|
-
type: 'select',
|
|
84
|
-
fieldProps: {
|
|
85
|
-
placeholder: '请选择',
|
|
86
|
-
options: [
|
|
87
|
-
{ label: '管理员', value: 'admin' },
|
|
88
|
-
{ label: '用户', value: 'user' },
|
|
89
|
-
],
|
|
90
|
-
},
|
|
91
|
-
},
|
|
92
|
-
], onFinish: (values) => console.log(values) }), _jsx("h1", { children: "label" }), _jsx("div", { children: _jsx(Label, { label: "labelName", layout: "horizontal", children: "123" }) }), _jsx("h1", { children: "TableSearch " }), _jsx(TableSearch, { onSearch: (v) => {
|
|
93
|
-
console.log(v);
|
|
94
|
-
}, schemes: [
|
|
95
|
-
{ type: 'input', fieldProps: {}, name: '1', label: '1' },
|
|
96
|
-
{ type: 'switch', fieldProps: {}, name: '2', label: '2' },
|
|
97
|
-
{ type: 'select', fieldProps: { options: [{ value: '3', label: '3' }] }, name: '3', label: '3' },
|
|
98
|
-
{ type: 'textarea', fieldProps: {}, name: '4', label: '4' },
|
|
99
|
-
{ type: 'date', fieldProps: {}, name: '5', label: '5' },
|
|
100
|
-
{
|
|
101
|
-
type: 'date',
|
|
102
|
-
fieldProps: {
|
|
103
|
-
mode: 'range',
|
|
104
|
-
},
|
|
105
|
-
name: '6',
|
|
106
|
-
label: '6',
|
|
107
|
-
},
|
|
108
|
-
{ type: 'input', fieldProps: {}, name: '7', label: '7' },
|
|
109
|
-
{ type: 'date', fieldProps: {}, name: '8', label: '8' },
|
|
110
|
-
{ type: 'input', fieldProps: {}, name: '9', label: '9' },
|
|
111
|
-
{ type: 'input', fieldProps: {}, name: '10', label: '10' },
|
|
112
|
-
{ type: 'input', fieldProps: {}, name: '11', label: '11' },
|
|
113
|
-
] }), _jsx("h1", { children: "Skeleton" }), _jsx(Skeleton, { mode: "pageloading", rows: 5, showTitle: true, showActions: true }), _jsx(Skeleton, { mode: "tableloading", rows: 8 }), _jsx(Skeleton, { mode: "componentsloading", rows: 3 }), _jsx("h1", { children: "TreeSelect" }), _jsx(TreeSelectDemo, {}), _jsx(DateTestPage, {}), _jsx("h1", { children: "PreviewImage" }), _jsx(PreviewImageDemo, {}), _jsx("h1", { children: "ImageUpload" }), _jsx(ImageUpload, { accept: ".jpg,.png", maxCount: 4, beforeChange: (f) => {
|
|
114
|
-
console.log(f);
|
|
115
|
-
return parseInt(Math.random() * 10 + '') % 2 === 0;
|
|
116
|
-
} })] }));
|
|
335
|
+
return (_jsxs("div", { className: "p-6 max-w-5xl mx-auto", children: [_jsx("h1", { className: "text-2xl font-bold mb-6", children: "\u7EC4\u4EF6\u5C55\u793A" }), _jsx(ThemeSwitcher, {}), _jsx(ButtonDemo, {}), _jsx(InputDemo, {}), _jsx(InputNumberDemo, {}), _jsx(TextareaDemo, {}), _jsx(SelectDemo, {}), _jsx(CheckboxDemo, {}), _jsx(SwitchDemo, {}), _jsx(TooltipDemo, {}), _jsx(DropdownDemo, {}), _jsx(MessageDemo, {}), _jsx(ModalDemo, {}), _jsx(DrawerDemo, {}), _jsx(ConfirmDialogDemo, {}), _jsx(PaginationDemo, {}), _jsx(TableDemo, {}), _jsx(DataTableDemo, {}), _jsx(SearchDemo, {}), _jsx(BreadcrumbDemo, {}), _jsx(LabelDemo, {}), _jsx(FormDemo, {}), _jsx(SchemaFormDemo, {}), _jsx(TableSearchDemo, {}), _jsx(SkeletonDemo, {}), _jsx(TreeSelectDemo, {}), _jsx(DateTestPage, {}), _jsx(PreviewImageDemo, {}), _jsx(ImageUploadDemo, {}), _jsx(MenuTestPage, {})] }));
|
|
117
336
|
};
|
|
118
337
|
export default TestPage;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export declare const executionPhaseType: {
|
|
2
|
+
readonly mount: "mount";
|
|
3
|
+
readonly render: "render";
|
|
4
|
+
readonly unMount: "unMount";
|
|
5
|
+
};
|
|
6
|
+
type ExecutionPhaseTypeKeys = keyof typeof executionPhaseType;
|
|
7
|
+
export type ExecutionPhaseType = (typeof executionPhaseType)[ExecutionPhaseTypeKeys];
|
|
8
|
+
/**
|
|
9
|
+
*
|
|
10
|
+
* @description 在各个阶段只触发一次
|
|
11
|
+
* @demo
|
|
12
|
+
* ```
|
|
13
|
+
const count = useExecuteOnce(() => {
|
|
14
|
+
console.log('123'); // 只会在第一次render时触发
|
|
15
|
+
return 123
|
|
16
|
+
})
|
|
17
|
+
|
|
18
|
+
// count 123
|
|
19
|
+
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
export default function useExecuteOnce<T>(factory: () => T,
|
|
23
|
+
/**
|
|
24
|
+
* @default executionPhase = render
|
|
25
|
+
*/
|
|
26
|
+
options?: {
|
|
27
|
+
executionPhase: ExecutionPhaseType[] | ExecutionPhaseType;
|
|
28
|
+
}): T | null;
|
|
29
|
+
export {};
|
|
30
|
+
//# sourceMappingURL=useExecuteOnce.d.ts.map
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { useEffect, useMemo, useRef } from 'react';
|
|
2
|
+
export const executionPhaseType = {
|
|
3
|
+
mount: 'mount',
|
|
4
|
+
render: 'render',
|
|
5
|
+
unMount: 'unMount',
|
|
6
|
+
};
|
|
7
|
+
// type ExecutionPhaseType =
|
|
8
|
+
// (typeof executionPhaseType)[keyof typeof executionPhaseType];
|
|
9
|
+
/**
|
|
10
|
+
*
|
|
11
|
+
* @description 在各个阶段只触发一次
|
|
12
|
+
* @demo
|
|
13
|
+
* ```
|
|
14
|
+
const count = useExecuteOnce(() => {
|
|
15
|
+
console.log('123'); // 只会在第一次render时触发
|
|
16
|
+
return 123
|
|
17
|
+
})
|
|
18
|
+
|
|
19
|
+
// count 123
|
|
20
|
+
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
export default function useExecuteOnce(factory,
|
|
24
|
+
/**
|
|
25
|
+
* @default executionPhase = render
|
|
26
|
+
*/
|
|
27
|
+
options) {
|
|
28
|
+
const { executionPhase: pExecutionPhase = executionPhaseType.render } = options ?? {};
|
|
29
|
+
const result = useRef(null);
|
|
30
|
+
const _executionPhase = useMemo(() => (typeof pExecutionPhase === 'string' ? [pExecutionPhase] : pExecutionPhase), [pExecutionPhase]);
|
|
31
|
+
const allowExecution = useRef([]);
|
|
32
|
+
// 跳过依赖;
|
|
33
|
+
const executionPhase = useRef(_executionPhase);
|
|
34
|
+
const runFN = (phase) => {
|
|
35
|
+
if (!allowExecution.current.includes(phase)) {
|
|
36
|
+
result.current = factory();
|
|
37
|
+
allowExecution.current.push(phase);
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
const fn = useRef(runFN);
|
|
41
|
+
executionPhase.current = _executionPhase;
|
|
42
|
+
fn.current = runFN;
|
|
43
|
+
if (executionPhase.current.includes(executionPhaseType.render)) {
|
|
44
|
+
fn.current(executionPhaseType.render);
|
|
45
|
+
}
|
|
46
|
+
useEffect(() => {
|
|
47
|
+
if (executionPhase.current.includes(executionPhaseType.mount)) {
|
|
48
|
+
fn.current(executionPhaseType['mount']);
|
|
49
|
+
}
|
|
50
|
+
return () => {
|
|
51
|
+
if (executionPhase.current.includes(executionPhaseType['unMount'])) {
|
|
52
|
+
fn.current(executionPhaseType['unMount']);
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
}, []);
|
|
56
|
+
return result.current;
|
|
57
|
+
}
|
|
@@ -1,7 +1,2 @@
|
|
|
1
|
-
export declare function useLanguage():
|
|
2
|
-
language: import("../locales").Language;
|
|
3
|
-
} & {
|
|
4
|
-
setLanguage: (lang: import("../locales").Language) => void;
|
|
5
|
-
t: typeof import("../stores/language").t;
|
|
6
|
-
};
|
|
1
|
+
export declare function useLanguage(): import("..").I18nStore;
|
|
7
2
|
//# sourceMappingURL=useLanguage.d.ts.map
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { RefObject } from 'react';
|
|
2
|
+
type SetState<S> = (value: S | ((preValue: S) => S), callback?: CallBackFN<S>) => void;
|
|
3
|
+
type CallBackFN<T> = (value: T) => void;
|
|
4
|
+
type RefState<T> = RefObject<{
|
|
5
|
+
data: T;
|
|
6
|
+
}>;
|
|
7
|
+
/**
|
|
8
|
+
*
|
|
9
|
+
* @demo
|
|
10
|
+
* ```
|
|
11
|
+
const [data, setData, dataRef] = useState(0);
|
|
12
|
+
|
|
13
|
+
setData(1, (newData) => {
|
|
14
|
+
// newData 1
|
|
15
|
+
// data 0
|
|
16
|
+
})
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
export default function useRefState<S>(initialState: S | (() => S)): [
|
|
20
|
+
S,
|
|
21
|
+
SetState<S>,
|
|
22
|
+
RefState<S>
|
|
23
|
+
];
|
|
24
|
+
export default function useRefState<S = undefined>(): [
|
|
25
|
+
S | undefined,
|
|
26
|
+
SetState<S | undefined>,
|
|
27
|
+
RefState<S | undefined>
|
|
28
|
+
];
|
|
29
|
+
export {};
|
|
30
|
+
//# sourceMappingURL=useRefState.d.ts.map
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { useState as RUS, useCallback, useLayoutEffect, useRef } from 'react';
|
|
2
|
+
import useInit from './useInit';
|
|
3
|
+
export default function useRefState(initialState) {
|
|
4
|
+
const [v, setValue] = RUS(initialState);
|
|
5
|
+
const data = useRef({ data: undefined });
|
|
6
|
+
const callbackRef = useRef(null);
|
|
7
|
+
const [callbackVersion, setCallbackVersion] = RUS(0);
|
|
8
|
+
useInit(() => {
|
|
9
|
+
data.current.data = v;
|
|
10
|
+
});
|
|
11
|
+
const setData = useCallback((action, callback) => {
|
|
12
|
+
const value = typeof action === 'function' ? action(data.current.data) : action;
|
|
13
|
+
setValue(value);
|
|
14
|
+
data.current.data = value;
|
|
15
|
+
if (callback) {
|
|
16
|
+
callbackRef.current = callback;
|
|
17
|
+
setCallbackVersion((version) => version + 1);
|
|
18
|
+
}
|
|
19
|
+
}, [setCallbackVersion, setValue]);
|
|
20
|
+
useLayoutEffect(() => {
|
|
21
|
+
if (callbackRef.current) {
|
|
22
|
+
const callback = callbackRef.current;
|
|
23
|
+
callbackRef.current = null;
|
|
24
|
+
callback(data.current.data);
|
|
25
|
+
}
|
|
26
|
+
}, [callbackVersion]);
|
|
27
|
+
return [v, setData, data];
|
|
28
|
+
// as [ExtractFNType<S>, SetState<S>];
|
|
29
|
+
}
|