@_tc/template-core 0.0.1-bate.1 → 0.0.1-bate.11
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/{app → cjs/app}/controller/base.d.ts +1 -2
- package/{app → cjs/app}/controller/base.js +0 -3
- package/{app → cjs/app}/controller/project.d.ts +1 -2
- package/cjs/app/controller/project.js +50 -0
- package/{app → cjs/app}/controller/view.d.ts +1 -2
- package/{app → cjs/app}/controller/view.js +0 -1
- package/cjs/app/data/signKey.d.ts +1 -0
- package/{app → cjs/app}/data/signKey.js +0 -1
- package/cjs/app/extend/db.d.ts +2 -0
- package/cjs/app/extend/db.js +12 -0
- package/cjs/app/extend/generateErrorMessage.d.ts +7 -0
- package/{app → cjs/app}/extend/generateErrorMessage.js +3 -1
- package/cjs/app/extend/logger.d.ts +11 -0
- package/{app → cjs/app}/extend/logger.js +0 -1
- package/cjs/app/extend/parsingParamsOnUrl.d.ts +2 -0
- package/{app → cjs/app}/extend/parsingParamsOnUrl.js +0 -1
- package/{app → cjs/app}/extend/render-view.d.ts +1 -2
- package/{app → cjs/app}/extend/render-view.js +0 -1
- package/{app → cjs/app}/middleware/api-params-verify.d.ts +1 -2
- package/{app → cjs/app}/middleware/api-params-verify.js +0 -1
- package/{app → cjs/app}/middleware/api-sign-verify.d.ts +1 -2
- package/{app → cjs/app}/middleware/api-sign-verify.js +0 -1
- package/{app → cjs/app}/middleware/error-handle.d.ts +1 -2
- package/{app → cjs/app}/middleware/error-handle.js +0 -1
- package/{app → cjs/app}/middleware/project-handler.d.ts +1 -2
- package/{app → cjs/app}/middleware/project-handler.js +0 -1
- package/cjs/app/middleware.d.ts +5 -0
- package/{app → cjs/app}/middleware.js +23 -2
- package/cjs/app/router/project.d.ts +4 -0
- package/{app → cjs/app}/router/project.js +0 -1
- package/cjs/app/router/view.d.ts +4 -0
- package/{app → cjs/app}/router/view.js +0 -1
- package/cjs/app/router-schema/project.d.ts +3 -0
- package/{app → cjs/app}/router-schema/project.js +0 -1
- package/cjs/app/service/bese.d.ts +10 -0
- package/{app → cjs/app}/service/bese.js +0 -1
- package/cjs/app/service/project.d.ts +27 -0
- package/cjs/app/service/project.js +42 -0
- package/cjs/app/type.d.ts +2 -0
- package/{app → cjs/app}/type.js +0 -1
- package/cjs/app/typings.d.ts +49 -0
- package/{app → cjs/app}/typings.js +0 -1
- package/cjs/app/view/entry.tpl +30 -0
- package/cjs/bundler/dev.d.ts +1 -0
- package/cjs/bundler/dev.js +68 -0
- package/cjs/bundler/index.d.ts +1 -0
- package/cjs/bundler/index.js +18 -0
- package/cjs/bundler/prod.d.ts +1 -0
- package/cjs/bundler/prod.js +19 -0
- package/cjs/bundler/utils.d.ts +7 -0
- package/cjs/bundler/utils.js +127 -0
- package/cjs/index.d.ts +28 -0
- package/{index.js → cjs/index.js} +0 -1
- package/cjs/packages/core/env.d.ts +15 -0
- package/{packages → cjs/packages}/core/env.js +0 -1
- package/cjs/packages/core/index.d.ts +6 -0
- package/{packages → cjs/packages}/core/index.js +24 -1
- package/cjs/packages/core/loader/config.d.ts +9 -0
- package/{packages → cjs/packages}/core/loader/config.js +14 -1
- package/cjs/packages/core/loader/controller.d.ts +17 -0
- package/{packages → cjs/packages}/core/loader/controller.js +23 -1
- package/cjs/packages/core/loader/extend.d.ts +8 -0
- package/{packages → cjs/packages}/core/loader/extend.js +8 -1
- package/cjs/packages/core/loader/middleware.d.ts +11 -0
- package/cjs/packages/core/loader/middleware.js +38 -0
- package/cjs/packages/core/loader/model.d.ts +36 -0
- package/{packages → cjs/packages}/core/loader/model.js +43 -1
- package/cjs/packages/core/loader/router-schema.d.ts +18 -0
- package/{packages → cjs/packages}/core/loader/router-schema.js +16 -1
- package/{packages → cjs/packages}/core/loader/router.d.ts +5 -1
- package/{packages → cjs/packages}/core/loader/router.js +20 -4
- package/cjs/packages/core/loader/service.d.ts +17 -0
- package/{packages → cjs/packages}/core/loader/service.js +14 -1
- package/cjs/packages/core/paths.d.ts +11 -0
- package/{packages → cjs/packages}/core/paths.js +0 -1
- package/{packages → cjs/packages}/core/types.d.ts +1 -1
- package/{packages → cjs/packages}/core/types.js +0 -1
- package/{packages → cjs/packages}/utils/getAllFilesInFolder.d.ts +5 -1
- package/{packages → cjs/packages}/utils/getAllFilesInFolder.js +0 -1
- package/cjs/packages/utils/getAllFnReturnValue.d.ts +0 -0
- package/cjs/packages/utils/getAllFnReturnValue.js +6 -0
- package/cjs/packages/utils/index.d.ts +4 -0
- package/{packages → cjs/packages}/utils/index.js +0 -1
- package/{packages → cjs/packages}/utils/loadFile.d.ts +6 -1
- package/{packages → cjs/packages}/utils/loadFile.js +9 -1
- package/cjs/packages/utils/path.d.ts +24 -0
- package/{packages → cjs/packages}/utils/path.js +14 -1
- package/cjs/packages/utils/runFileFn.d.ts +5 -0
- package/{packages → cjs/packages}/utils/runFileFn.js +0 -1
- package/cjs/typings/type.d.ts +4 -0
- package/{typings → cjs/typings}/type.js +0 -1
- package/esm/app/controller/base.d.ts +14 -0
- package/esm/app/controller/base.js +21 -0
- package/esm/app/controller/project.d.ts +12 -0
- package/{app → esm/app}/controller/project.js +3 -9
- package/esm/app/controller/view.d.ts +9 -0
- package/esm/app/controller/view.js +12 -0
- package/esm/app/data/signKey.js +1 -0
- package/esm/app/extend/db.js +9 -0
- package/esm/app/extend/generateErrorMessage.js +12 -0
- package/esm/app/extend/logger.js +37 -0
- package/esm/app/extend/parsingParamsOnUrl.js +20 -0
- package/esm/app/extend/render-view.d.ts +5 -0
- package/esm/app/extend/render-view.js +16 -0
- package/esm/app/middleware/api-params-verify.d.ts +6 -0
- package/esm/app/middleware/api-params-verify.js +58 -0
- package/esm/app/middleware/api-sign-verify.d.ts +6 -0
- package/esm/app/middleware/api-sign-verify.js +23 -0
- package/esm/app/middleware/error-handle.d.ts +6 -0
- package/esm/app/middleware/error-handle.js +31 -0
- package/esm/app/middleware/project-handler.d.ts +5 -0
- package/esm/app/middleware/project-handler.js +19 -0
- package/esm/app/middleware.js +55 -0
- package/esm/app/router/project.js +6 -0
- package/esm/app/router/view.js +3 -0
- package/esm/app/router-schema/project.js +31 -0
- package/esm/app/service/bese.js +12 -0
- package/{app → esm/app}/service/project.js +6 -11
- package/esm/app/type.js +1 -0
- package/esm/app/typings.js +1 -0
- package/esm/app/view/entry.tpl +30 -0
- package/esm/bundler/dev.d.ts +2 -0
- package/esm/bundler/dev.js +29 -0
- package/esm/bundler/index.d.ts +2 -0
- package/esm/bundler/index.js +14 -0
- package/esm/bundler/prod.d.ts +2 -0
- package/esm/bundler/prod.js +16 -0
- package/esm/bundler/utils.d.ts +8 -0
- package/esm/bundler/utils.js +85 -0
- package/esm/index.js +13 -0
- package/esm/packages/core/env.js +23 -0
- package/esm/packages/core/index.js +109 -0
- package/esm/packages/core/loader/config.d.ts +10 -0
- package/esm/packages/core/loader/config.js +43 -0
- package/esm/packages/core/loader/controller.d.ts +18 -0
- package/esm/packages/core/loader/controller.js +38 -0
- package/esm/packages/core/loader/extend.d.ts +9 -0
- package/esm/packages/core/loader/extend.js +39 -0
- package/esm/packages/core/loader/middleware.d.ts +12 -0
- package/esm/packages/core/loader/middleware.js +36 -0
- package/esm/packages/core/loader/model.d.ts +37 -0
- package/esm/packages/core/loader/model.js +127 -0
- package/esm/packages/core/loader/router-schema.d.ts +19 -0
- package/esm/packages/core/loader/router-schema.js +33 -0
- package/esm/packages/core/loader/router.d.ts +9 -0
- package/esm/packages/core/loader/router.js +57 -0
- package/esm/packages/core/loader/service.d.ts +18 -0
- package/esm/packages/core/loader/service.js +28 -0
- package/esm/packages/core/paths.js +6 -0
- package/esm/packages/core/types.d.ts +75 -0
- package/esm/packages/core/types.js +1 -0
- package/esm/packages/utils/getAllFilesInFolder.d.ts +10 -0
- package/esm/packages/utils/getAllFilesInFolder.js +8 -0
- package/esm/packages/utils/getAllFnReturnValue.js +6 -0
- package/esm/packages/utils/index.js +4 -0
- package/esm/packages/utils/loadFile.d.ts +21 -0
- package/esm/packages/utils/loadFile.js +63 -0
- package/esm/packages/utils/path.d.ts +25 -0
- package/esm/packages/utils/path.js +27 -0
- package/esm/packages/utils/runFileFn.js +1 -0
- package/esm/typings/type.d.ts +5 -0
- package/esm/typings/type.js +1 -0
- package/fe/frontend/main.d.ts +3 -0
- package/fe/frontend/main.js +6 -0
- package/fe/frontend/testPage/index.d.ts +3 -0
- package/fe/frontend/testPage/index.js +6 -0
- package/fe/frontend/testPage/testPage.entry.d.ts +2 -0
- package/fe/frontend/testPage/testPage.entry.js +4 -0
- package/fe/packages/ui/react/assets/table/no-result.svg +5 -0
- package/fe/packages/ui/react/components/Button/Button.d.ts +39 -0
- package/fe/packages/ui/react/components/Button/Button.js +42 -0
- package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +13 -0
- package/fe/packages/ui/react/components/Button/SumbitButton.js +32 -0
- package/fe/packages/ui/react/components/Button/index.d.ts +4 -0
- package/fe/packages/ui/react/components/Button/index.js +2 -0
- package/fe/packages/ui/react/components/Checkbox/Checkbox.d.ts +17 -0
- package/fe/packages/ui/react/components/Checkbox/Checkbox.js +37 -0
- package/fe/packages/ui/react/components/Checkbox/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Checkbox/index.js +1 -0
- package/fe/packages/ui/react/components/ConfirmDialog.d.ts +20 -0
- package/fe/packages/ui/react/components/ConfirmDialog.js +9 -0
- package/fe/packages/ui/react/components/DataTable/ActionBtn.d.ts +6 -0
- package/fe/packages/ui/react/components/DataTable/ActionBtn.js +13 -0
- package/fe/packages/ui/react/components/DataTable/data-table.d.ts +44 -0
- package/fe/packages/ui/react/components/DataTable/data-table.js +141 -0
- package/fe/packages/ui/react/components/Date/Calendar.d.ts +35 -0
- package/fe/packages/ui/react/components/Date/Calendar.js +215 -0
- package/fe/packages/ui/react/components/Date/Date.d.ts +36 -0
- package/fe/packages/ui/react/components/Date/Date.js +178 -0
- package/fe/packages/ui/react/components/Date/DateTestPage.d.ts +2 -0
- package/fe/packages/ui/react/components/Date/DateTestPage.js +29 -0
- package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +6 -0
- package/fe/packages/ui/react/components/Date/LocaleContext.js +8 -0
- package/fe/packages/ui/react/components/Date/LocaleProvider.d.ts +19 -0
- package/fe/packages/ui/react/components/Date/LocaleProvider.js +24 -0
- package/fe/packages/ui/react/components/Date/TimePicker.d.ts +7 -0
- package/fe/packages/ui/react/components/Date/TimePicker.js +76 -0
- package/fe/packages/ui/react/components/Date/data.d.ts +6 -0
- package/fe/packages/ui/react/components/Date/data.js +4 -0
- package/fe/packages/ui/react/components/Date/dateLocaleStore.d.ts +16 -0
- package/fe/packages/ui/react/components/Date/dateLocaleStore.js +14 -0
- package/fe/packages/ui/react/components/Date/index.d.ts +6 -0
- package/fe/packages/ui/react/components/Date/index.js +5 -0
- package/fe/packages/ui/react/components/Date/locales.d.ts +42 -0
- package/fe/packages/ui/react/components/Date/locales.js +52 -0
- package/fe/packages/ui/react/components/Dropdown.d.ts +16 -0
- package/fe/packages/ui/react/components/Dropdown.js +54 -0
- package/fe/packages/ui/react/components/Form/Form.d.ts +18 -0
- package/fe/packages/ui/react/components/Form/Form.js +8 -0
- package/fe/packages/ui/react/components/Form/FormItem.d.ts +41 -0
- package/fe/packages/ui/react/components/Form/FormItem.js +43 -0
- package/fe/packages/ui/react/components/Form/SchemeForm/data.d.ts +51 -0
- package/fe/packages/ui/react/components/Form/SchemeForm/data.js +8 -0
- package/fe/packages/ui/react/components/Form/SchemeForm/index.d.ts +152 -0
- package/fe/packages/ui/react/components/Form/SchemeForm/index.js +69 -0
- package/fe/packages/ui/react/components/Form/index.d.ts +5 -0
- package/fe/packages/ui/react/components/Form/index.js +4 -0
- package/fe/packages/ui/react/components/Form/useForm.d.ts +3 -0
- package/fe/packages/ui/react/components/Form/useForm.js +1 -0
- package/fe/packages/ui/react/components/ImagePreview/ImagePreview.d.ts +8 -0
- package/fe/packages/ui/react/components/ImagePreview/ImagePreview.js +166 -0
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.d.ts +11 -0
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +25 -0
- package/fe/packages/ui/react/components/ImagePreview/index.d.ts +3 -0
- package/fe/packages/ui/react/components/ImagePreview/index.js +2 -0
- package/fe/packages/ui/react/components/Input/Input.d.ts +41 -0
- package/fe/packages/ui/react/components/Input/Input.js +60 -0
- package/fe/packages/ui/react/components/Input/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Input/index.js +1 -0
- package/fe/packages/ui/react/components/Label/Label.d.ts +51 -0
- package/fe/packages/ui/react/components/Label/Label.js +35 -0
- package/fe/packages/ui/react/components/Label/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Label/index.js +2 -0
- package/fe/packages/ui/react/components/Message/Message.d.ts +20 -0
- package/fe/packages/ui/react/components/Message/Message.js +55 -0
- package/fe/packages/ui/react/components/Message/MessageManager.d.ts +37 -0
- package/fe/packages/ui/react/components/Message/MessageManager.js +90 -0
- package/fe/packages/ui/react/components/Message/data.d.ts +2 -0
- package/fe/packages/ui/react/components/Message/data.js +1 -0
- package/fe/packages/ui/react/components/Message/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Message/index.js +1 -0
- package/fe/packages/ui/react/components/Modal/Modal.d.ts +25 -0
- package/fe/packages/ui/react/components/Modal/Modal.js +51 -0
- package/fe/packages/ui/react/components/Modal/ModalManager.d.ts +59 -0
- package/fe/packages/ui/react/components/Modal/ModalManager.js +89 -0
- package/fe/packages/ui/react/components/Modal/index.d.ts +4 -0
- package/fe/packages/ui/react/components/Modal/index.js +2 -0
- package/fe/packages/ui/react/components/Pagination.d.ts +18 -0
- package/fe/packages/ui/react/components/Pagination.js +88 -0
- package/fe/packages/ui/react/components/Search/Search.d.ts +17 -0
- package/fe/packages/ui/react/components/Search/Search.js +12 -0
- package/fe/packages/ui/react/components/Search/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Search/index.js +1 -0
- package/fe/packages/ui/react/components/Select/Select.d.ts +21 -0
- package/fe/packages/ui/react/components/Select/Select.js +180 -0
- package/fe/packages/ui/react/components/Select/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Select/index.js +1 -0
- package/fe/packages/ui/react/components/Skeleton/Skeleton.d.ts +28 -0
- package/fe/packages/ui/react/components/Skeleton/Skeleton.js +31 -0
- package/fe/packages/ui/react/components/Skeleton/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Skeleton/index.js +1 -0
- package/fe/packages/ui/react/components/Switch/Switch.d.ts +11 -0
- package/fe/packages/ui/react/components/Switch/Switch.js +20 -0
- package/fe/packages/ui/react/components/Switch/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Switch/index.js +1 -0
- package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +67 -0
- package/fe/packages/ui/react/components/TableSearch/TableSearch.js +119 -0
- package/fe/packages/ui/react/components/TableSearch/index.d.ts +2 -0
- package/fe/packages/ui/react/components/TableSearch/index.js +1 -0
- package/fe/packages/ui/react/components/TableSearch/lang.d.ts +15 -0
- package/fe/packages/ui/react/components/TableSearch/lang.js +23 -0
- package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.d.ts +9 -0
- package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.js +11 -0
- package/fe/packages/ui/react/components/Textarea.d.ts +59 -0
- package/fe/packages/ui/react/components/Textarea.js +35 -0
- package/fe/packages/ui/react/components/Tooltip.d.ts +25 -0
- package/fe/packages/ui/react/components/Tooltip.js +118 -0
- package/fe/packages/ui/react/components/TreeSelect.d.ts +25 -0
- package/fe/packages/ui/react/components/TreeSelect.js +162 -0
- package/fe/packages/ui/react/components/Upload/ImageUpload.d.ts +9 -0
- package/fe/packages/ui/react/components/Upload/ImageUpload.js +63 -0
- package/fe/packages/ui/react/components/Upload/Upload.d.ts +41 -0
- package/fe/packages/ui/react/components/Upload/Upload.js +5 -0
- package/fe/packages/ui/react/components/Upload/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Upload/index.js +2 -0
- package/fe/packages/ui/react/components/breadcrumb.d.ts +35 -0
- package/fe/packages/ui/react/components/breadcrumb.js +78 -0
- package/fe/packages/ui/react/components/hooks/useInputController.d.ts +24 -0
- package/fe/packages/ui/react/components/hooks/useInputController.js +45 -0
- package/fe/packages/ui/react/components/index.d.ts +24 -0
- package/fe/packages/ui/react/components/index.js +23 -0
- package/fe/packages/ui/react/components/table.d.ts +17 -0
- package/fe/packages/ui/react/components/table.js +20 -0
- package/fe/packages/ui/react/components/testPage/index.d.ts +3 -0
- package/fe/packages/ui/react/components/testPage/index.js +118 -0
- package/fe/packages/ui/react/hooks/useBreadcrumb.d.ts +10 -0
- package/fe/packages/ui/react/hooks/useBreadcrumb.js +2 -0
- package/fe/packages/ui/react/hooks/useInit.d.ts +3 -0
- package/fe/packages/ui/react/hooks/useInit.js +9 -0
- package/fe/packages/ui/react/hooks/useLanguage.d.ts +7 -0
- package/fe/packages/ui/react/hooks/useLanguage.js +4 -0
- package/fe/packages/ui/react/hooks/usePagination.d.ts +16 -0
- package/fe/packages/ui/react/hooks/usePagination.js +27 -0
- package/fe/packages/ui/react/index.d.ts +3 -0
- package/fe/packages/ui/react/index.js +4 -0
- package/fe/packages/ui/react/lib/export.d.ts +66 -0
- package/fe/packages/ui/react/lib/export.js +138 -0
- package/fe/packages/ui/react/lib/utils.d.ts +34 -0
- package/fe/packages/ui/react/lib/utils.js +70 -0
- package/fe/packages/ui/react/locales/index.d.ts +8 -0
- package/fe/packages/ui/react/locales/index.js +6 -0
- package/fe/packages/ui/react/stores/breadcrumb.d.ts +15 -0
- package/fe/packages/ui/react/stores/breadcrumb.js +66 -0
- package/fe/packages/ui/react/stores/language.d.ts +13 -0
- package/fe/packages/ui/react/stores/language.js +51 -0
- package/{typings/type.d.ts → fe/packages/ui/react/types/index.d.ts} +1 -1
- package/fe/packages/ui/react/types/index.js +1 -0
- package/package.json +39 -3
- package/app/controller/base.d.ts.map +0 -1
- package/app/controller/base.js.map +0 -1
- package/app/controller/project.d.ts.map +0 -1
- package/app/controller/project.js.map +0 -1
- package/app/controller/view.d.ts.map +0 -1
- package/app/controller/view.js.map +0 -1
- package/app/data/signKey.d.ts.map +0 -1
- package/app/data/signKey.js.map +0 -1
- package/app/extend/db.d.ts.map +0 -1
- package/app/extend/db.js +0 -8
- package/app/extend/db.js.map +0 -1
- package/app/extend/generateErrorMessage.d.ts.map +0 -1
- package/app/extend/generateErrorMessage.js.map +0 -1
- package/app/extend/logger.d.ts.map +0 -1
- package/app/extend/logger.js.map +0 -1
- package/app/extend/parsingParamsOnUrl.d.ts.map +0 -1
- package/app/extend/parsingParamsOnUrl.js.map +0 -1
- package/app/extend/render-view.d.ts.map +0 -1
- package/app/extend/render-view.js.map +0 -1
- package/app/middleware/api-params-verify.d.ts.map +0 -1
- package/app/middleware/api-params-verify.js.map +0 -1
- package/app/middleware/api-sign-verify.d.ts.map +0 -1
- package/app/middleware/api-sign-verify.js.map +0 -1
- package/app/middleware/error-handle.d.ts.map +0 -1
- package/app/middleware/error-handle.js.map +0 -1
- package/app/middleware/project-handler.d.ts.map +0 -1
- package/app/middleware/project-handler.js.map +0 -1
- package/app/middleware.d.ts.map +0 -1
- package/app/middleware.js.map +0 -1
- package/app/router/project.d.ts.map +0 -1
- package/app/router/project.js.map +0 -1
- package/app/router/view.d.ts.map +0 -1
- package/app/router/view.js.map +0 -1
- package/app/router-schema/project.d.ts.map +0 -1
- package/app/router-schema/project.js.map +0 -1
- package/app/service/bese.d.ts.map +0 -1
- package/app/service/bese.js.map +0 -1
- package/app/service/project.d.ts.map +0 -1
- package/app/service/project.js.map +0 -1
- package/app/type.d.ts.map +0 -1
- package/app/type.js.map +0 -1
- package/app/typings.d.ts.map +0 -1
- package/app/typings.js.map +0 -1
- package/index.d.ts.map +0 -1
- package/index.js.map +0 -1
- package/model/index.d.ts +0 -2
- package/model/index.d.ts.map +0 -1
- package/model/index.js +0 -7
- package/model/index.js.map +0 -1
- package/model/test.d.ts +0 -6
- package/model/test.d.ts.map +0 -1
- package/model/test.js +0 -6
- package/model/test.js.map +0 -1
- package/model/test2.d.ts +0 -6
- package/model/test2.d.ts.map +0 -1
- package/model/test2.js +0 -6
- package/model/test2.js.map +0 -1
- package/packages/core/env.d.ts.map +0 -1
- package/packages/core/env.js.map +0 -1
- package/packages/core/index.d.ts.map +0 -1
- package/packages/core/index.js.map +0 -1
- package/packages/core/loader/config.d.ts +0 -4
- package/packages/core/loader/config.d.ts.map +0 -1
- package/packages/core/loader/config.js.map +0 -1
- package/packages/core/loader/controller.d.ts +0 -4
- package/packages/core/loader/controller.d.ts.map +0 -1
- package/packages/core/loader/controller.js.map +0 -1
- package/packages/core/loader/extend.d.ts +0 -4
- package/packages/core/loader/extend.d.ts.map +0 -1
- package/packages/core/loader/extend.js.map +0 -1
- package/packages/core/loader/middleware.d.ts +0 -4
- package/packages/core/loader/middleware.d.ts.map +0 -1
- package/packages/core/loader/middleware.js +0 -16
- package/packages/core/loader/middleware.js.map +0 -1
- package/packages/core/loader/model.d.ts +0 -15
- package/packages/core/loader/model.d.ts.map +0 -1
- package/packages/core/loader/model.js.map +0 -1
- package/packages/core/loader/router-schema.d.ts +0 -4
- package/packages/core/loader/router-schema.d.ts.map +0 -1
- package/packages/core/loader/router-schema.js.map +0 -1
- package/packages/core/loader/router.d.ts.map +0 -1
- package/packages/core/loader/router.js.map +0 -1
- package/packages/core/loader/service.d.ts +0 -4
- package/packages/core/loader/service.d.ts.map +0 -1
- package/packages/core/loader/service.js.map +0 -1
- package/packages/core/paths.d.ts.map +0 -1
- package/packages/core/paths.js.map +0 -1
- package/packages/core/types.d.ts.map +0 -1
- package/packages/core/types.js.map +0 -1
- package/packages/utils/getAllFilesInFolder.d.ts.map +0 -1
- package/packages/utils/getAllFilesInFolder.js.map +0 -1
- package/packages/utils/getAllFnReturnValue.d.ts.map +0 -1
- package/packages/utils/getAllFnReturnValue.js +0 -2
- package/packages/utils/getAllFnReturnValue.js.map +0 -1
- package/packages/utils/index.d.ts.map +0 -1
- package/packages/utils/index.js.map +0 -1
- package/packages/utils/loadFile.d.ts.map +0 -1
- package/packages/utils/loadFile.js.map +0 -1
- package/packages/utils/path.d.ts +0 -7
- package/packages/utils/path.d.ts.map +0 -1
- package/packages/utils/path.js.map +0 -1
- package/packages/utils/runFileFn.d.ts.map +0 -1
- package/packages/utils/runFileFn.js.map +0 -1
- package/typings/type.d.ts.map +0 -1
- package/typings/type.js.map +0 -1
- /package/{app → esm/app}/data/signKey.d.ts +0 -0
- /package/{app → esm/app}/extend/db.d.ts +0 -0
- /package/{app → esm/app}/extend/generateErrorMessage.d.ts +0 -0
- /package/{app → esm/app}/extend/logger.d.ts +0 -0
- /package/{app → esm/app}/extend/parsingParamsOnUrl.d.ts +0 -0
- /package/{app → esm/app}/middleware.d.ts +0 -0
- /package/{app → esm/app}/router/project.d.ts +0 -0
- /package/{app → esm/app}/router/view.d.ts +0 -0
- /package/{app → esm/app}/router-schema/project.d.ts +0 -0
- /package/{app → esm/app}/service/bese.d.ts +0 -0
- /package/{app → esm/app}/service/project.d.ts +0 -0
- /package/{app → esm/app}/type.d.ts +0 -0
- /package/{app → esm/app}/typings.d.ts +0 -0
- /package/{index.d.ts → esm/index.d.ts} +0 -0
- /package/{packages → esm/packages}/core/env.d.ts +0 -0
- /package/{packages → esm/packages}/core/index.d.ts +0 -0
- /package/{packages → esm/packages}/core/paths.d.ts +0 -0
- /package/{packages → esm/packages}/utils/getAllFnReturnValue.d.ts +0 -0
- /package/{packages → esm/packages}/utils/index.d.ts +0 -0
- /package/{packages → esm/packages}/utils/runFileFn.d.ts +0 -0
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from '../lib/utils';
|
|
3
|
+
import { Check, ChevronDown, ChevronRight } from 'lucide-react';
|
|
4
|
+
import { useCallback, useMemo, useState } from 'react';
|
|
5
|
+
export function TreeSelect({ data, value = [], onChange, labelField = 'name', checkable = true, className, }) {
|
|
6
|
+
const [expandedKeys, setExpandedKeys] = useState(new Set());
|
|
7
|
+
const { nodeMap, parentMap } = useMemo(() => {
|
|
8
|
+
const nodeM = new Map();
|
|
9
|
+
const parentM = new Map();
|
|
10
|
+
const traverse = (nodes, parentId) => {
|
|
11
|
+
nodes.forEach((node) => {
|
|
12
|
+
nodeM.set(node.id, node);
|
|
13
|
+
parentM.set(node.id, parentId);
|
|
14
|
+
if (node.children && node.children.length > 0) {
|
|
15
|
+
traverse(node.children, node.id);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
traverse(data, null);
|
|
20
|
+
return { nodeMap: nodeM, parentMap: parentM };
|
|
21
|
+
}, [data]);
|
|
22
|
+
// 获取节点的所有子节点 ID
|
|
23
|
+
const getDescendantIds = useCallback((node) => {
|
|
24
|
+
const ids = [];
|
|
25
|
+
const traverse = (n) => {
|
|
26
|
+
if (n.children && n.children.length > 0) {
|
|
27
|
+
n.children.forEach((child) => {
|
|
28
|
+
ids.push(child.id);
|
|
29
|
+
traverse(child);
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
traverse(node);
|
|
34
|
+
return ids;
|
|
35
|
+
}, []);
|
|
36
|
+
const updateParentSelection = useCallback((checkedSet) => {
|
|
37
|
+
const traverseUp = (nodeId) => {
|
|
38
|
+
const parentId = parentMap.get(nodeId);
|
|
39
|
+
if (parentId === undefined || parentId === null)
|
|
40
|
+
return;
|
|
41
|
+
const parentNode = nodeMap.get(parentId);
|
|
42
|
+
if (!parentNode || !parentNode.children)
|
|
43
|
+
return;
|
|
44
|
+
const childIds = parentNode.children.map((child) => child.id);
|
|
45
|
+
const checkedCount = childIds.filter((id) => checkedSet.has(id)).length;
|
|
46
|
+
if (checkedCount === childIds.length) {
|
|
47
|
+
checkedSet.add(parentId);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
checkedSet.delete(parentId);
|
|
51
|
+
}
|
|
52
|
+
traverseUp(parentId);
|
|
53
|
+
};
|
|
54
|
+
checkedSet.forEach((id) => traverseUp(id));
|
|
55
|
+
}, [nodeMap, parentMap]);
|
|
56
|
+
// 切换展开/折叠
|
|
57
|
+
const toggleExpand = useCallback((nodeId) => {
|
|
58
|
+
setExpandedKeys((prev) => {
|
|
59
|
+
const newSet = new Set(prev);
|
|
60
|
+
if (newSet.has(nodeId)) {
|
|
61
|
+
newSet.delete(nodeId);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
newSet.add(nodeId);
|
|
65
|
+
}
|
|
66
|
+
return newSet;
|
|
67
|
+
});
|
|
68
|
+
}, []);
|
|
69
|
+
const getIndeterminateKeys = useCallback((checkedSet) => {
|
|
70
|
+
const indeterminateKeys = [];
|
|
71
|
+
const getDescendantCount = (node) => {
|
|
72
|
+
if (!node.children || node.children.length === 0) {
|
|
73
|
+
return { total: 1, checked: checkedSet.has(node.id) ? 1 : 0 };
|
|
74
|
+
}
|
|
75
|
+
return node.children.reduce((acc, child) => {
|
|
76
|
+
const childResult = getDescendantCount(child);
|
|
77
|
+
return { total: acc.total + childResult.total, checked: acc.checked + childResult.checked };
|
|
78
|
+
}, { total: 0, checked: 0 });
|
|
79
|
+
};
|
|
80
|
+
const traverse = (nodes) => {
|
|
81
|
+
nodes.forEach((node) => {
|
|
82
|
+
if (node.children && node.children.length > 0) {
|
|
83
|
+
const { total, checked } = getDescendantCount(node);
|
|
84
|
+
if (checked > 0 && checked < total) {
|
|
85
|
+
indeterminateKeys.push(node.id);
|
|
86
|
+
}
|
|
87
|
+
traverse(node.children);
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
};
|
|
91
|
+
traverse(data);
|
|
92
|
+
return indeterminateKeys;
|
|
93
|
+
}, [data]);
|
|
94
|
+
// 切换选中状态
|
|
95
|
+
const toggleCheck = useCallback((node) => {
|
|
96
|
+
if (!checkable || !onChange)
|
|
97
|
+
return;
|
|
98
|
+
const isChecked = value.includes(node.id);
|
|
99
|
+
const nextChecked = new Set(value);
|
|
100
|
+
const descendantIds = getDescendantIds(node);
|
|
101
|
+
if (isChecked) {
|
|
102
|
+
nextChecked.delete(node.id);
|
|
103
|
+
descendantIds.forEach((id) => nextChecked.delete(id));
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
nextChecked.add(node.id);
|
|
107
|
+
descendantIds.forEach((id) => nextChecked.add(id));
|
|
108
|
+
}
|
|
109
|
+
updateParentSelection(nextChecked);
|
|
110
|
+
const indeterminateKeys = getIndeterminateKeys(nextChecked);
|
|
111
|
+
onChange({ checked: Array.from(nextChecked), indeterminate: indeterminateKeys });
|
|
112
|
+
}, [value, onChange, checkable, getDescendantIds, updateParentSelection, getIndeterminateKeys]);
|
|
113
|
+
// 判断节点是否选中
|
|
114
|
+
const isNodeChecked = useCallback((nodeId) => {
|
|
115
|
+
return value.includes(nodeId);
|
|
116
|
+
}, [value]);
|
|
117
|
+
const isNodeIndeterminate = useCallback((node) => {
|
|
118
|
+
if (!node.children || node.children.length === 0)
|
|
119
|
+
return false;
|
|
120
|
+
const getDescendantCount = (n) => {
|
|
121
|
+
if (!n.children || n.children.length === 0) {
|
|
122
|
+
return { total: 1, checked: value.includes(n.id) ? 1 : 0 };
|
|
123
|
+
}
|
|
124
|
+
return n.children.reduce((acc, child) => {
|
|
125
|
+
const childResult = getDescendantCount(child);
|
|
126
|
+
return { total: acc.total + childResult.total, checked: acc.checked + childResult.checked };
|
|
127
|
+
}, { total: 0, checked: 0 });
|
|
128
|
+
};
|
|
129
|
+
const { total, checked } = getDescendantCount(node);
|
|
130
|
+
return checked > 0 && checked < total;
|
|
131
|
+
}, [value]);
|
|
132
|
+
// 渲染树节点
|
|
133
|
+
function renderTreeNode(node, level = 0) {
|
|
134
|
+
const hasChildren = node.children && node.children.length > 0;
|
|
135
|
+
const isExpanded = expandedKeys.has(node.id);
|
|
136
|
+
const isChecked = isNodeChecked(node.id);
|
|
137
|
+
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("button", { type: "button", onClick: (e) => {
|
|
139
|
+
e.stopPropagation();
|
|
140
|
+
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("button", { type: "button", onClick: (e) => {
|
|
142
|
+
e.stopPropagation();
|
|
143
|
+
toggleCheck(node);
|
|
144
|
+
}, className: cn('flex-shrink-0 w-4 h-4 rounded border-2 flex items-center justify-center transition-colors', isChecked
|
|
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: () => {
|
|
149
|
+
if (hasChildren) {
|
|
150
|
+
toggleExpand(node.id);
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
toggleCheck(node);
|
|
154
|
+
}
|
|
155
|
+
}, children: labelField === 'desctext' ? node.desctext || node.name : node.name })] }), hasChildren && isExpanded && _jsx("div", { children: node.children.map((child) => renderTreeNode(child, level + 1)) })] }, node.id));
|
|
156
|
+
}
|
|
157
|
+
// 如果没有数据
|
|
158
|
+
if (!data || data.length === 0) {
|
|
159
|
+
return _jsx("div", { className: cn('p-8 text-center text-sm text-muted-foreground', className), children: "No data" });
|
|
160
|
+
}
|
|
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)) }));
|
|
162
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface ImageUploadProps {
|
|
2
|
+
accept?: string;
|
|
3
|
+
maxCount?: number;
|
|
4
|
+
value?: string[];
|
|
5
|
+
onChange?: (urls: string[]) => void;
|
|
6
|
+
beforeChange?: (file: File) => boolean | void;
|
|
7
|
+
}
|
|
8
|
+
export declare function ImageUpload({ accept, maxCount, value, onChange, beforeChange }: ImageUploadProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=ImageUpload.d.ts.map
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Camera, X } from 'lucide-react';
|
|
3
|
+
import { useEffect, useMemo, useRef, useState } from 'react';
|
|
4
|
+
import { FileUpload } from './Upload';
|
|
5
|
+
export function ImageUpload({ accept = '.jpg,.png', maxCount = 1, value, onChange, beforeChange }) {
|
|
6
|
+
const inputRef = useRef(null);
|
|
7
|
+
const [internalUrls, setInternalUrls] = useState([]);
|
|
8
|
+
const urls = value ?? internalUrls;
|
|
9
|
+
const setUrls = onChange ?? setInternalUrls;
|
|
10
|
+
const mAccept = useMemo(() => {
|
|
11
|
+
const aType = accept
|
|
12
|
+
.split(',')
|
|
13
|
+
.map((item) => item.trim().replace(/\./g, ''))
|
|
14
|
+
.filter(Boolean);
|
|
15
|
+
return aType.map((a) => `image/${a}`).join(', ');
|
|
16
|
+
}, [accept]);
|
|
17
|
+
const handleFileChange = (e) => {
|
|
18
|
+
const files = e.target.files;
|
|
19
|
+
if (!files || files.length === 0)
|
|
20
|
+
return;
|
|
21
|
+
const newUrls = [];
|
|
22
|
+
const fileArray = Array.from(files);
|
|
23
|
+
const remainingCount = maxCount - urls.length;
|
|
24
|
+
fileArray.forEach((file) => {
|
|
25
|
+
if (newUrls.length < remainingCount) {
|
|
26
|
+
if (beforeChange) {
|
|
27
|
+
const result = beforeChange(file);
|
|
28
|
+
if (result === false) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
const url = URL.createObjectURL(file);
|
|
33
|
+
newUrls.push(url);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
if (maxCount > 1) {
|
|
37
|
+
setUrls([...urls, ...newUrls]);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
urls.forEach((url) => URL.revokeObjectURL(url));
|
|
41
|
+
setUrls(newUrls.slice(0, 1));
|
|
42
|
+
}
|
|
43
|
+
if (inputRef.current) {
|
|
44
|
+
inputRef.current.value = '';
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
const handleRemove = (index) => {
|
|
48
|
+
const urlToRemove = urls[index];
|
|
49
|
+
URL.revokeObjectURL(urlToRemove);
|
|
50
|
+
setUrls(urls.filter((_, i) => i !== index));
|
|
51
|
+
};
|
|
52
|
+
useEffect(() => {
|
|
53
|
+
return () => {
|
|
54
|
+
if (!onChange) {
|
|
55
|
+
internalUrls.forEach((url) => URL.revokeObjectURL(url));
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
}, [onChange, internalUrls]);
|
|
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("button", { type: "button", onClick: (e) => {
|
|
60
|
+
e.stopPropagation();
|
|
61
|
+
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": "\u5220\u9664\u56FE\u7247", title: "\u5220\u9664\u56FE\u7247", 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: "\u4E0A\u4F20" })] }) }))] }));
|
|
63
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { ChangeEvent, ReactNode, RefObject } from 'react';
|
|
2
|
+
export interface FileUploadProps {
|
|
3
|
+
/**
|
|
4
|
+
* 文件 input 的 ref,用于父组件重置 value 等
|
|
5
|
+
*/
|
|
6
|
+
inputRef?: RefObject<HTMLInputElement | null>;
|
|
7
|
+
/**
|
|
8
|
+
* input 的 accept 属性,默认接收任意文件
|
|
9
|
+
*/
|
|
10
|
+
accept?: string;
|
|
11
|
+
/**
|
|
12
|
+
* 是否支持多选
|
|
13
|
+
*/
|
|
14
|
+
multiple?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* 选择文件时的回调
|
|
17
|
+
*/
|
|
18
|
+
onChange?: (event: ChangeEvent<HTMLInputElement>) => void;
|
|
19
|
+
/**
|
|
20
|
+
* 选择文件按钮文案
|
|
21
|
+
*/
|
|
22
|
+
selectLabel: ReactNode;
|
|
23
|
+
/**
|
|
24
|
+
* label 的自定义 className
|
|
25
|
+
*/
|
|
26
|
+
labelClassName?: string;
|
|
27
|
+
/**
|
|
28
|
+
* 是否展示清空按钮
|
|
29
|
+
*/
|
|
30
|
+
showClear?: boolean;
|
|
31
|
+
/**
|
|
32
|
+
* 清空按钮点击回调
|
|
33
|
+
*/
|
|
34
|
+
onClear?: () => void;
|
|
35
|
+
/**
|
|
36
|
+
* 清空按钮文案
|
|
37
|
+
*/
|
|
38
|
+
clearLabel?: ReactNode;
|
|
39
|
+
}
|
|
40
|
+
export declare function FileUpload({ inputRef, accept, multiple, onChange, selectLabel, labelClassName, showClear, onClear, clearLabel, }: FileUploadProps): import("react/jsx-runtime").JSX.Element;
|
|
41
|
+
//# sourceMappingURL=Upload.d.ts.map
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button } from '../Button';
|
|
3
|
+
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-white', children: [_jsx("input", { ref: inputRef, type: "file", accept: accept, multiple: multiple, className: "hidden", onChange: onChange }), selectLabel] }), showClear && onClear && (_jsx(Button, { size: "sm", variant: "link", onClick: onClear, children: clearLabel }))] }));
|
|
5
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
declare const Breadcrumb: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, "ref"> & {
|
|
2
|
+
separator?: React.ReactNode;
|
|
3
|
+
} & import("react").RefAttributes<HTMLElement>>;
|
|
4
|
+
declare const BreadcrumbList: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").OlHTMLAttributes<HTMLOListElement>, HTMLOListElement>, "ref"> & import("react").RefAttributes<HTMLOListElement>>;
|
|
5
|
+
declare const BreadcrumbItem: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>, "ref"> & import("react").RefAttributes<HTMLLIElement>>;
|
|
6
|
+
declare const BreadcrumbLink: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>, "ref"> & {
|
|
7
|
+
asChild?: boolean;
|
|
8
|
+
} & import("react").RefAttributes<HTMLAnchorElement>>;
|
|
9
|
+
declare const BreadcrumbPage: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "ref"> & {
|
|
10
|
+
active?: boolean;
|
|
11
|
+
onClose?: () => void;
|
|
12
|
+
closable?: boolean;
|
|
13
|
+
} & import("react").RefAttributes<HTMLSpanElement>>;
|
|
14
|
+
declare const BreadcrumbSeparator: {
|
|
15
|
+
({ children, className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
displayName: string;
|
|
17
|
+
};
|
|
18
|
+
declare const BreadcrumbEllipsis: {
|
|
19
|
+
({ className, ...props }: React.ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
displayName: string;
|
|
21
|
+
};
|
|
22
|
+
export { Breadcrumb, BreadcrumbEllipsis, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, };
|
|
23
|
+
export interface BreadcrumbItemData {
|
|
24
|
+
label: string;
|
|
25
|
+
desctext?: string;
|
|
26
|
+
id: string | number;
|
|
27
|
+
path?: string;
|
|
28
|
+
active?: boolean;
|
|
29
|
+
closable?: boolean;
|
|
30
|
+
}
|
|
31
|
+
export interface SimpleBreadcrumbProps {
|
|
32
|
+
className?: string;
|
|
33
|
+
}
|
|
34
|
+
export declare function SimpleBreadcrumb({ className }: SimpleBreadcrumbProps): import("react/jsx-runtime").JSX.Element;
|
|
35
|
+
//# sourceMappingURL=breadcrumb.d.ts.map
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useBreadcrumb } from '../hooks/useBreadcrumb';
|
|
3
|
+
import { useLanguage } from '../hooks/useLanguage';
|
|
4
|
+
import { cn } from '../lib/utils';
|
|
5
|
+
// import useUserStore from '@tc/ui-react/stores/user'
|
|
6
|
+
import { ChevronRight, MoreHorizontal } from 'lucide-react';
|
|
7
|
+
import { forwardRef } from 'react';
|
|
8
|
+
import { useNavigate } from 'react-router-dom';
|
|
9
|
+
const Breadcrumb = forwardRef(({ ...props }, ref) => _jsx("nav", { ref: ref, "aria-label": "breadcrumb", ...props }));
|
|
10
|
+
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 })));
|
|
12
|
+
BreadcrumbList.displayName = 'BreadcrumbList';
|
|
13
|
+
const BreadcrumbItem = forwardRef(({ className, ...props }, ref) => _jsx("li", { ref: ref, className: cn('inline-flex items-center', className), ...props }));
|
|
14
|
+
BreadcrumbItem.displayName = 'BreadcrumbItem';
|
|
15
|
+
const BreadcrumbLink = forwardRef(({ className, ...props }, ref) => {
|
|
16
|
+
return _jsx("a", { ref: ref, className: cn('transition-colors hover:text-foreground', className), ...props });
|
|
17
|
+
});
|
|
18
|
+
BreadcrumbLink.displayName = 'BreadcrumbLink';
|
|
19
|
+
const BreadcrumbPage = forwardRef(({ className, active, onClose, closable = true, children, ...props }, ref) => {
|
|
20
|
+
return (_jsxs("span", { ref: ref, role: "link", "aria-disabled": "true", "aria-current": "page", className: cn('inline-flex items-center gap-2 px-4 py-2 rounded-lg border transition-all duration-200 text-sm', active
|
|
21
|
+
? 'bg-breadcrumb-active-bg text-breadcrumb-active-text border-breadcrumb-active-bg shadow-sm'
|
|
22
|
+
: 'bg-white text-breadcrumb-text border-breadcrumb-border hover:border-gray-400', className), ...props, children: [_jsx("span", { className: "font-normal", children: children }), onClose && closable && (_jsx("button", { onClick: (e) => {
|
|
23
|
+
e.stopPropagation();
|
|
24
|
+
onClose();
|
|
25
|
+
}, className: "inline-flex items-center justify-center hover:opacity-70 transition-opacity", "aria-label": "\u5173\u95ED", 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
|
+
});
|
|
27
|
+
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, {}) }));
|
|
29
|
+
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" })] }));
|
|
31
|
+
BreadcrumbEllipsis.displayName = 'BreadcrumbEllipsis';
|
|
32
|
+
export { Breadcrumb, BreadcrumbEllipsis, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, };
|
|
33
|
+
export function SimpleBreadcrumb({ className }) {
|
|
34
|
+
const { language } = useLanguage();
|
|
35
|
+
const navigate = useNavigate();
|
|
36
|
+
const { items, setActiveItem, removeItem } = useBreadcrumb();
|
|
37
|
+
const handleBreadcrumbClick = (id) => {
|
|
38
|
+
const item = items.find((item) => item.id === id);
|
|
39
|
+
if (item?.path) {
|
|
40
|
+
navigate(item.path);
|
|
41
|
+
setActiveItem(id);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
const handleBreadcrumbClose = (id) => {
|
|
45
|
+
const itemToRemove = items.find((item) => item.id === id);
|
|
46
|
+
const isActive = itemToRemove?.active;
|
|
47
|
+
// 先计算剩余的面包屑项(在删除之前)
|
|
48
|
+
const remainingItems = items.filter((item) => item.id !== id);
|
|
49
|
+
// 立即删除该项,确保状态及时更新
|
|
50
|
+
removeItem(id);
|
|
51
|
+
// 如果删除的是当前激活的项,需要跳转
|
|
52
|
+
if (isActive) {
|
|
53
|
+
if (remainingItems.length > 0) {
|
|
54
|
+
// 有剩余项,跳转到最后一个
|
|
55
|
+
const targetItem = remainingItems.at(-1);
|
|
56
|
+
const targetPath = targetItem.path;
|
|
57
|
+
if (targetPath) {
|
|
58
|
+
// 使用 setTimeout 确保删除操作先完成
|
|
59
|
+
setTimeout(() => {
|
|
60
|
+
navigate(targetPath);
|
|
61
|
+
setActiveItem(targetItem.id);
|
|
62
|
+
}, 0);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
// 获取首页路径(第一个权限页面)
|
|
67
|
+
setTimeout(() => {
|
|
68
|
+
// todo
|
|
69
|
+
// navigate(useUserStore.getState().userPagePermissions[0]?.menuUrl || '/')
|
|
70
|
+
}, 0);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
const getItemLabel = (item) => {
|
|
75
|
+
return language === 'zh-CN' ? item.label : item.desctext || item.label;
|
|
76
|
+
};
|
|
77
|
+
return (_jsx(Breadcrumb, { className: className, children: _jsx(BreadcrumbList, { children: items.map((item) => (_jsx(BreadcrumbItem, { children: _jsx(BreadcrumbPage, { active: item.active, closable: item.closable !== false, onClose: () => handleBreadcrumbClose(item.id), onClick: () => handleBreadcrumbClick(item.id), className: 'cursor-pointer', "data-active": item.active ? 'true' : undefined, children: getItemLabel(item) }) }, item.id))) }) }));
|
|
78
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
interface IParams<T> {
|
|
2
|
+
ref: React.ForwardedRef<T>;
|
|
3
|
+
defaultValue?: string;
|
|
4
|
+
controlledValue?: string;
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* 处理ref & 判断是否受控 & 使用的value & value.length
|
|
9
|
+
*/
|
|
10
|
+
export declare const useInputController: <T>(params: IParams<T>) => {
|
|
11
|
+
setRefs: (node: T | null) => void;
|
|
12
|
+
setIsFocused: import("react").Dispatch<import("react").SetStateAction<boolean>>;
|
|
13
|
+
setInternalValue: import("react").Dispatch<import("react").SetStateAction<string>>;
|
|
14
|
+
controllerRef: import("react").RefObject<T | null>;
|
|
15
|
+
isControlledRef: import("react").RefObject<boolean>;
|
|
16
|
+
isControlled: boolean;
|
|
17
|
+
isFocused: boolean;
|
|
18
|
+
currentLength: number;
|
|
19
|
+
hasValue: boolean;
|
|
20
|
+
internalValue: string;
|
|
21
|
+
value: string | undefined;
|
|
22
|
+
};
|
|
23
|
+
export {};
|
|
24
|
+
//# sourceMappingURL=useInputController.d.ts.map
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { useCallback, useMemo, useRef, useState } from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* 处理ref & 判断是否受控 & 使用的value & value.length
|
|
4
|
+
*/
|
|
5
|
+
export const useInputController = (params) => {
|
|
6
|
+
const { defaultValue, ref, controlledValue } = params;
|
|
7
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
8
|
+
const [internalValue, setInternalValue] = useState(defaultValue || '');
|
|
9
|
+
const controllerRef = useRef(null);
|
|
10
|
+
// 合并 refs
|
|
11
|
+
const setRefs = useCallback((node) => {
|
|
12
|
+
controllerRef.current = node;
|
|
13
|
+
if (typeof ref === 'function') {
|
|
14
|
+
ref(node);
|
|
15
|
+
}
|
|
16
|
+
else if (ref) {
|
|
17
|
+
// eslint-disable-next-line react-hooks/immutability
|
|
18
|
+
ref.current = node;
|
|
19
|
+
}
|
|
20
|
+
}, [ref]);
|
|
21
|
+
const isControlledRef = useRef(false);
|
|
22
|
+
// 外部传了value
|
|
23
|
+
const isControlled = useMemo(() => {
|
|
24
|
+
const r = controlledValue !== undefined;
|
|
25
|
+
// 当传入的value改变时,更新ref值
|
|
26
|
+
isControlledRef.current = r;
|
|
27
|
+
return r;
|
|
28
|
+
}, [controlledValue]);
|
|
29
|
+
const value = isControlled ? controlledValue : internalValue;
|
|
30
|
+
const hasValue = Boolean(value && String(value).length > 0);
|
|
31
|
+
const currentLength = value ? String(value).length : 0;
|
|
32
|
+
return {
|
|
33
|
+
setRefs,
|
|
34
|
+
setIsFocused,
|
|
35
|
+
setInternalValue,
|
|
36
|
+
controllerRef,
|
|
37
|
+
isControlledRef,
|
|
38
|
+
isControlled,
|
|
39
|
+
isFocused,
|
|
40
|
+
currentLength,
|
|
41
|
+
hasValue,
|
|
42
|
+
internalValue,
|
|
43
|
+
value,
|
|
44
|
+
};
|
|
45
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export * from './breadcrumb';
|
|
2
|
+
export * from './Button';
|
|
3
|
+
export * from './Checkbox';
|
|
4
|
+
export * from './ConfirmDialog';
|
|
5
|
+
export * from './DataTable/data-table';
|
|
6
|
+
export * from './Dropdown';
|
|
7
|
+
export * from './Form';
|
|
8
|
+
export * from './ImagePreview';
|
|
9
|
+
export * from './Input';
|
|
10
|
+
export * from './Label';
|
|
11
|
+
export * from './Message';
|
|
12
|
+
export * from './Modal';
|
|
13
|
+
export * from './Pagination';
|
|
14
|
+
export * from './Search';
|
|
15
|
+
export * from './Select';
|
|
16
|
+
export * from './Skeleton';
|
|
17
|
+
export * from './Switch';
|
|
18
|
+
export * from './table';
|
|
19
|
+
export * from './TableSearch';
|
|
20
|
+
export * from './Textarea';
|
|
21
|
+
export * from './Tooltip';
|
|
22
|
+
export * from './TreeSelect';
|
|
23
|
+
export * from './Upload';
|
|
24
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export * from './breadcrumb';
|
|
2
|
+
export * from './Button';
|
|
3
|
+
export * from './Checkbox';
|
|
4
|
+
export * from './ConfirmDialog';
|
|
5
|
+
export * from './DataTable/data-table';
|
|
6
|
+
export * from './Dropdown';
|
|
7
|
+
export * from './Form';
|
|
8
|
+
export * from './ImagePreview';
|
|
9
|
+
export * from './Input';
|
|
10
|
+
export * from './Label';
|
|
11
|
+
export * from './Message';
|
|
12
|
+
export * from './Modal';
|
|
13
|
+
export * from './Pagination';
|
|
14
|
+
export * from './Search';
|
|
15
|
+
export * from './Select';
|
|
16
|
+
export * from './Skeleton';
|
|
17
|
+
export * from './Switch';
|
|
18
|
+
export * from './table';
|
|
19
|
+
export * from './TableSearch';
|
|
20
|
+
export * from './Textarea';
|
|
21
|
+
export * from './Tooltip';
|
|
22
|
+
export * from './TreeSelect';
|
|
23
|
+
export * from './Upload';
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
declare const Table: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableElement> & {
|
|
3
|
+
containerClassName?: string;
|
|
4
|
+
} & React.RefAttributes<HTMLTableElement>>;
|
|
5
|
+
declare const TableHeader: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableSectionElement> & React.RefAttributes<HTMLTableSectionElement>>;
|
|
6
|
+
declare const TableBody: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableSectionElement> & React.RefAttributes<HTMLTableSectionElement>>;
|
|
7
|
+
declare const TableFooter: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableSectionElement> & React.RefAttributes<HTMLTableSectionElement>>;
|
|
8
|
+
declare const TableRow: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableRowElement> & React.RefAttributes<HTMLTableRowElement>>;
|
|
9
|
+
declare const TableHead: React.ForwardRefExoticComponent<React.ThHTMLAttributes<HTMLTableCellElement> & {
|
|
10
|
+
isAction?: boolean;
|
|
11
|
+
} & React.RefAttributes<HTMLTableCellElement>>;
|
|
12
|
+
declare const TableCell: React.ForwardRefExoticComponent<React.TdHTMLAttributes<HTMLTableCellElement> & {
|
|
13
|
+
isAction?: boolean;
|
|
14
|
+
} & React.RefAttributes<HTMLTableCellElement>>;
|
|
15
|
+
declare const TableCaption: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableCaptionElement> & React.RefAttributes<HTMLTableCaptionElement>>;
|
|
16
|
+
export { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow };
|
|
17
|
+
//# sourceMappingURL=table.d.ts.map
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from '../lib/utils';
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
const Table = React.forwardRef(({ className, containerClassName, ...props }, ref) => (_jsx("div", { className: cn('relative w-full overflow-auto rounded-[20px]', containerClassName), children: _jsx("table", { ref: ref, className: cn('w-full caption-bottom text-sm', className), ...props }) })));
|
|
5
|
+
Table.displayName = 'Table';
|
|
6
|
+
const TableHeader = React.forwardRef(({ className, ...props }, ref) => _jsx("thead", { ref: ref, className: cn('bg-table-header', className), ...props }));
|
|
7
|
+
TableHeader.displayName = 'TableHeader';
|
|
8
|
+
const TableBody = React.forwardRef(({ className, ...props }, ref) => (_jsx("tbody", { ref: ref, className: cn('[&_tr:last-child]:border-0', className), ...props })));
|
|
9
|
+
TableBody.displayName = 'TableBody';
|
|
10
|
+
const TableFooter = React.forwardRef(({ className, ...props }, ref) => (_jsx("tfoot", { ref: ref, className: cn('border-t bg-muted/50 font-medium [&>tr]:last:border-b-0', className), ...props })));
|
|
11
|
+
TableFooter.displayName = 'TableFooter';
|
|
12
|
+
const TableRow = React.forwardRef(({ className, ...props }, ref) => (_jsx("tr", { ref: ref, className: cn('border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted', className), ...props })));
|
|
13
|
+
TableRow.displayName = 'TableRow';
|
|
14
|
+
const TableHead = React.forwardRef(({ className, isAction, ...props }, ref) => (_jsx("th", { ref: ref, className: cn('h-12 px-4 text-left align-middle text-xs font-normal', 'text-table-head-text', isAction && 'bg-table-action text-table-action-text w-[85px] text-center', className), ...props })));
|
|
15
|
+
TableHead.displayName = 'TableHead';
|
|
16
|
+
const TableCell = React.forwardRef(({ className, isAction, ...props }, ref) => (_jsx("td", { ref: ref, className: cn('p-4 align-middle text-sm font-normal', 'text-table-cell-text', isAction && 'bg-table-action text-table-action-text w-[85px] text-center', className), ...props })));
|
|
17
|
+
TableCell.displayName = 'TableCell';
|
|
18
|
+
const TableCaption = React.forwardRef(({ className, ...props }, ref) => (_jsx("caption", { ref: ref, className: cn('mt-4 text-sm text-muted-foreground', className), ...props })));
|
|
19
|
+
TableCaption.displayName = 'TableCaption';
|
|
20
|
+
export { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow };
|