@ctzy-web-client/plugin-component-vue 1.0.0 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/es/_virtual/_plugin-vue_export-helper.mjs +9 -0
  2. package/es/advance-select/advance-operation.mjs +43 -0
  3. package/es/advance-select/advance-option.mjs +125 -0
  4. package/es/advance-select/advance-select.mjs +359 -0
  5. package/es/advance-select/events-helpers.mjs +29 -0
  6. package/es/advance-select/index.mjs +13 -0
  7. package/es/advance-select/use-advance-option.mjs +43 -0
  8. package/es/advance-select/use-advance-select.mjs +117 -0
  9. package/es/application-slot/application-slot.mjs +51 -0
  10. package/es/application-slot/breadcrumb-item.mjs +23 -0
  11. package/es/application-slot/header-tools-item.mjs +23 -0
  12. package/es/application-slot/index.mjs +16 -0
  13. package/es/breadcrumb-select/breadcrumb-select.mjs +155 -0
  14. package/es/breadcrumb-select/index.mjs +6 -0
  15. package/es/components.mjs +22 -0
  16. package/es/contextmenu/contextmenu-item.mjs +21 -0
  17. package/es/contextmenu/contextmenu.mjs +64 -0
  18. package/es/contextmenu/index.mjs +10 -0
  19. package/es/contextmenu/use-contextmenu.mjs +85 -0
  20. package/es/data-form/data-form-item.mjs +53 -0
  21. package/es/data-form/data-form.mjs +175 -0
  22. package/es/data-form/dynamic-component.mjs +23 -0
  23. package/es/data-form/form-components/Blots/AtBlot.mjs +25 -0
  24. package/es/data-form/form-components/bwa-date-picker.mjs +45 -0
  25. package/es/data-form/form-components/bwa-date-time-picker.mjs +50 -0
  26. package/es/data-form/form-components/bwa-input-float.mjs +43 -0
  27. package/es/data-form/form-components/bwa-input-integer.mjs +56 -0
  28. package/es/data-form/form-components/bwa-input.mjs +38 -0
  29. package/es/data-form/form-components/bwa-multi-select.mjs +35 -0
  30. package/es/data-form/form-components/bwa-rich-text-tinymce.mjs +234 -0
  31. package/es/data-form/form-components/bwa-rich-text.mjs +325 -0
  32. package/es/data-form/form-components/bwa-select.mjs +76 -0
  33. package/es/data-form/form-components/bwa-textarea.mjs +33 -0
  34. package/es/data-form/form-components/bwa-upload.mjs +159 -0
  35. package/es/data-form/form-components/bwa-user-multi-select.mjs +30 -0
  36. package/es/data-form/form-components/bwa-user-select.mjs +69 -0
  37. package/es/data-form/index.mjs +34 -0
  38. package/es/data-table/data-column-view.mjs +131 -0
  39. package/es/data-table/data-table-card.mjs +118 -0
  40. package/es/data-table/data-table-column.mjs +56 -0
  41. package/es/data-table/data-table.mjs +369 -0
  42. package/es/data-table/dynamic-component.mjs +48 -0
  43. package/es/data-table/index.mjs +13 -0
  44. package/es/data-table/use-datatable-drag.mjs +110 -0
  45. package/es/datatable-settings/datatable-settings.mjs +309 -0
  46. package/es/datatable-settings/index.mjs +6 -0
  47. package/es/date-range/date-picker.mjs +128 -0
  48. package/es/date-range/date-range.mjs +181 -0
  49. package/es/date-range/index.mjs +6 -0
  50. package/es/drag-list/constants.mjs +3 -0
  51. package/es/drag-list/drag-item.mjs +49 -0
  52. package/es/drag-list/drag-list.mjs +56 -0
  53. package/es/drag-list/index.mjs +6 -0
  54. package/es/drag-list/use-drag-list.mjs +154 -0
  55. package/es/dragable/constants.mjs +4 -0
  56. package/es/dragable/dragable-item.mjs +25 -0
  57. package/es/dragable/dragable-operation.mjs +32 -0
  58. package/es/dragable/dragable.mjs +31 -0
  59. package/es/dragable/index.mjs +15 -0
  60. package/es/dragable/use-dragable.mjs +134 -0
  61. package/es/filter-panel/conditions/condition.mjs +30 -0
  62. package/es/filter-panel/conditions/date-range-condition.mjs +46 -0
  63. package/es/filter-panel/conditions/department-condition/department-condition.mjs +81 -0
  64. package/es/filter-panel/conditions/department-condition/department-node.mjs +74 -0
  65. package/es/filter-panel/conditions/index.mjs +21 -0
  66. package/es/filter-panel/conditions/input-condition.mjs +83 -0
  67. package/es/filter-panel/conditions/multi-user-condition.mjs +64 -0
  68. package/es/filter-panel/conditions/multiple-menu-condition.mjs +41 -0
  69. package/es/filter-panel/conditions/single-menu-condition.mjs +68 -0
  70. package/es/filter-panel/conditions/single-user-condition.mjs +64 -0
  71. package/es/filter-panel/filter-panel-item.mjs +47 -0
  72. package/es/filter-panel/filter-panel.mjs +180 -0
  73. package/es/filter-panel/index.mjs +15 -0
  74. package/es/filter-panel/use-filter-panel-item.mjs +52 -0
  75. package/es/filter-panel/use-filter-panel.mjs +135 -0
  76. package/es/hooks/use-data/index.mjs +152 -0
  77. package/es/index.mjs +27 -0
  78. package/es/layout/index.mjs +6 -0
  79. package/es/layout/layout.mjs +86 -0
  80. package/es/make-installer.mjs +34 -0
  81. package/es/math/Rectangle.mjs +25 -0
  82. package/es/menu/index.mjs +6 -0
  83. package/es/menu/menu-item.mjs +75 -0
  84. package/es/menu/menu.mjs +60 -0
  85. package/es/node_modules/.pnpm/@vueuse_core@9.6.0_vue@3.2.41/node_modules/@vueuse/core/index.mjs +6372 -0
  86. package/es/node_modules/.pnpm/@vueuse_shared@9.6.0_vue@3.2.41/node_modules/@vueuse/shared/index.mjs +1517 -0
  87. package/es/panel/index.mjs +6 -0
  88. package/es/panel/panel.mjs +55 -0
  89. package/es/panel-tabs/index.mjs +6 -0
  90. package/es/panel-tabs/panel-tabs.mjs +66 -0
  91. package/es/pct-filter-panel/index.mjs +10 -0
  92. package/es/pct-filter-panel/pct-compents/index.mjs +10 -0
  93. package/es/pct-filter-panel/pct-compents/pct-Input-condition.mjs +71 -0
  94. package/es/pct-filter-panel/pct-compents/pct-date-range-condition.mjs +74 -0
  95. package/es/pct-filter-panel/pct-compents/pct-multiple-menu-condition.mjs +186 -0
  96. package/es/pct-filter-panel/pct-compents/pct-multiple-menu-condition2.mjs +147 -0
  97. package/es/pct-filter-panel/pct-filter-panel-item.mjs +48 -0
  98. package/es/pct-filter-panel/pct-filter-panel.mjs +251 -0
  99. package/es/pct-filter-panel/use-filter-panel-item.mjs +56 -0
  100. package/es/pct-filter-panel/use-filter-panel.mjs +127 -0
  101. package/es/plugins.mjs +5 -0
  102. package/es/progress/index.mjs +10 -0
  103. package/es/progress/progress-item.mjs +68 -0
  104. package/es/progress/progress.mjs +74 -0
  105. package/es/progress/use-progress.mjs +46 -0
  106. package/es/utils/db.mjs +9 -0
  107. package/es/utils.mjs +99 -0
  108. package/es/where-filter-panel/index.mjs +1 -0
  109. package/es/where-filter-panel/use-where-filter-panel.mjs +18 -0
  110. package/es/where-filter-panel/where-filter-panel.mjs +17 -0
  111. package/lib/_virtual/_plugin-vue_export-helper.js +13 -0
  112. package/lib/advance-select/advance-operation.js +47 -0
  113. package/lib/advance-select/advance-option.js +129 -0
  114. package/lib/advance-select/advance-select.js +363 -0
  115. package/lib/advance-select/events-helpers.js +33 -0
  116. package/lib/advance-select/index.js +20 -0
  117. package/lib/advance-select/use-advance-option.js +47 -0
  118. package/lib/advance-select/use-advance-select.js +122 -0
  119. package/lib/application-slot/application-slot.js +55 -0
  120. package/lib/application-slot/breadcrumb-item.js +27 -0
  121. package/lib/application-slot/header-tools-item.js +27 -0
  122. package/lib/application-slot/index.js +23 -0
  123. package/lib/breadcrumb-select/breadcrumb-select.js +159 -0
  124. package/lib/breadcrumb-select/index.js +11 -0
  125. package/lib/components.js +26 -0
  126. package/lib/contextmenu/contextmenu-item.js +25 -0
  127. package/lib/contextmenu/contextmenu.js +68 -0
  128. package/lib/contextmenu/index.js +16 -0
  129. package/lib/contextmenu/use-contextmenu.js +89 -0
  130. package/lib/data-form/data-form-item.js +57 -0
  131. package/lib/data-form/data-form.js +179 -0
  132. package/lib/data-form/dynamic-component.js +27 -0
  133. package/lib/data-form/form-components/Blots/AtBlot.js +31 -0
  134. package/lib/data-form/form-components/bwa-date-picker.js +49 -0
  135. package/lib/data-form/form-components/bwa-date-time-picker.js +54 -0
  136. package/lib/data-form/form-components/bwa-input-float.js +47 -0
  137. package/lib/data-form/form-components/bwa-input-integer.js +60 -0
  138. package/lib/data-form/form-components/bwa-input.js +42 -0
  139. package/lib/data-form/form-components/bwa-multi-select.js +39 -0
  140. package/lib/data-form/form-components/bwa-rich-text-tinymce.js +242 -0
  141. package/lib/data-form/form-components/bwa-rich-text.js +333 -0
  142. package/lib/data-form/form-components/bwa-select.js +80 -0
  143. package/lib/data-form/form-components/bwa-textarea.js +37 -0
  144. package/lib/data-form/form-components/bwa-upload.js +163 -0
  145. package/lib/data-form/form-components/bwa-user-multi-select.js +34 -0
  146. package/lib/data-form/form-components/bwa-user-select.js +73 -0
  147. package/lib/data-form/index.js +40 -0
  148. package/lib/data-table/data-column-view.js +135 -0
  149. package/lib/data-table/data-table-card.js +122 -0
  150. package/lib/data-table/data-table-column.js +60 -0
  151. package/lib/data-table/data-table.js +373 -0
  152. package/lib/data-table/dynamic-component.js +56 -0
  153. package/lib/data-table/index.js +20 -0
  154. package/lib/data-table/use-datatable-drag.js +114 -0
  155. package/lib/datatable-settings/datatable-settings.js +313 -0
  156. package/lib/datatable-settings/index.js +11 -0
  157. package/lib/date-range/date-picker.js +136 -0
  158. package/lib/date-range/date-range.js +189 -0
  159. package/lib/date-range/index.js +11 -0
  160. package/lib/drag-list/constants.js +7 -0
  161. package/lib/drag-list/drag-item.js +53 -0
  162. package/lib/drag-list/drag-list.js +60 -0
  163. package/lib/drag-list/index.js +11 -0
  164. package/lib/drag-list/use-drag-list.js +158 -0
  165. package/lib/dragable/constants.js +9 -0
  166. package/lib/dragable/dragable-item.js +29 -0
  167. package/lib/dragable/dragable-operation.js +36 -0
  168. package/lib/dragable/dragable.js +35 -0
  169. package/lib/dragable/index.js +22 -0
  170. package/lib/dragable/use-dragable.js +138 -0
  171. package/lib/filter-panel/conditions/condition.js +34 -0
  172. package/lib/filter-panel/conditions/date-range-condition.js +50 -0
  173. package/lib/filter-panel/conditions/department-condition/department-condition.js +85 -0
  174. package/lib/filter-panel/conditions/department-condition/department-node.js +78 -0
  175. package/lib/filter-panel/conditions/index.js +26 -0
  176. package/lib/filter-panel/conditions/input-condition.js +87 -0
  177. package/lib/filter-panel/conditions/multi-user-condition.js +68 -0
  178. package/lib/filter-panel/conditions/multiple-menu-condition.js +45 -0
  179. package/lib/filter-panel/conditions/single-menu-condition.js +72 -0
  180. package/lib/filter-panel/conditions/single-user-condition.js +68 -0
  181. package/lib/filter-panel/filter-panel-item.js +51 -0
  182. package/lib/filter-panel/filter-panel.js +184 -0
  183. package/lib/filter-panel/index.js +20 -0
  184. package/lib/filter-panel/use-filter-panel-item.js +56 -0
  185. package/lib/filter-panel/use-filter-panel.js +139 -0
  186. package/lib/hooks/use-data/index.js +157 -0
  187. package/lib/index.js +60 -0
  188. package/lib/layout/index.js +11 -0
  189. package/lib/layout/layout.js +90 -0
  190. package/lib/make-installer.js +62 -0
  191. package/lib/math/Rectangle.js +29 -0
  192. package/lib/menu/index.js +11 -0
  193. package/lib/menu/menu-item.js +79 -0
  194. package/lib/menu/menu.js +64 -0
  195. package/lib/node_modules/.pnpm/@vueuse_core@9.6.0_vue@3.2.41/node_modules/@vueuse/core/index.js +6635 -0
  196. package/lib/node_modules/.pnpm/@vueuse_shared@9.6.0_vue@3.2.41/node_modules/@vueuse/shared/index.js +1628 -0
  197. package/lib/panel/index.js +11 -0
  198. package/lib/panel/panel.js +59 -0
  199. package/lib/panel-tabs/index.js +11 -0
  200. package/lib/panel-tabs/panel-tabs.js +70 -0
  201. package/lib/pct-filter-panel/index.js +14 -0
  202. package/lib/pct-filter-panel/pct-compents/index.js +16 -0
  203. package/lib/pct-filter-panel/pct-compents/pct-Input-condition.js +75 -0
  204. package/lib/pct-filter-panel/pct-compents/pct-date-range-condition.js +78 -0
  205. package/lib/pct-filter-panel/pct-compents/pct-multiple-menu-condition.js +190 -0
  206. package/lib/pct-filter-panel/pct-compents/pct-multiple-menu-condition2.js +151 -0
  207. package/lib/pct-filter-panel/pct-filter-panel-item.js +52 -0
  208. package/lib/pct-filter-panel/pct-filter-panel.js +255 -0
  209. package/lib/pct-filter-panel/use-filter-panel-item.js +60 -0
  210. package/lib/pct-filter-panel/use-filter-panel.js +131 -0
  211. package/lib/plugins.js +9 -0
  212. package/lib/progress/index.js +16 -0
  213. package/lib/progress/progress-item.js +72 -0
  214. package/lib/progress/progress.js +78 -0
  215. package/lib/progress/use-progress.js +51 -0
  216. package/lib/utils/db.js +17 -0
  217. package/lib/utils.js +110 -0
  218. package/lib/where-filter-panel/index.js +2 -0
  219. package/lib/where-filter-panel/use-where-filter-panel.js +22 -0
  220. package/lib/where-filter-panel/where-filter-panel.js +21 -0
  221. package/package.json +1 -1
  222. package/style/advance-select.css +1 -0
  223. package/style/breadcrumb-select.css +1 -0
  224. package/style/common.css +1 -0
  225. package/style/contextmenu.css +1 -0
  226. package/style/data-form.css +1 -0
  227. package/style/data-table.css +1 -0
  228. package/style/datatable-settings.css +1 -0
  229. package/style/date-range.css +1 -0
  230. package/style/department-condition.css +1 -0
  231. package/style/drag-list.css +1 -0
  232. package/style/dragable.css +1 -0
  233. package/style/filter-panel.css +1 -0
  234. package/style/index.css +1 -0
  235. package/style/input-condition.css +1 -0
  236. package/style/layout.css +1 -0
  237. package/style/menu.css +1 -0
  238. package/style/panel-tabs.css +1 -0
  239. package/style/panel.css +1 -0
  240. package/style/pct-filter-panel.css +1 -0
  241. package/style/progress.css +1 -0
  242. package/style/rich-text.css +1 -0
  243. package/style/{common → src/common}/var.scss +16 -16
  244. package/style/var.css +1 -0
  245. /package/style/{advance-select.scss → src/advance-select.scss} +0 -0
  246. /package/style/{breadcrumb-select.scss → src/breadcrumb-select.scss} +0 -0
  247. /package/style/{common.scss → src/common.scss} +0 -0
  248. /package/style/{contextmenu.scss → src/contextmenu.scss} +0 -0
  249. /package/style/{data-form.scss → src/data-form.scss} +0 -0
  250. /package/style/{data-table.scss → src/data-table.scss} +0 -0
  251. /package/style/{datatable-settings.scss → src/datatable-settings.scss} +0 -0
  252. /package/style/{date-range.scss → src/date-range.scss} +0 -0
  253. /package/style/{department-condition.scss → src/department-condition.scss} +0 -0
  254. /package/style/{drag-list.scss → src/drag-list.scss} +0 -0
  255. /package/style/{dragable.scss → src/dragable.scss} +0 -0
  256. /package/style/{filter-panel.scss → src/filter-panel.scss} +0 -0
  257. /package/style/{index.scss → src/index.scss} +0 -0
  258. /package/style/{input-condition.scss → src/input-condition.scss} +0 -0
  259. /package/style/{layout.scss → src/layout.scss} +0 -0
  260. /package/style/{menu.scss → src/menu.scss} +0 -0
  261. /package/style/{mixins → src/mixins}/_var.scss +0 -0
  262. /package/style/{mixins → src/mixins}/config.scss +0 -0
  263. /package/style/{mixins → src/mixins}/function.scss +0 -0
  264. /package/style/{mixins → src/mixins}/mixins.scss +0 -0
  265. /package/style/{panel-tabs.scss → src/panel-tabs.scss} +0 -0
  266. /package/style/{panel.scss → src/panel.scss} +0 -0
  267. /package/style/{pct-filter-panel.scss → src/pct-filter-panel.scss} +0 -0
  268. /package/style/{progress.scss → src/progress.scss} +0 -0
  269. /package/style/{rich-text.scss → src/rich-text.scss} +0 -0
  270. /package/style/{theme → src/theme}/theme.scss +0 -0
  271. /package/style/{theme → src/theme}/var.scss +0 -0
  272. /package/style/{var.scss → src/var.scss} +0 -0
@@ -0,0 +1,6 @@
1
+ import { withInstall } from 'element-plus/es/utils/vue/install';
2
+ import Panel from './panel.mjs';
3
+
4
+ const BwaPanel = withInstall(Panel);
5
+
6
+ export { BwaPanel, BwaPanel as default };
@@ -0,0 +1,55 @@
1
+ import { defineComponent, useSlots, openBlock, createElementBlock, normalizeClass, unref, renderSlot, createCommentVNode, createElementVNode } from 'vue';
2
+ import { useNamespace } from 'web-base-client-vue';
3
+ import _export_sfc from '../_virtual/_plugin-vue_export-helper.mjs';
4
+
5
+ const __default__ = defineComponent({
6
+ name: "BwaPanel"
7
+ });
8
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
9
+ props: {
10
+ name: {
11
+ type: String
12
+ },
13
+ label: {
14
+ type: String,
15
+ default: ""
16
+ }
17
+ },
18
+ setup(__props) {
19
+ ;
20
+ const ns = useNamespace("panel");
21
+ const slots = useSlots();
22
+ return (_ctx, _cache) => {
23
+ return openBlock(), createElementBlock("div", {
24
+ class: normalizeClass(unref(ns).b())
25
+ }, [
26
+ unref(slots).header ? (openBlock(), createElementBlock("div", {
27
+ key: 0,
28
+ class: normalizeClass(unref(ns).e("header"))
29
+ }, [
30
+ renderSlot(_ctx.$slots, "header")
31
+ ], 2)) : createCommentVNode("v-if", true),
32
+ unref(slots).tools ? (openBlock(), createElementBlock("div", {
33
+ key: 1,
34
+ class: normalizeClass(unref(ns).e("tools"))
35
+ }, [
36
+ renderSlot(_ctx.$slots, "tools")
37
+ ], 2)) : createCommentVNode("v-if", true),
38
+ createElementVNode("div", {
39
+ class: normalizeClass(unref(ns).e("body"))
40
+ }, [
41
+ renderSlot(_ctx.$slots, "default")
42
+ ], 2),
43
+ unref(slots).footer ? (openBlock(), createElementBlock("div", {
44
+ key: 2,
45
+ class: normalizeClass(unref(ns).e("footer"))
46
+ }, [
47
+ renderSlot(_ctx.$slots, "footer")
48
+ ], 2)) : createCommentVNode("v-if", true)
49
+ ], 2);
50
+ };
51
+ }
52
+ });
53
+ var Panel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "panel.vue"]]);
54
+
55
+ export { Panel as default };
@@ -0,0 +1,6 @@
1
+ import { withInstall } from 'element-plus/es/utils/vue/install';
2
+ import PanelTab from './panel-tabs.mjs';
3
+
4
+ const BwaPanelTab = withInstall(PanelTab);
5
+
6
+ export { BwaPanelTab, BwaPanelTab as default };
@@ -0,0 +1,66 @@
1
+ import { ElTabs, ElTabPane } from 'element-plus';
2
+ import { defineComponent, useSlots, useAttrs, ref, watch, computed, h, unref } from 'vue';
3
+ import { useNamespace } from 'web-base-client-vue';
4
+
5
+ var PanelTab = defineComponent({
6
+ name: "BwaPanelTabs",
7
+ props: {
8
+ modelValue: {
9
+ type: String,
10
+ default: ""
11
+ }
12
+ },
13
+ emits: ["update:modelValue"],
14
+ setup(props, {
15
+ emit
16
+ }) {
17
+ const slots = useSlots();
18
+ const attrs = useAttrs();
19
+ const ns = useNamespace("panel-tabs");
20
+ const modelValue = ref(props.modelValue || "");
21
+ const visibledNames = [];
22
+ watch(modelValue, (modelValue2) => {
23
+ emit("update:modelValue", modelValue2);
24
+ if (modelValue2 && !visibledNames.includes(modelValue2)) {
25
+ visibledNames.push(modelValue2);
26
+ }
27
+ }, {
28
+ immediate: true
29
+ });
30
+ watch(computed(() => props.modelValue), (value) => {
31
+ modelValue.value = value || "";
32
+ });
33
+ return () => {
34
+ var _a, _b;
35
+ let panels = (_b = (_a = slots.default) == null ? void 0 : _a.call(slots)) != null ? _b : [];
36
+ panels = panels.filter((panel) => {
37
+ var _a2, _b2;
38
+ return ((_a2 = panel.props) == null ? void 0 : _a2.label) && ((_b2 = panel.props) == null ? void 0 : _b2.name);
39
+ });
40
+ if (!modelValue.value && panels.length) {
41
+ modelValue.value = panels[0].props.name;
42
+ }
43
+ return h(ElTabs, {
44
+ class: ns.b(),
45
+ type: "card",
46
+ ...attrs,
47
+ modelValue: unref(modelValue),
48
+ "onUpdate:modelValue": (value) => {
49
+ modelValue.value = value;
50
+ }
51
+ }, {
52
+ default: () => panels.map((panel) => {
53
+ return h(ElTabPane, {
54
+ class: ns.b("item"),
55
+ label: panel.props.label,
56
+ name: panel.props.name
57
+ }, {
58
+ default: () => visibledNames.includes(panel.props.name) ? panel : null
59
+ });
60
+ })
61
+ });
62
+ };
63
+ }
64
+ });
65
+
66
+ export { PanelTab as default };
@@ -0,0 +1,10 @@
1
+ import { withInstall } from 'element-plus/es/utils/vue/install';
2
+ import PctFilterPanel from './pct-filter-panel.mjs';
3
+ export { default } from './pct-filter-panel.mjs';
4
+ import PctFilterPanelItem from './pct-filter-panel-item.mjs';
5
+
6
+ const BwaPctFilterPanel = withInstall(PctFilterPanel, {
7
+ PctFilterPanelItem
8
+ });
9
+
10
+ export { BwaPctFilterPanel };
@@ -0,0 +1,10 @@
1
+ import { withInstall } from 'element-plus/es/utils/vue/install';
2
+ import PctMultipleMenuCondition from './pct-multiple-menu-condition.mjs';
3
+ import PctInputCondition from './pct-Input-condition.mjs';
4
+ import PctDateRangeCondition from './pct-date-range-condition.mjs';
5
+
6
+ const BwaPctInputCondition = withInstall(PctInputCondition, {});
7
+ const BwaPctMultipleMenuCondition = withInstall(PctMultipleMenuCondition, {});
8
+ const BwaPctDateRangeCondition = withInstall(PctDateRangeCondition, {});
9
+
10
+ export { BwaPctDateRangeCondition, BwaPctInputCondition, BwaPctMultipleMenuCondition };
@@ -0,0 +1,71 @@
1
+ import { defineComponent, inject, computed, useAttrs, resolveComponent, openBlock, createElementBlock, normalizeClass, unref, toDisplayString, createCommentVNode, createVNode, isRef } from 'vue';
2
+ import { useNamespace, filterPanelItemKey } from 'web-base-client-vue';
3
+ import { dataProps } from '../../hooks/use-data/index.mjs';
4
+ import _export_sfc from '../../_virtual/_plugin-vue_export-helper.mjs';
5
+
6
+ const __default__ = defineComponent({
7
+ name: "BwaPctInputCondition",
8
+ __conditionTitle__: "\u8F93\u5165\u6846",
9
+ __conditionDefault__: () => []
10
+ });
11
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
12
+ props: {
13
+ ...dataProps,
14
+ modelValue: {
15
+ type: null
16
+ },
17
+ placeholder: {
18
+ type: String,
19
+ default: "\u8BF7\u8F93\u5165"
20
+ },
21
+ prefixIcon: {
22
+ type: String,
23
+ default: "Search"
24
+ },
25
+ showIcon: {
26
+ type: Boolean,
27
+ default: false
28
+ }
29
+ },
30
+ emits: ["update:modelValue"],
31
+ setup(__props, { emit }) {
32
+ const props = __props;
33
+ const ns = useNamespace("pct-input");
34
+ ;
35
+ const filterPanelItem = inject(filterPanelItemKey, null);
36
+ const column = computed(() => {
37
+ var _a;
38
+ return (_a = filterPanelItem == null ? void 0 : filterPanelItem.column) != null ? _a : null;
39
+ });
40
+ const placeholderStr = computed(() => showTitle.value ? props.placeholder : column.value.title);
41
+ const attrs = useAttrs();
42
+ const showTitle = computed(() => attrs.showTitle);
43
+ const modelValue = computed({
44
+ get: () => props.modelValue,
45
+ set: (v) => emit("update:modelValue", v)
46
+ });
47
+ return (_ctx, _cache) => {
48
+ const _component_el_input = resolveComponent("el-input");
49
+ return openBlock(), createElementBlock("div", {
50
+ class: normalizeClass(unref(ns).e("inputCon"))
51
+ }, [
52
+ unref(showTitle) ? (openBlock(), createElementBlock("span", {
53
+ key: 0,
54
+ class: normalizeClass(unref(ns).e("title"))
55
+ }, toDisplayString(unref(column).title), 3)) : createCommentVNode("v-if", true),
56
+ createVNode(_component_el_input, {
57
+ "prefix-icon": __props.showIcon ? __props.prefixIcon : "",
58
+ size: "small",
59
+ clearable: "",
60
+ class: normalizeClass(unref(ns).e("search")),
61
+ placeholder: unref(placeholderStr),
62
+ modelValue: unref(modelValue),
63
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null)
64
+ }, null, 8, ["prefix-icon", "class", "placeholder", "modelValue"])
65
+ ], 2);
66
+ };
67
+ }
68
+ });
69
+ var PctInputCondition = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pct-Input-condition.vue"]]);
70
+
71
+ export { PctInputCondition as default };
@@ -0,0 +1,74 @@
1
+ import { defineComponent, inject, computed, resolveComponent, openBlock, createElementBlock, normalizeClass, unref, toDisplayString, createCommentVNode, createVNode, isRef } from 'vue';
2
+ import { useNamespace, filterPanelItemKey } from 'web-base-client-vue';
3
+ import _export_sfc from '../../_virtual/_plugin-vue_export-helper.mjs';
4
+
5
+ const __default__ = defineComponent({
6
+ name: "BwaPctDateRangeCondition",
7
+ __conditionTitle__: "\u65E5\u671F\u9009\u62E9",
8
+ __conditionDefault__: () => ({ start: "", end: "" })
9
+ });
10
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
11
+ props: {
12
+ modelValue: {
13
+ type: null
14
+ },
15
+ valueFormat: {
16
+ type: String,
17
+ default: "YYYY-MM-DD"
18
+ },
19
+ showTitle: {
20
+ type: Boolean,
21
+ default: false
22
+ }
23
+ },
24
+ emits: ["update:modelValue"],
25
+ setup(__props, { emit }) {
26
+ const props = __props;
27
+ const ns = useNamespace("pct-daterange");
28
+ ;
29
+ const filterPanelItem = inject(filterPanelItemKey);
30
+ const column = computed(() => {
31
+ var _a;
32
+ return (_a = filterPanelItem == null ? void 0 : filterPanelItem.column) != null ? _a : null;
33
+ });
34
+ const value = computed({
35
+ get: () => {
36
+ if (props.modelValue && props.modelValue.start && props.modelValue.end) {
37
+ return [props.modelValue.start, props.modelValue.end];
38
+ }
39
+ return [];
40
+ },
41
+ set: (v) => {
42
+ if (v && v.length === 2) {
43
+ emit("update:modelValue", { start: v[0], end: v[1] });
44
+ } else {
45
+ emit("update:modelValue", { start: "", end: "" });
46
+ }
47
+ }
48
+ });
49
+ return (_ctx, _cache) => {
50
+ const _component_el_date_picker = resolveComponent("el-date-picker");
51
+ return openBlock(), createElementBlock("div", {
52
+ class: normalizeClass(unref(ns).e("cont"))
53
+ }, [
54
+ unref(column) && __props.showTitle ? (openBlock(), createElementBlock("div", {
55
+ key: 0,
56
+ class: normalizeClass(unref(ns).e("label"))
57
+ }, toDisplayString(unref(column).title), 3)) : createCommentVNode("v-if", true),
58
+ createVNode(_component_el_date_picker, {
59
+ modelValue: unref(value),
60
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(value) ? value.value = $event : null),
61
+ type: "daterange",
62
+ "range-separator": "\u81F3",
63
+ "start-placeholder": "\u5F00\u59CB\u65E5\u671F",
64
+ "end-placeholder": "\u7ED3\u675F\u65E5\u671F",
65
+ "value-format": __props.valueFormat,
66
+ size: "small"
67
+ }, null, 8, ["modelValue", "value-format"])
68
+ ], 2);
69
+ };
70
+ }
71
+ });
72
+ var PctDateRangeCondition = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pct-date-range-condition.vue"]]);
73
+
74
+ export { PctDateRangeCondition as default };
@@ -0,0 +1,186 @@
1
+ import { defineComponent, ref, useAttrs, computed, inject, unref, resolveComponent, openBlock, createElementBlock, normalizeClass, toDisplayString, createCommentVNode, createVNode, isRef, withCtx, Fragment, renderList, createBlock } from 'vue';
2
+ import { useService, HttpRequest, useNamespace, filterPanelItemKey } from 'web-base-client-vue';
3
+ import { dataProps } from '../../hooks/use-data/index.mjs';
4
+ import _export_sfc from '../../_virtual/_plugin-vue_export-helper.mjs';
5
+
6
+ const __default__ = defineComponent({
7
+ name: "BwaPctMultipleMenuCondition",
8
+ __conditionTitle__: "\u591A\u9009\u5217\u8868",
9
+ __conditionDefault__: () => []
10
+ });
11
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
12
+ props: {
13
+ ...dataProps,
14
+ modelValue: {
15
+ type: null
16
+ },
17
+ options: {
18
+ type: Array,
19
+ default: () => []
20
+ },
21
+ labelProp: {
22
+ type: String,
23
+ default: "label"
24
+ },
25
+ valueProp: {
26
+ type: String,
27
+ default: "value"
28
+ },
29
+ multiple: {
30
+ type: Boolean,
31
+ default: true
32
+ },
33
+ showSearch: {
34
+ type: Boolean,
35
+ default: true
36
+ },
37
+ placeholder: {
38
+ type: String,
39
+ default: "\u8BF7\u9009\u62E9"
40
+ },
41
+ remote: {
42
+ type: Boolean,
43
+ default: true
44
+ },
45
+ size: {
46
+ type: String,
47
+ default: "small"
48
+ },
49
+ searchPlaceholder: {
50
+ type: String,
51
+ default: ""
52
+ },
53
+ labelAttr: "",
54
+ valueAttr: "",
55
+ searchAttr: "",
56
+ itfInfo: null,
57
+ isRequiredByVisibleChange: {
58
+ type: Boolean,
59
+ default: false
60
+ }
61
+ },
62
+ emits: ["update:modelValue", "search"],
63
+ setup(__props, { expose, emit }) {
64
+ var _a;
65
+ const props = __props;
66
+ const httpRequest = useService(HttpRequest);
67
+ ;
68
+ const ns = useNamespace("pctfilterpanel-item");
69
+ const isShowPopper = ref(false);
70
+ const attrs = useAttrs();
71
+ const showTitle = computed(() => attrs.showTitle);
72
+ const data = ref([]);
73
+ const loading = ref(false);
74
+ const filterPanelItem = inject(filterPanelItemKey, null);
75
+ const column = computed(() => {
76
+ var _a2;
77
+ return (_a2 = filterPanelItem == null ? void 0 : filterPanelItem.column) != null ? _a2 : null;
78
+ });
79
+ if (props.itfInfo) {
80
+ column.value.componentProps = {
81
+ itfInfo: props.itfInfo || {},
82
+ labelAttr: props.labelAttr || "label",
83
+ valueAttr: props.valueAttr || "value",
84
+ searchAttr: props.searchAttr || "search"
85
+ };
86
+ }
87
+ const searchPlaceholderStr = computed(() => {
88
+ var _a2, _b;
89
+ return ((_b = (_a2 = column.value) == null ? void 0 : _a2.componentProps) == null ? void 0 : _b.searchPlaceholder) || props.searchPlaceholder;
90
+ });
91
+ const placeholderStr = computed(() => showTitle.value ? props.placeholder : column.value.title);
92
+ const labelPropStr = computed(() => {
93
+ var _a2, _b;
94
+ return ((_b = (_a2 = column.value) == null ? void 0 : _a2.componentProps) == null ? void 0 : _b.labelAttr) || props.labelProp;
95
+ });
96
+ const valuePropStr = computed(() => {
97
+ var _a2, _b;
98
+ return ((_b = (_a2 = column.value) == null ? void 0 : _a2.componentProps) == null ? void 0 : _b.valueAttr) || props.valueProp;
99
+ });
100
+ const getData = async (query) => {
101
+ var _a2;
102
+ loading.value = true;
103
+ const { itfInfo, searchAttr } = column.value.componentProps;
104
+ const { url, method, options, params } = {
105
+ url: unref(itfInfo).url,
106
+ method: unref(itfInfo).method || "POST",
107
+ options: unref(itfInfo).options || {},
108
+ params: { ...unref(itfInfo).params, [searchAttr]: query || "" }
109
+ };
110
+ data.value = (_a2 = await unref(httpRequest)[method.toLowerCase()](url, params, options)) == null ? void 0 : _a2.data;
111
+ loading.value = false;
112
+ };
113
+ data.value = (_a = props.options) != null ? _a : [];
114
+ const visibleChange = (val) => {
115
+ var _a2, _b;
116
+ isShowPopper.value = val;
117
+ if (!val || !column.value.componentProps || ((_b = (_a2 = column.value) == null ? void 0 : _a2.componentProps) == null ? void 0 : _b.options)) {
118
+ if (isShowPopper.value && props.isRequiredByVisibleChange) {
119
+ emit("search", "");
120
+ }
121
+ return;
122
+ }
123
+ getData();
124
+ };
125
+ const remoteMethod = (query) => {
126
+ if (column.value.componentProps) {
127
+ getData(query);
128
+ } else {
129
+ emit("search", query);
130
+ }
131
+ };
132
+ const modelValue = computed({
133
+ get: () => {
134
+ if (props.multiple) {
135
+ return Array.isArray(props.modelValue) ? props.modelValue.map((item) => item) : [];
136
+ } else {
137
+ return props.modelValue == null || Array.isArray(props.modelValue) ? "" : props.modelValue;
138
+ }
139
+ },
140
+ set: (v) => emit("update:modelValue", v)
141
+ });
142
+ expose({
143
+ data
144
+ });
145
+ return (_ctx, _cache) => {
146
+ const _component_el_option = resolveComponent("el-option");
147
+ const _component_el_select = resolveComponent("el-select");
148
+ return openBlock(), createElementBlock("div", {
149
+ class: normalizeClass(unref(ns).e("conditbox"))
150
+ }, [
151
+ unref(showTitle) ? (openBlock(), createElementBlock("div", {
152
+ key: 0,
153
+ class: normalizeClass(unref(ns).e("title"))
154
+ }, toDisplayString(unref(column).title), 3)) : createCommentVNode("v-if", true),
155
+ createVNode(_component_el_select, {
156
+ multiple: __props.multiple,
157
+ modelValue: unref(modelValue),
158
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),
159
+ onVisibleChange: visibleChange,
160
+ class: normalizeClass(unref(ns).e("options")),
161
+ loading: loading.value,
162
+ placeholder: unref(placeholderStr),
163
+ clearable: true,
164
+ filterable: __props.showSearch,
165
+ remote: __props.remote,
166
+ "remote-method": remoteMethod,
167
+ size: "small"
168
+ }, {
169
+ default: withCtx(() => [
170
+ (openBlock(true), createElementBlock(Fragment, null, renderList(data.value, (item) => {
171
+ return openBlock(), createBlock(_component_el_option, {
172
+ key: item[unref(valuePropStr)] + "",
173
+ value: item[unref(valuePropStr)] + "",
174
+ label: item[unref(labelPropStr)] + ""
175
+ }, null, 8, ["value", "label"]);
176
+ }), 128))
177
+ ]),
178
+ _: 1
179
+ }, 8, ["multiple", "modelValue", "class", "loading", "placeholder", "filterable", "remote"])
180
+ ], 2);
181
+ };
182
+ }
183
+ });
184
+ var PctMultipleMenuCondition = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pct-multiple-menu-condition.vue"]]);
185
+
186
+ export { PctMultipleMenuCondition as default };
@@ -0,0 +1,147 @@
1
+ import { defineComponent, useAttrs, computed, ref, inject, unref, openBlock, createElementBlock, Fragment, normalizeClass, toDisplayString, createCommentVNode, createVNode, isRef, withCtx, renderList, createBlock } from 'vue';
2
+ import { ElSelect, ElOption } from 'element-plus';
3
+ import { useService, HttpRequest, useNamespace, filterPanelItemKey } from 'web-base-client-vue';
4
+ import { dataProps } from '../../hooks/use-data/index.mjs';
5
+ import _export_sfc from '../../_virtual/_plugin-vue_export-helper.mjs';
6
+
7
+ const __default__ = defineComponent({
8
+ name: "BwaPctMultipleMenuCondition",
9
+ __conditionTitle__: "\u591A\u9009\u83DC\u5355-PZ",
10
+ __conditionDefault__: () => []
11
+ });
12
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
13
+ props: {
14
+ ...dataProps,
15
+ modelValue: {
16
+ type: null
17
+ },
18
+ options: {
19
+ type: Array,
20
+ default: () => []
21
+ },
22
+ labelProp: {
23
+ type: String,
24
+ default: "label"
25
+ },
26
+ valueProp: {
27
+ type: String,
28
+ default: "value"
29
+ },
30
+ multiple: {
31
+ type: Boolean,
32
+ default: false
33
+ },
34
+ filterable: {
35
+ type: Boolean,
36
+ default: true
37
+ },
38
+ placeholder: {
39
+ type: String,
40
+ default: "\u8BF7\u9009\u62E9"
41
+ },
42
+ remote: {
43
+ type: Boolean,
44
+ default: true
45
+ },
46
+ size: {
47
+ type: String,
48
+ default: "small"
49
+ }
50
+ },
51
+ emits: ["update:modelValue", "search", "visible-change"],
52
+ setup(__props, { emit }) {
53
+ var _a, _b;
54
+ const props = __props;
55
+ const httpRequest = useService(HttpRequest);
56
+ ;
57
+ const ns = useNamespace("pctfilterpanel-item");
58
+ const attrs = useAttrs();
59
+ const showTitle = computed(() => attrs.showTitle);
60
+ const data = ref([]);
61
+ const loading = ref(false);
62
+ const filterPanelItem = inject(filterPanelItemKey, null);
63
+ const column = computed(() => {
64
+ var _a2;
65
+ return (_a2 = filterPanelItem == null ? void 0 : filterPanelItem.column) != null ? _a2 : null;
66
+ });
67
+ const placeholderStr = computed(() => showTitle.value ? props.placeholder : column.value.title);
68
+ const getData = async (query) => {
69
+ var _a2;
70
+ loading.value = true;
71
+ const { itfInfo, searchAttr } = column.value.componentProps;
72
+ const { url, method, options, params } = {
73
+ url: unref(itfInfo).url,
74
+ method: unref(itfInfo).method || "POST",
75
+ options: unref(itfInfo).options || {},
76
+ params: { ...unref(itfInfo).params, [searchAttr]: query || "" }
77
+ };
78
+ data.value = (_a2 = await unref(httpRequest)[method.toLowerCase()](url, params, options)) == null ? void 0 : _a2.data;
79
+ loading.value = false;
80
+ };
81
+ if ((_a = column.value) == null ? void 0 : _a.componentProps) {
82
+ } else {
83
+ data.value = (_b = props.options) != null ? _b : [];
84
+ }
85
+ const visibleChange = (val) => {
86
+ if (!val || !column.value.componentProps)
87
+ return;
88
+ getData();
89
+ };
90
+ const remoteMethod = (query) => {
91
+ if (column.value.componentProps) {
92
+ getData(query);
93
+ } else {
94
+ emit("search", query);
95
+ }
96
+ };
97
+ const modelValue = computed({
98
+ get: () => {
99
+ if (props.multiple) {
100
+ return Array.isArray(props.modelValue) ? props.modelValue.map((item) => item + "") : [];
101
+ } else {
102
+ return props.modelValue == null ? "" : props.modelValue + "";
103
+ }
104
+ },
105
+ set: (v) => emit("update:modelValue", v)
106
+ });
107
+ return (_ctx, _cache) => {
108
+ return openBlock(), createElementBlock(Fragment, null, [
109
+ unref(showTitle) ? (openBlock(), createElementBlock("span", {
110
+ key: 0,
111
+ class: normalizeClass(unref(ns).e("title"))
112
+ }, toDisplayString(unref(column).title), 3)) : createCommentVNode("v-if", true),
113
+ createVNode(unref(ElSelect), {
114
+ modelValue: unref(modelValue),
115
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),
116
+ clearable: "",
117
+ multiple: __props.multiple,
118
+ filterable: __props.filterable,
119
+ placeholder: unref(placeholderStr),
120
+ loading: loading.value,
121
+ onVisibleChange: visibleChange,
122
+ remote: __props.remote,
123
+ "remote-method": remoteMethod,
124
+ size: __props.size,
125
+ class: normalizeClass(unref(ns).e("multiple")),
126
+ "collapse-tags": "",
127
+ "collapse-tags-tooltip": "",
128
+ "no-data-text": "\u6682\u65E0\u6570\u636E"
129
+ }, {
130
+ default: withCtx(() => [
131
+ (openBlock(true), createElementBlock(Fragment, null, renderList(data.value, (item, index) => {
132
+ return openBlock(), createBlock(unref(ElOption), {
133
+ key: item[__props.valueProp] + index,
134
+ value: item[__props.valueProp] + "",
135
+ label: item[__props.labelProp]
136
+ }, null, 8, ["value", "label"]);
137
+ }), 128))
138
+ ]),
139
+ _: 1
140
+ }, 8, ["modelValue", "multiple", "filterable", "placeholder", "loading", "remote", "size", "class"])
141
+ ], 64);
142
+ };
143
+ }
144
+ });
145
+ var pctMultipleMenuCondition2 = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pct-multiple-menu-condition2.vue"]]);
146
+
147
+ export { pctMultipleMenuCondition2 as default };
@@ -0,0 +1,48 @@
1
+ import { defineComponent, reactive, provide, openBlock, createElementBlock, normalizeClass, unref, normalizeStyle, renderSlot, createCommentVNode } from 'vue';
2
+ import { useNamespace, filterPanelItemKey } from 'web-base-client-vue';
3
+ import { useFilterPanelItem } from './use-filter-panel-item.mjs';
4
+ import _export_sfc from '../_virtual/_plugin-vue_export-helper.mjs';
5
+
6
+ const __default__ = defineComponent({
7
+ name: "BwaPctFilterPanelItem"
8
+ });
9
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
10
+ props: {
11
+ prop: {
12
+ type: String
13
+ },
14
+ close: {
15
+ type: Boolean,
16
+ default: false
17
+ }
18
+ },
19
+ emits: ["close"],
20
+ setup(__props, { emit }) {
21
+ const props = __props;
22
+ const ns = useNamespace("pctfilterpanel");
23
+ const { value, column, allowClose, closeHandle, showTitle, filterPanelLineNum } = useFilterPanelItem(props);
24
+ const data = reactive({ value });
25
+ provide(
26
+ filterPanelItemKey,
27
+ reactive({
28
+ column
29
+ })
30
+ );
31
+ return (_ctx, _cache) => {
32
+ return openBlock(), createElementBlock("div", {
33
+ class: normalizeClass(unref(ns).b("item")),
34
+ style: normalizeStyle({ "width": unref(filterPanelLineNum) ? (100 / unref(filterPanelLineNum)).toFixed(2) + "%" : unref(showTitle) ? "25%" : "20%" })
35
+ }, [
36
+ renderSlot(_ctx.$slots, "default", { data }),
37
+ unref(allowClose) ? (openBlock(), createElementBlock("i", {
38
+ key: 0,
39
+ class: normalizeClass(["ptp-icon", "ptp-close", unref(ns).be("item", "close")]),
40
+ onClick: _cache[0] || (_cache[0] = (...args) => unref(closeHandle) && unref(closeHandle)(...args))
41
+ }, null, 2)) : createCommentVNode("v-if", true)
42
+ ], 6);
43
+ };
44
+ }
45
+ });
46
+ var PctFilterPanelItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pct-filter-panel-item.vue"]]);
47
+
48
+ export { PctFilterPanelItem as default };