sohelp-eleplus 1.1.1-8.beta.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 (298) hide show
  1. package/README.md +35 -0
  2. package/cache/DictCache.js +58 -0
  3. package/cache/ModuleCache.js +322 -0
  4. package/components.js +46 -0
  5. package/core-export.js +4 -0
  6. package/http/CrudHttp.js +115 -0
  7. package/http/DictHttp.js +12 -0
  8. package/http/ModuleHttp.js +68 -0
  9. package/http/SohelpHttp.js +125 -0
  10. package/index.js +6 -0
  11. package/installer.js +8 -0
  12. package/lang/en_US.js +4 -0
  13. package/lang/zh_CN.js +4 -0
  14. package/lang/zh_TW.js +4 -0
  15. package/package.json +9 -0
  16. package/sohelp-ace-editor/index.vue +198 -0
  17. package/sohelp-application-select/index.vue +15 -0
  18. package/sohelp-autocode/index.vue +53 -0
  19. package/sohelp-calendar-view/index.vue +11 -0
  20. package/sohelp-card-view/index.vue +11 -0
  21. package/sohelp-condition/index.vue +210 -0
  22. package/sohelp-cry-input/index.vue +64 -0
  23. package/sohelp-date/index.vue +27 -0
  24. package/sohelp-datetime/index.vue +44 -0
  25. package/sohelp-datetime-picker/index.vue +86 -0
  26. package/sohelp-datetime-range/index.vue +59 -0
  27. package/sohelp-dict/index.vue +206 -0
  28. package/sohelp-dict/props.js +68 -0
  29. package/sohelp-drawer/index.vue +50 -0
  30. package/sohelp-drop-card/index.vue +94 -0
  31. package/sohelp-drop-card/props.js +68 -0
  32. package/sohelp-dyn-select/index.vue +99 -0
  33. package/sohelp-dyn-select/props.js +67 -0
  34. package/sohelp-dyn-tree/index.vue +82 -0
  35. package/sohelp-dyn-tree-select/index.vue +114 -0
  36. package/sohelp-entity-form/index.vue +524 -0
  37. package/sohelp-entity-grid/index.vue +30 -0
  38. package/sohelp-file-upload/index.vue +218 -0
  39. package/sohelp-filter-scheme/components/condition.vue +102 -0
  40. package/sohelp-filter-scheme/components/filter.vue +45 -0
  41. package/sohelp-filter-scheme/components/keywords.vue +15 -0
  42. package/sohelp-filter-scheme/components/scheme.vue +49 -0
  43. package/sohelp-filter-scheme/index.vue +113 -0
  44. package/sohelp-grid/SohelpGridConfig.js~ +408 -0
  45. package/sohelp-grid/components/filter-condition-item.vue +298 -0
  46. package/sohelp-grid/index.vue +1965 -0
  47. package/sohelp-grid/js/ConditionType.js +101 -0
  48. package/sohelp-grid/js/DefaultGridOptions.js +145 -0
  49. package/sohelp-grid/js/DefaultProps.js +27 -0
  50. package/sohelp-grid/js/SohelpConfigFunction.js +0 -0
  51. package/sohelp-grid/js/SohelpGridConfig.js +101 -0
  52. package/sohelp-grid/js/useSohelpGridConfig.js +525 -0
  53. package/sohelp-grid-select/index.vue +245 -0
  54. package/sohelp-grid-view/filter/config/grid-filter-condition.vue +221 -0
  55. package/sohelp-grid-view/filter/config/grid-filter-config.vue +27 -0
  56. package/sohelp-grid-view/filter/config/grid-filter-field.vue +378 -0
  57. package/sohelp-grid-view/filter/config/grid-filter-keywords.vue +310 -0
  58. package/sohelp-grid-view/filter/config/grid-filter-list.vue +313 -0
  59. package/sohelp-grid-view/filter/config/grid-filter-scheme.vue +264 -0
  60. package/sohelp-grid-view/filter/config/grid-filter-sort.vue +310 -0
  61. package/sohelp-grid-view/filter/config/index.vue +206 -0
  62. package/sohelp-grid-view/filter/filter-form.vue +446 -0
  63. package/sohelp-grid-view/filter/filter-toolbar.vue +110 -0
  64. package/sohelp-grid-view/filter/index.vue +160 -0
  65. package/sohelp-grid-view/index.vue +379 -0
  66. package/sohelp-grid-view-select/index.vue +141 -0
  67. package/sohelp-group-view/index.vue +11 -0
  68. package/sohelp-icon-select/icons/AnalysisOutlined.vue +22 -0
  69. package/sohelp-icon-select/icons/ApplicationOutlined.vue +21 -0
  70. package/sohelp-icon-select/icons/AppstoreAddOutlined.vue +28 -0
  71. package/sohelp-icon-select/icons/AppstoreOutlined.vue +30 -0
  72. package/sohelp-icon-select/icons/ArrowDown.vue +21 -0
  73. package/sohelp-icon-select/icons/ArrowDownOutlined.vue +20 -0
  74. package/sohelp-icon-select/icons/ArrowLeft.vue +21 -0
  75. package/sohelp-icon-select/icons/ArrowLeftOutlined.vue +20 -0
  76. package/sohelp-icon-select/icons/ArrowRight.vue +21 -0
  77. package/sohelp-icon-select/icons/ArrowRightOutlined.vue +20 -0
  78. package/sohelp-icon-select/icons/ArrowUp.vue +21 -0
  79. package/sohelp-icon-select/icons/ArrowUpOutlined.vue +20 -0
  80. package/sohelp-icon-select/icons/BellOutlined.vue +21 -0
  81. package/sohelp-icon-select/icons/BookOutlined.vue +21 -0
  82. package/sohelp-icon-select/icons/CalendarOutlined.vue +19 -0
  83. package/sohelp-icon-select/icons/CaretDownFilled.vue +13 -0
  84. package/sohelp-icon-select/icons/CaretUpFilled.vue +13 -0
  85. package/sohelp-icon-select/icons/CheckCircleFilled.vue +15 -0
  86. package/sohelp-icon-select/icons/CheckCircleOutlined.vue +23 -0
  87. package/sohelp-icon-select/icons/CheckOutlined.vue +20 -0
  88. package/sohelp-icon-select/icons/CityOutlined.vue +22 -0
  89. package/sohelp-icon-select/icons/ClockCircleOutlined.vue +23 -0
  90. package/sohelp-icon-select/icons/CloseCircleFilled.vue +15 -0
  91. package/sohelp-icon-select/icons/CloseCircleOutlined.vue +22 -0
  92. package/sohelp-icon-select/icons/CloseOutlined.vue +20 -0
  93. package/sohelp-icon-select/icons/CloudUploadOutlined.vue +23 -0
  94. package/sohelp-icon-select/icons/ClusterOutlined.vue +21 -0
  95. package/sohelp-icon-select/icons/CodeOutlined.vue +22 -0
  96. package/sohelp-icon-select/icons/ColumnHeightOutlined.vue +18 -0
  97. package/sohelp-icon-select/icons/CompassOutlined.vue +22 -0
  98. package/sohelp-icon-select/icons/CompressOutlined.vue +23 -0
  99. package/sohelp-icon-select/icons/ConnectionOutlined.vue +24 -0
  100. package/sohelp-icon-select/icons/ControlOutlined.vue +27 -0
  101. package/sohelp-icon-select/icons/CopyOutlined.vue +22 -0
  102. package/sohelp-icon-select/icons/CpuOutlined.vue +22 -0
  103. package/sohelp-icon-select/icons/DashboardOutlined.vue +26 -0
  104. package/sohelp-icon-select/icons/DatabaseOutlined.vue +22 -0
  105. package/sohelp-icon-select/icons/DeleteOutlined.vue +22 -0
  106. package/sohelp-icon-select/icons/DesktopOutlined.vue +19 -0
  107. package/sohelp-icon-select/icons/DownloadOutlined.vue +21 -0
  108. package/sohelp-icon-select/icons/DragOutlined.vue +22 -0
  109. package/sohelp-icon-select/icons/EditOutlined.vue +21 -0
  110. package/sohelp-icon-select/icons/EllipsisOutlined.vue +15 -0
  111. package/sohelp-icon-select/icons/EnvironmentOutlined.vue +22 -0
  112. package/sohelp-icon-select/icons/ExclamationCircleFilled.vue +15 -0
  113. package/sohelp-icon-select/icons/ExpandOutlined.vue +23 -0
  114. package/sohelp-icon-select/icons/FileOutlined.vue +22 -0
  115. package/sohelp-icon-select/icons/FilterFilled.vue +15 -0
  116. package/sohelp-icon-select/icons/FolderAddOutlined.vue +20 -0
  117. package/sohelp-icon-select/icons/FolderOutlined.vue +19 -0
  118. package/sohelp-icon-select/icons/FormOutlined.vue +20 -0
  119. package/sohelp-icon-select/icons/FullscreenExitOutlined.vue +16 -0
  120. package/sohelp-icon-select/icons/FullscreenOutlined.vue +16 -0
  121. package/sohelp-icon-select/icons/FundOutlined.vue +20 -0
  122. package/sohelp-icon-select/icons/GlobalOutlined.vue +15 -0
  123. package/sohelp-icon-select/icons/HolderOutlined.vue +18 -0
  124. package/sohelp-icon-select/icons/HomeOutlined.vue +19 -0
  125. package/sohelp-icon-select/icons/IdcardOutlined.vue +25 -0
  126. package/sohelp-icon-select/icons/InfoCircleFilled.vue +15 -0
  127. package/sohelp-icon-select/icons/LinkOutlined.vue +15 -0
  128. package/sohelp-icon-select/icons/LoadingDotOutlined.vue +21 -0
  129. package/sohelp-icon-select/icons/LoadingOutlined.vue +19 -0
  130. package/sohelp-icon-select/icons/LockOutlined.vue +21 -0
  131. package/sohelp-icon-select/icons/LogOutlined.vue +22 -0
  132. package/sohelp-icon-select/icons/LogoutOutlined.vue +22 -0
  133. package/sohelp-icon-select/icons/MailOutlined.vue +19 -0
  134. package/sohelp-icon-select/icons/MenuFoldOutlined.vue +17 -0
  135. package/sohelp-icon-select/icons/MenuUnfoldOutlined.vue +17 -0
  136. package/sohelp-icon-select/icons/MessageOutlined.vue +22 -0
  137. package/sohelp-icon-select/icons/MinusCircleOutlined.vue +22 -0
  138. package/sohelp-icon-select/icons/MobileOutlined.vue +20 -0
  139. package/sohelp-icon-select/icons/MoonOutlined.vue +21 -0
  140. package/sohelp-icon-select/icons/MoreOutlined.vue +15 -0
  141. package/sohelp-icon-select/icons/PauseFilled.vue +14 -0
  142. package/sohelp-icon-select/icons/PieChartOutlined.vue +20 -0
  143. package/sohelp-icon-select/icons/PlayFilled.vue +13 -0
  144. package/sohelp-icon-select/icons/PlusCircleOutlined.vue +22 -0
  145. package/sohelp-icon-select/icons/PlusOutlined.vue +19 -0
  146. package/sohelp-icon-select/icons/ProtectOutlined.vue +21 -0
  147. package/sohelp-icon-select/icons/QuestionCircleFilled.vue +15 -0
  148. package/sohelp-icon-select/icons/QuestionCircleOutlined.vue +25 -0
  149. package/sohelp-icon-select/icons/ReloadOutlined.vue +22 -0
  150. package/sohelp-icon-select/icons/SearchOutlined.vue +21 -0
  151. package/sohelp-icon-select/icons/SettingOutlined.vue +24 -0
  152. package/sohelp-icon-select/icons/ShoppingOutlined.vue +19 -0
  153. package/sohelp-icon-select/icons/SortOutlined.vue +21 -0
  154. package/sohelp-icon-select/icons/StarFilled.vue +15 -0
  155. package/sohelp-icon-select/icons/StepBackwardFilled.vue +17 -0
  156. package/sohelp-icon-select/icons/StepForwardFilled.vue +17 -0
  157. package/sohelp-icon-select/icons/SuitcaseOutlined.vue +19 -0
  158. package/sohelp-icon-select/icons/SunOutlined.vue +29 -0
  159. package/sohelp-icon-select/icons/SwapOutlined.vue +21 -0
  160. package/sohelp-icon-select/icons/SyncOutlined.vue +21 -0
  161. package/sohelp-icon-select/icons/TableOutlined.vue +19 -0
  162. package/sohelp-icon-select/icons/TagOutlined.vue +20 -0
  163. package/sohelp-icon-select/icons/TimerOutlined.vue +22 -0
  164. package/sohelp-icon-select/icons/UndoOutlined.vue +22 -0
  165. package/sohelp-icon-select/icons/UnlockOutlined.vue +21 -0
  166. package/sohelp-icon-select/icons/UploadOutlined.vue +21 -0
  167. package/sohelp-icon-select/icons/UserOutlined.vue +21 -0
  168. package/sohelp-icon-select/icons/VerticalAlignMiddleOutlined.vue +15 -0
  169. package/sohelp-icon-select/icons/VerticalLeftOutlined.vue +13 -0
  170. package/sohelp-icon-select/icons/VerticalRightOutlined.vue +13 -0
  171. package/sohelp-icon-select/icons/WarningOutlined.vue +21 -0
  172. package/sohelp-icon-select/icons/ZoomInOutlined.vue +22 -0
  173. package/sohelp-icon-select/icons/ZoomOutOutlined.vue +22 -0
  174. package/sohelp-icon-select/icons/index.js +106 -0
  175. package/sohelp-icon-select/icons/index.ts +106 -0
  176. package/sohelp-icon-select/index.vue +95 -0
  177. package/sohelp-icon-select/vxeui-icon.js +90 -0
  178. package/sohelp-image-upload/index.vue +286 -0
  179. package/sohelp-input/index.vue +39 -0
  180. package/sohelp-modal/index.vue +72 -0
  181. package/sohelp-module/index.vue +54 -0
  182. package/sohelp-module/useModalManager.js +89 -0
  183. package/sohelp-module/useSohelpModule.js +64 -0
  184. package/sohelp-number-input/index.vue +32 -0
  185. package/sohelp-number-range/index.vue +135 -0
  186. package/sohelp-org-select/index.vue +30 -0
  187. package/sohelp-org-tree/index.vue +18 -0
  188. package/sohelp-org-tree-select/index.vue +93 -0
  189. package/sohelp-org-user-tree/index.vue +26 -0
  190. package/sohelp-org-user-tree-select/index.vue +11 -0
  191. package/sohelp-pagination/index.vue +11 -0
  192. package/sohelp-power/index.vue +105 -0
  193. package/sohelp-pro-form/components/pro-form-footer.vue +44 -0
  194. package/sohelp-pro-form/components/pro-form-item.vue +1133 -0
  195. package/sohelp-pro-form/index.vue +257 -0
  196. package/sohelp-pro-form/util.js +140 -0
  197. package/sohelp-pro-layout/index.vue +11 -0
  198. package/sohelp-pro-table/index.vue +14 -0
  199. package/sohelp-process/index.vue +216 -0
  200. package/sohelp-rate/index.vue +56 -0
  201. package/sohelp-rate/props.js +71 -0
  202. package/sohelp-relation/index.vue +11 -0
  203. package/sohelp-rich-text/index.vue +242 -0
  204. package/sohelp-rich-text/util.js +231 -0
  205. package/sohelp-richtext/index.vue +10 -0
  206. package/sohelp-role-select/index.vue +33 -0
  207. package/sohelp-search/components/search-config.vue +0 -0
  208. package/sohelp-search/index.vue +49 -0
  209. package/sohelp-search-pro-form/index.vue +11 -0
  210. package/sohelp-select/index.vue +120 -0
  211. package/sohelp-split-panel/index.vue +15 -0
  212. package/sohelp-switch/index.vue +56 -0
  213. package/sohelp-table/index.vue +151 -0
  214. package/sohelp-tenant-select/index.vue +128 -0
  215. package/sohelp-text/index.vue +14 -0
  216. package/sohelp-textarea-input/index.vue +36 -0
  217. package/sohelp-time/index.vue +10 -0
  218. package/sohelp-tree/index.vue +37 -0
  219. package/sohelp-tree-select/index.vue +18 -0
  220. package/sohelp-user-select/index.vue +44 -0
  221. package/sohelp-user-select/index.vue~ +53 -0
  222. package/sohelp-user-select/props.js +71 -0
  223. package/sohelp-user-tag/index.vue +12 -0
  224. package/sohelp-user-tree/index.vue +11 -0
  225. package/sohelp-vform-drawer/index.vue +40 -0
  226. package/sohelp-vform-eleplus/favicon.ico +0 -0
  227. package/sohelp-vform-eleplus/index.vue +297 -0
  228. package/sohelp-vform-eleplus/preview.html +91 -0
  229. package/sohelp-vform-eleplus/render.es.js +72433 -0
  230. package/sohelp-vform-eleplus/render.style.css +16 -0
  231. package/sohelp-vform-eleplus/render.umd.js +57 -0
  232. package/sohelp-vform-eleplus/tinymce/langs/zh_CN.js +462 -0
  233. package/sohelp-vform-eleplus/tinymce/langs/zh_TW.js +419 -0
  234. package/sohelp-vform-eleplus/tinymce/skins/content/dark/content.css +72 -0
  235. package/sohelp-vform-eleplus/tinymce/skins/content/dark/content.min.css +7 -0
  236. package/sohelp-vform-eleplus/tinymce/skins/content/default/content.css +67 -0
  237. package/sohelp-vform-eleplus/tinymce/skins/content/default/content.min.css +7 -0
  238. package/sohelp-vform-eleplus/tinymce/skins/content/document/content.css +72 -0
  239. package/sohelp-vform-eleplus/tinymce/skins/content/document/content.min.css +7 -0
  240. package/sohelp-vform-eleplus/tinymce/skins/content/writer/content.css +68 -0
  241. package/sohelp-vform-eleplus/tinymce/skins/content/writer/content.min.css +7 -0
  242. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/content.css +732 -0
  243. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/content.inline.css +726 -0
  244. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/content.inline.min.css +7 -0
  245. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/content.min.css +7 -0
  246. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/content.mobile.css +29 -0
  247. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/content.mobile.min.css +7 -0
  248. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/fonts/tinymce-mobile.woff +0 -0
  249. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/skin.css +3047 -0
  250. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/skin.min.css +7 -0
  251. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/skin.mobile.css +673 -0
  252. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/skin.mobile.min.css +7 -0
  253. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/skin.shadowdom.css +37 -0
  254. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide/skin.shadowdom.min.css +7 -0
  255. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/content.css +714 -0
  256. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/content.inline.css +726 -0
  257. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/content.inline.min.css +7 -0
  258. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/content.min.css +7 -0
  259. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/content.mobile.css +29 -0
  260. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/content.mobile.min.css +7 -0
  261. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/fonts/tinymce-mobile.woff +0 -0
  262. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/skin.css +3047 -0
  263. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/skin.min.css +7 -0
  264. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/skin.mobile.css +673 -0
  265. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/skin.mobile.min.css +7 -0
  266. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/skin.shadowdom.css +37 -0
  267. package/sohelp-vform-eleplus/tinymce/skins/ui/oxide-dark/skin.shadowdom.min.css +7 -0
  268. package/sohelp-vform-modal/index.vue +41 -0
  269. package/sohelp-vform-select/index.vue +11 -0
  270. package/sohelp-vform-vant/favicon.ico +0 -0
  271. package/sohelp-vform-vant/render.es.js +14608 -0
  272. package/sohelp-vform-vant/render.style.css +1 -0
  273. package/sohelp-vform-vant/render.umd.js +22 -0
  274. package/sohelp-vxe-grid/DefaultGridOptions.js +90 -0
  275. package/sohelp-vxe-grid/DefaultProps.js +27 -0
  276. package/sohelp-vxe-grid/SohelpGridConfig.js +143 -0
  277. package/sohelp-vxe-grid/index.vue +475 -0
  278. package/sohelp-vxe-grid-select/index.vue +148 -0
  279. package/sohelp-vxe-table/index.vue +184 -0
  280. package/sohelp-workflow/index.vue +495 -0
  281. package/sohelp-workflow/nodeWrap.vue +53 -0
  282. package/sohelp-workflow/nodes/addNode.vue +27 -0
  283. package/sohelp-workflow/nodes/approver.vue +125 -0
  284. package/sohelp-workflow/nodes/branch.vue +434 -0
  285. package/sohelp-workflow/nodes/promoter.vue +80 -0
  286. package/sohelp-workflow/nodes/send.vue +95 -0
  287. package/sohelp-workflow-drawer/components/approval-modal.vue +182 -0
  288. package/sohelp-workflow-drawer/components/draw-box.vue +141 -0
  289. package/sohelp-workflow-drawer/components/form.vue +78 -0
  290. package/sohelp-workflow-drawer/components/table.vue +153 -0
  291. package/sohelp-workflow-drawer/components/timeline.vue +189 -0
  292. package/sohelp-workflow-drawer/components/workflow.vue +68 -0
  293. package/sohelp-workflow-drawer/index.vue +311 -0
  294. package/sohelp-workflow-drawer/js/index.js +119 -0
  295. package/utils/ProFormConvertUtil.js +76 -0
  296. package/utils/core.js +310 -0
  297. package/utils/use-form-data.js +48 -0
  298. package/utils/use-mobile.js +43 -0
@@ -0,0 +1,218 @@
1
+ <template>
2
+ <div class="sohelp-file-upload">
3
+ <vxe-upload
4
+ ref="vxeUploadRef"
5
+ v-model="fileList"
6
+ :autoHiddenButton="!multiple"
7
+ show-download-button
8
+ :dragSort="true"
9
+ :urlMode="true"
10
+ :showProgress="true"
11
+ :showButtonText="false"
12
+ :pasteToUpload="true"
13
+ :singleMode="!multiple"
14
+ :multiple="multiple"
15
+ :readonly="readonly"
16
+ :limitSize="limitSize"
17
+ :progressText="'{percent}%'"
18
+ :moreConfig="moreConfig"
19
+ :upload-method="uploadMethod"
20
+ :before-remove-method="beforeRemoveMethod"
21
+ :before-download-method="beforeDownloadMethod"
22
+ :previewMethod="previewMethod"
23
+ >
24
+ </vxe-upload>
25
+ </div>
26
+ </template>
27
+
28
+ <script setup>
29
+ import { ref, watch } from 'vue';
30
+ import { ElMessage, ElMessageBox } from 'element-plus';
31
+ import { SohelpHttp } from '../core-export';
32
+ import { VxeUI } from 'vxe-pc-ui';
33
+ import { EleMessage } from '@/components/ele-admin-plus/components';
34
+
35
+ const modelValue = defineModel('modelValue');
36
+ const data = defineModel('data');
37
+
38
+ const imagePath = `${SohelpHttp.getBaseUrl()}/engine/web/file/download?id=`;
39
+ const props = defineProps({
40
+ readonly: {
41
+ type: Boolean,
42
+ default: false
43
+ },
44
+ multiple: {
45
+ type: Boolean,
46
+ default: false
47
+ },
48
+ limitSize: {
49
+ type: Number,
50
+ default: 1 //10Mb
51
+ },
52
+ moreConfig: {
53
+ type: Object,
54
+ default: () => {
55
+ return {
56
+ maxCount: 1,
57
+ layout: 'horizontal'
58
+ };
59
+ }
60
+ }
61
+ });
62
+
63
+ const emit = defineEmits(['update:modelValue']);
64
+
65
+ const vxeUploadRef = ref(null);
66
+ const fileList = ref([]);
67
+ const originList = ref([]);
68
+
69
+ const previewMethod = async ({ option }) => {
70
+ const { name } = option;
71
+ const image = originList.value.find((item) => item.name === name);
72
+ if (image && ['jpg', 'png', 'jpeg', 'gif', 'webp'].includes(image.type)) {
73
+ VxeUI.previewImage({
74
+ urlList: [image.url]
75
+ });
76
+ }
77
+ };
78
+
79
+ /**
80
+ * 下载
81
+ * @param param0
82
+ */
83
+ const beforeDownloadMethod = async ({ option }) => {
84
+ try {
85
+ const blob = await fetch(option.url).then((response) => response.blob());
86
+ await VxeUI.saveFile({
87
+ filename: option.name,
88
+ content: blob
89
+ });
90
+ VxeUI.modal.message({
91
+ content: '下载成功',
92
+ status: 'success'
93
+ });
94
+ } catch (e) {
95
+ VxeUI.modal.message({
96
+ content: '下载失败',
97
+ status: 'error'
98
+ });
99
+ }
100
+ return false;
101
+ };
102
+
103
+ /**
104
+ *
105
+ * @param param0 删除
106
+ */
107
+ const beforeRemoveMethod = async ({ option }) => {
108
+ const flag = await ElMessageBox.confirm('确定要删除文件吗?', '系统提示', {
109
+ type: 'warning',
110
+ draggable: false
111
+ })
112
+ .then(async () => {
113
+ const urlObj = new URL(option.url);
114
+ const id = urlObj.searchParams.get('id');
115
+
116
+ if (id) {
117
+ const res = await SohelpHttp.post('/engine/web/file/delete', {
118
+ id: id
119
+ });
120
+
121
+ if (res.meta.success) {
122
+ originList.value = originList.value.filter((item) => item.id !== id);
123
+ setTimeout(() => {
124
+ updateModelValue();
125
+ }, 1);
126
+ ElMessage.success(res.meta.message);
127
+ return true;
128
+ } else {
129
+ ElMessage.error(res.meta.message);
130
+ return false;
131
+ }
132
+ }
133
+ return false;
134
+ })
135
+ .catch(() => {
136
+ return false;
137
+ });
138
+
139
+ return flag;
140
+ };
141
+
142
+ /**
143
+ * 上传
144
+ */
145
+ const uploadMethod = async ({ file }) => {
146
+ const formData = new FormData();
147
+ formData.append('files', file);
148
+
149
+ const res = await SohelpHttp.post('/engine/web/file/upload', formData);
150
+ if (res.meta.success) {
151
+ originList.value.push({
152
+ name: file.name,
153
+ id: res.data[0]
154
+ });
155
+
156
+ updateModelValue();
157
+ EleMessage.success('上传成功!');
158
+ return {
159
+ url: imagePath + res.data[0]
160
+ };
161
+ } else {
162
+ ElMessage.error(res.meta.message);
163
+ }
164
+ };
165
+
166
+ /**
167
+ * 更新modelValue
168
+ */
169
+ const updateModelValue = () => {
170
+ const arr = props.multiple ? originList.value : [originList.value[0]];
171
+ if (props.multiple) {
172
+ modelValue.value = arr?.map((item) => item.id) || '';
173
+ } else {
174
+ modelValue.value = arr?.length > 0 ? arr[0].id : '';
175
+ }
176
+
177
+ data.value =
178
+ arr?.map((item) => {
179
+ return {
180
+ id: item.id,
181
+ filename: item.name
182
+ };
183
+ }) || [];
184
+ };
185
+
186
+ watch(
187
+ () => modelValue.value,
188
+ (val) => {
189
+ if (val && val != '0' && val !== 0) {
190
+ const arr = Array.isArray(val) ? val : [val];
191
+ const v = Array.isArray(data.value) ? data.value : [data.value];
192
+ originList.value = arr.map((item) => {
193
+ const filename = v?.find((row) => row?.id === item)?.filename || item.id;
194
+ return {
195
+ id: item,
196
+ name: filename,
197
+ url: imagePath + item
198
+ };
199
+ });
200
+ fileList.value = originList.value;
201
+ } else {
202
+ originList.value = [];
203
+ data.value = [];
204
+ fileList.value = [];
205
+ }
206
+ },
207
+ {
208
+ immediate: true
209
+ }
210
+ );
211
+ </script>
212
+
213
+ <script>
214
+ export default {
215
+ name: 'SohelpFileUpload'
216
+ };
217
+ </script>
218
+ <style scoped lang="scss"></style>
@@ -0,0 +1,102 @@
1
+ <template>
2
+ <div class="sohelp-filter-condition">
3
+ <el-form-item :label="label">
4
+ <sohelp-select v-model="value.comparison" :datasource="comparisonOptions" class="sohelp-select-row"></sohelp-select>
5
+ </el-form-item>
6
+ <sohelp-input v-model="value.value"></sohelp-input>
7
+ </div>
8
+ </template>
9
+
10
+ <script setup>
11
+ import { reactive, watch } from 'vue';
12
+ const props = defineProps({
13
+ modelValue: Object,
14
+ label: String
15
+ });
16
+
17
+ const emit = defineEmits(['update:modelValue']);
18
+ const value = reactive(props.modelValue);
19
+
20
+ const comparisonOptions = [
21
+ {
22
+ label: '包含',
23
+ value: 'LIKE'
24
+ },
25
+ {
26
+ label: '不包含',
27
+ value: 'NOT_LIKE'
28
+ },
29
+
30
+ {
31
+ label: '等于',
32
+ value: 'EQ'
33
+ },
34
+ {
35
+ label: '不等于',
36
+ value: 'NE'
37
+ },
38
+ {
39
+ label: '大于',
40
+ value: 'GT'
41
+ },
42
+ {
43
+ label: '小于',
44
+ value: 'LT'
45
+ },
46
+ {
47
+ label: '大于等于',
48
+ value: 'GTE'
49
+ },
50
+ {
51
+ label: '小于等于',
52
+ value: 'LTE'
53
+ },
54
+ {
55
+ label: '左包含',
56
+ value: 'LEFT_LIKE'
57
+ },
58
+ {
59
+ label: '右包含',
60
+ value: 'RIGHT_LIKE'
61
+ },
62
+ {
63
+ label: '为空',
64
+ value: 'EMPTY'
65
+ },
66
+ {
67
+ label: '不为空',
68
+ value: 'NOT_EMPTY'
69
+ }
70
+ ];
71
+
72
+ watch(
73
+ () => props.modelValue,
74
+ (val) => {
75
+ Object.assign(value, val);
76
+ },
77
+ {
78
+ deep: true
79
+ }
80
+ );
81
+ </script>
82
+ <script>
83
+ export default {
84
+ name: 'SohelpFilterCondition'
85
+ };
86
+ </script>
87
+ <style lang="scss" scoped>
88
+ .sohelp-filter-condition {
89
+ width: 180px;
90
+ display: flex;
91
+ flex-direction: column;
92
+
93
+ .el-form-item{
94
+ margin-bottom: 10px;
95
+ }
96
+ .sohelp-select-row{
97
+ width: 100%;
98
+ background: #f5f5f5!important;
99
+ border-radius: 6px;
100
+ }
101
+ }
102
+ </style>
@@ -0,0 +1,45 @@
1
+ <template>
2
+ <div class="sohelp-filter">
3
+ <filter-condition
4
+ v-for="(item, index) in filterList"
5
+ :key="item.name"
6
+ v-model="filterList[index]"
7
+ :label="propertiesMap[item.name]?.label || ''"
8
+ ></filter-condition>
9
+ </div>
10
+ </template>
11
+
12
+ <script setup>
13
+ import { ref, watch } from 'vue';
14
+ import FilterCondition from './condition.vue';
15
+ const props = defineProps({
16
+ modelValue: Array,
17
+ propertiesMap: Object
18
+ });
19
+
20
+ const filterList = ref([]);
21
+
22
+ watch(
23
+ () => props.modelValue,
24
+ (val) => {
25
+ filterList.value = val;
26
+ },
27
+ {
28
+ immediate: true,
29
+ deep: true
30
+ }
31
+ );
32
+ </script>
33
+ <script>
34
+ export default {
35
+ name: 'SohelpFilterSchemeFilter'
36
+ };
37
+ </script>
38
+
39
+ <style lang="scss" scoped>
40
+ .sohelp-filter {
41
+ display: flex;
42
+ flex-direction: row;
43
+ gap: 20px;
44
+ }
45
+ </style>
@@ -0,0 +1,15 @@
1
+ <template>
2
+ <sohelp-input v-bind="$attrs" style="min-width: 300px"></sohelp-input>
3
+ </template>
4
+
5
+ <script setup>
6
+
7
+
8
+ </script>
9
+ <script>
10
+ export default {
11
+ name: 'SohelpFilterSchemeKeywords'
12
+ };
13
+ </script>
14
+
15
+ <style lang="scss" scoped></style>
@@ -0,0 +1,49 @@
1
+ <template>
2
+ <el-radio-group v-model="radioValue">
3
+ <el-radio
4
+ border
5
+ v-for="scheme in schemeList"
6
+ :key="scheme"
7
+ :label="scheme"
8
+ @click.prevent="handleRadioClick(scheme)"
9
+ ></el-radio>
10
+ </el-radio-group>
11
+ </template>
12
+
13
+ <script setup>
14
+ import { computed, ref, watch } from 'vue';
15
+ const props = defineProps({
16
+ filterConfig: Object,
17
+ modelValue: String
18
+ });
19
+ const emit = defineEmits(['update:modelValue']);
20
+ const radioValue = ref('');
21
+
22
+ // 方案列表
23
+ const schemeList = computed(() => {
24
+ if (props.filterConfig.scheme?.length) {
25
+ return props.filterConfig.scheme.map((item) => item.label);
26
+ }
27
+ return [];
28
+ });
29
+
30
+ watch(() => props.modelValue, (val) => {
31
+ radioValue.value = val;
32
+ },{
33
+ immediate: true
34
+ })
35
+
36
+ /**
37
+ * radio 取消点击
38
+ */
39
+ const handleRadioClick = (val) => {
40
+ radioValue.value = radioValue.value === val ? '' : val;
41
+ emit('update:modelValue', radioValue.value);
42
+ };
43
+ </script>
44
+ <script>
45
+ export default {
46
+ name: 'SohelpFilterSchemeScheme'
47
+ };
48
+ </script>
49
+ <style lang="scss" scoped></style>
@@ -0,0 +1,113 @@
1
+ <template>
2
+ <ele-card :headerStyle="{ padding: '0' }" :bodyStyle="{ padding: '15px 0' }" class="sohelp-filter-scheme-card">
3
+
4
+ <template #header>
5
+ <ele-tabs :items="tabs" v-model="active"> </ele-tabs>
6
+ </template>
7
+ <div class="filter-box">
8
+ <div class="filter-content">
9
+ <keywords-card
10
+ :placeholder="getKeywordsPlaceholder"
11
+ v-model="filterForm.keywords"
12
+ v-if="active === 'keywords'"
13
+ ></keywords-card>
14
+ <filter-card :propertiesMap="propertiesMap" v-model="filterForm.filter" v-if="active === 'filter'"></filter-card>
15
+ <scheme-card :propertiesMap="propertiesMap" :filterConfig="filterConfig" v-model="filterForm.scheme" v-if="active === 'scheme'"></scheme-card>
16
+ </div>
17
+ <div class="filter-opt">
18
+ <el-button type="primary" size="small" @click="onFilter">筛选</el-button>
19
+ <el-button size="small" @click="onReset">重置</el-button>
20
+ </div>
21
+ </div>
22
+ </ele-card>
23
+ </template>
24
+
25
+ <script setup>
26
+ import { reactive, ref, computed } from 'vue';
27
+ import KeywordsCard from './components/keywords.vue';
28
+ import FilterCard from './components/filter.vue';
29
+ import SchemeCard from './components/scheme.vue';
30
+
31
+ const props = defineProps({
32
+ filterConfig: {
33
+ type: Object,
34
+ default: () => ({}),
35
+ required: true
36
+ },
37
+ refid: String,
38
+ modelValue: {
39
+ type: Object,
40
+ default: () => ({
41
+ keywords: '',
42
+ filter: {},
43
+ scheme: ''
44
+ }),
45
+ required: true
46
+ },
47
+ propertiesMap: Object
48
+ });
49
+
50
+ const emit = defineEmits(['filter', 'reset', 'update:modelValue']);
51
+ const filterForm = ref({ ...props.modelValue });
52
+
53
+ const tabs = reactive([
54
+ {
55
+ name: 'keywords',
56
+ label: '快捷筛选'
57
+ },
58
+ {
59
+ name: 'filter',
60
+ label: '高级筛选'
61
+ },
62
+ {
63
+ name: 'scheme',
64
+ label: '场景筛选'
65
+ }
66
+ ]);
67
+ const active = ref('keywords');
68
+ const filterConfig = reactive(props.filterConfig);
69
+
70
+ /**
71
+ * 获取关键字查询placeholder
72
+ */
73
+ const getKeywordsPlaceholder = computed(() => {
74
+ const labels = props.filterConfig?.keywords?.map((name) => props.propertiesMap[name]?.label)?.filter(Boolean) || [];
75
+ return labels.length ? `请输入${labels.join('、')}` : '请输入';
76
+ });
77
+
78
+ const onFilter = () => {
79
+ emit('update:modelValue', { ...filterForm.value });
80
+ emit('filter');
81
+ };
82
+
83
+ const onReset = () => {
84
+ filterForm.value = { ...props.modelValue };
85
+ emit('update:modelValue', { ...props.modelValue });
86
+ emit('filter');
87
+ };
88
+ </script>
89
+ <script>
90
+ export default {
91
+ name: 'SohelpFilterScheme'
92
+ };
93
+ </script>
94
+
95
+ <style lang="scss" scoped>
96
+ .sohelp-filter-scheme-card {
97
+ .filter-box {
98
+ display: flex;
99
+ gap: 20px;
100
+ flex-direction: row;
101
+ justify-content: flex-start;
102
+ align-items: flex-end;
103
+ .filter-content {
104
+ }
105
+ .filter-opt {
106
+ margin-bottom: 3px;
107
+ flex: 1;
108
+ width: 60px;
109
+ }
110
+ }
111
+
112
+ }
113
+ </style>