@ibiz-template/vue3-util 0.2.11 → 0.2.12

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.
Files changed (557) hide show
  1. package/dist/index.min.css +1 -0
  2. package/dist/index.system.min.js +1 -1
  3. package/dist/index.system.min.js.map +1 -1
  4. package/es/_virtual/_commonjsHelpers.mjs +40 -0
  5. package/es/common/code-list/code-list.css +1 -0
  6. package/es/common/code-list/code-list.d.ts +58 -0
  7. package/es/common/code-list/code-list.d.ts.map +1 -0
  8. package/es/common/code-list/code-list.mjs +85 -0
  9. package/es/common/control-base/control-base.css +1 -0
  10. package/es/common/control-base/control-base.d.ts +2 -0
  11. package/es/common/control-base/control-base.d.ts.map +1 -0
  12. package/es/common/control-base/control-base.mjs +99 -0
  13. package/es/common/control-loading-placeholder/control-loading-placeholder.d.ts +31 -0
  14. package/es/common/control-loading-placeholder/control-loading-placeholder.d.ts.map +1 -0
  15. package/es/common/control-loading-placeholder/control-loading-placeholder.mjs +30 -0
  16. package/es/common/control-shell/control-shell.css +1 -0
  17. package/es/common/control-shell/control-shell.d.ts +21 -0
  18. package/es/common/control-shell/control-shell.d.ts.map +1 -0
  19. package/es/common/control-shell/control-shell.mjs +56 -0
  20. package/es/common/icon/icon.d.ts +29 -0
  21. package/es/common/icon/icon.d.ts.map +1 -0
  22. package/es/common/icon/icon.mjs +89 -0
  23. package/es/common/index.d.ts +9 -0
  24. package/es/common/index.d.ts.map +1 -0
  25. package/es/common/index.mjs +9 -0
  26. package/es/common/router-view/router-view.d.ts +30 -0
  27. package/es/common/router-view/router-view.d.ts.map +1 -0
  28. package/es/common/router-view/router-view.mjs +75 -0
  29. package/es/common/view-shell/view-shell.css +1 -0
  30. package/es/common/view-shell/view-shell.d.ts +40 -0
  31. package/es/common/view-shell/view-shell.d.ts.map +1 -0
  32. package/es/common/view-shell/view-shell.mjs +77 -0
  33. package/{out → es}/index.d.ts +3 -0
  34. package/es/index.d.ts.map +1 -0
  35. package/es/index.mjs +107 -0
  36. package/es/interface/index.mjs +3 -0
  37. package/es/interface/util/index.mjs +3 -0
  38. package/es/interface/util/route/route.mjs +1 -0
  39. package/es/node_modules/.pnpm/path-browserify@1.0.1/node_modules/path-browserify/index.mjs +535 -0
  40. package/es/panel-component/grid-container/grid-container.controller.d.ts +15 -0
  41. package/es/panel-component/grid-container/grid-container.controller.d.ts.map +1 -0
  42. package/es/panel-component/grid-container/grid-container.controller.mjs +12 -0
  43. package/es/panel-component/grid-container/grid-container.css +1 -0
  44. package/es/panel-component/grid-container/grid-container.d.ts +38 -0
  45. package/es/panel-component/grid-container/grid-container.d.ts.map +1 -0
  46. package/es/panel-component/grid-container/grid-container.mjs +106 -0
  47. package/es/panel-component/grid-container/grid-container.provider.d.ts +16 -0
  48. package/es/panel-component/grid-container/grid-container.provider.d.ts.map +1 -0
  49. package/es/panel-component/grid-container/grid-container.provider.mjs +15 -0
  50. package/es/panel-component/grid-container/grid-container.state.d.ts +13 -0
  51. package/es/panel-component/grid-container/grid-container.state.d.ts.map +1 -0
  52. package/es/panel-component/grid-container/grid-container.state.mjs +7 -0
  53. package/es/panel-component/grid-container/index.d.ts +39 -0
  54. package/es/panel-component/grid-container/index.d.ts.map +1 -0
  55. package/es/panel-component/grid-container/index.mjs +18 -0
  56. package/es/panel-component/index.d.ts +10 -0
  57. package/es/panel-component/index.d.ts.map +1 -0
  58. package/es/panel-component/index.mjs +38 -0
  59. package/es/panel-component/multi-data-container/index.d.ts +38 -0
  60. package/es/panel-component/multi-data-container/index.d.ts.map +1 -0
  61. package/es/panel-component/multi-data-container/index.mjs +21 -0
  62. package/es/panel-component/multi-data-container/multi-data-container-item.controller.d.ts +61 -0
  63. package/es/panel-component/multi-data-container/multi-data-container-item.controller.d.ts.map +1 -0
  64. package/es/panel-component/multi-data-container/multi-data-container-item.controller.mjs +117 -0
  65. package/es/panel-component/multi-data-container/multi-data-container-itm.state.d.ts +20 -0
  66. package/es/panel-component/multi-data-container/multi-data-container-itm.state.d.ts.map +1 -0
  67. package/es/panel-component/multi-data-container/multi-data-container-itm.state.mjs +17 -0
  68. package/es/panel-component/multi-data-container/multi-data-container.controller.d.ts +107 -0
  69. package/es/panel-component/multi-data-container/multi-data-container.controller.d.ts.map +1 -0
  70. package/es/panel-component/multi-data-container/multi-data-container.controller.mjs +260 -0
  71. package/es/panel-component/multi-data-container/multi-data-container.css +1 -0
  72. package/es/panel-component/multi-data-container/multi-data-container.d.ts +36 -0
  73. package/es/panel-component/multi-data-container/multi-data-container.d.ts.map +1 -0
  74. package/es/panel-component/multi-data-container/multi-data-container.mjs +87 -0
  75. package/es/panel-component/multi-data-container/multi-data-container.provider.d.ts +16 -0
  76. package/es/panel-component/multi-data-container/multi-data-container.provider.d.ts.map +1 -0
  77. package/es/panel-component/multi-data-container/multi-data-container.provider.mjs +15 -0
  78. package/es/panel-component/multi-data-container/multi-data-container.state.d.ts +20 -0
  79. package/es/panel-component/multi-data-container/multi-data-container.state.d.ts.map +1 -0
  80. package/es/panel-component/multi-data-container/multi-data-container.state.mjs +17 -0
  81. package/es/panel-component/nav-pos/index.d.ts +29 -0
  82. package/es/panel-component/nav-pos/index.d.ts.map +1 -0
  83. package/es/panel-component/nav-pos/index.mjs +15 -0
  84. package/es/panel-component/nav-pos/nav-pos.controller.d.ts +162 -0
  85. package/es/panel-component/nav-pos/nav-pos.controller.d.ts.map +1 -0
  86. package/es/panel-component/nav-pos/nav-pos.controller.mjs +261 -0
  87. package/es/panel-component/nav-pos/nav-pos.css +1 -0
  88. package/es/panel-component/nav-pos/nav-pos.d.ts +29 -0
  89. package/es/panel-component/nav-pos/nav-pos.d.ts.map +1 -0
  90. package/es/panel-component/nav-pos/nav-pos.mjs +105 -0
  91. package/es/panel-component/nav-pos/nav-pos.provider.d.ts +23 -0
  92. package/es/panel-component/nav-pos/nav-pos.provider.d.ts.map +1 -0
  93. package/es/panel-component/nav-pos/nav-pos.provider.mjs +24 -0
  94. package/es/panel-component/nav-pos/nav-pos.state.d.ts +50 -0
  95. package/es/panel-component/nav-pos/nav-pos.state.d.ts.map +1 -0
  96. package/es/panel-component/nav-pos/nav-pos.state.mjs +47 -0
  97. package/es/panel-component/panel-container/index.d.ts +28 -0
  98. package/es/panel-component/panel-container/index.d.ts.map +1 -0
  99. package/es/panel-component/panel-container/index.mjs +22 -0
  100. package/es/panel-component/panel-container/panel-container.controller.d.ts +15 -0
  101. package/es/panel-component/panel-container/panel-container.controller.d.ts.map +1 -0
  102. package/es/panel-component/panel-container/panel-container.controller.mjs +12 -0
  103. package/es/panel-component/panel-container/panel-container.css +1 -0
  104. package/es/panel-component/panel-container/panel-container.d.ts +27 -0
  105. package/es/panel-component/panel-container/panel-container.d.ts.map +1 -0
  106. package/es/panel-component/panel-container/panel-container.mjs +70 -0
  107. package/es/panel-component/panel-container/panel-container.provider.d.ts +16 -0
  108. package/es/panel-component/panel-container/panel-container.provider.d.ts.map +1 -0
  109. package/es/panel-component/panel-container/panel-container.provider.mjs +15 -0
  110. package/es/panel-component/panel-container/panel-container.state.d.ts +13 -0
  111. package/es/panel-component/panel-container/panel-container.state.d.ts.map +1 -0
  112. package/es/panel-component/panel-container/panel-container.state.mjs +7 -0
  113. package/es/panel-component/panel-ctrl-pos/index.d.ts +26 -0
  114. package/es/panel-component/panel-ctrl-pos/index.d.ts.map +1 -0
  115. package/es/panel-component/panel-ctrl-pos/index.mjs +14 -0
  116. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.d.ts +36 -0
  117. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.d.ts.map +1 -0
  118. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.mjs +23 -0
  119. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.css +1 -0
  120. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.d.ts +25 -0
  121. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.d.ts.map +1 -0
  122. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.mjs +45 -0
  123. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.d.ts +17 -0
  124. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.d.ts.map +1 -0
  125. package/es/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.mjs +15 -0
  126. package/es/panel-component/panel-field/index.d.ts +27 -0
  127. package/es/panel-component/panel-field/index.d.ts.map +1 -0
  128. package/es/panel-component/panel-field/index.mjs +14 -0
  129. package/es/panel-component/panel-field/panel-field.controller.d.ts +75 -0
  130. package/es/panel-component/panel-field/panel-field.controller.d.ts.map +1 -0
  131. package/es/panel-component/panel-field/panel-field.controller.mjs +90 -0
  132. package/es/panel-component/panel-field/panel-field.css +1 -0
  133. package/es/panel-component/panel-field/panel-field.d.ts +28 -0
  134. package/es/panel-component/panel-field/panel-field.d.ts.map +1 -0
  135. package/es/panel-component/panel-field/panel-field.mjs +73 -0
  136. package/es/panel-component/panel-field/panel-field.provider.d.ts +15 -0
  137. package/es/panel-component/panel-field/panel-field.provider.d.ts.map +1 -0
  138. package/es/panel-component/panel-field/panel-field.provider.mjs +15 -0
  139. package/es/panel-component/panel-field/panel-field.state.d.ts +13 -0
  140. package/es/panel-component/panel-field/panel-field.state.d.ts.map +1 -0
  141. package/es/panel-component/panel-field/panel-field.state.mjs +7 -0
  142. package/es/panel-component/panel-rawitem/index.d.ts +26 -0
  143. package/es/panel-component/panel-rawitem/index.d.ts.map +1 -0
  144. package/es/panel-component/panel-rawitem/index.mjs +18 -0
  145. package/es/panel-component/panel-rawitem/panel-rawitem.controller.d.ts +29 -0
  146. package/es/panel-component/panel-rawitem/panel-rawitem.controller.d.ts.map +1 -0
  147. package/es/panel-component/panel-rawitem/panel-rawitem.controller.mjs +28 -0
  148. package/es/panel-component/panel-rawitem/panel-rawitem.css +1 -0
  149. package/es/panel-component/panel-rawitem/panel-rawitem.d.ts +27 -0
  150. package/es/panel-component/panel-rawitem/panel-rawitem.d.ts.map +1 -0
  151. package/es/panel-component/panel-rawitem/panel-rawitem.mjs +50 -0
  152. package/es/panel-component/panel-rawitem/panel-rawitem.provider.d.ts +15 -0
  153. package/es/panel-component/panel-rawitem/panel-rawitem.provider.d.ts.map +1 -0
  154. package/es/panel-component/panel-rawitem/panel-rawitem.provider.mjs +15 -0
  155. package/es/panel-component/scroll-container/index.d.ts +26 -0
  156. package/es/panel-component/scroll-container/index.d.ts.map +1 -0
  157. package/es/panel-component/scroll-container/index.mjs +46 -0
  158. package/es/panel-component/scroll-container/scroll-container/index.d.ts +4 -0
  159. package/es/panel-component/scroll-container/scroll-container/index.d.ts.map +1 -0
  160. package/es/panel-component/scroll-container/scroll-container/index.mjs +5 -0
  161. package/es/panel-component/scroll-container/scroll-container/scroll-container.controller.d.ts +23 -0
  162. package/es/panel-component/scroll-container/scroll-container/scroll-container.controller.d.ts.map +1 -0
  163. package/es/panel-component/scroll-container/scroll-container/scroll-container.controller.mjs +12 -0
  164. package/es/panel-component/scroll-container/scroll-container/scroll-container.css +1 -0
  165. package/es/panel-component/scroll-container/scroll-container/scroll-container.d.ts +27 -0
  166. package/es/panel-component/scroll-container/scroll-container/scroll-container.d.ts.map +1 -0
  167. package/es/panel-component/scroll-container/scroll-container/scroll-container.mjs +112 -0
  168. package/es/panel-component/scroll-container/scroll-container/scroll-container.provider.d.ts +17 -0
  169. package/es/panel-component/scroll-container/scroll-container/scroll-container.provider.d.ts.map +1 -0
  170. package/es/panel-component/scroll-container/scroll-container/scroll-container.provider.mjs +15 -0
  171. package/es/panel-component/scroll-container/scroll-container-item/index.d.ts +4 -0
  172. package/es/panel-component/scroll-container/scroll-container-item/index.d.ts.map +1 -0
  173. package/es/panel-component/scroll-container/scroll-container-item/index.mjs +5 -0
  174. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.d.ts +22 -0
  175. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.d.ts.map +1 -0
  176. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.mjs +7 -0
  177. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.css +1 -0
  178. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.d.ts +27 -0
  179. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.d.ts.map +1 -0
  180. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.mjs +64 -0
  181. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.d.ts +17 -0
  182. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.d.ts.map +1 -0
  183. package/es/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.mjs +15 -0
  184. package/es/panel-component/single-data-container/index.d.ts +38 -0
  185. package/es/panel-component/single-data-container/index.d.ts.map +1 -0
  186. package/es/panel-component/single-data-container/index.mjs +21 -0
  187. package/es/panel-component/single-data-container/single-data-container.controller.d.ts +122 -0
  188. package/es/panel-component/single-data-container/single-data-container.controller.d.ts.map +1 -0
  189. package/es/panel-component/single-data-container/single-data-container.controller.mjs +285 -0
  190. package/es/panel-component/single-data-container/single-data-container.css +1 -0
  191. package/es/panel-component/single-data-container/single-data-container.d.ts +36 -0
  192. package/es/panel-component/single-data-container/single-data-container.d.ts.map +1 -0
  193. package/es/panel-component/single-data-container/single-data-container.mjs +77 -0
  194. package/es/panel-component/single-data-container/single-data-container.provider.d.ts +16 -0
  195. package/es/panel-component/single-data-container/single-data-container.provider.d.ts.map +1 -0
  196. package/es/panel-component/single-data-container/single-data-container.provider.mjs +15 -0
  197. package/es/panel-component/single-data-container/single-data-container.state.d.ts +20 -0
  198. package/es/panel-component/single-data-container/single-data-container.state.d.ts.map +1 -0
  199. package/es/panel-component/single-data-container/single-data-container.state.mjs +17 -0
  200. package/es/plugin/index.mjs +3 -0
  201. package/es/plugin/plugin-factory/plugin-factory.mjs +292 -0
  202. package/es/props/common.mjs +15 -0
  203. package/es/props/editor/array.mjs +11 -0
  204. package/es/props/editor/autocomplete.mjs +11 -0
  205. package/es/props/editor/cascader.mjs +11 -0
  206. package/es/props/editor/check-box-list.mjs +11 -0
  207. package/es/props/editor/check-box.mjs +11 -0
  208. package/es/props/editor/code.mjs +20 -0
  209. package/es/props/editor/color-picker.mjs +11 -0
  210. package/es/props/editor/common.mjs +48 -0
  211. package/es/props/editor/data-picker.mjs +11 -0
  212. package/es/props/editor/date-picker.mjs +11 -0
  213. package/es/props/editor/date-range.mjs +11 -0
  214. package/es/props/editor/dropdown-list.mjs +11 -0
  215. package/es/props/editor/html.mjs +11 -0
  216. package/es/props/editor/index.mjs +27 -0
  217. package/es/props/editor/list-box.mjs +11 -0
  218. package/es/props/editor/markdown.mjs +19 -0
  219. package/es/props/editor/number-range.mjs +11 -0
  220. package/es/props/editor/radio-button-list.mjs +11 -0
  221. package/es/props/editor/rate.mjs +11 -0
  222. package/es/props/editor/raw.mjs +11 -0
  223. package/es/props/editor/slider.mjs +11 -0
  224. package/{out → es}/props/editor/span.d.ts +2 -2
  225. package/es/props/editor/span.mjs +11 -0
  226. package/es/props/editor/stepper.mjs +11 -0
  227. package/es/props/editor/switch.mjs +11 -0
  228. package/es/props/editor/text-box.mjs +23 -0
  229. package/es/props/editor/upload.mjs +11 -0
  230. package/es/props/index.mjs +29 -0
  231. package/es/use/click-outside/click-outside.mjs +48 -0
  232. package/es/use/control/index.mjs +3 -0
  233. package/es/use/control/use-control-controller/use-control-controller.mjs +74 -0
  234. package/es/use/event/event.mjs +37 -0
  235. package/es/use/focus-blur/focus-blur.mjs +46 -0
  236. package/es/use/index.mjs +13 -0
  237. package/es/use/namespace/namespace.mjs +8 -0
  238. package/es/use/route/route.mjs +28 -0
  239. package/es/use/util/index.mjs +11 -0
  240. package/{out/use/view/index.js → es/use/view/index.mjs} +3 -1
  241. package/es/use/view/use-view-controller/use-view-controller.mjs +72 -0
  242. package/es/use/vue/vue.mjs +55 -0
  243. package/es/util/control/prepare-control.mjs +22 -0
  244. package/es/util/index.d.ts +11 -0
  245. package/es/util/index.d.ts.map +1 -0
  246. package/es/util/index.mjs +14 -0
  247. package/es/util/install.mjs +9 -0
  248. package/es/util/overlay-container/overlay-container.d.ts +93 -0
  249. package/es/util/overlay-container/overlay-container.d.ts.map +1 -0
  250. package/es/util/overlay-container/overlay-container.mjs +114 -0
  251. package/es/util/overlay-popover-container/overlay-popover-container.d.ts +17 -0
  252. package/es/util/overlay-popover-container/overlay-popover-container.d.ts.map +1 -0
  253. package/es/util/overlay-popover-container/overlay-popover-container.mjs +10 -0
  254. package/es/util/overlay-view-util/overlay-view-util.d.ts +9 -0
  255. package/es/util/overlay-view-util/overlay-view-util.d.ts.map +1 -0
  256. package/es/util/overlay-view-util/overlay-view-util.mjs +63 -0
  257. package/es/util/render/render.mjs +20 -0
  258. package/es/util/route/route-listener.mjs +73 -0
  259. package/{out → es}/util/route/route.d.ts +20 -20
  260. package/es/util/route/route.d.ts.map +1 -0
  261. package/es/util/route/route.mjs +252 -0
  262. package/es/util/router-callback/router-callback-item.d.ts +62 -0
  263. package/es/util/router-callback/router-callback-item.d.ts.map +1 -0
  264. package/es/util/router-callback/router-callback-item.mjs +72 -0
  265. package/es/util/router-callback/router-callback.d.ts +60 -0
  266. package/es/util/router-callback/router-callback.d.ts.map +1 -0
  267. package/es/util/router-callback/router-callback.mjs +86 -0
  268. package/es/util/store/app-store/app-store.d.ts +10 -0
  269. package/es/util/store/app-store/app-store.d.ts.map +1 -0
  270. package/es/util/store/app-store/app-store.mjs +10 -0
  271. package/es/util/store/index.d.ts +4 -0
  272. package/es/util/store/index.d.ts.map +1 -0
  273. package/es/util/store/index.mjs +8 -0
  274. package/es/util/store/ui-store/ui-store.d.ts +32 -0
  275. package/es/util/store/ui-store/ui-store.d.ts.map +1 -0
  276. package/es/util/store/ui-store/ui-store.mjs +15 -0
  277. package/es/util/store/ui-store/z-index.d.ts +35 -0
  278. package/es/util/store/ui-store/z-index.d.ts.map +1 -0
  279. package/es/util/store/ui-store/z-index.mjs +18 -0
  280. package/es/view/app-redirect-view/app-redirect-view.d.ts +2 -0
  281. package/es/view/app-redirect-view/app-redirect-view.d.ts.map +1 -0
  282. package/es/view/app-redirect-view/app-redirect-view.mjs +27 -0
  283. package/es/view/common/index.d.ts +51 -0
  284. package/es/view/common/index.d.ts.map +1 -0
  285. package/es/view/common/index.mjs +13 -0
  286. package/es/view/common/view.css +1 -0
  287. package/es/view/common/view.d.ts +53 -0
  288. package/es/view/common/view.d.ts.map +1 -0
  289. package/es/view/common/view.mjs +143 -0
  290. package/es/view/common/view.provider.d.ts +14 -0
  291. package/es/view/common/view.provider.d.ts.map +1 -0
  292. package/es/view/common/view.provider.mjs +8 -0
  293. package/es/view/index.d.ts +5 -0
  294. package/es/view/index.d.ts.map +1 -0
  295. package/es/view/index.mjs +8 -0
  296. package/es/view/portal-view/index.d.ts +43 -0
  297. package/es/view/portal-view/index.d.ts.map +1 -0
  298. package/es/view/portal-view/index.mjs +21 -0
  299. package/es/view/portal-view/portal-view.d.ts +44 -0
  300. package/es/view/portal-view/portal-view.d.ts.map +1 -0
  301. package/es/view/portal-view/portal-view.mjs +93 -0
  302. package/es/view/portal-view/portal-view.provider.d.ts +14 -0
  303. package/es/view/portal-view/portal-view.provider.d.ts.map +1 -0
  304. package/es/view/portal-view/portal-view.provider.mjs +8 -0
  305. package/es/view/todo-redirect/todo-redirect.d.ts +2 -0
  306. package/es/view/todo-redirect/todo-redirect.d.ts.map +1 -0
  307. package/es/view/todo-redirect/todo-redirect.mjs +52 -0
  308. package/lib/index.cjs +260 -0
  309. package/package.json +19 -14
  310. package/src/common/code-list/code-list.scss +5 -0
  311. package/src/common/code-list/code-list.tsx +108 -0
  312. package/src/common/control-base/control-base.scss +4 -0
  313. package/src/common/control-base/control-base.tsx +129 -0
  314. package/src/common/control-loading-placeholder/control-loading-placeholder.tsx +22 -0
  315. package/src/common/control-shell/control-shell.scss +5 -0
  316. package/src/common/control-shell/control-shell.tsx +70 -0
  317. package/src/common/icon/icon.tsx +69 -0
  318. package/src/common/index.ts +8 -0
  319. package/src/common/router-view/router-view.tsx +74 -0
  320. package/src/common/view-shell/view-shell.scss +5 -0
  321. package/src/common/view-shell/view-shell.tsx +70 -0
  322. package/src/index.ts +3 -0
  323. package/src/panel-component/grid-container/grid-container.controller.ts +18 -0
  324. package/src/panel-component/grid-container/grid-container.provider.ts +30 -0
  325. package/src/panel-component/grid-container/grid-container.scss +17 -0
  326. package/src/panel-component/grid-container/grid-container.state.ts +12 -0
  327. package/src/panel-component/grid-container/grid-container.tsx +119 -0
  328. package/src/panel-component/grid-container/index.ts +19 -0
  329. package/src/panel-component/index.ts +9 -0
  330. package/src/panel-component/multi-data-container/index.ts +26 -0
  331. package/src/panel-component/multi-data-container/multi-data-container-item.controller.ts +166 -0
  332. package/src/panel-component/multi-data-container/multi-data-container-itm.state.ts +20 -0
  333. package/src/panel-component/multi-data-container/multi-data-container.controller.ts +308 -0
  334. package/src/panel-component/multi-data-container/multi-data-container.provider.ts +30 -0
  335. package/src/panel-component/multi-data-container/multi-data-container.scss +10 -0
  336. package/src/panel-component/multi-data-container/multi-data-container.state.ts +20 -0
  337. package/src/panel-component/multi-data-container/multi-data-container.tsx +109 -0
  338. package/src/panel-component/nav-pos/index.ts +16 -0
  339. package/src/panel-component/nav-pos/nav-pos.controller.ts +351 -0
  340. package/src/panel-component/nav-pos/nav-pos.provider.ts +38 -0
  341. package/src/panel-component/nav-pos/nav-pos.scss +4 -0
  342. package/src/panel-component/nav-pos/nav-pos.state.ts +52 -0
  343. package/src/panel-component/nav-pos/nav-pos.tsx +121 -0
  344. package/src/panel-component/panel-container/index.ts +31 -0
  345. package/src/panel-component/panel-container/panel-container.controller.ts +18 -0
  346. package/src/panel-component/panel-container/panel-container.provider.ts +30 -0
  347. package/src/panel-component/panel-container/panel-container.scss +15 -0
  348. package/src/panel-component/panel-container/panel-container.state.ts +12 -0
  349. package/src/panel-component/panel-container/panel-container.tsx +72 -0
  350. package/src/panel-component/panel-ctrl-pos/index.ts +14 -0
  351. package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.controller.ts +53 -0
  352. package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.provider.ts +30 -0
  353. package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.scss +8 -0
  354. package/src/panel-component/panel-ctrl-pos/panel-ctrl-pos.tsx +53 -0
  355. package/src/panel-component/panel-field/index.ts +15 -0
  356. package/src/panel-component/panel-field/panel-field.controller.ts +130 -0
  357. package/src/panel-component/panel-field/panel-field.provider.ts +28 -0
  358. package/src/panel-component/panel-field/panel-field.scss +36 -0
  359. package/src/panel-component/panel-field/panel-field.state.ts +12 -0
  360. package/src/panel-component/panel-field/panel-field.tsx +78 -0
  361. package/src/panel-component/panel-rawitem/index.ts +19 -0
  362. package/src/panel-component/panel-rawitem/panel-rawitem.controller.ts +34 -0
  363. package/src/panel-component/panel-rawitem/panel-rawitem.provider.ts +28 -0
  364. package/src/panel-component/panel-rawitem/panel-rawitem.scss +8 -0
  365. package/src/panel-component/panel-rawitem/panel-rawitem.tsx +51 -0
  366. package/src/panel-component/scroll-container/index.ts +44 -0
  367. package/src/panel-component/scroll-container/scroll-container/index.ts +3 -0
  368. package/src/panel-component/scroll-container/scroll-container/scroll-container.controller.ts +32 -0
  369. package/src/panel-component/scroll-container/scroll-container/scroll-container.provider.ts +30 -0
  370. package/src/panel-component/scroll-container/scroll-container/scroll-container.scss +34 -0
  371. package/src/panel-component/scroll-container/scroll-container/scroll-container.tsx +110 -0
  372. package/src/panel-component/scroll-container/scroll-container-item/index.ts +3 -0
  373. package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.controller.ts +25 -0
  374. package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.provider.ts +30 -0
  375. package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.scss +9 -0
  376. package/src/panel-component/scroll-container/scroll-container-item/scroll-container-item.tsx +60 -0
  377. package/src/panel-component/single-data-container/index.ts +26 -0
  378. package/src/panel-component/single-data-container/single-data-container.controller.ts +345 -0
  379. package/src/panel-component/single-data-container/single-data-container.provider.ts +30 -0
  380. package/src/panel-component/single-data-container/single-data-container.scss +10 -0
  381. package/src/panel-component/single-data-container/single-data-container.state.ts +20 -0
  382. package/src/panel-component/single-data-container/single-data-container.tsx +95 -0
  383. package/src/props/editor/span.ts +1 -1
  384. package/src/util/index.ts +5 -0
  385. package/src/util/overlay-container/overlay-container.ts +155 -0
  386. package/src/util/overlay-popover-container/overlay-popover-container.ts +30 -0
  387. package/src/util/overlay-view-util/overlay-view-util.ts +89 -0
  388. package/src/util/route/route.ts +140 -140
  389. package/src/util/router-callback/router-callback-item.ts +98 -0
  390. package/src/util/router-callback/router-callback.ts +97 -0
  391. package/src/util/store/app-store/app-store.ts +10 -0
  392. package/src/util/store/index.ts +6 -0
  393. package/src/util/store/ui-store/ui-store.ts +27 -0
  394. package/src/util/store/ui-store/z-index.ts +53 -0
  395. package/src/view/app-redirect-view/app-redirect-view.tsx +26 -0
  396. package/src/view/common/index.ts +12 -0
  397. package/src/view/common/view.provider.ts +14 -0
  398. package/src/view/common/view.scss +38 -0
  399. package/src/view/common/view.tsx +180 -0
  400. package/src/view/index.ts +4 -0
  401. package/src/view/portal-view/index.ts +20 -0
  402. package/src/view/portal-view/portal-view.provider.ts +14 -0
  403. package/src/view/portal-view/portal-view.tsx +79 -0
  404. package/src/view/todo-redirect/todo-redirect.tsx +51 -0
  405. package/dist/index.esm.js +0 -1859
  406. package/out/index.d.ts.map +0 -1
  407. package/out/index.js +0 -5
  408. package/out/interface/index.js +0 -1
  409. package/out/interface/util/index.js +0 -1
  410. package/out/interface/util/route/route.js +0 -1
  411. package/out/plugin/index.js +0 -1
  412. package/out/plugin/plugin-factory/plugin-factory.js +0 -297
  413. package/out/props/common.js +0 -23
  414. package/out/props/editor/array.js +0 -25
  415. package/out/props/editor/autocomplete.js +0 -25
  416. package/out/props/editor/cascader.js +0 -25
  417. package/out/props/editor/check-box-list.js +0 -25
  418. package/out/props/editor/check-box.js +0 -25
  419. package/out/props/editor/code.js +0 -29
  420. package/out/props/editor/color-picker.js +0 -25
  421. package/out/props/editor/common.js +0 -79
  422. package/out/props/editor/data-picker.js +0 -25
  423. package/out/props/editor/date-picker.js +0 -25
  424. package/out/props/editor/date-range.js +0 -21
  425. package/out/props/editor/dropdown-list.js +0 -25
  426. package/out/props/editor/html.js +0 -25
  427. package/out/props/editor/index.js +0 -25
  428. package/out/props/editor/list-box.js +0 -25
  429. package/out/props/editor/markdown.js +0 -28
  430. package/out/props/editor/number-range.js +0 -21
  431. package/out/props/editor/radio-button-list.js +0 -25
  432. package/out/props/editor/rate.js +0 -21
  433. package/out/props/editor/raw.js +0 -21
  434. package/out/props/editor/slider.js +0 -21
  435. package/out/props/editor/span.js +0 -25
  436. package/out/props/editor/stepper.js +0 -21
  437. package/out/props/editor/switch.js +0 -21
  438. package/out/props/editor/text-box.js +0 -73
  439. package/out/props/editor/upload.js +0 -25
  440. package/out/props/index.js +0 -2
  441. package/out/use/click-outside/click-outside.js +0 -50
  442. package/out/use/control/index.js +0 -1
  443. package/out/use/control/use-control-controller/use-control-controller.js +0 -94
  444. package/out/use/event/event.js +0 -39
  445. package/out/use/focus-blur/focus-blur.js +0 -63
  446. package/out/use/index.js +0 -9
  447. package/out/use/namespace/namespace.js +0 -13
  448. package/out/use/route/route.js +0 -41
  449. package/out/use/util/index.js +0 -23
  450. package/out/use/view/use-view-controller/use-view-controller.js +0 -94
  451. package/out/use/vue/vue.js +0 -112
  452. package/out/util/control/prepare-control.js +0 -25
  453. package/out/util/index.d.ts +0 -6
  454. package/out/util/index.d.ts.map +0 -1
  455. package/out/util/index.js +0 -5
  456. package/out/util/install.js +0 -6
  457. package/out/util/render/render.js +0 -28
  458. package/out/util/route/route-listener.js +0 -76
  459. package/out/util/route/route.d.ts.map +0 -1
  460. package/out/util/route/route.js +0 -385
  461. /package/{out → es}/interface/index.d.ts +0 -0
  462. /package/{out → es}/interface/index.d.ts.map +0 -0
  463. /package/{out → es}/interface/util/index.d.ts +0 -0
  464. /package/{out → es}/interface/util/index.d.ts.map +0 -0
  465. /package/{out → es}/interface/util/route/route.d.ts +0 -0
  466. /package/{out → es}/interface/util/route/route.d.ts.map +0 -0
  467. /package/{out → es}/plugin/index.d.ts +0 -0
  468. /package/{out → es}/plugin/index.d.ts.map +0 -0
  469. /package/{out → es}/plugin/plugin-factory/plugin-factory.d.ts +0 -0
  470. /package/{out → es}/plugin/plugin-factory/plugin-factory.d.ts.map +0 -0
  471. /package/{out → es}/props/common.d.ts +0 -0
  472. /package/{out → es}/props/common.d.ts.map +0 -0
  473. /package/{out → es}/props/editor/array.d.ts +0 -0
  474. /package/{out → es}/props/editor/array.d.ts.map +0 -0
  475. /package/{out → es}/props/editor/autocomplete.d.ts +0 -0
  476. /package/{out → es}/props/editor/autocomplete.d.ts.map +0 -0
  477. /package/{out → es}/props/editor/cascader.d.ts +0 -0
  478. /package/{out → es}/props/editor/cascader.d.ts.map +0 -0
  479. /package/{out → es}/props/editor/check-box-list.d.ts +0 -0
  480. /package/{out → es}/props/editor/check-box-list.d.ts.map +0 -0
  481. /package/{out → es}/props/editor/check-box.d.ts +0 -0
  482. /package/{out → es}/props/editor/check-box.d.ts.map +0 -0
  483. /package/{out → es}/props/editor/code.d.ts +0 -0
  484. /package/{out → es}/props/editor/code.d.ts.map +0 -0
  485. /package/{out → es}/props/editor/color-picker.d.ts +0 -0
  486. /package/{out → es}/props/editor/color-picker.d.ts.map +0 -0
  487. /package/{out → es}/props/editor/common.d.ts +0 -0
  488. /package/{out → es}/props/editor/common.d.ts.map +0 -0
  489. /package/{out → es}/props/editor/data-picker.d.ts +0 -0
  490. /package/{out → es}/props/editor/data-picker.d.ts.map +0 -0
  491. /package/{out → es}/props/editor/date-picker.d.ts +0 -0
  492. /package/{out → es}/props/editor/date-picker.d.ts.map +0 -0
  493. /package/{out → es}/props/editor/date-range.d.ts +0 -0
  494. /package/{out → es}/props/editor/date-range.d.ts.map +0 -0
  495. /package/{out → es}/props/editor/dropdown-list.d.ts +0 -0
  496. /package/{out → es}/props/editor/dropdown-list.d.ts.map +0 -0
  497. /package/{out → es}/props/editor/html.d.ts +0 -0
  498. /package/{out → es}/props/editor/html.d.ts.map +0 -0
  499. /package/{out → es}/props/editor/index.d.ts +0 -0
  500. /package/{out → es}/props/editor/index.d.ts.map +0 -0
  501. /package/{out → es}/props/editor/list-box.d.ts +0 -0
  502. /package/{out → es}/props/editor/list-box.d.ts.map +0 -0
  503. /package/{out → es}/props/editor/markdown.d.ts +0 -0
  504. /package/{out → es}/props/editor/markdown.d.ts.map +0 -0
  505. /package/{out → es}/props/editor/number-range.d.ts +0 -0
  506. /package/{out → es}/props/editor/number-range.d.ts.map +0 -0
  507. /package/{out → es}/props/editor/radio-button-list.d.ts +0 -0
  508. /package/{out → es}/props/editor/radio-button-list.d.ts.map +0 -0
  509. /package/{out → es}/props/editor/rate.d.ts +0 -0
  510. /package/{out → es}/props/editor/rate.d.ts.map +0 -0
  511. /package/{out → es}/props/editor/raw.d.ts +0 -0
  512. /package/{out → es}/props/editor/raw.d.ts.map +0 -0
  513. /package/{out → es}/props/editor/slider.d.ts +0 -0
  514. /package/{out → es}/props/editor/slider.d.ts.map +0 -0
  515. /package/{out → es}/props/editor/span.d.ts.map +0 -0
  516. /package/{out → es}/props/editor/stepper.d.ts +0 -0
  517. /package/{out → es}/props/editor/stepper.d.ts.map +0 -0
  518. /package/{out → es}/props/editor/switch.d.ts +0 -0
  519. /package/{out → es}/props/editor/switch.d.ts.map +0 -0
  520. /package/{out → es}/props/editor/text-box.d.ts +0 -0
  521. /package/{out → es}/props/editor/text-box.d.ts.map +0 -0
  522. /package/{out → es}/props/editor/upload.d.ts +0 -0
  523. /package/{out → es}/props/editor/upload.d.ts.map +0 -0
  524. /package/{out → es}/props/index.d.ts +0 -0
  525. /package/{out → es}/props/index.d.ts.map +0 -0
  526. /package/{out → es}/use/click-outside/click-outside.d.ts +0 -0
  527. /package/{out → es}/use/click-outside/click-outside.d.ts.map +0 -0
  528. /package/{out → es}/use/control/index.d.ts +0 -0
  529. /package/{out → es}/use/control/index.d.ts.map +0 -0
  530. /package/{out → es}/use/control/use-control-controller/use-control-controller.d.ts +0 -0
  531. /package/{out → es}/use/control/use-control-controller/use-control-controller.d.ts.map +0 -0
  532. /package/{out → es}/use/event/event.d.ts +0 -0
  533. /package/{out → es}/use/event/event.d.ts.map +0 -0
  534. /package/{out → es}/use/focus-blur/focus-blur.d.ts +0 -0
  535. /package/{out → es}/use/focus-blur/focus-blur.d.ts.map +0 -0
  536. /package/{out → es}/use/index.d.ts +0 -0
  537. /package/{out → es}/use/index.d.ts.map +0 -0
  538. /package/{out → es}/use/namespace/namespace.d.ts +0 -0
  539. /package/{out → es}/use/namespace/namespace.d.ts.map +0 -0
  540. /package/{out → es}/use/route/route.d.ts +0 -0
  541. /package/{out → es}/use/route/route.d.ts.map +0 -0
  542. /package/{out → es}/use/util/index.d.ts +0 -0
  543. /package/{out → es}/use/util/index.d.ts.map +0 -0
  544. /package/{out → es}/use/view/index.d.ts +0 -0
  545. /package/{out → es}/use/view/index.d.ts.map +0 -0
  546. /package/{out → es}/use/view/use-view-controller/use-view-controller.d.ts +0 -0
  547. /package/{out → es}/use/view/use-view-controller/use-view-controller.d.ts.map +0 -0
  548. /package/{out → es}/use/vue/vue.d.ts +0 -0
  549. /package/{out → es}/use/vue/vue.d.ts.map +0 -0
  550. /package/{out → es}/util/control/prepare-control.d.ts +0 -0
  551. /package/{out → es}/util/control/prepare-control.d.ts.map +0 -0
  552. /package/{out → es}/util/install.d.ts +0 -0
  553. /package/{out → es}/util/install.d.ts.map +0 -0
  554. /package/{out → es}/util/render/render.d.ts +0 -0
  555. /package/{out → es}/util/render/render.d.ts.map +0 -0
  556. /package/{out → es}/util/route/route-listener.d.ts +0 -0
  557. /package/{out → es}/util/route/route-listener.d.ts.map +0 -0
@@ -0,0 +1,351 @@
1
+ import {
2
+ EventBase,
3
+ IModal,
4
+ Modal,
5
+ OpenAppViewCommand,
6
+ IPanelItemNavPosController,
7
+ ViewMode,
8
+ INavViewMsg,
9
+ NavViewChangeEvent,
10
+ PanelItemController,
11
+ } from '@ibiz-template/runtime';
12
+ import { IPanelRawItem } from '@ibiz/model-core';
13
+ import { RouteLocationNormalizedLoaded, Router } from 'vue-router';
14
+ import { notNilEmpty } from 'qx-util';
15
+ import { mergeLeft } from 'ramda';
16
+ import { NavPosState } from './nav-pos.state';
17
+ /**
18
+ * 导航占位控制器
19
+ *
20
+ * @export
21
+ * @class NavPosController
22
+ * @extends {PanelItemController}
23
+ */
24
+ export class NavPosController
25
+ extends PanelItemController<IPanelRawItem>
26
+ implements IPanelItemNavPosController
27
+ {
28
+ /**
29
+ * 导航占位状态
30
+ *
31
+ * @type {NavPosState}
32
+ * @memberof NavPosController
33
+ */
34
+ declare state: NavPosState;
35
+
36
+ /**
37
+ * 导航视图的modal
38
+ *
39
+ * @type {{ [key: string]: IModal }}
40
+ * @memberof NavPosController
41
+ */
42
+ viewModals: { [key: string]: IModal } = {};
43
+
44
+ /**
45
+ * 当前导航视图
46
+ *
47
+ * @type {INavViewMsg}
48
+ * @memberof NavPosController
49
+ */
50
+ curNavViewMsg!: INavViewMsg;
51
+
52
+ /**
53
+ * Router 对象
54
+ *
55
+ * @type {Router}
56
+ * @memberof NavPosController
57
+ */
58
+ router!: Router;
59
+
60
+ /**
61
+ * 关联部件标识集合
62
+ * @author lxm
63
+ * @date 2023-08-10 07:35:08
64
+ * @type {string[]}
65
+ */
66
+ refCtrlKeys: string[] = [];
67
+
68
+ /**
69
+ * 自定义补充参数
70
+ *
71
+ * @author zk
72
+ * @date 2023-09-27 03:09:02
73
+ * @type {IData}
74
+ * @memberof NavPosController
75
+ */
76
+ rawItemParams: IData = {};
77
+
78
+ /**
79
+ * Route 对象
80
+ *
81
+ * @author zk
82
+ * @date 2023-06-29 04:06:59
83
+ * @type {RouteLocationNormalizedLoaded}
84
+ * @memberof NavPosController
85
+ */
86
+ get route(): RouteLocationNormalizedLoaded {
87
+ return this.router.currentRoute.value;
88
+ }
89
+
90
+ /**
91
+ * 导航项是否缓存
92
+ *
93
+ * @author zk
94
+ * @date 2023-09-27 03:09:49
95
+ * @param {INavViewMsg} navViewMsg
96
+ * @return {*} {boolean}
97
+ * @memberof NavPosController
98
+ */
99
+ getExpItemIsCache(navViewMsg: INavViewMsg): boolean {
100
+ if (this.rawItemParams.expcache === 'CACHE') {
101
+ return true;
102
+ }
103
+ if (this.rawItemParams.expcache === 'NO_CACHE') {
104
+ return false;
105
+ }
106
+ return navViewMsg.isCache as boolean;
107
+ }
108
+
109
+ /**
110
+ * 设置 Router 对象
111
+ *
112
+ * @param {Router} router
113
+ * @memberof NavPosController
114
+ */
115
+ setRouter(router: Router): void {
116
+ this.router = router;
117
+ }
118
+
119
+ protected async onInit(): Promise<void> {
120
+ await super.onInit();
121
+ this.handleRawItemParams();
122
+ if (this.model.rawItem?.rawItemParams) {
123
+ this.model.rawItem.rawItemParams.find(item => {
124
+ if (item.key === 'REFCTRL' && item.value) {
125
+ this.refCtrlKeys = item.value
126
+ .split(';')
127
+ .map(str => str.toLowerCase());
128
+ return true;
129
+ }
130
+ return false;
131
+ });
132
+ }
133
+
134
+ this.panel.evt.on('onControlEvent', event => {
135
+ // 是否是关联部件,如果没有配置都监控,配置了只监控指定部件
136
+ const isRefCtrl =
137
+ this.refCtrlKeys.length === 0 ||
138
+ this.refCtrlKeys.includes(event.triggerControlName);
139
+ if (isRefCtrl && event.triggerEventName === 'onNavViewChange') {
140
+ const triggerEvent = event.triggerEvent as NavViewChangeEvent;
141
+ this.openView(triggerEvent.navViewMsg);
142
+ }
143
+ });
144
+
145
+ // 根据 导航占位参数 || 视图参数 判断是否用路由打开视图 不使用:NO_ROUTE 使用 :ROUTE
146
+ // 导航占位参数优先级大于视图参数
147
+ const expRoute =
148
+ this.rawItemParams.expmode || this.panel.view.params.expmode;
149
+
150
+ // 路由模式下 必须为路由打开
151
+ if (expRoute === 'ROUTE' && this.routeDepth) {
152
+ this.state.routeOpen = true;
153
+ } else if (expRoute === 'NO_ROUTE') {
154
+ this.state.routeOpen = false;
155
+ } else {
156
+ this.state.routeOpen = !!this.routeDepth;
157
+ }
158
+ // 消费完参数销毁 expmode
159
+ if (this.panel.view.params.expmode) {
160
+ delete this.panel.view.params.expmode;
161
+ }
162
+ }
163
+
164
+ /**
165
+ * 创建导航占位状态对象
166
+ *
167
+ * @protected
168
+ * @return {*} {NavPosState}
169
+ * @memberof NavPosController
170
+ */
171
+ protected createState(): NavPosState {
172
+ return new NavPosState(this.parent?.state);
173
+ }
174
+
175
+ /**
176
+ * 当前路由视图的层级
177
+ *
178
+ * @readonly
179
+ * @type {(number | undefined)}
180
+ * @memberof NavPosController
181
+ */
182
+ get routeDepth(): number | undefined {
183
+ return this.panel.view.modal.routeDepth;
184
+ }
185
+
186
+ /**
187
+ * 路由改变
188
+ *
189
+ * @memberof NavPosController
190
+ */
191
+ onRouteChange(route: RouteLocationNormalizedLoaded): void {
192
+ // 没有当前导航视图信息时不做任何处理
193
+ if (this.curNavViewMsg) {
194
+ // 路由打开的视图,currentKey在路由变更之后改值。此时新建的视图才能识别到跳转之后的路由。
195
+ this.state.currentKey = this.curNavViewMsg.key;
196
+
197
+ // 更新fullPath信息
198
+ this.state.navViewMsgs[this.curNavViewMsg.key].fullPath = route.fullPath;
199
+ }
200
+ }
201
+
202
+ /**
203
+ * 设置导航视图信息
204
+ *
205
+ * @author zk
206
+ * @date 2023-06-29 02:06:41
207
+ * @param {INavViewMsg} navViewMsg 导航视图信息
208
+ * @memberof NavPosController
209
+ */
210
+ setNavViewMsgs(navViewMsg: INavViewMsg): void {
211
+ // 已经存在的更新数据
212
+ if (this.state.navViewMsgs[navViewMsg.key]) {
213
+ mergeLeft(this.state.navViewMsgs[navViewMsg.key], navViewMsg);
214
+ } else {
215
+ // 不存在的走新建流程
216
+ this.state.navViewMsgs[navViewMsg.key] = navViewMsg;
217
+ if (this.getExpItemIsCache(navViewMsg)) {
218
+ // 往缓存keys里添加新视图的key
219
+ this.state.cacheKeys.push(navViewMsg.key);
220
+ }
221
+ this.viewModals[navViewMsg.key] = new Modal({
222
+ mode: this.routeDepth ? ViewMode.ROUTE : ViewMode.EMBED,
223
+ routeDepth: this.routeDepth ? this.routeDepth + 1 : undefined,
224
+ dismiss: () => {
225
+ // 执行对应key的dismiss方法
226
+ this.dismiss(navViewMsg.key);
227
+ },
228
+ });
229
+ }
230
+
231
+ // todo 换个方式
232
+ this.curNavViewMsg = this.state.navViewMsgs[navViewMsg.key];
233
+ }
234
+
235
+ /**
236
+ * 自身的dismiss相关操作
237
+ *
238
+ * @param {string} key
239
+ * @memberof NavPosController
240
+ */
241
+ dismiss(key: string): void {
242
+ ibiz.log.debug(this.constructor.name, 'dismiss', key);
243
+ }
244
+
245
+ /**
246
+ * 监听视图创建
247
+ *
248
+ * @param {EventBase} event
249
+ * @memberof NavPosController
250
+ */
251
+ onViewCreated(event: EventBase): void {
252
+ ibiz.log.debug(this.constructor.name, 'onViewCreated', event);
253
+ }
254
+
255
+ /**
256
+ * 打开视图
257
+ *
258
+ * @param {INavViewMsg} openViewMsg
259
+ * @memberof NavPosController
260
+ */
261
+ openView(openViewMsg: INavViewMsg): void {
262
+ // 当key为空时,直接切换currentKey,绘制null
263
+ if (!openViewMsg.key) {
264
+ this.state.currentKey = openViewMsg.key;
265
+ return;
266
+ }
267
+
268
+ if (this.routeDepth && this.state.routeOpen) {
269
+ this.openViewByPath(openViewMsg);
270
+ } else {
271
+ this.openViewByModel(openViewMsg);
272
+ }
273
+ }
274
+
275
+ /**
276
+ * 通过路由打开视图
277
+ *
278
+ * @param {INavViewMsg} openViewMsg
279
+ * @memberof NavPosController
280
+ */
281
+ openViewByPath(openViewMsg: INavViewMsg): void {
282
+ this.setNavViewMsgs(openViewMsg);
283
+ const isRoutePushed =
284
+ this.state.navViewMsgs[this.curNavViewMsg.key].isRoutePushed === true;
285
+ // * 外部跳转过了的场景不需要这边跳转路由了,直接处理后续内容。
286
+ if (isRoutePushed) {
287
+ this.state.currentKey = openViewMsg.key;
288
+ this.state.navViewMsgs[this.curNavViewMsg.key].fullPath =
289
+ this.route.fullPath;
290
+ return;
291
+ }
292
+
293
+ // * 路由跳转
294
+ // 如果启用缓存并且有之前存过的fullPath则push回fullPath。
295
+ if (
296
+ this.state.navViewMsgs[openViewMsg.key].fullPath &&
297
+ this.getExpItemIsCache(openViewMsg)
298
+ ) {
299
+ this.router.push(this.state.navViewMsgs[openViewMsg.key].fullPath!);
300
+ } else {
301
+ // 走视图路由打开逻辑计算并push
302
+ const tempContext = Object.assign(openViewMsg.context!.clone(), {
303
+ toRouteDepth: this.routeDepth! + 1,
304
+ });
305
+ if (this.getExpItemIsCache(openViewMsg)) {
306
+ this.state.cacheKeys.push(openViewMsg.key);
307
+ }
308
+ ibiz.commands.execute(
309
+ OpenAppViewCommand.TAG,
310
+ openViewMsg.viewId,
311
+ tempContext,
312
+ openViewMsg.params,
313
+ { openMode: 'INDEXVIEWTAB' },
314
+ );
315
+ }
316
+
317
+ // !跳转路由过后,修改currentKey由onRouteChange那边路由变更之后处理。
318
+ }
319
+
320
+ /**
321
+ * 通过模型绘制视图
322
+ *
323
+ * @param {INavViewMsg} openViewMsg
324
+ * @memberof NavPosController
325
+ */
326
+ openViewByModel(openViewMsg: INavViewMsg): void {
327
+ this.setNavViewMsgs(openViewMsg);
328
+ // 切换currentKey,重新渲染openViewMsg
329
+ this.state.currentKey = openViewMsg.key;
330
+ }
331
+
332
+ /**
333
+ * 处理自定义补充参数 [{key:'name',value:'data'}] => {name:'data'}
334
+ *
335
+ * @author zk
336
+ * @date 2023-09-27 03:09:55
337
+ * @protected
338
+ * @memberof NavPosController
339
+ */
340
+ protected handleRawItemParams(): void {
341
+ let params = {};
342
+ const rawItemParams = this.model.rawItem?.rawItemParams;
343
+ if (notNilEmpty(rawItemParams)) {
344
+ params = rawItemParams!.reduce((param: IData, item) => {
345
+ param[item.key!.toLowerCase()] = item.value;
346
+ return param;
347
+ }, {});
348
+ }
349
+ Object.assign(this.rawItemParams, params);
350
+ }
351
+ }
@@ -0,0 +1,38 @@
1
+ import {
2
+ IPanelItemNavPosController,
3
+ IPanelItemProvider,
4
+ PanelController,
5
+ PanelItemController,
6
+ } from '@ibiz-template/runtime';
7
+ import { IPanelItem } from '@ibiz/model-core';
8
+ import { NavPosController } from './nav-pos.controller';
9
+
10
+ /**
11
+ * 导航占位适配器
12
+ *
13
+ * @export
14
+ * @class NavPosProvider
15
+ * @implements {IPanelItemProvider}
16
+ */
17
+ export class NavPosProvider implements IPanelItemProvider {
18
+ component: string = 'IBizNavPos';
19
+
20
+ /**
21
+ * 创建控制器
22
+ *
23
+ * @param {IPanelItem} panelItem
24
+ * @param {PanelController} panel
25
+ * @param {(PanelItemController | undefined)} parent
26
+ * @return {*} {Promise<IPanelItemNavPosController>}
27
+ * @memberof NavPosProvider
28
+ */
29
+ async createController(
30
+ panelItem: IPanelItem,
31
+ panel: PanelController,
32
+ parent: PanelItemController | undefined,
33
+ ): Promise<IPanelItemNavPosController> {
34
+ const c = new NavPosController(panelItem, panel, parent);
35
+ await c.init();
36
+ return c;
37
+ }
38
+ }
@@ -0,0 +1,4 @@
1
+ @include b(nav-pos) {
2
+ width: 100%;
3
+ height: 100%;
4
+ }
@@ -0,0 +1,52 @@
1
+ import { INavViewMsg, PanelItemState } from '@ibiz-template/runtime';
2
+
3
+ /**
4
+ * 导航占位状态
5
+ *
6
+ * @export
7
+ * @class NavPosState
8
+ * @extends {PanelItemState}
9
+ */
10
+ export class NavPosState extends PanelItemState {
11
+ /**
12
+ * 是否启用缓存
13
+ *
14
+ * @type {boolean}
15
+ * @memberof NavPosState
16
+ */
17
+ cache: boolean = true;
18
+
19
+ /**
20
+ * 是否是路由打开
21
+ *
22
+ * @author zk
23
+ * @date 2023-09-26 04:09:23
24
+ * @type {boolean}
25
+ * @memberof NavPosState
26
+ */
27
+ routeOpen: boolean = true;
28
+
29
+ /**
30
+ * 当前导航视图标识
31
+ * @author lxm
32
+ * @date 2023-05-25 06:24:48
33
+ * @type {string}
34
+ */
35
+ currentKey: string = '';
36
+
37
+ /**
38
+ * 缓存的视图标识
39
+ * @author lxm
40
+ * @date 2023-05-25 06:25:21
41
+ * @type {string[]}
42
+ */
43
+ cacheKeys: string[] = ['RouterShell'];
44
+
45
+ /**
46
+ * 导航视图详细信息
47
+ * @author lxm
48
+ * @date 2023-05-25 07:07:05
49
+ * @type {INavViewMsg[]}
50
+ */
51
+ navViewMsgs: { [p: string]: INavViewMsg } = {};
52
+ }
@@ -0,0 +1,121 @@
1
+ import {
2
+ defineComponent,
3
+ h,
4
+ PropType,
5
+ resolveComponent,
6
+ VNode,
7
+ watch,
8
+ } from 'vue';
9
+ import { IPanelRawItem } from '@ibiz/model-core';
10
+ import { EventBase } from '@ibiz-template/runtime';
11
+ import { useRoute, useRouter } from 'vue-router';
12
+ import { NavPosController } from './nav-pos.controller';
13
+ import './nav-pos.scss';
14
+ import { useNamespace } from '../../use';
15
+ import { getNestedRoutePath } from '../../util';
16
+
17
+ export const NavPos = defineComponent({
18
+ name: 'IBizNavPos',
19
+ props: {
20
+ modelData: {
21
+ type: Object as PropType<IPanelRawItem>,
22
+ required: true,
23
+ },
24
+ controller: {
25
+ type: NavPosController,
26
+ required: true,
27
+ },
28
+ },
29
+ setup(props) {
30
+ const c = props.controller;
31
+ const ns = useNamespace('nav-pos');
32
+ const onViewCreated = (event: EventBase): void => {
33
+ c.onViewCreated(event);
34
+ };
35
+
36
+ const router = useRouter();
37
+ const route = useRoute();
38
+
39
+ c.setRouter(router);
40
+
41
+ if (c.routeDepth) {
42
+ // 计算当前导航视图对应层级路由的路径,删除了srfnav
43
+ const expViewRoutePath = getNestedRoutePath(route, c.routeDepth!);
44
+ watch(
45
+ () => route.fullPath,
46
+ () => {
47
+ const currentRoutePath = getNestedRoutePath(route, c.routeDepth!);
48
+ // 前面路由不是当前导航视图的不走
49
+ // 路由跳转匹配层级不比导航视图层级高的不走。如分页关系的表单对应的事导航视图的路由。
50
+ if (
51
+ expViewRoutePath === currentRoutePath &&
52
+ route.matched.length > c.routeDepth!
53
+ ) {
54
+ c.onRouteChange(route);
55
+ }
56
+ },
57
+ { immediate: true },
58
+ );
59
+ }
60
+
61
+ return { ns, c, onViewCreated };
62
+ },
63
+ render() {
64
+ const { viewModals, state } = this.c;
65
+ const { currentKey, cacheKeys, navViewMsgs, cache } = state;
66
+ let content: VNode | null = null;
67
+ if (state.routeOpen) {
68
+ content = (
69
+ <iBizRouterView
70
+ manualKey={currentKey}
71
+ modal={viewModals[currentKey]}
72
+ onCreated={this.onViewCreated}
73
+ >
74
+ {({ Component }: { Component: string }): VNode | null => {
75
+ const routerContent =
76
+ currentKey === '' || !Component
77
+ ? null
78
+ : ((<Component />) as VNode);
79
+
80
+ return cache ? (
81
+ <keepAlive include={cacheKeys} max={30} isKey>
82
+ {routerContent}
83
+ </keepAlive>
84
+ ) : (
85
+ routerContent
86
+ );
87
+ }}
88
+ </iBizRouterView>
89
+ );
90
+ } else {
91
+ const view = currentKey
92
+ ? h(resolveComponent('IBizViewShell'), {
93
+ context: navViewMsgs[currentKey].context,
94
+ params: navViewMsgs[currentKey].params,
95
+ key: navViewMsgs[currentKey].key,
96
+ viewId: navViewMsgs[currentKey].viewId,
97
+ onCreated: this.onViewCreated,
98
+ })
99
+ : null;
100
+ content = cache ? (
101
+ <keepAlive include={cacheKeys} max={30} isKey>
102
+ {view}
103
+ </keepAlive>
104
+ ) : (
105
+ view
106
+ );
107
+ }
108
+
109
+ return (
110
+ <div
111
+ class={[
112
+ this.ns.b(),
113
+ this.ns.m(this.modelData.id),
114
+ ...this.controller.containerClass,
115
+ ]}
116
+ >
117
+ {content}
118
+ </div>
119
+ );
120
+ },
121
+ });
@@ -0,0 +1,31 @@
1
+ import { App } from 'vue';
2
+ import { registerPanelItemProvider } from '@ibiz-template/runtime';
3
+ import { withInstall } from '../../util';
4
+ import { PanelContainer } from './panel-container';
5
+ import { PanelContainerProvider } from './panel-container.provider';
6
+ import { PanelContainerState } from './panel-container.state';
7
+ import { PanelContainerController } from './panel-container.controller';
8
+
9
+ export {
10
+ PanelContainerProvider,
11
+ PanelContainerState,
12
+ PanelContainerController,
13
+ };
14
+
15
+ export const IBizPanelContainer = withInstall(
16
+ PanelContainer,
17
+ function (v: App) {
18
+ v.component(PanelContainer.name, PanelContainer);
19
+ registerPanelItemProvider('CONTAINER', () => new PanelContainerProvider());
20
+ registerPanelItemProvider(
21
+ 'CONTAINER_DEFAULT',
22
+ () => new PanelContainerProvider(),
23
+ );
24
+ // registerPanelItemProvider(
25
+ // 'CONTAINER_CONTAINER_GRID',
26
+ // () => new PanelContainerProvider(),
27
+ // );
28
+ },
29
+ );
30
+
31
+ export default IBizPanelContainer;
@@ -0,0 +1,18 @@
1
+ import { PanelItemController } from '@ibiz-template/runtime';
2
+ import { IPanelContainer } from '@ibiz/model-core';
3
+ import { PanelContainerState } from './panel-container.state';
4
+
5
+ /**
6
+ * 面板容器控制器
7
+ *
8
+ * @export
9
+ * @class PanelContainerController
10
+ * @extends {PanelItemController}
11
+ */
12
+ export class PanelContainerController extends PanelItemController<IPanelContainer> {
13
+ declare state: PanelContainerState;
14
+
15
+ protected createState(): PanelContainerState {
16
+ return new PanelContainerState(this.parent?.state);
17
+ }
18
+ }
@@ -0,0 +1,30 @@
1
+ import {
2
+ IPanelItemProvider,
3
+ PanelController,
4
+ PanelItemController,
5
+ } from '@ibiz-template/runtime';
6
+ import { IPanelContainer } from '@ibiz/model-core';
7
+ import { PanelContainerController } from './panel-container.controller';
8
+
9
+ /**
10
+ * 面板容器适配器
11
+ *
12
+ * @author lxm
13
+ * @date 2022-09-19 22:09:03
14
+ * @export
15
+ * @class PanelContainerProvider
16
+ * @implements {EditorProvider}
17
+ */
18
+ export class PanelContainerProvider implements IPanelItemProvider {
19
+ component: string = 'IBizPanelContainer';
20
+
21
+ async createController(
22
+ panelItem: IPanelContainer,
23
+ panel: PanelController,
24
+ parent: PanelItemController | undefined,
25
+ ): Promise<PanelItemController> {
26
+ const c = new PanelContainerController(panelItem, panel, parent);
27
+ await c.init();
28
+ return c;
29
+ }
30
+ }
@@ -0,0 +1,15 @@
1
+ // 默认样式
2
+ @include b(panel-container) {
3
+ width: 100%;
4
+ height: 100%;
5
+
6
+ > .#{bem('row')} {
7
+ height: 100%;
8
+ overflow-x: hidden;
9
+ overflow-y: auto;
10
+ }
11
+
12
+ @include when(hidden) {
13
+ display: none;
14
+ }
15
+ }
@@ -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 PanelContainerState
10
+ * @extends {PanelItemState}
11
+ */
12
+ export class PanelContainerState extends PanelItemState {}