vxe-pc-ui 3.13.11 → 3.13.13

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 (674) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +134 -134
  3. package/es/icon/style.css +1 -1
  4. package/es/style.css +1 -1
  5. package/es/style.min.css +1 -1
  6. package/es/tag/style.css +1 -3
  7. package/es/tag/style.min.css +1 -1
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/es/vxe-tag/style.css +1 -3
  11. package/es/vxe-tag/style.min.css +1 -1
  12. package/lib/components.js +2 -1
  13. package/lib/components.min.js +1 -1
  14. package/lib/drawer/index.js +2 -1
  15. package/lib/drawer/index.min.js +1 -1
  16. package/lib/icon/style/style.css +1 -1
  17. package/lib/icon/style/style.min.css +1 -1
  18. package/lib/index.common.js +2 -1
  19. package/lib/index.umd.js +7962 -8834
  20. package/lib/index.umd.min.js +1 -1
  21. package/lib/modal/index.js +2 -1
  22. package/lib/modal/index.min.js +1 -1
  23. package/lib/style.css +1 -1
  24. package/lib/style.min.css +1 -1
  25. package/lib/tag/style/style.css +1 -3
  26. package/lib/tag/style/style.min.css +1 -1
  27. package/lib/ui/index.js +1 -1
  28. package/lib/ui/index.min.js +1 -1
  29. package/lib/ui/src/log.js +1 -1
  30. package/lib/ui/src/log.min.js +1 -1
  31. package/lib/vxe-alert/index.js +2 -1
  32. package/lib/vxe-alert/index.min.js +1 -1
  33. package/lib/vxe-anchor/index.js +2 -1
  34. package/lib/vxe-anchor/index.min.js +1 -1
  35. package/lib/vxe-anchor-link/index.js +2 -1
  36. package/lib/vxe-anchor-link/index.min.js +1 -1
  37. package/lib/vxe-avatar/index.js +2 -1
  38. package/lib/vxe-avatar/index.min.js +1 -1
  39. package/lib/vxe-backtop/index.js +2 -1
  40. package/lib/vxe-backtop/index.min.js +1 -1
  41. package/lib/vxe-badge/index.js +2 -1
  42. package/lib/vxe-badge/index.min.js +1 -1
  43. package/lib/vxe-breadcrumb/index.js +2 -1
  44. package/lib/vxe-breadcrumb/index.min.js +1 -1
  45. package/lib/vxe-breadcrumb-item/index.js +2 -1
  46. package/lib/vxe-breadcrumb-item/index.min.js +1 -1
  47. package/lib/vxe-button/index.js +2 -1
  48. package/lib/vxe-button/index.min.js +1 -1
  49. package/lib/vxe-button-group/index.js +2 -1
  50. package/lib/vxe-button-group/index.min.js +1 -1
  51. package/lib/vxe-calendar/index.js +2 -1
  52. package/lib/vxe-calendar/index.min.js +1 -1
  53. package/lib/vxe-card/index.js +2 -1
  54. package/lib/vxe-card/index.min.js +1 -1
  55. package/lib/vxe-carousel/index.js +2 -1
  56. package/lib/vxe-carousel/index.min.js +1 -1
  57. package/lib/vxe-carousel-item/index.js +2 -1
  58. package/lib/vxe-carousel-item/index.min.js +1 -1
  59. package/lib/vxe-cascader/index.js +2 -1
  60. package/lib/vxe-cascader/index.min.js +1 -1
  61. package/lib/vxe-checkbox/index.js +2 -1
  62. package/lib/vxe-checkbox/index.min.js +1 -1
  63. package/lib/vxe-checkbox-button/index.js +2 -1
  64. package/lib/vxe-checkbox-button/index.min.js +1 -1
  65. package/lib/vxe-checkbox-group/index.js +2 -1
  66. package/lib/vxe-checkbox-group/index.min.js +1 -1
  67. package/lib/vxe-col/index.js +2 -1
  68. package/lib/vxe-col/index.min.js +1 -1
  69. package/lib/vxe-collapse/index.js +2 -1
  70. package/lib/vxe-collapse/index.min.js +1 -1
  71. package/lib/vxe-collapse-pane/index.js +2 -1
  72. package/lib/vxe-collapse-pane/index.min.js +1 -1
  73. package/lib/vxe-color-picker/index.js +2 -1
  74. package/lib/vxe-color-picker/index.min.js +1 -1
  75. package/lib/vxe-context-menu/index.js +2 -1
  76. package/lib/vxe-context-menu/index.min.js +1 -1
  77. package/lib/vxe-countdown/index.js +2 -1
  78. package/lib/vxe-countdown/index.min.js +1 -1
  79. package/lib/vxe-date-panel/index.js +2 -1
  80. package/lib/vxe-date-panel/index.min.js +1 -1
  81. package/lib/vxe-date-picker/index.js +2 -1
  82. package/lib/vxe-date-picker/index.min.js +1 -1
  83. package/lib/vxe-date-range-picker/index.js +2 -1
  84. package/lib/vxe-date-range-picker/index.min.js +1 -1
  85. package/lib/vxe-drawer/index.js +2 -1
  86. package/lib/vxe-drawer/index.min.js +1 -1
  87. package/lib/vxe-empty/index.js +2 -1
  88. package/lib/vxe-empty/index.min.js +1 -1
  89. package/lib/vxe-form/index.js +2 -1
  90. package/lib/vxe-form/index.min.js +1 -1
  91. package/lib/vxe-form-gather/index.js +2 -1
  92. package/lib/vxe-form-gather/index.min.js +1 -1
  93. package/lib/vxe-form-group/index.js +2 -1
  94. package/lib/vxe-form-group/index.min.js +1 -1
  95. package/lib/vxe-form-item/index.js +2 -1
  96. package/lib/vxe-form-item/index.min.js +1 -1
  97. package/lib/vxe-icon/index.js +2 -1
  98. package/lib/vxe-icon/index.min.js +1 -1
  99. package/lib/vxe-icon-picker/index.js +2 -1
  100. package/lib/vxe-icon-picker/index.min.js +1 -1
  101. package/lib/vxe-image/index.js +2 -1
  102. package/lib/vxe-image/index.min.js +1 -1
  103. package/lib/vxe-image-group/index.js +2 -1
  104. package/lib/vxe-image-group/index.min.js +1 -1
  105. package/lib/vxe-image-preview/index.js +2 -1
  106. package/lib/vxe-image-preview/index.min.js +1 -1
  107. package/lib/vxe-input/index.js +2 -1
  108. package/lib/vxe-input/index.min.js +1 -1
  109. package/lib/vxe-layout-aside/index.js +2 -1
  110. package/lib/vxe-layout-aside/index.min.js +1 -1
  111. package/lib/vxe-layout-body/index.js +2 -1
  112. package/lib/vxe-layout-body/index.min.js +1 -1
  113. package/lib/vxe-layout-container/index.js +2 -1
  114. package/lib/vxe-layout-container/index.min.js +1 -1
  115. package/lib/vxe-layout-footer/index.js +2 -1
  116. package/lib/vxe-layout-footer/index.min.js +1 -1
  117. package/lib/vxe-layout-header/index.js +2 -1
  118. package/lib/vxe-layout-header/index.min.js +1 -1
  119. package/lib/vxe-link/index.js +2 -1
  120. package/lib/vxe-link/index.min.js +1 -1
  121. package/lib/vxe-list/index.js +2 -1
  122. package/lib/vxe-list/index.min.js +1 -1
  123. package/lib/vxe-loading/index.js +2 -1
  124. package/lib/vxe-loading/index.min.js +1 -1
  125. package/lib/vxe-mention/index.js +2 -1
  126. package/lib/vxe-mention/index.min.js +1 -1
  127. package/lib/vxe-menu/index.js +2 -1
  128. package/lib/vxe-menu/index.min.js +1 -1
  129. package/lib/vxe-modal/index.js +2 -1
  130. package/lib/vxe-modal/index.min.js +1 -1
  131. package/lib/vxe-notice-bar/index.js +2 -1
  132. package/lib/vxe-notice-bar/index.min.js +1 -1
  133. package/lib/vxe-number-input/index.js +2 -1
  134. package/lib/vxe-number-input/index.min.js +1 -1
  135. package/lib/vxe-optgroup/index.js +2 -1
  136. package/lib/vxe-optgroup/index.min.js +1 -1
  137. package/lib/vxe-option/index.js +2 -1
  138. package/lib/vxe-option/index.min.js +1 -1
  139. package/lib/vxe-pager/index.js +2 -1
  140. package/lib/vxe-pager/index.min.js +1 -1
  141. package/lib/vxe-password-input/index.js +2 -1
  142. package/lib/vxe-password-input/index.min.js +1 -1
  143. package/lib/vxe-print/index.js +2 -1
  144. package/lib/vxe-print/index.min.js +1 -1
  145. package/lib/vxe-print-page-break/index.js +2 -1
  146. package/lib/vxe-print-page-break/index.min.js +1 -1
  147. package/lib/vxe-pulldown/index.js +2 -1
  148. package/lib/vxe-pulldown/index.min.js +1 -1
  149. package/lib/vxe-radio/index.js +2 -1
  150. package/lib/vxe-radio/index.min.js +1 -1
  151. package/lib/vxe-radio-button/index.js +2 -1
  152. package/lib/vxe-radio-button/index.min.js +1 -1
  153. package/lib/vxe-radio-group/index.js +2 -1
  154. package/lib/vxe-radio-group/index.min.js +1 -1
  155. package/lib/vxe-rate/index.js +2 -1
  156. package/lib/vxe-rate/index.min.js +1 -1
  157. package/lib/vxe-result/index.js +2 -1
  158. package/lib/vxe-result/index.min.js +1 -1
  159. package/lib/vxe-row/index.js +2 -1
  160. package/lib/vxe-row/index.min.js +1 -1
  161. package/lib/vxe-segmented/index.js +2 -1
  162. package/lib/vxe-segmented/index.min.js +1 -1
  163. package/lib/vxe-select/index.js +2 -1
  164. package/lib/vxe-select/index.min.js +1 -1
  165. package/lib/vxe-slider/index.js +2 -1
  166. package/lib/vxe-slider/index.min.js +1 -1
  167. package/lib/vxe-split/index.js +2 -1
  168. package/lib/vxe-split/index.min.js +1 -1
  169. package/lib/vxe-split-pane/index.js +2 -1
  170. package/lib/vxe-split-pane/index.min.js +1 -1
  171. package/lib/vxe-splitter/index.js +2 -1
  172. package/lib/vxe-splitter/index.min.js +1 -1
  173. package/lib/vxe-splitter-panel/index.js +2 -1
  174. package/lib/vxe-splitter-panel/index.min.js +1 -1
  175. package/lib/vxe-steps/index.js +2 -1
  176. package/lib/vxe-steps/index.min.js +1 -1
  177. package/lib/vxe-switch/index.js +2 -1
  178. package/lib/vxe-switch/index.min.js +1 -1
  179. package/lib/vxe-tab-pane/index.js +2 -1
  180. package/lib/vxe-tab-pane/index.min.js +1 -1
  181. package/lib/vxe-table-select/index.js +2 -1
  182. package/lib/vxe-table-select/index.min.js +1 -1
  183. package/lib/vxe-tabs/index.js +2 -1
  184. package/lib/vxe-tabs/index.min.js +1 -1
  185. package/lib/vxe-tag/index.js +2 -1
  186. package/lib/vxe-tag/index.min.js +1 -1
  187. package/lib/vxe-tag/style/style.css +1 -3
  188. package/lib/vxe-tag/style/style.min.css +1 -1
  189. package/lib/vxe-text/index.js +2 -1
  190. package/lib/vxe-text/index.min.js +1 -1
  191. package/lib/vxe-text-ellipsis/index.js +2 -1
  192. package/lib/vxe-text-ellipsis/index.min.js +1 -1
  193. package/lib/vxe-textarea/index.js +2 -1
  194. package/lib/vxe-textarea/index.min.js +1 -1
  195. package/lib/vxe-timeline/index.js +2 -1
  196. package/lib/vxe-timeline/index.min.js +1 -1
  197. package/lib/vxe-timeline-item/index.js +2 -1
  198. package/lib/vxe-timeline-item/index.min.js +1 -1
  199. package/lib/vxe-tip/index.js +2 -1
  200. package/lib/vxe-tip/index.min.js +1 -1
  201. package/lib/vxe-tooltip/index.js +2 -1
  202. package/lib/vxe-tooltip/index.min.js +1 -1
  203. package/lib/vxe-tour/index.js +2 -1
  204. package/lib/vxe-tour/index.min.js +1 -1
  205. package/lib/vxe-tree/index.js +2 -1
  206. package/lib/vxe-tree/index.min.js +1 -1
  207. package/lib/vxe-tree-select/index.js +2 -1
  208. package/lib/vxe-tree-select/index.min.js +1 -1
  209. package/lib/vxe-u-i/index.js +2 -1
  210. package/lib/vxe-u-i/index.min.js +1 -1
  211. package/lib/vxe-ui/index.js +2 -1
  212. package/lib/vxe-ui/index.min.js +1 -1
  213. package/lib/vxe-upload/index.js +2 -1
  214. package/lib/vxe-upload/index.min.js +1 -1
  215. package/lib/vxe-watermark/index.js +2 -1
  216. package/lib/vxe-watermark/index.min.js +1 -1
  217. package/package.json +89 -89
  218. package/packages/alert/index.ts +16 -16
  219. package/packages/alert/src/alert.ts +106 -106
  220. package/packages/anchor/index.ts +16 -16
  221. package/packages/anchor/src/anchor-link.ts +158 -158
  222. package/packages/anchor/src/anchor.ts +267 -267
  223. package/packages/anchor/src/util.ts +23 -23
  224. package/packages/anchor-link/index.ts +16 -16
  225. package/packages/avatar/index.ts +16 -16
  226. package/packages/avatar/src/avatar.ts +141 -141
  227. package/packages/backtop/index.ts +16 -16
  228. package/packages/backtop/src/backtop.ts +330 -330
  229. package/packages/badge/index.ts +16 -16
  230. package/packages/badge/src/badge.ts +87 -87
  231. package/packages/breadcrumb/index.ts +16 -16
  232. package/packages/breadcrumb/src/breadcrumb-item.ts +118 -118
  233. package/packages/breadcrumb/src/breadcrumb.ts +89 -89
  234. package/packages/breadcrumb-item/index.ts +16 -16
  235. package/packages/button/index.ts +16 -16
  236. package/packages/button/src/button-group.ts +113 -113
  237. package/packages/button/src/button.ts +955 -955
  238. package/packages/button-group/index.ts +16 -16
  239. package/packages/calendar/index.ts +16 -16
  240. package/packages/calendar/src/calendar.ts +1527 -1527
  241. package/packages/card/index.ts +16 -16
  242. package/packages/card/src/card.ts +162 -162
  243. package/packages/carousel/index.ts +16 -16
  244. package/packages/carousel/src/carousel-item.ts +117 -117
  245. package/packages/carousel/src/carousel.ts +460 -460
  246. package/packages/carousel/src/util.ts +21 -21
  247. package/packages/carousel-item/index.ts +16 -16
  248. package/packages/cascader/index.ts +16 -16
  249. package/packages/cascader/src/cascader.ts +941 -941
  250. package/packages/checkbox/index.ts +16 -16
  251. package/packages/checkbox/src/button.ts +185 -185
  252. package/packages/checkbox/src/checkbox.ts +189 -189
  253. package/packages/checkbox/src/group.ts +259 -259
  254. package/packages/checkbox-button/index.ts +16 -16
  255. package/packages/checkbox-group/index.ts +16 -16
  256. package/packages/col/index.ts +16 -16
  257. package/packages/collapse/index.ts +16 -16
  258. package/packages/collapse/src/collapse-pane.ts +136 -136
  259. package/packages/collapse/src/collapse.ts +259 -259
  260. package/packages/collapse/src/util.ts +21 -21
  261. package/packages/collapse-pane/index.ts +16 -16
  262. package/packages/color-picker/index.ts +16 -16
  263. package/packages/color-picker/src/color-picker.ts +1277 -1277
  264. package/packages/color-picker/src/util.ts +198 -198
  265. package/packages/components.ts +307 -307
  266. package/packages/context-menu/index.ts +54 -54
  267. package/packages/context-menu/src/context-menu.ts +709 -709
  268. package/packages/countdown/index.ts +16 -16
  269. package/packages/countdown/src/countdown.ts +276 -276
  270. package/packages/date-panel/index.ts +16 -16
  271. package/packages/date-panel/src/date-panel.ts +2024 -2024
  272. package/packages/date-panel/src/util.ts +244 -244
  273. package/packages/date-picker/index.ts +17 -17
  274. package/packages/date-picker/src/date-picker.ts +1238 -1238
  275. package/packages/date-range-picker/index.ts +16 -16
  276. package/packages/date-range-picker/src/date-range-picker.ts +1466 -1466
  277. package/packages/drawer/index.ts +87 -87
  278. package/packages/drawer/src/drawer.ts +767 -767
  279. package/packages/dynamics/index.ts +125 -125
  280. package/packages/empty/index.ts +16 -16
  281. package/packages/empty/src/empty.ts +80 -80
  282. package/packages/form/index.ts +16 -16
  283. package/packages/form/render/index.ts +617 -617
  284. package/packages/form/src/form-config-item.ts +86 -86
  285. package/packages/form/src/form-group.ts +125 -125
  286. package/packages/form/src/form-item.ts +217 -217
  287. package/packages/form/src/form.ts +1032 -1032
  288. package/packages/form/src/itemInfo.ts +80 -80
  289. package/packages/form/src/render.ts +398 -398
  290. package/packages/form/src/util.ts +92 -92
  291. package/packages/form-gather/index.ts +18 -18
  292. package/packages/form-group/index.ts +16 -16
  293. package/packages/form-item/index.ts +16 -16
  294. package/packages/icon/index.ts +16 -16
  295. package/packages/icon/src/icon.ts +75 -75
  296. package/packages/icon-picker/index.ts +16 -16
  297. package/packages/icon-picker/src/icon-picker.ts +752 -752
  298. package/packages/image/index.ts +16 -16
  299. package/packages/image/src/group.ts +162 -162
  300. package/packages/image/src/image.ts +286 -286
  301. package/packages/image/src/preview.ts +737 -737
  302. package/packages/image/src/util.ts +62 -62
  303. package/packages/image-group/index.ts +16 -16
  304. package/packages/image-preview/index.ts +19 -19
  305. package/packages/index.ts +8 -8
  306. package/packages/input/index.ts +16 -16
  307. package/packages/input/src/input.ts +3187 -3187
  308. package/packages/language/ar-EG.ts +832 -832
  309. package/packages/language/de-DE.ts +832 -832
  310. package/packages/language/en-US.ts +832 -832
  311. package/packages/language/es-ES.ts +832 -832
  312. package/packages/language/fr-FR.ts +832 -832
  313. package/packages/language/hu-HU.ts +832 -832
  314. package/packages/language/hy-AM.ts +832 -832
  315. package/packages/language/id-ID.ts +832 -832
  316. package/packages/language/it-IT.ts +832 -832
  317. package/packages/language/ja-JP.ts +832 -832
  318. package/packages/language/ko-KR.ts +832 -832
  319. package/packages/language/ms-MY.ts +832 -832
  320. package/packages/language/nb-NO.ts +832 -832
  321. package/packages/language/pt-BR.ts +832 -832
  322. package/packages/language/ru-RU.ts +832 -832
  323. package/packages/language/th-TH.ts +832 -832
  324. package/packages/language/ug-CN.ts +832 -832
  325. package/packages/language/uk-UA.ts +832 -832
  326. package/packages/language/uz-UZ.ts +832 -832
  327. package/packages/language/vi-VN.ts +832 -832
  328. package/packages/language/zh-CHT.ts +832 -832
  329. package/packages/language/zh-CN.ts +832 -832
  330. package/packages/language/zh-HK.ts +3 -3
  331. package/packages/language/zh-MO.ts +3 -3
  332. package/packages/language/zh-TC.ts +3 -3
  333. package/packages/language/zh-TW.ts +3 -3
  334. package/packages/layout-aside/index.ts +16 -16
  335. package/packages/layout-aside/src/layout-aside.ts +115 -115
  336. package/packages/layout-body/index.ts +16 -16
  337. package/packages/layout-body/src/layout-body.ts +137 -137
  338. package/packages/layout-container/index.ts +16 -16
  339. package/packages/layout-container/src/layout-container.ts +65 -65
  340. package/packages/layout-footer/index.ts +16 -16
  341. package/packages/layout-footer/src/layout-footer.ts +53 -53
  342. package/packages/layout-header/index.ts +16 -16
  343. package/packages/layout-header/src/layout-header.ts +49 -49
  344. package/packages/link/index.ts +16 -16
  345. package/packages/link/src/link.ts +153 -153
  346. package/packages/list/index.ts +16 -16
  347. package/packages/list/src/list.ts +492 -492
  348. package/packages/loading/index.ts +34 -34
  349. package/packages/loading/src/loading.ts +162 -162
  350. package/packages/mention/index.ts +16 -16
  351. package/packages/mention/src/mention.ts +54 -54
  352. package/packages/menu/index.ts +16 -16
  353. package/packages/menu/src/menu.ts +632 -632
  354. package/packages/modal/index.ts +150 -150
  355. package/packages/modal/src/modal.ts +1657 -1657
  356. package/packages/notice-bar/index.ts +16 -16
  357. package/packages/notice-bar/src/notice-bar.ts +182 -182
  358. package/packages/number-input/index.ts +16 -16
  359. package/packages/number-input/src/number-input.ts +1255 -1255
  360. package/packages/number-input/src/util.ts +12 -12
  361. package/packages/optgroup/index.ts +16 -16
  362. package/packages/option/index.ts +16 -16
  363. package/packages/pager/index.ts +16 -16
  364. package/packages/pager/src/pager.ts +913 -913
  365. package/packages/password-input/index.ts +16 -16
  366. package/packages/password-input/src/password-input.ts +466 -466
  367. package/packages/print/index.ts +18 -18
  368. package/packages/print/src/page-break.ts +78 -78
  369. package/packages/print/src/print.ts +266 -266
  370. package/packages/print/src/util.ts +284 -284
  371. package/packages/print-page-break/index.ts +14 -14
  372. package/packages/pulldown/index.ts +16 -16
  373. package/packages/pulldown/src/pulldown.ts +532 -532
  374. package/packages/radio/index.ts +16 -16
  375. package/packages/radio/src/button.ts +221 -221
  376. package/packages/radio/src/group.ts +252 -252
  377. package/packages/radio/src/radio.ts +228 -228
  378. package/packages/radio-button/index.ts +16 -16
  379. package/packages/radio-group/index.ts +16 -16
  380. package/packages/rate/index.ts +16 -16
  381. package/packages/rate/src/rate.ts +199 -199
  382. package/packages/result/index.ts +16 -16
  383. package/packages/result/src/result.ts +93 -93
  384. package/packages/row/index.ts +16 -16
  385. package/packages/row/src/col.ts +130 -130
  386. package/packages/row/src/row.ts +106 -106
  387. package/packages/segmented/index.ts +16 -16
  388. package/packages/segmented/src/segmented.ts +281 -281
  389. package/packages/select/index.ts +16 -16
  390. package/packages/select/src/optgroup.ts +107 -107
  391. package/packages/select/src/option-info.ts +20 -20
  392. package/packages/select/src/option.ts +103 -103
  393. package/packages/select/src/select.ts +2000 -2000
  394. package/packages/select/src/util.ts +47 -47
  395. package/packages/slider/index.ts +16 -16
  396. package/packages/slider/src/slider.ts +332 -332
  397. package/packages/split/index.ts +16 -16
  398. package/packages/split-pane/index.ts +17 -17
  399. package/packages/splitter/index.ts +16 -16
  400. package/packages/splitter/src/splitter-panel.ts +171 -171
  401. package/packages/splitter/src/splitter.ts +1032 -1032
  402. package/packages/splitter/src/util.ts +21 -21
  403. package/packages/splitter-panel/index.ts +16 -16
  404. package/packages/steps/index.ts +16 -16
  405. package/packages/steps/src/steps.ts +57 -57
  406. package/packages/switch/index.ts +16 -16
  407. package/packages/switch/src/switch.ts +279 -279
  408. package/packages/tab-pane/index.ts +16 -16
  409. package/packages/table-select/index.ts +16 -16
  410. package/packages/table-select/src/table-select.ts +903 -903
  411. package/packages/tabs/index.ts +16 -16
  412. package/packages/tabs/src/tab-pane.ts +137 -137
  413. package/packages/tabs/src/tabs.ts +1014 -1014
  414. package/packages/tabs/src/util.ts +21 -21
  415. package/packages/tag/index.ts +16 -16
  416. package/packages/tag/src/tag.ts +195 -195
  417. package/packages/text/index.ts +16 -16
  418. package/packages/text/src/text.ts +267 -267
  419. package/packages/text-ellipsis/index.ts +16 -16
  420. package/packages/text-ellipsis/src/text-ellipsis.ts +291 -291
  421. package/packages/textarea/index.ts +16 -16
  422. package/packages/textarea/src/textarea.ts +436 -436
  423. package/packages/timeline/index.ts +16 -16
  424. package/packages/timeline/src/timeline-item.ts +41 -41
  425. package/packages/timeline/src/timeline.ts +54 -54
  426. package/packages/timeline-item/index.ts +16 -16
  427. package/packages/tip/index.ts +19 -19
  428. package/packages/tip/src/tip.ts +112 -112
  429. package/packages/tooltip/index.ts +16 -16
  430. package/packages/tooltip/src/tooltip.ts +641 -641
  431. package/packages/tour/index.ts +16 -16
  432. package/packages/tour/src/tour.ts +54 -54
  433. package/packages/tree/index.ts +16 -16
  434. package/packages/tree/src/store.ts +15 -15
  435. package/packages/tree/src/tree.ts +3080 -3080
  436. package/packages/tree/src/util.ts +44 -44
  437. package/packages/tree-select/index.ts +16 -16
  438. package/packages/tree-select/src/tree-select.ts +1115 -1115
  439. package/packages/ui/index.ts +695 -695
  440. package/packages/ui/src/anime.ts +52 -52
  441. package/packages/ui/src/comp.ts +3 -3
  442. package/packages/ui/src/dom.ts +263 -263
  443. package/packages/ui/src/log.ts +6 -6
  444. package/packages/ui/src/utils.ts +49 -49
  445. package/packages/ui/src/vn.ts +60 -60
  446. package/packages/upload/index.ts +20 -20
  447. package/packages/upload/src/upload.ts +2127 -2127
  448. package/packages/upload/src/util.ts +109 -109
  449. package/packages/vxe-u-i/index.ts +4 -4
  450. package/packages/watermark/index.ts +31 -31
  451. package/packages/watermark/src/util.ts +176 -176
  452. package/packages/watermark/src/watermark.ts +166 -166
  453. package/styles/all.scss +90 -90
  454. package/styles/base.scss +16 -16
  455. package/styles/components/alert.scss +101 -101
  456. package/styles/components/anchor.scss +44 -44
  457. package/styles/components/avatar.scss +115 -115
  458. package/styles/components/backtop.scss +82 -82
  459. package/styles/components/badge.scss +45 -45
  460. package/styles/components/breadcrumb.scss +29 -29
  461. package/styles/components/button-group.scss +30 -30
  462. package/styles/components/button.scss +415 -415
  463. package/styles/components/calendar.scss +471 -471
  464. package/styles/components/card.scss +121 -121
  465. package/styles/components/carousel.scss +184 -184
  466. package/styles/components/cascader.scss +140 -140
  467. package/styles/components/checkbox-button.scss +57 -57
  468. package/styles/components/checkbox.scss +81 -81
  469. package/styles/components/collapse.scss +56 -56
  470. package/styles/components/color-picker.scss +409 -409
  471. package/styles/components/context-menu.scss +102 -102
  472. package/styles/components/countdown.scss +35 -35
  473. package/styles/components/date-panel.scss +505 -505
  474. package/styles/components/date-picker.scss +247 -247
  475. package/styles/components/date-range-picker.scss +252 -252
  476. package/styles/components/drawer.scss +298 -298
  477. package/styles/components/empty.scss +79 -79
  478. package/styles/components/form.scss +668 -668
  479. package/styles/components/icon-picker.scss +211 -211
  480. package/styles/components/icon.scss +1044 -1044
  481. package/styles/components/image-group.scss +2 -2
  482. package/styles/components/image-preview.scss +215 -215
  483. package/styles/components/image.scss +16 -16
  484. package/styles/components/input.scss +846 -846
  485. package/styles/components/layout-aside.scss +22 -22
  486. package/styles/components/layout-body.scss +14 -14
  487. package/styles/components/layout-container.scss +13 -13
  488. package/styles/components/layout-footer.scss +14 -14
  489. package/styles/components/layout-header.scss +11 -11
  490. package/styles/components/link.scss +115 -115
  491. package/styles/components/list.scss +40 -40
  492. package/styles/components/loading.scss +137 -137
  493. package/styles/components/menu.scss +150 -150
  494. package/styles/components/modal.scss +480 -480
  495. package/styles/components/notice-bar.scss +91 -91
  496. package/styles/components/number-input.scss +283 -283
  497. package/styles/components/old-icon.scss +4 -4
  498. package/styles/components/pager.scss +282 -282
  499. package/styles/components/password-input.scss +374 -374
  500. package/styles/components/print.scss +3 -3
  501. package/styles/components/pulldown.scss +75 -75
  502. package/styles/components/radio-button.scss +57 -57
  503. package/styles/components/radio.scss +79 -79
  504. package/styles/components/rate.scss +76 -76
  505. package/styles/components/result.scss +91 -91
  506. package/styles/components/row.scss +69 -69
  507. package/styles/components/segmented.scss +215 -215
  508. package/styles/components/select.scss +244 -244
  509. package/styles/components/slider.scss +139 -139
  510. package/styles/components/split.scss +1 -1
  511. package/styles/components/splitter.scss +318 -318
  512. package/styles/components/switch.scss +128 -128
  513. package/styles/components/table-select.scss +105 -105
  514. package/styles/components/tabs.scss +745 -745
  515. package/styles/components/tag.scss +184 -184
  516. package/styles/components/text-ellipsis.scss +130 -130
  517. package/styles/components/text.scss +123 -123
  518. package/styles/components/textarea.scss +106 -106
  519. package/styles/components/tip.scss +97 -97
  520. package/styles/components/tooltip.scss +140 -140
  521. package/styles/components/tree-select.scss +166 -166
  522. package/styles/components/tree.scss +294 -294
  523. package/styles/components/upload.scss +497 -497
  524. package/styles/components/watermark.scss +26 -26
  525. package/styles/helpers/baseMixin.scss +95 -95
  526. package/styles/helpers/baseVar.scss +3 -3
  527. package/styles/helpers/placement.scss +38 -38
  528. package/styles/theme/base.scss +214 -214
  529. package/styles/theme/dark.scss +119 -119
  530. package/styles/theme/light.scss +118 -118
  531. package/styles/variable.scss +111 -111
  532. package/types/all.d.ts +328 -328
  533. package/types/components/alert.d.ts +80 -80
  534. package/types/components/anchor-link.d.ts +84 -84
  535. package/types/components/anchor.d.ts +84 -84
  536. package/types/components/avatar.d.ts +81 -81
  537. package/types/components/backtop.d.ts +115 -115
  538. package/types/components/badge.d.ts +69 -69
  539. package/types/components/breadcrumb-item.d.ts +73 -73
  540. package/types/components/breadcrumb.d.ts +80 -80
  541. package/types/components/button-group.d.ts +113 -113
  542. package/types/components/button.d.ts +314 -314
  543. package/types/components/calendar.d.ts +254 -254
  544. package/types/components/card.d.ts +86 -86
  545. package/types/components/carousel-item.d.ts +68 -68
  546. package/types/components/carousel.d.ts +126 -126
  547. package/types/components/cascader.d.ts +242 -242
  548. package/types/components/checkbox-button.d.ts +93 -93
  549. package/types/components/checkbox-group.d.ts +135 -135
  550. package/types/components/checkbox.d.ts +115 -115
  551. package/types/components/col.d.ts +73 -73
  552. package/types/components/colgroup.d.ts +131 -131
  553. package/types/components/collapse-pane.d.ts +82 -82
  554. package/types/components/collapse.d.ts +115 -115
  555. package/types/components/color-picker.d.ts +127 -127
  556. package/types/components/column.d.ts +852 -852
  557. package/types/components/context-menu.d.ts +300 -300
  558. package/types/components/countdown.d.ts +99 -99
  559. package/types/components/date-panel.d.ts +269 -269
  560. package/types/components/date-picker.d.ts +302 -302
  561. package/types/components/date-range-picker.d.ts +316 -316
  562. package/types/components/drawer.d.ts +295 -295
  563. package/types/components/empty.d.ts +71 -71
  564. package/types/components/flow-design.d.ts +78 -78
  565. package/types/components/flow-view.d.ts +78 -78
  566. package/types/components/form-design.d.ts +364 -364
  567. package/types/components/form-gather.d.ts +72 -72
  568. package/types/components/form-group.d.ts +63 -63
  569. package/types/components/form-item.d.ts +405 -405
  570. package/types/components/form-view.d.ts +175 -175
  571. package/types/components/form.d.ts +463 -463
  572. package/types/components/gantt-module/gantt-view.d.ts +170 -170
  573. package/types/components/gantt-module/index.d.ts +1 -1
  574. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +114 -114
  575. package/types/components/gantt-plugins/index.d.ts +1 -1
  576. package/types/components/gantt.d.ts +1129 -1129
  577. package/types/components/grid.d.ts +1030 -1030
  578. package/types/components/icon-picker.d.ts +181 -181
  579. package/types/components/icon.d.ts +80 -80
  580. package/types/components/image-group.d.ts +120 -120
  581. package/types/components/image-preview.d.ts +159 -159
  582. package/types/components/image.d.ts +158 -158
  583. package/types/components/input.d.ts +425 -425
  584. package/types/components/layout-aside.d.ts +73 -73
  585. package/types/components/layout-body.d.ts +84 -84
  586. package/types/components/layout-container.d.ts +66 -66
  587. package/types/components/layout-footer.d.ts +66 -66
  588. package/types/components/layout-header.d.ts +64 -64
  589. package/types/components/link.d.ts +104 -104
  590. package/types/components/list-design.d.ts +177 -177
  591. package/types/components/list-view.d.ts +190 -190
  592. package/types/components/list.d.ts +196 -196
  593. package/types/components/loading.d.ts +96 -96
  594. package/types/components/mention.d.ts +70 -70
  595. package/types/components/menu.d.ts +203 -203
  596. package/types/components/modal.d.ts +540 -540
  597. package/types/components/notice-bar.d.ts +95 -95
  598. package/types/components/number-input.d.ts +300 -300
  599. package/types/components/optgroup.d.ts +81 -81
  600. package/types/components/option.d.ts +95 -95
  601. package/types/components/pager.d.ts +322 -322
  602. package/types/components/password-input.d.ts +129 -129
  603. package/types/components/print-page-break.d.ts +62 -62
  604. package/types/components/print.d.ts +199 -199
  605. package/types/components/pulldown.d.ts +222 -222
  606. package/types/components/radio-button.d.ts +104 -104
  607. package/types/components/radio-group.d.ts +136 -136
  608. package/types/components/radio.d.ts +121 -121
  609. package/types/components/rate.d.ts +75 -75
  610. package/types/components/result.d.ts +77 -77
  611. package/types/components/row.d.ts +72 -72
  612. package/types/components/segmented.d.ts +117 -117
  613. package/types/components/select.d.ts +515 -515
  614. package/types/components/slider.d.ts +117 -117
  615. package/types/components/split-pane.d.ts +135 -135
  616. package/types/components/split.d.ts +318 -318
  617. package/types/components/splitter-panel.d.ts +98 -98
  618. package/types/components/splitter.d.ts +283 -283
  619. package/types/components/steps.d.ts +61 -61
  620. package/types/components/switch.d.ts +124 -124
  621. package/types/components/tab-pane.d.ts +107 -107
  622. package/types/components/table-module/custom.d.ts +111 -111
  623. package/types/components/table-module/edit.d.ts +244 -244
  624. package/types/components/table-module/export.d.ts +96 -96
  625. package/types/components/table-module/filter.d.ts +140 -140
  626. package/types/components/table-module/index.d.ts +7 -7
  627. package/types/components/table-module/keyboard.d.ts +26 -26
  628. package/types/components/table-module/menu.d.ts +26 -26
  629. package/types/components/table-module/validator.d.ts +53 -53
  630. package/types/components/table-plugins/extend-cell-area.d.ts +734 -734
  631. package/types/components/table-plugins/extend-pivot-table.d.ts +62 -62
  632. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  633. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  634. package/types/components/table-plugins/index.d.ts +4 -4
  635. package/types/components/table-select.d.ts +212 -212
  636. package/types/components/table.d.ts +7222 -7206
  637. package/types/components/tabs.d.ts +324 -324
  638. package/types/components/tag.d.ts +107 -107
  639. package/types/components/text-ellipsis.d.ts +105 -105
  640. package/types/components/text.d.ts +115 -115
  641. package/types/components/textarea.d.ts +237 -237
  642. package/types/components/timeline-item.d.ts +68 -68
  643. package/types/components/timeline.d.ts +70 -70
  644. package/types/components/tip.d.ts +76 -76
  645. package/types/components/toolbar.d.ts +329 -329
  646. package/types/components/tooltip.d.ts +165 -165
  647. package/types/components/tour.d.ts +70 -70
  648. package/types/components/tree-select.d.ts +295 -295
  649. package/types/components/tree.d.ts +826 -826
  650. package/types/components/upload.d.ts +432 -432
  651. package/types/components/watermark.d.ts +113 -113
  652. package/types/index.d.ts +4 -4
  653. package/types/ui/commands.d.ts +57 -57
  654. package/types/ui/formats.d.ts +62 -62
  655. package/types/ui/global-config.d.ts +254 -254
  656. package/types/ui/global-icon.d.ts +292 -292
  657. package/types/ui/hooks.d.ts +11 -11
  658. package/types/ui/index.d.ts +95 -95
  659. package/types/ui/interceptor.d.ts +54 -54
  660. package/types/ui/menus.d.ts +77 -77
  661. package/types/ui/renderer.d.ts +1042 -1042
  662. package/types/ui/validators.d.ts +38 -38
  663. /package/es/icon/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  664. /package/es/icon/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  665. /package/es/icon/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  666. /package/es/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  667. /package/es/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  668. /package/es/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  669. /package/lib/icon/style/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  670. /package/lib/icon/style/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  671. /package/lib/icon/style/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  672. /package/lib/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  673. /package/lib/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  674. /package/lib/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
@@ -1,737 +1,737 @@
1
- import { CreateElement, PropType, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { VxeUI, getConfig, createEvent, getIcon, globalEvents, GLOBAL_EVENT_KEYS, getI18n, renderEmptyElement } from '../../ui'
5
- import { getDomNode, addClass, removeClass, hasControlKey } from '../../ui/src/dom'
6
-
7
- import type { ImagePreviewReactData, VxeGlobalIcon, VxeImagePreviewEmits, VxeComponentSizeType, VxeImagePreviewPropTypes, ValueOf, VxeImagePreviewDefines } from '../../../types'
8
-
9
- export default /* define-vxe-component start */ defineVxeComponent({
10
- name: 'VxeImagePreview',
11
- props: {
12
- value: Number as PropType<VxeImagePreviewPropTypes.ModelValue>,
13
- urlList: Array as PropType<VxeImagePreviewPropTypes.UrlList>,
14
- urlField: {
15
- type: String as PropType<VxeImagePreviewPropTypes.UrlField>,
16
- default: () => getConfig().imagePreview.urlField
17
- },
18
- maskClosable: {
19
- type: Boolean as PropType<VxeImagePreviewPropTypes.MaskClosable>,
20
- default: () => getConfig().imagePreview.maskClosable
21
- },
22
- marginSize: {
23
- type: String as PropType<VxeImagePreviewPropTypes.MarginSize>,
24
- default: () => getConfig().imagePreview.marginSize
25
- },
26
- showPrintButton: {
27
- type: Boolean as PropType<VxeImagePreviewPropTypes.ShowPrintButton>,
28
- default: () => getConfig().imagePreview.showPrintButton
29
- },
30
- showDownloadButton: {
31
- type: Boolean as PropType<VxeImagePreviewPropTypes.ShowDownloadButton>,
32
- default: () => getConfig().imagePreview.showDownloadButton
33
- },
34
- zIndex: Number as PropType<VxeImagePreviewPropTypes.ZIndex>,
35
- toolbarConfig: Object as PropType<VxeImagePreviewPropTypes.ToolbarConfig>,
36
- beforeDownloadMethod: Function as PropType<VxeImagePreviewPropTypes.BeforeDownloadMethod>,
37
- downloadMethod: Function as PropType<VxeImagePreviewPropTypes.DownloadMethod>
38
- },
39
- provide () {
40
- const $xeImagePreview = this
41
- return {
42
- $xeImagePreview
43
- }
44
- },
45
- data () {
46
- const xID = XEUtils.uniqueId()
47
- const reactData: ImagePreviewReactData = {
48
- activeIndex: 0,
49
- offsetPct11: false,
50
- offsetScale: 0,
51
- offsetRotate: 0,
52
- offsetLeft: 0,
53
- offsetTop: 0
54
- }
55
- return {
56
- xID,
57
- reactData
58
- }
59
- },
60
- computed: {
61
- ...({} as {
62
- computeSize(): VxeComponentSizeType
63
- }),
64
- computeUrlProp () {
65
- const $xeImagePreview = this
66
- const props = $xeImagePreview
67
-
68
- return props.urlField || 'url'
69
- },
70
- computeMarginSize () {
71
- const $xeImagePreview = this
72
- const props = $xeImagePreview
73
-
74
- return XEUtils.toNumber(props.marginSize || 0) || 16
75
- },
76
- computeToolbarOpts () {
77
- const $xeImagePreview = this
78
- const props = $xeImagePreview
79
-
80
- return Object.assign({}, getConfig().imagePreview.toolbarConfig, props.toolbarConfig)
81
- },
82
- computeRotateText () {
83
- const $xeImagePreview = this
84
- const reactData = $xeImagePreview.reactData as ImagePreviewReactData
85
-
86
- const { offsetRotate } = reactData
87
- if (offsetRotate) {
88
- return `${offsetRotate}°`
89
- }
90
- return '0°'
91
- },
92
- computeScaleText () {
93
- const $xeImagePreview = this
94
- const reactData = $xeImagePreview.reactData as ImagePreviewReactData
95
-
96
- const { offsetScale } = reactData
97
- if (offsetScale) {
98
- return `${XEUtils.ceil((1 + offsetScale) * 100)}%`
99
- }
100
- return '100%'
101
- },
102
- computeImgList () {
103
- const $xeImagePreview = this
104
- const props = $xeImagePreview
105
-
106
- const { urlList } = props
107
- const urlProp = $xeImagePreview.computeUrlProp as string
108
- if (urlList && urlList.length) {
109
- return urlList.map(item => {
110
- if (XEUtils.isString(item)) {
111
- return item
112
- }
113
- if (item[urlProp]) {
114
- return item[urlProp]
115
- }
116
- return ''
117
- })
118
- }
119
- return []
120
- },
121
- computeImgTransform () {
122
- const $xeImagePreview = this
123
- const reactData = $xeImagePreview.reactData
124
-
125
- let { offsetScale, offsetRotate, offsetLeft, offsetTop } = reactData
126
- const stys: string[] = []
127
- let targetScale = 1
128
- if (offsetScale) {
129
- targetScale = 1 + offsetScale
130
- stys.push(`scale(${targetScale})`)
131
- }
132
- if (offsetRotate) {
133
- stys.push(`rotate(${offsetRotate}deg)`)
134
- }
135
- if (offsetLeft || offsetTop) {
136
- // 缩放与位移
137
- offsetLeft /= targetScale
138
- offsetTop /= targetScale
139
-
140
- let targetOffsetLeft = offsetLeft
141
- let targetOffsetTop = offsetTop
142
- if (offsetRotate) {
143
- // 转向与位移
144
- switch (offsetRotate % 360) {
145
- case 90:
146
- case -270:
147
- targetOffsetLeft = offsetTop
148
- targetOffsetTop = -offsetLeft
149
- break
150
- case 180:
151
- case -180:
152
- targetOffsetLeft = -offsetLeft
153
- targetOffsetTop = -offsetTop
154
- break
155
- case 270:
156
- case -90:
157
- targetOffsetLeft = -offsetTop
158
- targetOffsetTop = offsetLeft
159
- break
160
- }
161
- }
162
- stys.push(`translate(${targetOffsetLeft}px, ${targetOffsetTop}px)`)
163
- }
164
- return stys.length ? stys.join(' ') : ''
165
- }
166
- },
167
- methods: {
168
- //
169
- // Method
170
- //
171
- dispatchEvent (type: ValueOf<VxeImagePreviewEmits>, params: Record<string, any>, evnt: Event | null) {
172
- const $xeImagePreview = this
173
- $xeImagePreview.$emit(type, createEvent(evnt, { $imagePreview: $xeImagePreview }, params))
174
- },
175
- emitModel (value: VxeImagePreviewPropTypes.ModelValue) {
176
- const $xeImagePreview = this
177
-
178
- const { _events } = $xeImagePreview as any
179
- $xeImagePreview.$emit('input', value)
180
- if (_events && _events.modelValue) {
181
- $xeImagePreview.$emit('modelValue', value)
182
- } else {
183
- $xeImagePreview.$emit('model-value', value)
184
- }
185
- },
186
- handleCloseEvent (evnt: MouseEvent) {
187
- const $xeImagePreview = this
188
-
189
- $xeImagePreview.dispatchEvent('close', {}, evnt)
190
- },
191
- resetStyle () {
192
- const $xeImagePreview = this
193
- const reactData = $xeImagePreview.reactData
194
-
195
- const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
196
- removeClass(elem, 'is--move')
197
- Object.assign(reactData, {
198
- offsetPct11: false,
199
- offsetScale: 0,
200
- offsetRotate: 0,
201
- offsetLeft: 0,
202
- offsetTop: 0
203
- })
204
- },
205
- getOffsetZoomStep () {
206
- const $xeImagePreview = this
207
- const reactData = $xeImagePreview.reactData
208
-
209
- const { offsetScale } = reactData
210
- let stepNum = 0.02
211
- if (offsetScale >= -0.6) {
212
- stepNum = 0.04
213
- if (offsetScale >= -0.4) {
214
- stepNum = 0.07
215
- if (offsetScale >= 0) {
216
- stepNum = 0.1
217
- if (offsetScale >= 3) {
218
- stepNum = 0.25
219
- if (offsetScale >= 8) {
220
- stepNum = 0.4
221
- if (offsetScale >= 16) {
222
- stepNum = 0.6
223
- if (offsetScale >= 24) {
224
- stepNum = 0.9
225
- if (offsetScale >= 32) {
226
- stepNum = 1.3
227
- if (offsetScale >= 39) {
228
- stepNum = 1.9
229
- if (offsetScale >= 45) {
230
- stepNum = 2.5
231
- }
232
- }
233
- }
234
- }
235
- }
236
- }
237
- }
238
- }
239
- }
240
- }
241
- return stepNum
242
- },
243
- handleZoom (isAdd: boolean) {
244
- const $xeImagePreview = this
245
- const reactData = $xeImagePreview.reactData
246
-
247
- const { offsetScale } = reactData
248
- const stepNum = $xeImagePreview.getOffsetZoomStep()
249
- if (isAdd) {
250
- reactData.offsetScale = Number(Math.min(49, offsetScale + stepNum).toFixed(2))
251
- } else {
252
- reactData.offsetScale = Number(Math.max(-0.9, offsetScale - stepNum).toFixed(2))
253
- }
254
- },
255
- handleChangeEvent (evnt: Event, isNext: boolean) {
256
- const $xeImagePreview = this
257
- const reactData = $xeImagePreview.reactData
258
-
259
- let activeIndex = reactData.activeIndex || 0
260
- const imgList = $xeImagePreview.computeImgList
261
- if (isNext) {
262
- if (activeIndex >= imgList.length - 1) {
263
- activeIndex = 0
264
- } else {
265
- activeIndex++
266
- }
267
- } else {
268
- if (activeIndex <= 0) {
269
- activeIndex = imgList.length - 1
270
- } else {
271
- activeIndex--
272
- }
273
- }
274
- const imgUrl = imgList[activeIndex || 0]
275
- reactData.activeIndex = activeIndex
276
- $xeImagePreview.resetStyle()
277
- $xeImagePreview.emitModel(activeIndex)
278
- $xeImagePreview.dispatchEvent('change', { url: imgUrl, activeIndex }, evnt)
279
- },
280
- handleRotateImgEvent (evnt: Event, isRight: boolean) {
281
- const $xeImagePreview = this
282
- const reactData = $xeImagePreview.reactData
283
-
284
- const imgList = $xeImagePreview.computeImgList
285
- const { activeIndex } = reactData
286
- const imgUrl = imgList[activeIndex || 0]
287
- let offsetRotate = reactData.offsetRotate
288
- if (isRight) {
289
- offsetRotate += 90
290
- } else {
291
- offsetRotate -= 90
292
- }
293
- reactData.offsetRotate = offsetRotate
294
- $xeImagePreview.dispatchEvent('rotate', { url: imgUrl, rotateValue: offsetRotate }, evnt)
295
- },
296
- handlePct11 () {
297
- const $xeImagePreview = this
298
- const reactData = $xeImagePreview.reactData
299
-
300
- $xeImagePreview.resetStyle()
301
- reactData.offsetPct11 = true
302
- },
303
- handlePrintImg () {
304
- const $xeImagePreview = this
305
- const reactData = $xeImagePreview.reactData
306
-
307
- const { activeIndex } = reactData
308
- const imgList = $xeImagePreview.computeImgList
309
- const imgUrl = imgList[activeIndex || 0]
310
- if (VxeUI.print) {
311
- VxeUI.print({
312
- align: 'center',
313
- pageBreaks: [
314
- {
315
- bodyHtml: `<img src="${imgUrl}" style="max-width:100%;max-height:100%;">`
316
- }
317
- ]
318
- })
319
- }
320
- },
321
- handleDownloadEvent (evnt: MouseEvent, imgUrl: string) {
322
- const $xeImagePreview = this
323
-
324
- $xeImagePreview.dispatchEvent('download', { url: imgUrl }, evnt)
325
- },
326
- handleDefaultDownload (evnt: MouseEvent, imgUrl: string) {
327
- const $xeImagePreview = this
328
-
329
- if (VxeUI.saveFile) {
330
- fetch(imgUrl).then(res => {
331
- return res.blob().then(blob => {
332
- VxeUI.saveFile({
333
- filename: imgUrl,
334
- content: blob
335
- })
336
- $xeImagePreview.handleDownloadEvent(evnt, imgUrl)
337
- })
338
- }).catch(() => {
339
- if (VxeUI.modal) {
340
- VxeUI.modal.message({
341
- content: getI18n('vxe.error.downErr'),
342
- status: 'error'
343
- })
344
- }
345
- })
346
- }
347
- },
348
- handleDownloadImg (evnt: MouseEvent) {
349
- const $xeImagePreview = this
350
- const props = $xeImagePreview
351
- const reactData = $xeImagePreview.reactData
352
-
353
- const { activeIndex } = reactData
354
- const toolbarOpts = $xeImagePreview.computeToolbarOpts
355
- const btnConf = toolbarOpts.download
356
- const btnOpts = XEUtils.isBoolean(btnConf) ? {} : (btnConf ? Object.assign({}, btnConf) : {})
357
- const imgList = $xeImagePreview.computeImgList
358
- const imgUrl = imgList[activeIndex || 0]
359
- const beforeDownloadFn = props.beforeDownloadMethod || btnOpts.beforeDownloadMethod || getConfig().imagePreview.beforeDownloadMethod
360
- const downloadFn = props.downloadMethod || btnOpts.downloadMethod || getConfig().imagePreview.downloadMethod
361
- Promise.resolve(
362
- beforeDownloadFn
363
- ? beforeDownloadFn({
364
- $imagePreview: $xeImagePreview,
365
- url: imgUrl,
366
- index: activeIndex || 0
367
- })
368
- : true
369
- ).then(status => {
370
- if (status) {
371
- if (downloadFn) {
372
- Promise.resolve(
373
- downloadFn({
374
- $imagePreview: $xeImagePreview,
375
- url: imgUrl,
376
- index: activeIndex || 0
377
- })
378
- ).then(() => {
379
- $xeImagePreview.handleDownloadEvent(evnt, imgUrl)
380
- }).catch(e => e)
381
- } else {
382
- $xeImagePreview.handleDefaultDownload(evnt, imgUrl)
383
- }
384
- }
385
- })
386
- },
387
- handleOperationBtn (evnt: MouseEvent, code: VxeImagePreviewDefines.ToolbarCode) {
388
- const $xeImagePreview = this
389
- const reactData = $xeImagePreview.reactData
390
-
391
- const { activeIndex } = reactData
392
- const imgList = $xeImagePreview.computeImgList
393
- const imgUrl = imgList[activeIndex || 0]
394
- if (imgUrl) {
395
- switch (code) {
396
- case 'zoomOut':
397
- $xeImagePreview.handleZoom(false)
398
- break
399
- case 'zoomIn':
400
- $xeImagePreview.handleZoom(true)
401
- break
402
- case 'pctFull':
403
- $xeImagePreview.resetStyle()
404
- break
405
- case 'pct11':
406
- $xeImagePreview.handlePct11()
407
- break
408
- case 'rotateLeft':
409
- $xeImagePreview.handleRotateImgEvent(evnt, false)
410
- break
411
- case 'rotateRight':
412
- $xeImagePreview.handleRotateImgEvent(evnt, true)
413
- break
414
- case 'print':
415
- $xeImagePreview.handlePrintImg()
416
- break
417
- case 'download':
418
- $xeImagePreview.handleDownloadImg(evnt)
419
- break
420
- }
421
- }
422
- },
423
- wheelEvent (evnt: WheelEvent) {
424
- const $xeImagePreview = this
425
-
426
- const delta = evnt.deltaY
427
- if (delta > 0) {
428
- evnt.preventDefault()
429
- $xeImagePreview.handleZoom(false)
430
- } else if (delta < 0) {
431
- evnt.preventDefault()
432
- $xeImagePreview.handleZoom(true)
433
- }
434
- },
435
- moveEvent (evnt: MouseEvent) {
436
- const $xeImagePreview = this
437
- const reactData = $xeImagePreview.reactData
438
-
439
- const { offsetTop, offsetLeft } = reactData
440
- const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
441
- evnt.preventDefault()
442
- const domMousemove = document.onmousemove
443
- const domMouseup = document.onmouseup
444
- const startX = evnt.pageX
445
- const startY = evnt.pageY
446
- const marginSize = $xeImagePreview.computeMarginSize
447
- document.onmousemove = et => {
448
- const { pageX, pageY } = et
449
- const { visibleHeight, visibleWidth } = getDomNode()
450
- et.preventDefault()
451
- addClass(elem, 'is--move')
452
- // 限制边界值
453
- if (pageX > marginSize && pageY > marginSize && pageX < (visibleWidth - marginSize) && pageY < (visibleHeight - marginSize)) {
454
- reactData.offsetLeft = offsetLeft + pageX - startX
455
- reactData.offsetTop = offsetTop + pageY - startY
456
- }
457
- }
458
- document.onmouseup = () => {
459
- document.onmousemove = domMousemove
460
- document.onmouseup = domMouseup
461
- removeClass(elem, 'is--move')
462
- }
463
- },
464
- handleGlobalKeydownEvent (evnt: KeyboardEvent) {
465
- const $xeImagePreview = this
466
- const reactData = $xeImagePreview.reactData
467
-
468
- const isControlKey = hasControlKey(evnt)
469
- const hasShiftKey = evnt.shiftKey
470
- const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
471
- const isDownArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
472
- const isLeftArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_LEFT)
473
- const isRightArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_RIGHT)
474
- const isR = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.R)
475
- const isP = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.P)
476
- if (isUpArrow) {
477
- evnt.preventDefault()
478
- if (hasShiftKey) {
479
- reactData.offsetTop -= 1
480
- } else {
481
- $xeImagePreview.handleZoom(true)
482
- }
483
- } else if (isDownArrow) {
484
- evnt.preventDefault()
485
- if (hasShiftKey) {
486
- reactData.offsetTop += 1
487
- } else {
488
- $xeImagePreview.handleZoom(false)
489
- }
490
- } else if (isLeftArrow) {
491
- evnt.preventDefault()
492
- if (hasShiftKey) {
493
- reactData.offsetLeft -= 1
494
- } else {
495
- $xeImagePreview.handleChangeEvent(evnt, false)
496
- }
497
- } else if (isRightArrow) {
498
- evnt.preventDefault()
499
- if (hasShiftKey) {
500
- reactData.offsetLeft += 1
501
- } else {
502
- $xeImagePreview.handleChangeEvent(evnt, true)
503
- }
504
- } else if (isR && isControlKey) {
505
- evnt.preventDefault()
506
- if (hasShiftKey) {
507
- $xeImagePreview.handleRotateImgEvent(evnt, false)
508
- } else {
509
- $xeImagePreview.handleRotateImgEvent(evnt, true)
510
- }
511
- } else if (isP && isControlKey) {
512
- evnt.preventDefault()
513
- $xeImagePreview.handlePrintImg()
514
- }
515
- },
516
- handleClickMaskEvent (evnt: MouseEvent) {
517
- const $xeImagePreview = this
518
- const props = $xeImagePreview
519
-
520
- if (props.maskClosable) {
521
- if (evnt.target === evnt.currentTarget) {
522
- $xeImagePreview.dispatchEvent('close', {}, evnt)
523
- }
524
- }
525
- },
526
-
527
- //
528
- // Render
529
- //
530
- renderImgWrapper (h: CreateElement) {
531
- const $xeImagePreview = this
532
- const reactData = $xeImagePreview.reactData
533
-
534
- const { activeIndex } = reactData
535
- const imgList = $xeImagePreview.computeImgList
536
- const imgTransform = $xeImagePreview.computeImgTransform
537
- return h('div', {
538
- class: 'vxe-image-preview--img-list',
539
- on: {
540
- click: $xeImagePreview.handleClickMaskEvent
541
- }
542
- }, imgList.map((url, index) => {
543
- const isActive = activeIndex === index
544
- return h('img', {
545
- class: ['vxe-image-preview--img-item', {
546
- 'is--active': isActive
547
- }],
548
- style: isActive
549
- ? {
550
- transform: imgTransform
551
- }
552
- : {},
553
- attrs: {
554
- src: url
555
- },
556
- on: {
557
- mousedown (evnt: MouseEvent) {
558
- $xeImagePreview.moveEvent(evnt)
559
- }
560
- }
561
- })
562
- }))
563
- },
564
- renderOperationBtn (h: CreateElement, code: VxeImagePreviewDefines.ToolbarCode, icon: keyof VxeGlobalIcon) {
565
- const $xeImagePreview = this
566
-
567
- const toolbarOpts = $xeImagePreview.computeToolbarOpts
568
- const btnConf = toolbarOpts[code]
569
- const btnOpts = XEUtils.isBoolean(btnConf) ? {} : (btnConf ? Object.assign({}, btnConf) : {})
570
- const showBtn = btnConf !== false
571
- return showBtn
572
- ? h('div', {
573
- class: 'vxe-image-preview--operation-btn',
574
- attrs: {
575
- title: getI18n(`vxe.imagePreview.operBtn.${code}`)
576
- },
577
- on: {
578
- click (evnt: MouseEvent) {
579
- $xeImagePreview.handleOperationBtn(evnt, code)
580
- }
581
- }
582
- }, [
583
- h('i', {
584
- class: btnOpts.icon || getIcon()[icon]
585
- })
586
- ])
587
- : renderEmptyElement($xeImagePreview)
588
- },
589
- renderBtnWrapper (h: CreateElement) {
590
- const $xeImagePreview = this
591
- const props = $xeImagePreview
592
- const reactData = $xeImagePreview.reactData
593
-
594
- const { showPrintButton, showDownloadButton } = props
595
- const { activeIndex } = reactData
596
- const imgList = $xeImagePreview.computeImgList
597
- const rotateText = $xeImagePreview.computeRotateText
598
- const scaleText = $xeImagePreview.computeScaleText
599
- const toolbarOpts = $xeImagePreview.computeToolbarOpts
600
-
601
- return h('div', {
602
- class: 'vxe-image-preview--btn-wrapper'
603
- }, [
604
- h('div', {
605
- class: 'vxe-image-preview--close-wrapper'
606
- }, [
607
- h('div', {
608
- class: 'vxe-image-preview--close-btn',
609
- on: {
610
- click: $xeImagePreview.handleCloseEvent
611
- }
612
- }, [
613
- h('i', {
614
- class: getIcon().IMAGE_PREVIEW_CLOSE
615
- })
616
- ]),
617
- h('div', {
618
- class: 'vxe-image-preview--close-bg'
619
- })
620
- ]),
621
- imgList.length > 1
622
- ? h('div', {
623
- class: 'vxe-image-preview--previous-btn',
624
- on: {
625
- click (evnt: KeyboardEvent) {
626
- $xeImagePreview.handleChangeEvent(evnt, false)
627
- }
628
- }
629
- }, [
630
- h('i', {
631
- class: getIcon().IMAGE_PREVIEW_PREVIOUS
632
- })
633
- ])
634
- : renderEmptyElement($xeImagePreview),
635
- imgList.length > 1
636
- ? h('div', {
637
- class: 'vxe-image-preview--next-btn',
638
- on: {
639
- click (evnt: KeyboardEvent) {
640
- $xeImagePreview.handleChangeEvent(evnt, true)
641
- }
642
- }
643
- }, [
644
- h('i', {
645
- class: getIcon().IMAGE_PREVIEW_NEXT
646
- })
647
- ])
648
- : renderEmptyElement($xeImagePreview),
649
- h('div', {
650
- class: 'vxe-image-preview--operation-info'
651
- }, [
652
- h('div', {
653
- class: 'vxe-image-preview--operation-deg'
654
- }, rotateText),
655
- h('div', {
656
- class: 'vxe-image-preview--operation-pct'
657
- }, scaleText)
658
- ]),
659
- h('div', {
660
- class: 'vxe-image-preview--operation-wrapper'
661
- }, [
662
- h('div', {
663
- class: 'vxe-image-preview--operation-active-count'
664
- }, [
665
- h('span', {
666
- class: 'vxe-image-preview--operation-active-current'
667
- }, `${(activeIndex || 0) + 1}`),
668
- h('span', {
669
- class: 'vxe-image-preview--operation-active-total'
670
- }, `/${imgList.length}`)
671
- ]),
672
- $xeImagePreview.renderOperationBtn(h, 'zoomOut', 'IMAGE_PREVIEW_ZOOM_OUT'),
673
- $xeImagePreview.renderOperationBtn(h, 'zoomIn', 'IMAGE_PREVIEW_ZOOM_IN'),
674
- $xeImagePreview.renderOperationBtn(h, 'pctFull', 'IMAGE_PREVIEW_PCT_FULL'),
675
- $xeImagePreview.renderOperationBtn(h, 'pct11', 'IMAGE_PREVIEW_PCT_1_1'),
676
- $xeImagePreview.renderOperationBtn(h, 'rotateLeft', 'IMAGE_PREVIEW_ROTATE_LEFT'),
677
- $xeImagePreview.renderOperationBtn(h, 'rotateRight', 'IMAGE_PREVIEW_ROTATE_RIGHT'),
678
- showPrintButton || toolbarOpts.print ? $xeImagePreview.renderOperationBtn(h, 'print', 'IMAGE_PREVIEW_PRINT') : renderEmptyElement($xeImagePreview),
679
- showDownloadButton || toolbarOpts.download ? $xeImagePreview.renderOperationBtn(h, 'download', 'IMAGE_PREVIEW_DOWNLOAD') : renderEmptyElement($xeImagePreview)
680
- ])
681
- ])
682
- },
683
- renderVN (h: CreateElement): VNode {
684
- const $xeImagePreview = this
685
- const reactData = $xeImagePreview.reactData
686
-
687
- const { offsetPct11 } = reactData
688
- return h('div', {
689
- ref: 'refElem',
690
- class: ['vxe-image-preview', {
691
- 'is--pct11': offsetPct11
692
- }]
693
- }, [
694
- $xeImagePreview.renderImgWrapper(h),
695
- $xeImagePreview.renderBtnWrapper(h)
696
- ])
697
- }
698
- },
699
- watch: {
700
- value (val) {
701
- const $xeImagePreview = this
702
- const reactData = $xeImagePreview.reactData
703
-
704
- reactData.activeIndex = val
705
- $xeImagePreview.resetStyle()
706
- }
707
- },
708
- created () {
709
- const $xeImagePreview = this
710
- const props = $xeImagePreview
711
- const reactData = $xeImagePreview.reactData
712
-
713
- reactData.activeIndex = props.value || 0
714
- },
715
- mounted () {
716
- const $xeImagePreview = this
717
-
718
- const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
719
- if (elem) {
720
- elem.addEventListener('wheel', $xeImagePreview.wheelEvent, { passive: false })
721
- }
722
- globalEvents.on($xeImagePreview, 'keydown', $xeImagePreview.handleGlobalKeydownEvent)
723
- },
724
- beforeDestroy () {
725
- const $xeImagePreview = this
726
-
727
- const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
728
- if (elem) {
729
- elem.removeEventListener('wheel', $xeImagePreview.wheelEvent)
730
- removeClass(elem, 'is--move')
731
- }
732
- globalEvents.off($xeImagePreview, 'keydown')
733
- },
734
- render (this: any, h) {
735
- return this.renderVN(h)
736
- }
737
- }) /* define-vxe-component end */
1
+ import { CreateElement, PropType, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { VxeUI, getConfig, createEvent, getIcon, globalEvents, GLOBAL_EVENT_KEYS, getI18n, renderEmptyElement } from '../../ui'
5
+ import { getDomNode, addClass, removeClass, hasControlKey } from '../../ui/src/dom'
6
+
7
+ import type { ImagePreviewReactData, VxeGlobalIcon, VxeImagePreviewEmits, VxeComponentSizeType, VxeImagePreviewPropTypes, ValueOf, VxeImagePreviewDefines } from '../../../types'
8
+
9
+ export default /* define-vxe-component start */ defineVxeComponent({
10
+ name: 'VxeImagePreview',
11
+ props: {
12
+ value: Number as PropType<VxeImagePreviewPropTypes.ModelValue>,
13
+ urlList: Array as PropType<VxeImagePreviewPropTypes.UrlList>,
14
+ urlField: {
15
+ type: String as PropType<VxeImagePreviewPropTypes.UrlField>,
16
+ default: () => getConfig().imagePreview.urlField
17
+ },
18
+ maskClosable: {
19
+ type: Boolean as PropType<VxeImagePreviewPropTypes.MaskClosable>,
20
+ default: () => getConfig().imagePreview.maskClosable
21
+ },
22
+ marginSize: {
23
+ type: String as PropType<VxeImagePreviewPropTypes.MarginSize>,
24
+ default: () => getConfig().imagePreview.marginSize
25
+ },
26
+ showPrintButton: {
27
+ type: Boolean as PropType<VxeImagePreviewPropTypes.ShowPrintButton>,
28
+ default: () => getConfig().imagePreview.showPrintButton
29
+ },
30
+ showDownloadButton: {
31
+ type: Boolean as PropType<VxeImagePreviewPropTypes.ShowDownloadButton>,
32
+ default: () => getConfig().imagePreview.showDownloadButton
33
+ },
34
+ zIndex: Number as PropType<VxeImagePreviewPropTypes.ZIndex>,
35
+ toolbarConfig: Object as PropType<VxeImagePreviewPropTypes.ToolbarConfig>,
36
+ beforeDownloadMethod: Function as PropType<VxeImagePreviewPropTypes.BeforeDownloadMethod>,
37
+ downloadMethod: Function as PropType<VxeImagePreviewPropTypes.DownloadMethod>
38
+ },
39
+ provide () {
40
+ const $xeImagePreview = this
41
+ return {
42
+ $xeImagePreview
43
+ }
44
+ },
45
+ data () {
46
+ const xID = XEUtils.uniqueId()
47
+ const reactData: ImagePreviewReactData = {
48
+ activeIndex: 0,
49
+ offsetPct11: false,
50
+ offsetScale: 0,
51
+ offsetRotate: 0,
52
+ offsetLeft: 0,
53
+ offsetTop: 0
54
+ }
55
+ return {
56
+ xID,
57
+ reactData
58
+ }
59
+ },
60
+ computed: {
61
+ ...({} as {
62
+ computeSize(): VxeComponentSizeType
63
+ }),
64
+ computeUrlProp () {
65
+ const $xeImagePreview = this
66
+ const props = $xeImagePreview
67
+
68
+ return props.urlField || 'url'
69
+ },
70
+ computeMarginSize () {
71
+ const $xeImagePreview = this
72
+ const props = $xeImagePreview
73
+
74
+ return XEUtils.toNumber(props.marginSize || 0) || 16
75
+ },
76
+ computeToolbarOpts () {
77
+ const $xeImagePreview = this
78
+ const props = $xeImagePreview
79
+
80
+ return Object.assign({}, getConfig().imagePreview.toolbarConfig, props.toolbarConfig)
81
+ },
82
+ computeRotateText () {
83
+ const $xeImagePreview = this
84
+ const reactData = $xeImagePreview.reactData as ImagePreviewReactData
85
+
86
+ const { offsetRotate } = reactData
87
+ if (offsetRotate) {
88
+ return `${offsetRotate}°`
89
+ }
90
+ return '0°'
91
+ },
92
+ computeScaleText () {
93
+ const $xeImagePreview = this
94
+ const reactData = $xeImagePreview.reactData as ImagePreviewReactData
95
+
96
+ const { offsetScale } = reactData
97
+ if (offsetScale) {
98
+ return `${XEUtils.ceil((1 + offsetScale) * 100)}%`
99
+ }
100
+ return '100%'
101
+ },
102
+ computeImgList () {
103
+ const $xeImagePreview = this
104
+ const props = $xeImagePreview
105
+
106
+ const { urlList } = props
107
+ const urlProp = $xeImagePreview.computeUrlProp as string
108
+ if (urlList && urlList.length) {
109
+ return urlList.map(item => {
110
+ if (XEUtils.isString(item)) {
111
+ return item
112
+ }
113
+ if (item[urlProp]) {
114
+ return item[urlProp]
115
+ }
116
+ return ''
117
+ })
118
+ }
119
+ return []
120
+ },
121
+ computeImgTransform () {
122
+ const $xeImagePreview = this
123
+ const reactData = $xeImagePreview.reactData
124
+
125
+ let { offsetScale, offsetRotate, offsetLeft, offsetTop } = reactData
126
+ const stys: string[] = []
127
+ let targetScale = 1
128
+ if (offsetScale) {
129
+ targetScale = 1 + offsetScale
130
+ stys.push(`scale(${targetScale})`)
131
+ }
132
+ if (offsetRotate) {
133
+ stys.push(`rotate(${offsetRotate}deg)`)
134
+ }
135
+ if (offsetLeft || offsetTop) {
136
+ // 缩放与位移
137
+ offsetLeft /= targetScale
138
+ offsetTop /= targetScale
139
+
140
+ let targetOffsetLeft = offsetLeft
141
+ let targetOffsetTop = offsetTop
142
+ if (offsetRotate) {
143
+ // 转向与位移
144
+ switch (offsetRotate % 360) {
145
+ case 90:
146
+ case -270:
147
+ targetOffsetLeft = offsetTop
148
+ targetOffsetTop = -offsetLeft
149
+ break
150
+ case 180:
151
+ case -180:
152
+ targetOffsetLeft = -offsetLeft
153
+ targetOffsetTop = -offsetTop
154
+ break
155
+ case 270:
156
+ case -90:
157
+ targetOffsetLeft = -offsetTop
158
+ targetOffsetTop = offsetLeft
159
+ break
160
+ }
161
+ }
162
+ stys.push(`translate(${targetOffsetLeft}px, ${targetOffsetTop}px)`)
163
+ }
164
+ return stys.length ? stys.join(' ') : ''
165
+ }
166
+ },
167
+ methods: {
168
+ //
169
+ // Method
170
+ //
171
+ dispatchEvent (type: ValueOf<VxeImagePreviewEmits>, params: Record<string, any>, evnt: Event | null) {
172
+ const $xeImagePreview = this
173
+ $xeImagePreview.$emit(type, createEvent(evnt, { $imagePreview: $xeImagePreview }, params))
174
+ },
175
+ emitModel (value: VxeImagePreviewPropTypes.ModelValue) {
176
+ const $xeImagePreview = this
177
+
178
+ const { _events } = $xeImagePreview as any
179
+ $xeImagePreview.$emit('input', value)
180
+ if (_events && _events.modelValue) {
181
+ $xeImagePreview.$emit('modelValue', value)
182
+ } else {
183
+ $xeImagePreview.$emit('model-value', value)
184
+ }
185
+ },
186
+ handleCloseEvent (evnt: MouseEvent) {
187
+ const $xeImagePreview = this
188
+
189
+ $xeImagePreview.dispatchEvent('close', {}, evnt)
190
+ },
191
+ resetStyle () {
192
+ const $xeImagePreview = this
193
+ const reactData = $xeImagePreview.reactData
194
+
195
+ const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
196
+ removeClass(elem, 'is--move')
197
+ Object.assign(reactData, {
198
+ offsetPct11: false,
199
+ offsetScale: 0,
200
+ offsetRotate: 0,
201
+ offsetLeft: 0,
202
+ offsetTop: 0
203
+ })
204
+ },
205
+ getOffsetZoomStep () {
206
+ const $xeImagePreview = this
207
+ const reactData = $xeImagePreview.reactData
208
+
209
+ const { offsetScale } = reactData
210
+ let stepNum = 0.02
211
+ if (offsetScale >= -0.6) {
212
+ stepNum = 0.04
213
+ if (offsetScale >= -0.4) {
214
+ stepNum = 0.07
215
+ if (offsetScale >= 0) {
216
+ stepNum = 0.1
217
+ if (offsetScale >= 3) {
218
+ stepNum = 0.25
219
+ if (offsetScale >= 8) {
220
+ stepNum = 0.4
221
+ if (offsetScale >= 16) {
222
+ stepNum = 0.6
223
+ if (offsetScale >= 24) {
224
+ stepNum = 0.9
225
+ if (offsetScale >= 32) {
226
+ stepNum = 1.3
227
+ if (offsetScale >= 39) {
228
+ stepNum = 1.9
229
+ if (offsetScale >= 45) {
230
+ stepNum = 2.5
231
+ }
232
+ }
233
+ }
234
+ }
235
+ }
236
+ }
237
+ }
238
+ }
239
+ }
240
+ }
241
+ return stepNum
242
+ },
243
+ handleZoom (isAdd: boolean) {
244
+ const $xeImagePreview = this
245
+ const reactData = $xeImagePreview.reactData
246
+
247
+ const { offsetScale } = reactData
248
+ const stepNum = $xeImagePreview.getOffsetZoomStep()
249
+ if (isAdd) {
250
+ reactData.offsetScale = Number(Math.min(49, offsetScale + stepNum).toFixed(2))
251
+ } else {
252
+ reactData.offsetScale = Number(Math.max(-0.9, offsetScale - stepNum).toFixed(2))
253
+ }
254
+ },
255
+ handleChangeEvent (evnt: Event, isNext: boolean) {
256
+ const $xeImagePreview = this
257
+ const reactData = $xeImagePreview.reactData
258
+
259
+ let activeIndex = reactData.activeIndex || 0
260
+ const imgList = $xeImagePreview.computeImgList
261
+ if (isNext) {
262
+ if (activeIndex >= imgList.length - 1) {
263
+ activeIndex = 0
264
+ } else {
265
+ activeIndex++
266
+ }
267
+ } else {
268
+ if (activeIndex <= 0) {
269
+ activeIndex = imgList.length - 1
270
+ } else {
271
+ activeIndex--
272
+ }
273
+ }
274
+ const imgUrl = imgList[activeIndex || 0]
275
+ reactData.activeIndex = activeIndex
276
+ $xeImagePreview.resetStyle()
277
+ $xeImagePreview.emitModel(activeIndex)
278
+ $xeImagePreview.dispatchEvent('change', { url: imgUrl, activeIndex }, evnt)
279
+ },
280
+ handleRotateImgEvent (evnt: Event, isRight: boolean) {
281
+ const $xeImagePreview = this
282
+ const reactData = $xeImagePreview.reactData
283
+
284
+ const imgList = $xeImagePreview.computeImgList
285
+ const { activeIndex } = reactData
286
+ const imgUrl = imgList[activeIndex || 0]
287
+ let offsetRotate = reactData.offsetRotate
288
+ if (isRight) {
289
+ offsetRotate += 90
290
+ } else {
291
+ offsetRotate -= 90
292
+ }
293
+ reactData.offsetRotate = offsetRotate
294
+ $xeImagePreview.dispatchEvent('rotate', { url: imgUrl, rotateValue: offsetRotate }, evnt)
295
+ },
296
+ handlePct11 () {
297
+ const $xeImagePreview = this
298
+ const reactData = $xeImagePreview.reactData
299
+
300
+ $xeImagePreview.resetStyle()
301
+ reactData.offsetPct11 = true
302
+ },
303
+ handlePrintImg () {
304
+ const $xeImagePreview = this
305
+ const reactData = $xeImagePreview.reactData
306
+
307
+ const { activeIndex } = reactData
308
+ const imgList = $xeImagePreview.computeImgList
309
+ const imgUrl = imgList[activeIndex || 0]
310
+ if (VxeUI.print) {
311
+ VxeUI.print({
312
+ align: 'center',
313
+ pageBreaks: [
314
+ {
315
+ bodyHtml: `<img src="${imgUrl}" style="max-width:100%;max-height:100%;">`
316
+ }
317
+ ]
318
+ })
319
+ }
320
+ },
321
+ handleDownloadEvent (evnt: MouseEvent, imgUrl: string) {
322
+ const $xeImagePreview = this
323
+
324
+ $xeImagePreview.dispatchEvent('download', { url: imgUrl }, evnt)
325
+ },
326
+ handleDefaultDownload (evnt: MouseEvent, imgUrl: string) {
327
+ const $xeImagePreview = this
328
+
329
+ if (VxeUI.saveFile) {
330
+ fetch(imgUrl).then(res => {
331
+ return res.blob().then(blob => {
332
+ VxeUI.saveFile({
333
+ filename: imgUrl,
334
+ content: blob
335
+ })
336
+ $xeImagePreview.handleDownloadEvent(evnt, imgUrl)
337
+ })
338
+ }).catch(() => {
339
+ if (VxeUI.modal) {
340
+ VxeUI.modal.message({
341
+ content: getI18n('vxe.error.downErr'),
342
+ status: 'error'
343
+ })
344
+ }
345
+ })
346
+ }
347
+ },
348
+ handleDownloadImg (evnt: MouseEvent) {
349
+ const $xeImagePreview = this
350
+ const props = $xeImagePreview
351
+ const reactData = $xeImagePreview.reactData
352
+
353
+ const { activeIndex } = reactData
354
+ const toolbarOpts = $xeImagePreview.computeToolbarOpts
355
+ const btnConf = toolbarOpts.download
356
+ const btnOpts = XEUtils.isBoolean(btnConf) ? {} : (btnConf ? Object.assign({}, btnConf) : {})
357
+ const imgList = $xeImagePreview.computeImgList
358
+ const imgUrl = imgList[activeIndex || 0]
359
+ const beforeDownloadFn = props.beforeDownloadMethod || btnOpts.beforeDownloadMethod || getConfig().imagePreview.beforeDownloadMethod
360
+ const downloadFn = props.downloadMethod || btnOpts.downloadMethod || getConfig().imagePreview.downloadMethod
361
+ Promise.resolve(
362
+ beforeDownloadFn
363
+ ? beforeDownloadFn({
364
+ $imagePreview: $xeImagePreview,
365
+ url: imgUrl,
366
+ index: activeIndex || 0
367
+ })
368
+ : true
369
+ ).then(status => {
370
+ if (status) {
371
+ if (downloadFn) {
372
+ Promise.resolve(
373
+ downloadFn({
374
+ $imagePreview: $xeImagePreview,
375
+ url: imgUrl,
376
+ index: activeIndex || 0
377
+ })
378
+ ).then(() => {
379
+ $xeImagePreview.handleDownloadEvent(evnt, imgUrl)
380
+ }).catch(e => e)
381
+ } else {
382
+ $xeImagePreview.handleDefaultDownload(evnt, imgUrl)
383
+ }
384
+ }
385
+ })
386
+ },
387
+ handleOperationBtn (evnt: MouseEvent, code: VxeImagePreviewDefines.ToolbarCode) {
388
+ const $xeImagePreview = this
389
+ const reactData = $xeImagePreview.reactData
390
+
391
+ const { activeIndex } = reactData
392
+ const imgList = $xeImagePreview.computeImgList
393
+ const imgUrl = imgList[activeIndex || 0]
394
+ if (imgUrl) {
395
+ switch (code) {
396
+ case 'zoomOut':
397
+ $xeImagePreview.handleZoom(false)
398
+ break
399
+ case 'zoomIn':
400
+ $xeImagePreview.handleZoom(true)
401
+ break
402
+ case 'pctFull':
403
+ $xeImagePreview.resetStyle()
404
+ break
405
+ case 'pct11':
406
+ $xeImagePreview.handlePct11()
407
+ break
408
+ case 'rotateLeft':
409
+ $xeImagePreview.handleRotateImgEvent(evnt, false)
410
+ break
411
+ case 'rotateRight':
412
+ $xeImagePreview.handleRotateImgEvent(evnt, true)
413
+ break
414
+ case 'print':
415
+ $xeImagePreview.handlePrintImg()
416
+ break
417
+ case 'download':
418
+ $xeImagePreview.handleDownloadImg(evnt)
419
+ break
420
+ }
421
+ }
422
+ },
423
+ wheelEvent (evnt: WheelEvent) {
424
+ const $xeImagePreview = this
425
+
426
+ const delta = evnt.deltaY
427
+ if (delta > 0) {
428
+ evnt.preventDefault()
429
+ $xeImagePreview.handleZoom(false)
430
+ } else if (delta < 0) {
431
+ evnt.preventDefault()
432
+ $xeImagePreview.handleZoom(true)
433
+ }
434
+ },
435
+ moveEvent (evnt: MouseEvent) {
436
+ const $xeImagePreview = this
437
+ const reactData = $xeImagePreview.reactData
438
+
439
+ const { offsetTop, offsetLeft } = reactData
440
+ const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
441
+ evnt.preventDefault()
442
+ const domMousemove = document.onmousemove
443
+ const domMouseup = document.onmouseup
444
+ const startX = evnt.pageX
445
+ const startY = evnt.pageY
446
+ const marginSize = $xeImagePreview.computeMarginSize
447
+ document.onmousemove = et => {
448
+ const { pageX, pageY } = et
449
+ const { visibleHeight, visibleWidth } = getDomNode()
450
+ et.preventDefault()
451
+ addClass(elem, 'is--move')
452
+ // 限制边界值
453
+ if (pageX > marginSize && pageY > marginSize && pageX < (visibleWidth - marginSize) && pageY < (visibleHeight - marginSize)) {
454
+ reactData.offsetLeft = offsetLeft + pageX - startX
455
+ reactData.offsetTop = offsetTop + pageY - startY
456
+ }
457
+ }
458
+ document.onmouseup = () => {
459
+ document.onmousemove = domMousemove
460
+ document.onmouseup = domMouseup
461
+ removeClass(elem, 'is--move')
462
+ }
463
+ },
464
+ handleGlobalKeydownEvent (evnt: KeyboardEvent) {
465
+ const $xeImagePreview = this
466
+ const reactData = $xeImagePreview.reactData
467
+
468
+ const isControlKey = hasControlKey(evnt)
469
+ const hasShiftKey = evnt.shiftKey
470
+ const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
471
+ const isDownArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
472
+ const isLeftArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_LEFT)
473
+ const isRightArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_RIGHT)
474
+ const isR = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.R)
475
+ const isP = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.P)
476
+ if (isUpArrow) {
477
+ evnt.preventDefault()
478
+ if (hasShiftKey) {
479
+ reactData.offsetTop -= 1
480
+ } else {
481
+ $xeImagePreview.handleZoom(true)
482
+ }
483
+ } else if (isDownArrow) {
484
+ evnt.preventDefault()
485
+ if (hasShiftKey) {
486
+ reactData.offsetTop += 1
487
+ } else {
488
+ $xeImagePreview.handleZoom(false)
489
+ }
490
+ } else if (isLeftArrow) {
491
+ evnt.preventDefault()
492
+ if (hasShiftKey) {
493
+ reactData.offsetLeft -= 1
494
+ } else {
495
+ $xeImagePreview.handleChangeEvent(evnt, false)
496
+ }
497
+ } else if (isRightArrow) {
498
+ evnt.preventDefault()
499
+ if (hasShiftKey) {
500
+ reactData.offsetLeft += 1
501
+ } else {
502
+ $xeImagePreview.handleChangeEvent(evnt, true)
503
+ }
504
+ } else if (isR && isControlKey) {
505
+ evnt.preventDefault()
506
+ if (hasShiftKey) {
507
+ $xeImagePreview.handleRotateImgEvent(evnt, false)
508
+ } else {
509
+ $xeImagePreview.handleRotateImgEvent(evnt, true)
510
+ }
511
+ } else if (isP && isControlKey) {
512
+ evnt.preventDefault()
513
+ $xeImagePreview.handlePrintImg()
514
+ }
515
+ },
516
+ handleClickMaskEvent (evnt: MouseEvent) {
517
+ const $xeImagePreview = this
518
+ const props = $xeImagePreview
519
+
520
+ if (props.maskClosable) {
521
+ if (evnt.target === evnt.currentTarget) {
522
+ $xeImagePreview.dispatchEvent('close', {}, evnt)
523
+ }
524
+ }
525
+ },
526
+
527
+ //
528
+ // Render
529
+ //
530
+ renderImgWrapper (h: CreateElement) {
531
+ const $xeImagePreview = this
532
+ const reactData = $xeImagePreview.reactData
533
+
534
+ const { activeIndex } = reactData
535
+ const imgList = $xeImagePreview.computeImgList
536
+ const imgTransform = $xeImagePreview.computeImgTransform
537
+ return h('div', {
538
+ class: 'vxe-image-preview--img-list',
539
+ on: {
540
+ click: $xeImagePreview.handleClickMaskEvent
541
+ }
542
+ }, imgList.map((url, index) => {
543
+ const isActive = activeIndex === index
544
+ return h('img', {
545
+ class: ['vxe-image-preview--img-item', {
546
+ 'is--active': isActive
547
+ }],
548
+ style: isActive
549
+ ? {
550
+ transform: imgTransform
551
+ }
552
+ : {},
553
+ attrs: {
554
+ src: url
555
+ },
556
+ on: {
557
+ mousedown (evnt: MouseEvent) {
558
+ $xeImagePreview.moveEvent(evnt)
559
+ }
560
+ }
561
+ })
562
+ }))
563
+ },
564
+ renderOperationBtn (h: CreateElement, code: VxeImagePreviewDefines.ToolbarCode, icon: keyof VxeGlobalIcon) {
565
+ const $xeImagePreview = this
566
+
567
+ const toolbarOpts = $xeImagePreview.computeToolbarOpts
568
+ const btnConf = toolbarOpts[code]
569
+ const btnOpts = XEUtils.isBoolean(btnConf) ? {} : (btnConf ? Object.assign({}, btnConf) : {})
570
+ const showBtn = btnConf !== false
571
+ return showBtn
572
+ ? h('div', {
573
+ class: 'vxe-image-preview--operation-btn',
574
+ attrs: {
575
+ title: getI18n(`vxe.imagePreview.operBtn.${code}`)
576
+ },
577
+ on: {
578
+ click (evnt: MouseEvent) {
579
+ $xeImagePreview.handleOperationBtn(evnt, code)
580
+ }
581
+ }
582
+ }, [
583
+ h('i', {
584
+ class: btnOpts.icon || getIcon()[icon]
585
+ })
586
+ ])
587
+ : renderEmptyElement($xeImagePreview)
588
+ },
589
+ renderBtnWrapper (h: CreateElement) {
590
+ const $xeImagePreview = this
591
+ const props = $xeImagePreview
592
+ const reactData = $xeImagePreview.reactData
593
+
594
+ const { showPrintButton, showDownloadButton } = props
595
+ const { activeIndex } = reactData
596
+ const imgList = $xeImagePreview.computeImgList
597
+ const rotateText = $xeImagePreview.computeRotateText
598
+ const scaleText = $xeImagePreview.computeScaleText
599
+ const toolbarOpts = $xeImagePreview.computeToolbarOpts
600
+
601
+ return h('div', {
602
+ class: 'vxe-image-preview--btn-wrapper'
603
+ }, [
604
+ h('div', {
605
+ class: 'vxe-image-preview--close-wrapper'
606
+ }, [
607
+ h('div', {
608
+ class: 'vxe-image-preview--close-btn',
609
+ on: {
610
+ click: $xeImagePreview.handleCloseEvent
611
+ }
612
+ }, [
613
+ h('i', {
614
+ class: getIcon().IMAGE_PREVIEW_CLOSE
615
+ })
616
+ ]),
617
+ h('div', {
618
+ class: 'vxe-image-preview--close-bg'
619
+ })
620
+ ]),
621
+ imgList.length > 1
622
+ ? h('div', {
623
+ class: 'vxe-image-preview--previous-btn',
624
+ on: {
625
+ click (evnt: KeyboardEvent) {
626
+ $xeImagePreview.handleChangeEvent(evnt, false)
627
+ }
628
+ }
629
+ }, [
630
+ h('i', {
631
+ class: getIcon().IMAGE_PREVIEW_PREVIOUS
632
+ })
633
+ ])
634
+ : renderEmptyElement($xeImagePreview),
635
+ imgList.length > 1
636
+ ? h('div', {
637
+ class: 'vxe-image-preview--next-btn',
638
+ on: {
639
+ click (evnt: KeyboardEvent) {
640
+ $xeImagePreview.handleChangeEvent(evnt, true)
641
+ }
642
+ }
643
+ }, [
644
+ h('i', {
645
+ class: getIcon().IMAGE_PREVIEW_NEXT
646
+ })
647
+ ])
648
+ : renderEmptyElement($xeImagePreview),
649
+ h('div', {
650
+ class: 'vxe-image-preview--operation-info'
651
+ }, [
652
+ h('div', {
653
+ class: 'vxe-image-preview--operation-deg'
654
+ }, rotateText),
655
+ h('div', {
656
+ class: 'vxe-image-preview--operation-pct'
657
+ }, scaleText)
658
+ ]),
659
+ h('div', {
660
+ class: 'vxe-image-preview--operation-wrapper'
661
+ }, [
662
+ h('div', {
663
+ class: 'vxe-image-preview--operation-active-count'
664
+ }, [
665
+ h('span', {
666
+ class: 'vxe-image-preview--operation-active-current'
667
+ }, `${(activeIndex || 0) + 1}`),
668
+ h('span', {
669
+ class: 'vxe-image-preview--operation-active-total'
670
+ }, `/${imgList.length}`)
671
+ ]),
672
+ $xeImagePreview.renderOperationBtn(h, 'zoomOut', 'IMAGE_PREVIEW_ZOOM_OUT'),
673
+ $xeImagePreview.renderOperationBtn(h, 'zoomIn', 'IMAGE_PREVIEW_ZOOM_IN'),
674
+ $xeImagePreview.renderOperationBtn(h, 'pctFull', 'IMAGE_PREVIEW_PCT_FULL'),
675
+ $xeImagePreview.renderOperationBtn(h, 'pct11', 'IMAGE_PREVIEW_PCT_1_1'),
676
+ $xeImagePreview.renderOperationBtn(h, 'rotateLeft', 'IMAGE_PREVIEW_ROTATE_LEFT'),
677
+ $xeImagePreview.renderOperationBtn(h, 'rotateRight', 'IMAGE_PREVIEW_ROTATE_RIGHT'),
678
+ showPrintButton || toolbarOpts.print ? $xeImagePreview.renderOperationBtn(h, 'print', 'IMAGE_PREVIEW_PRINT') : renderEmptyElement($xeImagePreview),
679
+ showDownloadButton || toolbarOpts.download ? $xeImagePreview.renderOperationBtn(h, 'download', 'IMAGE_PREVIEW_DOWNLOAD') : renderEmptyElement($xeImagePreview)
680
+ ])
681
+ ])
682
+ },
683
+ renderVN (h: CreateElement): VNode {
684
+ const $xeImagePreview = this
685
+ const reactData = $xeImagePreview.reactData
686
+
687
+ const { offsetPct11 } = reactData
688
+ return h('div', {
689
+ ref: 'refElem',
690
+ class: ['vxe-image-preview', {
691
+ 'is--pct11': offsetPct11
692
+ }]
693
+ }, [
694
+ $xeImagePreview.renderImgWrapper(h),
695
+ $xeImagePreview.renderBtnWrapper(h)
696
+ ])
697
+ }
698
+ },
699
+ watch: {
700
+ value (val) {
701
+ const $xeImagePreview = this
702
+ const reactData = $xeImagePreview.reactData
703
+
704
+ reactData.activeIndex = val
705
+ $xeImagePreview.resetStyle()
706
+ }
707
+ },
708
+ created () {
709
+ const $xeImagePreview = this
710
+ const props = $xeImagePreview
711
+ const reactData = $xeImagePreview.reactData
712
+
713
+ reactData.activeIndex = props.value || 0
714
+ },
715
+ mounted () {
716
+ const $xeImagePreview = this
717
+
718
+ const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
719
+ if (elem) {
720
+ elem.addEventListener('wheel', $xeImagePreview.wheelEvent, { passive: false })
721
+ }
722
+ globalEvents.on($xeImagePreview, 'keydown', $xeImagePreview.handleGlobalKeydownEvent)
723
+ },
724
+ beforeDestroy () {
725
+ const $xeImagePreview = this
726
+
727
+ const elem = $xeImagePreview.$refs.refElem as HTMLDivElement
728
+ if (elem) {
729
+ elem.removeEventListener('wheel', $xeImagePreview.wheelEvent)
730
+ removeClass(elem, 'is--move')
731
+ }
732
+ globalEvents.off($xeImagePreview, 'keydown')
733
+ },
734
+ render (this: any, h) {
735
+ return this.renderVN(h)
736
+ }
737
+ }) /* define-vxe-component end */