@_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,13 +1,96 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from '../../lib/utils';
|
|
2
3
|
import { MoreHorizontal } from 'lucide-react';
|
|
4
|
+
import { useCallback, useLayoutEffect, useRef, useState } from 'react';
|
|
5
|
+
import { Button } from '../Button';
|
|
3
6
|
import { Dropdown } from '../Dropdown';
|
|
4
|
-
|
|
7
|
+
const isInlineAction = (action) => !('render' in action);
|
|
8
|
+
const renderActionLabel = (action) => (_jsxs(_Fragment, { children: [action.icon && _jsx("span", { className: "flex-shrink-0", children: action.icon }), _jsx("span", { className: "truncate", children: action.label })] }));
|
|
9
|
+
const canShowInlineActions = (actions) => actions.every(isInlineAction);
|
|
10
|
+
const InlineActions = ({ actions }) => (_jsx("div", { className: "tc-ui-action-btn-list inline-flex max-w-full items-center justify-center gap-1 whitespace-nowrap", children: actions.map((action) => isInlineAction(action) ? (_jsx(Button, { type: "button", onClick: action.onClick, className: cn('tc-ui-action-btn inline-flex h-8 max-w-full items-center justify-center gap-1 rounded px-2 text-sm transition-colors', action.danger
|
|
11
|
+
? 'text-destructive hover:bg-destructive/10'
|
|
12
|
+
: 'text-table-action-text hover:bg-background/60'), children: renderActionLabel(action) }, action.key)) : null) }));
|
|
13
|
+
const DropdownActions = ({ actions }) => (_jsx(Dropdown, { items: actions, placement: "bottom-end", children: _jsx(Button, { type: "button", state: "ghost", variant: "text", "aria-label": "More actions", className: "inline-flex h-8 w-8 items-center justify-center rounded-md text-table-action-text transition-colors hover:bg-background/60 focus-visible:ring-border", children: _jsx(MoreHorizontal, { className: "h-5 w-5 opacity-70" }) }) }));
|
|
14
|
+
const AutoActionBtn = ({ actions }) => {
|
|
15
|
+
const containerRef = useRef(null);
|
|
16
|
+
const measureRef = useRef(null);
|
|
17
|
+
const [canShowInline, setCanShowInline] = useState(false);
|
|
18
|
+
const updateOverflow = useCallback(() => {
|
|
19
|
+
const container = containerRef.current;
|
|
20
|
+
const measure = measureRef.current;
|
|
21
|
+
if (!container || !measure) {
|
|
22
|
+
setCanShowInline(false);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const containerWidth = container.clientWidth;
|
|
26
|
+
const actionsWidth = measure.scrollWidth;
|
|
27
|
+
setCanShowInline(containerWidth > 0 && actionsWidth <= containerWidth);
|
|
28
|
+
}, []);
|
|
29
|
+
useLayoutEffect(() => {
|
|
30
|
+
if (!canShowInlineActions(actions))
|
|
31
|
+
return;
|
|
32
|
+
if (actions.length <= 1)
|
|
33
|
+
return;
|
|
34
|
+
updateOverflow();
|
|
35
|
+
let rafId = 0;
|
|
36
|
+
const scheduleUpdate = () => {
|
|
37
|
+
cancelAnimationFrame(rafId);
|
|
38
|
+
rafId = requestAnimationFrame(updateOverflow);
|
|
39
|
+
};
|
|
40
|
+
if (typeof ResizeObserver === 'undefined') {
|
|
41
|
+
window.addEventListener('resize', scheduleUpdate);
|
|
42
|
+
return () => {
|
|
43
|
+
cancelAnimationFrame(rafId);
|
|
44
|
+
window.removeEventListener('resize', scheduleUpdate);
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
const observer = new ResizeObserver(scheduleUpdate);
|
|
48
|
+
if (containerRef.current) {
|
|
49
|
+
observer.observe(containerRef.current);
|
|
50
|
+
}
|
|
51
|
+
if (measureRef.current) {
|
|
52
|
+
observer.observe(measureRef.current);
|
|
53
|
+
}
|
|
54
|
+
window.addEventListener('resize', scheduleUpdate);
|
|
55
|
+
return () => {
|
|
56
|
+
cancelAnimationFrame(rafId);
|
|
57
|
+
observer.disconnect();
|
|
58
|
+
window.removeEventListener('resize', scheduleUpdate);
|
|
59
|
+
};
|
|
60
|
+
}, [actions, updateOverflow]);
|
|
5
61
|
if (actions.length === 0) {
|
|
6
62
|
return '-';
|
|
7
63
|
}
|
|
64
|
+
if (actions.length === 1) {
|
|
65
|
+
if (!canShowInlineActions(actions)) {
|
|
66
|
+
return _jsx(DropdownActions, { actions: actions });
|
|
67
|
+
}
|
|
68
|
+
return _jsx(InlineActions, { actions: actions });
|
|
69
|
+
}
|
|
70
|
+
if (!canShowInlineActions(actions)) {
|
|
71
|
+
return _jsx(DropdownActions, { actions: actions });
|
|
72
|
+
}
|
|
73
|
+
return (_jsxs("div", { ref: containerRef, className: "relative w-full min-w-0", children: [_jsx("div", { ref: measureRef, "aria-hidden": "true", className: "pointer-events-none invisible absolute left-0 top-0 w-max max-w-none", children: _jsx(InlineActions, { actions: actions }) }), canShowInline ? _jsx(InlineActions, { actions: actions }) : _jsx(DropdownActions, { actions: actions })] }));
|
|
74
|
+
};
|
|
75
|
+
export const ActionBtn = ({ actions, overflow }) => {
|
|
76
|
+
if (overflow === 'dropdown') {
|
|
77
|
+
return actions.length === 0 ? '-' : _jsx(DropdownActions, { actions: actions });
|
|
78
|
+
}
|
|
79
|
+
if (overflow === 'auto') {
|
|
80
|
+
return _jsx(AutoActionBtn, { actions: actions });
|
|
81
|
+
}
|
|
82
|
+
if (actions.length === 0) {
|
|
83
|
+
return '-';
|
|
84
|
+
}
|
|
85
|
+
if (overflow === 'inline') {
|
|
86
|
+
return canShowInlineActions(actions) ? (_jsx(InlineActions, { actions: actions })) : (_jsx(DropdownActions, { actions: actions }));
|
|
87
|
+
}
|
|
8
88
|
if (actions.length === 1) {
|
|
9
89
|
const action = actions[0];
|
|
10
|
-
|
|
90
|
+
if (!isInlineAction(action)) {
|
|
91
|
+
return _jsx(DropdownActions, { actions: actions });
|
|
92
|
+
}
|
|
93
|
+
return (_jsx(Button, { type: "button", onClick: action.onClick, className: "tc-ui-action-btn inline-flex items-center justify-center w-8 h-8 rounded transition-colors", children: action.label }));
|
|
11
94
|
}
|
|
12
|
-
return
|
|
95
|
+
return _jsx(DropdownActions, { actions: actions });
|
|
13
96
|
};
|
|
@@ -1,7 +1,15 @@
|
|
|
1
1
|
import { type ReactNode } from 'react';
|
|
2
|
+
import type { DropdownItem } from '../Dropdown';
|
|
2
3
|
import { type PaginationProps } from '../Pagination';
|
|
4
|
+
import { type TableFixed } from '../table';
|
|
3
5
|
import type { ColumnDef } from '../types/baseType';
|
|
4
|
-
|
|
6
|
+
import { type ActionOverflow } from './ActionBtn';
|
|
7
|
+
type DataTableActionColumnOptions<T> = {
|
|
8
|
+
actions?: DropdownItem[] | ((value: unknown, record: T, index: number) => DropdownItem[]);
|
|
9
|
+
actionOverflow?: ActionOverflow;
|
|
10
|
+
fixed?: TableFixed;
|
|
11
|
+
};
|
|
12
|
+
type TableColumnDef<T = Record<string, unknown>> = ColumnDef<T> & DataTableActionColumnOptions<T>;
|
|
5
13
|
type RowSelection<T> = {
|
|
6
14
|
/**
|
|
7
15
|
* 受控用法:完全由外部维护选中 keys
|
|
@@ -25,7 +33,7 @@ type RowSelection<T> = {
|
|
|
25
33
|
beforeCheckboxNode?: ReactNode;
|
|
26
34
|
};
|
|
27
35
|
interface DataTableProps<T = Record<string, unknown>> {
|
|
28
|
-
columns:
|
|
36
|
+
columns: TableColumnDef<T>[];
|
|
29
37
|
data: T[];
|
|
30
38
|
rowKey?: keyof T | ((record: T, index: number) => string | number);
|
|
31
39
|
rowSelection?: RowSelection<T>;
|
|
@@ -40,5 +48,5 @@ interface DataTableProps<T = Record<string, unknown>> {
|
|
|
40
48
|
export declare function DataTable<T = Record<string, unknown>>({ columns, data: pData, loading, rowKey, rowSelection, defaultColumnWidth, pagination: pPagination, }: DataTableProps<T>): import("react/jsx-runtime").JSX.Element;
|
|
41
49
|
export { ActionBtn } from './ActionBtn';
|
|
42
50
|
export type { ActionBtnProps } from './ActionBtn';
|
|
43
|
-
export type { DataTableProps, RowSelection };
|
|
44
|
-
//# sourceMappingURL=
|
|
51
|
+
export type { DataTableProps, RowSelection, TableColumnDef };
|
|
52
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import noResult from '@tc/ui-react/assets/table/no-result.svg';
|
|
3
|
+
import { useI18n } from '../../i18n';
|
|
4
|
+
import { useMemo, useState } from 'react';
|
|
5
|
+
import { Checkbox } from '../Checkbox';
|
|
6
|
+
import { Pagination } from '../Pagination';
|
|
7
|
+
import { Skeleton } from '../Skeleton';
|
|
8
|
+
import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow } from '../table';
|
|
9
|
+
import { ActionBtn } from './ActionBtn';
|
|
10
|
+
const defaultRowKey = 'id';
|
|
11
|
+
const rowSelectionColumnWidth = 48;
|
|
12
|
+
const actionColumnWidth = 96;
|
|
13
|
+
const zeroOffset = '0px';
|
|
14
|
+
const getRowKey = (record, index, rowKey = defaultRowKey) => {
|
|
15
|
+
if (typeof rowKey === 'function') {
|
|
16
|
+
return rowKey(record, index);
|
|
17
|
+
}
|
|
18
|
+
const key = record[rowKey];
|
|
19
|
+
return typeof key === 'string' || typeof key === 'number' ? key : index;
|
|
20
|
+
};
|
|
21
|
+
const renderCellContent = (column, value, record, rowIndex, hasAction) => {
|
|
22
|
+
if (hasAction && column.actions) {
|
|
23
|
+
const actions = typeof column.actions === 'function' ? column.actions(value, record, rowIndex) : column.actions;
|
|
24
|
+
return (_jsx("div", { className: "flex w-full min-w-0 justify-center", children: _jsx(ActionBtn, { actions: actions, overflow: column.actionOverflow ?? 'auto' }) }));
|
|
25
|
+
}
|
|
26
|
+
return column.render ? column.render(value, record, rowIndex) : value;
|
|
27
|
+
};
|
|
28
|
+
const getColumnWidth = (column, defaultColumnWidth) => {
|
|
29
|
+
const hasAction = column.isAction ?? column.key === 'action';
|
|
30
|
+
if (column.width) {
|
|
31
|
+
return column.width;
|
|
32
|
+
}
|
|
33
|
+
return `${hasAction ? actionColumnWidth : defaultColumnWidth}px`;
|
|
34
|
+
};
|
|
35
|
+
const getColumnStyle = (column, defaultColumnWidth) => {
|
|
36
|
+
const hasAction = column.isAction ?? column.key === 'action';
|
|
37
|
+
if (column.width || hasAction) {
|
|
38
|
+
const width = getColumnWidth(column, defaultColumnWidth);
|
|
39
|
+
return { width, minWidth: width };
|
|
40
|
+
}
|
|
41
|
+
return { minWidth: defaultColumnWidth };
|
|
42
|
+
};
|
|
43
|
+
const getFixedOffset = (widths) => {
|
|
44
|
+
if (widths.length === 0)
|
|
45
|
+
return zeroOffset;
|
|
46
|
+
if (widths.length === 1)
|
|
47
|
+
return widths[0];
|
|
48
|
+
return `calc(${widths.join(' + ')})`;
|
|
49
|
+
};
|
|
50
|
+
export function DataTable({ columns, data: pData, loading, rowKey = defaultRowKey, rowSelection, defaultColumnWidth = 100, pagination: pPagination, }) {
|
|
51
|
+
const t = useI18n();
|
|
52
|
+
const getCellValue = (record, column) => record[(column.dataIndex || column.key)];
|
|
53
|
+
const isControlled = rowSelection && Array.isArray(rowSelection.selectedRowKeys);
|
|
54
|
+
const [innerSelectedRowKeys, setInnerSelectedRowKeys] = useState(rowSelection?.defaultSelectedRowKeys ?? []);
|
|
55
|
+
const selectedRowKeys = (isControlled ? rowSelection?.selectedRowKeys : innerSelectedRowKeys) ?? [];
|
|
56
|
+
const selectedKeySet = new Set(selectedRowKeys);
|
|
57
|
+
const [currentPage, setCurrentPage] = useState(1);
|
|
58
|
+
const { showPagination, pagination, data, pageStartIndex } = useMemo(() => {
|
|
59
|
+
let pagination;
|
|
60
|
+
let data = pData;
|
|
61
|
+
let showPagination;
|
|
62
|
+
let pageStartIndex = 0;
|
|
63
|
+
// 使用外部
|
|
64
|
+
if (pPagination) {
|
|
65
|
+
pagination = pPagination;
|
|
66
|
+
showPagination = pagination.total > 0;
|
|
67
|
+
}
|
|
68
|
+
// 使用内部
|
|
69
|
+
else {
|
|
70
|
+
pagination = {
|
|
71
|
+
onChange(v) {
|
|
72
|
+
setCurrentPage(v);
|
|
73
|
+
},
|
|
74
|
+
current: currentPage,
|
|
75
|
+
pageSize: 10,
|
|
76
|
+
total: pData.length,
|
|
77
|
+
};
|
|
78
|
+
showPagination = pData.length > pagination.pageSize;
|
|
79
|
+
pageStartIndex = (pagination.current - 1) * pagination.pageSize;
|
|
80
|
+
data = pData.slice(pageStartIndex, pagination.current * pagination.pageSize);
|
|
81
|
+
}
|
|
82
|
+
return {
|
|
83
|
+
showPagination,
|
|
84
|
+
pagination,
|
|
85
|
+
data,
|
|
86
|
+
pageStartIndex,
|
|
87
|
+
};
|
|
88
|
+
}, [currentPage, pData, pPagination]);
|
|
89
|
+
const pageRowKeys = data.map((record, index) => getRowKey(record, pageStartIndex + index, rowKey));
|
|
90
|
+
const handleRowSelectChange = (key) => {
|
|
91
|
+
if (!rowSelection)
|
|
92
|
+
return;
|
|
93
|
+
const nextSelectedKeys = selectedKeySet.has(key)
|
|
94
|
+
? selectedRowKeys.filter((k) => k !== key)
|
|
95
|
+
: [...selectedRowKeys, key];
|
|
96
|
+
const nextSelectedKeySet = new Set(nextSelectedKeys);
|
|
97
|
+
const selectedRows = pData.filter((record, index) => nextSelectedKeySet.has(getRowKey(record, index, rowKey)));
|
|
98
|
+
if (!isControlled) {
|
|
99
|
+
setInnerSelectedRowKeys(nextSelectedKeys);
|
|
100
|
+
}
|
|
101
|
+
rowSelection.onChange?.(nextSelectedKeys, selectedRows, false);
|
|
102
|
+
};
|
|
103
|
+
const handleSelectAllChange = (event) => {
|
|
104
|
+
if (!rowSelection)
|
|
105
|
+
return;
|
|
106
|
+
const checked = event.target.checked;
|
|
107
|
+
let nextSelectedKeys;
|
|
108
|
+
if (checked) {
|
|
109
|
+
const pageKeySet = new Set(pageRowKeys);
|
|
110
|
+
nextSelectedKeys = Array.from(new Set([
|
|
111
|
+
...selectedRowKeys,
|
|
112
|
+
//
|
|
113
|
+
...pageRowKeys.filter((key) => !selectedKeySet.has(key)),
|
|
114
|
+
]))
|
|
115
|
+
//
|
|
116
|
+
.filter((key) => pageKeySet.has(key) || selectedKeySet.has(key));
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
const pageKeySet = new Set(pageRowKeys);
|
|
120
|
+
nextSelectedKeys = selectedRowKeys.filter((key) => !pageKeySet.has(key));
|
|
121
|
+
}
|
|
122
|
+
const nextSelectedKeySet = new Set(nextSelectedKeys);
|
|
123
|
+
const selectedRows = pData.filter((record, index) => nextSelectedKeySet.has(getRowKey(record, index, rowKey)));
|
|
124
|
+
if (!isControlled) {
|
|
125
|
+
setInnerSelectedRowKeys(nextSelectedKeys);
|
|
126
|
+
}
|
|
127
|
+
rowSelection.onChange?.(nextSelectedKeys, selectedRows, checked);
|
|
128
|
+
};
|
|
129
|
+
const allChecked = rowSelection
|
|
130
|
+
? (rowSelection.isAll ?? (pageRowKeys.length > 0 && pageRowKeys.every((key) => selectedKeySet.has(key))))
|
|
131
|
+
: false;
|
|
132
|
+
const partiallyChecked = rowSelection ? pageRowKeys.some((key) => selectedKeySet.has(key)) && !allChecked : false;
|
|
133
|
+
const fixedColumns = useMemo(() => {
|
|
134
|
+
const columnsWithFixed = columns.map((column, index) => {
|
|
135
|
+
const hasAction = column.isAction ?? column.key === 'action';
|
|
136
|
+
return {
|
|
137
|
+
column,
|
|
138
|
+
index,
|
|
139
|
+
fixed: column.fixed ?? (hasAction ? 'right' : undefined),
|
|
140
|
+
width: getColumnWidth(column, defaultColumnWidth),
|
|
141
|
+
};
|
|
142
|
+
});
|
|
143
|
+
const leftOffsetWidths = rowSelection ? [`${rowSelectionColumnWidth}px`] : [];
|
|
144
|
+
const leftOffsets = new Map();
|
|
145
|
+
for (const item of columnsWithFixed) {
|
|
146
|
+
if (item.fixed !== 'left')
|
|
147
|
+
continue;
|
|
148
|
+
leftOffsets.set(item.index, getFixedOffset(leftOffsetWidths));
|
|
149
|
+
leftOffsetWidths.push(item.width);
|
|
150
|
+
}
|
|
151
|
+
const rightOffsetWidths = [];
|
|
152
|
+
const rightOffsets = new Map();
|
|
153
|
+
for (const item of [...columnsWithFixed].reverse()) {
|
|
154
|
+
if (item.fixed !== 'right')
|
|
155
|
+
continue;
|
|
156
|
+
rightOffsets.set(item.index, getFixedOffset(rightOffsetWidths));
|
|
157
|
+
rightOffsetWidths.push(item.width);
|
|
158
|
+
}
|
|
159
|
+
return columnsWithFixed.map((item) => ({
|
|
160
|
+
...item,
|
|
161
|
+
fixedOffset: item.fixed === 'left'
|
|
162
|
+
? leftOffsets.get(item.index)
|
|
163
|
+
: item.fixed === 'right'
|
|
164
|
+
? rightOffsets.get(item.index)
|
|
165
|
+
: undefined,
|
|
166
|
+
}));
|
|
167
|
+
}, [columns, defaultColumnWidth, rowSelection]);
|
|
168
|
+
return (_jsxs("div", { className: "tc-ui-data-table bg-background rounded-[20px] overflow-hidden relative", children: [_jsxs(Table, { containerClassName: "rounded-b-none overflow-x-auto", children: [_jsx(TableHeader, { children: _jsxs(TableRow, { children: [rowSelection && (_jsxs(TableHead, { fixed: "left", style: {
|
|
169
|
+
width: '48px',
|
|
170
|
+
minWidth: '48px',
|
|
171
|
+
}, children: [rowSelection.beforeCheckboxNode, _jsx(Checkbox, { checked: allChecked, "aria-label": "Select all rows", indeterminate: partiallyChecked, onChange: (_, event) => handleSelectAllChange(event) })] })), fixedColumns.map(({ column, fixed, fixedOffset }) => {
|
|
172
|
+
const hasAction = column.isAction ?? column.key === 'action';
|
|
173
|
+
return (_jsx(TableHead, { isAction: hasAction, fixed: fixed, fixedOffset: fixedOffset, style: getColumnStyle(column, defaultColumnWidth), children: column.title }, column.key));
|
|
174
|
+
})] }) }), _jsx(TableBody, { children: data.length === 0 ? (_jsx(TableRow, { children: _jsx(TableCell, { colSpan: columns.length + (rowSelection ? 1 : 0), className: "text-muted-foreground", children: _jsxs("div", { className: "flex flex-col items-center w-full gap-2.5", children: [_jsx("img", { src: noResult, alt: t('components.dataTable.noData'), className: " w-24 h-24" }), t('components.dataTable.noData')] }) }) })) : (data.map((record, rowIndex) => {
|
|
175
|
+
const absoluteRowIndex = pageStartIndex + rowIndex;
|
|
176
|
+
const recordKey = getRowKey(record, absoluteRowIndex, rowKey);
|
|
177
|
+
return (_jsxs(TableRow, { children: [rowSelection && (_jsx(TableCell, { fixed: "left", style: {
|
|
178
|
+
width: '48px',
|
|
179
|
+
minWidth: '48px',
|
|
180
|
+
}, children: _jsx(Checkbox, { checked: selectedKeySet.has(recordKey), "aria-label": "Select row", onChange: () => handleRowSelectChange(recordKey) }) })), fixedColumns.map(({ column, fixed, fixedOffset }) => {
|
|
181
|
+
const value = getCellValue(record, column);
|
|
182
|
+
const hasAction = column.isAction ?? column.key === 'action';
|
|
183
|
+
return (_jsx(TableCell, { isAction: hasAction, fixed: fixed, fixedOffset: fixedOffset, style: getColumnStyle(column, defaultColumnWidth), children: renderCellContent(column, value, record, rowIndex, hasAction) }, column.key));
|
|
184
|
+
})] }, recordKey));
|
|
185
|
+
})) })] }), loading && (_jsx("div", { className: "absolute inset-0 rounded-[20px] bg-background/70 text-sm text-gray-600 z-[100]", children: _jsx(Skeleton, { mode: "tableloading", rows: 8 }) })), showPagination && (_jsx("div", { className: "px-6 pb-6 mt-6", children: _jsx(Pagination, { ...pagination }) }))] }));
|
|
186
|
+
}
|
|
187
|
+
export { ActionBtn } from './ActionBtn';
|
|
@@ -4,6 +4,7 @@ import { addMonths, addYears, eachDayOfInterval, endOfDay, endOfMonth, endOfWeek
|
|
|
4
4
|
import { zhCN } from 'date-fns/locale';
|
|
5
5
|
import { ChevronLeft, ChevronRight, ChevronsLeft, ChevronsRight } from 'lucide-react';
|
|
6
6
|
import { useMemo, useState } from 'react';
|
|
7
|
+
import { Button } from '../Button';
|
|
7
8
|
import { ModeType } from './data';
|
|
8
9
|
import { useDateLocale } from './LocaleContext';
|
|
9
10
|
import { TimePicker } from './TimePicker';
|
|
@@ -190,13 +191,13 @@ export function Calendar({ mode = ModeType.Single, value, onChange, disabledDate
|
|
|
190
191
|
const handleTimeChangeInternal = (date) => {
|
|
191
192
|
setPendingValue(date);
|
|
192
193
|
};
|
|
193
|
-
return (_jsxs("div", { className: cn('p-3', showTime || isRangeMode ? 'flex flex-col' : 'w-[280px]', className), children: [_jsxs("div", { className: cn('flex', (showTime || isRangeMode) && 'gap-4'), children: [isRangeMode && (_jsxs("div", { className: "w-[140px] pr-3 border-r border-border", children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-2", children: locale.quickRanges }), _jsx("div", { className: "space-y-1", children: quickRangePresets.map((preset) => (_jsx("
|
|
194
|
+
return (_jsxs("div", { className: cn('tc-ui-calendar p-3', showTime || isRangeMode ? 'flex flex-col' : 'w-[280px]', className), children: [_jsxs("div", { className: cn('flex', (showTime || isRangeMode) && 'gap-4'), children: [isRangeMode && (_jsxs("div", { className: "w-[140px] pr-3 border-r border-border", children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-2", children: locale.quickRanges }), _jsx("div", { className: "space-y-1", children: quickRangePresets.map((preset) => (_jsx(Button, { variant: "text", type: "button", onClick: () => handleQuickRangeClick(preset.getRange), className: cn('w-full justify-start text-left text-xs px-2 py-1 rounded', 'text-foreground hover:bg-muted transition-colors'), children: preset.label }, preset.label))) })] })), _jsxs("div", { className: "w-[280px]", children: [_jsxs("div", { className: "flex items-center justify-between mb-4", children: [_jsxs("div", { className: "flex items-center gap-1", children: [_jsx(Button, { variant: "text", onClick: prevYear, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronsLeft, { size: 16 }) }), _jsx(Button, { variant: "text", onClick: prevMonth, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronLeft, { size: 16 }) })] }), _jsx("div", { className: "font-medium text-sm", children: format(currentMonth, locale.monthFormat, { locale: zhCN }) }), _jsxs("div", { className: "flex items-center gap-1", children: [_jsx(Button, { variant: "text", onClick: nextMonth, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronRight, { size: 16 }) }), _jsx(Button, { variant: "text", onClick: nextYear, className: "p-1 hover:bg-muted rounded text-muted-foreground hover:text-foreground transition-colors", type: "button", children: _jsx(ChevronsRight, { size: 16 }) })] })] }), _jsx("div", { className: "grid grid-cols-7 mb-2", children: weekDays.map((day) => (_jsx("div", { className: "text-center text-xs text-muted-foreground font-medium py-1", children: day }, day))) }), _jsx("div", { className: "grid grid-cols-7 gap-y-1", onMouseLeave: () => setHoverDate(null), children: days.map((date, i) => {
|
|
194
195
|
const selected = isSelected(date);
|
|
195
196
|
const inRange = isInRange(date);
|
|
196
197
|
const isToday = isSameDay(date, new Date());
|
|
197
198
|
const isCurrentMonth = isSameMonth(date, currentMonth);
|
|
198
199
|
const isDisabled = disabledDate?.(date);
|
|
199
|
-
return (_jsx("div", { className: "flex justify-center p-0", children: _jsx("
|
|
200
|
+
return (_jsx("div", { className: "flex justify-center p-0", children: _jsx(Button, { variant: "text", type: "button", onClick: () => handleDateClick(date), onMouseEnter: () => setHoverDate(date), disabled: isDisabled, className: cn('w-8 h-8 flex items-center justify-center rounded text-sm transition-colors relative z-10', !isCurrentMonth && 'text-muted-foreground/40', isCurrentMonth && !selected && !inRange && !isDisabled && 'text-foreground hover:bg-muted', selected && 'bg-theme text-theme-foreground hover:bg-theme/90', inRange && !selected && 'bg-theme/10 text-theme', !selected && !inRange && isToday && 'border border-theme text-theme', isDisabled && 'text-muted-foreground cursor-not-allowed hover:bg-transparent opacity-50'), children: format(date, 'd') }) }, i));
|
|
200
201
|
}) })] }), showTime && (_jsx("div", { className: "flex flex-col border-l border-border pl-4", children: mode === ModeType.Single ? (_jsxs("div", { className: "flex flex-col justify-center h-full", children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-3 text-center", children: locale.selectTime }), _jsx(TimePicker, { value: pendingValue instanceof Date ? pendingValue : undefined, onChange: handleTimeChangeInternal, className: "border-0" })] })) : (
|
|
201
202
|
// Range mode: show two time pickers
|
|
202
203
|
_jsxs("div", { className: "space-y-4 flex flex-col justify-center h-full", children: [_jsxs("div", { children: [_jsx("div", { className: "text-xs font-medium text-muted-foreground mb-2 text-center", children: locale.startTime }), _jsx(TimePicker, { value: pendingValue && 'from' in pendingValue && pendingValue.from ? pendingValue.from : undefined, onChange: (newDate) => {
|
|
@@ -211,5 +212,5 @@ export function Calendar({ mode = ModeType.Single, value, onChange, disabledDate
|
|
|
211
212
|
from: range?.from,
|
|
212
213
|
to: newDate,
|
|
213
214
|
});
|
|
214
|
-
}, className: "border-0" })] }))] })) }))] }), showTime && (_jsx("div", { className: "pt-3 mt-3 border-t border-border", children: _jsx("
|
|
215
|
+
}, className: "border-0" })] }))] })) }))] }), showTime && (_jsx("div", { className: "pt-3 mt-3 border-t border-border", children: _jsx(Button, { variant: "primary", type: "button", onClick: handleConfirm, className: cn('w-full py-2 px-4 rounded', 'bg-theme text-theme-foreground', 'hover:bg-theme/90 transition-colors', 'text-sm font-medium'), children: locale.confirm }) }))] }));
|
|
215
216
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { type DateRange, type QuickRangePreset } from
|
|
2
|
-
import { ModeType } from
|
|
3
|
-
import { type DateLocaleConfig } from
|
|
1
|
+
import { type DateRange, type QuickRangePreset } from "./Calendar";
|
|
2
|
+
import { ModeType } from "./data";
|
|
3
|
+
import { type DateLocaleConfig } from "./locales";
|
|
4
4
|
export type DateChangeStrValue = [string, string] | string;
|
|
5
5
|
type DateBaseValue = Date | DateRange;
|
|
6
6
|
type Dates = DateBaseValue | [Date, Date];
|
|
@@ -29,6 +29,8 @@ export type DatePickerProps = {
|
|
|
29
29
|
* 不传则使用默认预设
|
|
30
30
|
*/
|
|
31
31
|
quickRanges?: QuickRangePreset[];
|
|
32
|
+
/** 自定义弹出容器,不传则默认挂载到 document.body */
|
|
33
|
+
getPopupContainer?: () => HTMLElement;
|
|
32
34
|
};
|
|
33
35
|
declare const DatePicker: import("react").ForwardRefExoticComponent<DatePickerProps & import("react").RefAttributes<HTMLDivElement>>;
|
|
34
36
|
export { DatePicker };
|
|
@@ -1,17 +1,22 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { cn } from
|
|
3
|
-
import { format as formatDate, isValid, parse } from
|
|
4
|
-
import { Calendar as CalendarIcon, X } from
|
|
5
|
-
import { forwardRef, useEffect, useMemo, useRef, useState } from
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
2
|
+
import { cn } from "../../lib/utils";
|
|
3
|
+
import { format as formatDate, isValid, parse } from "date-fns";
|
|
4
|
+
import { Calendar as CalendarIcon, X } from "lucide-react";
|
|
5
|
+
import { forwardRef, useEffect, useMemo, useRef, useState } from "react";
|
|
6
|
+
import { Button } from "../Button";
|
|
7
|
+
import { Input } from "../Input";
|
|
8
|
+
import { Popup } from "../Popup";
|
|
9
|
+
import { useDropdownPositioning } from "../hooks/useDropdownPositioning";
|
|
10
|
+
import { Calendar } from "./Calendar";
|
|
11
|
+
import { ModeType } from "./data";
|
|
12
|
+
import { getDatePickerDropdownPosition } from "./dropdownPositioning";
|
|
13
|
+
import { useDateLocale } from "./LocaleContext";
|
|
9
14
|
const formatValue = (val, format) => {
|
|
10
15
|
if (!val)
|
|
11
|
-
return
|
|
16
|
+
return "";
|
|
12
17
|
if (val instanceof Date)
|
|
13
18
|
return formatDate(val, format);
|
|
14
|
-
if (
|
|
19
|
+
if ("from" in val) {
|
|
15
20
|
if (val.from && val.to) {
|
|
16
21
|
return `${formatDate(val.from, format)} - ${formatDate(val.to, format)}`;
|
|
17
22
|
}
|
|
@@ -19,24 +24,26 @@ const formatValue = (val, format) => {
|
|
|
19
24
|
return formatDate(val.from, format);
|
|
20
25
|
}
|
|
21
26
|
}
|
|
22
|
-
return
|
|
27
|
+
return "";
|
|
23
28
|
};
|
|
24
29
|
const formatDateValue = (val, format) => {
|
|
25
30
|
if (!val)
|
|
26
|
-
return
|
|
31
|
+
return "";
|
|
27
32
|
/**
|
|
28
33
|
* 将 DateBaseValue 转为 yyyy-MM-dd | [yyyy-MM-dd, yyyy-MM-dd]
|
|
29
34
|
*/
|
|
30
35
|
if (val instanceof Date)
|
|
31
36
|
return formatDate(val, format);
|
|
32
|
-
if (
|
|
37
|
+
if ("from" in val) {
|
|
33
38
|
if (val.from && val.to) {
|
|
34
39
|
return [formatDate(val.from, format), formatDate(val.to, format)];
|
|
35
40
|
}
|
|
36
41
|
}
|
|
37
|
-
return
|
|
42
|
+
return "";
|
|
38
43
|
};
|
|
39
|
-
const DatePicker = forwardRef((
|
|
44
|
+
const DatePicker = forwardRef((props, ref) => {
|
|
45
|
+
const { mode = ModeType.Single, className, format: customFormat, placeholder, allowClear = true, disabled = false, showTime = false, value: pValue, defaultValue: pDefaultValue, onChange, disabledDate, locale: customLocale, quickRanges, getPopupContainer, } = props;
|
|
46
|
+
const isControlled = Object.prototype.hasOwnProperty.call(props, "value");
|
|
40
47
|
const contextLocale = useDateLocale();
|
|
41
48
|
const locale = { ...contextLocale, ...customLocale };
|
|
42
49
|
// 如果没有传入 placeholder,根据模式自动选择
|
|
@@ -49,7 +56,7 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
49
56
|
? locale.placeholderRange
|
|
50
57
|
: locale.placeholder);
|
|
51
58
|
// Auto-adjust format based on showTime
|
|
52
|
-
const format = customFormat || (showTime ?
|
|
59
|
+
const format = customFormat || (showTime ? "yyyy-MM-dd HH:mm" : "yyyy-MM-dd");
|
|
53
60
|
const { value, defaultValue } = useMemo(() => {
|
|
54
61
|
/**
|
|
55
62
|
* 将 DateChangeStrValue 转为 Dates
|
|
@@ -61,10 +68,10 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
61
68
|
if (val instanceof Date)
|
|
62
69
|
return val;
|
|
63
70
|
// Already a DateRange object
|
|
64
|
-
if (typeof val ===
|
|
71
|
+
if (typeof val === "object" && "from" in val)
|
|
65
72
|
return val;
|
|
66
73
|
// String value - single date
|
|
67
|
-
if (typeof val ===
|
|
74
|
+
if (typeof val === "string") {
|
|
68
75
|
try {
|
|
69
76
|
const parsed = parse(val, format, new Date());
|
|
70
77
|
return isValid(parsed) ? parsed : undefined;
|
|
@@ -76,7 +83,7 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
76
83
|
// date range
|
|
77
84
|
if (Array.isArray(val)) {
|
|
78
85
|
// string
|
|
79
|
-
if (typeof val[0] ===
|
|
86
|
+
if (typeof val[0] === "string" && typeof val[1] === "string") {
|
|
80
87
|
try {
|
|
81
88
|
const from = parse(val[0], format, new Date());
|
|
82
89
|
const to = parse(val[1], format, new Date());
|
|
@@ -97,40 +104,42 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
97
104
|
defaultValue: convertValue(pDefaultValue),
|
|
98
105
|
};
|
|
99
106
|
}, [pDefaultValue, pValue, format]);
|
|
100
|
-
const
|
|
107
|
+
const initialValue = isControlled ? value : (value || defaultValue);
|
|
108
|
+
const [selectedDate, setSelectedDate] = useState(initialValue);
|
|
101
109
|
const [isOpen, setIsOpen] = useState(false);
|
|
102
|
-
const [inputValue, setInputValue] = useState(formatValue(
|
|
110
|
+
const [inputValue, setInputValue] = useState(formatValue(initialValue, format));
|
|
103
111
|
const [isHover, setIsHover] = useState(false);
|
|
104
112
|
const containerRef = useRef(null);
|
|
113
|
+
const dropdownContentRef = useRef(null);
|
|
105
114
|
const inputRef = useRef(null);
|
|
115
|
+
const rangeDraftRef = useRef(false);
|
|
116
|
+
const positioning = useDropdownPositioning({
|
|
117
|
+
open: isOpen,
|
|
118
|
+
anchorRef: containerRef,
|
|
119
|
+
contentRef: dropdownContentRef,
|
|
120
|
+
placement: "bottom-start",
|
|
121
|
+
offset: 8,
|
|
122
|
+
matchAnchorWidth: false,
|
|
123
|
+
strategy: getDatePickerDropdownPosition,
|
|
124
|
+
});
|
|
106
125
|
// 同步外部 value 变化
|
|
107
126
|
useEffect(() => {
|
|
108
|
-
if (
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
127
|
+
if (!isControlled)
|
|
128
|
+
return;
|
|
129
|
+
if (mode === ModeType.Range && rangeDraftRef.current && value === undefined) {
|
|
130
|
+
return;
|
|
112
131
|
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
if (containerRef.current && !containerRef.current.contains(event.target)) {
|
|
118
|
-
setIsOpen(false);
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
if (isOpen) {
|
|
122
|
-
document.addEventListener('mousedown', handleClickOutside);
|
|
123
|
-
return () => document.removeEventListener('mousedown', handleClickOutside);
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
return () => { };
|
|
132
|
+
setSelectedDate(value);
|
|
133
|
+
setInputValue(formatValue(value, format));
|
|
134
|
+
if (mode !== ModeType.Range || !value || !('from' in value) || value.to) {
|
|
135
|
+
rangeDraftRef.current = false;
|
|
127
136
|
}
|
|
128
|
-
}, [
|
|
137
|
+
}, [isControlled, mode, value, format]);
|
|
129
138
|
const handleSelect = (date) => {
|
|
130
139
|
const newDate = date;
|
|
131
140
|
if (mode === ModeType.Range) {
|
|
132
141
|
// 如果是范围选择,只有当 from 和 to 都存在时才关闭
|
|
133
|
-
if (date &&
|
|
142
|
+
if (date && "from" in date && "to" in date && date.from && date.to) {
|
|
134
143
|
setIsOpen(false);
|
|
135
144
|
}
|
|
136
145
|
}
|
|
@@ -139,18 +148,24 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
139
148
|
// (In showTime mode, this only happens when user clicks confirm button)
|
|
140
149
|
setIsOpen(false);
|
|
141
150
|
}
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
// 只在非受控模式下更新内部状态
|
|
145
|
-
if (value === undefined) {
|
|
151
|
+
// range 选择需要保留内部草稿态,避免受控 value 把第一步点击抹掉
|
|
152
|
+
if (mode === ModeType.Range || !isControlled) {
|
|
146
153
|
setSelectedDate(newDate);
|
|
154
|
+
setInputValue(formatValue(newDate, format));
|
|
147
155
|
}
|
|
156
|
+
rangeDraftRef.current =
|
|
157
|
+
mode === ModeType.Range && !(newDate &&
|
|
158
|
+
typeof newDate === 'object' &&
|
|
159
|
+
'from' in newDate &&
|
|
160
|
+
newDate.from &&
|
|
161
|
+
newDate.to);
|
|
148
162
|
onChange?.(formatDateValue(newDate, format), newDate);
|
|
149
163
|
};
|
|
150
164
|
const handleClear = (e) => {
|
|
151
165
|
e.stopPropagation();
|
|
166
|
+
rangeDraftRef.current = false;
|
|
152
167
|
setSelectedDate(undefined);
|
|
153
|
-
setInputValue(
|
|
168
|
+
setInputValue("");
|
|
154
169
|
onChange?.(undefined, undefined);
|
|
155
170
|
inputRef.current?.focus();
|
|
156
171
|
};
|
|
@@ -161,7 +176,7 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
161
176
|
try {
|
|
162
177
|
const parsedDate = parse(newValue, format, new Date());
|
|
163
178
|
if (isValid(parsedDate)) {
|
|
164
|
-
if (
|
|
179
|
+
if (!isControlled)
|
|
165
180
|
setSelectedDate(parsedDate);
|
|
166
181
|
onChange?.(formatDateValue(parsedDate, format), parsedDate);
|
|
167
182
|
}
|
|
@@ -172,7 +187,15 @@ const DatePicker = forwardRef(({ mode = ModeType.Single, className, format: cust
|
|
|
172
187
|
}
|
|
173
188
|
};
|
|
174
189
|
const showClearIcon = allowClear && selectedDate && !disabled && isHover;
|
|
175
|
-
return (_jsx("div", { ref: ref, className: cn(
|
|
190
|
+
return (_jsx("div", { ref: ref, className: cn("tc-ui-date-picker relative w-full", mode === ModeType.Range ? "min-w-[255px]" : "", className), children: _jsxs("div", { ref: containerRef, className: "relative", children: [_jsxs("div", { className: cn("flex items-center w-full rounded-lg px-4 py-3 text-sm", "border transition-colors duration-200", "bg-background cursor-pointer", disabled &&
|
|
191
|
+
"cursor-not-allowed bg-muted border-border text-muted-foreground", !disabled && !selectedDate && !isOpen && "border-border", !disabled && (selectedDate || isOpen) && "border-theme"), onClick: () => !disabled && setIsOpen(!isOpen), onMouseEnter: () => setIsHover(true), onMouseLeave: () => setIsHover(false), children: [_jsx(Input, { ref: inputRef, type: "text", value: inputValue, onChange: (_, e) => handleInputChange(e), placeholder: finalPlaceholder, disabled: disabled, readOnly: mode === ModeType.Range, className: "flex-1", inputClassName: cn("flex-1 rounded-none border-0 bg-transparent px-0 py-0 outline-none", "text-sm text-foreground placeholder:text-muted-foreground", disabled && "cursor-not-allowed", mode === ModeType.Range &&
|
|
192
|
+
!disabled &&
|
|
193
|
+
"cursor-pointer caret-transparent") }), showClearIcon ? (_jsx(Button, { variant: "text", type: "button", onClick: handleClear, title: locale.clear, "aria-label": locale.clear, className: cn("ml-2 flex items-center justify-center", "w-5 h-5 rounded-full", "bg-muted hover:bg-muted/80", "text-foreground transition-colors", "cursor-pointer"), children: _jsx(X, { size: 12 }) })) : (_jsx(CalendarIcon, { size: 16, className: "ml-2 text-muted-foreground" }))] }), _jsx(Popup, { open: isOpen && !disabled, anchorRef: containerRef, contentRef: dropdownContentRef, positioning: positioning, keepMounted: true, onOpenChange: (nextOpen) => {
|
|
194
|
+
setIsOpen(nextOpen);
|
|
195
|
+
if (!nextOpen) {
|
|
196
|
+
rangeDraftRef.current = false;
|
|
197
|
+
}
|
|
198
|
+
}, className: cn("overflow-hidden"), container: getPopupContainer?.(), children: _jsx("div", { ref: dropdownContentRef, children: _jsx(Calendar, { mode: mode, value: selectedDate || null, onChange: handleSelect, disabledDate: disabledDate, showTime: showTime, locale: locale, quickRanges: quickRanges }) }) })] }) }));
|
|
176
199
|
});
|
|
177
|
-
DatePicker.displayName =
|
|
200
|
+
DatePicker.displayName = "DatePicker";
|
|
178
201
|
export { DatePicker };
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { cn } from '../../lib/utils';
|
|
3
3
|
import { ChevronDown, ChevronUp } from 'lucide-react';
|
|
4
|
+
import { Button } from '../Button';
|
|
5
|
+
import { Input } from '../Input';
|
|
4
6
|
export function TimePicker({ value, onChange, className }) {
|
|
5
7
|
// Derive time from value prop directly
|
|
6
8
|
const hours = value?.getHours() ?? 0;
|
|
@@ -72,5 +74,5 @@ export function TimePicker({ value, onChange, className }) {
|
|
|
72
74
|
}
|
|
73
75
|
};
|
|
74
76
|
const formatNumber = (num) => String(num).padStart(2, '0');
|
|
75
|
-
return (_jsxs("div", { className: cn('flex items-center justify-center gap-3 py-3', className), children: [_jsxs("div", { className: "flex flex-col items-center gap-1", children: [_jsx("
|
|
77
|
+
return (_jsxs("div", { className: cn('tc-ui-time-picker flex items-center justify-center gap-3 py-3', className), children: [_jsxs("div", { className: "flex flex-col items-center gap-1", children: [_jsx(Button, { variant: "text", type: "button", onClick: incrementHours, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronUp, { size: 14 }) }), _jsx(Input, { type: "text", value: formatNumber(hours), onChange: (_, e) => handleHoursInput(e), onKeyDown: handleHoursKeyDown, className: "w-12", inputClassName: cn('w-12 h-9 px-0 py-0 text-center text-sm font-medium', 'border border-border rounded', 'bg-background text-foreground', 'focus:outline-none focus:border-theme', 'transition-colors'), maxLength: 2 }), _jsx(Button, { variant: "text", type: "button", onClick: decrementHours, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronDown, { size: 14 }) })] }), _jsx("div", { className: "text-lg font-medium text-foreground mb-1", children: ":" }), _jsxs("div", { className: "flex flex-col items-center gap-1", children: [_jsx(Button, { variant: "text", type: "button", onClick: incrementMinutes, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronUp, { size: 14 }) }), _jsx(Input, { type: "text", value: formatNumber(minutes), onChange: (_, e) => handleMinutesInput(e), onKeyDown: handleMinutesKeyDown, className: "w-12", inputClassName: cn('w-12 h-9 px-0 py-0 text-center text-sm font-medium', 'border border-border rounded', 'bg-background text-foreground', 'focus:outline-none focus:border-theme', 'transition-colors'), maxLength: 2 }), _jsx(Button, { variant: "text", type: "button", onClick: decrementMinutes, className: "p-1 hover:bg-muted rounded transition-colors text-muted-foreground hover:text-foreground", children: _jsx(ChevronDown, { size: 14 }) })] })] }));
|
|
76
78
|
}
|