@ibiz-template/vue3-util 0.2.11 → 0.2.13
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/dist/index.min.css +1 -0
- package/dist/index.system.min.js +1 -1
- package/dist/index.system.min.js.map +1 -1
- package/es/_virtual/_commonjsHelpers.mjs +40 -0
- package/es/common/code-list/code-list.css +1 -0
- package/es/common/code-list/code-list.d.ts +58 -0
- package/es/common/code-list/code-list.d.ts.map +1 -0
- package/es/common/code-list/code-list.mjs +85 -0
- package/es/common/control-base/control-base.css +1 -0
- package/es/common/control-base/control-base.d.ts +2 -0
- package/es/common/control-base/control-base.d.ts.map +1 -0
- package/es/common/control-base/control-base.mjs +99 -0
- package/es/common/control-loading-placeholder/control-loading-placeholder.d.ts +31 -0
- package/es/common/control-loading-placeholder/control-loading-placeholder.d.ts.map +1 -0
- package/es/common/control-loading-placeholder/control-loading-placeholder.mjs +30 -0
- package/es/common/control-shell/control-shell.css +1 -0
- package/es/common/control-shell/control-shell.d.ts +21 -0
- package/es/common/control-shell/control-shell.d.ts.map +1 -0
- package/es/common/control-shell/control-shell.mjs +56 -0
- package/es/common/icon/icon.d.ts +29 -0
- package/es/common/icon/icon.d.ts.map +1 -0
- package/es/common/icon/icon.mjs +89 -0
- package/es/common/index.d.ts +9 -0
- package/es/common/index.d.ts.map +1 -0
- package/es/common/index.mjs +9 -0
- package/es/common/router-view/router-view.d.ts +30 -0
- package/es/common/router-view/router-view.d.ts.map +1 -0
- package/es/common/router-view/router-view.mjs +75 -0
- package/es/common/view-shell/view-shell.css +1 -0
- package/es/common/view-shell/view-shell.d.ts +40 -0
- package/es/common/view-shell/view-shell.d.ts.map +1 -0
- package/es/common/view-shell/view-shell.mjs +77 -0
- package/{out → es}/index.d.ts +3 -0
- package/es/index.d.ts.map +1 -0
- package/es/index.mjs +95 -0
- package/es/interface/index.mjs +3 -0
- package/es/interface/util/index.mjs +3 -0
- package/es/interface/util/route/route.mjs +1 -0
- package/es/node_modules/.pnpm/path-browserify@1.0.1/node_modules/path-browserify/index.mjs +535 -0
- package/es/panel-component/grid-container/grid-container.controller.d.ts +15 -0
- package/es/panel-component/grid-container/grid-container.controller.d.ts.map +1 -0
- package/es/panel-component/grid-container/grid-container.controller.mjs +12 -0
- package/es/panel-component/grid-container/grid-container.css +1 -0
- package/es/panel-component/grid-container/grid-container.d.ts +38 -0
- package/es/panel-component/grid-container/grid-container.d.ts.map +1 -0
- package/es/panel-component/grid-container/grid-container.mjs +106 -0
- package/es/panel-component/grid-container/grid-container.provider.d.ts +16 -0
- package/es/panel-component/grid-container/grid-container.provider.d.ts.map +1 -0
- package/es/panel-component/grid-container/grid-container.provider.mjs +15 -0
- package/es/panel-component/grid-container/grid-container.state.d.ts +13 -0
- package/es/panel-component/grid-container/grid-container.state.d.ts.map +1 -0
- package/es/panel-component/grid-container/grid-container.state.mjs +7 -0
- package/es/panel-component/grid-container/index.d.ts +38 -0
- package/es/panel-component/grid-container/index.d.ts.map +1 -0
- package/es/panel-component/grid-container/index.mjs +18 -0
- package/es/panel-component/index.d.ts +10 -0
- package/es/panel-component/index.d.ts.map +1 -0
- package/es/panel-component/index.mjs +28 -0
- package/es/panel-component/multi-data-container/index.d.ts +37 -0
- package/es/panel-component/multi-data-container/index.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/index.mjs +21 -0
- package/es/panel-component/multi-data-container/multi-data-container-item.controller.d.ts +61 -0
- package/es/panel-component/multi-data-container/multi-data-container-item.controller.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/multi-data-container-item.controller.mjs +117 -0
- package/es/panel-component/multi-data-container/multi-data-container-itm.state.d.ts +20 -0
- package/es/panel-component/multi-data-container/multi-data-container-itm.state.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/multi-data-container-itm.state.mjs +17 -0
- package/es/panel-component/multi-data-container/multi-data-container.controller.d.ts +107 -0
- package/es/panel-component/multi-data-container/multi-data-container.controller.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/multi-data-container.controller.mjs +260 -0
- package/es/panel-component/multi-data-container/multi-data-container.css +1 -0
- package/es/panel-component/multi-data-container/multi-data-container.d.ts +36 -0
- package/es/panel-component/multi-data-container/multi-data-container.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/multi-data-container.mjs +87 -0
- package/es/panel-component/multi-data-container/multi-data-container.provider.d.ts +16 -0
- package/es/panel-component/multi-data-container/multi-data-container.provider.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/multi-data-container.provider.mjs +15 -0
- package/es/panel-component/multi-data-container/multi-data-container.state.d.ts +20 -0
- package/es/panel-component/multi-data-container/multi-data-container.state.d.ts.map +1 -0
- package/es/panel-component/multi-data-container/multi-data-container.state.mjs +17 -0
- package/es/panel-component/nav-pos/index.d.ts +28 -0
- package/es/panel-component/nav-pos/index.d.ts.map +1 -0
- package/es/panel-component/nav-pos/index.mjs +15 -0
- package/es/panel-component/nav-pos/nav-pos.controller.d.ts +163 -0
- package/es/panel-component/nav-pos/nav-pos.controller.d.ts.map +1 -0
- package/es/panel-component/nav-pos/nav-pos.controller.mjs +283 -0
- package/es/panel-component/nav-pos/nav-pos.css +1 -0
- package/es/panel-component/nav-pos/nav-pos.d.ts +29 -0
- package/es/panel-component/nav-pos/nav-pos.d.ts.map +1 -0
- package/es/panel-component/nav-pos/nav-pos.mjs +105 -0
- package/es/panel-component/nav-pos/nav-pos.provider.d.ts +23 -0
- package/es/panel-component/nav-pos/nav-pos.provider.d.ts.map +1 -0
- package/es/panel-component/nav-pos/nav-pos.provider.mjs +24 -0
- package/es/panel-component/nav-pos/nav-pos.state.d.ts +50 -0
- package/es/panel-component/nav-pos/nav-pos.state.d.ts.map +1 -0
- package/es/panel-component/nav-pos/nav-pos.state.mjs +47 -0
- package/es/panel-component/panel-container/index.d.ts +27 -0
- package/es/panel-component/panel-container/index.d.ts.map +1 -0
- package/es/panel-component/panel-container/index.mjs +22 -0
- package/es/panel-component/panel-container/panel-container.controller.d.ts +15 -0
- package/es/panel-component/panel-container/panel-container.controller.d.ts.map +1 -0
- package/es/panel-component/panel-container/panel-container.controller.mjs +12 -0
- package/es/panel-component/panel-container/panel-container.css +1 -0
- package/es/panel-component/panel-container/panel-container.d.ts +27 -0
- package/es/panel-component/panel-container/panel-container.d.ts.map +1 -0
- package/es/panel-component/panel-container/panel-container.mjs +70 -0
- package/es/panel-component/panel-container/panel-container.provider.d.ts +16 -0
- package/es/panel-component/panel-container/panel-container.provider.d.ts.map +1 -0
- package/es/panel-component/panel-container/panel-container.provider.mjs +15 -0
- package/es/panel-component/panel-container/panel-container.state.d.ts +13 -0
- package/es/panel-component/panel-container/panel-container.state.d.ts.map +1 -0
- package/es/panel-component/panel-container/panel-container.state.mjs +7 -0
- package/es/panel-component/panel-ctrl-pos/index.d.ts +25 -0
- package/es/panel-component/panel-ctrl-pos/index.d.ts.map +1 -0
- package/es/panel-component/panel-ctrl-pos/index.mjs +14 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.d.ts +36 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.d.ts.map +1 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.mjs +23 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.css +1 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.d.ts +25 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.d.ts.map +1 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.mjs +45 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.d.ts +17 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.d.ts.map +1 -0
- package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.mjs +15 -0
- package/es/panel-component/panel-field/index.d.ts +26 -0
- package/es/panel-component/panel-field/index.d.ts.map +1 -0
- package/es/panel-component/panel-field/index.mjs +14 -0
- package/es/panel-component/panel-field/panel-field.controller.d.ts +75 -0
- package/es/panel-component/panel-field/panel-field.controller.d.ts.map +1 -0
- package/es/panel-component/panel-field/panel-field.controller.mjs +90 -0
- package/es/panel-component/panel-field/panel-field.css +1 -0
- package/es/panel-component/panel-field/panel-field.d.ts +28 -0
- package/es/panel-component/panel-field/panel-field.d.ts.map +1 -0
- package/es/panel-component/panel-field/panel-field.mjs +73 -0
- package/es/panel-component/panel-field/panel-field.provider.d.ts +15 -0
- package/es/panel-component/panel-field/panel-field.provider.d.ts.map +1 -0
- package/es/panel-component/panel-field/panel-field.provider.mjs +15 -0
- package/es/panel-component/panel-field/panel-field.state.d.ts +13 -0
- package/es/panel-component/panel-field/panel-field.state.d.ts.map +1 -0
- package/es/panel-component/panel-field/panel-field.state.mjs +7 -0
- package/es/panel-component/panel-rawitem/index.d.ts +25 -0
- package/es/panel-component/panel-rawitem/index.d.ts.map +1 -0
- package/es/panel-component/panel-rawitem/index.mjs +18 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.controller.d.ts +29 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.controller.d.ts.map +1 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.controller.mjs +28 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.css +1 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.d.ts +27 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.d.ts.map +1 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.mjs +50 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.provider.d.ts +15 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.provider.d.ts.map +1 -0
- package/es/panel-component/panel-rawitem/panel-rawitem.provider.mjs +15 -0
- package/es/panel-component/scroll-container/index.d.ts +26 -0
- package/es/panel-component/scroll-container/index.d.ts.map +1 -0
- package/es/panel-component/scroll-container/index.mjs +46 -0
- package/es/panel-component/scroll-container/scroll-container/index.d.ts +3 -0
- package/es/panel-component/scroll-container/scroll-container/index.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container/index.mjs +4 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.controller.d.ts +23 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.controller.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.controller.mjs +12 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.css +1 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.d.ts +27 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.mjs +112 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.provider.d.ts +17 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.provider.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container/scroll-container.provider.mjs +15 -0
- package/es/panel-component/scroll-container/scroll-container-item/index.d.ts +3 -0
- package/es/panel-component/scroll-container/scroll-container-item/index.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container-item/index.mjs +4 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.d.ts +22 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.mjs +7 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.css +1 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.d.ts +27 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.mjs +64 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.d.ts +17 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.d.ts.map +1 -0
- package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.mjs +15 -0
- package/es/panel-component/single-data-container/index.d.ts +37 -0
- package/es/panel-component/single-data-container/index.d.ts.map +1 -0
- package/es/panel-component/single-data-container/index.mjs +21 -0
- package/es/panel-component/single-data-container/single-data-container.controller.d.ts +122 -0
- package/es/panel-component/single-data-container/single-data-container.controller.d.ts.map +1 -0
- package/es/panel-component/single-data-container/single-data-container.controller.mjs +285 -0
- package/es/panel-component/single-data-container/single-data-container.css +1 -0
- package/es/panel-component/single-data-container/single-data-container.d.ts +36 -0
- package/es/panel-component/single-data-container/single-data-container.d.ts.map +1 -0
- package/es/panel-component/single-data-container/single-data-container.mjs +77 -0
- package/es/panel-component/single-data-container/single-data-container.provider.d.ts +16 -0
- package/es/panel-component/single-data-container/single-data-container.provider.d.ts.map +1 -0
- package/es/panel-component/single-data-container/single-data-container.provider.mjs +15 -0
- package/es/panel-component/single-data-container/single-data-container.state.d.ts +20 -0
- package/es/panel-component/single-data-container/single-data-container.state.d.ts.map +1 -0
- package/es/panel-component/single-data-container/single-data-container.state.mjs +17 -0
- package/es/plugin/index.mjs +3 -0
- package/es/plugin/plugin-factory/plugin-factory.mjs +292 -0
- package/es/props/common.mjs +15 -0
- package/es/props/editor/array.mjs +11 -0
- package/es/props/editor/autocomplete.mjs +11 -0
- package/es/props/editor/cascader.mjs +11 -0
- package/es/props/editor/check-box-list.mjs +11 -0
- package/es/props/editor/check-box.mjs +11 -0
- package/es/props/editor/code.mjs +20 -0
- package/es/props/editor/color-picker.mjs +11 -0
- package/es/props/editor/common.mjs +48 -0
- package/es/props/editor/data-picker.mjs +11 -0
- package/es/props/editor/date-picker.mjs +11 -0
- package/es/props/editor/date-range.mjs +11 -0
- package/es/props/editor/dropdown-list.mjs +11 -0
- package/es/props/editor/html.mjs +11 -0
- package/es/props/editor/index.mjs +27 -0
- package/es/props/editor/list-box.mjs +11 -0
- package/es/props/editor/markdown.mjs +19 -0
- package/es/props/editor/number-range.mjs +11 -0
- package/es/props/editor/radio-button-list.mjs +11 -0
- package/es/props/editor/rate.mjs +11 -0
- package/es/props/editor/raw.mjs +11 -0
- package/es/props/editor/slider.mjs +11 -0
- package/{out → es}/props/editor/span.d.ts +2 -2
- package/es/props/editor/span.mjs +11 -0
- package/es/props/editor/stepper.mjs +11 -0
- package/es/props/editor/switch.mjs +11 -0
- package/es/props/editor/text-box.mjs +23 -0
- package/es/props/editor/upload.mjs +11 -0
- package/es/props/index.mjs +29 -0
- package/es/use/click-outside/click-outside.mjs +48 -0
- package/es/use/control/index.mjs +3 -0
- package/es/use/control/use-control-controller/use-control-controller.mjs +74 -0
- package/es/use/event/event.mjs +37 -0
- package/es/use/focus-blur/focus-blur.mjs +46 -0
- package/es/use/index.mjs +13 -0
- package/es/use/namespace/namespace.mjs +8 -0
- package/es/use/route/route.mjs +28 -0
- package/es/use/util/index.mjs +11 -0
- package/{out/use/view/index.js → es/use/view/index.mjs} +3 -1
- package/es/use/view/use-view-controller/use-view-controller.mjs +72 -0
- package/es/use/vue/vue.mjs +55 -0
- package/es/util/control/prepare-control.mjs +22 -0
- package/es/util/index.d.ts +11 -0
- package/es/util/index.d.ts.map +1 -0
- package/es/util/index.mjs +14 -0
- package/es/util/install.mjs +9 -0
- package/es/util/overlay-container/overlay-container.d.ts +93 -0
- package/es/util/overlay-container/overlay-container.d.ts.map +1 -0
- package/es/util/overlay-container/overlay-container.mjs +114 -0
- package/es/util/overlay-popover-container/overlay-popover-container.d.ts +17 -0
- package/es/util/overlay-popover-container/overlay-popover-container.d.ts.map +1 -0
- package/es/util/overlay-popover-container/overlay-popover-container.mjs +10 -0
- package/es/util/overlay-view-util/overlay-view-util.d.ts +9 -0
- package/es/util/overlay-view-util/overlay-view-util.d.ts.map +1 -0
- package/es/util/overlay-view-util/overlay-view-util.mjs +63 -0
- package/es/util/render/render.mjs +20 -0
- package/es/util/route/route-listener.mjs +73 -0
- package/{out → es}/util/route/route.d.ts +20 -20
- package/es/util/route/route.d.ts.map +1 -0
- package/es/util/route/route.mjs +252 -0
- package/es/util/router-callback/router-callback-item.d.ts +62 -0
- package/es/util/router-callback/router-callback-item.d.ts.map +1 -0
- package/es/util/router-callback/router-callback-item.mjs +72 -0
- package/es/util/router-callback/router-callback.d.ts +60 -0
- package/es/util/router-callback/router-callback.d.ts.map +1 -0
- package/es/util/router-callback/router-callback.mjs +86 -0
- package/es/util/store/app-store/app-store.d.ts +10 -0
- package/es/util/store/app-store/app-store.d.ts.map +1 -0
- package/es/util/store/app-store/app-store.mjs +10 -0
- package/es/util/store/index.d.ts +4 -0
- package/es/util/store/index.d.ts.map +1 -0
- package/es/util/store/index.mjs +8 -0
- package/es/util/store/ui-store/ui-store.d.ts +32 -0
- package/es/util/store/ui-store/ui-store.d.ts.map +1 -0
- package/es/util/store/ui-store/ui-store.mjs +15 -0
- package/es/util/store/ui-store/z-index.d.ts +35 -0
- package/es/util/store/ui-store/z-index.d.ts.map +1 -0
- package/es/util/store/ui-store/z-index.mjs +18 -0
- package/es/view/app-redirect-view/app-redirect-view.d.ts +2 -0
- package/es/view/app-redirect-view/app-redirect-view.d.ts.map +1 -0
- package/es/view/app-redirect-view/app-redirect-view.mjs +27 -0
- package/es/view/common/index.d.ts +49 -0
- package/es/view/common/index.d.ts.map +1 -0
- package/es/view/common/index.mjs +13 -0
- package/es/view/common/view.css +1 -0
- package/es/view/common/view.d.ts +53 -0
- package/es/view/common/view.d.ts.map +1 -0
- package/es/view/common/view.mjs +143 -0
- package/es/view/common/view.provider.d.ts +14 -0
- package/es/view/common/view.provider.d.ts.map +1 -0
- package/es/view/common/view.provider.mjs +8 -0
- package/es/view/index.d.ts +5 -0
- package/es/view/index.d.ts.map +1 -0
- package/es/view/index.mjs +6 -0
- package/es/view/portal-view/index.d.ts +41 -0
- package/es/view/portal-view/index.d.ts.map +1 -0
- package/es/view/portal-view/index.mjs +21 -0
- package/es/view/portal-view/portal-view.d.ts +44 -0
- package/es/view/portal-view/portal-view.d.ts.map +1 -0
- package/es/view/portal-view/portal-view.mjs +93 -0
- package/es/view/portal-view/portal-view.provider.d.ts +14 -0
- package/es/view/portal-view/portal-view.provider.d.ts.map +1 -0
- package/es/view/portal-view/portal-view.provider.mjs +8 -0
- package/es/view/todo-redirect/todo-redirect.d.ts +2 -0
- package/es/view/todo-redirect/todo-redirect.d.ts.map +1 -0
- package/es/view/todo-redirect/todo-redirect.mjs +52 -0
- package/lib/index.cjs +236 -0
- package/package.json +20 -16
- package/src/common/code-list/code-list.scss +5 -0
- package/src/common/code-list/code-list.tsx +108 -0
- package/src/common/control-base/control-base.scss +4 -0
- package/src/common/control-base/control-base.tsx +129 -0
- package/src/common/control-loading-placeholder/control-loading-placeholder.tsx +22 -0
- package/src/common/control-shell/control-shell.scss +5 -0
- package/src/common/control-shell/control-shell.tsx +70 -0
- package/src/common/icon/icon.tsx +69 -0
- package/src/common/index.ts +8 -0
- package/src/common/router-view/router-view.tsx +74 -0
- package/src/common/view-shell/view-shell.scss +5 -0
- package/src/common/view-shell/view-shell.tsx +70 -0
- package/src/index.ts +3 -0
- package/src/panel-component/grid-container/grid-container.controller.ts +18 -0
- package/src/panel-component/grid-container/grid-container.provider.ts +30 -0
- package/src/panel-component/grid-container/grid-container.scss +17 -0
- package/src/panel-component/grid-container/grid-container.state.ts +12 -0
- package/src/panel-component/grid-container/grid-container.tsx +119 -0
- package/src/panel-component/grid-container/index.ts +19 -0
- package/src/panel-component/index.ts +9 -0
- package/src/panel-component/multi-data-container/index.ts +22 -0
- package/src/panel-component/multi-data-container/multi-data-container-item.controller.ts +166 -0
- package/src/panel-component/multi-data-container/multi-data-container-itm.state.ts +20 -0
- package/src/panel-component/multi-data-container/multi-data-container.controller.ts +308 -0
- package/src/panel-component/multi-data-container/multi-data-container.provider.ts +30 -0
- package/src/panel-component/multi-data-container/multi-data-container.scss +10 -0
- package/src/panel-component/multi-data-container/multi-data-container.state.ts +20 -0
- package/src/panel-component/multi-data-container/multi-data-container.tsx +109 -0
- package/src/panel-component/nav-pos/index.ts +16 -0
- package/src/panel-component/nav-pos/nav-pos.controller.ts +373 -0
- package/src/panel-component/nav-pos/nav-pos.provider.ts +38 -0
- package/src/panel-component/nav-pos/nav-pos.scss +4 -0
- package/src/panel-component/nav-pos/nav-pos.state.ts +52 -0
- package/src/panel-component/nav-pos/nav-pos.tsx +121 -0
- package/src/panel-component/panel-container/index.ts +27 -0
- package/src/panel-component/panel-container/panel-container.controller.ts +18 -0
- package/src/panel-component/panel-container/panel-container.provider.ts +30 -0
- package/src/panel-component/panel-container/panel-container.scss +15 -0
- package/src/panel-component/panel-container/panel-container.state.ts +12 -0
- package/src/panel-component/panel-container/panel-container.tsx +72 -0
- package/src/panel-component/panel-ctrl-pos/index.ts +14 -0
- package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.ts +53 -0
- package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.ts +30 -0
- package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.scss +8 -0
- package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.tsx +53 -0
- package/src/panel-component/panel-field/index.ts +14 -0
- package/src/panel-component/panel-field/panel-field.controller.ts +130 -0
- package/src/panel-component/panel-field/panel-field.provider.ts +28 -0
- package/src/panel-component/panel-field/panel-field.scss +36 -0
- package/src/panel-component/panel-field/panel-field.state.ts +12 -0
- package/src/panel-component/panel-field/panel-field.tsx +78 -0
- package/src/panel-component/panel-rawitem/index.ts +18 -0
- package/src/panel-component/panel-rawitem/panel-rawitem.controller.ts +34 -0
- package/src/panel-component/panel-rawitem/panel-rawitem.provider.ts +28 -0
- package/src/panel-component/panel-rawitem/panel-rawitem.scss +8 -0
- package/src/panel-component/panel-rawitem/panel-rawitem.tsx +51 -0
- package/src/panel-component/scroll-container/index.ts +44 -0
- package/src/panel-component/scroll-container/scroll-container/index.ts +2 -0
- package/src/panel-component/scroll-container/scroll-container/scroll-container.controller.ts +32 -0
- package/src/panel-component/scroll-container/scroll-container/scroll-container.provider.ts +30 -0
- package/src/panel-component/scroll-container/scroll-container/scroll-container.scss +34 -0
- package/src/panel-component/scroll-container/scroll-container/scroll-container.tsx +110 -0
- package/src/panel-component/scroll-container/scroll-container-item/index.ts +2 -0
- package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.ts +25 -0
- package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.ts +30 -0
- package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.scss +9 -0
- package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.tsx +60 -0
- package/src/panel-component/single-data-container/index.ts +22 -0
- package/src/panel-component/single-data-container/single-data-container.controller.ts +345 -0
- package/src/panel-component/single-data-container/single-data-container.provider.ts +30 -0
- package/src/panel-component/single-data-container/single-data-container.scss +10 -0
- package/src/panel-component/single-data-container/single-data-container.state.ts +20 -0
- package/src/panel-component/single-data-container/single-data-container.tsx +95 -0
- package/src/props/editor/span.ts +1 -1
- package/src/util/index.ts +5 -0
- package/src/util/overlay-container/overlay-container.ts +155 -0
- package/src/util/overlay-popover-container/overlay-popover-container.ts +30 -0
- package/src/util/overlay-view-util/overlay-view-util.ts +89 -0
- package/src/util/route/route.ts +142 -142
- package/src/util/router-callback/router-callback-item.ts +98 -0
- package/src/util/router-callback/router-callback.ts +97 -0
- package/src/util/store/app-store/app-store.ts +10 -0
- package/src/util/store/index.ts +6 -0
- package/src/util/store/ui-store/ui-store.ts +27 -0
- package/src/util/store/ui-store/z-index.ts +53 -0
- package/src/view/app-redirect-view/app-redirect-view.tsx +26 -0
- package/src/view/common/index.ts +10 -0
- package/src/view/common/view.provider.ts +14 -0
- package/src/view/common/view.scss +38 -0
- package/src/view/common/view.tsx +180 -0
- package/src/view/index.ts +4 -0
- package/src/view/portal-view/index.ts +18 -0
- package/src/view/portal-view/portal-view.provider.ts +14 -0
- package/src/view/portal-view/portal-view.tsx +79 -0
- package/src/view/todo-redirect/todo-redirect.tsx +51 -0
- package/dist/index.esm.js +0 -1859
- package/out/index.d.ts.map +0 -1
- package/out/index.js +0 -5
- package/out/interface/index.js +0 -1
- package/out/interface/util/index.js +0 -1
- package/out/interface/util/route/route.js +0 -1
- package/out/plugin/index.js +0 -1
- package/out/plugin/plugin-factory/plugin-factory.js +0 -297
- package/out/props/common.js +0 -23
- package/out/props/editor/array.js +0 -25
- package/out/props/editor/autocomplete.js +0 -25
- package/out/props/editor/cascader.js +0 -25
- package/out/props/editor/check-box-list.js +0 -25
- package/out/props/editor/check-box.js +0 -25
- package/out/props/editor/code.js +0 -29
- package/out/props/editor/color-picker.js +0 -25
- package/out/props/editor/common.js +0 -79
- package/out/props/editor/data-picker.js +0 -25
- package/out/props/editor/date-picker.js +0 -25
- package/out/props/editor/date-range.js +0 -21
- package/out/props/editor/dropdown-list.js +0 -25
- package/out/props/editor/html.js +0 -25
- package/out/props/editor/index.js +0 -25
- package/out/props/editor/list-box.js +0 -25
- package/out/props/editor/markdown.js +0 -28
- package/out/props/editor/number-range.js +0 -21
- package/out/props/editor/radio-button-list.js +0 -25
- package/out/props/editor/rate.js +0 -21
- package/out/props/editor/raw.js +0 -21
- package/out/props/editor/slider.js +0 -21
- package/out/props/editor/span.js +0 -25
- package/out/props/editor/stepper.js +0 -21
- package/out/props/editor/switch.js +0 -21
- package/out/props/editor/text-box.js +0 -73
- package/out/props/editor/upload.js +0 -25
- package/out/props/index.js +0 -2
- package/out/use/click-outside/click-outside.js +0 -50
- package/out/use/control/index.js +0 -1
- package/out/use/control/use-control-controller/use-control-controller.js +0 -94
- package/out/use/event/event.js +0 -39
- package/out/use/focus-blur/focus-blur.js +0 -63
- package/out/use/index.js +0 -9
- package/out/use/namespace/namespace.js +0 -13
- package/out/use/route/route.js +0 -41
- package/out/use/util/index.js +0 -23
- package/out/use/view/use-view-controller/use-view-controller.js +0 -94
- package/out/use/vue/vue.js +0 -112
- package/out/util/control/prepare-control.js +0 -25
- package/out/util/index.d.ts +0 -6
- package/out/util/index.d.ts.map +0 -1
- package/out/util/index.js +0 -5
- package/out/util/install.js +0 -6
- package/out/util/render/render.js +0 -28
- package/out/util/route/route-listener.js +0 -76
- package/out/util/route/route.d.ts.map +0 -1
- package/out/util/route/route.js +0 -385
- /package/{out → es}/interface/index.d.ts +0 -0
- /package/{out → es}/interface/index.d.ts.map +0 -0
- /package/{out → es}/interface/util/index.d.ts +0 -0
- /package/{out → es}/interface/util/index.d.ts.map +0 -0
- /package/{out → es}/interface/util/route/route.d.ts +0 -0
- /package/{out → es}/interface/util/route/route.d.ts.map +0 -0
- /package/{out → es}/plugin/index.d.ts +0 -0
- /package/{out → es}/plugin/index.d.ts.map +0 -0
- /package/{out → es}/plugin/plugin-factory/plugin-factory.d.ts +0 -0
- /package/{out → es}/plugin/plugin-factory/plugin-factory.d.ts.map +0 -0
- /package/{out → es}/props/common.d.ts +0 -0
- /package/{out → es}/props/common.d.ts.map +0 -0
- /package/{out → es}/props/editor/array.d.ts +0 -0
- /package/{out → es}/props/editor/array.d.ts.map +0 -0
- /package/{out → es}/props/editor/autocomplete.d.ts +0 -0
- /package/{out → es}/props/editor/autocomplete.d.ts.map +0 -0
- /package/{out → es}/props/editor/cascader.d.ts +0 -0
- /package/{out → es}/props/editor/cascader.d.ts.map +0 -0
- /package/{out → es}/props/editor/check-box-list.d.ts +0 -0
- /package/{out → es}/props/editor/check-box-list.d.ts.map +0 -0
- /package/{out → es}/props/editor/check-box.d.ts +0 -0
- /package/{out → es}/props/editor/check-box.d.ts.map +0 -0
- /package/{out → es}/props/editor/code.d.ts +0 -0
- /package/{out → es}/props/editor/code.d.ts.map +0 -0
- /package/{out → es}/props/editor/color-picker.d.ts +0 -0
- /package/{out → es}/props/editor/color-picker.d.ts.map +0 -0
- /package/{out → es}/props/editor/common.d.ts +0 -0
- /package/{out → es}/props/editor/common.d.ts.map +0 -0
- /package/{out → es}/props/editor/data-picker.d.ts +0 -0
- /package/{out → es}/props/editor/data-picker.d.ts.map +0 -0
- /package/{out → es}/props/editor/date-picker.d.ts +0 -0
- /package/{out → es}/props/editor/date-picker.d.ts.map +0 -0
- /package/{out → es}/props/editor/date-range.d.ts +0 -0
- /package/{out → es}/props/editor/date-range.d.ts.map +0 -0
- /package/{out → es}/props/editor/dropdown-list.d.ts +0 -0
- /package/{out → es}/props/editor/dropdown-list.d.ts.map +0 -0
- /package/{out → es}/props/editor/html.d.ts +0 -0
- /package/{out → es}/props/editor/html.d.ts.map +0 -0
- /package/{out → es}/props/editor/index.d.ts +0 -0
- /package/{out → es}/props/editor/index.d.ts.map +0 -0
- /package/{out → es}/props/editor/list-box.d.ts +0 -0
- /package/{out → es}/props/editor/list-box.d.ts.map +0 -0
- /package/{out → es}/props/editor/markdown.d.ts +0 -0
- /package/{out → es}/props/editor/markdown.d.ts.map +0 -0
- /package/{out → es}/props/editor/number-range.d.ts +0 -0
- /package/{out → es}/props/editor/number-range.d.ts.map +0 -0
- /package/{out → es}/props/editor/radio-button-list.d.ts +0 -0
- /package/{out → es}/props/editor/radio-button-list.d.ts.map +0 -0
- /package/{out → es}/props/editor/rate.d.ts +0 -0
- /package/{out → es}/props/editor/rate.d.ts.map +0 -0
- /package/{out → es}/props/editor/raw.d.ts +0 -0
- /package/{out → es}/props/editor/raw.d.ts.map +0 -0
- /package/{out → es}/props/editor/slider.d.ts +0 -0
- /package/{out → es}/props/editor/slider.d.ts.map +0 -0
- /package/{out → es}/props/editor/span.d.ts.map +0 -0
- /package/{out → es}/props/editor/stepper.d.ts +0 -0
- /package/{out → es}/props/editor/stepper.d.ts.map +0 -0
- /package/{out → es}/props/editor/switch.d.ts +0 -0
- /package/{out → es}/props/editor/switch.d.ts.map +0 -0
- /package/{out → es}/props/editor/text-box.d.ts +0 -0
- /package/{out → es}/props/editor/text-box.d.ts.map +0 -0
- /package/{out → es}/props/editor/upload.d.ts +0 -0
- /package/{out → es}/props/editor/upload.d.ts.map +0 -0
- /package/{out → es}/props/index.d.ts +0 -0
- /package/{out → es}/props/index.d.ts.map +0 -0
- /package/{out → es}/use/click-outside/click-outside.d.ts +0 -0
- /package/{out → es}/use/click-outside/click-outside.d.ts.map +0 -0
- /package/{out → es}/use/control/index.d.ts +0 -0
- /package/{out → es}/use/control/index.d.ts.map +0 -0
- /package/{out → es}/use/control/use-control-controller/use-control-controller.d.ts +0 -0
- /package/{out → es}/use/control/use-control-controller/use-control-controller.d.ts.map +0 -0
- /package/{out → es}/use/event/event.d.ts +0 -0
- /package/{out → es}/use/event/event.d.ts.map +0 -0
- /package/{out → es}/use/focus-blur/focus-blur.d.ts +0 -0
- /package/{out → es}/use/focus-blur/focus-blur.d.ts.map +0 -0
- /package/{out → es}/use/index.d.ts +0 -0
- /package/{out → es}/use/index.d.ts.map +0 -0
- /package/{out → es}/use/namespace/namespace.d.ts +0 -0
- /package/{out → es}/use/namespace/namespace.d.ts.map +0 -0
- /package/{out → es}/use/route/route.d.ts +0 -0
- /package/{out → es}/use/route/route.d.ts.map +0 -0
- /package/{out → es}/use/util/index.d.ts +0 -0
- /package/{out → es}/use/util/index.d.ts.map +0 -0
- /package/{out → es}/use/view/index.d.ts +0 -0
- /package/{out → es}/use/view/index.d.ts.map +0 -0
- /package/{out → es}/use/view/use-view-controller/use-view-controller.d.ts +0 -0
- /package/{out → es}/use/view/use-view-controller/use-view-controller.d.ts.map +0 -0
- /package/{out → es}/use/vue/vue.d.ts +0 -0
- /package/{out → es}/use/vue/vue.d.ts.map +0 -0
- /package/{out → es}/util/control/prepare-control.d.ts +0 -0
- /package/{out → es}/util/control/prepare-control.d.ts.map +0 -0
- /package/{out → es}/util/install.d.ts +0 -0
- /package/{out → es}/util/install.d.ts.map +0 -0
- /package/{out → es}/util/render/render.d.ts +0 -0
- /package/{out → es}/util/render/render.d.ts.map +0 -0
- /package/{out → es}/util/route/route-listener.d.ts +0 -0
- /package/{out → es}/util/route/route-listener.d.ts.map +0 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { IPanelContainer } from '@ibiz/model-core';
|
|
2
|
+
import { computed, defineComponent, PropType, VNode } from 'vue';
|
|
3
|
+
import { useNamespace } from '../../use';
|
|
4
|
+
import { PanelContainerController } from './panel-container.controller';
|
|
5
|
+
import './panel-container.scss';
|
|
6
|
+
|
|
7
|
+
export const PanelContainer = defineComponent({
|
|
8
|
+
name: 'IBizPanelContainer',
|
|
9
|
+
props: {
|
|
10
|
+
modelData: {
|
|
11
|
+
type: Object as PropType<IPanelContainer>,
|
|
12
|
+
required: true,
|
|
13
|
+
},
|
|
14
|
+
controller: {
|
|
15
|
+
type: PanelContainerController,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
setup(props) {
|
|
20
|
+
const ns = useNamespace('panel-container');
|
|
21
|
+
const { id } = props.modelData;
|
|
22
|
+
|
|
23
|
+
// 类名控制
|
|
24
|
+
const classArr = computed(() => {
|
|
25
|
+
let result: Array<string | false> = [ns.b(), ns.m(id)];
|
|
26
|
+
result = [
|
|
27
|
+
...result,
|
|
28
|
+
...props.controller.containerClass,
|
|
29
|
+
ns.is('hidden', !props.controller.state.visible),
|
|
30
|
+
];
|
|
31
|
+
return result;
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
return { ns, classArr };
|
|
35
|
+
},
|
|
36
|
+
render() {
|
|
37
|
+
// 内容区默认插槽处理,封装app-col
|
|
38
|
+
const defaultSlots: VNode[] = this.$slots.default?.() || [];
|
|
39
|
+
const content = (
|
|
40
|
+
<iBizRow slot='content' layout={this.modelData.layout}>
|
|
41
|
+
{defaultSlots.map(slot => {
|
|
42
|
+
const props = slot.props as IData;
|
|
43
|
+
if (!props || !props.controller) {
|
|
44
|
+
return slot;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return (
|
|
48
|
+
<iBizCol
|
|
49
|
+
layoutPos={props.modelData.layoutPos}
|
|
50
|
+
state={props.controller.state}
|
|
51
|
+
>
|
|
52
|
+
{slot}
|
|
53
|
+
</iBizCol>
|
|
54
|
+
);
|
|
55
|
+
})}
|
|
56
|
+
</iBizRow>
|
|
57
|
+
);
|
|
58
|
+
return (
|
|
59
|
+
<div
|
|
60
|
+
class={this.classArr}
|
|
61
|
+
onClick={() => {
|
|
62
|
+
this.controller.onClick();
|
|
63
|
+
}}
|
|
64
|
+
>
|
|
65
|
+
{this.controller.model.cssStyle ? (
|
|
66
|
+
<style type='text/css'>{this.controller.model.cssStyle}</style>
|
|
67
|
+
) : null}
|
|
68
|
+
{content}
|
|
69
|
+
</div>
|
|
70
|
+
);
|
|
71
|
+
},
|
|
72
|
+
});
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { App } from 'vue';
|
|
2
|
+
import { registerPanelItemProvider } from '@ibiz-template/runtime';
|
|
3
|
+
import { withInstall } from '../../util';
|
|
4
|
+
import { PanelCtrlPos } from './panel-ctrl-pos';
|
|
5
|
+
import { PanelCtrlPosProvider } from './panel-ctrl-pos.provider';
|
|
6
|
+
import { PanelCtrlPosController } from './panel-ctrl-pos.controller';
|
|
7
|
+
|
|
8
|
+
export { PanelCtrlPosController };
|
|
9
|
+
export const IBizPanelCtrlPos = withInstall(PanelCtrlPos, function (v: App) {
|
|
10
|
+
v.component(PanelCtrlPos.name, PanelCtrlPos);
|
|
11
|
+
registerPanelItemProvider('CTRLPOS', () => new PanelCtrlPosProvider());
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
export default IBizPanelCtrlPos;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import {
|
|
2
|
+
IControlController,
|
|
3
|
+
PanelItemController,
|
|
4
|
+
ViewLayoutPanelController,
|
|
5
|
+
} from '@ibiz-template/runtime';
|
|
6
|
+
import { IPanelCtrlPos } from '@ibiz/model-core';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* 面板控件占位控制器
|
|
10
|
+
*
|
|
11
|
+
* @author lxm
|
|
12
|
+
* @date 2023-02-07 06:05:23
|
|
13
|
+
* @export
|
|
14
|
+
* @class PanelButtonController
|
|
15
|
+
* @extends {PanelItemController}
|
|
16
|
+
*/
|
|
17
|
+
export class PanelCtrlPosController extends PanelItemController<IPanelCtrlPos> {
|
|
18
|
+
/**
|
|
19
|
+
* 面板控制器
|
|
20
|
+
*
|
|
21
|
+
* @author lxm
|
|
22
|
+
* @date 2022-08-24 22:08:59
|
|
23
|
+
* @type {PanelController}
|
|
24
|
+
*/
|
|
25
|
+
declare panel: ViewLayoutPanelController;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* 部件占位对应部件控制器
|
|
29
|
+
* @author lxm
|
|
30
|
+
* @date 2023-08-09 10:41:38
|
|
31
|
+
* @type {IControlController}
|
|
32
|
+
*/
|
|
33
|
+
control?: IControlController;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* 绑定部件控制器
|
|
37
|
+
* @author lxm
|
|
38
|
+
* @date 2023-08-09 10:42:30
|
|
39
|
+
* @param {IControlController} controller
|
|
40
|
+
*/
|
|
41
|
+
bindControl(controller: IControlController): void {
|
|
42
|
+
this.control = controller;
|
|
43
|
+
|
|
44
|
+
// 绑定部件,并监听所有事件,通过面板转发部件的事件。
|
|
45
|
+
controller.evt.onAll((eventName, event) => {
|
|
46
|
+
this.panel.evt.emit('onControlEvent', {
|
|
47
|
+
triggerControlName: this.model.id!,
|
|
48
|
+
triggerEventName: eventName,
|
|
49
|
+
triggerEvent: event,
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import {
|
|
2
|
+
IPanelItemProvider,
|
|
3
|
+
PanelController,
|
|
4
|
+
PanelItemController,
|
|
5
|
+
} from '@ibiz-template/runtime';
|
|
6
|
+
import { IPanelCtrlPos } from '@ibiz/model-core';
|
|
7
|
+
import { PanelCtrlPosController } from './panel-ctrl-pos.controller';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* 面板控件占位适配器
|
|
11
|
+
*
|
|
12
|
+
* @author lxm
|
|
13
|
+
* @date 2022-09-19 22:09:03
|
|
14
|
+
* @export
|
|
15
|
+
* @class PanelCtrlPosProvider
|
|
16
|
+
* @implements {EditorProvider}
|
|
17
|
+
*/
|
|
18
|
+
export class PanelCtrlPosProvider implements IPanelItemProvider {
|
|
19
|
+
component: string = 'IBizPanelCtrlPos';
|
|
20
|
+
|
|
21
|
+
async createController(
|
|
22
|
+
panelItem: IPanelCtrlPos,
|
|
23
|
+
panel: PanelController,
|
|
24
|
+
parent: PanelItemController | undefined,
|
|
25
|
+
): Promise<PanelCtrlPosController> {
|
|
26
|
+
const c = new PanelCtrlPosController(panelItem, panel, parent);
|
|
27
|
+
await c.init();
|
|
28
|
+
return c;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { CTX, IControlController } from '@ibiz-template/runtime';
|
|
2
|
+
import { IPanelCtrlPos } from '@ibiz/model-core';
|
|
3
|
+
import { defineComponent, inject, PropType, VNode } from 'vue';
|
|
4
|
+
import { useNamespace } from '../../use';
|
|
5
|
+
import { PanelCtrlPosController } from './panel-ctrl-pos.controller';
|
|
6
|
+
import './panel-ctrl-pos.scss';
|
|
7
|
+
|
|
8
|
+
export const PanelCtrlPos = defineComponent({
|
|
9
|
+
name: 'IBizPanelCtrlPos',
|
|
10
|
+
props: {
|
|
11
|
+
modelData: {
|
|
12
|
+
type: Object as PropType<IPanelCtrlPos>,
|
|
13
|
+
required: true,
|
|
14
|
+
},
|
|
15
|
+
controller: {
|
|
16
|
+
type: Object as PropType<PanelCtrlPosController>,
|
|
17
|
+
required: true,
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
setup(props) {
|
|
21
|
+
// 上下文里提前预告部件
|
|
22
|
+
const ctx = inject('ctx') as CTX;
|
|
23
|
+
ctx.evt.on('onRegister', (name, c) => {
|
|
24
|
+
if (name === props.modelData.id) {
|
|
25
|
+
props.controller.bindControl(c as IControlController);
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
const ns = useNamespace('panel-ctrl-pos');
|
|
30
|
+
return { ns };
|
|
31
|
+
},
|
|
32
|
+
render() {
|
|
33
|
+
const { state } = this.controller;
|
|
34
|
+
let content: VNode | VNode[] | undefined;
|
|
35
|
+
|
|
36
|
+
if (this.$slots.default) {
|
|
37
|
+
content = this.$slots.default();
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
return (
|
|
41
|
+
<div
|
|
42
|
+
class={[
|
|
43
|
+
this.ns.b(),
|
|
44
|
+
this.ns.m(this.modelData.id),
|
|
45
|
+
...this.controller.containerClass,
|
|
46
|
+
this.ns.is('hidden', !state.visible),
|
|
47
|
+
]}
|
|
48
|
+
>
|
|
49
|
+
{content || (ibiz.env.dev ? `未提供${this.modelData.id}插槽` : '')}
|
|
50
|
+
</div>
|
|
51
|
+
);
|
|
52
|
+
},
|
|
53
|
+
});
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { registerPanelItemProvider } from '@ibiz-template/runtime';
|
|
2
|
+
import { App } from 'vue';
|
|
3
|
+
import { withInstall } from '../../util';
|
|
4
|
+
import { PanelField } from './panel-field';
|
|
5
|
+
import { PanelFieldProvider } from './panel-field.provider';
|
|
6
|
+
|
|
7
|
+
export * from './panel-field.controller';
|
|
8
|
+
|
|
9
|
+
export const IBizPanelField = withInstall(PanelField, function (v: App) {
|
|
10
|
+
v.component(PanelField.name, PanelField);
|
|
11
|
+
registerPanelItemProvider('FIELD', () => new PanelFieldProvider());
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
export default IBizPanelField;
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getEditorProvider,
|
|
3
|
+
IEditorContainerController,
|
|
4
|
+
IEditorController,
|
|
5
|
+
IEditorProvider,
|
|
6
|
+
PanelItemController,
|
|
7
|
+
} from '@ibiz-template/runtime';
|
|
8
|
+
import { IPanelField } from '@ibiz/model-core';
|
|
9
|
+
import { PanelFieldState } from './panel-field.state';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* 面板按钮控制器
|
|
13
|
+
*
|
|
14
|
+
* @export
|
|
15
|
+
* @class PanelFieldController
|
|
16
|
+
* @extends {PanelItemController<IPanelField>}
|
|
17
|
+
*/
|
|
18
|
+
export class PanelFieldController
|
|
19
|
+
extends PanelItemController<IPanelField>
|
|
20
|
+
implements IEditorContainerController
|
|
21
|
+
{
|
|
22
|
+
declare state: PanelFieldState;
|
|
23
|
+
|
|
24
|
+
unitName: string | undefined = undefined;
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* 值格式化
|
|
28
|
+
* @author lxm
|
|
29
|
+
* @date 2023-05-24 05:46:56
|
|
30
|
+
* @readonly
|
|
31
|
+
* @type {(string | undefined)}
|
|
32
|
+
*/
|
|
33
|
+
get valueFormat(): string | undefined {
|
|
34
|
+
return this.model.valueFormat;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
get dataType(): number | undefined {
|
|
38
|
+
return undefined;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
get context(): IContext {
|
|
42
|
+
return this.panel.context;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
get params(): IParams {
|
|
46
|
+
return this.panel.params;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* 父容器数据对象数据
|
|
51
|
+
* @author lxm
|
|
52
|
+
* @date 2023-07-15 01:33:58
|
|
53
|
+
* @readonly
|
|
54
|
+
* @type {IData}
|
|
55
|
+
*/
|
|
56
|
+
get data(): IData {
|
|
57
|
+
return this.dataParent.data;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* 面板属性成员的值
|
|
62
|
+
* @author lxm
|
|
63
|
+
* @date 2023-07-14 02:30:58
|
|
64
|
+
* @readonly
|
|
65
|
+
*/
|
|
66
|
+
get value(): string | number {
|
|
67
|
+
return this.data[this.model.id!];
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* 编辑器控制器
|
|
72
|
+
*
|
|
73
|
+
* @author lxm
|
|
74
|
+
* @date 2022-08-24 20:08:42
|
|
75
|
+
* @type {IEditorController}
|
|
76
|
+
*/
|
|
77
|
+
editor?: IEditorController;
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* 编辑器适配器
|
|
81
|
+
*
|
|
82
|
+
* @author lxm
|
|
83
|
+
* @date 2022-08-24 20:08:42
|
|
84
|
+
*/
|
|
85
|
+
editorProvider?: IEditorProvider;
|
|
86
|
+
|
|
87
|
+
protected createState(): PanelFieldState {
|
|
88
|
+
return new PanelFieldState(this.parent?.state);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* 初始化
|
|
93
|
+
*
|
|
94
|
+
* @author lxm
|
|
95
|
+
* @date 2022-08-24 20:08:42
|
|
96
|
+
* @protected
|
|
97
|
+
* @returns {*} {Promise<void>}
|
|
98
|
+
*/
|
|
99
|
+
protected async onInit(): Promise<void> {
|
|
100
|
+
await super.onInit();
|
|
101
|
+
// 空输入默认值
|
|
102
|
+
this.state.required = !this.model.allowEmpty;
|
|
103
|
+
// 初始化编辑器控制器,除了隐藏都会需要适配器
|
|
104
|
+
if (this.model.editor && this.model.editor.editorType !== 'HIDDEN') {
|
|
105
|
+
this.editorProvider = await getEditorProvider(this.model.editor);
|
|
106
|
+
if (this.editorProvider) {
|
|
107
|
+
this.editor = await this.editorProvider.createController(
|
|
108
|
+
this.model.editor,
|
|
109
|
+
this,
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* 设置面板数据的值
|
|
117
|
+
*
|
|
118
|
+
* @author lxm
|
|
119
|
+
* @date 2022-08-24 10:08:40
|
|
120
|
+
* @param {unknown} value 要设置的值
|
|
121
|
+
* @param {string} name 要设置的面板数据的属性名称
|
|
122
|
+
*/
|
|
123
|
+
async setDataValue(value: unknown, name?: string): Promise<void> {
|
|
124
|
+
const { id } = this.model;
|
|
125
|
+
name = name || id;
|
|
126
|
+
if (this.dataParent.setDataValue) {
|
|
127
|
+
await this.dataParent.setDataValue(name!, value);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import {
|
|
2
|
+
IPanelItemProvider,
|
|
3
|
+
PanelController,
|
|
4
|
+
PanelItemController,
|
|
5
|
+
} from '@ibiz-template/runtime';
|
|
6
|
+
import { IPanelItem } from '@ibiz/model-core';
|
|
7
|
+
import { PanelFieldController } from './panel-field.controller';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* 面板属性适配器
|
|
11
|
+
*
|
|
12
|
+
* @export
|
|
13
|
+
* @class PanelFieldProvider
|
|
14
|
+
* @implements {IPanelItemProvider}
|
|
15
|
+
*/
|
|
16
|
+
export class PanelFieldProvider implements IPanelItemProvider {
|
|
17
|
+
component: string = 'IBizPanelField';
|
|
18
|
+
|
|
19
|
+
async createController(
|
|
20
|
+
panelItem: IPanelItem,
|
|
21
|
+
panel: PanelController,
|
|
22
|
+
parent: PanelItemController | undefined,
|
|
23
|
+
): Promise<PanelFieldController> {
|
|
24
|
+
const c = new PanelFieldController(panelItem, panel, parent);
|
|
25
|
+
await c.init();
|
|
26
|
+
return c;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
$panel-field: (
|
|
2
|
+
'icon-margin': 6px,
|
|
3
|
+
);
|
|
4
|
+
|
|
5
|
+
// 三块定义该变量的地方,要改的话一起改!
|
|
6
|
+
// form-item, panel-field, grid-edit-item
|
|
7
|
+
$form-item: (
|
|
8
|
+
'label-color': getCssVar(color, text, 1),
|
|
9
|
+
'text-color': getCssVar(color, text, 2),
|
|
10
|
+
'hover-color': getCssVar(color, text, 0),
|
|
11
|
+
'hover-bg-color': getCssVar(color, fill, 1),
|
|
12
|
+
'readonly-color': getCssVar(color, disabled, text),
|
|
13
|
+
'border-color': transparent,
|
|
14
|
+
'font-size': getCssVar(font-size, regular),
|
|
15
|
+
'placeholder-color': getCssVar(color, text, 3),
|
|
16
|
+
'disabled-color': getCssVar(color, disabled, text),
|
|
17
|
+
'disabled-bg-color': getCssVar(color, disabled, fill),
|
|
18
|
+
'disabled-border-color': getCssVar(color, disabled, border),
|
|
19
|
+
'active-bg': getCssVar(color, fill, 2),
|
|
20
|
+
'active-border': getCssVar(active, bg),
|
|
21
|
+
'focus-bg': getCssVar(color, fill, 0),
|
|
22
|
+
'focus-border': getCssVar(color, focus, border),
|
|
23
|
+
'line-height': getCssVar(editor,default,line-height),
|
|
24
|
+
'font-weight': getCssVar(font-weight, regular),
|
|
25
|
+
);
|
|
26
|
+
|
|
27
|
+
@include b(panel-field) {
|
|
28
|
+
@include set-component-css-var('form-item', $form-item);
|
|
29
|
+
|
|
30
|
+
width: 100%;
|
|
31
|
+
height: 100%;
|
|
32
|
+
|
|
33
|
+
@include b(panel-field-content) {
|
|
34
|
+
line-height: inherit ;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { PanelItemState } from '@ibiz-template/runtime';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* 面板属性状态
|
|
5
|
+
*
|
|
6
|
+
* @author lxm
|
|
7
|
+
* @date 2023-02-07 06:04:27
|
|
8
|
+
* @export
|
|
9
|
+
* @class PanelFieldState
|
|
10
|
+
* @extends {PanelItemState}
|
|
11
|
+
*/
|
|
12
|
+
export class PanelFieldState extends PanelItemState {}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { IPanelField } from '@ibiz/model-core';
|
|
2
|
+
import { computed, defineComponent, PropType, resolveComponent, h } from 'vue';
|
|
3
|
+
import { useNamespace } from '../../use';
|
|
4
|
+
import { PanelFieldController } from './panel-field.controller';
|
|
5
|
+
import './panel-field.scss';
|
|
6
|
+
|
|
7
|
+
export const PanelField = defineComponent({
|
|
8
|
+
name: 'IBizPanelField',
|
|
9
|
+
props: {
|
|
10
|
+
modelData: {
|
|
11
|
+
type: Object as PropType<IPanelField>,
|
|
12
|
+
required: true,
|
|
13
|
+
},
|
|
14
|
+
controller: {
|
|
15
|
+
type: PanelFieldController,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
setup(props) {
|
|
20
|
+
const ns = useNamespace('panel-field');
|
|
21
|
+
|
|
22
|
+
// 类名控制
|
|
23
|
+
const classArr = computed(() => {
|
|
24
|
+
const { id } = props.modelData;
|
|
25
|
+
const result: Array<string | false> = [ns.b(), ns.m(id)];
|
|
26
|
+
result.push(...props.controller.containerClass);
|
|
27
|
+
return result;
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
const onValueChange = (val: unknown, name?: string): void => {
|
|
31
|
+
props.controller.setDataValue(val, name);
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
return {
|
|
35
|
+
ns,
|
|
36
|
+
classArr,
|
|
37
|
+
onValueChange,
|
|
38
|
+
};
|
|
39
|
+
},
|
|
40
|
+
render() {
|
|
41
|
+
// 编辑器内容
|
|
42
|
+
let editor = null;
|
|
43
|
+
if (this.controller.data) {
|
|
44
|
+
const editorProps = {
|
|
45
|
+
value: this.controller.value,
|
|
46
|
+
data: this.controller.data,
|
|
47
|
+
controller: this.controller.editor,
|
|
48
|
+
disabled: this.controller.state.disabled,
|
|
49
|
+
class: this.ns.b('content'),
|
|
50
|
+
readonly: this.controller.model.editor!.readOnly,
|
|
51
|
+
onChange: this.onValueChange,
|
|
52
|
+
};
|
|
53
|
+
if (this.$slots.default) {
|
|
54
|
+
editor = this.$slots.default(editorProps);
|
|
55
|
+
} else if (this.controller.editorProvider) {
|
|
56
|
+
const component = resolveComponent(
|
|
57
|
+
this.controller.editorProvider.formEditor,
|
|
58
|
+
);
|
|
59
|
+
editor = h(component, {
|
|
60
|
+
...editorProps,
|
|
61
|
+
});
|
|
62
|
+
} else {
|
|
63
|
+
editor = <not-supported-editor modelData={this.modelData.editor} />;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
return (
|
|
68
|
+
<div
|
|
69
|
+
class={this.classArr}
|
|
70
|
+
onClick={() => {
|
|
71
|
+
this.controller.onClick();
|
|
72
|
+
}}
|
|
73
|
+
>
|
|
74
|
+
{editor}
|
|
75
|
+
</div>
|
|
76
|
+
);
|
|
77
|
+
},
|
|
78
|
+
});
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { registerPanelItemProvider } from '@ibiz-template/runtime';
|
|
2
|
+
import { App } from 'vue';
|
|
3
|
+
import { withInstall } from '../../util';
|
|
4
|
+
import { PanelRawItem } from './panel-rawitem';
|
|
5
|
+
import { PanelRawItemProvider } from './panel-rawitem.provider';
|
|
6
|
+
|
|
7
|
+
export * from './panel-rawitem.controller';
|
|
8
|
+
|
|
9
|
+
export const IBizPanelRawItem = withInstall(PanelRawItem, function (v: App) {
|
|
10
|
+
v.component(PanelRawItem.name, PanelRawItem);
|
|
11
|
+
registerPanelItemProvider('RAWITEM', () => new PanelRawItemProvider());
|
|
12
|
+
registerPanelItemProvider(
|
|
13
|
+
'RAWITEM_STATIC_IMAGE',
|
|
14
|
+
() => new PanelRawItemProvider(),
|
|
15
|
+
);
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export default IBizPanelRawItem;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { IPanelRawItem } from '@ibiz/model-core';
|
|
2
|
+
import { PanelItemController } from '@ibiz-template/runtime';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* 面板按钮控制器
|
|
6
|
+
*
|
|
7
|
+
* @export
|
|
8
|
+
* @class PanelRawItemController
|
|
9
|
+
* @extends {PanelItemController<IPanelRawItem>}
|
|
10
|
+
*/
|
|
11
|
+
export class PanelRawItemController extends PanelItemController<IPanelRawItem> {
|
|
12
|
+
/**
|
|
13
|
+
* 父容器数据对象数据
|
|
14
|
+
* @author lxm
|
|
15
|
+
* @date 2023-07-15 01:33:58
|
|
16
|
+
* @readonly
|
|
17
|
+
* @type {IData}
|
|
18
|
+
*/
|
|
19
|
+
get data(): IData {
|
|
20
|
+
return this.dataParent.data!;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* 初始化
|
|
25
|
+
*
|
|
26
|
+
* @author lxm
|
|
27
|
+
* @date 2022-08-24 20:08:42
|
|
28
|
+
* @protected
|
|
29
|
+
* @returns {*} {Promise<void>}
|
|
30
|
+
*/
|
|
31
|
+
protected async onInit(): Promise<void> {
|
|
32
|
+
await super.onInit();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import {
|
|
2
|
+
IPanelItemProvider,
|
|
3
|
+
PanelController,
|
|
4
|
+
PanelItemController,
|
|
5
|
+
} from '@ibiz-template/runtime';
|
|
6
|
+
import { IPanelItem } from '@ibiz/model-core';
|
|
7
|
+
import { PanelRawItemController } from './panel-rawitem.controller';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* 面板属性适配器
|
|
11
|
+
*
|
|
12
|
+
* @export
|
|
13
|
+
* @class PanelRawItemProvider
|
|
14
|
+
* @implements {IPanelItemProvider}
|
|
15
|
+
*/
|
|
16
|
+
export class PanelRawItemProvider implements IPanelItemProvider {
|
|
17
|
+
component: string = 'IBizPanelRawItem';
|
|
18
|
+
|
|
19
|
+
async createController(
|
|
20
|
+
panelItem: IPanelItem,
|
|
21
|
+
panel: PanelController,
|
|
22
|
+
parent: PanelItemController | undefined,
|
|
23
|
+
): Promise<PanelRawItemController> {
|
|
24
|
+
const c = new PanelRawItemController(panelItem, panel, parent);
|
|
25
|
+
await c.init();
|
|
26
|
+
return c;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { IPanelRawItem } from '@ibiz/model-core';
|
|
2
|
+
import { computed, defineComponent, PropType } from 'vue';
|
|
3
|
+
import { useNamespace } from '../../use';
|
|
4
|
+
import { PanelRawItemController } from './panel-rawitem.controller';
|
|
5
|
+
import './panel-rawitem.scss';
|
|
6
|
+
|
|
7
|
+
export const PanelRawItem = defineComponent({
|
|
8
|
+
name: 'IBizPanelRawItem',
|
|
9
|
+
props: {
|
|
10
|
+
modelData: {
|
|
11
|
+
type: Object as PropType<IPanelRawItem>,
|
|
12
|
+
required: true,
|
|
13
|
+
},
|
|
14
|
+
controller: {
|
|
15
|
+
type: PanelRawItemController,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
setup(props) {
|
|
20
|
+
const ns = useNamespace('panel-rawitem');
|
|
21
|
+
|
|
22
|
+
// 类名控制
|
|
23
|
+
const classArr = computed(() => {
|
|
24
|
+
const { id } = props.modelData;
|
|
25
|
+
const result: Array<string | false> = [ns.b(), ns.m(id)];
|
|
26
|
+
result.push(...props.controller.containerClass);
|
|
27
|
+
return result;
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
return {
|
|
31
|
+
ns,
|
|
32
|
+
classArr,
|
|
33
|
+
};
|
|
34
|
+
},
|
|
35
|
+
render() {
|
|
36
|
+
// 动态控制显示
|
|
37
|
+
if (!this.controller.state.visible) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
return (
|
|
41
|
+
<div
|
|
42
|
+
class={this.classArr}
|
|
43
|
+
onClick={() => {
|
|
44
|
+
this.controller.onClick();
|
|
45
|
+
}}
|
|
46
|
+
>
|
|
47
|
+
<iBizRawItem rawItem={this.modelData}></iBizRawItem>
|
|
48
|
+
</div>
|
|
49
|
+
);
|
|
50
|
+
},
|
|
51
|
+
});
|