@_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,20 +1,11 @@
|
|
|
1
|
+
import { defaultEnglishResources, defaultLanguageResources } from '../../../../common/i18n';
|
|
2
|
+
const tableSearchDefaultLocale = defaultLanguageResources.components.tableSearch;
|
|
3
|
+
const tableSearchDefaultEnglishLocale = defaultEnglishResources.components.tableSearch;
|
|
1
4
|
export const zhCNLocale = {
|
|
2
|
-
|
|
3
|
-
search: '查询',
|
|
4
|
-
export: '导出Excel',
|
|
5
|
-
expand: '展开',
|
|
6
|
-
collapse: '收起',
|
|
7
|
-
exportCurrentPage: '当前页',
|
|
8
|
-
exportCurrentQuery: '当前查询条件',
|
|
5
|
+
...tableSearchDefaultLocale,
|
|
9
6
|
};
|
|
10
7
|
export const enUSLocale = {
|
|
11
|
-
|
|
12
|
-
search: 'Search',
|
|
13
|
-
export: 'Export Excel',
|
|
14
|
-
expand: 'Expand',
|
|
15
|
-
collapse: 'Collapse',
|
|
16
|
-
exportCurrentPage: 'Current Page',
|
|
17
|
-
exportCurrentQuery: 'Current Filters',
|
|
8
|
+
...tableSearchDefaultEnglishLocale,
|
|
18
9
|
};
|
|
19
10
|
export const defaultLocale = zhCNLocale;
|
|
20
11
|
export const btnConfig = defaultLocale;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { ChangeEvent, TextareaHTMLAttributes } from
|
|
2
|
-
export type TextareaProps = Omit<TextareaHTMLAttributes<HTMLTextAreaElement>,
|
|
1
|
+
import type { ChangeEvent, TextareaHTMLAttributes } from "react";
|
|
2
|
+
export type TextareaProps = Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, "value" | "onChange" | "defaultValue"> & {
|
|
3
3
|
value?: string;
|
|
4
4
|
/**
|
|
5
5
|
*
|
|
@@ -26,8 +26,12 @@ export type TextareaProps = Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'v
|
|
|
26
26
|
* 占位符文本
|
|
27
27
|
*/
|
|
28
28
|
placeholder?: string;
|
|
29
|
+
/**
|
|
30
|
+
* 原生 textarea 节点的自定义 className
|
|
31
|
+
*/
|
|
32
|
+
textareaClassName?: string;
|
|
29
33
|
};
|
|
30
|
-
declare const Textarea: import("react").ForwardRefExoticComponent<Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, "
|
|
34
|
+
declare const Textarea: import("react").ForwardRefExoticComponent<Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, "value" | "defaultValue" | "onChange"> & {
|
|
31
35
|
value?: string;
|
|
32
36
|
/**
|
|
33
37
|
*
|
|
@@ -54,6 +58,10 @@ declare const Textarea: import("react").ForwardRefExoticComponent<Omit<TextareaH
|
|
|
54
58
|
* 占位符文本
|
|
55
59
|
*/
|
|
56
60
|
placeholder?: string;
|
|
61
|
+
/**
|
|
62
|
+
* 原生 textarea 节点的自定义 className
|
|
63
|
+
*/
|
|
64
|
+
textareaClassName?: string;
|
|
57
65
|
} & import("react").RefAttributes<HTMLTextAreaElement>>;
|
|
58
66
|
export { Textarea };
|
|
59
67
|
//# sourceMappingURL=Textarea.d.ts.map
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "../../lib/utils";
|
|
3
|
+
import { forwardRef, useCallback } from "react";
|
|
4
|
+
import { useInputController } from "../hooks/useInputController";
|
|
5
|
+
const Textarea = forwardRef(({ className, textareaClassName, value: controlledValue, onChange, defaultValue, maxLength = 500, showCount = true, placeholder, disabled, ...props }, ref) => {
|
|
6
|
+
const { isFocused, setIsFocused, setInternalValue, setRefs, value, hasValue, isControlledRef, currentLength, } = useInputController({
|
|
7
|
+
controlledValue,
|
|
8
|
+
defaultValue,
|
|
9
|
+
ref,
|
|
10
|
+
});
|
|
11
|
+
const handleChange = useCallback((e) => {
|
|
12
|
+
const newValue = e.target.value;
|
|
13
|
+
// 如果设置了 maxLength,限制输入长度
|
|
14
|
+
if (maxLength && newValue.length > maxLength) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (!isControlledRef.current) {
|
|
18
|
+
setInternalValue(newValue);
|
|
19
|
+
}
|
|
20
|
+
onChange?.(newValue, e);
|
|
21
|
+
}, [maxLength, isControlledRef, onChange, setInternalValue]);
|
|
22
|
+
return (_jsxs("div", { className: cn("tc-ui-textarea relative w-fit", className), children: [_jsx("textarea", { ref: setRefs, value: value, onChange: handleChange, maxLength: maxLength, placeholder: placeholder, className: cn("flex w-full rounded-lg px-4 py-3 text-sm", "border transition-colors duration-200", "placeholder:text-muted-foreground", "focus:outline-none", "resize-none", showCount && "pb-10", disabled
|
|
23
|
+
? "cursor-not-allowed bg-muted border-border text-muted-foreground"
|
|
24
|
+
: "bg-background", !disabled && !hasValue && !isFocused && "border-border", !disabled && (hasValue || isFocused) && "border-foreground", textareaClassName), onFocus: (e) => {
|
|
25
|
+
if (!disabled) {
|
|
26
|
+
setIsFocused(true);
|
|
27
|
+
props.onFocus?.(e);
|
|
28
|
+
}
|
|
29
|
+
}, onBlur: (e) => {
|
|
30
|
+
if (!disabled) {
|
|
31
|
+
setIsFocused(false);
|
|
32
|
+
props.onBlur?.(e);
|
|
33
|
+
}
|
|
34
|
+
}, disabled: disabled, ...props }), showCount && (_jsxs("div", { className: cn('text-end', "text-xs text-muted-foreground", "pointer-events-none"), children: [currentLength, "/", maxLength] }))] }));
|
|
35
|
+
});
|
|
36
|
+
Textarea.displayName = "Textarea";
|
|
37
|
+
export { Textarea };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Textarea';
|
|
@@ -11,7 +11,7 @@ export interface TooltipProps {
|
|
|
11
11
|
* 提示位置
|
|
12
12
|
* @default 'right'
|
|
13
13
|
*/
|
|
14
|
-
placement?:
|
|
14
|
+
placement?: "top" | "bottom" | "left" | "right";
|
|
15
15
|
/**
|
|
16
16
|
* 是否显示
|
|
17
17
|
*/
|
|
@@ -21,5 +21,5 @@ export interface TooltipProps {
|
|
|
21
21
|
*/
|
|
22
22
|
className?: string;
|
|
23
23
|
}
|
|
24
|
-
export declare function Tooltip({ content, children, placement, visible, className }: TooltipProps): import("react/jsx-runtime").JSX.Element;
|
|
24
|
+
export declare function Tooltip({ content, children, placement, visible, className, }: TooltipProps): import("react/jsx-runtime").JSX.Element;
|
|
25
25
|
//# sourceMappingURL=Tooltip.d.ts.map
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "../../lib/utils";
|
|
3
|
+
import { useState, useRef, useEffect } from "react";
|
|
4
|
+
import { createPortal } from "react-dom";
|
|
5
|
+
export function Tooltip({ content, children, placement = "right", visible, className, }) {
|
|
6
|
+
const [isVisible, setIsVisible] = useState(false);
|
|
7
|
+
const [position, setPosition] = useState({ top: 0, left: 0 });
|
|
8
|
+
const triggerRef = useRef(null);
|
|
9
|
+
const tooltipRef = useRef(null);
|
|
10
|
+
const showTooltip = () => {
|
|
11
|
+
if (visible !== undefined) {
|
|
12
|
+
setIsVisible(visible);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
setIsVisible(true);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
const hideTooltip = () => {
|
|
19
|
+
if (visible === undefined) {
|
|
20
|
+
setIsVisible(false);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (visible !== undefined) {
|
|
25
|
+
setIsVisible(visible);
|
|
26
|
+
}
|
|
27
|
+
}, [visible]);
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
// 显示时
|
|
30
|
+
if (isVisible && triggerRef.current && tooltipRef.current) {
|
|
31
|
+
// 使用 requestAnimationFrame 确保 DOM 已更新
|
|
32
|
+
requestAnimationFrame(() => {
|
|
33
|
+
if (!triggerRef.current || !tooltipRef.current)
|
|
34
|
+
return;
|
|
35
|
+
const triggerRect = triggerRef.current.getBoundingClientRect();
|
|
36
|
+
const tooltipRect = tooltipRef.current.getBoundingClientRect();
|
|
37
|
+
// const scrollY = window.scrollY;
|
|
38
|
+
// const scrollX = window.scrollX;
|
|
39
|
+
// const viewportWidth = window.innerWidth;
|
|
40
|
+
// const viewportHeight = window.innerHeight;
|
|
41
|
+
const padding = 8;
|
|
42
|
+
let top = 0;
|
|
43
|
+
let left = 0;
|
|
44
|
+
switch (placement) {
|
|
45
|
+
case "top":
|
|
46
|
+
top = triggerRect.top - tooltipRect.height - padding;
|
|
47
|
+
left =
|
|
48
|
+
triggerRect.left + triggerRect.width / 2 - tooltipRect.width / 2;
|
|
49
|
+
break;
|
|
50
|
+
case "bottom":
|
|
51
|
+
top = triggerRect.bottom + padding;
|
|
52
|
+
left =
|
|
53
|
+
triggerRect.left + triggerRect.width / 2 - tooltipRect.width / 2;
|
|
54
|
+
break;
|
|
55
|
+
case "left":
|
|
56
|
+
top = triggerRect.top;
|
|
57
|
+
left = triggerRect.left - tooltipRect.width - padding;
|
|
58
|
+
break;
|
|
59
|
+
case "right":
|
|
60
|
+
// 直接使用元素所在元素
|
|
61
|
+
top = triggerRect.top;
|
|
62
|
+
left = triggerRect.right + padding;
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
setPosition({ top, left });
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
// 隐藏时 重置定位定制 去除重影
|
|
69
|
+
if (!isVisible) {
|
|
70
|
+
const top = -100, left = -100;
|
|
71
|
+
setPosition({ top, left });
|
|
72
|
+
}
|
|
73
|
+
}, [isVisible, placement]);
|
|
74
|
+
return (_jsxs(_Fragment, { children: [_jsx("div", { ref: triggerRef, onMouseEnter: showTooltip, onMouseLeave: hideTooltip, className: "tc-ui-tooltip inline-block", children: children }), isVisible &&
|
|
75
|
+
createPortal(_jsx("div", { ref: tooltipRef, className: cn("fixed z-[9999] px-3 py-2", "bg-gray-800 text-white text-xs rounded", "shadow-lg", "pointer-events-none", "max-w-xs", className), style: {
|
|
76
|
+
top: `${position.top}px`,
|
|
77
|
+
left: `${position.left}px`,
|
|
78
|
+
}, children: content }), document.body)] }));
|
|
79
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Tooltip';
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { cn } from '
|
|
3
|
-
import {
|
|
2
|
+
import { cn } from '../../lib/utils';
|
|
3
|
+
import { ChevronDown, ChevronRight } from 'lucide-react';
|
|
4
4
|
import { useCallback, useMemo, useState } from 'react';
|
|
5
|
+
import { Button } from '../Button';
|
|
6
|
+
import { Checkbox } from '../Checkbox';
|
|
5
7
|
export function TreeSelect({ data, value = [], onChange, labelField = 'name', checkable = true, className, }) {
|
|
6
8
|
const [expandedKeys, setExpandedKeys] = useState(new Set());
|
|
7
9
|
const { nodeMap, parentMap } = useMemo(() => {
|
|
@@ -135,17 +137,13 @@ export function TreeSelect({ data, value = [], onChange, labelField = 'name', ch
|
|
|
135
137
|
const isExpanded = expandedKeys.has(node.id);
|
|
136
138
|
const isChecked = isNodeChecked(node.id);
|
|
137
139
|
const isIndeterminate = isNodeIndeterminate(node);
|
|
138
|
-
return (_jsxs("div", { children: [_jsxs("div", { className: cn('flex items-center gap-2 py-2 px-2 hover:bg-muted/50 rounded-md cursor-pointer transition-colors', 'group'), style: { paddingLeft: `${level * 20 + 8}px` }, children: [hasChildren ? (_jsx("
|
|
140
|
+
return (_jsxs("div", { children: [_jsxs("div", { className: cn('flex items-center gap-2 py-2 px-2 hover:bg-muted/50 rounded-md cursor-pointer transition-colors', 'group'), style: { paddingLeft: `${level * 20 + 8}px` }, children: [hasChildren ? (_jsx(Button, { variant: "text", type: "button", onClick: (e) => {
|
|
139
141
|
e.stopPropagation();
|
|
140
142
|
toggleExpand(node.id);
|
|
141
|
-
}, className: "flex-shrink-0 p-0.5 hover:bg-muted rounded", children: isExpanded ? _jsx(ChevronDown, { className: "h-4 w-4" }) : _jsx(ChevronRight, { className: "h-4 w-4" }) })) : (_jsx("span", { className: "w-5" })), checkable && (_jsx(
|
|
143
|
+
}, className: "flex-shrink-0 p-0.5 hover:bg-muted rounded", children: isExpanded ? _jsx(ChevronDown, { className: "h-4 w-4" }) : _jsx(ChevronRight, { className: "h-4 w-4" }) })) : (_jsx("span", { className: "w-5" })), checkable && (_jsx(Checkbox, { className: "flex-shrink-0", checked: isChecked, indeterminate: isIndeterminate, "aria-label": `Select ${node.name}`, onChange: (_, e) => {
|
|
142
144
|
e.stopPropagation();
|
|
143
145
|
toggleCheck(node);
|
|
144
|
-
}, className:
|
|
145
|
-
? 'bg-black border-black'
|
|
146
|
-
: isIndeterminate
|
|
147
|
-
? 'bg-gray-400 border-gray-400'
|
|
148
|
-
: 'border-border hover:border-foreground'), children: (isChecked || isIndeterminate) && _jsx(Check, { className: "h-3 w-3 text-white", strokeWidth: 3 }) })), _jsx("span", { className: "flex-1 text-sm select-none", onClick: () => {
|
|
146
|
+
} })), _jsx("span", { className: "flex-1 text-sm select-none", onClick: () => {
|
|
149
147
|
if (hasChildren) {
|
|
150
148
|
toggleExpand(node.id);
|
|
151
149
|
}
|
|
@@ -156,7 +154,7 @@ export function TreeSelect({ data, value = [], onChange, labelField = 'name', ch
|
|
|
156
154
|
}
|
|
157
155
|
// 如果没有数据
|
|
158
156
|
if (!data || data.length === 0) {
|
|
159
|
-
return _jsx("div", { className: cn('p-8 text-center text-sm text-muted-foreground', className), children: "No data" });
|
|
157
|
+
return _jsx("div", { className: cn('tc-ui-tree-select p-8 text-center text-sm text-muted-foreground', className), children: "No data" });
|
|
160
158
|
}
|
|
161
|
-
return (_jsx("div", { className: cn('border border-border rounded-lg p-2 max-h-[400px] overflow-y-auto', className), children: data.map((node) => renderTreeNode(node)) }));
|
|
159
|
+
return (_jsx("div", { className: cn('tc-ui-tree-select border border-border rounded-lg p-2 max-h-[400px] overflow-y-auto', className), children: data.map((node) => renderTreeNode(node)) }));
|
|
162
160
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './TreeSelect';
|
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useI18n } from '../../i18n';
|
|
2
3
|
import { Camera, X } from 'lucide-react';
|
|
3
4
|
import { useEffect, useMemo, useRef, useState } from 'react';
|
|
5
|
+
import { Button } from '../Button';
|
|
4
6
|
import { FileUpload } from './Upload';
|
|
5
7
|
export function ImageUpload({ accept = '.jpg,.png', maxCount = 1, value, onChange, beforeChange }) {
|
|
8
|
+
const t = useI18n();
|
|
6
9
|
const inputRef = useRef(null);
|
|
7
10
|
const [internalUrls, setInternalUrls] = useState([]);
|
|
11
|
+
const internalUrlsRef = useRef([]);
|
|
8
12
|
const urls = value ?? internalUrls;
|
|
9
13
|
const setUrls = onChange ?? setInternalUrls;
|
|
10
14
|
const mAccept = useMemo(() => {
|
|
@@ -49,15 +53,23 @@ export function ImageUpload({ accept = '.jpg,.png', maxCount = 1, value, onChang
|
|
|
49
53
|
URL.revokeObjectURL(urlToRemove);
|
|
50
54
|
setUrls(urls.filter((_, i) => i !== index));
|
|
51
55
|
};
|
|
56
|
+
useEffect(() => {
|
|
57
|
+
if (onChange) {
|
|
58
|
+
internalUrlsRef.current = [];
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
const removedUrls = internalUrlsRef.current.filter((url) => !internalUrls.includes(url));
|
|
62
|
+
removedUrls.forEach((url) => URL.revokeObjectURL(url));
|
|
63
|
+
internalUrlsRef.current = internalUrls;
|
|
64
|
+
}, [onChange, internalUrls]);
|
|
52
65
|
useEffect(() => {
|
|
53
66
|
return () => {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
}
|
|
67
|
+
internalUrlsRef.current.forEach((url) => URL.revokeObjectURL(url));
|
|
68
|
+
internalUrlsRef.current = [];
|
|
57
69
|
};
|
|
58
|
-
}, [
|
|
59
|
-
return (_jsxs("div", { className: "flex flex-wrap gap-3", children: [urls.map((url, index) => (_jsxs("div", { className: "relative w-24 h-24 rounded-lg overflow-hidden border border-gray-200 group cursor-pointer", children: [_jsx("img", { src: url, alt: "", className: "w-full h-full object-cover" }), _jsx("div", { className: "absolute inset-0 bg-black/0 group-hover:bg-black/40 transition-colors flex items-center justify-center", children: _jsx("
|
|
70
|
+
}, []);
|
|
71
|
+
return (_jsxs("div", { className: "tc-ui-image-upload flex flex-wrap gap-3", children: [urls.map((url, index) => (_jsxs("div", { className: "relative w-24 h-24 rounded-lg overflow-hidden border border-gray-200 group cursor-pointer", children: [_jsx("img", { src: url, alt: "", className: "w-full h-full object-cover" }), _jsx("div", { className: "absolute inset-0 bg-black/0 group-hover:bg-black/40 transition-colors flex items-center justify-center", children: _jsx(Button, { variant: "text", type: "button", onClick: (e) => {
|
|
60
72
|
e.stopPropagation();
|
|
61
73
|
handleRemove(index);
|
|
62
|
-
}, className: "opacity-0 group-hover:opacity-100 transition-opacity p-1.5 rounded-full bg-red-500 hover:bg-red-600 text-white", "aria-label":
|
|
74
|
+
}, className: "opacity-0 group-hover:opacity-100 transition-opacity p-1.5 rounded-full bg-red-500 hover:bg-red-600 text-white", "aria-label": t('components.upload.deleteImage'), title: t('components.upload.deleteImage'), children: _jsx(X, { size: 16 }) }) })] }, index))), urls.length < maxCount && (_jsx(FileUpload, { inputRef: inputRef, accept: mAccept, multiple: maxCount > 1, onChange: handleFileChange, labelClassName: "w-24 h-24 p-0 border-0 cursor-pointer", selectLabel: _jsxs("div", { className: "w-full h-full rounded-[8px] bg-[#F5F5F5] border border-gray-200 flex flex-col items-center justify-center gap-1 hover:bg-gray-50 transition-colors", children: [_jsx(Camera, { className: "text-gray-500", size: 24 }), _jsx("span", { className: "text-xs text-gray-500", children: t('components.upload.upload') })] }) }))] }));
|
|
63
75
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { Button } from '../Button';
|
|
3
|
+
import { Input } from '../Input';
|
|
3
4
|
export function FileUpload({ inputRef, accept = '*', multiple, onChange, selectLabel, labelClassName, showClear, onClear, clearLabel, }) {
|
|
4
|
-
return (_jsxs("div", { className: "flex items-center gap-3", children: [_jsxs("label", { className: labelClassName ?? 'flex items-center gap-2 px-4 py-2 border rounded-lg cursor-pointer bg-
|
|
5
|
+
return (_jsxs("div", { className: "tc-ui-file-upload flex items-center gap-3", children: [_jsxs("label", { className: labelClassName ?? 'flex items-center gap-2 px-4 py-2 border rounded-lg cursor-pointer bg-background', children: [_jsx(Input, { ref: inputRef, type: "file", accept: accept, multiple: multiple, className: "hidden", onChange: (_, e) => onChange?.(e) }), selectLabel] }), showClear && onClear && (_jsx(Button, { size: "sm", variant: "link", onClick: onClear, children: clearLabel }))] }));
|
|
5
6
|
}
|
|
@@ -1,33 +1,36 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
2
|
+
import { useI18n } from '../../i18n';
|
|
3
|
+
import { useBreadcrumb } from '../../hooks/useBreadcrumb';
|
|
4
|
+
import { useLanguage } from '../../hooks/useLanguage';
|
|
5
|
+
import { cn } from '../../lib/utils';
|
|
5
6
|
// import useUserStore from '@tc/ui-react/stores/user'
|
|
6
7
|
import { ChevronRight, MoreHorizontal } from 'lucide-react';
|
|
7
8
|
import { forwardRef } from 'react';
|
|
8
9
|
import { useNavigate } from 'react-router-dom';
|
|
9
|
-
|
|
10
|
+
import { Button } from '../Button';
|
|
11
|
+
const Breadcrumb = forwardRef(({ className, ...props }, ref) => _jsx("nav", { ref: ref, "aria-label": "breadcrumb", className: cn('tc-ui-breadcrumb', className), ...props }));
|
|
10
12
|
Breadcrumb.displayName = 'Breadcrumb';
|
|
11
|
-
const BreadcrumbList = forwardRef(({ className, ...props }, ref) => (_jsx("ol", { ref: ref, className: cn('flex items-center gap-3 flex-wrap', className), ...props })));
|
|
13
|
+
const BreadcrumbList = forwardRef(({ className, ...props }, ref) => (_jsx("ol", { ref: ref, className: cn('tc-ui-breadcrumb-list flex items-center gap-3 flex-wrap', className), ...props })));
|
|
12
14
|
BreadcrumbList.displayName = 'BreadcrumbList';
|
|
13
|
-
const BreadcrumbItem = forwardRef(({ className, ...props }, ref) => _jsx("li", { ref: ref, className: cn('inline-flex items-center', className), ...props }));
|
|
15
|
+
const BreadcrumbItem = forwardRef(({ className, ...props }, ref) => _jsx("li", { ref: ref, className: cn('tc-ui-breadcrumb-item inline-flex items-center', className), ...props }));
|
|
14
16
|
BreadcrumbItem.displayName = 'BreadcrumbItem';
|
|
15
17
|
const BreadcrumbLink = forwardRef(({ className, ...props }, ref) => {
|
|
16
|
-
return _jsx("a", { ref: ref, className: cn('transition-colors hover:text-foreground', className), ...props });
|
|
18
|
+
return _jsx("a", { ref: ref, className: cn('tc-ui-breadcrumb-link transition-colors hover:text-foreground', className), ...props });
|
|
17
19
|
});
|
|
18
20
|
BreadcrumbLink.displayName = 'BreadcrumbLink';
|
|
19
21
|
const BreadcrumbPage = forwardRef(({ className, active, onClose, closable = true, children, ...props }, ref) => {
|
|
20
|
-
|
|
22
|
+
const t = useI18n();
|
|
23
|
+
return (_jsxs("span", { ref: ref, role: "link", "aria-disabled": "true", "aria-current": "page", className: cn('tc-ui-breadcrumb-page inline-flex items-center gap-2 px-4 py-2 rounded-lg border transition-all duration-200 text-sm', active
|
|
21
24
|
? 'bg-breadcrumb-active-bg text-breadcrumb-active-text border-breadcrumb-active-bg shadow-sm'
|
|
22
|
-
: 'bg-
|
|
25
|
+
: 'bg-background text-breadcrumb-text border-breadcrumb-border hover:border-gray-400', className), ...props, children: [_jsx("span", { className: "font-normal", children: children }), onClose && closable && (_jsx(Button, { variant: "text", type: "button", onClick: (e) => {
|
|
23
26
|
e.stopPropagation();
|
|
24
27
|
onClose();
|
|
25
|
-
}, className: "inline-flex items-center justify-center hover:opacity-70 transition-opacity", "aria-label":
|
|
28
|
+
}, className: "inline-flex items-center justify-center hover:opacity-70 transition-opacity", "aria-label": t('components.breadcrumb.close'), children: _jsxs("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [_jsxs("g", { clipPath: "url(#clip0_228_519)", children: [_jsx("circle", { cx: "8", cy: "8", r: "6.66667", stroke: "currentColor", strokeWidth: "1" }), _jsx("path", { d: "M9.66669 6.33302L6.33337 9.66634M6.33336 6.33301L9.66668 9.66633", stroke: "currentColor", strokeWidth: "1", strokeLinecap: "round" })] }), _jsx("defs", { children: _jsx("clipPath", { id: "clip0_228_519", children: _jsx("rect", { width: "16", height: "16", fill: "white" }) }) })] }) }))] }));
|
|
26
29
|
});
|
|
27
30
|
BreadcrumbPage.displayName = 'BreadcrumbPage';
|
|
28
|
-
const BreadcrumbSeparator = ({ children, className, ...props }) => (_jsx("li", { role: "presentation", "aria-hidden": "true", className: cn('[&>svg]:size-3.5', className), ...props, children: children ?? _jsx(ChevronRight, {}) }));
|
|
31
|
+
const BreadcrumbSeparator = ({ children, className, ...props }) => (_jsx("li", { role: "presentation", "aria-hidden": "true", className: cn('tc-ui-breadcrumb-separator [&>svg]:size-3.5', className), ...props, children: children ?? _jsx(ChevronRight, {}) }));
|
|
29
32
|
BreadcrumbSeparator.displayName = 'BreadcrumbSeparator';
|
|
30
|
-
const BreadcrumbEllipsis = ({ className, ...props }) => (_jsxs("span", { role: "presentation", "aria-hidden": "true", "aria-label": "More", className: cn('flex h-9 w-9 items-center justify-center', className), ...props, children: [_jsx(MoreHorizontal, { className: "h-4 w-4" }), _jsx("span", { className: "sr-only", children: "More" })] }));
|
|
33
|
+
const BreadcrumbEllipsis = ({ className, ...props }) => (_jsxs("span", { role: "presentation", "aria-hidden": "true", "aria-label": "More", className: cn('tc-ui-breadcrumb-ellipsis flex h-9 w-9 items-center justify-center', className), ...props, children: [_jsx(MoreHorizontal, { className: "h-4 w-4" }), _jsx("span", { className: "sr-only", children: "More" })] }));
|
|
31
34
|
BreadcrumbEllipsis.displayName = 'BreadcrumbEllipsis';
|
|
32
35
|
export { Breadcrumb, BreadcrumbEllipsis, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, };
|
|
33
36
|
export function SimpleBreadcrumb({ className }) {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './breadcrumb';
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { RefObject } from "react";
|
|
2
|
+
export type DropdownPlacement = "bottom-end" | "bottom-start" | "left-start" | "top-end" | "top-start" | "right-start" | "right-end";
|
|
3
|
+
export type DropdownPosition = {
|
|
4
|
+
top: number;
|
|
5
|
+
left?: number;
|
|
6
|
+
right?: number;
|
|
7
|
+
width?: number;
|
|
8
|
+
};
|
|
9
|
+
export type DropdownPositioningContext = {
|
|
10
|
+
anchorRect: DOMRect;
|
|
11
|
+
contentRect?: DOMRect;
|
|
12
|
+
containerRect?: DOMRect;
|
|
13
|
+
viewportWidth: number;
|
|
14
|
+
viewportHeight: number;
|
|
15
|
+
placement: DropdownPlacement;
|
|
16
|
+
offset: number;
|
|
17
|
+
matchAnchorWidth: boolean;
|
|
18
|
+
};
|
|
19
|
+
export type DropdownPositioningStrategy = (context: DropdownPositioningContext) => DropdownPosition;
|
|
20
|
+
export type UseDropdownPositioningOptions = {
|
|
21
|
+
open: boolean;
|
|
22
|
+
anchorRef: RefObject<HTMLElement | null>;
|
|
23
|
+
contentRef: RefObject<HTMLElement | null>;
|
|
24
|
+
placement?: DropdownPlacement;
|
|
25
|
+
offset?: number;
|
|
26
|
+
matchAnchorWidth?: boolean;
|
|
27
|
+
strategy?: DropdownPositioningStrategy;
|
|
28
|
+
estimateSize?: () => {
|
|
29
|
+
width?: number;
|
|
30
|
+
height?: number;
|
|
31
|
+
};
|
|
32
|
+
watchDeps?: readonly unknown[];
|
|
33
|
+
containerRef?: RefObject<HTMLElement | null>;
|
|
34
|
+
positionMode?: "fixed" | "absolute";
|
|
35
|
+
};
|
|
36
|
+
export type UseDropdownPositioningResult = {
|
|
37
|
+
position: DropdownPosition;
|
|
38
|
+
ready: boolean;
|
|
39
|
+
updatePosition: () => void;
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* 计算弹窗该放在哪。
|
|
43
|
+
*
|
|
44
|
+
* right/left:跟触发元素顶部对齐,往右或往左弹。
|
|
45
|
+
* bottom/top:放在触发元素下方或上方,再按 start/end 对齐。
|
|
46
|
+
*/
|
|
47
|
+
export declare const getDefaultDropdownPosition: DropdownPositioningStrategy;
|
|
48
|
+
export declare function useDropdownPositioning({ open, anchorRef, contentRef, placement, offset, matchAnchorWidth, strategy, estimateSize, watchDeps, containerRef, positionMode, }: UseDropdownPositioningOptions): UseDropdownPositioningResult;
|
|
49
|
+
//# sourceMappingURL=useDropdownPositioning.d.ts.map
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { useCallback, useEffect, useMemo, useRef, useState } from "react";
|
|
2
|
+
const HIDDEN_POSITION = {
|
|
3
|
+
top: -100,
|
|
4
|
+
left: -100,
|
|
5
|
+
};
|
|
6
|
+
const EMPTY_DEPS = [];
|
|
7
|
+
/**
|
|
8
|
+
* 计算弹窗该放在哪。
|
|
9
|
+
*
|
|
10
|
+
* right/left:跟触发元素顶部对齐,往右或往左弹。
|
|
11
|
+
* bottom/top:放在触发元素下方或上方,再按 start/end 对齐。
|
|
12
|
+
*/
|
|
13
|
+
export const getDefaultDropdownPosition = ({ anchorRect, contentRect, containerRect, viewportWidth, placement, offset, matchAnchorWidth, }) => {
|
|
14
|
+
const isRight = placement.startsWith("right");
|
|
15
|
+
const isLeft = placement.startsWith("left");
|
|
16
|
+
const isTop = placement.startsWith("top");
|
|
17
|
+
const containerTop = containerRect?.top ?? 0;
|
|
18
|
+
const containerLeft = containerRect?.left ?? 0;
|
|
19
|
+
const containerRight = containerRect?.right ?? viewportWidth;
|
|
20
|
+
const nextPosition = {
|
|
21
|
+
top: (isRight || isLeft
|
|
22
|
+
? anchorRect.top
|
|
23
|
+
: isTop
|
|
24
|
+
? anchorRect.top - (contentRect?.height ?? 0) - offset
|
|
25
|
+
: anchorRect.bottom + offset) - containerTop,
|
|
26
|
+
width: matchAnchorWidth ? anchorRect.width : undefined,
|
|
27
|
+
};
|
|
28
|
+
if (isRight) {
|
|
29
|
+
nextPosition.left = anchorRect.right + offset - containerLeft;
|
|
30
|
+
}
|
|
31
|
+
else if (isLeft) {
|
|
32
|
+
// 往左弹时,要知道弹窗宽度,才能算出左边应该从哪里开始。
|
|
33
|
+
nextPosition.left = anchorRect.left - (contentRect?.width ?? 0) - offset - containerLeft;
|
|
34
|
+
}
|
|
35
|
+
else if (placement.endsWith("start")) {
|
|
36
|
+
nextPosition.left = anchorRect.left - containerLeft;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
nextPosition.right = containerRight - anchorRect.right;
|
|
40
|
+
}
|
|
41
|
+
return nextPosition;
|
|
42
|
+
};
|
|
43
|
+
export function useDropdownPositioning({ open, anchorRef, contentRef, placement = "bottom-end", offset = 8, matchAnchorWidth = false, strategy = getDefaultDropdownPosition, estimateSize, watchDeps = EMPTY_DEPS, containerRef, positionMode = "fixed", }) {
|
|
44
|
+
const [position, setPosition] = useState(HIDDEN_POSITION);
|
|
45
|
+
const [ready, setReady] = useState(false);
|
|
46
|
+
const getContentRect = useCallback(() => {
|
|
47
|
+
// 优先用真实 DOM 尺寸。刚打开时可能还量不到,就允许外部给一个预估尺寸。
|
|
48
|
+
const measuredRect = contentRef.current?.getBoundingClientRect();
|
|
49
|
+
if (measuredRect && measuredRect.height > 0) {
|
|
50
|
+
return measuredRect;
|
|
51
|
+
}
|
|
52
|
+
const estimatedSize = estimateSize?.();
|
|
53
|
+
if (!estimatedSize)
|
|
54
|
+
return measuredRect;
|
|
55
|
+
return new DOMRect(0, 0, estimatedSize.width ?? 0, estimatedSize.height ?? 0);
|
|
56
|
+
}, [contentRef, estimateSize]);
|
|
57
|
+
const updatePosition = useCallback(() => {
|
|
58
|
+
if (!anchorRef.current)
|
|
59
|
+
return;
|
|
60
|
+
// 每次定位前重新读取位置,这样滚动或窗口变化后不会用旧坐标。
|
|
61
|
+
const anchorRect = anchorRef.current.getBoundingClientRect();
|
|
62
|
+
const contentRect = getContentRect();
|
|
63
|
+
const containerRect = positionMode === "absolute"
|
|
64
|
+
? containerRef?.current?.getBoundingClientRect()
|
|
65
|
+
: undefined;
|
|
66
|
+
const newData = strategy({
|
|
67
|
+
anchorRect,
|
|
68
|
+
contentRect: contentRect ?? undefined,
|
|
69
|
+
containerRect,
|
|
70
|
+
viewportWidth: window.innerWidth,
|
|
71
|
+
viewportHeight: window.innerHeight,
|
|
72
|
+
placement,
|
|
73
|
+
offset,
|
|
74
|
+
matchAnchorWidth,
|
|
75
|
+
});
|
|
76
|
+
setPosition((returnData.current.position = newData));
|
|
77
|
+
setReady((returnData.current.ready = Boolean(contentRef.current &&
|
|
78
|
+
contentRef.current.getBoundingClientRect().height > 0)));
|
|
79
|
+
}, [
|
|
80
|
+
anchorRef,
|
|
81
|
+
contentRef,
|
|
82
|
+
containerRef,
|
|
83
|
+
getContentRect,
|
|
84
|
+
matchAnchorWidth,
|
|
85
|
+
offset,
|
|
86
|
+
placement,
|
|
87
|
+
positionMode,
|
|
88
|
+
strategy,
|
|
89
|
+
]);
|
|
90
|
+
useEffect(() => {
|
|
91
|
+
if (!open) {
|
|
92
|
+
// 关闭时先挪到屏幕外,避免 keepMounted 的弹窗在旧位置闪一下。
|
|
93
|
+
setPosition((returnData.current.position = HIDDEN_POSITION));
|
|
94
|
+
setReady((returnData.current.ready = false));
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
// 打开后等两帧再量尺寸:先让 DOM 挂上去,再让浏览器完成布局。
|
|
98
|
+
const rafId = requestAnimationFrame(() => requestAnimationFrame(updatePosition));
|
|
99
|
+
return () => cancelAnimationFrame(rafId);
|
|
100
|
+
}, [open, updatePosition]);
|
|
101
|
+
useEffect(() => {
|
|
102
|
+
if (!open)
|
|
103
|
+
return;
|
|
104
|
+
// 页面滚动、外层容器滚动、窗口缩放时,都重新算一次位置。
|
|
105
|
+
const handleUpdate = () => updatePosition();
|
|
106
|
+
window.addEventListener("scroll", handleUpdate, true);
|
|
107
|
+
window.addEventListener("resize", handleUpdate);
|
|
108
|
+
return () => {
|
|
109
|
+
window.removeEventListener("scroll", handleUpdate, true);
|
|
110
|
+
window.removeEventListener("resize", handleUpdate);
|
|
111
|
+
};
|
|
112
|
+
}, [open, updatePosition]);
|
|
113
|
+
const deps = useMemo(() => watchDeps, [watchDeps]);
|
|
114
|
+
useEffect(() => {
|
|
115
|
+
if (!open)
|
|
116
|
+
return;
|
|
117
|
+
// 外部内容变化时,可以通过 watchDeps 主动触发重新定位。
|
|
118
|
+
updatePosition();
|
|
119
|
+
}, [deps, open, updatePosition]);
|
|
120
|
+
useEffect(() => {
|
|
121
|
+
if (!open || !contentRef.current)
|
|
122
|
+
return;
|
|
123
|
+
// 弹窗打开后内容高度/宽度可能变,尺寸变了就重新定位。
|
|
124
|
+
let rafId = 0;
|
|
125
|
+
const observer = new ResizeObserver(() => {
|
|
126
|
+
rafId = requestAnimationFrame(() => requestAnimationFrame(updatePosition));
|
|
127
|
+
});
|
|
128
|
+
observer.observe(contentRef.current);
|
|
129
|
+
return () => {
|
|
130
|
+
observer.disconnect();
|
|
131
|
+
cancelAnimationFrame(rafId);
|
|
132
|
+
};
|
|
133
|
+
}, [contentRef, open, updatePosition]);
|
|
134
|
+
const returnData = useRef({ position, ready, updatePosition });
|
|
135
|
+
returnData.current.updatePosition = updatePosition;
|
|
136
|
+
return returnData.current;
|
|
137
|
+
}
|
|
@@ -2,14 +2,20 @@ export * from './breadcrumb';
|
|
|
2
2
|
export * from './Button';
|
|
3
3
|
export * from './Checkbox';
|
|
4
4
|
export * from './ConfirmDialog';
|
|
5
|
-
export * from './DataTable
|
|
5
|
+
export * from './DataTable';
|
|
6
|
+
export * from './Drawer';
|
|
6
7
|
export * from './Dropdown';
|
|
8
|
+
export * from './Popup';
|
|
7
9
|
export * from './Form';
|
|
10
|
+
export * from './hooks/useDropdownPositioning';
|
|
8
11
|
export * from './ImagePreview';
|
|
9
12
|
export * from './Input';
|
|
13
|
+
export * from './InputNumber';
|
|
10
14
|
export * from './Label';
|
|
15
|
+
export * from './Menu';
|
|
11
16
|
export * from './Message';
|
|
12
17
|
export * from './Modal';
|
|
18
|
+
export * from './Overlay';
|
|
13
19
|
export * from './Pagination';
|
|
14
20
|
export * from './Search';
|
|
15
21
|
export * from './Select';
|
|
@@ -2,14 +2,20 @@ export * from './breadcrumb';
|
|
|
2
2
|
export * from './Button';
|
|
3
3
|
export * from './Checkbox';
|
|
4
4
|
export * from './ConfirmDialog';
|
|
5
|
-
export * from './DataTable
|
|
5
|
+
export * from './DataTable';
|
|
6
|
+
export * from './Drawer';
|
|
6
7
|
export * from './Dropdown';
|
|
8
|
+
export * from './Popup';
|
|
7
9
|
export * from './Form';
|
|
10
|
+
export * from './hooks/useDropdownPositioning';
|
|
8
11
|
export * from './ImagePreview';
|
|
9
12
|
export * from './Input';
|
|
13
|
+
export * from './InputNumber';
|
|
10
14
|
export * from './Label';
|
|
15
|
+
export * from './Menu';
|
|
11
16
|
export * from './Message';
|
|
12
17
|
export * from './Modal';
|
|
18
|
+
export * from './Overlay';
|
|
13
19
|
export * from './Pagination';
|
|
14
20
|
export * from './Search';
|
|
15
21
|
export * from './Select';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './table';
|