@_tc/template-core 0.0.1-bate.35 → 0.0.1-bate.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/app/controller/base.js +3 -3
- package/cjs/app/controller/project.js +1 -1
- package/cjs/app/controller/view.js +16 -7
- package/cjs/app/middleware/api-params-verify.js +10 -1
- package/cjs/app/middleware/error-handle.js +9 -3
- package/cjs/app/middleware/project-handler.js +1 -1
- package/cjs/app/router/view.js +3 -1
- package/cjs/app/router-schema/project.js +1 -1
- package/cjs/app/service/project.js +5 -0
- package/cjs/bundler/defaultAlias.js +5 -0
- package/cjs/bundler/dev.js +4 -3
- package/cjs/bundler/index.js +2 -1
- package/cjs/bundler/prod.js +4 -3
- package/cjs/bundler/utils.js +53 -24
- package/cjs/packages/common/LRUCache.js +4 -0
- package/cjs/packages/common/array/index.js +43 -0
- package/cjs/packages/common/cache/LRUCache.js +45 -0
- package/cjs/packages/common/cache/index.js +4 -0
- package/cjs/packages/common/guards/index.js +34 -0
- package/cjs/packages/common/i18n/default.js +95 -0
- package/cjs/packages/common/i18n/en-US.js +95 -0
- package/cjs/packages/common/i18n/index.js +178 -0
- package/cjs/packages/common/i18n/locales.js +17 -0
- package/cjs/packages/common/i18n/types.js +1 -0
- package/cjs/packages/common/index.js +65 -0
- package/cjs/packages/common/log/index.js +160 -0
- package/cjs/packages/common/number/index.js +14 -0
- package/cjs/packages/common/object/filterEmpty.js +32 -0
- package/cjs/packages/common/object/filtereEmpty.js +5 -0
- package/cjs/packages/common/object/index.js +26 -0
- package/cjs/packages/common/string/index.js +17 -0
- package/cjs/packages/common/types/index.js +1 -0
- package/cjs/packages/core/index.js +17 -12
- package/cjs/packages/core/loader/model.js +3 -3
- package/cjs/packages/core/loader/router.js +14 -5
- package/esm/app/controller/base.js +3 -3
- package/esm/app/controller/project.js +3 -3
- package/esm/app/controller/view.js +16 -7
- package/esm/app/middleware/api-params-verify.js +10 -1
- package/esm/app/middleware/error-handle.js +9 -3
- package/esm/app/middleware/project-handler.js +1 -1
- package/esm/app/router/view.js +3 -1
- package/esm/app/router-schema/project.js +1 -1
- package/esm/app/service/project.js +5 -0
- package/esm/bundler/defaultAlias.js +4 -0
- package/esm/bundler/dev.js +4 -3
- package/esm/bundler/index.js +2 -1
- package/esm/bundler/prod.js +4 -3
- package/esm/bundler/utils.js +53 -24
- package/esm/index.js +2 -2
- package/esm/packages/common/LRUCache.js +2 -0
- package/esm/packages/common/array/index.js +37 -0
- package/esm/packages/common/cache/LRUCache.js +43 -0
- package/esm/packages/common/cache/index.js +2 -0
- package/esm/packages/common/guards/index.js +26 -0
- package/esm/packages/common/i18n/default.js +93 -0
- package/esm/packages/common/i18n/en-US.js +93 -0
- package/esm/packages/common/i18n/index.js +162 -0
- package/esm/packages/common/i18n/locales.js +11 -0
- package/esm/packages/common/i18n/types.js +0 -0
- package/esm/packages/common/index.js +13 -0
- package/esm/packages/common/log/index.js +146 -0
- package/esm/packages/common/number/index.js +11 -0
- package/esm/packages/common/object/filterEmpty.js +29 -0
- package/esm/packages/common/object/filtereEmpty.js +2 -0
- package/esm/packages/common/object/index.js +20 -0
- package/esm/packages/common/string/index.js +13 -0
- package/esm/packages/common/types/index.js +0 -0
- package/esm/packages/core/index.js +17 -12
- package/esm/packages/core/loader/model.js +3 -3
- package/esm/packages/core/loader/router.js +14 -5
- package/fe/frontend/dash/Dashboard.d.ts +7 -0
- package/fe/frontend/dash/Dashboard.js +63 -0
- package/fe/frontend/dash/dash.entry.d.ts +2 -0
- package/fe/frontend/dash/dash.entry.js +62 -0
- package/fe/frontend/index.d.ts +3 -0
- package/fe/frontend/index.js +1 -0
- package/fe/frontend/main.css +5 -1
- package/fe/frontend/main.d.ts +10 -3
- package/fe/frontend/main.js +13 -4
- package/fe/frontend/testPage/testPage.entry.js +1 -2
- package/fe/frontend/typing/window.d.ts +7 -0
- package/fe/frontend/typing/window.js +1 -0
- package/fe/frontend/widgets/api/baseInfo.d.ts +31 -0
- package/fe/frontend/widgets/api/baseInfo.js +15 -0
- package/fe/frontend/widgets/common/CRUD/CRUD.d.ts +70 -0
- package/fe/frontend/widgets/common/CRUD/CRUD.js +207 -0
- package/fe/frontend/widgets/common/CRUD/index.d.ts +2 -0
- package/fe/frontend/widgets/common/CRUD/index.js +1 -0
- package/fe/frontend/widgets/common/auth/index.d.ts +7 -0
- package/fe/frontend/widgets/common/auth/index.js +20 -0
- package/fe/frontend/widgets/common/generateMenuData.d.ts +4 -0
- package/fe/frontend/widgets/common/generateMenuData.js +14 -0
- package/fe/frontend/widgets/common/importComponent.d.ts +5 -0
- package/fe/frontend/widgets/common/importComponent.js +7 -0
- package/fe/frontend/widgets/common/language.d.ts +2 -0
- package/fe/frontend/widgets/common/language.js +8 -0
- package/fe/frontend/widgets/common/logFn/index.d.ts +4 -0
- package/fe/frontend/widgets/common/logFn/index.js +8 -0
- package/fe/frontend/widgets/common/menu.d.ts +22 -0
- package/fe/frontend/widgets/common/menu.js +80 -0
- package/fe/frontend/widgets/common/request.d.ts +33 -0
- package/fe/frontend/widgets/common/request.js +127 -0
- package/fe/frontend/widgets/components/BasePage/HeaderView.d.ts +9 -0
- package/fe/frontend/widgets/components/BasePage/HeaderView.js +14 -0
- package/fe/frontend/widgets/components/Router/index.d.ts +9 -0
- package/fe/frontend/widgets/components/Router/index.js +11 -0
- package/fe/frontend/widgets/components/Router/type.d.ts +2 -0
- package/fe/frontend/widgets/components/Router/type.js +1 -0
- package/fe/frontend/widgets/defaultPages/Iframe/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Iframe/index.js +14 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/DetailPanel.d.ts +7 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/DetailPanel.js +94 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/PopFrom.d.ts +13 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/PopFrom.js +109 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/data.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/data.js +6 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaSearch/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaSearch/index.js +58 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaTable/index.d.ts +11 -0
- package/fe/frontend/widgets/defaultPages/Schema/components/SchemaTable/index.js +176 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/eventInfo.d.ts +8 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/eventInfo.js +6 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/data/index.js +1 -0
- package/fe/frontend/widgets/defaultPages/Schema/hooks/useComConfig.d.ts +10 -0
- package/fe/frontend/widgets/defaultPages/Schema/hooks/useComConfig.js +14 -0
- package/fe/frontend/widgets/defaultPages/Schema/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/index.js +67 -0
- package/fe/frontend/widgets/defaultPages/Schema/schemaType.d.ts +41 -0
- package/fe/frontend/widgets/defaultPages/Schema/schemaType.js +4 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaEventBus.d.ts +23 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaEventBus.js +66 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaStore.d.ts +33 -0
- package/fe/frontend/widgets/defaultPages/Schema/stores/schemaStore.js +24 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/fetchErrorShow.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/fetchErrorShow.js +8 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/permissions.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/permissions.js +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/schemaConversion.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/schemaConversion.js +72 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/validator.d.ts +4 -0
- package/fe/frontend/widgets/defaultPages/Schema/utils/validator.js +31 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/SidebarSlotContainer.d.ts +10 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/SidebarSlotContainer.js +31 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPage/index.js +15 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPageTmp.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/SidebarSlotPageTmp.js +17 -0
- package/fe/frontend/widgets/defaultPages/SlotPage/index.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/SlotPage/index.js +24 -0
- package/fe/frontend/widgets/defaultPages/Todo.d.ts +3 -0
- package/fe/frontend/widgets/defaultPages/Todo.js +5 -0
- package/fe/frontend/widgets/hooks/useCurrentMenuData.d.ts +11 -0
- package/fe/frontend/widgets/hooks/useCurrentMenuData.js +20 -0
- package/fe/frontend/widgets/hooks/useRouterParams.d.ts +5 -0
- package/fe/frontend/widgets/hooks/useRouterParams.js +11 -0
- package/fe/frontend/widgets/store/mode.d.ts +16 -0
- package/fe/frontend/widgets/store/mode.js +36 -0
- package/fe/model/types/data/button.d.ts +23 -0
- package/fe/model/types/data/button.js +1 -0
- package/fe/model/types/data/component.d.ts +37 -0
- package/fe/model/types/data/component.js +1 -0
- package/fe/model/types/data/fetchInfo.d.ts +8 -0
- package/fe/model/types/data/fetchInfo.js +1 -0
- package/fe/model/types/data/schema.d.ts +47 -0
- package/fe/model/types/data/schema.js +1 -0
- package/fe/model/types/data/search.d.ts +7 -0
- package/fe/model/types/data/search.js +1 -0
- package/fe/model/types/menuType.d.ts +44 -0
- package/fe/model/types/menuType.js +1 -0
- package/fe/model/types/model.d.ts +20 -0
- package/fe/model/types/model.js +1 -0
- package/fe/packages/common/array/index.d.ts +7 -0
- package/fe/packages/common/array/index.js +40 -0
- package/fe/packages/common/cache/LRUCache.d.ts +13 -0
- package/fe/packages/common/cache/LRUCache.js +47 -0
- package/fe/packages/common/cache/index.d.ts +2 -0
- package/fe/packages/common/cache/index.js +1 -0
- package/fe/packages/common/guards/index.d.ts +9 -0
- package/fe/packages/common/guards/index.js +24 -0
- package/fe/packages/common/i18n/default.d.ts +87 -0
- package/fe/packages/common/i18n/default.js +85 -0
- package/fe/packages/common/i18n/en-US.d.ts +87 -0
- package/fe/packages/common/i18n/en-US.js +85 -0
- package/fe/packages/common/i18n/index.d.ts +19 -0
- package/fe/packages/common/i18n/index.js +142 -0
- package/fe/packages/common/i18n/locales.d.ts +8 -0
- package/fe/packages/common/i18n/locales.js +10 -0
- package/fe/packages/common/i18n/types.d.ts +47 -0
- package/fe/packages/common/i18n/types.js +1 -0
- package/fe/packages/common/index.d.ts +10 -0
- package/fe/packages/common/index.js +9 -0
- package/fe/packages/common/log/index.d.ts +33 -0
- package/fe/packages/common/log/index.js +176 -0
- package/fe/packages/common/number/index.d.ts +3 -0
- package/fe/packages/common/number/index.js +10 -0
- package/fe/packages/common/object/filterEmpty.d.ts +3 -0
- package/fe/packages/common/object/filterEmpty.js +33 -0
- package/fe/packages/common/object/index.d.ts +5 -0
- package/fe/packages/common/object/index.js +25 -0
- package/fe/packages/common/string/index.d.ts +4 -0
- package/fe/packages/common/string/index.js +17 -0
- package/fe/packages/common/types/index.d.ts +4 -0
- package/fe/packages/common/types/index.js +1 -0
- package/fe/packages/ui/react/components/Button/Button.d.ts +16 -30
- package/fe/packages/ui/react/components/Button/Button.js +53 -26
- package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +2 -6
- package/fe/packages/ui/react/components/Button/SumbitButton.js +3 -14
- package/fe/packages/ui/react/components/Button/index.d.ts +1 -1
- package/fe/packages/ui/react/components/Checkbox/Checkbox.d.ts +1 -1
- package/fe/packages/ui/react/components/Checkbox/Checkbox.js +5 -3
- package/fe/packages/ui/react/components/{ConfirmDialog.d.ts → ConfirmDialog/ConfirmDialog.d.ts} +0 -8
- package/fe/packages/ui/react/components/ConfirmDialog/ConfirmDialog.js +11 -0
- package/fe/packages/ui/react/components/ConfirmDialog/index.d.ts +2 -0
- package/fe/packages/ui/react/components/ConfirmDialog/index.js +1 -0
- package/fe/packages/ui/react/components/DataTable/ActionBtn.d.ts +3 -1
- package/fe/packages/ui/react/components/DataTable/ActionBtn.js +85 -4
- package/fe/packages/ui/react/components/DataTable/{data-table.d.ts → index.d.ts} +10 -23
- package/fe/packages/ui/react/components/DataTable/{data-table.js → index.js} +57 -47
- package/fe/packages/ui/react/components/Date/Calendar.d.ts +0 -13
- package/fe/packages/ui/react/components/Date/Calendar.js +5 -13
- package/fe/packages/ui/react/components/Date/Date.d.ts +4 -13
- package/fe/packages/ui/react/components/Date/Date.js +70 -66
- package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +0 -4
- package/fe/packages/ui/react/components/Date/LocaleContext.js +0 -4
- package/fe/packages/ui/react/components/Date/LocaleProvider.d.ts +0 -11
- package/fe/packages/ui/react/components/Date/LocaleProvider.js +0 -11
- package/fe/packages/ui/react/components/Date/TimePicker.js +3 -2
- package/fe/packages/ui/react/components/Date/dateLocaleStore.d.ts +0 -6
- package/fe/packages/ui/react/components/Date/dropdownPositioning.d.ts +3 -0
- package/fe/packages/ui/react/components/Date/dropdownPositioning.js +12 -0
- package/fe/packages/ui/react/components/Date/locales.d.ts +1 -19
- package/fe/packages/ui/react/components/Date/locales.js +7 -47
- package/fe/packages/ui/react/components/Drawer/Drawer.d.ts +23 -0
- package/fe/packages/ui/react/components/Drawer/Drawer.js +100 -0
- package/fe/packages/ui/react/components/Drawer/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Drawer/index.js +1 -0
- package/fe/packages/ui/react/components/Dropdown/Dropdown.d.ts +24 -0
- package/fe/packages/ui/react/components/Dropdown/Dropdown.js +28 -0
- package/fe/packages/ui/react/components/Dropdown/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Dropdown/index.js +1 -0
- package/fe/packages/ui/react/components/Form/Form.d.ts +0 -6
- package/fe/packages/ui/react/components/Form/Form.js +1 -1
- package/fe/packages/ui/react/components/Form/FormItem.d.ts +0 -21
- package/fe/packages/ui/react/components/Form/FormItem.js +2 -9
- package/fe/packages/ui/react/components/Form/SchemaForm/data.d.ts +45 -0
- package/fe/packages/ui/react/components/Form/{SchemeForm → SchemaForm}/data.js +8 -1
- package/fe/packages/ui/react/components/Form/SchemaForm/index.d.ts +60 -0
- package/fe/packages/ui/react/components/Form/SchemaForm/index.js +75 -0
- package/fe/packages/ui/react/components/Form/index.d.ts +1 -1
- package/fe/packages/ui/react/components/Form/index.js +1 -1
- package/fe/packages/ui/react/components/ImagePreview/ImagePreview.js +15 -20
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.d.ts +0 -3
- package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +5 -2
- package/fe/packages/ui/react/components/Input/Input.d.ts +3 -21
- package/fe/packages/ui/react/components/Input/Input.js +5 -7
- package/fe/packages/ui/react/components/InputNumber/InputNumber.d.ts +26 -0
- package/fe/packages/ui/react/components/InputNumber/InputNumber.js +144 -0
- package/fe/packages/ui/react/components/InputNumber/index.d.ts +2 -0
- package/fe/packages/ui/react/components/InputNumber/index.js +1 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.d.ts +30 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.js +63 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.test.d.ts +2 -0
- package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.test.js +27 -0
- package/fe/packages/ui/react/components/Label/Label.d.ts +0 -29
- package/fe/packages/ui/react/components/Label/Label.js +2 -4
- package/fe/packages/ui/react/components/Menu/Menu.d.ts +18 -0
- package/fe/packages/ui/react/components/Menu/Menu.js +98 -0
- package/fe/packages/ui/react/components/Menu/MenuContext.d.ts +39 -0
- package/fe/packages/ui/react/components/Menu/MenuContext.js +97 -0
- package/fe/packages/ui/react/components/Menu/MenuItem.d.ts +3 -0
- package/fe/packages/ui/react/components/Menu/MenuItem.js +33 -0
- package/fe/packages/ui/react/components/Menu/SubMenu.d.ts +3 -0
- package/fe/packages/ui/react/components/Menu/SubMenu.js +124 -0
- package/fe/packages/ui/react/components/Menu/index.d.ts +9 -0
- package/fe/packages/ui/react/components/Menu/index.js +5 -0
- package/fe/packages/ui/react/components/Menu/menuTypes.d.ts +58 -0
- package/fe/packages/ui/react/components/Menu/menuTypes.js +1 -0
- package/fe/packages/ui/react/components/Menu/utils.d.ts +2 -0
- package/fe/packages/ui/react/components/Menu/utils.js +7 -0
- package/fe/packages/ui/react/components/Message/Message.d.ts +0 -7
- package/fe/packages/ui/react/components/Message/Message.js +4 -4
- package/fe/packages/ui/react/components/Message/MessageManager.js +0 -8
- package/fe/packages/ui/react/components/Modal/Modal.d.ts +3 -7
- package/fe/packages/ui/react/components/Modal/Modal.js +6 -44
- package/fe/packages/ui/react/components/Modal/ModalManager.d.ts +0 -12
- package/fe/packages/ui/react/components/Modal/ModalManager.js +5 -7
- package/fe/packages/ui/react/components/Overlay/Overlay.d.ts +20 -0
- package/fe/packages/ui/react/components/Overlay/Overlay.js +53 -0
- package/fe/packages/ui/react/components/Overlay/index.d.ts +3 -0
- package/fe/packages/ui/react/components/Overlay/index.js +1 -0
- package/fe/packages/ui/react/components/{Pagination.d.ts → Pagination/Pagination.d.ts} +0 -7
- package/fe/packages/ui/react/components/{Pagination.js → Pagination/Pagination.js} +5 -12
- package/fe/packages/ui/react/components/Pagination/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Pagination/index.js +1 -0
- package/fe/packages/ui/react/components/Popup/Popup.d.ts +26 -0
- package/fe/packages/ui/react/components/Popup/Popup.js +69 -0
- package/fe/packages/ui/react/components/Popup/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Popup/index.js +1 -0
- package/fe/packages/ui/react/components/Search/Search.d.ts +2 -5
- package/fe/packages/ui/react/components/Search/Search.js +3 -3
- package/fe/packages/ui/react/components/Select/Select.d.ts +2 -2
- package/fe/packages/ui/react/components/Select/Select.js +52 -113
- package/fe/packages/ui/react/components/Select/dropdownPositioning.d.ts +3 -0
- package/fe/packages/ui/react/components/Select/dropdownPositioning.js +13 -0
- package/fe/packages/ui/react/components/Skeleton/Skeleton.d.ts +0 -15
- package/fe/packages/ui/react/components/Skeleton/Skeleton.js +3 -3
- package/fe/packages/ui/react/components/Switch/Switch.js +3 -1
- package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +5 -41
- package/fe/packages/ui/react/components/TableSearch/TableSearch.js +21 -22
- package/fe/packages/ui/react/components/TableSearch/lang.js +5 -14
- package/fe/packages/ui/react/components/Textarea/Textarea.d.ts +21 -0
- package/fe/packages/ui/react/components/Textarea/Textarea.js +36 -0
- package/fe/packages/ui/react/components/Textarea/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Textarea/index.js +1 -0
- package/fe/packages/ui/react/components/Tooltip/Tooltip.d.ts +9 -0
- package/fe/packages/ui/react/components/Tooltip/Tooltip.js +71 -0
- package/fe/packages/ui/react/components/Tooltip/index.d.ts +2 -0
- package/fe/packages/ui/react/components/Tooltip/index.js +1 -0
- package/fe/packages/ui/react/components/{TreeSelect.d.ts → TreeSelect/TreeSelect.d.ts} +0 -6
- package/fe/packages/ui/react/components/{TreeSelect.js → TreeSelect/TreeSelect.js} +9 -17
- package/fe/packages/ui/react/components/TreeSelect/index.d.ts +2 -0
- package/fe/packages/ui/react/components/TreeSelect/index.js +1 -0
- package/fe/packages/ui/react/components/Upload/ImageUpload.js +18 -6
- package/fe/packages/ui/react/components/Upload/Upload.d.ts +0 -27
- package/fe/packages/ui/react/components/Upload/Upload.js +2 -1
- package/fe/packages/ui/react/components/{breadcrumb.js → breadcrumb/breadcrumb.js} +15 -21
- package/fe/packages/ui/react/components/breadcrumb/index.d.ts +2 -0
- package/fe/packages/ui/react/components/breadcrumb/index.js +1 -0
- package/fe/packages/ui/react/components/hooks/useDropdownPositioning.d.ts +43 -0
- package/fe/packages/ui/react/components/hooks/useDropdownPositioning.js +123 -0
- package/fe/packages/ui/react/components/hooks/useInputController.d.ts +0 -3
- package/fe/packages/ui/react/components/hooks/useInputController.js +0 -7
- package/fe/packages/ui/react/components/index.d.ts +7 -1
- package/fe/packages/ui/react/components/index.js +7 -1
- package/fe/packages/ui/react/components/table/index.d.ts +2 -0
- package/fe/packages/ui/react/components/table/index.js +1 -0
- package/fe/packages/ui/react/components/table/table.js +20 -0
- package/fe/packages/ui/react/components/testPage/MenuTestPage.d.ts +2 -0
- package/fe/packages/ui/react/components/testPage/MenuTestPage.js +101 -0
- package/fe/packages/ui/react/components/testPage/index.js +251 -81
- package/fe/packages/ui/react/hooks/useExecuteOnce.d.ts +12 -0
- package/fe/packages/ui/react/hooks/useExecuteOnce.js +36 -0
- package/fe/packages/ui/react/hooks/useInit.d.ts +1 -1
- package/fe/packages/ui/react/hooks/useInit.js +1 -1
- package/fe/packages/ui/react/hooks/useLanguage.d.ts +1 -6
- package/fe/packages/ui/react/hooks/useRefState.d.ts +18 -0
- package/fe/packages/ui/react/hooks/useRefState.js +28 -0
- package/fe/packages/ui/react/hooks/useWatch.d.ts +15 -0
- package/fe/packages/ui/react/hooks/useWatch.js +87 -0
- package/fe/packages/ui/react/hooks/useWatch.test.d.ts +2 -0
- package/fe/packages/ui/react/hooks/useWatch.test.js +22 -0
- package/fe/packages/ui/react/i18n/I18nProvider.d.ts +13 -0
- package/fe/packages/ui/react/i18n/I18nProvider.js +25 -0
- package/fe/packages/ui/react/i18n/index.d.ts +4 -0
- package/fe/packages/ui/react/i18n/index.js +3 -0
- package/fe/packages/ui/react/i18n/useI18n.d.ts +9 -0
- package/fe/packages/ui/react/i18n/useI18n.js +14 -0
- package/fe/packages/ui/react/index.css +238 -0
- package/fe/packages/ui/react/index.d.ts +2 -0
- package/fe/packages/ui/react/index.js +2 -2
- package/fe/packages/ui/react/lib/createStoreHook.d.ts +9 -0
- package/fe/packages/ui/react/lib/createStoreHook.js +6 -0
- package/fe/packages/ui/react/lib/export.d.ts +2 -46
- package/fe/packages/ui/react/lib/export.js +0 -40
- package/fe/packages/ui/react/lib/utils.d.ts +0 -24
- package/fe/packages/ui/react/lib/utils.js +0 -25
- package/fe/packages/ui/react/stores/breadcrumb.js +0 -2
- package/fe/packages/ui/react/stores/language.d.ts +3 -12
- package/fe/packages/ui/react/stores/language.js +2 -51
- package/fe/typings/type.d.ts +5 -0
- package/fe/typings/type.js +1 -0
- package/package.json +14 -2
- package/types/app/controller/base.d.ts +3 -3
- package/types/app/router/view.d.ts +2 -3
- package/types/app/service/project.d.ts +29 -4
- package/types/app/type.d.ts +1 -0
- package/types/app/typings.d.ts +12 -21
- package/types/bundler/defaultAlias.d.ts +3 -0
- package/types/bundler/utils.d.ts +1 -1
- package/types/config/config.default.d.ts +14 -0
- package/types/packages/common/LRUCache.d.ts +1 -0
- package/types/packages/common/array/index.d.ts +6 -0
- package/types/packages/common/cache/LRUCache.d.ts +12 -0
- package/types/packages/common/cache/index.d.ts +1 -0
- package/types/packages/common/guards/index.d.ts +8 -0
- package/types/packages/common/i18n/default.d.ts +86 -0
- package/types/packages/common/i18n/en-US.d.ts +86 -0
- package/types/packages/common/i18n/index.d.ts +18 -0
- package/types/packages/common/i18n/locales.d.ts +7 -0
- package/types/packages/common/i18n/types.d.ts +46 -0
- package/types/packages/common/index.d.ts +9 -0
- package/types/packages/common/log/index.d.ts +32 -0
- package/types/packages/common/number/index.d.ts +2 -0
- package/types/packages/common/object/filterEmpty.d.ts +2 -0
- package/types/packages/common/object/filtereEmpty.d.ts +1 -0
- package/types/packages/common/object/index.d.ts +4 -0
- package/types/packages/common/string/index.d.ts +3 -0
- package/types/packages/common/types/index.d.ts +3 -0
- package/types/packages/core/index.d.ts +1 -1
- package/types/packages/core/loader/router.d.ts +1 -1
- package/types/packages/core/types.d.ts +12 -3
- package/fe/packages/ui/react/components/ConfirmDialog.js +0 -9
- package/fe/packages/ui/react/components/Dropdown.d.ts +0 -16
- package/fe/packages/ui/react/components/Dropdown.js +0 -54
- package/fe/packages/ui/react/components/Form/SchemeForm/data.d.ts +0 -51
- package/fe/packages/ui/react/components/Form/SchemeForm/index.d.ts +0 -152
- package/fe/packages/ui/react/components/Form/SchemeForm/index.js +0 -69
- package/fe/packages/ui/react/components/Textarea.d.ts +0 -59
- package/fe/packages/ui/react/components/Textarea.js +0 -35
- package/fe/packages/ui/react/components/Tooltip.d.ts +0 -25
- package/fe/packages/ui/react/components/Tooltip.js +0 -118
- package/fe/packages/ui/react/components/table.js +0 -20
- package/fe/packages/ui/react/locales/index.d.ts +0 -8
- package/fe/packages/ui/react/locales/index.js +0 -6
- /package/fe/packages/ui/react/components/{breadcrumb.d.ts → breadcrumb/breadcrumb.d.ts} +0 -0
- /package/fe/packages/ui/react/components/{table.d.ts → table/table.d.ts} +0 -0
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useMemo, useRef, useState } from 'react';
|
|
3
|
+
import { Outlet, useNavigate } from 'react-router-dom';
|
|
4
|
+
import { generateMenuItemData } from '../widgets/common/generateMenuData';
|
|
5
|
+
import { findMenuItem, leftSidebarBasePath } from '../widgets/common/menu';
|
|
6
|
+
import HeaderView from '../widgets/components/BasePage/HeaderView';
|
|
7
|
+
import useRouterParams from '../widgets/hooks/useRouterParams';
|
|
8
|
+
import { useModeStore } from '../widgets/store/mode';
|
|
9
|
+
import { Menu } from '../../packages/ui/react/components';
|
|
10
|
+
import useInit from '../../packages/ui/react/hooks/useInit';
|
|
11
|
+
const Dashboard = (props) => {
|
|
12
|
+
const { initModeData, initData, projestInfo } = useModeStore();
|
|
13
|
+
useInit(initModeData);
|
|
14
|
+
const isInit = useRef(false);
|
|
15
|
+
const params = useRouterParams();
|
|
16
|
+
const [SK, uSK] = useState(params.key ?? params.custk);
|
|
17
|
+
const nav = useNavigate();
|
|
18
|
+
const menu = useMemo(() => {
|
|
19
|
+
if (initData && projestInfo?.menuLayout === 'top') {
|
|
20
|
+
const menuData = generateMenuItemData(projestInfo.menu);
|
|
21
|
+
return (_jsx(Menu, { className: " w-full", mode: "top", items: menuData, selectedKey: SK, onSelect: (e) => {
|
|
22
|
+
uSK(e);
|
|
23
|
+
const m = findMenuItem(projestInfo.menu, e);
|
|
24
|
+
m && nav(m?.path);
|
|
25
|
+
} }));
|
|
26
|
+
}
|
|
27
|
+
return _jsx(_Fragment, {});
|
|
28
|
+
}, [initData, projestInfo, SK, nav]);
|
|
29
|
+
useEffect(() => {
|
|
30
|
+
if (initData && projestInfo) {
|
|
31
|
+
if (isInit.current)
|
|
32
|
+
return;
|
|
33
|
+
if (projestInfo.menuLayout !== 'top') {
|
|
34
|
+
console.log('left sidebar');
|
|
35
|
+
if (Object.keys(params).length && location.pathname.includes(`/${leftSidebarBasePath}`)) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const m = findMenuItem(projestInfo.menu);
|
|
39
|
+
nav({
|
|
40
|
+
pathname: `/${leftSidebarBasePath}${m.path.pathname}`,
|
|
41
|
+
search: m.path.search,
|
|
42
|
+
}, {
|
|
43
|
+
replace: true,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
console.log('top sidebar');
|
|
48
|
+
if (!Object.keys(params).length ||
|
|
49
|
+
location.pathname.includes(`/${leftSidebarBasePath}`)) {
|
|
50
|
+
const m = findMenuItem(projestInfo.menu);
|
|
51
|
+
uSK(m.key);
|
|
52
|
+
nav(m.path, {
|
|
53
|
+
replace: true,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
isInit.current = true;
|
|
58
|
+
}
|
|
59
|
+
}, [initData, projestInfo, params, nav]);
|
|
60
|
+
return (_jsxs("div", { className: "dash-main h-screen flex flex-col", children: [_jsx(HeaderView, { title: projestInfo?.desc, menu: menu }), _jsx("div", { className: "dash-container p-1.5 flex-1", children: _jsx(Outlet, {}) })] }));
|
|
61
|
+
};
|
|
62
|
+
Dashboard.displayName = 'Dashboard';
|
|
63
|
+
export default Dashboard;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { renderImportComponent } from '../widgets/common/importComponent';
|
|
3
|
+
import { leftSidebarBasePath, QK } from '../widgets/common/menu';
|
|
4
|
+
import { initApp } from '../main';
|
|
5
|
+
import Dashboard from './Dashboard';
|
|
6
|
+
const baseRoutes = [
|
|
7
|
+
{
|
|
8
|
+
path: '/',
|
|
9
|
+
component: _jsx(Dashboard, {}),
|
|
10
|
+
children: [
|
|
11
|
+
{
|
|
12
|
+
path: `/:${QK.k}`,
|
|
13
|
+
component: renderImportComponent(import('../widgets/defaultPages/SlotPage')),
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
path: `/testPage`,
|
|
17
|
+
component: renderImportComponent(import('../testPage')),
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
path: `todo`,
|
|
21
|
+
component: renderImportComponent(import('../widgets/defaultPages/Todo')),
|
|
22
|
+
},
|
|
23
|
+
],
|
|
24
|
+
},
|
|
25
|
+
];
|
|
26
|
+
const sidebarRoutes = [
|
|
27
|
+
{
|
|
28
|
+
path: `/:${QK.k}/*`,
|
|
29
|
+
component: renderImportComponent(import('../widgets/defaultPages/SidebarSlotPage')),
|
|
30
|
+
children: [
|
|
31
|
+
{
|
|
32
|
+
path: `todo`,
|
|
33
|
+
component: renderImportComponent(import('../widgets/defaultPages/Todo')),
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
path: `:${QK.sk}`,
|
|
37
|
+
component: renderImportComponent(import('../widgets/defaultPages/SlotPage')),
|
|
38
|
+
},
|
|
39
|
+
],
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
path: `/${leftSidebarBasePath}/*`,
|
|
43
|
+
component: renderImportComponent(import('../widgets/defaultPages/SidebarSlotPageTmp')),
|
|
44
|
+
children: [
|
|
45
|
+
{
|
|
46
|
+
path: `todo`,
|
|
47
|
+
component: renderImportComponent(import('../widgets/defaultPages/Todo')),
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
path: `:${QK.sk}`,
|
|
51
|
+
component: renderImportComponent(import('../widgets/defaultPages/SlotPage')),
|
|
52
|
+
},
|
|
53
|
+
],
|
|
54
|
+
},
|
|
55
|
+
];
|
|
56
|
+
const getDefaultPageRoutes = () => {
|
|
57
|
+
baseRoutes[0].children?.push(...sidebarRoutes);
|
|
58
|
+
return [...baseRoutes];
|
|
59
|
+
};
|
|
60
|
+
initApp(({ children }) => _jsx("div", { className: "dash", children: children }), {
|
|
61
|
+
routes: getDefaultPageRoutes(),
|
|
62
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './main';
|
package/fe/frontend/main.css
CHANGED
package/fe/frontend/main.d.ts
CHANGED
|
@@ -1,4 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
|
|
1
|
+
import { PropsWithChildren } from "react";
|
|
2
|
+
import type { JSX } from "react/jsx-runtime";
|
|
3
|
+
import "./main.css";
|
|
4
|
+
import "./typing/window";
|
|
5
|
+
import { RouterType } from "./widgets/components/Router/type";
|
|
6
|
+
import { RouteInfo } from "./widgets/components/Router";
|
|
7
|
+
export declare const initApp: (RootComponent: (props: PropsWithChildren) => JSX.Element, options?: {
|
|
8
|
+
routes: RouteInfo[];
|
|
9
|
+
routerType?: RouterType;
|
|
10
|
+
}) => void;
|
|
4
11
|
//# sourceMappingURL=main.d.ts.map
|
package/fe/frontend/main.js
CHANGED
|
@@ -1,7 +1,16 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
1
2
|
import { createRoot } from "react-dom/client";
|
|
2
|
-
import
|
|
3
|
-
|
|
3
|
+
import "./main.css";
|
|
4
|
+
import "./typing/window";
|
|
5
|
+
import { generateRouter } from "./widgets/components/Router";
|
|
6
|
+
export const initApp = (RootComponent, options) => {
|
|
4
7
|
const root = createRoot(document.getElementById("root"));
|
|
5
|
-
|
|
6
|
-
|
|
8
|
+
const { routerType = "browser", routes: pRoutes = [] } = options ?? {};
|
|
9
|
+
const routes = [...pRoutes];
|
|
10
|
+
const usedRouter = !!routes.length;
|
|
11
|
+
let routerDom;
|
|
12
|
+
if (usedRouter) {
|
|
13
|
+
routerDom = generateRouter(routes, routerType);
|
|
14
|
+
}
|
|
15
|
+
root.render(_jsx(RootComponent, { children: routerDom }));
|
|
7
16
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { ModeMenuType } from '../../../model/types/model';
|
|
2
|
+
type ProjectMenuType = ModeMenuType;
|
|
3
|
+
export type ModelInfo = {
|
|
4
|
+
model: {
|
|
5
|
+
key: string;
|
|
6
|
+
name: string;
|
|
7
|
+
desc: string;
|
|
8
|
+
};
|
|
9
|
+
project: {
|
|
10
|
+
[k: string]: {
|
|
11
|
+
key: string;
|
|
12
|
+
name: string;
|
|
13
|
+
desc: string;
|
|
14
|
+
homePage: string;
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export declare const getModelList: () => Promise<ModelInfo[]>;
|
|
19
|
+
export type ProjectInfo = {
|
|
20
|
+
mode: string;
|
|
21
|
+
homePage: string;
|
|
22
|
+
icon: string;
|
|
23
|
+
name: string;
|
|
24
|
+
desc: string;
|
|
25
|
+
} & ProjectMenuType & {
|
|
26
|
+
key: string;
|
|
27
|
+
modelKey: string;
|
|
28
|
+
};
|
|
29
|
+
export declare const getProjeckData: (key: string) => Promise<ProjectInfo | null>;
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=baseInfo.d.ts.map
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { get } from '../../widgets/common/request';
|
|
2
|
+
export const getModelList = async () => {
|
|
3
|
+
const res = await get('/project/model_list');
|
|
4
|
+
if (res.data.code === 0) {
|
|
5
|
+
return res.data.data;
|
|
6
|
+
}
|
|
7
|
+
return [];
|
|
8
|
+
};
|
|
9
|
+
export const getProjeckData = async (key) => {
|
|
10
|
+
const res = await get(`/project/${key}`);
|
|
11
|
+
if (res.data.code === 0) {
|
|
12
|
+
return res.data.data;
|
|
13
|
+
}
|
|
14
|
+
return null;
|
|
15
|
+
};
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export interface RequestConfig<D = unknown> {
|
|
2
|
+
url?: string;
|
|
3
|
+
method?: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH' | 'HEAD' | 'OPTIONS';
|
|
4
|
+
baseURL?: string;
|
|
5
|
+
headers?: Record<string, string>;
|
|
6
|
+
params?: Record<string, string | number | boolean | undefined | null>;
|
|
7
|
+
data?: D;
|
|
8
|
+
timeout?: number;
|
|
9
|
+
signal?: AbortSignal;
|
|
10
|
+
credentials?: RequestCredentials;
|
|
11
|
+
cache?: RequestCache;
|
|
12
|
+
redirect?: RequestRedirect;
|
|
13
|
+
referrer?: string;
|
|
14
|
+
referrerPolicy?: ReferrerPolicy;
|
|
15
|
+
transformRequest?: ((data: D, headers: Headers) => D | string | ArrayBuffer | Blob) | ((data: D, headers: Headers) => D | string | ArrayBuffer | Blob)[];
|
|
16
|
+
transformResponse?: ((data: unknown) => unknown) | ((data: unknown) => unknown)[];
|
|
17
|
+
validateStatus?: (status: number) => boolean;
|
|
18
|
+
onUploadProgress?: (progress: ProgressEvent) => void;
|
|
19
|
+
onDownloadProgress?: (progress: ProgressEvent) => void;
|
|
20
|
+
}
|
|
21
|
+
export interface ResponseConfig<T = unknown, D = unknown> {
|
|
22
|
+
data: T;
|
|
23
|
+
status: number;
|
|
24
|
+
statusText: string;
|
|
25
|
+
headers: Record<string, string>;
|
|
26
|
+
config: RequestConfig<D>;
|
|
27
|
+
request?: Request;
|
|
28
|
+
}
|
|
29
|
+
export interface AxiosError<T = unknown, D = unknown> extends Error {
|
|
30
|
+
config: RequestConfig<D>;
|
|
31
|
+
code?: string;
|
|
32
|
+
request?: Request;
|
|
33
|
+
response?: ResponseConfig<T, D>;
|
|
34
|
+
isAxiosError: boolean;
|
|
35
|
+
}
|
|
36
|
+
interface InterceptorHandler<V> {
|
|
37
|
+
fulfilled?: (value: V) => V | Promise<V>;
|
|
38
|
+
rejected?: (error: unknown) => unknown;
|
|
39
|
+
id: number;
|
|
40
|
+
}
|
|
41
|
+
declare class InterceptorManager<V> {
|
|
42
|
+
private handlers;
|
|
43
|
+
private nextId;
|
|
44
|
+
use(onFulfilled?: (value: V) => V | Promise<V>, onRejected?: (error: unknown) => unknown): number;
|
|
45
|
+
eject(id: number): void;
|
|
46
|
+
clear(): void;
|
|
47
|
+
getHandlers(): InterceptorHandler<V>[];
|
|
48
|
+
}
|
|
49
|
+
export declare class FetchAxios {
|
|
50
|
+
defaults: RequestConfig;
|
|
51
|
+
interceptors: {
|
|
52
|
+
request: InterceptorManager<RequestConfig<unknown>>;
|
|
53
|
+
response: InterceptorManager<ResponseConfig<unknown, unknown>>;
|
|
54
|
+
};
|
|
55
|
+
constructor(config?: RequestConfig);
|
|
56
|
+
private request;
|
|
57
|
+
private _doRequest;
|
|
58
|
+
private createError;
|
|
59
|
+
get<T = unknown, D = unknown>(url: string, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
60
|
+
post<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
61
|
+
put<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
62
|
+
patch<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
63
|
+
delete<T = unknown, D = unknown>(url: string, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
64
|
+
head<T = unknown, D = unknown>(url: string, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
65
|
+
options<T = unknown, D = unknown>(url: string, config?: RequestConfig<D>): Promise<ResponseConfig<T, D>>;
|
|
66
|
+
}
|
|
67
|
+
export declare const axios: FetchAxios;
|
|
68
|
+
export declare const createInstance: (defaultConfig: RequestConfig) => FetchAxios;
|
|
69
|
+
export default FetchAxios;
|
|
70
|
+
//# sourceMappingURL=CRUD.d.ts.map
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
class InterceptorManager {
|
|
2
|
+
handlers = [];
|
|
3
|
+
nextId = 0;
|
|
4
|
+
use(onFulfilled, onRejected) {
|
|
5
|
+
const id = this.nextId++;
|
|
6
|
+
this.handlers.push({ id, fulfilled: onFulfilled, rejected: onRejected });
|
|
7
|
+
return id;
|
|
8
|
+
}
|
|
9
|
+
eject(id) {
|
|
10
|
+
const idx = this.handlers.findIndex((h) => h.id === id);
|
|
11
|
+
if (idx !== -1)
|
|
12
|
+
this.handlers.splice(idx, 1);
|
|
13
|
+
}
|
|
14
|
+
clear() {
|
|
15
|
+
this.handlers = [];
|
|
16
|
+
}
|
|
17
|
+
getHandlers() {
|
|
18
|
+
return this.handlers;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function buildURL(url, baseURL, params) {
|
|
22
|
+
let fullUrl = baseURL ? `${baseURL.replace(/\/+$/, '')}/${url.replace(/^\/+/, '')}` : url;
|
|
23
|
+
if (params) {
|
|
24
|
+
const searchParams = new URLSearchParams();
|
|
25
|
+
for (const [key, value] of Object.entries(params)) {
|
|
26
|
+
if (value !== undefined && value !== null) {
|
|
27
|
+
searchParams.append(key, String(value));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
const query = searchParams.toString();
|
|
31
|
+
if (query) {
|
|
32
|
+
fullUrl += (fullUrl.includes('?') ? '&' : '?') + query;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return fullUrl;
|
|
36
|
+
}
|
|
37
|
+
function parseHeaders(rawHeaders) {
|
|
38
|
+
const headers = {};
|
|
39
|
+
rawHeaders.forEach((value, key) => {
|
|
40
|
+
headers[key] = value;
|
|
41
|
+
});
|
|
42
|
+
return headers;
|
|
43
|
+
}
|
|
44
|
+
function mergeConfig(primary, secondary) {
|
|
45
|
+
return {
|
|
46
|
+
...secondary,
|
|
47
|
+
...primary,
|
|
48
|
+
headers: {
|
|
49
|
+
...secondary?.headers,
|
|
50
|
+
...primary.headers,
|
|
51
|
+
},
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
function isObject(value) {
|
|
55
|
+
return Object.prototype.toString.call(value) === '[object Object]';
|
|
56
|
+
}
|
|
57
|
+
function applyTransformers(value, transformers) {
|
|
58
|
+
if (!transformers?.length)
|
|
59
|
+
return value;
|
|
60
|
+
return transformers.reduce((acc, fn) => fn(acc), value);
|
|
61
|
+
}
|
|
62
|
+
export class FetchAxios {
|
|
63
|
+
defaults;
|
|
64
|
+
interceptors = {
|
|
65
|
+
request: new InterceptorManager(),
|
|
66
|
+
response: new InterceptorManager(),
|
|
67
|
+
};
|
|
68
|
+
constructor(config = {}) {
|
|
69
|
+
this.defaults = config;
|
|
70
|
+
}
|
|
71
|
+
async request(config) {
|
|
72
|
+
const merged = mergeConfig(this.defaults, config);
|
|
73
|
+
const chain = [];
|
|
74
|
+
this.interceptors.request.getHandlers().forEach((h) => {
|
|
75
|
+
chain.unshift({
|
|
76
|
+
fulfilled: h.fulfilled,
|
|
77
|
+
rejected: h.rejected,
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
chain.push({
|
|
81
|
+
fulfilled: (cfg) => Promise.resolve(cfg),
|
|
82
|
+
rejected: undefined,
|
|
83
|
+
});
|
|
84
|
+
this.interceptors.response.getHandlers().forEach((h) => {
|
|
85
|
+
chain.push({
|
|
86
|
+
fulfilled: h.fulfilled,
|
|
87
|
+
rejected: h.rejected,
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
let currentConfig = merged;
|
|
91
|
+
for (let i = 0; i < chain.length; i++) {
|
|
92
|
+
const item = chain[i];
|
|
93
|
+
const { fulfilled, rejected } = item;
|
|
94
|
+
try {
|
|
95
|
+
currentConfig = await fulfilled(currentConfig);
|
|
96
|
+
}
|
|
97
|
+
catch (err) {
|
|
98
|
+
if (rejected) {
|
|
99
|
+
void (await rejected(err));
|
|
100
|
+
}
|
|
101
|
+
throw err;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return this._doRequest(currentConfig);
|
|
105
|
+
}
|
|
106
|
+
async _doRequest(config) {
|
|
107
|
+
const { method = 'GET', baseURL, headers: rawHeaders = {}, params, data, timeout, credentials, cache, redirect, referrer, referrerPolicy, transformRequest, transformResponse, validateStatus, } = config;
|
|
108
|
+
const url = buildURL(config.url ?? '', baseURL, params);
|
|
109
|
+
const requestHeaders = new Headers(rawHeaders);
|
|
110
|
+
let requestData = data;
|
|
111
|
+
if (transformRequest && (method === 'POST' || method === 'PUT' || method === 'PATCH')) {
|
|
112
|
+
const fns = Array.isArray(transformRequest) ? transformRequest : [transformRequest];
|
|
113
|
+
requestData = applyTransformers(data, fns);
|
|
114
|
+
if (isObject(requestData) || Array.isArray(requestData)) {
|
|
115
|
+
if (!requestHeaders.has('Content-Type')) {
|
|
116
|
+
requestHeaders.set('Content-Type', 'application/json');
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
const init = {
|
|
121
|
+
method,
|
|
122
|
+
headers: requestHeaders,
|
|
123
|
+
credentials: credentials ?? 'same-origin',
|
|
124
|
+
cache: cache,
|
|
125
|
+
redirect: redirect,
|
|
126
|
+
referrer: referrer,
|
|
127
|
+
referrerPolicy: referrerPolicy,
|
|
128
|
+
};
|
|
129
|
+
if (requestData !== undefined && method !== 'GET' && method !== 'HEAD') {
|
|
130
|
+
init.body = typeof requestData === 'string' ? requestData : JSON.stringify(requestData);
|
|
131
|
+
}
|
|
132
|
+
const controller = new AbortController();
|
|
133
|
+
init.signal = config.signal ?? controller.signal;
|
|
134
|
+
let timeoutId;
|
|
135
|
+
if (timeout) {
|
|
136
|
+
timeoutId = setTimeout(() => controller.abort(), timeout);
|
|
137
|
+
}
|
|
138
|
+
let response;
|
|
139
|
+
try {
|
|
140
|
+
response = await fetch(url, init);
|
|
141
|
+
}
|
|
142
|
+
catch (err) {
|
|
143
|
+
if (timeoutId)
|
|
144
|
+
clearTimeout(timeoutId);
|
|
145
|
+
const error = this.createError(err instanceof Error ? err : new Error(String(err)), 'ECONNABORTED', config);
|
|
146
|
+
throw error;
|
|
147
|
+
}
|
|
148
|
+
if (timeoutId)
|
|
149
|
+
clearTimeout(timeoutId);
|
|
150
|
+
const responseHeaders = parseHeaders(response.headers);
|
|
151
|
+
const responseConfig = {
|
|
152
|
+
data: null,
|
|
153
|
+
status: response.status,
|
|
154
|
+
statusText: response.statusText,
|
|
155
|
+
headers: responseHeaders,
|
|
156
|
+
config,
|
|
157
|
+
};
|
|
158
|
+
if (!validateStatus || validateStatus(response.status)) {
|
|
159
|
+
const rawData = await response.text();
|
|
160
|
+
const parsed = rawData ? JSON.parse(rawData) : null;
|
|
161
|
+
const transformedData = transformResponse
|
|
162
|
+
? applyTransformers(parsed, Array.isArray(transformResponse) ? transformResponse : [transformResponse])
|
|
163
|
+
: parsed;
|
|
164
|
+
responseConfig.data = transformedData;
|
|
165
|
+
return responseConfig;
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
const rawData = response.body ? await response.text() : null;
|
|
169
|
+
responseConfig.data = rawData ? JSON.parse(rawData) : null;
|
|
170
|
+
const error = this.createError(new Error(`Request failed with status ${response.status}`), undefined, config, responseConfig);
|
|
171
|
+
throw error;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
createError(message, code, config, response) {
|
|
175
|
+
const error = message;
|
|
176
|
+
error.config = config;
|
|
177
|
+
error.code = code;
|
|
178
|
+
error.response = response;
|
|
179
|
+
error.isAxiosError = true;
|
|
180
|
+
return error;
|
|
181
|
+
}
|
|
182
|
+
get(url, config) {
|
|
183
|
+
return this.request({ ...config, url, method: 'GET' });
|
|
184
|
+
}
|
|
185
|
+
post(url, data, config) {
|
|
186
|
+
return this.request({ ...config, url, method: 'POST', data });
|
|
187
|
+
}
|
|
188
|
+
put(url, data, config) {
|
|
189
|
+
return this.request({ ...config, url, method: 'PUT', data });
|
|
190
|
+
}
|
|
191
|
+
patch(url, data, config) {
|
|
192
|
+
return this.request({ ...config, url, method: 'PATCH', data });
|
|
193
|
+
}
|
|
194
|
+
delete(url, config) {
|
|
195
|
+
return this.request({ ...config, url, method: 'DELETE' });
|
|
196
|
+
}
|
|
197
|
+
head(url, config) {
|
|
198
|
+
return this.request({ ...config, url, method: 'HEAD' });
|
|
199
|
+
}
|
|
200
|
+
options(url, config) {
|
|
201
|
+
return this.request({ ...config, url, method: 'OPTIONS' });
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
const instance = new FetchAxios();
|
|
205
|
+
export const axios = instance;
|
|
206
|
+
export const createInstance = (defaultConfig) => new FetchAxios(defaultConfig);
|
|
207
|
+
export default FetchAxios;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './CRUD';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare const AUTH_HEADER_KEY = "Authorization";
|
|
2
|
+
export declare function getAuthToken(): Promise<string | null>;
|
|
3
|
+
export declare function clearAuthToken(): Promise<void>;
|
|
4
|
+
export declare const API_AUTH_HEADER_KEY = "projk";
|
|
5
|
+
export declare const getApiAuth: () => string;
|
|
6
|
+
export declare const setApiAuth: (v: string) => void;
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const AUTH_LOCAL_KEY = 'auth_token';
|
|
2
|
+
const API_AUTH_LOCAL_KEY = 'p_J_k';
|
|
3
|
+
export const AUTH_HEADER_KEY = 'Authorization';
|
|
4
|
+
export async function getAuthToken() {
|
|
5
|
+
if (typeof localStorage === 'undefined')
|
|
6
|
+
return null;
|
|
7
|
+
return localStorage.getItem(AUTH_LOCAL_KEY);
|
|
8
|
+
}
|
|
9
|
+
export async function clearAuthToken() {
|
|
10
|
+
if (typeof localStorage === 'undefined')
|
|
11
|
+
return;
|
|
12
|
+
localStorage.removeItem(AUTH_LOCAL_KEY);
|
|
13
|
+
}
|
|
14
|
+
export const API_AUTH_HEADER_KEY = 'projk';
|
|
15
|
+
export const getApiAuth = () => {
|
|
16
|
+
return localStorage.getItem(API_AUTH_LOCAL_KEY) ?? '';
|
|
17
|
+
};
|
|
18
|
+
export const setApiAuth = (v) => {
|
|
19
|
+
return localStorage.setItem(API_AUTH_LOCAL_KEY, v);
|
|
20
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export const generateMenuItemData = (data) => {
|
|
2
|
+
return data.map((m) => {
|
|
3
|
+
const children = (m.menuType === "group" && m.subMenu.length
|
|
4
|
+
? generateMenuItemData(m.subMenu)
|
|
5
|
+
: undefined);
|
|
6
|
+
return {
|
|
7
|
+
key: m.key,
|
|
8
|
+
label: m.name,
|
|
9
|
+
icon: m.icon,
|
|
10
|
+
children: children,
|
|
11
|
+
minWidth: 100,
|
|
12
|
+
};
|
|
13
|
+
});
|
|
14
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { lazy, Suspense } from 'react';
|
|
3
|
+
export const renderImportComponent = (c, fallback) => {
|
|
4
|
+
const Component = lazy(() => c);
|
|
5
|
+
const showFallback = typeof fallback !== 'undefined' ? fallback : 'loading';
|
|
6
|
+
return (_jsx(Suspense, { fallback: showFallback, children: _jsx(Component, {}) }));
|
|
7
|
+
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
const logJoin = (...logs) => logs.join(`
|
|
2
|
+
---------
|
|
3
|
+
`);
|
|
4
|
+
export const logPageNotFound = () => {
|
|
5
|
+
console.error(logJoin('url有问题 或者 自定义页面未在路由器注册', 'The URL is incorrect, or the custom page is not registered with the router.'));
|
|
6
|
+
};
|
|
7
|
+
export const logIllegalComponentCallback = (comName) => console.error(logJoin(`非法的组件回调 - ${comName}`, `Illegal component callback - ${comName}`));
|
|
8
|
+
export const logSubscriptionError = () => console.error(logJoin('不曾订阅过,请检查代码,关注函数与取消函数必须为同一个', "You haven't subscribed. Please check your code; the follow function and unsubscribe function must be the same."));
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { ProjectInfo } from "../../widgets/api/baseInfo";
|
|
2
|
+
type MenuItem = {
|
|
3
|
+
key: string;
|
|
4
|
+
name: string;
|
|
5
|
+
path: Partial<{
|
|
6
|
+
pathname: string;
|
|
7
|
+
search: string;
|
|
8
|
+
hash: string;
|
|
9
|
+
}>;
|
|
10
|
+
};
|
|
11
|
+
export declare const enum QK {
|
|
12
|
+
pk = "projk",
|
|
13
|
+
k = "key",
|
|
14
|
+
sk = "sidek",
|
|
15
|
+
ck = "custk"
|
|
16
|
+
}
|
|
17
|
+
export declare const leftSidebarBasePath = "_sidebar_";
|
|
18
|
+
export declare const deserializationUrlSearch: <T = Record<string, string>>(url?: string) => T;
|
|
19
|
+
export declare const serializationUrl: (url: string, data: Record<string, string>) => string;
|
|
20
|
+
export declare const findMenuItem: <T = Record<string, any>>(menuData: ProjectInfo["menu"], key?: string) => MenuItem & T;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=menu.d.ts.map
|