three-trees-ui 1.0.0

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 (384) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +32 -0
  3. package/lib/demo.html +10 -0
  4. package/lib/three-trees-ui.common.js +49136 -0
  5. package/lib/three-trees-ui.css +1 -0
  6. package/lib/three-trees-ui.umd.js +49146 -0
  7. package/lib/three-trees-ui.umd.min.js +1 -0
  8. package/package.json +137 -0
  9. package/packages/AddQueryStrategy/index.js +7 -0
  10. package/packages/AddQueryStrategy/src/main.vue +236 -0
  11. package/packages/Autocomplete/index.js +7 -0
  12. package/packages/Autocomplete/src/main.vue +201 -0
  13. package/packages/Avatar/index.js +7 -0
  14. package/packages/Avatar/src/AvatarImage.vue +218 -0
  15. package/packages/Button/index.js +7 -0
  16. package/packages/Button/src/main.vue +90 -0
  17. package/packages/Cascader/index.js +7 -0
  18. package/packages/Cascader/src/main.vue +210 -0
  19. package/packages/Chart/index.js +7 -0
  20. package/packages/Chart/src/Chart.vue +856 -0
  21. package/packages/Checkbox/index.js +7 -0
  22. package/packages/Checkbox/src/main.vue +205 -0
  23. package/packages/Collapse/index.js +7 -0
  24. package/packages/Collapse/src/HtCollapse.vue +85 -0
  25. package/packages/Collapse/src/HtCollapseItem.vue +21 -0
  26. package/packages/CollapseItem/index.js +7 -0
  27. package/packages/CustomComponent/index.js +6 -0
  28. package/packages/CustomComponent/src/main.vue +87 -0
  29. package/packages/CustomDialog/index.js +7 -0
  30. package/packages/CustomDialog/src/customDialog.js +126 -0
  31. package/packages/CustomDialog/src/customDialog.vue +1864 -0
  32. package/packages/CustomDialog/src/customMobileDialog.vue +1619 -0
  33. package/packages/CustomDialog/src/main.vue +485 -0
  34. package/packages/DataView/index.js +7 -0
  35. package/packages/DataView/src/DataView.vue +45 -0
  36. package/packages/Date/index.js +7 -0
  37. package/packages/Date/src/main.vue +182 -0
  38. package/packages/DatePicker/index.js +7 -0
  39. package/packages/DatePicker/src/main.vue +155 -0
  40. package/packages/Demension/index.js +7 -0
  41. package/packages/Demension/src/main.vue +382 -0
  42. package/packages/Dialog/index.js +7 -0
  43. package/packages/Dialog/src/main.vue +169 -0
  44. package/packages/Dictionary/index.js +7 -0
  45. package/packages/Dictionary/src/main.vue +211 -0
  46. package/packages/DimensionSelector/index.js +7 -0
  47. package/packages/DimensionSelector/src/main.vue +526 -0
  48. package/packages/DimensionSelectorInput/index.js +7 -0
  49. package/packages/DimensionSelectorInput/src/main.vue +161 -0
  50. package/packages/Divider/index.js +7 -0
  51. package/packages/Divider/src/main.vue +38 -0
  52. package/packages/Duration/index.js +7 -0
  53. package/packages/Duration/src/main.vue +180 -0
  54. package/packages/Editor/index.js +7 -0
  55. package/packages/Editor/src/main.vue +320 -0
  56. package/packages/Explain/index.js +7 -0
  57. package/packages/Explain/src/main.vue +126 -0
  58. package/packages/FieldTail/index.js +7 -0
  59. package/packages/FieldTail/src/main.vue +188 -0
  60. package/packages/File/index.js +7 -0
  61. package/packages/File/src/FileCard.vue +169 -0
  62. package/packages/File/src/FileList.vue +180 -0
  63. package/packages/File/src/FileTable.vue +223 -0
  64. package/packages/File/src/main.vue +499 -0
  65. package/packages/FileUpload/index.js +7 -0
  66. package/packages/FileUpload/src/main.vue +242 -0
  67. package/packages/FlowChart/index.js +7 -0
  68. package/packages/FlowChart/src/main.vue +386 -0
  69. package/packages/FormItem/index.js +7 -0
  70. package/packages/FormItem/src/main.vue +175 -0
  71. package/packages/Global/index.js +12 -0
  72. package/packages/Global/src/GlobalQuery.vue +225 -0
  73. package/packages/Global/src/GlobalValidate.vue +132 -0
  74. package/packages/HistoricalApproval/index.js +7 -0
  75. package/packages/HistoricalApproval/src/main.vue +427 -0
  76. package/packages/Icon/index.js +7 -0
  77. package/packages/Icon/src/icons/ad.js +14 -0
  78. package/packages/Icon/src/icons/address-book.js +14 -0
  79. package/packages/Icon/src/icons/arrow.js +14 -0
  80. package/packages/Icon/src/icons/attachment.js +18 -0
  81. package/packages/Icon/src/icons/balance.js +14 -0
  82. package/packages/Icon/src/icons/ban.js +14 -0
  83. package/packages/Icon/src/icons/bell.js +14 -0
  84. package/packages/Icon/src/icons/block.js +26 -0
  85. package/packages/Icon/src/icons/book.js +14 -0
  86. package/packages/Icon/src/icons/bookmark.js +14 -0
  87. package/packages/Icon/src/icons/bug.js +22 -0
  88. package/packages/Icon/src/icons/bullhorn.js +14 -0
  89. package/packages/Icon/src/icons/calc.js +14 -0
  90. package/packages/Icon/src/icons/checkbox.js +14 -0
  91. package/packages/Icon/src/icons/circle.js +14 -0
  92. package/packages/Icon/src/icons/close.js +14 -0
  93. package/packages/Icon/src/icons/cloud-sun.js +14 -0
  94. package/packages/Icon/src/icons/coffee.js +14 -0
  95. package/packages/Icon/src/icons/component.js +14 -0
  96. package/packages/Icon/src/icons/compress.js +14 -0
  97. package/packages/Icon/src/icons/copyright.js +14 -0
  98. package/packages/Icon/src/icons/demension.js +18 -0
  99. package/packages/Icon/src/icons/dialog.js +14 -0
  100. package/packages/Icon/src/icons/down-unfold.js +18 -0
  101. package/packages/Icon/src/icons/download.js +14 -0
  102. package/packages/Icon/src/icons/duration.js +14 -0
  103. package/packages/Icon/src/icons/excel.js +18 -0
  104. package/packages/Icon/src/icons/expand.js +14 -0
  105. package/packages/Icon/src/icons/export.js +21 -0
  106. package/packages/Icon/src/icons/eye-slash.js +14 -0
  107. package/packages/Icon/src/icons/eye.js +14 -0
  108. package/packages/Icon/src/icons/file.js +18 -0
  109. package/packages/Icon/src/icons/form.js +14 -0
  110. package/packages/Icon/src/icons/ganged.js +14 -0
  111. package/packages/Icon/src/icons/gaode.js +27 -0
  112. package/packages/Icon/src/icons/gift.js +14 -0
  113. package/packages/Icon/src/icons/home.js +14 -0
  114. package/packages/Icon/src/icons/hotent.js +26 -0
  115. package/packages/Icon/src/icons/image.js +14 -0
  116. package/packages/Icon/src/icons/import.js +18 -0
  117. package/packages/Icon/src/icons/index.js +75 -0
  118. package/packages/Icon/src/icons/info.js +21 -0
  119. package/packages/Icon/src/icons/job.js +18 -0
  120. package/packages/Icon/src/icons/laptop.js +14 -0
  121. package/packages/Icon/src/icons/line.js +34 -0
  122. package/packages/Icon/src/icons/lock.js +14 -0
  123. package/packages/Icon/src/icons/map.js +18 -0
  124. package/packages/Icon/src/icons/more.js +19 -0
  125. package/packages/Icon/src/icons/move.js +14 -0
  126. package/packages/Icon/src/icons/org-tree.js +33 -0
  127. package/packages/Icon/src/icons/org-tree2.js +42 -0
  128. package/packages/Icon/src/icons/org.js +18 -0
  129. package/packages/Icon/src/icons/palette.js +14 -0
  130. package/packages/Icon/src/icons/plan.js +17 -0
  131. package/packages/Icon/src/icons/post.js +23 -0
  132. package/packages/Icon/src/icons/ppt.js +18 -0
  133. package/packages/Icon/src/icons/question.js +18 -0
  134. package/packages/Icon/src/icons/radio.js +14 -0
  135. package/packages/Icon/src/icons/refresh.js +14 -0
  136. package/packages/Icon/src/icons/role.js +38 -0
  137. package/packages/Icon/src/icons/search.js +14 -0
  138. package/packages/Icon/src/icons/select.js +14 -0
  139. package/packages/Icon/src/icons/setting.js +18 -0
  140. package/packages/Icon/src/icons/simple-collapse.js +18 -0
  141. package/packages/Icon/src/icons/simple-expand.js +14 -0
  142. package/packages/Icon/src/icons/sort.js +22 -0
  143. package/packages/Icon/src/icons/table.js +14 -0
  144. package/packages/Icon/src/icons/time.js +14 -0
  145. package/packages/Icon/src/icons/tree.js +14 -0
  146. package/packages/Icon/src/icons/typography.js +18 -0
  147. package/packages/Icon/src/icons/up-fold.js +18 -0
  148. package/packages/Icon/src/icons/upload.js +18 -0
  149. package/packages/Icon/src/icons/user.js +14 -0
  150. package/packages/Icon/src/icons/users.js +30 -0
  151. package/packages/Icon/src/icons/video.js +14 -0
  152. package/packages/Icon/src/icons/word.js +19 -0
  153. package/packages/Icon/src/main.vue +432 -0
  154. package/packages/Iframe/index.js +6 -0
  155. package/packages/Iframe/src/main.vue +208 -0
  156. package/packages/Image/index.js +7 -0
  157. package/packages/Image/src/main.vue +70 -0
  158. package/packages/Input/index.js +7 -0
  159. package/packages/Input/src/main.vue +659 -0
  160. package/packages/JobDialog/index.js +7 -0
  161. package/packages/JobDialog/src/main.vue +197 -0
  162. package/packages/JobSelector/index.js +7 -0
  163. package/packages/JobSelector/src/JobSelectorDialog.vue +305 -0
  164. package/packages/JobSelector/src/JobSelectorMobileDialog.vue +293 -0
  165. package/packages/JobSelector/src/main.vue +346 -0
  166. package/packages/JobSelectorInput/index.js +7 -0
  167. package/packages/JobSelectorInput/src/main.vue +166 -0
  168. package/packages/ListSelector/index.js +7 -0
  169. package/packages/ListSelector/src/ListSelector.vue +499 -0
  170. package/packages/Map/index.js +7 -0
  171. package/packages/Map/src/Map.vue +434 -0
  172. package/packages/Milepost/index.js +7 -0
  173. package/packages/Milepost/src/main.vue +45 -0
  174. package/packages/OnlineForm/index.js +7 -0
  175. package/packages/OnlineForm/src/Form.vue +659 -0
  176. package/packages/OrgPostDialog/index.js +7 -0
  177. package/packages/OrgPostDialog/src/main.vue +331 -0
  178. package/packages/OrgSelector/index.js +7 -0
  179. package/packages/OrgSelector/src/OrgSelectorDialog.vue +334 -0
  180. package/packages/OrgSelector/src/OrgSelectorMobileDialog.vue +307 -0
  181. package/packages/OrgSelector/src/Organization.vue +131 -0
  182. package/packages/OrgSelector/src/PolicyUser.vue +141 -0
  183. package/packages/OrgSelector/src/main.vue +409 -0
  184. package/packages/OrgSelectorInput/index.js +7 -0
  185. package/packages/OrgSelectorInput/src/OrgSelectorInput.vue +324 -0
  186. package/packages/PostDialog/index.js +7 -0
  187. package/packages/PostDialog/src/main.vue +309 -0
  188. package/packages/PostSelector/index.js +7 -0
  189. package/packages/PostSelector/src/Organization.vue +131 -0
  190. package/packages/PostSelector/src/PolicyUser.vue +141 -0
  191. package/packages/PostSelector/src/PostSelectorDialog.vue +342 -0
  192. package/packages/PostSelector/src/PostSelectorMobileDialog.vue +307 -0
  193. package/packages/PostSelector/src/main.vue +374 -0
  194. package/packages/PostSelectorInput/index.js +7 -0
  195. package/packages/PostSelectorInput/src/PostSelectorInput.vue +317 -0
  196. package/packages/Preview/index.js +7 -0
  197. package/packages/Preview/src/FillPage.vue +311 -0
  198. package/packages/Preview/src/FrameViewer.vue +157 -0
  199. package/packages/Preview/src/Loading.vue +126 -0
  200. package/packages/Preview/src/PdfViewer.vue +125 -0
  201. package/packages/Preview/src/TextViewer.vue +99 -0
  202. package/packages/Preview/src/main.vue +242 -0
  203. package/packages/Preview/src/watermark.js +124 -0
  204. package/packages/ProcessRecord/index.js +7 -0
  205. package/packages/ProcessRecord/src/main.vue +396 -0
  206. package/packages/Qrcode/index.js +7 -0
  207. package/packages/Qrcode/src/Qrcode.vue +110 -0
  208. package/packages/QuerySqlPreview/index.js +7 -0
  209. package/packages/QuerySqlPreview/src/QuerySqlPreview.vue +163 -0
  210. package/packages/Radio/index.js +7 -0
  211. package/packages/Radio/src/main.vue +174 -0
  212. package/packages/Rate/index.js +7 -0
  213. package/packages/Rate/src/main.vue +141 -0
  214. package/packages/ReadonlyInput/index.js +7 -0
  215. package/packages/ReadonlyInput/src/main.vue +92 -0
  216. package/packages/RelevantFlow/index.js +7 -0
  217. package/packages/RelevantFlow/src/main.vue +579 -0
  218. package/packages/RelevantFlow/src/relevantFlow.js +35 -0
  219. package/packages/RoleDialog/index.js +7 -0
  220. package/packages/RoleDialog/src/main.vue +198 -0
  221. package/packages/RoleSelector/index.js +7 -0
  222. package/packages/RoleSelector/src/RoleSelectorDialog.vue +307 -0
  223. package/packages/RoleSelector/src/RoleSelectorMobileDialog.vue +293 -0
  224. package/packages/RoleSelector/src/main.vue +367 -0
  225. package/packages/RoleSelectorInput/index.js +7 -0
  226. package/packages/RoleSelectorInput/src/main.vue +166 -0
  227. package/packages/SaveButton/index.js +7 -0
  228. package/packages/SaveButton/src/main.vue +73 -0
  229. package/packages/Select/index.js +7 -0
  230. package/packages/Select/src/main.vue +376 -0
  231. package/packages/SelectTree/index.js +7 -0
  232. package/packages/SelectTree/src/SelectTree.vue +360 -0
  233. package/packages/Selector/index.js +7 -0
  234. package/packages/Selector/src/main.vue +623 -0
  235. package/packages/SidebarDialog/index.js +7 -0
  236. package/packages/SidebarDialog/src/main.vue +156 -0
  237. package/packages/Slider/index.js +7 -0
  238. package/packages/Slider/src/main.vue +141 -0
  239. package/packages/Step/index.js +7 -0
  240. package/packages/StepLayout/index.js +7 -0
  241. package/packages/Steps/index.js +7 -0
  242. package/packages/Steps/src/Step.vue +139 -0
  243. package/packages/Steps/src/StepLayout.vue +35 -0
  244. package/packages/Steps/src/Steps.vue +65 -0
  245. package/packages/Subtable/index.js +33 -0
  246. package/packages/Subtable/src/SubDialog.vue +2145 -0
  247. package/packages/Subtable/src/SubExportDialog.vue +115 -0
  248. package/packages/Subtable/src/SubImportDialog.vue +340 -0
  249. package/packages/Subtable/src/SubPagination.vue +128 -0
  250. package/packages/Subtable/src/SubtableBackfill.vue +150 -0
  251. package/packages/Subtable/src/dialog.js +42 -0
  252. package/packages/Switch/index.js +7 -0
  253. package/packages/Switch/src/main.vue +92 -0
  254. package/packages/Table/index.js +7 -0
  255. package/packages/Table/src/CustomColumn.vue +353 -0
  256. package/packages/Table/src/Table.vue +1031 -0
  257. package/packages/TableColumn/index.js +7 -0
  258. package/packages/TableColumn/src/main.vue +189 -0
  259. package/packages/TableSearchField/index.js +7 -0
  260. package/packages/TableSearchField/src/main.vue +334 -0
  261. package/packages/TableSearchPanel/index.js +7 -0
  262. package/packages/TableSearchPanel/src/main.vue +182 -0
  263. package/packages/Tabs/index.js +7 -0
  264. package/packages/Tabs/src/Tabs.vue +140 -0
  265. package/packages/Tag/index.js +7 -0
  266. package/packages/Tag/src/main.vue +266 -0
  267. package/packages/TemplateBatchUpdate/index.js +7 -0
  268. package/packages/TemplateBatchUpdate/src/TemplateBatchUpdateDialog.vue +175 -0
  269. package/packages/TemplateForm/index.js +7 -0
  270. package/packages/TemplateForm/src/main.vue +661 -0
  271. package/packages/TemplateFormDialog/index.js +7 -0
  272. package/packages/TemplateFormDialog/src/main.vue +97 -0
  273. package/packages/TemplateIframeDialog/index.js +7 -0
  274. package/packages/TemplateIframeDialog/src/main.vue +72 -0
  275. package/packages/TemplateImportResult/index.js +7 -0
  276. package/packages/TemplateImportResult/src/main.vue +206 -0
  277. package/packages/TemplatePreview/index.js +19 -0
  278. package/packages/TemplatePreview/src/TemplatePreview.vue +239 -0
  279. package/packages/TemplatePreview/src/TemplatePreviewFile.vue +179 -0
  280. package/packages/TemplatePreview/src/TemplatePreviewImage.vue +83 -0
  281. package/packages/TemplateTaskCirculate/index.js +7 -0
  282. package/packages/TemplateTaskCirculate/src/main.vue +258 -0
  283. package/packages/Text/index.js +7 -0
  284. package/packages/Text/src/main.vue +58 -0
  285. package/packages/TimePicker/index.js +7 -0
  286. package/packages/TimePicker/src/main.vue +149 -0
  287. package/packages/TimeSelect/index.js +7 -0
  288. package/packages/TimeSelect/src/main.vue +106 -0
  289. package/packages/Tree/index.js +7 -0
  290. package/packages/Tree/src/main.vue +443 -0
  291. package/packages/TreeDialog/index.js +7 -0
  292. package/packages/TreeDialog/src/main.vue +322 -0
  293. package/packages/TreeListDialog/index.js +7 -0
  294. package/packages/TreeListDialog/src/main.vue +219 -0
  295. package/packages/Typography/index.js +8 -0
  296. package/packages/Typography/src/create-header.js +72 -0
  297. package/packages/UserDialog/index.js +7 -0
  298. package/packages/UserDialog/src/main.vue +393 -0
  299. package/packages/UserSelector/index.js +7 -0
  300. package/packages/UserSelector/src/Organization.vue +131 -0
  301. package/packages/UserSelector/src/PolicyUser.vue +141 -0
  302. package/packages/UserSelector/src/RoleUser.vue +139 -0
  303. package/packages/UserSelector/src/TopContactUser.vue +109 -0
  304. package/packages/UserSelector/src/UserSelectorDialog.vue +370 -0
  305. package/packages/UserSelector/src/UserSelectorMobileDialog.vue +332 -0
  306. package/packages/UserSelector/src/main.vue +519 -0
  307. package/packages/UserSelectorInput/index.js +7 -0
  308. package/packages/UserSelectorInput/src/main.vue +374 -0
  309. package/packages/picture/index.js +7 -0
  310. package/packages/picture/src/main.vue +736 -0
  311. package/packages/plugins/Echarts.js +30 -0
  312. package/packages/plugins/Map.js +29 -0
  313. package/packages/plugins/Preview.js +49 -0
  314. package/packages/plugins/Qrcode.js +7 -0
  315. package/packages/plugins/XLSX.js +7 -0
  316. package/packages/plugins/wangeditor.js +19 -0
  317. package/src/assets/icon_found_img.png +0 -0
  318. package/src/assets/no-data.png +0 -0
  319. package/src/assets/table-no-data.png +0 -0
  320. package/src/directive/badge.js +53 -0
  321. package/src/directive/copy.js +47 -0
  322. package/src/directive/ellipsis.js +6 -0
  323. package/src/directive/expandClick.js +23 -0
  324. package/src/directive/express.js +86 -0
  325. package/src/directive/form.js +122 -0
  326. package/src/directive/format.js +24 -0
  327. package/src/directive/formulas.js +710 -0
  328. package/src/directive/index.js +42 -0
  329. package/src/directive/permissionLine.js +59 -0
  330. package/src/directive/permissionLineLable.js +56 -0
  331. package/src/directive/permit.js +23 -0
  332. package/src/directive/popconfirm.js +86 -0
  333. package/src/directive/relatedQuery.js +61 -0
  334. package/src/directive/resize.js +18 -0
  335. package/src/directive/subSort.js +18 -0
  336. package/src/directive/tableDrag.js +25 -0
  337. package/src/directive/tooltip.js +37 -0
  338. package/src/filter/computerSize.js +23 -0
  339. package/src/filter/dateFormat.js +10 -0
  340. package/src/filter/index.js +10 -0
  341. package/src/index.js +295 -0
  342. package/src/locale/format.js +44 -0
  343. package/src/locale/index.js +48 -0
  344. package/src/locale/lang/en.js +59 -0
  345. package/src/locale/lang/zh-CN.js +59 -0
  346. package/src/locale/lang/zh-TW.js +57 -0
  347. package/src/locale/validate/dict.js +278 -0
  348. package/src/math.js +270 -0
  349. package/src/mixins/dialog.js +16 -0
  350. package/src/mixins/emitter.js +33 -0
  351. package/src/mixins/form.js +33 -0
  352. package/src/mixins/formDataUpdate.js +32 -0
  353. package/src/mixins/ganged.js +131 -0
  354. package/src/mixins/inputName.js +30 -0
  355. package/src/mixins/linkage.js +414 -0
  356. package/src/mixins/locale.js +9 -0
  357. package/src/mixins/mobileMode.js +27 -0
  358. package/src/mixins/onlineHottable.js +128 -0
  359. package/src/mixins/onlineSubtable.js +538 -0
  360. package/src/mixins/permission.js +94 -0
  361. package/src/mixins/querySqlPreview.js +852 -0
  362. package/src/mixins/regionValidator.js +70 -0
  363. package/src/mixins/script.js +37 -0
  364. package/src/mixins/templatePreview.js +4527 -0
  365. package/src/plugins/loading/index.js +37 -0
  366. package/src/plugins/loading/index.vue +18 -0
  367. package/src/service.js +336 -0
  368. package/src/services/CustomQuery.js +197 -0
  369. package/src/services/SubPagination.js +132 -0
  370. package/src/services/commonScripts.js +45 -0
  371. package/src/styles/index.scss +7 -0
  372. package/src/styles/selector.css +140 -0
  373. package/src/styles/selector.min.css +1 -0
  374. package/src/styles/selector.scss +130 -0
  375. package/src/styles/variables.css +67 -0
  376. package/src/styles/variables.min.css +1 -0
  377. package/src/styles/variables.scss +109 -0
  378. package/src/util/base64.js +46 -0
  379. package/src/util/brower.js +15 -0
  380. package/src/util/clone.js +61 -0
  381. package/src/util/path.js +4 -0
  382. package/src/util/request.js +14 -0
  383. package/src/utils.js +1242 -0
  384. package/src/validate.js +256 -0
@@ -0,0 +1,736 @@
1
+ <template>
2
+ <div
3
+ class="inputs ht-picture"
4
+ :class="[
5
+ 'inputs',
6
+ formInputsDisplay == 'block'
7
+ ? 'ht-form-inputs__block'
8
+ : 'ht-form-inputs__inline',
9
+ ]"
10
+ >
11
+ <div v-show="!!imgList.length" class="ht-picture__images">
12
+ <el-card
13
+ v-for="(item, index) of imgList"
14
+ :key="item.uid"
15
+ class="ht-picture__card"
16
+ :alt="t('ht.picture.viewOriginalImage')"
17
+ :body-style="bodyStyle"
18
+ >
19
+ <el-image
20
+ :key="index"
21
+ v-loading="loading"
22
+ :src="item.url || getCurrentImgSrc(item)"
23
+ :style="style"
24
+ :preview-src-list="srcList"
25
+ class="ht-picture__item-img"
26
+ />
27
+ <div class="ht-picture__footer">
28
+ <div class="ht-picture__name">
29
+ <template v-if="openUrl">
30
+ <a href="javascript:void(0);" @click="hrefClick()">
31
+ {{ item.name || item.fileName }}
32
+ </a>
33
+ </template>
34
+ <template v-else>
35
+ {{ item.name || item.fileName }}
36
+ </template>
37
+ </div>
38
+ <div class="ht-picture__footer-btn">
39
+ <el-button
40
+ v-if="uploadType === 'local' && downloadable"
41
+ icon="el-icon-download"
42
+ class="ht-picture__download"
43
+ circle
44
+ @click="downloadPicture(item)"
45
+ />
46
+
47
+ <el-popconfirm
48
+ v-if="inputWriteable"
49
+ :title="
50
+ t('ht.picture.deleteTip', { clear: t('ht.common.clear') })
51
+ "
52
+ @confirm="handleDelete(item)"
53
+ >
54
+ <el-button slot="reference" icon="el-icon-delete" circle />
55
+ </el-popconfirm>
56
+ </div>
57
+ </div>
58
+ </el-card>
59
+ </div>
60
+ <input
61
+ v-model="value"
62
+ v-validate="inputValidate"
63
+ type="hidden"
64
+ :name="inputName"
65
+ />
66
+ <file-upload
67
+ v-if="uploadType === 'local' && inputWriteable && !userAgentMobile"
68
+ ref="fileUpload"
69
+ v-model="inputVal"
70
+ class="ht-picture-upload"
71
+ :action-url="actionUrlVal"
72
+ :header="headerVal"
73
+ :on-success="handleSuccess"
74
+ :on-progress="onProgress"
75
+ :before-upload="beforeImgUpload"
76
+ :multiple="multiple"
77
+ :limit="limit"
78
+ :size="fileSize"
79
+ :accept="accept"
80
+ :show-file-list="false"
81
+ :with-credentials="withCredentials"
82
+ :on-exceed="handleExceed"
83
+ @clear="handleClear"
84
+ />
85
+ <ht-field-tail
86
+ :writeable.sync="inputWriteable"
87
+ :field-name="inputName"
88
+ :input-value="value"
89
+ />
90
+ <!-- 上传网络图片 -->
91
+ <el-button
92
+ v-if="uploadType == 'web' && inputWriteable"
93
+ size="mini"
94
+ round
95
+ icon="el-icon-plus"
96
+ @click="openDialog"
97
+ >
98
+ {{ t('ht.picture.uploadButtonText') }}
99
+ </el-button>
100
+
101
+ <el-popconfirm
102
+ v-if="uploadType == 'web' && inputWriteable && imgList.length"
103
+ class="pop-confirm-btn"
104
+ :title="t('ht.picture.deleteTip', { clear: t('ht.common.clear') })"
105
+ @confirm="handleClear"
106
+ >
107
+ <el-button slot="reference" icon="el-icon-delete" round size="mini">
108
+ {{ t('ht.common.clear') }}
109
+ </el-button>
110
+ </el-popconfirm>
111
+ <!-- 移动端本地图片 -->
112
+ <div
113
+ v-if="inputWriteable && uploadType === 'local' && userAgentMobile"
114
+ class="ht-picture__mobile"
115
+ >
116
+ <input
117
+ id="upload"
118
+ ref="mobilePicRef"
119
+ class="ht-picture__hide-input"
120
+ type="file"
121
+ accept="image/*"
122
+ :multiple="multiple"
123
+ @change="handlePicChange($event)"
124
+ />
125
+ <div class="camera">
126
+ <el-button
127
+ v-if="userAgentMobile && uploadType == 'local'"
128
+ size="mini"
129
+ round
130
+ icon="el-icon-plus"
131
+ @click="clickPicture"
132
+ >
133
+ {{ t('ht.picture.uploadButtonText') }}
134
+ </el-button>
135
+ <el-popconfirm
136
+ v-if="imgList.length"
137
+ class="pop-confirm-btn"
138
+ :title="t('ht.picture.deleteTip', { clear: t('ht.common.clear') })"
139
+ @confirm="handleClear"
140
+ >
141
+ <el-button slot="reference" icon="el-icon-delete" round size="mini">
142
+ {{ t('ht.common.clear') }}
143
+ </el-button>
144
+ </el-popconfirm>
145
+ </div>
146
+ </div>
147
+ <el-dialog
148
+ :visible.sync="dialogFormVisible"
149
+ :title="t('ht.picture.uploadWebImg')"
150
+ :close-on-click-modal="false"
151
+ :width="userAgentMobile ? '85%' : '50%'"
152
+ :custom-class="isMobileClass"
153
+ :append-to-body="appendToBody"
154
+ >
155
+ <el-form
156
+ ref="webImgFormRef"
157
+ :model="webImages"
158
+ data-vv-scope="webImgFrom"
159
+ >
160
+ <ht-form-item :label="t('ht.picture.imgName')" label-width="100px">
161
+ <ht-input
162
+ v-model="webImages.fileName"
163
+ style="width: 100%"
164
+ :placeholder="t('ht.picture.imgNamePlaceHolder')"
165
+ validate="required"
166
+ />
167
+ </ht-form-item>
168
+ <ht-form-item :label="t('ht.picture.imgUrl')" label-width="100px">
169
+ <ht-input
170
+ v-model="webImages.url"
171
+ style="width: 100%"
172
+ :placeholder="t('ht.picture.imgUrlPlaceHolder')"
173
+ validate="required"
174
+ />
175
+ </ht-form-item>
176
+ <div class="ht-dialog-footer">
177
+ <el-button
178
+ type="primary"
179
+ size="small"
180
+ class="submit-button"
181
+ :loading="btnLoading"
182
+ @click="handleSubmit"
183
+ >
184
+ {{ t('ht.common.confirm') }}
185
+ </el-button>
186
+ <el-button size="small" @click="dialogFormVisible = false">
187
+ {{ t('ht.common.close') }}
188
+ </el-button>
189
+ </div>
190
+ </el-form>
191
+ </el-dialog>
192
+ </div>
193
+ </template>
194
+ <script>
195
+ import permission from '@/mixins/permission.js'
196
+ import mobileMode from '@/mixins/mobileMode.js'
197
+ import locale from '@/mixins/locale.js'
198
+ import form from '@/mixins/form.js'
199
+
200
+ import fileUpload from '../../FileUpload'
201
+ import inputName from '@/mixins/inputName.js'
202
+
203
+ const { saveAs } = require('file-saver')
204
+ import { createObjectURL } from '@/util/brower.js'
205
+ import utils from '@/utils.js'
206
+ import _ from 'lodash'
207
+ import { compress } from 'image-conversion'
208
+
209
+ export default {
210
+ name: 'HtPicture',
211
+ components: {
212
+ fileUpload,
213
+ },
214
+ mixins: [permission, mobileMode, locale, inputName, form],
215
+ props: {
216
+ compress: {
217
+ type: Boolean,
218
+ default: false,
219
+ },
220
+ value: {
221
+ type: String,
222
+ },
223
+ withCredentials: {
224
+ type: Boolean,
225
+ default: false,
226
+ },
227
+ uploadType: {
228
+ type: String,
229
+ default: '',
230
+ validator: (val) => ['web', 'local'].includes(val),
231
+ },
232
+ actionUrl: {
233
+ type: String,
234
+ default: '',
235
+ },
236
+ headers: Object,
237
+ imgHeight: [String, Number],
238
+ imgWidth: [String, Number],
239
+ limit: Number,
240
+ multiple: {
241
+ type: Boolean,
242
+ default: true,
243
+ },
244
+ allowPreview: {
245
+ type: Boolean,
246
+ default: false,
247
+ },
248
+ allowDownload: {
249
+ type: Boolean,
250
+ default: false,
251
+ },
252
+ fileSize: {
253
+ type: Number,
254
+ default: 6,
255
+ },
256
+ bodyStyle: {
257
+ type: Object,
258
+ default: () => {
259
+ return {
260
+ padding: '10px',
261
+ cursor: 'pointer',
262
+ }
263
+ },
264
+ },
265
+ onProgress: Function,
266
+ openUrl: {
267
+ type: String,
268
+ default: '',
269
+ },
270
+ flowData: {
271
+ type: Object,
272
+ default: () => {
273
+ return {}
274
+ },
275
+ },
276
+ appendToBody: {
277
+ type: Boolean,
278
+ default: true,
279
+ },
280
+ },
281
+ data() {
282
+ return {
283
+ imgList: [], //上传成功展示图片列表
284
+ dialogFormVisible: false,
285
+ srcList: [], //图片预览url列表
286
+ webImages: {
287
+ fileName: '',
288
+ url: '',
289
+ },
290
+ accept: 'jpg,png,gif,ico,jpeg,GPG,PNG,GIF,JPEG',
291
+ refreshFileUploadDebounce: _.debounce(this.refreshFileUpload, 200),
292
+ loading: false,
293
+ btnLoading: false,
294
+ compressConfig: 0.3,
295
+ }
296
+ },
297
+ computed: {
298
+ inputVal: {
299
+ get() {
300
+ let imgValue = []
301
+ if (utils.isEmpty(this.value)) {
302
+ imgValue = []
303
+ } else if (this.value.constructor == String) {
304
+ imgValue = [...JSON.parse(this.value)]
305
+ }
306
+ return imgValue
307
+ },
308
+ set() {},
309
+ },
310
+ downloadable() {
311
+ return this.inputWriteable || this.allowDownload
312
+ },
313
+ preview() {
314
+ return this.inputWriteable || this.allowPreview
315
+ },
316
+ style() {
317
+ return {
318
+ width: `${this.imgWidth || ''}px`,
319
+ height: `${this.imgHeight || ''}px`,
320
+ }
321
+ },
322
+ isUpload() {
323
+ return !['r', 'n'].includes(this.permission)
324
+ },
325
+ isMobileClass() {
326
+ return this.userAgentMobile ? 'is-mobile' : 'form-dialog'
327
+ },
328
+ actionUrlVal: function() {
329
+ return this.actionUrl
330
+ ? this.actionUrl
331
+ : this.$requestConfig.uploadUrl
332
+ ? this.handlerUploadUrl
333
+ : 'https://jsonplaceholder.typicode.com/posts/'
334
+ },
335
+ handlerUploadUrl() {
336
+ const baseUrl = this.$requestConfig.uploadUrl
337
+ if (!this.flowData.defId) {
338
+ return baseUrl
339
+ }
340
+ const indexOfMark = baseUrl.indexOf('?')
341
+ if (indexOfMark == -1) {
342
+ return `${baseUrl}?defId=${this.flowData.defId}`
343
+ }
344
+ if (indexOfMark > -1 && indexOfMark == baseUrl.length - 1) {
345
+ return `${baseUrl}defId=${this.flowData.defId}`
346
+ }
347
+ if (indexOfMark > -1 && indexOfMark < baseUrl.length - 1) {
348
+ return `${baseUrl}&defId=${this.flowData.defId}`
349
+ }
350
+ return baseUrl
351
+ },
352
+ headerVal: function() {
353
+ return this.headers
354
+ ? this.headers
355
+ : this.$requestConfig.header
356
+ ? this.$requestConfig.header()
357
+ : null
358
+ },
359
+ },
360
+ watch: {
361
+ imgList: {
362
+ handler() {
363
+ this.syncSrcList()
364
+ },
365
+ deep: true,
366
+ immediate: true,
367
+ },
368
+ value(val) {
369
+ if (val) {
370
+ this.initData()
371
+ } else {
372
+ this.imgList = []
373
+ }
374
+ },
375
+ },
376
+ mounted() {
377
+ if (this.value) {
378
+ this.initData()
379
+ }
380
+ },
381
+ methods: {
382
+ initData() {
383
+ const currentImgList =
384
+ this.value.constructor == String ? JSON.parse(this.value) : this.value
385
+ if (currentImgList.constructor == Array && currentImgList.length > -1) {
386
+ this.updateImgListWithCurrentImgList(currentImgList)
387
+ }
388
+ },
389
+ // 比对原来的图片数组和现在的图片数组,如果元素相同时把原图片中url属性复制过来,避免图片反复加载。
390
+ updateImgListWithCurrentImgList(currentImgList) {
391
+ if (
392
+ !this.imgList ||
393
+ this.imgList.length == 0 ||
394
+ !currentImgList ||
395
+ currentImgList.length == 0
396
+ ) {
397
+ this.imgList = currentImgList
398
+ } else {
399
+ currentImgList.forEach((m) => {
400
+ const oldItem = this.imgList.find(
401
+ (n) =>
402
+ m.uid === n.uid ||
403
+ (m.response &&
404
+ n.response &&
405
+ m.response.fileId == n.response.fileId)
406
+ )
407
+ if (oldItem && oldItem.url) {
408
+ m.url = oldItem.url
409
+ }
410
+ })
411
+ this.imgList = currentImgList
412
+ }
413
+ },
414
+
415
+ getCurrentImgSrc(item) {
416
+ const this_ = this
417
+ if (item && item.response && item.response.fileId && !item.urlLoading) {
418
+ item.urlLoading = true
419
+ this.loading = true
420
+ this.$requestConfig
421
+ .getImgSrc(item.response.fileId)
422
+ .then((res) => {
423
+ if (res.size > 0) {
424
+ const reader = new FileReader()
425
+ reader.readAsDataURL(res)
426
+ reader.onload = function(e) {
427
+ // this_.$set(item, 'url', e.target.result)
428
+ item.url = e.target.result
429
+ delete item['urlLoading']
430
+ if (this_.imgList && this_.imgList.length > 0) {
431
+ const firstItem = this_.imgList[0]
432
+ this_.$set(this_.imgList, 0, firstItem)
433
+ this_.imgList.forEach((m) => {
434
+ // console.info([m.uid, m.url ? m.url.length : '0'])
435
+ })
436
+ this_.syncSrcList()
437
+ }
438
+ }
439
+ }
440
+ })
441
+ .finally(() => {
442
+ this.loading = false
443
+ })
444
+ }
445
+ },
446
+ syncSrcList() {
447
+ const urlList = this.imgList.map((file) => file.url)
448
+ this.srcList = this.preview ? urlList : []
449
+ },
450
+ downloadPicture(file) {
451
+ // 组件单独绑定了download事件
452
+ if (this.$options._parentListeners.download) {
453
+ this.$emit('download', file)
454
+ }
455
+ // 未绑定时触发全局download事件处理函数
456
+ else if (this.$requestConfig.download) {
457
+ this.$requestConfig
458
+ .download(file.fileId || file.response ? file.response.fileId : '')
459
+ .then(({ data, headers }) => {
460
+ // 附件下载
461
+ const fileName = decodeURIComponent(
462
+ headers['content-disposition']
463
+ .split(';')[1]
464
+ .split('filename=')[1]
465
+ )
466
+ const blob = new Blob([data])
467
+ saveAs(blob, fileName)
468
+ })
469
+ .catch((err) => {
470
+ this.$message.error(`附件下载失败:${err}`)
471
+ })
472
+ }
473
+ },
474
+ handleDelete(item) {
475
+ let currentFileList = utils.isEmpty(this.value)
476
+ ? []
477
+ : this.value.constructor == String
478
+ ? JSON.parse(this.value)
479
+ : this.value
480
+ const index = currentFileList.findIndex((file) => file.uid == item.uid)
481
+ currentFileList.splice(index, 1)
482
+ const imgListIndex = this.imgList.findIndex(
483
+ (file) => file.uid == item.uid
484
+ )
485
+ this.imgList.splice(imgListIndex, 1)
486
+ this.$emit(
487
+ 'input',
488
+ currentFileList.length > 0 ? JSON.stringify(currentFileList) : ''
489
+ )
490
+ if (this.uploadType === 'local') {
491
+ this.refreshFileUploadDebounce()
492
+ }
493
+ if (this.userAgentMobile) {
494
+ this.$refs.mobilePicRef.value = ''
495
+ }
496
+ },
497
+ handlePicChange(e) {
498
+ const imgData = [...e.target.files]
499
+ // 如果有个数限制
500
+ if (this.limit) {
501
+ let totalLength = imgData.length + this.imgList.length
502
+ if (this.limit < totalLength) {
503
+ this.$message({
504
+ type: 'warning',
505
+ message: this.t('ht.picture.limitCountTip', {
506
+ limit: this.limit,
507
+ }),
508
+ })
509
+ return
510
+ }
511
+ }
512
+ // 图片格式校验
513
+ let wrongFlag = false
514
+ imgData.forEach((item) => {
515
+ if (this.isPictureType(item.name)) {
516
+ wrongFlag = true
517
+ }
518
+ })
519
+ if (wrongFlag) {
520
+ this.toast()
521
+ return
522
+ }
523
+ imgData.forEach((item) => {
524
+ this.mobileUploadFile(item)
525
+ })
526
+ },
527
+ clickPicture() {
528
+ this.$refs.mobilePicRef.click()
529
+ },
530
+ async handleSubmit() {
531
+ let result = await this.$validator.validateAll('webImgFrom')
532
+ if (!result) {
533
+ return
534
+ }
535
+ this.btnLoading = true
536
+ if (
537
+ this.inputVal.length + 1 > this.limit ||
538
+ this.srcList.length + 1 > this.limit
539
+ ) {
540
+ this.btnLoading = false
541
+ return this.$message({
542
+ type: 'warning',
543
+ message: this.t('ht.picture.limitCountTip', { limit: this.limit }),
544
+ })
545
+ }
546
+ this.setImgList(this.webImages)
547
+ this.$emit('input', JSON.stringify(this.imgList))
548
+ this.dialogFormVisible = false
549
+ },
550
+ openDialog() {
551
+ this.dialogFormVisible = true
552
+ this.btnLoading = false
553
+ this.$nextTick(() => {
554
+ this.$refs.webImgFormRef.resetFields()
555
+ this.webImages = {
556
+ fileName: '',
557
+ url: '',
558
+ }
559
+ })
560
+ },
561
+ setImgList(files) {
562
+ this.imgList.push({
563
+ ...files,
564
+ uid: `${new Date().getTime()}_${Math.ceil(Math.random() * 10)}`,
565
+ })
566
+ },
567
+ handleSuccess(response, file, fileList) {
568
+ let url = ''
569
+ if (
570
+ (file.raw && file.raw.type && file.raw.type.indexOf('image/') > -1) ||
571
+ (!file.raw && file.type && file.type.indexOf('image/') > -1)
572
+ ) {
573
+ url = createObjectURL(file.raw ? file.raw : file)
574
+ }
575
+ this.imgList.push({ ...file, url, fileName: file.name })
576
+ this.$emit('input', JSON.stringify(fileList))
577
+ this.$emit('on-success', response, file, fileList)
578
+ this.refreshFileUploadDebounce()
579
+ },
580
+ beforeImgUpload(file) {
581
+ if (this.isPictureType(file.name)) {
582
+ this.toast()
583
+ return false
584
+ }
585
+ if (this.compress) {
586
+ return new Promise((resolve) => {
587
+ compress(
588
+ file,
589
+ this.$imageCompressConfig
590
+ ? this.$imageCompressConfig
591
+ : this.compressConfig
592
+ ).then((res) => {
593
+ resolve(res)
594
+ })
595
+ })
596
+ }
597
+ },
598
+ clearForm() {
599
+ this.webImages.fileName = ''
600
+ this.webImages.url = ''
601
+ },
602
+ isPictureType(name) {
603
+ const fileType = name.replace(/.+\./, '')
604
+ const allowedTypeArr = this.accept.split(',')
605
+ return allowedTypeArr.indexOf(fileType.toLowerCase()) === -1
606
+ },
607
+ toast() {
608
+ this.$message({
609
+ type: 'warning',
610
+ message: this.t('ht.picture.limitTypeTip'),
611
+ })
612
+ },
613
+ handleClear() {
614
+ this.imgList = []
615
+ this.srcList = []
616
+ this.$emit('input', '')
617
+ },
618
+ // 同步附件数据到上传组件
619
+ refreshFileUpload() {
620
+ this.$nextTick(() => {
621
+ this.$refs.fileUpload && this.$refs.fileUpload.reload(this.inputVal)
622
+ })
623
+ },
624
+ hrefClick() {
625
+ let url = this.openUrl
626
+ .replaceAll('${mvue}', this.$requestConfig.manageUrl)
627
+ .replaceAll('${fvue}', this.$requestConfig.frontUrl)
628
+ .replaceAll('${front}', this.$requestConfig.frontUrl)
629
+
630
+ window.open(url, '_blank')
631
+ },
632
+ // 移动端发送上传图片请求
633
+ mobileUploadFile(file) {
634
+ let formData = new FormData()
635
+ formData.append('file', file, file.name)
636
+ this.$requestConfig
637
+ .request({
638
+ url: this.actionUrlVal,
639
+ method: 'post',
640
+ data: formData,
641
+ headers: {
642
+ ...this.headerVal,
643
+ 'Content-Type': 'multipart/form-data',
644
+ },
645
+ })
646
+ .then((res) => {
647
+ if (res.success) {
648
+ // 成功之后组装数据 组装成跟pc一样格式,预览时可以服用预览
649
+ let uid = `${new Date().getTime()}_${Math.ceil(
650
+ Math.random() * 10
651
+ )}`
652
+ res.uid = uid
653
+ let fileObj = {
654
+ uid: uid,
655
+ name: file.name,
656
+ response: res,
657
+ url: createObjectURL(file),
658
+ }
659
+ this.imgList.push(fileObj)
660
+ let newCopy = JSON.parse(JSON.stringify(this.imgList))
661
+ // 传给后端需把url删除
662
+ newCopy.forEach((item) => {
663
+ delete item.url
664
+ })
665
+ this.$emit('input', JSON.stringify(newCopy))
666
+ }
667
+ })
668
+ },
669
+ handleExceed() {
670
+ this.$message({
671
+ message: this.t('ht.picture.limitCountTip', { limit: this.limit }),
672
+ type: 'warning',
673
+ })
674
+ },
675
+ },
676
+ }
677
+ </script>
678
+ <style lang="scss" scoped>
679
+ .ht-picture {
680
+ &__images {
681
+ display: flex;
682
+ flex-wrap: wrap;
683
+ margin: 10px;
684
+ }
685
+ &__card {
686
+ margin-right: 10px;
687
+ margin-bottom: 10px;
688
+ }
689
+ &__item-img {
690
+ height: 240px;
691
+ width: 260px;
692
+ border-radius: 4px;
693
+ }
694
+ &__footer {
695
+ min-height: 32px;
696
+ display: flex;
697
+ justify-content: space-between;
698
+ flex-wrap: wrap;
699
+ }
700
+ &__name {
701
+ line-height: 32px;
702
+ font-size: 12px;
703
+ }
704
+ &__hide-input {
705
+ display: none;
706
+ }
707
+ .is-mobile {
708
+ width: 84% !important;
709
+ margin-top: 30vh !important;
710
+ }
711
+ .ht-picture__download {
712
+ margin-right: 10px;
713
+ }
714
+ .pop-confirm-btn {
715
+ margin-left: 10px;
716
+ }
717
+ }
718
+ .form-dialog {
719
+ .ht-dialog-footer {
720
+ text-align: center;
721
+ .submit-button {
722
+ width: unset;
723
+ margin-right: 10px;
724
+ }
725
+ }
726
+ }
727
+ .ht-dialog-footer {
728
+ text-align: center;
729
+ }
730
+ ::v-deep {
731
+ input[type='hidden'][aria-invalid='true'] + .ht-picture-upload {
732
+ max-width: 220px;
733
+ outline: 1px solid #f56c6c;
734
+ }
735
+ }
736
+ </style>