@_tc/template-core 0.0.1-bate.35 → 0.0.1-bate.37
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/cjs/app/controller/base.js +3 -3
- package/cjs/app/controller/project.js +1 -1
- package/cjs/app/controller/view.js +16 -7
- package/cjs/app/middleware/api-params-verify.js +10 -1
- package/cjs/app/middleware/error-handle.js +9 -3
- package/cjs/app/middleware/project-handler.js +1 -1
- package/cjs/app/router/view.js +3 -1
- package/cjs/app/router-schema/project.js +1 -1
- package/cjs/app/service/project.js +5 -0
- package/cjs/bundler/defaultAlias.js +5 -0
- package/cjs/bundler/dev.js +4 -3
- package/cjs/bundler/index.js +2 -1
- package/cjs/bundler/prod.js +4 -3
- package/cjs/bundler/utils.js +53 -24
- package/cjs/packages/common/LRUCache.js +4 -0
- package/cjs/packages/common/array/index.js +43 -0
- package/cjs/packages/common/cache/LRUCache.js +45 -0
- package/cjs/packages/common/cache/index.js +4 -0
- package/cjs/packages/common/guards/index.js +34 -0
- package/cjs/packages/common/i18n/default.js +95 -0
- package/cjs/packages/common/i18n/en-US.js +95 -0
- package/cjs/packages/common/i18n/index.js +178 -0
- package/cjs/packages/common/i18n/locales.js +17 -0
- package/cjs/packages/common/i18n/types.js +1 -0
- package/cjs/packages/common/index.js +65 -0
- package/cjs/packages/common/log/index.js +160 -0
- package/cjs/packages/common/number/index.js +14 -0
- package/cjs/packages/common/object/filterEmpty.js +32 -0
- package/cjs/packages/common/object/filtereEmpty.js +5 -0
- package/cjs/packages/common/object/index.js +26 -0
- package/cjs/packages/common/string/index.js +17 -0
- package/cjs/packages/common/types/index.js +1 -0
- package/cjs/packages/core/index.js +17 -12
- package/cjs/packages/core/loader/model.js +3 -3
- package/cjs/packages/core/loader/router.js +14 -5
- package/esm/app/controller/base.js +3 -3
- package/esm/app/controller/project.js +3 -3
- package/esm/app/controller/view.js +16 -7
- package/esm/app/middleware/api-params-verify.js +10 -1
- package/esm/app/middleware/error-handle.js +9 -3
- package/esm/app/middleware/project-handler.js +1 -1
- package/esm/app/router/view.js +3 -1
- package/esm/app/router-schema/project.js +1 -1
- package/esm/app/service/project.js +5 -0
- package/esm/bundler/defaultAlias.js +4 -0
- package/esm/bundler/dev.js +4 -3
- package/esm/bundler/index.js +2 -1
- package/esm/bundler/prod.js +4 -3
- package/esm/bundler/utils.js +53 -24
- package/esm/index.js +2 -2
- package/esm/packages/common/LRUCache.js +2 -0
- package/esm/packages/common/array/index.js +37 -0
- package/esm/packages/common/cache/LRUCache.js +43 -0
- package/esm/packages/common/cache/index.js +2 -0
- package/esm/packages/common/guards/index.js +26 -0
- package/esm/packages/common/i18n/default.js +93 -0
- package/esm/packages/common/i18n/en-US.js +93 -0
- package/esm/packages/common/i18n/index.js +162 -0
- package/esm/packages/common/i18n/locales.js +11 -0
- package/esm/packages/common/i18n/types.js +0 -0
- package/esm/packages/common/index.js +13 -0
- package/esm/packages/common/log/index.js +146 -0
- package/esm/packages/common/number/index.js +11 -0
- package/esm/packages/common/object/filterEmpty.js +29 -0
- package/esm/packages/common/object/filtereEmpty.js +2 -0
- package/esm/packages/common/object/index.js +20 -0
- package/esm/packages/common/string/index.js +13 -0
- package/esm/packages/common/types/index.js +0 -0
- package/esm/packages/core/index.js +17 -12
- package/esm/packages/core/loader/model.js +3 -3
- package/esm/packages/core/loader/router.js +14 -5
- package/fe/frontend/dash/Dashboard.d.ts +7 -0
- package/fe/frontend/dash/Dashboard.js +63 -0
- package/fe/frontend/dash/dash.entry.d.ts +2 -0
- package/fe/frontend/dash/dash.entry.js +62 -0
- package/fe/frontend/index.d.ts +3 -0
- package/fe/frontend/index.js +1 -0
- package/fe/frontend/main.css +5 -1
- package/fe/frontend/main.d.ts +10 -3
- package/fe/frontend/main.js +13 -4
- package/fe/frontend/testPage/testPage.entry.js +1 -2
- package/fe/frontend/typing/window.d.ts +7 -0
- package/fe/frontend/typing/window.js +1 -0
- package/fe/frontend/widgets/api/baseInfo.d.ts +31 -0
- package/fe/frontend/widgets/api/baseInfo.js +15 -0
- package/fe/frontend/widgets/common/CRUD/CRUD.d.ts +70 -0
- package/fe/frontend/widgets/common/CRUD/CRUD.js +207 -0
- package/fe/frontend/widgets/common/CRUD/index.d.ts +2 -0
- package/fe/frontend/widgets/common/CRUD/index.js +1 -0
- package/fe/frontend/widgets/common/auth/index.d.ts +7 -0
- package/fe/frontend/widgets/common/auth/index.js +20 -0
- package/fe/frontend/widgets/common/generateMenuData.d.ts +4 -0
- package/fe/frontend/widgets/common/generateMenuData.js +14 -0
- package/fe/frontend/widgets/common/importComponent.d.ts +5 -0
- package/fe/frontend/widgets/common/importComponent.js +7 -0
- package/fe/frontend/widgets/common/language.d.ts +2 -0
- package/fe/frontend/widgets/common/language.js +8 -0
- package/fe/frontend/widgets/common/logFn/index.d.ts +4 -0
- package/fe/frontend/widgets/common/logFn/index.js +8 -0
- package/fe/frontend/widgets/common/menu.d.ts +22 -0
- package/fe/frontend/widgets/common/menu.js +80 -0
- package/fe/frontend/widgets/common/request.d.ts +33 -0
- package/fe/frontend/widgets/common/request.js +127 -0
- package/fe/frontend/widgets/components/BasePage/HeaderView.d.ts +9 -0
- package/fe/frontend/widgets/components/BasePage/HeaderView.js +14 -0
- package/fe/frontend/widgets/components/Router/index.d.ts +9 -0
- package/fe/frontend/widgets/components/Router/index.js +11 -0
- package/fe/frontend/widgets/components/Router/type.d.ts +2 -0
- package/fe/frontend/widgets/components/Router/type.js +1 -0
- package/fe/frontend/widgets/defaultPages/Iframe/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Iframe/index.js +14 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/DetailPanel.d.ts +7 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/DetailPanel.js +94 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/PopFrom.d.ts +13 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/PopFrom.js +109 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/data.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/data.js +6 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaSearch/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaSearch/index.js +58 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaTable/index.d.ts +11 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaTable/index.js +176 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/eventInfo.d.ts +8 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/eventInfo.js +6 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/index.js +1 -0
- package/fe/frontend/widgets/defaultPages/Schema/hooks/useComConfig.d.ts +10 -0
- package/fe/frontend/widgets/defaultPages/Schema/hooks/useComConfig.js +14 -0
- package/fe/frontend/widgets/defaultPages/Schema/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/index.js +67 -0
- package/fe/frontend/widgets/defaultPages/Schema/schemaType.d.ts +41 -0
- package/fe/frontend/widgets/defaultPages/Schema/schemaType.js +4 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaEventBus.d.ts +23 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaEventBus.js +66 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaStore.d.ts +33 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaStore.js +24 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/fetchErrorShow.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/fetchErrorShow.js +8 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/permissions.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/permissions.js +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/schemaConversion.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/schemaConversion.js +72 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/validator.d.ts +4 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/validator.js +31 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/SidebarSlotContainer.d.ts +10 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/SidebarSlotContainer.js +31 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/index.js +15 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPageTmp.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPageTmp.js +17 -0
- package/fe/frontend/widgets/defaultPages/SlotPage/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/SlotPage/index.js +24 -0
- package/fe/frontend/widgets/defaultPages/Todo.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Todo.js +5 -0
- package/fe/frontend/widgets/hooks/useCurrentMenuData.d.ts +11 -0
- package/fe/frontend/widgets/hooks/useCurrentMenuData.js +20 -0
- package/fe/frontend/widgets/hooks/useRouterParams.d.ts +5 -0
- package/fe/frontend/widgets/hooks/useRouterParams.js +11 -0
- package/fe/frontend/widgets/store/mode.d.ts +16 -0
- package/fe/frontend/widgets/store/mode.js +36 -0
- package/fe/model/types/data/button.d.ts +23 -0
- package/fe/model/types/data/button.js +1 -0
- package/fe/model/types/data/component.d.ts +37 -0
- package/fe/model/types/data/component.js +1 -0
- package/fe/model/types/data/fetchInfo.d.ts +8 -0
- package/fe/model/types/data/fetchInfo.js +1 -0
- package/fe/model/types/data/schema.d.ts +47 -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 +44 -0
- package/fe/model/types/menuType.js +1 -0
- package/fe/model/types/model.d.ts +20 -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/i18n/default.d.ts +87 -0
- package/fe/packages/common/i18n/default.js +85 -0
- package/fe/packages/common/i18n/en-US.d.ts +87 -0
- package/fe/packages/common/i18n/en-US.js +85 -0
- package/fe/packages/common/i18n/index.d.ts +19 -0
- package/fe/packages/common/i18n/index.js +142 -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 +47 -0
- package/fe/packages/common/i18n/types.js +1 -0
- package/fe/packages/common/index.d.ts +10 -0
- package/fe/packages/common/index.js +9 -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 +16 -30
- package/fe/packages/ui/react/components/Button/Button.js +53 -26
- package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +2 -6
- package/fe/packages/ui/react/components/Button/SumbitButton.js +3 -14
- 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.d.ts → ConfirmDialog/ConfirmDialog.d.ts} +0 -8
- 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 +85 -4
- package/fe/packages/ui/react/components/DataTable/{data-table.d.ts → index.d.ts} +10 -23
- package/fe/packages/ui/react/components/DataTable/{data-table.js → index.js} +57 -47
- package/fe/packages/ui/react/components/Date/Calendar.d.ts +0 -13
- package/fe/packages/ui/react/components/Date/Calendar.js +5 -13
- package/fe/packages/ui/react/components/Date/Date.d.ts +4 -13
- package/fe/packages/ui/react/components/Date/Date.js +70 -66
- package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +0 -4
- package/fe/packages/ui/react/components/Date/LocaleContext.js +0 -4
- package/fe/packages/ui/react/components/Date/LocaleProvider.d.ts +0 -11
- package/fe/packages/ui/react/components/Date/LocaleProvider.js +0 -11
- package/fe/packages/ui/react/components/Date/TimePicker.js +3 -2
- package/fe/packages/ui/react/components/Date/dateLocaleStore.d.ts +0 -6
- 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 -19
- package/fe/packages/ui/react/components/Date/locales.js +7 -47
- package/fe/packages/ui/react/components/Drawer/Drawer.d.ts +23 -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 +24 -0
- package/fe/packages/ui/react/components/Dropdown/Dropdown.js +28 -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.d.ts +0 -6
- package/fe/packages/ui/react/components/Form/Form.js +1 -1
- package/fe/packages/ui/react/components/Form/FormItem.d.ts +0 -21
- package/fe/packages/ui/react/components/Form/FormItem.js +2 -9
- package/fe/packages/ui/react/components/Form/SchemaForm/data.d.ts +45 -0
- package/fe/packages/ui/react/components/Form/{SchemeForm → SchemaForm}/data.js +8 -1
- package/fe/packages/ui/react/components/Form/SchemaForm/index.d.ts +60 -0
- package/fe/packages/ui/react/components/Form/SchemaForm/index.js +75 -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 -20
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.d.ts +0 -3
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +5 -2
- package/fe/packages/ui/react/components/Input/Input.d.ts +3 -21
- package/fe/packages/ui/react/components/Input/Input.js +5 -7
- package/fe/packages/ui/react/components/InputNumber/InputNumber.d.ts +26 -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.d.ts +0 -29
- package/fe/packages/ui/react/components/Label/Label.js +2 -4
- package/fe/packages/ui/react/components/Menu/Menu.d.ts +18 -0
- package/fe/packages/ui/react/components/Menu/Menu.js +98 -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 +3 -0
- package/fe/packages/ui/react/components/Menu/SubMenu.js +124 -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 +58 -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.d.ts +0 -7
- package/fe/packages/ui/react/components/Message/Message.js +4 -4
- package/fe/packages/ui/react/components/Message/MessageManager.js +0 -8
- package/fe/packages/ui/react/components/Modal/Modal.d.ts +3 -7
- package/fe/packages/ui/react/components/Modal/Modal.js +6 -44
- package/fe/packages/ui/react/components/Modal/ModalManager.d.ts +0 -12
- package/fe/packages/ui/react/components/Modal/ModalManager.js +5 -7
- package/fe/packages/ui/react/components/Overlay/Overlay.d.ts +20 -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.d.ts → Pagination/Pagination.d.ts} +0 -7
- package/fe/packages/ui/react/components/{Pagination.js → Pagination/Pagination.js} +5 -12
- 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 +69 -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 -5
- package/fe/packages/ui/react/components/Search/Search.js +3 -3
- package/fe/packages/ui/react/components/Select/Select.d.ts +2 -2
- package/fe/packages/ui/react/components/Select/Select.js +52 -113
- 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.d.ts +0 -15
- package/fe/packages/ui/react/components/Skeleton/Skeleton.js +3 -3
- package/fe/packages/ui/react/components/Switch/Switch.js +3 -1
- package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +5 -41
- package/fe/packages/ui/react/components/TableSearch/TableSearch.js +21 -22
- package/fe/packages/ui/react/components/TableSearch/lang.js +5 -14
- package/fe/packages/ui/react/components/Textarea/Textarea.d.ts +21 -0
- package/fe/packages/ui/react/components/Textarea/Textarea.js +36 -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/Tooltip.d.ts +9 -0
- package/fe/packages/ui/react/components/Tooltip/Tooltip.js +71 -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.d.ts → TreeSelect/TreeSelect.d.ts} +0 -6
- package/fe/packages/ui/react/components/{TreeSelect.js → TreeSelect/TreeSelect.js} +9 -17
- 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.d.ts +0 -27
- package/fe/packages/ui/react/components/Upload/Upload.js +2 -1
- package/fe/packages/ui/react/components/{breadcrumb.js → breadcrumb/breadcrumb.js} +15 -21
- 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 +43 -0
- package/fe/packages/ui/react/components/hooks/useDropdownPositioning.js +123 -0
- package/fe/packages/ui/react/components/hooks/useInputController.d.ts +0 -3
- package/fe/packages/ui/react/components/hooks/useInputController.js +0 -7
- 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/table.js +20 -0
- package/fe/packages/ui/react/components/testPage/MenuTestPage.d.ts +2 -0
- package/fe/packages/ui/react/components/testPage/MenuTestPage.js +101 -0
- package/fe/packages/ui/react/components/testPage/index.js +251 -81
- package/fe/packages/ui/react/hooks/useExecuteOnce.d.ts +12 -0
- package/fe/packages/ui/react/hooks/useExecuteOnce.js +36 -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 +18 -0
- package/fe/packages/ui/react/hooks/useRefState.js +28 -0
- package/fe/packages/ui/react/hooks/useWatch.d.ts +15 -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 +13 -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 +9 -0
- package/fe/packages/ui/react/i18n/useI18n.js +14 -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 -2
- 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 -46
- package/fe/packages/ui/react/lib/export.js +0 -40
- package/fe/packages/ui/react/lib/utils.d.ts +0 -24
- package/fe/packages/ui/react/lib/utils.js +0 -25
- package/fe/packages/ui/react/stores/breadcrumb.js +0 -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/package.json +14 -2
- package/types/app/controller/base.d.ts +3 -3
- package/types/app/router/view.d.ts +2 -3
- package/types/app/service/project.d.ts +29 -4
- package/types/app/type.d.ts +1 -0
- package/types/app/typings.d.ts +12 -21
- package/types/bundler/defaultAlias.d.ts +3 -0
- package/types/bundler/utils.d.ts +1 -1
- package/types/config/config.default.d.ts +14 -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/i18n/default.d.ts +86 -0
- package/types/packages/common/i18n/en-US.d.ts +86 -0
- package/types/packages/common/i18n/index.d.ts +18 -0
- package/types/packages/common/i18n/locales.d.ts +7 -0
- package/types/packages/common/i18n/types.d.ts +46 -0
- package/types/packages/common/index.d.ts +9 -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/types/packages/core/index.d.ts +1 -1
- package/types/packages/core/loader/router.d.ts +1 -1
- package/types/packages/core/types.d.ts +12 -3
- package/fe/packages/ui/react/components/ConfirmDialog.js +0 -9
- 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/index.d.ts +0 -152
- package/fe/packages/ui/react/components/Form/SchemeForm/index.js +0 -69
- package/fe/packages/ui/react/components/Textarea.d.ts +0 -59
- package/fe/packages/ui/react/components/Textarea.js +0 -35
- package/fe/packages/ui/react/components/Tooltip.d.ts +0 -25
- 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/fe/packages/ui/react/components/{breadcrumb.d.ts → breadcrumb/breadcrumb.d.ts} +0 -0
- /package/fe/packages/ui/react/components/{table.d.ts → table/table.d.ts} +0 -0
|
@@ -1,24 +1,20 @@
|
|
|
1
1
|
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { cn } from '
|
|
2
|
+
import { cn } from '../../lib/utils';
|
|
3
3
|
import { ChevronLeft, ChevronRight } from 'lucide-react';
|
|
4
|
-
import { Button } from '
|
|
5
|
-
import { Select } from '
|
|
4
|
+
import { Button } from '../Button';
|
|
5
|
+
import { Select } from '../Select';
|
|
6
6
|
export function Pagination({ current, pageSize, total, onChange, onPageSizeChange, pageSizeOptions = [10, 20, 50, 100], className, }) {
|
|
7
7
|
const totalPages = Math.ceil(total / pageSize);
|
|
8
|
-
// 生成页码数组
|
|
9
8
|
const getPageNumbers = () => {
|
|
10
9
|
const pages = [];
|
|
11
|
-
const maxVisible = 7;
|
|
10
|
+
const maxVisible = 7;
|
|
12
11
|
if (totalPages <= maxVisible) {
|
|
13
|
-
// 总页数少于等于7,显示所有页码
|
|
14
12
|
for (let i = 1; i <= totalPages; i++) {
|
|
15
13
|
pages.push(i);
|
|
16
14
|
}
|
|
17
15
|
}
|
|
18
16
|
else {
|
|
19
|
-
// 总页数大于7,需要省略
|
|
20
17
|
if (current <= 4) {
|
|
21
|
-
// 当前页在前面
|
|
22
18
|
for (let i = 1; i <= 5; i++) {
|
|
23
19
|
pages.push(i);
|
|
24
20
|
}
|
|
@@ -26,7 +22,6 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
|
|
|
26
22
|
pages.push(totalPages);
|
|
27
23
|
}
|
|
28
24
|
else if (current >= totalPages - 3) {
|
|
29
|
-
// 当前页在后面
|
|
30
25
|
pages.push(1);
|
|
31
26
|
pages.push('...');
|
|
32
27
|
for (let i = totalPages - 4; i <= totalPages; i++) {
|
|
@@ -34,7 +29,6 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
|
|
|
34
29
|
}
|
|
35
30
|
}
|
|
36
31
|
else {
|
|
37
|
-
// 当前页在中间
|
|
38
32
|
pages.push(1);
|
|
39
33
|
pages.push('...');
|
|
40
34
|
for (let i = current - 1; i <= current + 1; i++) {
|
|
@@ -64,7 +58,6 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
|
|
|
64
58
|
const handlePageSizeChange = (newPageSize) => {
|
|
65
59
|
if (newPageSize !== undefined && typeof newPageSize === 'number' && newPageSize !== pageSize && onPageSizeChange) {
|
|
66
60
|
onPageSizeChange(newPageSize);
|
|
67
|
-
// 当改变 pageSize 时,通常需要重置到第一页
|
|
68
61
|
if (current !== 1) {
|
|
69
62
|
onChange(1);
|
|
70
63
|
}
|
|
@@ -72,7 +65,7 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
|
|
|
72
65
|
};
|
|
73
66
|
if (totalPages === 0)
|
|
74
67
|
return null;
|
|
75
|
-
return (_jsxs("div", { className: cn('flex items-center gap-4', className), children: [_jsxs("div", { className: "text-sm text-muted-foreground", children: ["Total ", total] }), _jsxs("div", { className: "flex-1 flex items-center justify-center gap-2", children: [_jsx(Button, { onClick: handlePrevious, disabled: current === 1, size: "sm", className: cn('inline-flex items-center justify-center', 'h-8 px-3 rounded-md', 'text-sm font-medium', 'border border-border', 'transition-colors', current === 1 ? 'cursor-not-allowed opacity-50 bg-muted' : 'hover:bg-muted bg-background cursor-pointer'), children: _jsx(ChevronLeft, { className: "h-4 w-4" }) }), getPageNumbers().map((page, index) => {
|
|
68
|
+
return (_jsxs("div", { className: cn('tc-ui-pagination flex items-center gap-4', className), children: [_jsxs("div", { className: "text-sm text-muted-foreground", children: ["Total ", total] }), _jsxs("div", { className: "flex-1 flex items-center justify-center gap-2", children: [_jsx(Button, { onClick: handlePrevious, disabled: current === 1, size: "sm", className: cn('inline-flex items-center justify-center', 'h-8 px-3 rounded-md', 'text-sm font-medium', 'border border-border', 'transition-colors', current === 1 ? 'cursor-not-allowed opacity-50 bg-muted' : 'hover:bg-muted bg-background cursor-pointer'), children: _jsx(ChevronLeft, { className: "h-4 w-4" }) }), getPageNumbers().map((page, index) => {
|
|
76
69
|
if (page === '...') {
|
|
77
70
|
return (_jsx("span", { className: "px-2 text-muted-foreground", children: "..." }, `ellipsis-${index}`));
|
|
78
71
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Pagination';
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { CSSProperties, ReactNode, RefObject } from "react";
|
|
2
|
+
import { type DropdownPlacement, type DropdownPosition, type DropdownPositioningStrategy, type UseDropdownPositioningResult } from "../hooks/useDropdownPositioning";
|
|
3
|
+
export interface PopupProps {
|
|
4
|
+
open: boolean;
|
|
5
|
+
anchorRef: RefObject<HTMLElement | null>;
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
className?: string;
|
|
8
|
+
style?: CSSProperties;
|
|
9
|
+
placement?: DropdownPlacement;
|
|
10
|
+
offset?: number;
|
|
11
|
+
keepMounted?: boolean;
|
|
12
|
+
closeOnClickOutside?: boolean;
|
|
13
|
+
closeOnEscape?: boolean;
|
|
14
|
+
matchAnchorWidth?: boolean;
|
|
15
|
+
position?: DropdownPosition;
|
|
16
|
+
positioning?: UseDropdownPositioningResult;
|
|
17
|
+
strategy?: DropdownPositioningStrategy;
|
|
18
|
+
contentRef?: RefObject<HTMLDivElement | null>;
|
|
19
|
+
container?: HTMLElement;
|
|
20
|
+
positionMode?: "fixed" | "absolute";
|
|
21
|
+
hoverBridge?: number;
|
|
22
|
+
hoverBridgePlacement?: "auto" | "horizontal";
|
|
23
|
+
onOpenChange?: (open: boolean) => void;
|
|
24
|
+
}
|
|
25
|
+
export declare function Popup({ open, anchorRef, children, className, style, placement, offset, keepMounted, closeOnClickOutside, closeOnEscape, matchAnchorWidth, position, positioning, strategy, contentRef, container, positionMode, hoverBridge, hoverBridgePlacement, onOpenChange, }: PopupProps): import("react").ReactPortal | null;
|
|
26
|
+
//# sourceMappingURL=Popup.d.ts.map
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "../../lib/utils";
|
|
3
|
+
import { useEffect, useMemo, useRef } from "react";
|
|
4
|
+
import { createPortal } from "react-dom";
|
|
5
|
+
import { getDefaultDropdownPosition, useDropdownPositioning, } from "../hooks/useDropdownPositioning";
|
|
6
|
+
const DEFAULT_POPUP_CLASSNAME = cn("fixed z-[9999]", "bg-background rounded-lg shadow-lg border border-gray-200", "animate-in fade-in-0 zoom-in-95");
|
|
7
|
+
const canUseDocument = () => typeof document !== "undefined";
|
|
8
|
+
export function Popup({ open, anchorRef, children, className, style, placement = "bottom-end", offset = 8, keepMounted = false, closeOnClickOutside = true, closeOnEscape = true, matchAnchorWidth = false, position, positioning, strategy = getDefaultDropdownPosition, contentRef, container, positionMode = "fixed", hoverBridge = 0, hoverBridgePlacement = "auto", onOpenChange, }) {
|
|
9
|
+
const internalContentRef = useRef(null);
|
|
10
|
+
const panelRef = contentRef ?? internalContentRef;
|
|
11
|
+
const containerRef = useMemo(() => ({ current: container ?? null }), [container]);
|
|
12
|
+
const internalPositioning = useDropdownPositioning({
|
|
13
|
+
open,
|
|
14
|
+
anchorRef,
|
|
15
|
+
contentRef: panelRef,
|
|
16
|
+
placement,
|
|
17
|
+
offset,
|
|
18
|
+
matchAnchorWidth,
|
|
19
|
+
strategy,
|
|
20
|
+
containerRef,
|
|
21
|
+
positionMode,
|
|
22
|
+
});
|
|
23
|
+
const resolvedPositioning = position
|
|
24
|
+
? null
|
|
25
|
+
: (positioning ?? internalPositioning);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (!open || !closeOnClickOutside)
|
|
28
|
+
return;
|
|
29
|
+
const handleClickOutside = (event) => {
|
|
30
|
+
const target = event.target;
|
|
31
|
+
const clickedAnchor = anchorRef.current?.contains(target);
|
|
32
|
+
const clickedPanel = panelRef.current?.contains(target);
|
|
33
|
+
if (!clickedAnchor && !clickedPanel) {
|
|
34
|
+
onOpenChange?.(false);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
document.addEventListener("mousedown", handleClickOutside);
|
|
38
|
+
return () => document.removeEventListener("mousedown", handleClickOutside);
|
|
39
|
+
}, [anchorRef, closeOnClickOutside, onOpenChange, open, panelRef]);
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
if (!open || !closeOnEscape)
|
|
42
|
+
return;
|
|
43
|
+
const handleKeyDown = (event) => {
|
|
44
|
+
if (event.key === "Escape") {
|
|
45
|
+
onOpenChange?.(false);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
document.addEventListener("keydown", handleKeyDown);
|
|
49
|
+
return () => document.removeEventListener("keydown", handleKeyDown);
|
|
50
|
+
}, [closeOnEscape, onOpenChange, open]);
|
|
51
|
+
const mergedStyle = useMemo(() => ({
|
|
52
|
+
...resolvedPositioning?.position,
|
|
53
|
+
...position,
|
|
54
|
+
...style,
|
|
55
|
+
}), [position, resolvedPositioning?.position, style]);
|
|
56
|
+
const showHorizontalHoverBridge = hoverBridge > 0 &&
|
|
57
|
+
(placement.startsWith("right") || placement.startsWith("left"));
|
|
58
|
+
const showBothHorizontalHoverBridges = showHorizontalHoverBridge && hoverBridgePlacement === "horizontal";
|
|
59
|
+
if (!keepMounted && !open) {
|
|
60
|
+
return null;
|
|
61
|
+
}
|
|
62
|
+
const portalContainer = container ?? (canUseDocument() ? document.body : undefined);
|
|
63
|
+
if (!portalContainer) {
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
return createPortal(_jsxs("div", { ref: panelRef, className: cn("tc-ui-popup", DEFAULT_POPUP_CLASSNAME, positionMode === "absolute" && "absolute", !resolvedPositioning?.ready && "invisible", keepMounted && !open && "hidden", className), style: mergedStyle, children: [hoverBridge > 0 && (_jsx("div", { "aria-hidden": "true", className: cn("absolute bg-transparent", placement.startsWith("bottom") && "left-0 right-0 top-0 -translate-y-full", placement.startsWith("top") && "bottom-0 left-0 right-0 translate-y-full", placement.startsWith("right") && "bottom-0 left-0 top-0 -translate-x-full", placement.startsWith("left") && "bottom-0 right-0 top-0 translate-x-full"), style: placement.startsWith("right") || placement.startsWith("left")
|
|
67
|
+
? { width: hoverBridge }
|
|
68
|
+
: { height: hoverBridge } })), showBothHorizontalHoverBridges && (_jsx("div", { "aria-hidden": "true", className: "absolute bottom-0 right-0 top-0 translate-x-full bg-transparent", style: { width: hoverBridge } })), children] }), portalContainer);
|
|
69
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Popup';
|
|
@@ -1,14 +1,11 @@
|
|
|
1
1
|
import type { MOmit } from '../../types';
|
|
2
2
|
import type { FormInstance } from 'rc-field-form';
|
|
3
3
|
import { type ReactNode } from 'react';
|
|
4
|
-
import { type
|
|
4
|
+
import { type FormFieldSchema } from '../Form';
|
|
5
5
|
export type SearchProps<T> = {
|
|
6
6
|
defaultValue?: T;
|
|
7
|
-
|
|
7
|
+
schemas: MOmit<FormFieldSchema<T>, 'rules' | 'required'>[];
|
|
8
8
|
children?: ReactNode;
|
|
9
|
-
/**
|
|
10
|
-
* 获取表单实例的回调
|
|
11
|
-
*/
|
|
12
9
|
getForm?: (form: FormInstance<T>) => void;
|
|
13
10
|
btnsClassName?: string;
|
|
14
11
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { cn } from '../../lib/utils';
|
|
3
3
|
import { useMemo } from 'react';
|
|
4
|
-
import {
|
|
4
|
+
import { SchemaForm } from '../Form';
|
|
5
5
|
const Search = (props) => {
|
|
6
|
-
const { defaultValue: pDefaultValue,
|
|
6
|
+
const { defaultValue: pDefaultValue, schemas, children, getForm, btnsClassName } = props;
|
|
7
7
|
const defaultValue = useMemo(() => {
|
|
8
8
|
return pDefaultValue;
|
|
9
9
|
}, []);
|
|
10
|
-
return (_jsxs("div", { className: "flex items-end justify-between gap-4 flex-wrap", children: [_jsx(
|
|
10
|
+
return (_jsxs("div", { className: "tc-ui-search flex items-end justify-between gap-4 flex-wrap", children: [_jsx(SchemaForm, { preserve: true, layout: "horizontal", schemas: schemas, initialValues: defaultValue, getForm: getForm, footerButtons: false }), _jsx("div", { className: cn('flex items-center gap-2 self-end ml-auto flex-wrap', btnsClassName), children: children })] }));
|
|
11
11
|
};
|
|
12
12
|
export default Search;
|
|
@@ -2,6 +2,7 @@ import React from 'react';
|
|
|
2
2
|
export type SelectOption = {
|
|
3
3
|
label: React.ReactNode;
|
|
4
4
|
value: string | number;
|
|
5
|
+
searchText?: string;
|
|
5
6
|
};
|
|
6
7
|
export type SelectProps = {
|
|
7
8
|
options: SelectOption[];
|
|
@@ -11,10 +12,9 @@ export type SelectProps = {
|
|
|
11
12
|
onChange?: (value: string | number | undefined) => void;
|
|
12
13
|
className?: string;
|
|
13
14
|
disabled?: boolean;
|
|
14
|
-
/** 开启清除 默认开启*/
|
|
15
15
|
clearable?: boolean;
|
|
16
|
-
/** 是否支持搜索 默认开启 */
|
|
17
16
|
searchable?: boolean;
|
|
17
|
+
getPopupContainer?: 'parent' | (() => HTMLElement);
|
|
18
18
|
};
|
|
19
19
|
declare const Select: React.ForwardRefExoticComponent<SelectProps & React.RefAttributes<HTMLDivElement>>;
|
|
20
20
|
export { Select };
|
|
@@ -1,18 +1,39 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useI18n } from '../../i18n';
|
|
2
3
|
import { cn } from '../../lib/utils';
|
|
3
4
|
import { ChevronUp, X } from 'lucide-react';
|
|
4
5
|
import { forwardRef, useCallback, useEffect, useMemo, useRef, useState } from 'react';
|
|
5
|
-
import {
|
|
6
|
-
|
|
6
|
+
import { Button } from '../Button';
|
|
7
|
+
import { Input } from '../Input';
|
|
8
|
+
import { Popup } from '../Popup';
|
|
9
|
+
import { useDropdownPositioning } from '../hooks/useDropdownPositioning';
|
|
10
|
+
import { getSelectDropdownPosition } from './dropdownPositioning';
|
|
11
|
+
const Select = forwardRef(({ options, value: controlledValue, defaultValue, placeholder, onChange, className, disabled, clearable = true, searchable = true, getPopupContainer, }, ref) => {
|
|
12
|
+
const t = useI18n();
|
|
7
13
|
const [isOpen, setIsOpen] = useState(false);
|
|
8
14
|
const [internalValue, setInternalValue] = useState(defaultValue);
|
|
9
15
|
const [isHover, setIsHover] = useState(false);
|
|
10
16
|
const [searchTerm, setSearchTerm] = useState('');
|
|
11
|
-
const
|
|
17
|
+
const rootRef = useRef(null);
|
|
12
18
|
const selectRef = useRef(null);
|
|
13
19
|
const dropdownRef = useRef(null);
|
|
14
20
|
const inputRef = useRef(null);
|
|
15
|
-
|
|
21
|
+
const popupContainerRef = useRef(null);
|
|
22
|
+
const isParentPopupContainer = getPopupContainer === 'parent';
|
|
23
|
+
popupContainerRef.current = isParentPopupContainer ? (rootRef.current?.parentElement ?? null) : null;
|
|
24
|
+
useEffect(() => {
|
|
25
|
+
if (!isParentPopupContainer)
|
|
26
|
+
return;
|
|
27
|
+
const container = rootRef.current?.parentElement;
|
|
28
|
+
popupContainerRef.current = container ?? null;
|
|
29
|
+
if (!container || window.getComputedStyle(container).position !== 'static')
|
|
30
|
+
return;
|
|
31
|
+
const previousPosition = container.style.position;
|
|
32
|
+
container.style.position = 'relative';
|
|
33
|
+
return () => {
|
|
34
|
+
container.style.position = previousPosition;
|
|
35
|
+
};
|
|
36
|
+
}, [isParentPopupContainer]);
|
|
16
37
|
const setRefs = useCallback((node) => {
|
|
17
38
|
selectRef.current = node;
|
|
18
39
|
if (typeof ref === 'function') {
|
|
@@ -24,119 +45,42 @@ const Select = forwardRef(({ options, value: controlledValue, defaultValue, plac
|
|
|
24
45
|
}, [ref]);
|
|
25
46
|
const isControlled = controlledValue !== undefined;
|
|
26
47
|
const value = isControlled ? controlledValue : internalValue;
|
|
27
|
-
// 获取当前选中的选项
|
|
28
48
|
const selectedOption = options.find((opt) => opt.value === value);
|
|
29
49
|
const displayText = selectedOption ? selectedOption.label : placeholder || '';
|
|
30
50
|
const filteredOptions = useMemo(() => {
|
|
31
51
|
if (!searchable || !searchTerm.trim())
|
|
32
52
|
return options;
|
|
33
53
|
const lower = searchTerm.trim().toLowerCase();
|
|
34
|
-
return options.filter((opt) =>
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
if (!isOpen)
|
|
39
|
-
return;
|
|
40
|
-
const handleClickOutside = (event) => {
|
|
41
|
-
// 点击不在 选择部分 以及 下拉部分 关闭下拉
|
|
42
|
-
if (selectRef.current &&
|
|
43
|
-
!selectRef.current.contains(event.target) &&
|
|
44
|
-
dropdownRef.current &&
|
|
45
|
-
!dropdownRef.current.contains(event.target)) {
|
|
46
|
-
setIsOpen(false);
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
document.addEventListener('mousedown', handleClickOutside);
|
|
50
|
-
return () => {
|
|
51
|
-
document.removeEventListener('mousedown', handleClickOutside);
|
|
52
|
-
};
|
|
53
|
-
}, [isOpen]);
|
|
54
|
-
// 键盘关闭
|
|
55
|
-
useEffect(() => {
|
|
56
|
-
const handleKeyDown = (event) => {
|
|
57
|
-
if (event.key === 'Escape' && isOpen) {
|
|
58
|
-
setIsOpen(false);
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
if (isOpen) {
|
|
62
|
-
document.addEventListener('keydown', handleKeyDown);
|
|
63
|
-
}
|
|
64
|
-
return () => {
|
|
65
|
-
document.removeEventListener('keydown', handleKeyDown);
|
|
66
|
-
};
|
|
67
|
-
}, [isOpen]);
|
|
68
|
-
// 计算下拉菜单位置和方向
|
|
69
|
-
const updatePosition = useCallback(() => {
|
|
70
|
-
if (!selectRef.current)
|
|
71
|
-
return;
|
|
72
|
-
const rect = selectRef.current.getBoundingClientRect();
|
|
73
|
-
const scrollX = window.scrollX;
|
|
74
|
-
const scrollY = window.scrollY;
|
|
75
|
-
const viewportHeight = window.innerHeight;
|
|
76
|
-
// 获取实际下拉菜单高度,如果还未渲染则使用估算值
|
|
77
|
-
let dropdownHeight = 240; // 默认最大高度 max-h-60
|
|
78
|
-
if (dropdownRef.current) {
|
|
79
|
-
dropdownHeight = dropdownRef.current.getBoundingClientRect().height;
|
|
80
|
-
}
|
|
81
|
-
else {
|
|
82
|
-
// 估算下拉菜单高度(最大高度为 240px,即 max-h-60)
|
|
83
|
-
dropdownHeight = Math.min(filteredOptions.length * 40 + 8, 240); // 每个选项约40px + padding
|
|
84
|
-
}
|
|
85
|
-
const spaceBelow = viewportHeight - rect.bottom;
|
|
86
|
-
const spaceAbove = rect.top;
|
|
87
|
-
// 决定向上还是向下展开
|
|
88
|
-
const shouldPlaceTop = spaceBelow < dropdownHeight && spaceAbove > spaceBelow;
|
|
89
|
-
// 计算位置
|
|
90
|
-
let top;
|
|
91
|
-
if (shouldPlaceTop) {
|
|
92
|
-
// 向上展开:下拉菜单底部对齐触发器顶部
|
|
93
|
-
top = rect.top + scrollY - dropdownHeight - 4; // 4px 间距
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
96
|
-
// 向下展开:下拉菜单顶部对齐触发器底部
|
|
97
|
-
top = rect.bottom + scrollY + 4; // 4px 间距
|
|
98
|
-
}
|
|
99
|
-
// 确保不超出视口
|
|
100
|
-
if (top < scrollY) {
|
|
101
|
-
top = scrollY + 4;
|
|
102
|
-
}
|
|
103
|
-
if (top + dropdownHeight > scrollY + viewportHeight) {
|
|
104
|
-
top = scrollY + viewportHeight - dropdownHeight - 4;
|
|
105
|
-
}
|
|
106
|
-
setPosition({
|
|
107
|
-
top,
|
|
108
|
-
left: rect.left + scrollX,
|
|
109
|
-
width: rect.width,
|
|
54
|
+
return options.filter((opt) => {
|
|
55
|
+
const searchText = opt.searchText ??
|
|
56
|
+
(typeof opt.label === 'string' || typeof opt.label === 'number' ? String(opt.label) : '');
|
|
57
|
+
return searchText.toLowerCase().includes(lower);
|
|
110
58
|
});
|
|
111
|
-
}, [
|
|
112
|
-
|
|
59
|
+
}, [options, searchTerm, searchable]);
|
|
60
|
+
const positioning = useDropdownPositioning({
|
|
61
|
+
open: isOpen,
|
|
62
|
+
anchorRef: selectRef,
|
|
63
|
+
contentRef: dropdownRef,
|
|
64
|
+
placement: 'bottom-start',
|
|
65
|
+
offset: 4,
|
|
66
|
+
matchAnchorWidth: true,
|
|
67
|
+
strategy: getSelectDropdownPosition,
|
|
68
|
+
estimateSize: () => ({
|
|
69
|
+
height: Math.min(filteredOptions.length * 40 + 8, 240),
|
|
70
|
+
}),
|
|
71
|
+
watchDeps: [filteredOptions.length, searchTerm, searchable],
|
|
72
|
+
containerRef: isParentPopupContainer ? popupContainerRef : undefined,
|
|
73
|
+
positionMode: isParentPopupContainer ? 'absolute' : 'fixed',
|
|
74
|
+
});
|
|
113
75
|
useEffect(() => {
|
|
114
76
|
if (isOpen) {
|
|
115
|
-
// 使用双重 requestAnimationFrame 确保 DOM 已完全渲染
|
|
116
77
|
requestAnimationFrame(() => {
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
inputRef.current?.focus();
|
|
121
|
-
}
|
|
122
|
-
});
|
|
78
|
+
if (searchable) {
|
|
79
|
+
inputRef.current?.focus();
|
|
80
|
+
}
|
|
123
81
|
});
|
|
124
82
|
}
|
|
125
|
-
}, [isOpen, searchable
|
|
126
|
-
// 监听滚动和窗口大小变化,更新位置
|
|
127
|
-
useEffect(() => {
|
|
128
|
-
if (!isOpen)
|
|
129
|
-
return;
|
|
130
|
-
const handleUpdate = () => {
|
|
131
|
-
updatePosition();
|
|
132
|
-
};
|
|
133
|
-
window.addEventListener('scroll', handleUpdate, true);
|
|
134
|
-
window.addEventListener('resize', handleUpdate);
|
|
135
|
-
return () => {
|
|
136
|
-
window.removeEventListener('scroll', handleUpdate, true);
|
|
137
|
-
window.removeEventListener('resize', handleUpdate);
|
|
138
|
-
};
|
|
139
|
-
}, [isOpen, updatePosition]);
|
|
83
|
+
}, [isOpen, searchable]);
|
|
140
84
|
const handleToggle = useCallback(() => {
|
|
141
85
|
if (disabled)
|
|
142
86
|
return;
|
|
@@ -159,22 +103,17 @@ const Select = forwardRef(({ options, value: controlledValue, defaultValue, plac
|
|
|
159
103
|
event.stopPropagation();
|
|
160
104
|
if (disabled)
|
|
161
105
|
return;
|
|
162
|
-
// 清除时 重置内外状态
|
|
163
106
|
setInternalValue(undefined);
|
|
164
107
|
onChange?.(undefined);
|
|
165
108
|
}, [disabled, onChange]);
|
|
166
109
|
const handleSearchChange = useCallback((event) => {
|
|
167
110
|
setSearchTerm(event.target.value);
|
|
168
111
|
}, []);
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
top: `${position.top}px`,
|
|
172
|
-
left: `${position.left}px`,
|
|
173
|
-
width: `${position.width}px`,
|
|
174
|
-
}, children: _jsx("div", { className: "p-1", children: filteredOptions.length > 0 ? (filteredOptions.map((option) => {
|
|
112
|
+
const popupContainer = getPopupContainer === 'parent' ? (rootRef.current?.parentElement ?? undefined) : getPopupContainer?.();
|
|
113
|
+
return (_jsxs("div", { ref: rootRef, className: cn('tc-ui-select relative w-full', className), children: [_jsxs("div", { ref: setRefs, onClick: handleToggle, onMouseEnter: () => setIsHover(true), onMouseLeave: () => setIsHover(false), className: cn('flex w-full items-center justify-between rounded-lg px-4 py-3 text-sm', 'border transition-colors duration-200', 'focus:outline-none', disabled ? 'cursor-not-allowed bg-muted border-border' : 'cursor-pointer bg-background', !disabled && isOpen && 'border-theme', !disabled && !isOpen && 'border-border'), children: [searchable && isOpen ? (_jsx(Input, { ref: inputRef, value: searchTerm, onChange: (_, e) => handleSearchChange(e), onClick: (e) => e.stopPropagation(), placeholder: typeof displayText === 'string' ? displayText : placeholder, className: "min-w-0 flex-1", inputClassName: cn('h-5 min-w-0 flex-1 rounded-none border-0 bg-transparent px-0 py-0 text-left leading-5 outline-none', 'placeholder:text-muted-foreground', disabled && 'text-muted-foreground cursor-not-allowed'), disabled: disabled })) : (_jsx("span", { className: cn('min-h-5 min-w-0 flex-1 text-left truncate leading-5', disabled ? 'text-muted-foreground' : !selectedOption && 'text-muted-foreground'), children: displayText })), clearable && !disabled && value !== undefined && isHover ? (_jsx(Button, { variant: "text", type: "button", onClick: handleClear, className: "ml-2 flex items-center justify-center text-muted-foreground hover:text-foreground cursor-pointer", "aria-label": "Clear selection", title: "Clear", children: _jsx(X, { size: 14 }) })) : (_jsx(ChevronUp, { size: 16, className: cn('ml-2 transition-transform duration-200', isOpen ? 'rotate-0' : 'rotate-180') }))] }), _jsx(Popup, { open: isOpen, anchorRef: selectRef, contentRef: dropdownRef, positioning: positioning, keepMounted: true, onOpenChange: setIsOpen, container: popupContainer, positionMode: isParentPopupContainer ? 'absolute' : 'fixed', className: cn('z-[1000] w-full rounded-lg bg-background shadow-lg', 'border border-border', 'max-h-60 overflow-auto'), children: _jsx("div", { className: cn('w-full', !isOpen && 'hidden'), children: _jsx("div", { className: "p-1", children: filteredOptions.length > 0 ? (filteredOptions.map((option) => {
|
|
175
114
|
const isSelected = option.value === value;
|
|
176
115
|
return (_jsx("div", { onClick: () => handleSelect(option.value), className: cn('px-4 py-2 text-sm cursor-pointer transition-colors rounded-md', 'hover:bg-muted', isSelected && 'bg-muted'), children: option.label }, option.value));
|
|
177
|
-
})) : (_jsx("div", { className: "px-4 py-2 text-sm text-muted-foreground text-center", children:
|
|
116
|
+
})) : (_jsx("div", { className: "px-4 py-2 text-sm text-muted-foreground text-center", children: t('components.select.empty') })) }) }) })] }));
|
|
178
117
|
});
|
|
179
118
|
Select.displayName = 'Select';
|
|
180
119
|
export { Select };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const getSelectDropdownPosition = ({ anchorRect, contentRect, containerRect, viewportHeight, offset, matchAnchorWidth, }) => {
|
|
2
|
+
const dropdownHeight = contentRect?.height ?? 240;
|
|
3
|
+
const spaceBelow = viewportHeight - anchorRect.bottom;
|
|
4
|
+
const spaceAbove = anchorRect.top;
|
|
5
|
+
const shouldPlaceTop = spaceBelow < dropdownHeight && spaceAbove > spaceBelow;
|
|
6
|
+
const containerTop = containerRect?.top ?? 0;
|
|
7
|
+
const containerLeft = containerRect?.left ?? 0;
|
|
8
|
+
return {
|
|
9
|
+
top: (shouldPlaceTop ? anchorRect.top - dropdownHeight - offset : anchorRect.bottom + offset) - containerTop,
|
|
10
|
+
left: anchorRect.left - containerLeft,
|
|
11
|
+
width: matchAnchorWidth ? anchorRect.width : undefined,
|
|
12
|
+
};
|
|
13
|
+
};
|
|
@@ -1,24 +1,9 @@
|
|
|
1
1
|
import type { HTMLAttributes } from 'react';
|
|
2
2
|
export type SkeletonMode = 'pageloading' | 'tableloading' | 'componentsloading';
|
|
3
3
|
export interface SkeletonProps extends HTMLAttributes<HTMLDivElement> {
|
|
4
|
-
/**
|
|
5
|
-
* 骨架屏模式
|
|
6
|
-
* @default 'componentsloading'
|
|
7
|
-
*/
|
|
8
4
|
mode?: SkeletonMode;
|
|
9
|
-
/**
|
|
10
|
-
* 行数(仅对 pageloading 和 tableloading 有效)
|
|
11
|
-
*/
|
|
12
5
|
rows?: number;
|
|
13
|
-
/**
|
|
14
|
-
* 是否显示标题骨架(仅对 pageloading 有效)
|
|
15
|
-
* @default true
|
|
16
|
-
*/
|
|
17
6
|
showTitle?: boolean;
|
|
18
|
-
/**
|
|
19
|
-
* 是否显示操作栏骨架(仅对 pageloading 有效)
|
|
20
|
-
* @default true
|
|
21
|
-
*/
|
|
22
7
|
showActions?: boolean;
|
|
23
8
|
}
|
|
24
9
|
export declare const Skeleton: {
|
|
@@ -7,8 +7,8 @@ const PageLoadingSkeleton = ({ rows = 5, showTitle = true, showActions = true })
|
|
|
7
7
|
return (_jsxs("div", { className: "w-full space-y-6 p-6", children: [showTitle && (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx(SkeletonItem, { className: "h-8 w-48" }), showActions && (_jsxs("div", { className: "flex gap-3", children: [_jsx(SkeletonItem, { className: "h-10 w-24" }), _jsx(SkeletonItem, { className: "h-10 w-24" })] }))] })), _jsxs("div", { className: "flex gap-4", children: [_jsx(SkeletonItem, { className: "h-10 flex-1" }), _jsx(SkeletonItem, { className: "h-10 w-24" }), _jsx(SkeletonItem, { className: "h-10 w-24" })] }), _jsx("div", { className: "space-y-4", children: Array.from({ length: rows }).map((_, index) => (_jsxs("div", { className: "flex gap-4", children: [_jsx(SkeletonItem, { className: "h-20 flex-1" }), _jsx(SkeletonItem, { className: "h-20 w-32" }), _jsx(SkeletonItem, { className: "h-20 w-32" })] }, index))) }), _jsxs("div", { className: "flex items-center justify-between", children: [_jsx(SkeletonItem, { className: "h-4 w-32" }), _jsxs("div", { className: "flex gap-2", children: [_jsx(SkeletonItem, { className: "h-8 w-8" }), _jsx(SkeletonItem, { className: "h-8 w-8" }), _jsx(SkeletonItem, { className: "h-8 w-8" })] })] })] }));
|
|
8
8
|
};
|
|
9
9
|
const TableLoadingSkeleton = ({ rows = 5 }) => {
|
|
10
|
-
const columnCount = 6;
|
|
11
|
-
return (_jsx("div", { className: "w-full", children: _jsx("div", { className: "bg-
|
|
10
|
+
const columnCount = 6;
|
|
11
|
+
return (_jsx("div", { className: "w-full", children: _jsx("div", { className: "bg-background rounded-[20px] overflow-hidden", children: _jsxs(Table, { containerClassName: "rounded-b-none", children: [_jsx(TableHeader, { children: _jsx(TableRow, { children: Array.from({ length: columnCount }).map((_, index) => (_jsx(TableHead, { children: _jsx(SkeletonText, { width: index === 0 ? 120 : index === columnCount - 1 ? 80 : 150 }) }, index))) }) }), _jsx(TableBody, { children: Array.from({ length: rows }).map((_, rowIndex) => (_jsx(TableRow, { children: Array.from({ length: columnCount }).map((_, colIndex) => (_jsx(TableCell, { children: colIndex === columnCount - 1 ? (_jsxs("div", { className: "flex gap-2", children: [_jsx(SkeletonItem, { className: "h-8 w-16" }), _jsx(SkeletonItem, { className: "h-8 w-16" })] })) : (_jsx(SkeletonText, { width: colIndex === 0 ? 120 : colIndex === 1 ? '80%' : 150 })) }, colIndex))) }, rowIndex))) })] }) }) }));
|
|
12
12
|
};
|
|
13
13
|
const ComponentsLoadingSkeleton = ({ rows = 3 }) => {
|
|
14
14
|
return (_jsx("div", { className: "w-full space-y-3", children: Array.from({ length: rows }).map((_, index) => (_jsx(SkeletonItem, { className: "h-4 w-full" }, index))) }));
|
|
@@ -26,6 +26,6 @@ export const Skeleton = ({ mode = 'componentsloading', className, rows, showTitl
|
|
|
26
26
|
return _jsx(ComponentsLoadingSkeleton, { rows: rows });
|
|
27
27
|
}
|
|
28
28
|
};
|
|
29
|
-
return (_jsx("div", { className: cn('w-full', className), ...props, children: renderSkeleton() }));
|
|
29
|
+
return (_jsx("div", { className: cn('tc-ui-skeleton w-full', className), ...props, children: renderSkeleton() }));
|
|
30
30
|
};
|
|
31
31
|
Skeleton.displayName = 'Skeleton';
|
|
@@ -14,7 +14,9 @@ const Switch = forwardRef(({ checked: controlledChecked, defaultChecked, onChang
|
|
|
14
14
|
}
|
|
15
15
|
onChange?.(newChecked);
|
|
16
16
|
};
|
|
17
|
-
return (_jsx("button", { ref: ref, type: "button", role: "switch", "aria-checked": checked, disabled: disabled, onClick: handleToggle, className: cn('relative inline-flex h-6 w-11 items-center rounded-full transition-colors duration-200', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-offset-2', disabled && 'cursor-not-allowed opacity-50', !disabled && 'cursor-pointer', checked
|
|
17
|
+
return (_jsx("button", { ref: ref, type: "button", role: "switch", "aria-checked": checked, disabled: disabled, onClick: handleToggle, className: cn('tc-ui-switch relative inline-flex h-6 w-11 items-center rounded-full transition-colors duration-200', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-offset-2', disabled && 'cursor-not-allowed opacity-50', !disabled && 'cursor-pointer', checked
|
|
18
|
+
? 'bg-[hsl(var(--ring))] dark:bg-[hsl(var(--ring))]'
|
|
19
|
+
: 'bg-muted dark:bg-muted', className), children: _jsx("span", { className: cn('inline-block h-4 w-4 transform rounded-full bg-background transition-transform duration-200', checked ? 'translate-x-6' : 'translate-x-1') }) }));
|
|
18
20
|
});
|
|
19
21
|
Switch.displayName = 'Switch';
|
|
20
22
|
export { Switch };
|
|
@@ -2,64 +2,28 @@ import { ExportType } from '../../lib/export';
|
|
|
2
2
|
import type { MOmit } from '../../types';
|
|
3
3
|
import { type ReactNode } from 'react';
|
|
4
4
|
import { type DropdownItem } from '../Dropdown';
|
|
5
|
-
import type {
|
|
5
|
+
import type { FormFieldSchema } from '../Form';
|
|
6
6
|
import type { SearchProps } from '../Search/Search';
|
|
7
|
-
type
|
|
8
|
-
/**
|
|
9
|
-
* - 字段是否常驻
|
|
10
|
-
* - 如果都没有则去前四个
|
|
11
|
-
*/
|
|
7
|
+
export type TableSearchSchema<T> = MOmit<FormFieldSchema<T>, 'rules' | 'required'> & {
|
|
12
8
|
isPermanent?: boolean;
|
|
13
9
|
};
|
|
14
|
-
type TableSearchProps<T> = MOmit<SearchProps<T>, 'children' | '
|
|
10
|
+
type TableSearchProps<T> = MOmit<SearchProps<T>, 'children' | 'schemas'> & {
|
|
15
11
|
onSearch?: (values: T) => void;
|
|
16
12
|
onReset?: () => void;
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
* 导出Excel按钮的下拉菜单项
|
|
20
|
-
*/
|
|
13
|
+
renderActionBtnArea?: () => ReactNode;
|
|
14
|
+
schemas: TableSearchSchema<T>[];
|
|
21
15
|
exportMenuItems?: DropdownItem[];
|
|
22
16
|
btnConfig?: Partial<{
|
|
23
|
-
/**
|
|
24
|
-
* 导出Excel按钮的文案
|
|
25
|
-
*/
|
|
26
17
|
export?: ReactNode;
|
|
27
|
-
/**
|
|
28
|
-
* 收起按钮的文案
|
|
29
|
-
*/
|
|
30
18
|
collapse?: ReactNode;
|
|
31
|
-
/**
|
|
32
|
-
* 展开按钮的icon
|
|
33
|
-
*/
|
|
34
19
|
expandIcon?: ReactNode;
|
|
35
|
-
/**
|
|
36
|
-
* 展开按钮的文案
|
|
37
|
-
*/
|
|
38
20
|
expand?: ReactNode;
|
|
39
|
-
/**
|
|
40
|
-
* 重置按钮的文案
|
|
41
|
-
*/
|
|
42
21
|
reset?: ReactNode;
|
|
43
|
-
/**
|
|
44
|
-
* 查询按钮的文案
|
|
45
|
-
*/
|
|
46
22
|
search?: ReactNode;
|
|
47
23
|
}>;
|
|
48
|
-
/**
|
|
49
|
-
* 备选边界
|
|
50
|
-
*/
|
|
51
24
|
expandBoundaries?: number;
|
|
52
|
-
/**
|
|
53
|
-
*
|
|
54
|
-
* @param exportType 导出类型
|
|
55
|
-
* @param searchData 当前查询条件
|
|
56
|
-
* @returns
|
|
57
|
-
*/
|
|
58
25
|
onExport?: (exportType: ExportType, searchData: T) => void;
|
|
59
26
|
additionalButtons?: ReactNode;
|
|
60
|
-
/**
|
|
61
|
-
* 默认是否展开 @default true
|
|
62
|
-
*/
|
|
63
27
|
defaultExpand?: boolean;
|
|
64
28
|
};
|
|
65
29
|
declare const TableSearch: <T extends object>(props: TableSearchProps<T>) => import("react/jsx-runtime").JSX.Element;
|