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

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/var.css +1 -0
  244. /package/style/{advance-select.scss → src/advance-select.scss} +0 -0
  245. /package/style/{breadcrumb-select.scss → src/breadcrumb-select.scss} +0 -0
  246. /package/style/{common → src/common}/var.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
package/es/utils.mjs ADDED
@@ -0,0 +1,99 @@
1
+ import { computed, unref, inject, isProxy, isRef, markRaw, resolveComponent } from 'vue';
2
+ import get from 'lodash/get';
3
+ import set from 'lodash/set';
4
+
5
+ const COMPONENT_NAME_PREFIX = "Bwa";
6
+ const createComponentName = (component) => {
7
+ component.name = COMPONENT_NAME_PREFIX + component.name;
8
+ };
9
+ const useDynamicComponent = (props, {
10
+ emit
11
+ }, defaultComponent, attributeName = "attrName") => {
12
+ const column = computed(() => props.column);
13
+ const componentProps = computed(() => {
14
+ const _column = unref(column);
15
+ if (!_column) {
16
+ return {};
17
+ }
18
+ const originalComponentProps = _column.componentProps;
19
+ const _componentProps = {
20
+ ...originalComponentProps
21
+ };
22
+ Object.keys(_componentProps).forEach((key) => {
23
+ let val = _componentProps[key];
24
+ if (val && typeof val == "string" && val.indexOf("inject:") == 0) {
25
+ let injectNode = val.replace("inject:", "");
26
+ let injectInfo = injectNode.split(".");
27
+ let injectScope = injectInfo.shift();
28
+ let injectObj = inject(injectScope);
29
+ if (injectInfo.length) {
30
+ _componentProps[key] = get(injectObj, injectInfo.join("."));
31
+ } else {
32
+ _componentProps[key] = injectObj;
33
+ }
34
+ if (isProxy(_componentProps[key])) {
35
+ _componentProps[key] = isRef(_componentProps[key]) ? _componentProps[key].value : _componentProps[key];
36
+ }
37
+ } else {
38
+ _componentProps[key] = val;
39
+ }
40
+ });
41
+ return _componentProps;
42
+ });
43
+ const isFunctionComponent = computed(() => {
44
+ var _a;
45
+ return typeof ((_a = unref(column)) == null ? void 0 : _a.component) == "function";
46
+ });
47
+ const component = computed(() => {
48
+ const _column = unref(column);
49
+ if (unref(isFunctionComponent)) {
50
+ return markRaw(_column == null ? void 0 : _column.component({
51
+ record: props.record,
52
+ column,
53
+ value: props.modelValue,
54
+ props: componentProps
55
+ }));
56
+ }
57
+ return markRaw(resolveComponent(_column.component || defaultComponent));
58
+ });
59
+ const params = computed(() => {
60
+ const _column = unref(column);
61
+ const _params = {
62
+ ...unref(componentProps)
63
+ };
64
+ const _component = unref(component);
65
+ if (!_component) {
66
+ return _params;
67
+ }
68
+ if (_component.emits) {
69
+ let emits = _component.emits || [];
70
+ if (!Array.isArray(emits) && emits && typeof emits === "object") {
71
+ emits = Object.keys(emits);
72
+ }
73
+ if (Array.isArray(emits) && emits.find((eventName) => ["onUpdate:modelValue", "onUpdate:model-value", "update:modelValue", "update:model-value"].includes(eventName))) {
74
+ _params["modelValue"] = get(props.record, _column[attributeName]);
75
+ _params["onUpdate:modelValue"] = (val) => {
76
+ set(props.record, _column[attributeName], val);
77
+ };
78
+ } else {
79
+ _params["value"] = get(props.record, _column[attributeName]);
80
+ }
81
+ if (emits.find((eventName) => eventName == "on-change")) {
82
+ _params["on-change"] = (event) => emit("on-change", {
83
+ data: event,
84
+ column
85
+ });
86
+ }
87
+ } else {
88
+ _params["value"] = get(props.record, _column[attributeName]);
89
+ }
90
+ Object.assign(_params, unref(componentProps));
91
+ return _params;
92
+ });
93
+ return {
94
+ params,
95
+ component
96
+ };
97
+ };
98
+
99
+ export { COMPONENT_NAME_PREFIX, createComponentName, useDynamicComponent };
@@ -0,0 +1 @@
1
+
@@ -0,0 +1,18 @@
1
+ import { useProp } from 'element-plus';
2
+ import { computed, unref } from 'vue';
3
+ import { useGlobalConfig } from 'web-base-client-vue';
4
+
5
+ const usewhereFilterPanel = (props, context) => {
6
+ const dataTable = useProp("dataTable");
7
+ const debounceDelay = useGlobalConfig("debounceDelay", 500);
8
+ const where = computed(() => unref(dataTable).where);
9
+ const filterColumns = computed(() => unref(dataTable).getFilterColumns());
10
+ const fixedColumns = computed(() => filterColumns.value.filter((column) => !column.closable));
11
+ const originalClosableColumns = computed(() => filterColumns.value.filter((column) => column.closable));
12
+ const addFilter = () => {
13
+ };
14
+ const removeFilter = () => {
15
+ };
16
+ };
17
+
18
+ export { usewhereFilterPanel };
@@ -0,0 +1,17 @@
1
+ import { defineComponent, openBlock, createElementBlock } from 'vue';
2
+ import _export_sfc from '../_virtual/_plugin-vue_export-helper.mjs';
3
+
4
+ const __default__ = defineComponent({
5
+ name: "BwaWhereFilterPanel"
6
+ });
7
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
8
+ setup(__props) {
9
+ ;
10
+ return (_ctx, _cache) => {
11
+ return openBlock(), createElementBlock("div");
12
+ };
13
+ }
14
+ });
15
+ var whereFilterPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "where-filter-panel.vue"]]);
16
+
17
+ export { whereFilterPanel as default };
@@ -0,0 +1,13 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var _export_sfc = (sfc, props) => {
6
+ const target = sfc.__vccOpts || sfc;
7
+ for (const [key, val] of props) {
8
+ target[key] = val;
9
+ }
10
+ return target;
11
+ };
12
+
13
+ exports["default"] = _export_sfc;
@@ -0,0 +1,47 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var vue = require('vue');
6
+ var webBaseClientVue = require('web-base-client-vue');
7
+ var _pluginVue_exportHelper = require('../_virtual/_plugin-vue_export-helper.js');
8
+
9
+ const __default__ = vue.defineComponent({
10
+ name: "BwaAdvanceOperation"
11
+ });
12
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
13
+ props: {
14
+ border: {
15
+ type: Boolean,
16
+ default: false
17
+ },
18
+ type: {
19
+ type: String,
20
+ default: "button"
21
+ }
22
+ },
23
+ emits: ["click"],
24
+ setup(__props, { emit }) {
25
+ const props = __props;
26
+ const advanceSelect = vue.inject(webBaseClientVue.advanceSelectKey);
27
+ const clickHandle = () => {
28
+ if (props.type !== "button") {
29
+ return;
30
+ }
31
+ advanceSelect.hidePoppper();
32
+ emit("click");
33
+ };
34
+ const ns = webBaseClientVue.useNamespace("advance");
35
+ return (_ctx, _cache) => {
36
+ return vue.openBlock(), vue.createElementBlock("div", {
37
+ class: vue.normalizeClass([vue.unref(ns).be("select", "operation"), vue.unref(ns).is("border", __props.border)]),
38
+ onClick: clickHandle
39
+ }, [
40
+ vue.renderSlot(_ctx.$slots, "default")
41
+ ], 2);
42
+ };
43
+ }
44
+ });
45
+ var AdvanceOperation = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["__file", "advance-operation.vue"]]);
46
+
47
+ exports["default"] = AdvanceOperation;
@@ -0,0 +1,129 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ require('element-plus');
6
+ var vue = require('vue');
7
+ var webBaseClientVue = require('web-base-client-vue');
8
+ var eventsHelpers = require('./events-helpers.js');
9
+ var useAdvanceOption = require('./use-advance-option.js');
10
+ var _pluginVue_exportHelper = require('../_virtual/_plugin-vue_export-helper.js');
11
+
12
+ const _sfc_main = {
13
+ name: "BwaAdvanceOption",
14
+ props: {
15
+ label: {
16
+ type: [String, Number, Boolean]
17
+ },
18
+ value: {
19
+ type: null
20
+ }
21
+ },
22
+ expose: ["currentLabel"],
23
+ setup(props, { expose }) {
24
+ const instance = vue.getCurrentInstance();
25
+ const ns = webBaseClientVue.useNamespace("advance");
26
+ const { handleOptionMouseEnter } = eventsHelpers.useEvent(ns);
27
+ const { advanceSelect, currentLabel, itemSelected, showSelectIcon, source } = useAdvanceOption.useAdvanceOption(props);
28
+ const show = vue.ref(true);
29
+ const clickFlag = vue.ref(true);
30
+ const contentText = vue.ref();
31
+ expose({ currentLabel });
32
+ const filterOptionClick = () => {
33
+ advanceSelect.handleOptionSelect(instance.proxy);
34
+ };
35
+ const isShow = async () => {
36
+ const dom = document.querySelector(`.content-label-${props.value} .bwa-advance-option__content-label`);
37
+ if (dom) {
38
+ const scrollWidth = document.querySelector(`.content-label-${props.value} .bwa-advance-option__content-label`).scrollWidth;
39
+ const offsetWidth = document.querySelector(`.content-label-${props.value} .bwa-advance-option__content-label`).offsetWidth;
40
+ if (scrollWidth > offsetWidth) {
41
+ show.value = false;
42
+ } else {
43
+ show.value = true;
44
+ }
45
+ }
46
+ };
47
+ const listenerClickFunction = () => {
48
+ setTimeout(() => {
49
+ isShow();
50
+ }, 100);
51
+ };
52
+ return {
53
+ show,
54
+ ns,
55
+ currentLabel,
56
+ itemSelected,
57
+ showSelectIcon,
58
+ filterOptionClick,
59
+ handleOptionMouseEnter,
60
+ source
61
+ };
62
+ }
63
+ };
64
+ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
65
+ const _component_ElCheckbox = vue.resolveComponent("ElCheckbox");
66
+ const _component_ElTooltip = vue.resolveComponent("ElTooltip");
67
+ const _component_Select = vue.resolveComponent("Select");
68
+ const _component_ElIcon = vue.resolveComponent("ElIcon");
69
+ return vue.openBlock(), vue.createElementBlock("div", {
70
+ class: vue.normalizeClass($setup.ns.b("option")),
71
+ onClick: _cache[1] || (_cache[1] = vue.withModifiers((...args) => $setup.filterOptionClick && $setup.filterOptionClick(...args), ["stop"]))
72
+ }, [
73
+ vue.createCommentVNode(' @mouseenter="handleOptionMouseEnter" '),
74
+ vue.createElementVNode("div", {
75
+ class: vue.normalizeClass(`${$setup.ns.be("option", "content")} content-label-${$props.value}`)
76
+ }, [
77
+ vue.renderSlot(_ctx.$slots, "default", {}, () => [
78
+ vue.createVNode(_component_ElTooltip, {
79
+ placement: "top",
80
+ "append-to": ".bwa-application",
81
+ disabled: $setup.currentLabel.length < 16
82
+ }, {
83
+ content: vue.withCtx(() => [
84
+ vue.createTextVNode(vue.toDisplayString($setup.currentLabel), 1)
85
+ ]),
86
+ default: vue.withCtx(() => [
87
+ vue.createElementVNode("div", {
88
+ class: vue.normalizeClass($setup.ns.be("option", "content-label")),
89
+ ref: "contentText"
90
+ }, [
91
+ $setup.source === "pct" && !$setup.showSelectIcon ? (vue.openBlock(), vue.createBlock(_component_ElCheckbox, {
92
+ key: 0,
93
+ onClick: _cache[0] || (_cache[0] = vue.withModifiers(() => {
94
+ }, ["prevent"])),
95
+ class: vue.normalizeClass($setup.ns.be("filter", "checkbox")),
96
+ modelValue: $setup.itemSelected,
97
+ style: { "height": "26px" }
98
+ }, {
99
+ default: vue.withCtx(() => [
100
+ vue.createElementVNode("div", {
101
+ class: vue.normalizeClass($setup.ns.be("option", "content-label")),
102
+ style: { "width": "178px" }
103
+ }, vue.toDisplayString($setup.currentLabel), 3)
104
+ ]),
105
+ _: 1
106
+ }, 8, ["class", "modelValue"])) : (vue.openBlock(), vue.createElementBlock("div", {
107
+ key: 1,
108
+ class: vue.normalizeClass([$setup.ns.be("option", "content-label"), $setup.ns.is("selected", $setup.source === "pct" && $setup.itemSelected && $setup.showSelectIcon)])
109
+ }, vue.toDisplayString($setup.currentLabel), 3))
110
+ ], 2)
111
+ ]),
112
+ _: 1
113
+ }, 8, ["disabled"])
114
+ ])
115
+ ], 2),
116
+ $setup.itemSelected && $setup.showSelectIcon ? (vue.openBlock(), vue.createBlock(_component_ElIcon, {
117
+ key: 0,
118
+ class: vue.normalizeClass($setup.ns.be("option", "selected"))
119
+ }, {
120
+ default: vue.withCtx(() => [
121
+ vue.createVNode(_component_Select)
122
+ ]),
123
+ _: 1
124
+ }, 8, ["class"])) : vue.createCommentVNode("v-if", true)
125
+ ], 2);
126
+ }
127
+ var AdvanceOption = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["render", _sfc_render], ["__file", "advance-option.vue"]]);
128
+
129
+ exports["default"] = AdvanceOption;