@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
@@ -0,0 +1,333 @@
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 Quill = require('quill');
8
+ require('quill/dist/quill.snow.css');
9
+ var ElementPlus = require('element-plus');
10
+ var _pluginVue_exportHelper = require('../../_virtual/_plugin-vue_export-helper.js');
11
+
12
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
13
+
14
+ var Quill__default = /*#__PURE__*/_interopDefaultLegacy(Quill);
15
+
16
+ const __default__ = vue.defineComponent({
17
+ name: "BwaRichText"
18
+ });
19
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
20
+ props: {
21
+ placeholder: {
22
+ type: String,
23
+ default: ""
24
+ },
25
+ modelValue: {
26
+ type: null
27
+ },
28
+ disabled: {
29
+ type: Boolean,
30
+ default: false
31
+ },
32
+ showAt: {
33
+ type: Boolean,
34
+ default: false
35
+ },
36
+ userIds: {
37
+ typee: Array,
38
+ default: () => []
39
+ }
40
+ },
41
+ emits: ["update:modelValue", "update:userIds"],
42
+ setup(__props, { expose, emit }) {
43
+ const props = __props;
44
+ let editor = null;
45
+ const userService = webBaseClientVue.useService("UserService");
46
+ const loading = vue.ref(false);
47
+ const userList = vue.ref([
48
+ { value: "1", label: "\u7528\u62371" },
49
+ { value: "2", label: "\u7528\u62372" },
50
+ { value: "3", label: "\u7528\u62373" }
51
+ ]);
52
+ const handleChange = ([userId]) => {
53
+ if (!editor || !userId) {
54
+ return;
55
+ }
56
+ const userInfo = vue.unref(userList).find((item) => item.value === userId);
57
+ if (!userInfo) {
58
+ return;
59
+ }
60
+ editor.focus();
61
+ let length = editor.getSelection() ? editor.getSelection().index || 0 : editor.getLength();
62
+ editor.insertEmbed(
63
+ length,
64
+ "at",
65
+ { id: userInfo.value, desc: userInfo.label },
66
+ "user"
67
+ );
68
+ editor.insertText(length + 1, " ");
69
+ editor.setSelection(length + 2);
70
+ };
71
+ const loadUserList = async (search = "") => {
72
+ try {
73
+ if (vue.unref(loading)) {
74
+ return;
75
+ }
76
+ loading.value = true;
77
+ if (!vue.unref(userService)) {
78
+ ElementPlus.ElMessage.error("\u65E0\u6CD5\u83B7\u53D6\u7528\u6237");
79
+ return;
80
+ }
81
+ const userListResult = await vue.unref(userService).getUserList({
82
+ name: search
83
+ });
84
+ if (userListResult.code != 0) {
85
+ ElementPlus.ElMessage.error(userListResult.msg);
86
+ return;
87
+ }
88
+ userList.value = userListResult.data;
89
+ } finally {
90
+ loading.value = false;
91
+ }
92
+ };
93
+ const handleVisibleChange = (visible) => {
94
+ if (!visible) {
95
+ return;
96
+ }
97
+ loadUserList();
98
+ };
99
+ const virtualRef = vue.ref(null);
100
+ ;
101
+ const ns = webBaseClientVue.useNamespace("rich-text");
102
+ const fileService = webBaseClientVue.useService("FileService");
103
+ const quillEditorContainer = vue.ref(null);
104
+ const quillEditorRef = vue.ref(null);
105
+ const currentScope = vue.getCurrentScope();
106
+ const editorInstance = vue.ref(null);
107
+ const toolbarOptions = [
108
+ [{ header: [1, 2, 3, 4, 5, 6, false] }],
109
+ [{ font: [] }],
110
+ ["bold", "italic", "underline", "strike"],
111
+ [{ align: [] }],
112
+ ["blockquote", "code-block"],
113
+ [{ header: 1 }, { header: 2 }],
114
+ [{ list: "ordered" }, { list: "bullet" }],
115
+ [{ script: "sub" }, { script: "super" }],
116
+ [{ indent: "-1" }, { indent: "+1" }],
117
+ [{ color: [] }, { background: [] }],
118
+ ["clean"].concat(props.showAt ? ["at"] : [])
119
+ ];
120
+ const value = vue.computed({
121
+ get: () => props.modelValue || "",
122
+ set: (v) => {
123
+ let str = "";
124
+ if (!v && editor && editor.root.innerHTML && editor.root.innerHTML.indexOf("<img") != -1) {
125
+ str = editor.root.innerHTML;
126
+ }
127
+ emit("update:modelValue", v || str);
128
+ }
129
+ });
130
+ const userIds = vue.computed({
131
+ get: () => props.userIds,
132
+ set: (v) => {
133
+ emit("update:userIds", v);
134
+ }
135
+ });
136
+ const updateImage = async (file) => {
137
+ if (!vue.unref(fileService)) {
138
+ return;
139
+ }
140
+ const uploadFileResult = await vue.unref(fileService).uploadFile(file);
141
+ if (uploadFileResult.code != 0) {
142
+ return uploadFileResult;
143
+ }
144
+ const fileID = uploadFileResult.data.id;
145
+ const filePathResult = await vue.unref(fileService).getFilePath(fileID);
146
+ if (filePathResult.code != 0) {
147
+ return filePathResult;
148
+ }
149
+ return {
150
+ ...filePathResult,
151
+ data: { id: fileID, path: filePathResult.data }
152
+ };
153
+ };
154
+ const quillEditorRefClick = () => {
155
+ if (!editor) {
156
+ return;
157
+ }
158
+ editor.focus();
159
+ };
160
+ vue.onMounted(() => {
161
+ editor = new Quill__default["default"](vue.unref(quillEditorRef), {
162
+ theme: "snow",
163
+ placeholder: props.placeholder,
164
+ modules: {
165
+ toolbar: {
166
+ container: toolbarOptions,
167
+ handlers: {
168
+ at: function(value2) {
169
+ }
170
+ }
171
+ }
172
+ }
173
+ });
174
+ virtualRef.value = quillEditorContainer.value.querySelector("button.ql-at");
175
+ editorInstance.value = vue.markRaw(editor);
176
+ const el = document.createElement("div");
177
+ const getUserIds = (html) => {
178
+ el.innerHTML = html;
179
+ const items = Array.from(el.querySelectorAll("span.ptp-at-item"));
180
+ userIds.value = [
181
+ ...new Set(items.map((item) => item.getAttribute("d-id")))
182
+ ];
183
+ };
184
+ getUserIds(vue.unref(value));
185
+ const handleTextChange = (delta, oldDelta, source) => {
186
+ const _value = editor.getText() === "\n" ? "" : editor.root.innerHTML;
187
+ value.value = _value;
188
+ getUserIds(_value);
189
+ };
190
+ const handlePaste = (evt) => {
191
+ if (evt.clipboardData && evt.clipboardData.files && evt.clipboardData.files.length) {
192
+ evt.preventDefault();
193
+ [].forEach.call(evt.clipboardData.files, async (file) => {
194
+ console.log(file);
195
+ if (file.type.match(/^image\/(gif|jpe?g|a?png|bmp)/i)) {
196
+ const filePathResult = await updateImage(file);
197
+ if (filePathResult.code != 0) {
198
+ return;
199
+ }
200
+ const fileData = filePathResult.data;
201
+ var range = editor.getSelection();
202
+ if (range && fileData) {
203
+ editor.insertEmbed(range.index, "image", fileData.path);
204
+ editor.formatText(range.index, 1, {
205
+ alt: fileData.id
206
+ });
207
+ setTimeout(() => {
208
+ editor.setSelection(range.index + 1);
209
+ }, 300);
210
+ }
211
+ }
212
+ });
213
+ }
214
+ };
215
+ currentScope.run(() => {
216
+ vue.watch(
217
+ vue.computed(() => props.disabled),
218
+ (disabled) => {
219
+ editor.enable(!disabled);
220
+ },
221
+ { immediate: true }
222
+ );
223
+ const getFilePaths = async (alt) => {
224
+ const filePathResult = await vue.unref(fileService).getFilePath(alt);
225
+ return filePathResult;
226
+ };
227
+ let artArr2 = [];
228
+ vue.watch(
229
+ value,
230
+ async () => {
231
+ if (vue.unref(value).indexOf("data:image/png") != -1 || vue.unref(value).indexOf("base64") != -1) {
232
+ editor.root.innerHTML = vue.unref(value);
233
+ return;
234
+ }
235
+ if (!vue.unref(value)) {
236
+ artArr2 = [];
237
+ }
238
+ let afterHtml = "";
239
+ let artArr = [];
240
+ let artArrOption = [];
241
+ if (vue.unref(value).indexOf("<img") != -1) {
242
+ vue.unref(value).replace(/<img [^>]*alt=['"]([^'"]+)[^>]*>/gi, (img, alt) => {
243
+ if (!artArr2.includes(alt)) {
244
+ artArr.push(alt);
245
+ }
246
+ });
247
+ for (const alt of artArr) {
248
+ artArrOption.push({
249
+ alt,
250
+ src: await getFilePaths(alt)
251
+ });
252
+ }
253
+ afterHtml = vue.unref(value).replace(/<img [^>]*alt=['"]([^'"]+)[^>]*>/gi, (img, alt) => {
254
+ var _a;
255
+ if (artArr.includes(alt)) {
256
+ return `<img src="${(_a = artArrOption.find((a) => a.alt === alt)) == null ? void 0 : _a.src.data}" alt="${alt}">`;
257
+ } else {
258
+ return img;
259
+ }
260
+ });
261
+ }
262
+ console.log("afterHtml =>", afterHtml);
263
+ artArr2 = [...artArr2, ...artArr];
264
+ artArr = [];
265
+ artArrOption = [];
266
+ if (editor.root.innerHTML === (afterHtml || vue.unref(value))) {
267
+ return;
268
+ }
269
+ const range = editor.getSelection();
270
+ editor.root.innerHTML = afterHtml || vue.unref(value);
271
+ setTimeout(() => {
272
+ if (range) {
273
+ editor.setSelection(range.index + 1);
274
+ editor.focus();
275
+ }
276
+ }, 100);
277
+ },
278
+ { immediate: true }
279
+ );
280
+ editor.on("text-change", handleTextChange);
281
+ editor.root.addEventListener("paste", handlePaste);
282
+ vue.onScopeDispose(() => {
283
+ editor.off("text-change", handleTextChange);
284
+ editor.root.removeEventListener("paste", handlePaste);
285
+ });
286
+ });
287
+ });
288
+ expose({
289
+ getEditorInstance() {
290
+ return vue.unref(editorInstance);
291
+ }
292
+ });
293
+ return (_ctx, _cache) => {
294
+ const _component_BwaAdvanceOption = vue.resolveComponent("BwaAdvanceOption");
295
+ const _component_BwaAdvanceSelect = vue.resolveComponent("BwaAdvanceSelect");
296
+ return vue.openBlock(), vue.createElementBlock("div", {
297
+ class: vue.normalizeClass(vue.unref(ns).b()),
298
+ ref_key: "quillEditorContainer",
299
+ ref: quillEditorContainer
300
+ }, [
301
+ vue.createElementVNode("div", {
302
+ class: vue.normalizeClass(vue.unref(ns).e("editor")),
303
+ ref_key: "quillEditorRef",
304
+ ref: quillEditorRef,
305
+ onClick: quillEditorRefClick
306
+ }, null, 2),
307
+ vue.createVNode(_component_BwaAdvanceSelect, {
308
+ showSelection: false,
309
+ "virtual-triggering": true,
310
+ "virtual-ref": virtualRef.value,
311
+ loading: loading.value,
312
+ onSearch: loadUserList,
313
+ "onUpdate:modelValue": handleChange,
314
+ onVisibleChange: handleVisibleChange
315
+ }, {
316
+ default: vue.withCtx(() => [
317
+ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(userList.value, (item) => {
318
+ return vue.openBlock(), vue.createBlock(_component_BwaAdvanceOption, {
319
+ key: item.value,
320
+ value: item.value,
321
+ label: item.label
322
+ }, null, 8, ["value", "label"]);
323
+ }), 128))
324
+ ]),
325
+ _: 1
326
+ }, 8, ["virtual-ref", "loading"])
327
+ ], 2);
328
+ };
329
+ }
330
+ });
331
+ var RichText = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["__file", "bwa-rich-text.vue"]]);
332
+
333
+ exports["default"] = RichText;
@@ -0,0 +1,80 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var vue = require('vue');
6
+ var ElementPlus = require('element-plus');
7
+ var _pluginVue_exportHelper = require('../../_virtual/_plugin-vue_export-helper.js');
8
+
9
+ const __default__ = vue.defineComponent({
10
+ name: "BwaSelect"
11
+ });
12
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
13
+ props: {
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: false
32
+ }
33
+ },
34
+ emits: ["update:modelValue"],
35
+ setup(__props, { emit }) {
36
+ const props = __props;
37
+ const options = vue.computed(
38
+ () => (props.options || []).map((item) => ({
39
+ ...item,
40
+ value: item.value + ""
41
+ }))
42
+ );
43
+ const attrs = vue.useAttrs();
44
+ const modelValue = vue.computed({
45
+ get: () => {
46
+ if (props.multiple) {
47
+ return Array.isArray(props.modelValue) ? props.modelValue.map((item) => item + "") : [];
48
+ } else {
49
+ return props.modelValue == null ? "" : props.modelValue + "";
50
+ }
51
+ },
52
+ set: (v) => emit("update:modelValue", v)
53
+ });
54
+ return (_ctx, _cache) => {
55
+ return vue.openBlock(), vue.createBlock(vue.unref(ElementPlus.ElSelect), vue.mergeProps(vue.unref(attrs), {
56
+ modelValue: vue.unref(modelValue),
57
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.isRef(modelValue) ? modelValue.value = $event : null),
58
+ clearable: "",
59
+ multiple: __props.multiple,
60
+ teleported: false
61
+ }), {
62
+ default: vue.withCtx(() => [
63
+ vue.renderSlot(_ctx.$slots, "default", {}, () => [
64
+ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(options), (item) => {
65
+ return vue.openBlock(), vue.createBlock(vue.unref(ElementPlus.ElOption), {
66
+ key: item.value,
67
+ value: item.value,
68
+ label: item.label
69
+ }, null, 8, ["value", "label"]);
70
+ }), 128))
71
+ ])
72
+ ]),
73
+ _: 3
74
+ }, 16, ["modelValue", "multiple"]);
75
+ };
76
+ }
77
+ });
78
+ var Select = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["__file", "bwa-select.vue"]]);
79
+
80
+ exports["default"] = Select;
@@ -0,0 +1,37 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var vue = require('vue');
6
+ var ElementPlus = require('element-plus');
7
+ var _pluginVue_exportHelper = require('../../_virtual/_plugin-vue_export-helper.js');
8
+
9
+ const __default__ = vue.defineComponent({
10
+ name: "BwaTextarea"
11
+ });
12
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
13
+ props: {
14
+ value: {
15
+ type: [String, Number],
16
+ default: ""
17
+ }
18
+ },
19
+ emits: ["update:model-value"],
20
+ setup(__props, { emit }) {
21
+ const props = __props;
22
+ const attrs = vue.useAttrs();
23
+ const modelValue = vue.computed({
24
+ get: () => props.modelValue,
25
+ set: (v) => emit("update:model-value", v)
26
+ });
27
+ return (_ctx, _cache) => {
28
+ return vue.openBlock(), vue.createBlock(vue.unref(ElementPlus.ElInput), vue.mergeProps({ type: "textarea" }, vue.unref(attrs), {
29
+ modelValue: vue.unref(modelValue),
30
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.isRef(modelValue) ? modelValue.value = $event : null)
31
+ }), null, 16, ["modelValue"]);
32
+ };
33
+ }
34
+ });
35
+ var Textarea = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["__file", "bwa-textarea.vue"]]);
36
+
37
+ exports["default"] = Textarea;
@@ -0,0 +1,163 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var vue = require('vue');
6
+ var icons = require('@element-plus/icons');
7
+ var ElementPlus = require('element-plus');
8
+ var webBaseClientVue = require('web-base-client-vue');
9
+ var _pluginVue_exportHelper = require('../../_virtual/_plugin-vue_export-helper.js');
10
+
11
+ const __default__ = vue.defineComponent({
12
+ name: "BwaUpload"
13
+ });
14
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
15
+ props: {
16
+ modelValue: { type: Array, default: () => [] }
17
+ },
18
+ emits: ["update:modelValue"],
19
+ setup(__props, { emit }) {
20
+ const props = __props;
21
+ vue.watch(
22
+ vue.computed(() => props.modelValue),
23
+ (modelValue) => {
24
+ if (!Array.isArray(modelValue)) {
25
+ emit("update:modelValue", []);
26
+ }
27
+ },
28
+ { immediate: true }
29
+ );
30
+ const fileList = vue.computed(
31
+ () => (Array.isArray(props.modelValue) ? props.modelValue : []).map((fileInfo) => {
32
+ return {
33
+ name: fileInfo.fileName,
34
+ response: fileInfo
35
+ };
36
+ })
37
+ );
38
+ const attrs = vue.useAttrs();
39
+ const ns = webBaseClientVue.useNamespace("upload");
40
+ const fileService = webBaseClientVue.useService("FileService");
41
+ const handleHttpRequest = ({ file, onProgress, onSuccess, onError }) => {
42
+ if (!vue.unref(fileService)) {
43
+ ElementPlus.ElMessage.error("\u65E0\u6CD5\u4E0A\u4F20\u6587\u4EF6\u3002");
44
+ return;
45
+ }
46
+ vue.unref(fileService).uploadFile(file, {
47
+ onUploadProgress: (event) => {
48
+ onProgress({ ...event, percent: event.progress });
49
+ }
50
+ }).then((res) => {
51
+ if (res.code != 0) {
52
+ onError(res.msg);
53
+ return;
54
+ }
55
+ onSuccess(res.data);
56
+ }, onError);
57
+ };
58
+ const handleSuccess = (fileInfo) => {
59
+ const value = Array.isArray(props.modelValue) ? props.modelValue : [];
60
+ emit("update:modelValue", value.concat(fileInfo));
61
+ };
62
+ const handleError = (error) => {
63
+ console.error(error);
64
+ ElementPlus.ElMessage.error("\u6587\u4EF6\u4E0A\u4F20\u5931\u8D25\u3002");
65
+ };
66
+ const handleDelete = (file) => {
67
+ emit(
68
+ "update:modelValue",
69
+ props.modelValue.filter((fileInfo) => fileInfo !== file.response)
70
+ );
71
+ };
72
+ const handleDownload = async (file) => {
73
+ if (!vue.unref(fileService)) {
74
+ ElementPlus.ElMessage.error("\u65E0\u6CD5\u4E0B\u8F7D\u6587\u4EF6\u3002");
75
+ return;
76
+ }
77
+ try {
78
+ const downloadFileResult = await vue.unref(fileService).downloadFile(
79
+ file.response
80
+ );
81
+ if (downloadFileResult.code != 0) {
82
+ ElementPlus.ElMessage.error(downloadFileResult.msg);
83
+ return;
84
+ }
85
+ } catch (e) {
86
+ console.error(e);
87
+ ElementPlus.ElMessage.error("\u4E0B\u8F7D\u6587\u4EF6\u5931\u8D25\u3002");
88
+ }
89
+ };
90
+ return (_ctx, _cache) => {
91
+ const _component_Plus = vue.resolveComponent("Plus");
92
+ const _component_ElTooltip = vue.resolveComponent("ElTooltip");
93
+ return vue.openBlock(), vue.createBlock(vue.unref(ElementPlus.ElUpload), vue.mergeProps(vue.unref(attrs), {
94
+ "file-list": vue.unref(fileList),
95
+ "http-request": handleHttpRequest,
96
+ class: vue.unref(ns).b(),
97
+ "on-success": handleSuccess,
98
+ "on-error": handleError
99
+ }), {
100
+ trigger: vue.withCtx(() => [
101
+ vue.createVNode(vue.unref(ElementPlus.ElButton), null, {
102
+ default: vue.withCtx(() => [
103
+ vue.createVNode(vue.unref(ElementPlus.ElIcon), null, {
104
+ default: vue.withCtx(() => [
105
+ vue.createVNode(_component_Plus)
106
+ ]),
107
+ _: 1
108
+ }),
109
+ vue.createTextVNode(" \u4E0A\u4F20\u6587\u4EF6 ")
110
+ ]),
111
+ _: 1
112
+ })
113
+ ]),
114
+ file: vue.withCtx(({ file }) => [
115
+ vue.createElementVNode("div", {
116
+ class: vue.normalizeClass(vue.unref(ns).b("item"))
117
+ }, [
118
+ vue.createElementVNode("div", {
119
+ class: vue.normalizeClass(vue.unref(ns).be("item", "info"))
120
+ }, [
121
+ vue.createVNode(_component_ElTooltip, {
122
+ content: file.name
123
+ }, {
124
+ default: vue.withCtx(() => [
125
+ vue.createElementVNode("div", {
126
+ class: vue.normalizeClass(vue.unref(ns).be("item", "file-name"))
127
+ }, vue.toDisplayString(file.name), 3)
128
+ ]),
129
+ _: 2
130
+ }, 1032, ["content"])
131
+ ], 2),
132
+ vue.createElementVNode("div", {
133
+ class: vue.normalizeClass(vue.unref(ns).be("item", "tools"))
134
+ }, [
135
+ vue.createVNode(vue.unref(ElementPlus.ElIcon), {
136
+ class: vue.normalizeClass(vue.unref(ns).be("item", "tools-item")),
137
+ onClick: ($event) => handleDownload(file)
138
+ }, {
139
+ default: vue.withCtx(() => [
140
+ vue.createVNode(vue.unref(icons.Download))
141
+ ]),
142
+ _: 2
143
+ }, 1032, ["class", "onClick"]),
144
+ vue.createVNode(vue.unref(ElementPlus.ElIcon), {
145
+ class: vue.normalizeClass(vue.unref(ns).be("item", "tools-item")),
146
+ onClick: ($event) => handleDelete(file)
147
+ }, {
148
+ default: vue.withCtx(() => [
149
+ vue.createVNode(vue.unref(icons.Delete))
150
+ ]),
151
+ _: 2
152
+ }, 1032, ["class", "onClick"])
153
+ ], 2)
154
+ ], 2)
155
+ ]),
156
+ _: 1
157
+ }, 16, ["file-list", "class"]);
158
+ };
159
+ }
160
+ });
161
+ var Upload = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["__file", "bwa-upload.vue"]]);
162
+
163
+ exports["default"] = Upload;
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var vue = require('vue');
6
+ var bwaUserSelect = require('./bwa-user-select.js');
7
+ var _pluginVue_exportHelper = require('../../_virtual/_plugin-vue_export-helper.js');
8
+
9
+ const __default__ = vue.defineComponent({
10
+ name: "BwaUserMultiSelect"
11
+ });
12
+ const _sfc_main = /* @__PURE__ */ Object.assign(__default__, {
13
+ props: {
14
+ modelValue: null
15
+ },
16
+ emits: ["update:model-value"],
17
+ setup(__props, { emit }) {
18
+ const props = __props;
19
+ const modelValue = vue.computed({
20
+ get: () => props.modelValue,
21
+ set: (v) => emit("update:model-value", v)
22
+ });
23
+ const attrs = vue.useAttrs();
24
+ return (_ctx, _cache) => {
25
+ return vue.openBlock(), vue.createBlock(bwaUserSelect["default"], vue.mergeProps({
26
+ modelValue: vue.unref(modelValue),
27
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.isRef(modelValue) ? modelValue.value = $event : null)
28
+ }, vue.unref(attrs), { multiple: "" }), null, 16, ["modelValue"]);
29
+ };
30
+ }
31
+ });
32
+ var UserMultiSelect = /* @__PURE__ */ _pluginVue_exportHelper["default"](_sfc_main, [["__file", "bwa-user-multi-select.vue"]]);
33
+
34
+ exports["default"] = UserMultiSelect;