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,1277 +1,1277 @@
1
- import { CreateElement, VNode, PropType } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { VxeUI, getIcon, getConfig, getI18n, globalEvents, createEvent, globalMixins, renderEmptyElement } from '../../ui'
5
- import { getEventTargetNode, toCssUnit, updatePanelPlacement } from '../../ui/src/dom'
6
- import { getLastZIndex, nextZIndex } from '../../ui/src/utils'
7
- import { parseColor, updateColorAlpha, hexToHsv, rgbToHsv, rgbToHex, hexToRgb, hsvToRgb, toRgb } from './util'
8
- import VxeButtonComponent from '../../button/src/button'
9
- import VxeInputComponent from '../../input/src/input'
10
- import VxeNumberInputComponent from '../../number-input/src/number-input'
11
-
12
- import type { ColorPickerReactData, VxeColorPickerPropTypes, VxeColorPickerEmits, VxeComponentSizeType, ColorPickerInternalData, ValueOf, VxeModalConstructor, VxeModalMethods, VxeDrawerConstructor, VxeDrawerMethods, VxeFormDefines, VxeFormConstructor, VxeFormPrivateMethods } from '../../../types'
13
- import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
14
-
15
- const WinEyeDropper = typeof window !== 'undefined' ? (window as any).EyeDropper : null
16
-
17
- const typeList = [
18
- { label: 'HEX', value: 'hex' },
19
- { label: 'RGB', value: 'rgb' }
20
- ]
21
-
22
- export default /* define-vxe-component start */ defineVxeComponent({
23
- name: 'VxeColorPicker',
24
- mixins: [
25
- globalMixins.sizeMixin
26
- ],
27
- model: {
28
- prop: 'value',
29
- event: 'modelValue'
30
- },
31
- props: {
32
- value: String as PropType<VxeColorPickerPropTypes.ModelValue>,
33
- placeholder: String as PropType<VxeColorPickerPropTypes.Placeholder>,
34
- clearable: {
35
- type: Boolean as PropType<VxeColorPickerPropTypes.Clearable>,
36
- default: () => getConfig().colorPicker.clearable
37
- },
38
- type: {
39
- type: String as PropType<VxeColorPickerPropTypes.Type>,
40
- default: () => getConfig().colorPicker.type
41
- },
42
- size: {
43
- type: String as PropType<VxeColorPickerPropTypes.Size>,
44
- default: () => getConfig().colorPicker.size || getConfig().size
45
- },
46
- className: [String, Function] as PropType<VxeColorPickerPropTypes.ClassName>,
47
- popupClassName: [String, Function] as PropType<VxeColorPickerPropTypes.PopupClassName>,
48
- colors: {
49
- type: Array as PropType<VxeColorPickerPropTypes.Colors>,
50
- default: () => XEUtils.clone(getConfig().colorPicker.colors, true) || []
51
- },
52
- showAlpha: {
53
- type: Boolean as PropType<VxeColorPickerPropTypes.ShowAlpha>,
54
- default: () => getConfig().colorPicker.showAlpha
55
- },
56
- showEyeDropper: {
57
- type: Boolean as PropType<VxeColorPickerPropTypes.ShowEyeDropper>,
58
- default: () => getConfig().colorPicker.showEyeDropper
59
- },
60
- showColorExtractor: {
61
- type: Boolean as PropType<VxeColorPickerPropTypes.ShowColorExtractor>,
62
- default: () => getConfig().colorPicker.showColorExtractor
63
- },
64
- showQuick: {
65
- type: Boolean as PropType<VxeColorPickerPropTypes.ShowQuick>,
66
- default: () => getConfig().colorPicker.showQuick
67
- },
68
- readonly: {
69
- type: Boolean as PropType<VxeColorPickerPropTypes.Readonly>,
70
- default: null
71
- },
72
- disabled: {
73
- type: Boolean as PropType<VxeColorPickerPropTypes.Disabled>,
74
- default: null
75
- },
76
- clickToCopy: {
77
- type: Boolean as PropType<VxeColorPickerPropTypes.ClickToCopy>,
78
- default: () => getConfig().colorPicker.clickToCopy
79
- },
80
- placement: String as PropType<VxeColorPickerPropTypes.Placement>,
81
- transfer: {
82
- type: Boolean as PropType<VxeColorPickerPropTypes.Transfer>,
83
- default: null
84
- }
85
- },
86
- inject: {
87
- $xeModal: {
88
- default: null
89
- },
90
- $xeDrawer: {
91
- default: null
92
- },
93
- $xeTable: {
94
- default: null
95
- },
96
- $xeForm: {
97
- default: null
98
- },
99
- formItemInfo: {
100
- from: 'xeFormItemInfo',
101
- default: null
102
- }
103
- },
104
- provide () {
105
- const $xeColorPicker = this
106
- return {
107
- $xeColorPicker
108
- }
109
- },
110
- data () {
111
- const xID = XEUtils.uniqueId()
112
- const reactData: ColorPickerReactData = {
113
- initialized: false,
114
- selectTyle: 'hex',
115
- selectColor: '',
116
- showTypePopup: false,
117
- panelColor: '',
118
- hexValue: '',
119
- rValue: 0,
120
- gValue: 0,
121
- bValue: 0,
122
- aValue: 0,
123
- panelIndex: 0,
124
- panelStyle: {},
125
- panelPlacement: null,
126
- visiblePanel: false,
127
- isAniVisible: false,
128
- isActivated: false
129
- }
130
- const internalData: ColorPickerInternalData = {
131
- hpTimeout: undefined
132
- }
133
- return {
134
- xID,
135
- reactData,
136
- internalData
137
- }
138
- },
139
- computed: {
140
- ...({} as {
141
- computeSize(): VxeComponentSizeType
142
- $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
143
- $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
144
- $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
145
- $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
146
- formItemInfo(): VxeFormDefines.ProvideItemInfo | null
147
- }),
148
- computeFormReadonly () {
149
- const $xeColorPicker = this
150
- const props = $xeColorPicker
151
- const $xeForm = $xeColorPicker.$xeForm
152
-
153
- const { readonly } = props
154
- if (readonly === null) {
155
- if ($xeForm) {
156
- return $xeForm.readonly
157
- }
158
- return false
159
- }
160
- return readonly
161
- },
162
- computeIsDisabled () {
163
- const $xeColorPicker = this
164
- const props = $xeColorPicker
165
- const $xeForm = $xeColorPicker.$xeForm
166
-
167
- const { disabled } = props
168
- if (disabled === null) {
169
- if ($xeForm) {
170
- return $xeForm.disabled
171
- }
172
- return false
173
- }
174
- return disabled
175
- },
176
- computeBtnTransfer () {
177
- const $xeColorPicker = this
178
- const props = $xeColorPicker
179
- const $xeTable = $xeColorPicker.$xeTable
180
- const $xeModal = $xeColorPicker.$xeModal
181
- const $xeDrawer = $xeColorPicker.$xeDrawer
182
- const $xeForm = $xeColorPicker.$xeForm
183
-
184
- const { transfer } = props
185
- if (transfer === null) {
186
- const globalTransfer = getConfig().colorPicker.transfer
187
- if (XEUtils.isBoolean(globalTransfer)) {
188
- return globalTransfer
189
- }
190
- if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
191
- return true
192
- }
193
- }
194
- return transfer
195
- },
196
- computeColorList () {
197
- const $xeColorPicker = this
198
- const props = $xeColorPicker
199
-
200
- const { colors } = props
201
- if (colors) {
202
- return colors.map(item => {
203
- if (XEUtils.isString(item)) {
204
- return {
205
- label: item,
206
- value: item
207
- }
208
- }
209
- return {
210
- label: XEUtils.eqNull(item.label) ? item.value : item.label,
211
- value: item.value
212
- }
213
- })
214
- }
215
- return []
216
- },
217
- computeIsRgb () {
218
- const $xeColorPicker = this
219
- const reactData = ($xeColorPicker as any).reactData
220
-
221
- const { selectTyle } = reactData
222
- return selectTyle === 'rgb'
223
- },
224
- computeSelectTypeItem () {
225
- const $xeColorPicker = this
226
- const reactData = ($xeColorPicker as any).reactData
227
-
228
- const { selectTyle } = reactData
229
- return typeList.find(item => item.value === selectTyle)
230
- }
231
- },
232
- methods: {
233
- //
234
- // Method
235
- //
236
- dispatchEvent (type: ValueOf<VxeColorPickerEmits>, params: Record<string, any>, evnt: Event | null) {
237
- const $xeColorPicker = this
238
- $xeColorPicker.$emit(type, createEvent(evnt, { $colorPicker: $xeColorPicker }, params))
239
- },
240
- emitModel (value: any) {
241
- const $xeColorPicker = this
242
-
243
- const { _events } = $xeColorPicker as any
244
- if (_events && _events.modelValue) {
245
- $xeColorPicker.$emit('modelValue', value)
246
- } else {
247
- $xeColorPicker.$emit('model-value', value)
248
- }
249
- },
250
- updateMode () {
251
- const $xeColorPicker = this
252
- const props = $xeColorPicker
253
- const reactData = $xeColorPicker.reactData
254
-
255
- const { value } = props
256
- reactData.selectColor = XEUtils.toValueString(value)
257
- $xeColorPicker.updateModelColor()
258
- },
259
- updateType () {
260
- const $xeColorPicker = this
261
- const props = $xeColorPicker
262
- const reactData = $xeColorPicker.reactData
263
-
264
- const { type } = props
265
- let selectTyle: VxeColorPickerPropTypes.Type = 'hex'
266
- if (type === 'rgb' || (type as string) === 'rgba') {
267
- selectTyle = 'rgb'
268
- }
269
- reactData.selectTyle = selectTyle
270
- $xeColorPicker.updateMode()
271
- },
272
- updateModelColor () {
273
- const $xeColorPicker = this
274
- const reactData = $xeColorPicker.reactData
275
-
276
- const { selectColor, isAniVisible } = reactData
277
- const isRgb = $xeColorPicker.computeIsRgb
278
- const hueSliderEl = $xeColorPicker.$refs.refHueSliderElem as HTMLDivElement
279
- const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
280
- const colorRest = parseColor(selectColor)
281
- reactData.hexValue = colorRest.hex
282
- reactData.rValue = colorRest.r
283
- reactData.gValue = colorRest.g
284
- reactData.bValue = colorRest.b
285
- reactData.aValue = colorRest.a
286
- if (colorRest.value) {
287
- if (isRgb) {
288
- if (colorRest.type === 'hex') {
289
- const rgbRest = hexToRgb(colorRest.hex)
290
- if (rgbRest) {
291
- reactData.rValue = rgbRest.r
292
- reactData.gValue = rgbRest.g
293
- reactData.bValue = rgbRest.b
294
- reactData.aValue = rgbRest.a
295
- }
296
- }
297
- } else {
298
- if (colorRest.type !== 'hex') {
299
- reactData.hexValue = rgbToHex(colorRest)
300
- }
301
- }
302
- }
303
- if (isAniVisible) {
304
- const hsvRest = colorRest.type === 'hex' ? hexToHsv(colorRest.hex) : rgbToHsv(colorRest)
305
- const colorPanelEl = $xeColorPicker.$refs.refColorPanelElem as HTMLDivElement
306
- if (hsvRest) {
307
- if (colorPanelEl) {
308
- const offsetTop = colorPanelEl.clientHeight * (1 - hsvRest.v)
309
- const offsetLeft = colorPanelEl.clientWidth * hsvRest.s
310
- $xeColorPicker.handlePanelColor(offsetLeft, offsetTop)
311
- }
312
- if (hueSliderEl) {
313
- $xeColorPicker.handleHueColor(XEUtils.ceil((1 - hsvRest.h / 360) * hueSliderEl.clientWidth))
314
- }
315
- }
316
- if (alphaSliderEl) {
317
- $xeColorPicker.handleAlphaColor(alphaSliderEl.clientWidth * colorRest.a)
318
- }
319
- }
320
- },
321
- updateZindex () {
322
- const $xeColorPicker = this
323
- const reactData = $xeColorPicker.reactData
324
-
325
- if (reactData.panelIndex < getLastZIndex()) {
326
- reactData.panelIndex = nextZIndex()
327
- }
328
- },
329
- updatePlacement () {
330
- const $xeColorPicker = this
331
- const props = $xeColorPicker
332
- const reactData = $xeColorPicker.reactData
333
-
334
- const { placement } = props
335
- const { panelIndex } = reactData
336
- const targetElem = $xeColorPicker.$refs.refElem as HTMLElement
337
- const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLDivElement
338
- const btnTransfer = $xeColorPicker.computeBtnTransfer
339
- const handleStyle = () => {
340
- const ppObj = updatePanelPlacement(targetElem, panelElem, {
341
- placement,
342
- teleportTo: btnTransfer
343
- })
344
- const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
345
- zIndex: panelIndex
346
- })
347
- reactData.panelStyle = panelStyle
348
- reactData.panelPlacement = ppObj.placement
349
- }
350
- handleStyle()
351
- return $xeColorPicker.$nextTick().then(handleStyle)
352
- },
353
- showOptionPanel () {
354
- const $xeColorPicker = this
355
- const reactData = $xeColorPicker.reactData
356
- const internalData = $xeColorPicker.internalData
357
-
358
- const { hpTimeout } = internalData
359
- const isDisabled = $xeColorPicker.computeIsDisabled
360
- if (!isDisabled) {
361
- if (hpTimeout) {
362
- clearTimeout(hpTimeout)
363
- internalData.hpTimeout = undefined
364
- }
365
- const btnTransfer = $xeColorPicker.computeBtnTransfer
366
- const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLElement
367
- if (!reactData.initialized) {
368
- reactData.initialized = true
369
- if (btnTransfer) {
370
- if (panelElem) {
371
- document.body.appendChild(panelElem)
372
- }
373
- }
374
- }
375
- reactData.isActivated = true
376
- reactData.isAniVisible = true
377
- setTimeout(() => {
378
- $xeColorPicker.updateModelColor()
379
- reactData.visiblePanel = true
380
- }, 10)
381
- $xeColorPicker.updateZindex()
382
- $xeColorPicker.updatePlacement()
383
- }
384
- },
385
- hideOptionPanel () {
386
- const $xeColorPicker = this
387
- const reactData = $xeColorPicker.reactData
388
- const internalData = $xeColorPicker.internalData
389
-
390
- reactData.visiblePanel = false
391
- internalData.hpTimeout = setTimeout(() => {
392
- reactData.isAniVisible = false
393
- }, 350)
394
- },
395
- changeEvent (evnt: Event, value: any) {
396
- const $xeColorPicker = this
397
- const props = $xeColorPicker
398
- const reactData = $xeColorPicker.reactData
399
- const $xeForm = $xeColorPicker.$xeForm
400
- const formItemInfo = $xeColorPicker.formItemInfo
401
-
402
- reactData.selectColor = value
403
- if (value !== props.value) {
404
- $xeColorPicker.emitModel(value)
405
- $xeColorPicker.dispatchEvent('change', { value }, evnt)
406
- // 自动更新校验状态
407
- if ($xeForm && formItemInfo) {
408
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
409
- }
410
- }
411
- },
412
- clearValueEvent (evnt: Event, selectValue: any) {
413
- const $xeColorPicker = this
414
-
415
- $xeColorPicker.changeEvent(evnt, selectValue)
416
- $xeColorPicker.dispatchEvent('clear', { value: selectValue }, evnt)
417
- },
418
- focusEvent () {
419
- const $xeColorPicker = this
420
- const reactData = $xeColorPicker.reactData
421
-
422
- const isDisabled = $xeColorPicker.computeIsDisabled
423
- if (!isDisabled) {
424
- if (!reactData.visiblePanel) {
425
- $xeColorPicker.showOptionPanel()
426
- }
427
- }
428
- },
429
- blurEvent () {
430
- const $xeColorPicker = this
431
- const reactData = $xeColorPicker.reactData
432
-
433
- reactData.isActivated = false
434
- },
435
- clearEvent (evnt: Event) {
436
- const $xeColorPicker = this
437
-
438
- $xeColorPicker.clearValueEvent(evnt, null)
439
- $xeColorPicker.hideOptionPanel()
440
- },
441
- confirmEvent (evnt: MouseEvent) {
442
- const $xeColorPicker = this
443
- const reactData = $xeColorPicker.reactData
444
-
445
- const { selectColor } = reactData
446
- $xeColorPicker.changeEvent(evnt, selectColor)
447
- $xeColorPicker.hideOptionPanel()
448
- },
449
- togglePanelEvent (evnt: MouseEvent) {
450
- const $xeColorPicker = this
451
- const reactData = $xeColorPicker.reactData
452
-
453
- evnt.preventDefault()
454
- if (reactData.visiblePanel) {
455
- $xeColorPicker.hideOptionPanel()
456
- } else {
457
- $xeColorPicker.showOptionPanel()
458
- }
459
- },
460
- clickEvent (evnt: MouseEvent) {
461
- const $xeColorPicker = this
462
-
463
- $xeColorPicker.togglePanelEvent(evnt)
464
- $xeColorPicker.dispatchEvent('click', {}, evnt)
465
- },
466
- handlePanelClickEvent () {
467
- const $xeColorPicker = this
468
- const reactData = $xeColorPicker.reactData
469
-
470
- reactData.showTypePopup = false
471
- },
472
- toggleTypeVisibleEvent (evnt: MouseEvent) {
473
- const $xeColorPicker = this
474
- const reactData = $xeColorPicker.reactData
475
-
476
- evnt.stopPropagation()
477
- reactData.showTypePopup = !reactData.showTypePopup
478
- },
479
- handleChangeType (type: VxeColorPickerPropTypes.Type) {
480
- const $xeColorPicker = this
481
- const reactData = $xeColorPicker.reactData
482
-
483
- const { selectTyle } = reactData
484
- if (type !== selectTyle) {
485
- reactData.selectTyle = type
486
- $xeColorPicker.updateModelColor()
487
- }
488
- reactData.showTypePopup = false
489
- },
490
- handleHueColor (offsetLeft: number) {
491
- const $xeColorPicker = this
492
- const reactData = $xeColorPicker.reactData
493
-
494
- const hueSliderEl = $xeColorPicker.$refs.refHueSliderElem as HTMLDivElement
495
- const hueSliderBtnEl = $xeColorPicker.$refs.refHueSliderBtnElem as HTMLDivElement
496
- if (hueSliderEl && hueSliderBtnEl) {
497
- if (offsetLeft < 0) {
498
- offsetLeft = 0
499
- }
500
- const barWidth = XEUtils.toInteger(hueSliderEl.clientWidth)
501
- const itemNum = 255
502
- const countNum = itemNum * 6
503
- const offsetX = XEUtils.ceil(countNum / barWidth * offsetLeft)
504
- const offsetNum = offsetX % itemNum
505
- let rNum = 0
506
- let gNum = 0
507
- let bNum = 0
508
- switch (Math.ceil(offsetX / itemNum)) {
509
- case 1:
510
- rNum = itemNum
511
- bNum = offsetNum
512
- break
513
- case 2:
514
- rNum = itemNum - offsetNum
515
- bNum = itemNum
516
- break
517
- case 3:
518
- gNum = offsetNum
519
- bNum = itemNum
520
- break
521
- case 4:
522
- gNum = itemNum
523
- bNum = itemNum - offsetNum
524
- break
525
- case 5:
526
- rNum = offsetNum
527
- gNum = itemNum
528
- break
529
- case 6:
530
- rNum = itemNum
531
- gNum = itemNum - offsetNum
532
- break
533
- }
534
- reactData.panelColor = toRgb(rNum, gNum, bNum)
535
- hueSliderBtnEl.style.left = toCssUnit(offsetLeft)
536
- }
537
- },
538
- handleHueBarEvent (evnt: MouseEvent) {
539
- const $xeColorPicker = this
540
-
541
- const hueSliderEl = $xeColorPicker.$refs.refHueSliderElem as HTMLDivElement
542
- const hueSliderBtnEl = $xeColorPicker.$refs.refHueSliderBtnElem as HTMLDivElement
543
- if (hueSliderEl && hueSliderBtnEl) {
544
- const hueSliderRect = hueSliderEl.getBoundingClientRect()
545
- const barWidth = XEUtils.toInteger(hueSliderEl.clientWidth)
546
- const offsetLeft = XEUtils.ceil(Math.min(barWidth - 1, Math.max(1, evnt.clientX - hueSliderRect.x)))
547
- $xeColorPicker.handleHueColor(offsetLeft)
548
- }
549
- },
550
- handleHueSliderMousedownEvent (evnt: MouseEvent) {
551
- const $xeColorPicker = this
552
-
553
- evnt.preventDefault()
554
- document.onmousemove = evnt => {
555
- evnt.preventDefault()
556
- $xeColorPicker.handleHueBarEvent(evnt)
557
- }
558
- document.onmouseup = (evnt: MouseEvent) => {
559
- document.onmousemove = null
560
- document.onmouseup = null
561
- $xeColorPicker.handleHueBarEvent(evnt)
562
- }
563
- },
564
- handleAlphaColor (offsetLeft: number) {
565
- const $xeColorPicker = this
566
- const reactData = $xeColorPicker.reactData
567
-
568
- const { selectColor } = reactData
569
- const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
570
- const alphaSliderBtnEl = $xeColorPicker.$refs.refAlphaSliderBtnElem as HTMLDivElement
571
- if (alphaSliderEl && alphaSliderBtnEl) {
572
- const alphaSliderRect = alphaSliderEl.getBoundingClientRect()
573
- const barWidth = alphaSliderRect.width
574
- if (offsetLeft < 0) {
575
- offsetLeft = 0
576
- }
577
- if (offsetLeft > barWidth) {
578
- offsetLeft = barWidth
579
- }
580
- const alpha = XEUtils.ceil(100 / barWidth * offsetLeft / 100, 2)
581
- reactData.aValue = alpha
582
- alphaSliderBtnEl.style.left = toCssUnit(offsetLeft)
583
- reactData.selectColor = updateColorAlpha(selectColor, alpha)
584
- }
585
- },
586
- handleAlphaBarEvent (evnt: MouseEvent) {
587
- const $xeColorPicker = this
588
-
589
- const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
590
- const alphaSliderBtnEl = $xeColorPicker.$refs.refAlphaSliderBtnElem as HTMLDivElement
591
- if (alphaSliderEl && alphaSliderBtnEl) {
592
- const alphaSliderRect = alphaSliderEl.getBoundingClientRect()
593
- const barWidth = alphaSliderRect.width
594
- const offsetLeft = Math.min(barWidth, Math.max(0, evnt.clientX - alphaSliderRect.x))
595
- $xeColorPicker.handleAlphaColor(offsetLeft)
596
- $xeColorPicker.updateModelColor()
597
- }
598
- },
599
- handleAlphaSliderMousedownEvent (evnt: MouseEvent) {
600
- const $xeColorPicker = this
601
-
602
- evnt.preventDefault()
603
- document.onmousemove = evnt => {
604
- evnt.preventDefault()
605
- $xeColorPicker.handleAlphaBarEvent(evnt)
606
- }
607
- document.onmouseup = (evnt: MouseEvent) => {
608
- document.onmousemove = null
609
- document.onmouseup = null
610
- $xeColorPicker.handleAlphaBarEvent(evnt)
611
- }
612
- },
613
- handleInputRgbEvent () {
614
- const $xeColorPicker = this
615
- const reactData = $xeColorPicker.reactData
616
-
617
- const { rValue, gValue, bValue, aValue } = reactData
618
- reactData.selectColor = toRgb(rValue, gValue, bValue, aValue)
619
- $xeColorPicker.updateModelColor()
620
- },
621
- handleInputAlphaEvent () {
622
- const $xeColorPicker = this
623
- const reactData = $xeColorPicker.reactData
624
-
625
- const { aValue } = reactData
626
- const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
627
- const alphaSliderBtnEl = $xeColorPicker.$refs.refAlphaSliderBtnElem as HTMLDivElement
628
- if (alphaSliderEl && alphaSliderBtnEl) {
629
- const alphaSliderRect = alphaSliderEl.getBoundingClientRect()
630
- const barWidth = alphaSliderRect.width
631
- const offsetLeft = barWidth * aValue
632
- $xeColorPicker.handleAlphaColor(offsetLeft)
633
- }
634
- },
635
- handleQuickEvent (evnt: MouseEvent, item: any) {
636
- const $xeColorPicker = this
637
- const reactData = $xeColorPicker.reactData
638
-
639
- const value = item.value
640
- reactData.selectColor = value
641
- $xeColorPicker.updateModelColor()
642
- },
643
- handlePanelColor (offsetLeft: number, offsetTop: number) {
644
- const $xeColorPicker = this
645
-
646
- const colorActiveEl = $xeColorPicker.$refs.refColorActiveElem as HTMLDivElement
647
- if (colorActiveEl) {
648
- colorActiveEl.style.top = toCssUnit(offsetTop)
649
- colorActiveEl.style.left = toCssUnit(offsetLeft)
650
- }
651
- },
652
- handleEyeDropperEvent () {
653
- const $xeColorPicker = this
654
- const reactData = $xeColorPicker.reactData
655
-
656
- if (WinEyeDropper) {
657
- try {
658
- const eyeDropper = new WinEyeDropper()
659
- eyeDropper.open().then((rest: any) => {
660
- if (rest && rest.sRGBHex) {
661
- reactData.selectColor = rest.sRGBHex
662
- $xeColorPicker.updateModelColor()
663
- }
664
- }).catch(() => {
665
- })
666
- } catch (e) {}
667
- }
668
- },
669
- handleSelectColorByXY (clientX: number, clientY: number) {
670
- const $xeColorPicker = this
671
- const props = $xeColorPicker
672
- const reactData = $xeColorPicker.reactData
673
-
674
- const { showAlpha } = props
675
- const { panelColor, aValue } = reactData
676
- const colorPanelEl = $xeColorPicker.$refs.refColorPanelElem as HTMLDivElement
677
- const colorActiveEl = $xeColorPicker.$refs.refColorActiveElem as HTMLDivElement
678
- if (colorPanelEl && colorActiveEl) {
679
- const { clientWidth, clientHeight } = colorPanelEl
680
- const colorPanelRect = colorPanelEl.getBoundingClientRect()
681
- const offsetTop = Math.min(clientHeight, Math.max(0, clientY - colorPanelRect.y))
682
- const offsetLeft = Math.min(clientWidth, Math.max(0, clientX - colorPanelRect.x))
683
- const colorRest = parseColor(panelColor)
684
- if (colorRest) {
685
- const hsvRest = colorRest.type === 'hex' ? hexToHsv(colorRest.hex) : rgbToHsv(colorRest)
686
- if (hsvRest) {
687
- const ragRest = hsvToRgb(hsvRest.h, offsetLeft / clientWidth, (1 - offsetTop / clientHeight))
688
- reactData.selectColor = toRgb(ragRest.r, ragRest.g, ragRest.b, showAlpha ? aValue : null)
689
- $xeColorPicker.handlePanelColor(offsetLeft, offsetTop)
690
- }
691
- }
692
- $xeColorPicker.updateModelColor()
693
- }
694
- },
695
- handleSelectColorMousedownEvent (evnt: MouseEvent) {
696
- const $xeColorPicker = this
697
-
698
- evnt.stopPropagation()
699
- evnt.preventDefault()
700
- $xeColorPicker.handleSelectColorByXY(evnt.clientX, evnt.clientY)
701
- document.onmousemove = evnt => {
702
- $xeColorPicker.handleSelectColorByXY(evnt.clientX, evnt.clientY)
703
- }
704
- document.onmouseup = () => {
705
- document.onmousemove = null
706
- document.onmouseup = null
707
- }
708
- },
709
- handleCopyColorEvent () {
710
- const $xeColorPicker = this
711
- const reactData = $xeColorPicker.reactData
712
-
713
- const { selectColor } = reactData
714
- if (selectColor) {
715
- if (VxeUI.clipboard.copy(selectColor)) {
716
- if (VxeUI.modal) {
717
- VxeUI.modal.message({
718
- content: getI18n('vxe.colorPicker.copySuccess', [selectColor]),
719
- status: 'success'
720
- })
721
- }
722
- }
723
- }
724
- },
725
- handleGlobalMousewheelEvent (evnt: MouseEvent) {
726
- const $xeColorPicker = this
727
- const reactData = $xeColorPicker.reactData
728
-
729
- const { visiblePanel } = reactData
730
- const isDisabled = $xeColorPicker.computeIsDisabled
731
- if (!isDisabled) {
732
- if (visiblePanel) {
733
- const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLDivElement
734
- if (getEventTargetNode(evnt, panelElem).flag) {
735
- $xeColorPicker.updatePlacement()
736
- } else {
737
- $xeColorPicker.hideOptionPanel()
738
- }
739
- }
740
- }
741
- },
742
- handleGlobalMousedownEvent (evnt: MouseEvent) {
743
- const $xeColorPicker = this
744
- const reactData = $xeColorPicker.reactData
745
-
746
- const { visiblePanel } = reactData
747
- const isDisabled = $xeColorPicker.computeIsDisabled
748
- if (!isDisabled) {
749
- const el = $xeColorPicker.$refs.refElem as HTMLDivElement
750
- const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLDivElement
751
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
752
- if (visiblePanel && !reactData.isActivated) {
753
- $xeColorPicker.hideOptionPanel()
754
- }
755
- }
756
- },
757
- handleGlobalBlurEvent () {
758
- const $xeColorPicker = this
759
- const reactData = $xeColorPicker.reactData
760
-
761
- const { visiblePanel, isActivated } = reactData
762
- if (visiblePanel) {
763
- $xeColorPicker.hideOptionPanel()
764
- }
765
- if (isActivated) {
766
- reactData.isActivated = false
767
- }
768
- if (visiblePanel || isActivated) {
769
- const targetElem = $xeColorPicker.$refs.refInputTarget as HTMLInputElement
770
- if (targetElem) {
771
- targetElem.blur()
772
- }
773
- }
774
- },
775
- handleGlobalResizeEvent () {
776
- const $xeColorPicker = this
777
- const reactData = $xeColorPicker.reactData
778
-
779
- const { visiblePanel } = reactData
780
- if (visiblePanel) {
781
- $xeColorPicker.updatePlacement()
782
- }
783
- },
784
-
785
- //
786
- // Render
787
- //
788
- renderColorWrapper (h: CreateElement) {
789
- const $xeColorPicker = this
790
- const props = $xeColorPicker
791
- const reactData = $xeColorPicker.reactData
792
-
793
- const { showColorExtractor } = props
794
- const { panelColor } = reactData
795
- if (showColorExtractor) {
796
- return h('div', {
797
- ref: 'refColorPanelElem',
798
- class: 'vxe-color-picker--color-wrapper',
799
- on: {
800
- mousedown: $xeColorPicker.handleSelectColorMousedownEvent
801
- }
802
- }, [
803
- h('div', {
804
- class: 'vxe-color-picker--color-bg',
805
- style: {
806
- backgroundColor: panelColor
807
- }
808
- }),
809
- h('div', {
810
- class: 'vxe-color-picker--white-bg'
811
- }),
812
- h('div', {
813
- class: 'vxe-color-picker--black-bg'
814
- }),
815
- h('div', {
816
- ref: 'refColorActiveElem',
817
- class: 'vxe-color-picker--color-active'
818
- })
819
- ])
820
- }
821
- return renderEmptyElement($xeColorPicker)
822
- },
823
- renderColorBar (h: CreateElement) {
824
- const $xeColorPicker = this
825
- const props = $xeColorPicker
826
- const reactData = $xeColorPicker.reactData
827
-
828
- const { showAlpha, clickToCopy, showEyeDropper } = props
829
- const { selectTyle, showTypePopup, hexValue, rValue, gValue, bValue, aValue, selectColor, panelColor } = reactData
830
- const isRgb = $xeColorPicker.computeIsRgb
831
- const selectTypeItem = $xeColorPicker.computeSelectTypeItem
832
- return h('div', {
833
- class: 'vxe-color-picker--bar-wrapper'
834
- }, [
835
- h('div', {
836
- class: 'vxe-color-picker--slider-wrapper'
837
- }, [
838
- showEyeDropper && WinEyeDropper
839
- ? h('div', {
840
- class: 'vxe-color-picker--color-dropper'
841
- }, [
842
- h('span', {
843
- class: 'vxe-color-picker--color-dropper-btn',
844
- on: {
845
- click: $xeColorPicker.handleEyeDropperEvent
846
- }
847
- }, [
848
- h('i', {
849
- class: getIcon().COLOR_PICKER_EYE_DROPPER
850
- })
851
- ])
852
- ])
853
- : renderEmptyElement($xeColorPicker),
854
- h('div', {
855
- class: 'vxe-color-picker--slider-preview'
856
- }, [
857
- h('div', {
858
- class: 'vxe-color-picker--preview-btn'
859
- }, [
860
- h('div', {
861
- class: 'vxe-color-picker--preview-color',
862
- style: {
863
- backgroundColor: selectColor
864
- }
865
- }, clickToCopy
866
- ? [
867
- h('span', {
868
- class: 'vxe-color-picker--preview-copy-btn',
869
- on: {
870
- click: $xeColorPicker.handleCopyColorEvent
871
- }
872
- }, [
873
- h('i', {
874
- class: getIcon().COLOR_PICKER_COLOR_COPY
875
- })
876
- ])
877
- ]
878
- : [])
879
- ])
880
- ]),
881
- h('div', {
882
- class: 'vxe-color-picker--slider-handle'
883
- }, [
884
- h('div', {
885
- ref: 'refHueSliderElem',
886
- class: 'vxe-color-picker--bar-hue-slider',
887
- on: {
888
- click: $xeColorPicker.handleHueBarEvent
889
- }
890
- }, [
891
- h('div', {
892
- ref: 'refHueSliderBtnElem',
893
- class: 'vxe-color-picker--bar-hue-btn',
894
- on: {
895
- mousedown: $xeColorPicker.handleHueSliderMousedownEvent
896
- }
897
- })
898
- ]),
899
- showAlpha
900
- ? h('div', {
901
- ref: 'refAlphaSliderElem',
902
- class: 'vxe-color-picker--bar-alpha-slider',
903
- on: {
904
- click: $xeColorPicker.handleAlphaBarEvent
905
- }
906
- }, [
907
- h('div', {
908
- class: 'vxe-color-picker--bar-alpha-bg',
909
- style: {
910
- background: `linear-gradient(to right, rgba(0, 0, 0, 0), ${panelColor})`
911
- }
912
- }),
913
- h('div', {
914
- ref: 'refAlphaSliderBtnElem',
915
- class: 'vxe-color-picker--bar-alpha-btn',
916
- on: {
917
- mousedown: $xeColorPicker.handleAlphaSliderMousedownEvent
918
- }
919
- })
920
- ])
921
- : renderEmptyElement($xeColorPicker)
922
- ])
923
- ]),
924
- h('div', {
925
- class: 'vxe-color-picker--custom-wrapper'
926
- }, [
927
- h('div', {
928
- class: 'vxe-color-picker--type-switch'
929
- }, [
930
- h('div', {
931
- class: 'vxe-color-picker--type-label',
932
- on: {
933
- click: $xeColorPicker.toggleTypeVisibleEvent
934
- }
935
- }, [
936
- h('span', `${selectTypeItem ? selectTypeItem.label : selectTyle}`),
937
- h('span', {
938
- class: 'vxe-color-picker--type-icon'
939
- }, [
940
- h('i', {
941
- class: showTypePopup ? getIcon().COLOR_PICKER_TPTY_OPEN : getIcon().COLOR_PICKER_TPTY_CLOSE
942
- })
943
- ])
944
- ]),
945
- h('div', {
946
- class: ['vxe-color-picker--type-popup', {
947
- 'is--visible': showTypePopup
948
- }]
949
- }, typeList.map(item => {
950
- return h('div', {
951
- class: 'vxe-color-picker--type-item',
952
- on: {
953
- click (evnt: KeyboardEvent) {
954
- evnt.stopPropagation()
955
- $xeColorPicker.handleChangeType(item.value as VxeColorPickerPropTypes.Type)
956
- }
957
- }
958
- }, item.label)
959
- }))
960
- ]),
961
- h('div', {
962
- class: `vxe-color-picker--${selectTyle}-wrapper`
963
- }, isRgb
964
- ? [
965
- h('div', {
966
- class: 'vxe-color-picker--input-wrapper'
967
- }, [
968
- h(VxeNumberInputComponent, {
969
- props: {
970
- type: 'integer',
971
- size: 'mini',
972
- align: 'center',
973
- min: 0,
974
- max: 255,
975
- maxLength: 3,
976
- placeholder: '',
977
- value: rValue,
978
- controlConfig: {
979
- showButton: false
980
- }
981
- },
982
- on: {
983
- 'modelValue' (val: any) {
984
- reactData.rValue = val
985
- },
986
- change: $xeColorPicker.handleInputRgbEvent
987
- }
988
- }),
989
- h(VxeNumberInputComponent, {
990
- props: {
991
- type: 'integer',
992
- size: 'mini',
993
- align: 'center',
994
- min: 0,
995
- max: 255,
996
- maxLength: 3,
997
- placeholder: '',
998
- value: gValue,
999
- controlConfig: {
1000
- showButton: false
1001
- }
1002
- },
1003
- on: {
1004
- 'modelValue' (val: any) {
1005
- reactData.gValue = val
1006
- },
1007
- change: $xeColorPicker.handleInputRgbEvent
1008
- }
1009
- }),
1010
- h(VxeNumberInputComponent, {
1011
- props: {
1012
- type: 'integer',
1013
- size: 'mini',
1014
- align: 'center',
1015
- min: 0,
1016
- max: 255,
1017
- maxLength: 3,
1018
- placeholder: '',
1019
- value: bValue,
1020
- controlConfig: {
1021
- showButton: false
1022
- }
1023
- },
1024
- on: {
1025
- 'modelValue' (val: any) {
1026
- reactData.bValue = val
1027
- },
1028
- change: $xeColorPicker.handleInputRgbEvent
1029
- }
1030
- }),
1031
- h(VxeNumberInputComponent, {
1032
- props: {
1033
- type: 'number',
1034
- size: 'mini',
1035
- align: 'center',
1036
- min: 0,
1037
- max: 1,
1038
- step: 0.01,
1039
- maxLength: 4,
1040
- placeholder: '',
1041
- value: aValue,
1042
- controlConfig: {
1043
- showButton: false
1044
- }
1045
- },
1046
- on: {
1047
- 'modelValue' (val: any) {
1048
- reactData.aValue = val
1049
- },
1050
- change: $xeColorPicker.handleInputAlphaEvent
1051
- }
1052
- })
1053
- ]),
1054
- h('div', {
1055
- class: 'vxe-color-picker--input-title'
1056
- }, [
1057
- h('span', 'R'),
1058
- h('span', 'G'),
1059
- h('span', 'B'),
1060
- h('span', 'A')
1061
- ])]
1062
- : [
1063
- h('div', {
1064
- class: 'vxe-color-picker--input-wrapper'
1065
- }, [
1066
- h(VxeInputComponent, {
1067
- props: {
1068
- type: 'text',
1069
- size: 'mini',
1070
- align: 'center',
1071
- maxLength: 9,
1072
- placeholder: '',
1073
- value: hexValue
1074
- },
1075
- on: {
1076
- 'modelValue' (val: any) {
1077
- reactData.hexValue = val
1078
- },
1079
- change () {
1080
- const colorRest = parseColor(reactData.hexValue)
1081
- if (colorRest) {
1082
- if (colorRest.value) {
1083
- reactData.selectColor = colorRest.value
1084
- $xeColorPicker.updateModelColor()
1085
- }
1086
- }
1087
- }
1088
- }
1089
- })
1090
- ]),
1091
- h('div', {
1092
- class: 'vxe-color-picker--input-title'
1093
- }, getI18n('vxe.colorPicker.hex'))
1094
- ])
1095
- ])
1096
- ])
1097
- },
1098
- renderQuickWrapper (h: CreateElement) {
1099
- const $xeColorPicker = this
1100
- const props = $xeColorPicker
1101
-
1102
- const { showQuick } = props
1103
- const colorList = $xeColorPicker.computeColorList
1104
- if (showQuick && colorList.length) {
1105
- return h('div', {
1106
- class: 'vxe-color-picker--quick-wrapper'
1107
- }, colorList.map((item, i) => {
1108
- return h('div', {
1109
- key: i,
1110
- class: 'vxe-color-picker--quick-item',
1111
- attrs: {
1112
- title: item.label || ''
1113
- },
1114
- style: {
1115
- backgroundColor: item.value
1116
- },
1117
- on: {
1118
- click (evnt: MouseEvent) {
1119
- $xeColorPicker.handleQuickEvent(evnt, item)
1120
- }
1121
- }
1122
- })
1123
- }))
1124
- }
1125
- return renderEmptyElement($xeColorPicker)
1126
- },
1127
- renderVN (h: CreateElement): VNode {
1128
- const $xeColorPicker = this
1129
- const props = $xeColorPicker
1130
- const reactData = $xeColorPicker.reactData
1131
-
1132
- const { className, popupClassName, clearable, value } = props
1133
- const { initialized, isActivated, isAniVisible, visiblePanel } = reactData
1134
- const vSize = $xeColorPicker.computeSize
1135
- const isDisabled = $xeColorPicker.computeIsDisabled
1136
- const btnTransfer = $xeColorPicker.computeBtnTransfer
1137
- const formReadonly = $xeColorPicker.computeFormReadonly
1138
-
1139
- if (formReadonly) {
1140
- return h('div', {
1141
- ref: 'refElem',
1142
- class: ['vxe-color-picker--readonly', className]
1143
- }, [
1144
- h('div', {
1145
- class: 'vxe-color-picker--readonly-color',
1146
- style: {
1147
- backgroundColor: value
1148
- }
1149
- })
1150
- ])
1151
- }
1152
- return h('div', {
1153
- ref: 'refElem',
1154
- class: ['vxe-color-picker', className ? (XEUtils.isFunction(className) ? className({ $colorPicker: $xeColorPicker }) : className) : '', {
1155
- [`size--${vSize}`]: vSize,
1156
- 'is--selected': !!value,
1157
- 'is--visible': visiblePanel,
1158
- 'is--disabled': isDisabled,
1159
- 'is--active': isActivated
1160
- }]
1161
- }, [
1162
- h('input', {
1163
- ref: 'refInputTarget',
1164
- class: 'vxe-color-picker--input',
1165
- on: {
1166
- focus: $xeColorPicker.focusEvent,
1167
- blur: $xeColorPicker.blurEvent
1168
- }
1169
- }),
1170
- h('div', {
1171
- class: 'vxe-color-picker--inner',
1172
- on: {
1173
- click: $xeColorPicker.clickEvent
1174
- }
1175
- }, [
1176
- h('div', {
1177
- class: 'vxe-color-picker--inner-color',
1178
- style: {
1179
- backgroundColor: value
1180
- }
1181
- })
1182
- ]),
1183
- h('div', {
1184
- ref: 'refOptionPanel',
1185
- class: ['vxe-table--ignore-clear vxe-color-picker--panel', popupClassName ? (XEUtils.isFunction(popupClassName) ? popupClassName({ $colorPicker: $xeColorPicker }) : popupClassName) : '', {
1186
- [`size--${vSize}`]: vSize,
1187
- 'is--transfer': btnTransfer,
1188
- 'ani--leave': isAniVisible,
1189
- 'ani--enter': visiblePanel
1190
- }],
1191
- attrs: {
1192
- placement: reactData.panelPlacement
1193
- },
1194
- style: reactData.panelStyle
1195
- }, [
1196
- initialized && (visiblePanel || isAniVisible)
1197
- ? h('div', {
1198
- class: 'vxe-color-picker--panel-wrapper',
1199
- on: {
1200
- click: $xeColorPicker.handlePanelClickEvent
1201
- }
1202
- }, [
1203
- $xeColorPicker.renderColorWrapper(h),
1204
- $xeColorPicker.renderColorBar(h),
1205
- $xeColorPicker.renderQuickWrapper(h),
1206
- h('div', {
1207
- class: 'vxe-color-picker--footer-wrapper'
1208
- }, [
1209
- clearable
1210
- ? h(VxeButtonComponent, {
1211
- props: {
1212
- content: getI18n('vxe.colorPicker.clear'),
1213
- size: 'mini'
1214
- },
1215
- on: {
1216
- click: $xeColorPicker.clearEvent
1217
- }
1218
- })
1219
- : renderEmptyElement($xeColorPicker),
1220
- h(VxeButtonComponent, {
1221
- props: {
1222
- content: getI18n('vxe.colorPicker.confirm'),
1223
- size: 'mini',
1224
- status: 'primary'
1225
- },
1226
- on: {
1227
- click: $xeColorPicker.confirmEvent
1228
- }
1229
- })
1230
- ])
1231
- ])
1232
- : renderEmptyElement($xeColorPicker)
1233
- ])
1234
- ])
1235
- }
1236
- },
1237
- watch: {
1238
- value () {
1239
- const $xeColorPicker = this
1240
-
1241
- $xeColorPicker.updateMode()
1242
- },
1243
- type () {
1244
- const $xeColorPicker = this
1245
-
1246
- $xeColorPicker.updateType()
1247
- }
1248
- },
1249
- created () {
1250
- const $xeColorPicker = this
1251
- const props = $xeColorPicker
1252
- const reactData = $xeColorPicker.reactData
1253
-
1254
- reactData.selectColor = `${props.value || ''}`
1255
- $xeColorPicker.updateType()
1256
-
1257
- globalEvents.on($xeColorPicker, 'mousewheel', $xeColorPicker.handleGlobalMousewheelEvent)
1258
- globalEvents.on($xeColorPicker, 'mousedown', $xeColorPicker.handleGlobalMousedownEvent)
1259
- globalEvents.on($xeColorPicker, 'blur', $xeColorPicker.handleGlobalBlurEvent)
1260
- globalEvents.on($xeColorPicker, 'resize', $xeColorPicker.handleGlobalResizeEvent)
1261
- },
1262
- beforeDestroy () {
1263
- const $xeColorPicker = this
1264
-
1265
- const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLElement | undefined
1266
- if (panelElem && panelElem.parentNode) {
1267
- panelElem.parentNode.removeChild(panelElem)
1268
- }
1269
- globalEvents.off($xeColorPicker, 'mousewheel')
1270
- globalEvents.off($xeColorPicker, 'mousedown')
1271
- globalEvents.off($xeColorPicker, 'blur')
1272
- globalEvents.off($xeColorPicker, 'resize')
1273
- },
1274
- render (this: any, h) {
1275
- return this.renderVN(h)
1276
- }
1277
- }) /* define-vxe-component end */
1
+ import { CreateElement, VNode, PropType } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { VxeUI, getIcon, getConfig, getI18n, globalEvents, createEvent, globalMixins, renderEmptyElement } from '../../ui'
5
+ import { getEventTargetNode, toCssUnit, updatePanelPlacement } from '../../ui/src/dom'
6
+ import { getLastZIndex, nextZIndex } from '../../ui/src/utils'
7
+ import { parseColor, updateColorAlpha, hexToHsv, rgbToHsv, rgbToHex, hexToRgb, hsvToRgb, toRgb } from './util'
8
+ import VxeButtonComponent from '../../button/src/button'
9
+ import VxeInputComponent from '../../input/src/input'
10
+ import VxeNumberInputComponent from '../../number-input/src/number-input'
11
+
12
+ import type { ColorPickerReactData, VxeColorPickerPropTypes, VxeColorPickerEmits, VxeComponentSizeType, ColorPickerInternalData, ValueOf, VxeModalConstructor, VxeModalMethods, VxeDrawerConstructor, VxeDrawerMethods, VxeFormDefines, VxeFormConstructor, VxeFormPrivateMethods } from '../../../types'
13
+ import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
14
+
15
+ const WinEyeDropper = typeof window !== 'undefined' ? (window as any).EyeDropper : null
16
+
17
+ const typeList = [
18
+ { label: 'HEX', value: 'hex' },
19
+ { label: 'RGB', value: 'rgb' }
20
+ ]
21
+
22
+ export default /* define-vxe-component start */ defineVxeComponent({
23
+ name: 'VxeColorPicker',
24
+ mixins: [
25
+ globalMixins.sizeMixin
26
+ ],
27
+ model: {
28
+ prop: 'value',
29
+ event: 'modelValue'
30
+ },
31
+ props: {
32
+ value: String as PropType<VxeColorPickerPropTypes.ModelValue>,
33
+ placeholder: String as PropType<VxeColorPickerPropTypes.Placeholder>,
34
+ clearable: {
35
+ type: Boolean as PropType<VxeColorPickerPropTypes.Clearable>,
36
+ default: () => getConfig().colorPicker.clearable
37
+ },
38
+ type: {
39
+ type: String as PropType<VxeColorPickerPropTypes.Type>,
40
+ default: () => getConfig().colorPicker.type
41
+ },
42
+ size: {
43
+ type: String as PropType<VxeColorPickerPropTypes.Size>,
44
+ default: () => getConfig().colorPicker.size || getConfig().size
45
+ },
46
+ className: [String, Function] as PropType<VxeColorPickerPropTypes.ClassName>,
47
+ popupClassName: [String, Function] as PropType<VxeColorPickerPropTypes.PopupClassName>,
48
+ colors: {
49
+ type: Array as PropType<VxeColorPickerPropTypes.Colors>,
50
+ default: () => XEUtils.clone(getConfig().colorPicker.colors, true) || []
51
+ },
52
+ showAlpha: {
53
+ type: Boolean as PropType<VxeColorPickerPropTypes.ShowAlpha>,
54
+ default: () => getConfig().colorPicker.showAlpha
55
+ },
56
+ showEyeDropper: {
57
+ type: Boolean as PropType<VxeColorPickerPropTypes.ShowEyeDropper>,
58
+ default: () => getConfig().colorPicker.showEyeDropper
59
+ },
60
+ showColorExtractor: {
61
+ type: Boolean as PropType<VxeColorPickerPropTypes.ShowColorExtractor>,
62
+ default: () => getConfig().colorPicker.showColorExtractor
63
+ },
64
+ showQuick: {
65
+ type: Boolean as PropType<VxeColorPickerPropTypes.ShowQuick>,
66
+ default: () => getConfig().colorPicker.showQuick
67
+ },
68
+ readonly: {
69
+ type: Boolean as PropType<VxeColorPickerPropTypes.Readonly>,
70
+ default: null
71
+ },
72
+ disabled: {
73
+ type: Boolean as PropType<VxeColorPickerPropTypes.Disabled>,
74
+ default: null
75
+ },
76
+ clickToCopy: {
77
+ type: Boolean as PropType<VxeColorPickerPropTypes.ClickToCopy>,
78
+ default: () => getConfig().colorPicker.clickToCopy
79
+ },
80
+ placement: String as PropType<VxeColorPickerPropTypes.Placement>,
81
+ transfer: {
82
+ type: Boolean as PropType<VxeColorPickerPropTypes.Transfer>,
83
+ default: null
84
+ }
85
+ },
86
+ inject: {
87
+ $xeModal: {
88
+ default: null
89
+ },
90
+ $xeDrawer: {
91
+ default: null
92
+ },
93
+ $xeTable: {
94
+ default: null
95
+ },
96
+ $xeForm: {
97
+ default: null
98
+ },
99
+ formItemInfo: {
100
+ from: 'xeFormItemInfo',
101
+ default: null
102
+ }
103
+ },
104
+ provide () {
105
+ const $xeColorPicker = this
106
+ return {
107
+ $xeColorPicker
108
+ }
109
+ },
110
+ data () {
111
+ const xID = XEUtils.uniqueId()
112
+ const reactData: ColorPickerReactData = {
113
+ initialized: false,
114
+ selectTyle: 'hex',
115
+ selectColor: '',
116
+ showTypePopup: false,
117
+ panelColor: '',
118
+ hexValue: '',
119
+ rValue: 0,
120
+ gValue: 0,
121
+ bValue: 0,
122
+ aValue: 0,
123
+ panelIndex: 0,
124
+ panelStyle: {},
125
+ panelPlacement: null,
126
+ visiblePanel: false,
127
+ isAniVisible: false,
128
+ isActivated: false
129
+ }
130
+ const internalData: ColorPickerInternalData = {
131
+ hpTimeout: undefined
132
+ }
133
+ return {
134
+ xID,
135
+ reactData,
136
+ internalData
137
+ }
138
+ },
139
+ computed: {
140
+ ...({} as {
141
+ computeSize(): VxeComponentSizeType
142
+ $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
143
+ $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
144
+ $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
145
+ $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
146
+ formItemInfo(): VxeFormDefines.ProvideItemInfo | null
147
+ }),
148
+ computeFormReadonly () {
149
+ const $xeColorPicker = this
150
+ const props = $xeColorPicker
151
+ const $xeForm = $xeColorPicker.$xeForm
152
+
153
+ const { readonly } = props
154
+ if (readonly === null) {
155
+ if ($xeForm) {
156
+ return $xeForm.readonly
157
+ }
158
+ return false
159
+ }
160
+ return readonly
161
+ },
162
+ computeIsDisabled () {
163
+ const $xeColorPicker = this
164
+ const props = $xeColorPicker
165
+ const $xeForm = $xeColorPicker.$xeForm
166
+
167
+ const { disabled } = props
168
+ if (disabled === null) {
169
+ if ($xeForm) {
170
+ return $xeForm.disabled
171
+ }
172
+ return false
173
+ }
174
+ return disabled
175
+ },
176
+ computeBtnTransfer () {
177
+ const $xeColorPicker = this
178
+ const props = $xeColorPicker
179
+ const $xeTable = $xeColorPicker.$xeTable
180
+ const $xeModal = $xeColorPicker.$xeModal
181
+ const $xeDrawer = $xeColorPicker.$xeDrawer
182
+ const $xeForm = $xeColorPicker.$xeForm
183
+
184
+ const { transfer } = props
185
+ if (transfer === null) {
186
+ const globalTransfer = getConfig().colorPicker.transfer
187
+ if (XEUtils.isBoolean(globalTransfer)) {
188
+ return globalTransfer
189
+ }
190
+ if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
191
+ return true
192
+ }
193
+ }
194
+ return transfer
195
+ },
196
+ computeColorList () {
197
+ const $xeColorPicker = this
198
+ const props = $xeColorPicker
199
+
200
+ const { colors } = props
201
+ if (colors) {
202
+ return colors.map(item => {
203
+ if (XEUtils.isString(item)) {
204
+ return {
205
+ label: item,
206
+ value: item
207
+ }
208
+ }
209
+ return {
210
+ label: XEUtils.eqNull(item.label) ? item.value : item.label,
211
+ value: item.value
212
+ }
213
+ })
214
+ }
215
+ return []
216
+ },
217
+ computeIsRgb () {
218
+ const $xeColorPicker = this
219
+ const reactData = ($xeColorPicker as any).reactData
220
+
221
+ const { selectTyle } = reactData
222
+ return selectTyle === 'rgb'
223
+ },
224
+ computeSelectTypeItem () {
225
+ const $xeColorPicker = this
226
+ const reactData = ($xeColorPicker as any).reactData
227
+
228
+ const { selectTyle } = reactData
229
+ return typeList.find(item => item.value === selectTyle)
230
+ }
231
+ },
232
+ methods: {
233
+ //
234
+ // Method
235
+ //
236
+ dispatchEvent (type: ValueOf<VxeColorPickerEmits>, params: Record<string, any>, evnt: Event | null) {
237
+ const $xeColorPicker = this
238
+ $xeColorPicker.$emit(type, createEvent(evnt, { $colorPicker: $xeColorPicker }, params))
239
+ },
240
+ emitModel (value: any) {
241
+ const $xeColorPicker = this
242
+
243
+ const { _events } = $xeColorPicker as any
244
+ if (_events && _events.modelValue) {
245
+ $xeColorPicker.$emit('modelValue', value)
246
+ } else {
247
+ $xeColorPicker.$emit('model-value', value)
248
+ }
249
+ },
250
+ updateMode () {
251
+ const $xeColorPicker = this
252
+ const props = $xeColorPicker
253
+ const reactData = $xeColorPicker.reactData
254
+
255
+ const { value } = props
256
+ reactData.selectColor = XEUtils.toValueString(value)
257
+ $xeColorPicker.updateModelColor()
258
+ },
259
+ updateType () {
260
+ const $xeColorPicker = this
261
+ const props = $xeColorPicker
262
+ const reactData = $xeColorPicker.reactData
263
+
264
+ const { type } = props
265
+ let selectTyle: VxeColorPickerPropTypes.Type = 'hex'
266
+ if (type === 'rgb' || (type as string) === 'rgba') {
267
+ selectTyle = 'rgb'
268
+ }
269
+ reactData.selectTyle = selectTyle
270
+ $xeColorPicker.updateMode()
271
+ },
272
+ updateModelColor () {
273
+ const $xeColorPicker = this
274
+ const reactData = $xeColorPicker.reactData
275
+
276
+ const { selectColor, isAniVisible } = reactData
277
+ const isRgb = $xeColorPicker.computeIsRgb
278
+ const hueSliderEl = $xeColorPicker.$refs.refHueSliderElem as HTMLDivElement
279
+ const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
280
+ const colorRest = parseColor(selectColor)
281
+ reactData.hexValue = colorRest.hex
282
+ reactData.rValue = colorRest.r
283
+ reactData.gValue = colorRest.g
284
+ reactData.bValue = colorRest.b
285
+ reactData.aValue = colorRest.a
286
+ if (colorRest.value) {
287
+ if (isRgb) {
288
+ if (colorRest.type === 'hex') {
289
+ const rgbRest = hexToRgb(colorRest.hex)
290
+ if (rgbRest) {
291
+ reactData.rValue = rgbRest.r
292
+ reactData.gValue = rgbRest.g
293
+ reactData.bValue = rgbRest.b
294
+ reactData.aValue = rgbRest.a
295
+ }
296
+ }
297
+ } else {
298
+ if (colorRest.type !== 'hex') {
299
+ reactData.hexValue = rgbToHex(colorRest)
300
+ }
301
+ }
302
+ }
303
+ if (isAniVisible) {
304
+ const hsvRest = colorRest.type === 'hex' ? hexToHsv(colorRest.hex) : rgbToHsv(colorRest)
305
+ const colorPanelEl = $xeColorPicker.$refs.refColorPanelElem as HTMLDivElement
306
+ if (hsvRest) {
307
+ if (colorPanelEl) {
308
+ const offsetTop = colorPanelEl.clientHeight * (1 - hsvRest.v)
309
+ const offsetLeft = colorPanelEl.clientWidth * hsvRest.s
310
+ $xeColorPicker.handlePanelColor(offsetLeft, offsetTop)
311
+ }
312
+ if (hueSliderEl) {
313
+ $xeColorPicker.handleHueColor(XEUtils.ceil((1 - hsvRest.h / 360) * hueSliderEl.clientWidth))
314
+ }
315
+ }
316
+ if (alphaSliderEl) {
317
+ $xeColorPicker.handleAlphaColor(alphaSliderEl.clientWidth * colorRest.a)
318
+ }
319
+ }
320
+ },
321
+ updateZindex () {
322
+ const $xeColorPicker = this
323
+ const reactData = $xeColorPicker.reactData
324
+
325
+ if (reactData.panelIndex < getLastZIndex()) {
326
+ reactData.panelIndex = nextZIndex()
327
+ }
328
+ },
329
+ updatePlacement () {
330
+ const $xeColorPicker = this
331
+ const props = $xeColorPicker
332
+ const reactData = $xeColorPicker.reactData
333
+
334
+ const { placement } = props
335
+ const { panelIndex } = reactData
336
+ const targetElem = $xeColorPicker.$refs.refElem as HTMLElement
337
+ const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLDivElement
338
+ const btnTransfer = $xeColorPicker.computeBtnTransfer
339
+ const handleStyle = () => {
340
+ const ppObj = updatePanelPlacement(targetElem, panelElem, {
341
+ placement,
342
+ teleportTo: btnTransfer
343
+ })
344
+ const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
345
+ zIndex: panelIndex
346
+ })
347
+ reactData.panelStyle = panelStyle
348
+ reactData.panelPlacement = ppObj.placement
349
+ }
350
+ handleStyle()
351
+ return $xeColorPicker.$nextTick().then(handleStyle)
352
+ },
353
+ showOptionPanel () {
354
+ const $xeColorPicker = this
355
+ const reactData = $xeColorPicker.reactData
356
+ const internalData = $xeColorPicker.internalData
357
+
358
+ const { hpTimeout } = internalData
359
+ const isDisabled = $xeColorPicker.computeIsDisabled
360
+ if (!isDisabled) {
361
+ if (hpTimeout) {
362
+ clearTimeout(hpTimeout)
363
+ internalData.hpTimeout = undefined
364
+ }
365
+ const btnTransfer = $xeColorPicker.computeBtnTransfer
366
+ const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLElement
367
+ if (!reactData.initialized) {
368
+ reactData.initialized = true
369
+ if (btnTransfer) {
370
+ if (panelElem) {
371
+ document.body.appendChild(panelElem)
372
+ }
373
+ }
374
+ }
375
+ reactData.isActivated = true
376
+ reactData.isAniVisible = true
377
+ setTimeout(() => {
378
+ $xeColorPicker.updateModelColor()
379
+ reactData.visiblePanel = true
380
+ }, 10)
381
+ $xeColorPicker.updateZindex()
382
+ $xeColorPicker.updatePlacement()
383
+ }
384
+ },
385
+ hideOptionPanel () {
386
+ const $xeColorPicker = this
387
+ const reactData = $xeColorPicker.reactData
388
+ const internalData = $xeColorPicker.internalData
389
+
390
+ reactData.visiblePanel = false
391
+ internalData.hpTimeout = setTimeout(() => {
392
+ reactData.isAniVisible = false
393
+ }, 350)
394
+ },
395
+ changeEvent (evnt: Event, value: any) {
396
+ const $xeColorPicker = this
397
+ const props = $xeColorPicker
398
+ const reactData = $xeColorPicker.reactData
399
+ const $xeForm = $xeColorPicker.$xeForm
400
+ const formItemInfo = $xeColorPicker.formItemInfo
401
+
402
+ reactData.selectColor = value
403
+ if (value !== props.value) {
404
+ $xeColorPicker.emitModel(value)
405
+ $xeColorPicker.dispatchEvent('change', { value }, evnt)
406
+ // 自动更新校验状态
407
+ if ($xeForm && formItemInfo) {
408
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
409
+ }
410
+ }
411
+ },
412
+ clearValueEvent (evnt: Event, selectValue: any) {
413
+ const $xeColorPicker = this
414
+
415
+ $xeColorPicker.changeEvent(evnt, selectValue)
416
+ $xeColorPicker.dispatchEvent('clear', { value: selectValue }, evnt)
417
+ },
418
+ focusEvent () {
419
+ const $xeColorPicker = this
420
+ const reactData = $xeColorPicker.reactData
421
+
422
+ const isDisabled = $xeColorPicker.computeIsDisabled
423
+ if (!isDisabled) {
424
+ if (!reactData.visiblePanel) {
425
+ $xeColorPicker.showOptionPanel()
426
+ }
427
+ }
428
+ },
429
+ blurEvent () {
430
+ const $xeColorPicker = this
431
+ const reactData = $xeColorPicker.reactData
432
+
433
+ reactData.isActivated = false
434
+ },
435
+ clearEvent (evnt: Event) {
436
+ const $xeColorPicker = this
437
+
438
+ $xeColorPicker.clearValueEvent(evnt, null)
439
+ $xeColorPicker.hideOptionPanel()
440
+ },
441
+ confirmEvent (evnt: MouseEvent) {
442
+ const $xeColorPicker = this
443
+ const reactData = $xeColorPicker.reactData
444
+
445
+ const { selectColor } = reactData
446
+ $xeColorPicker.changeEvent(evnt, selectColor)
447
+ $xeColorPicker.hideOptionPanel()
448
+ },
449
+ togglePanelEvent (evnt: MouseEvent) {
450
+ const $xeColorPicker = this
451
+ const reactData = $xeColorPicker.reactData
452
+
453
+ evnt.preventDefault()
454
+ if (reactData.visiblePanel) {
455
+ $xeColorPicker.hideOptionPanel()
456
+ } else {
457
+ $xeColorPicker.showOptionPanel()
458
+ }
459
+ },
460
+ clickEvent (evnt: MouseEvent) {
461
+ const $xeColorPicker = this
462
+
463
+ $xeColorPicker.togglePanelEvent(evnt)
464
+ $xeColorPicker.dispatchEvent('click', {}, evnt)
465
+ },
466
+ handlePanelClickEvent () {
467
+ const $xeColorPicker = this
468
+ const reactData = $xeColorPicker.reactData
469
+
470
+ reactData.showTypePopup = false
471
+ },
472
+ toggleTypeVisibleEvent (evnt: MouseEvent) {
473
+ const $xeColorPicker = this
474
+ const reactData = $xeColorPicker.reactData
475
+
476
+ evnt.stopPropagation()
477
+ reactData.showTypePopup = !reactData.showTypePopup
478
+ },
479
+ handleChangeType (type: VxeColorPickerPropTypes.Type) {
480
+ const $xeColorPicker = this
481
+ const reactData = $xeColorPicker.reactData
482
+
483
+ const { selectTyle } = reactData
484
+ if (type !== selectTyle) {
485
+ reactData.selectTyle = type
486
+ $xeColorPicker.updateModelColor()
487
+ }
488
+ reactData.showTypePopup = false
489
+ },
490
+ handleHueColor (offsetLeft: number) {
491
+ const $xeColorPicker = this
492
+ const reactData = $xeColorPicker.reactData
493
+
494
+ const hueSliderEl = $xeColorPicker.$refs.refHueSliderElem as HTMLDivElement
495
+ const hueSliderBtnEl = $xeColorPicker.$refs.refHueSliderBtnElem as HTMLDivElement
496
+ if (hueSliderEl && hueSliderBtnEl) {
497
+ if (offsetLeft < 0) {
498
+ offsetLeft = 0
499
+ }
500
+ const barWidth = XEUtils.toInteger(hueSliderEl.clientWidth)
501
+ const itemNum = 255
502
+ const countNum = itemNum * 6
503
+ const offsetX = XEUtils.ceil(countNum / barWidth * offsetLeft)
504
+ const offsetNum = offsetX % itemNum
505
+ let rNum = 0
506
+ let gNum = 0
507
+ let bNum = 0
508
+ switch (Math.ceil(offsetX / itemNum)) {
509
+ case 1:
510
+ rNum = itemNum
511
+ bNum = offsetNum
512
+ break
513
+ case 2:
514
+ rNum = itemNum - offsetNum
515
+ bNum = itemNum
516
+ break
517
+ case 3:
518
+ gNum = offsetNum
519
+ bNum = itemNum
520
+ break
521
+ case 4:
522
+ gNum = itemNum
523
+ bNum = itemNum - offsetNum
524
+ break
525
+ case 5:
526
+ rNum = offsetNum
527
+ gNum = itemNum
528
+ break
529
+ case 6:
530
+ rNum = itemNum
531
+ gNum = itemNum - offsetNum
532
+ break
533
+ }
534
+ reactData.panelColor = toRgb(rNum, gNum, bNum)
535
+ hueSliderBtnEl.style.left = toCssUnit(offsetLeft)
536
+ }
537
+ },
538
+ handleHueBarEvent (evnt: MouseEvent) {
539
+ const $xeColorPicker = this
540
+
541
+ const hueSliderEl = $xeColorPicker.$refs.refHueSliderElem as HTMLDivElement
542
+ const hueSliderBtnEl = $xeColorPicker.$refs.refHueSliderBtnElem as HTMLDivElement
543
+ if (hueSliderEl && hueSliderBtnEl) {
544
+ const hueSliderRect = hueSliderEl.getBoundingClientRect()
545
+ const barWidth = XEUtils.toInteger(hueSliderEl.clientWidth)
546
+ const offsetLeft = XEUtils.ceil(Math.min(barWidth - 1, Math.max(1, evnt.clientX - hueSliderRect.x)))
547
+ $xeColorPicker.handleHueColor(offsetLeft)
548
+ }
549
+ },
550
+ handleHueSliderMousedownEvent (evnt: MouseEvent) {
551
+ const $xeColorPicker = this
552
+
553
+ evnt.preventDefault()
554
+ document.onmousemove = evnt => {
555
+ evnt.preventDefault()
556
+ $xeColorPicker.handleHueBarEvent(evnt)
557
+ }
558
+ document.onmouseup = (evnt: MouseEvent) => {
559
+ document.onmousemove = null
560
+ document.onmouseup = null
561
+ $xeColorPicker.handleHueBarEvent(evnt)
562
+ }
563
+ },
564
+ handleAlphaColor (offsetLeft: number) {
565
+ const $xeColorPicker = this
566
+ const reactData = $xeColorPicker.reactData
567
+
568
+ const { selectColor } = reactData
569
+ const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
570
+ const alphaSliderBtnEl = $xeColorPicker.$refs.refAlphaSliderBtnElem as HTMLDivElement
571
+ if (alphaSliderEl && alphaSliderBtnEl) {
572
+ const alphaSliderRect = alphaSliderEl.getBoundingClientRect()
573
+ const barWidth = alphaSliderRect.width
574
+ if (offsetLeft < 0) {
575
+ offsetLeft = 0
576
+ }
577
+ if (offsetLeft > barWidth) {
578
+ offsetLeft = barWidth
579
+ }
580
+ const alpha = XEUtils.ceil(100 / barWidth * offsetLeft / 100, 2)
581
+ reactData.aValue = alpha
582
+ alphaSliderBtnEl.style.left = toCssUnit(offsetLeft)
583
+ reactData.selectColor = updateColorAlpha(selectColor, alpha)
584
+ }
585
+ },
586
+ handleAlphaBarEvent (evnt: MouseEvent) {
587
+ const $xeColorPicker = this
588
+
589
+ const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
590
+ const alphaSliderBtnEl = $xeColorPicker.$refs.refAlphaSliderBtnElem as HTMLDivElement
591
+ if (alphaSliderEl && alphaSliderBtnEl) {
592
+ const alphaSliderRect = alphaSliderEl.getBoundingClientRect()
593
+ const barWidth = alphaSliderRect.width
594
+ const offsetLeft = Math.min(barWidth, Math.max(0, evnt.clientX - alphaSliderRect.x))
595
+ $xeColorPicker.handleAlphaColor(offsetLeft)
596
+ $xeColorPicker.updateModelColor()
597
+ }
598
+ },
599
+ handleAlphaSliderMousedownEvent (evnt: MouseEvent) {
600
+ const $xeColorPicker = this
601
+
602
+ evnt.preventDefault()
603
+ document.onmousemove = evnt => {
604
+ evnt.preventDefault()
605
+ $xeColorPicker.handleAlphaBarEvent(evnt)
606
+ }
607
+ document.onmouseup = (evnt: MouseEvent) => {
608
+ document.onmousemove = null
609
+ document.onmouseup = null
610
+ $xeColorPicker.handleAlphaBarEvent(evnt)
611
+ }
612
+ },
613
+ handleInputRgbEvent () {
614
+ const $xeColorPicker = this
615
+ const reactData = $xeColorPicker.reactData
616
+
617
+ const { rValue, gValue, bValue, aValue } = reactData
618
+ reactData.selectColor = toRgb(rValue, gValue, bValue, aValue)
619
+ $xeColorPicker.updateModelColor()
620
+ },
621
+ handleInputAlphaEvent () {
622
+ const $xeColorPicker = this
623
+ const reactData = $xeColorPicker.reactData
624
+
625
+ const { aValue } = reactData
626
+ const alphaSliderEl = $xeColorPicker.$refs.refAlphaSliderElem as HTMLDivElement
627
+ const alphaSliderBtnEl = $xeColorPicker.$refs.refAlphaSliderBtnElem as HTMLDivElement
628
+ if (alphaSliderEl && alphaSliderBtnEl) {
629
+ const alphaSliderRect = alphaSliderEl.getBoundingClientRect()
630
+ const barWidth = alphaSliderRect.width
631
+ const offsetLeft = barWidth * aValue
632
+ $xeColorPicker.handleAlphaColor(offsetLeft)
633
+ }
634
+ },
635
+ handleQuickEvent (evnt: MouseEvent, item: any) {
636
+ const $xeColorPicker = this
637
+ const reactData = $xeColorPicker.reactData
638
+
639
+ const value = item.value
640
+ reactData.selectColor = value
641
+ $xeColorPicker.updateModelColor()
642
+ },
643
+ handlePanelColor (offsetLeft: number, offsetTop: number) {
644
+ const $xeColorPicker = this
645
+
646
+ const colorActiveEl = $xeColorPicker.$refs.refColorActiveElem as HTMLDivElement
647
+ if (colorActiveEl) {
648
+ colorActiveEl.style.top = toCssUnit(offsetTop)
649
+ colorActiveEl.style.left = toCssUnit(offsetLeft)
650
+ }
651
+ },
652
+ handleEyeDropperEvent () {
653
+ const $xeColorPicker = this
654
+ const reactData = $xeColorPicker.reactData
655
+
656
+ if (WinEyeDropper) {
657
+ try {
658
+ const eyeDropper = new WinEyeDropper()
659
+ eyeDropper.open().then((rest: any) => {
660
+ if (rest && rest.sRGBHex) {
661
+ reactData.selectColor = rest.sRGBHex
662
+ $xeColorPicker.updateModelColor()
663
+ }
664
+ }).catch(() => {
665
+ })
666
+ } catch (e) {}
667
+ }
668
+ },
669
+ handleSelectColorByXY (clientX: number, clientY: number) {
670
+ const $xeColorPicker = this
671
+ const props = $xeColorPicker
672
+ const reactData = $xeColorPicker.reactData
673
+
674
+ const { showAlpha } = props
675
+ const { panelColor, aValue } = reactData
676
+ const colorPanelEl = $xeColorPicker.$refs.refColorPanelElem as HTMLDivElement
677
+ const colorActiveEl = $xeColorPicker.$refs.refColorActiveElem as HTMLDivElement
678
+ if (colorPanelEl && colorActiveEl) {
679
+ const { clientWidth, clientHeight } = colorPanelEl
680
+ const colorPanelRect = colorPanelEl.getBoundingClientRect()
681
+ const offsetTop = Math.min(clientHeight, Math.max(0, clientY - colorPanelRect.y))
682
+ const offsetLeft = Math.min(clientWidth, Math.max(0, clientX - colorPanelRect.x))
683
+ const colorRest = parseColor(panelColor)
684
+ if (colorRest) {
685
+ const hsvRest = colorRest.type === 'hex' ? hexToHsv(colorRest.hex) : rgbToHsv(colorRest)
686
+ if (hsvRest) {
687
+ const ragRest = hsvToRgb(hsvRest.h, offsetLeft / clientWidth, (1 - offsetTop / clientHeight))
688
+ reactData.selectColor = toRgb(ragRest.r, ragRest.g, ragRest.b, showAlpha ? aValue : null)
689
+ $xeColorPicker.handlePanelColor(offsetLeft, offsetTop)
690
+ }
691
+ }
692
+ $xeColorPicker.updateModelColor()
693
+ }
694
+ },
695
+ handleSelectColorMousedownEvent (evnt: MouseEvent) {
696
+ const $xeColorPicker = this
697
+
698
+ evnt.stopPropagation()
699
+ evnt.preventDefault()
700
+ $xeColorPicker.handleSelectColorByXY(evnt.clientX, evnt.clientY)
701
+ document.onmousemove = evnt => {
702
+ $xeColorPicker.handleSelectColorByXY(evnt.clientX, evnt.clientY)
703
+ }
704
+ document.onmouseup = () => {
705
+ document.onmousemove = null
706
+ document.onmouseup = null
707
+ }
708
+ },
709
+ handleCopyColorEvent () {
710
+ const $xeColorPicker = this
711
+ const reactData = $xeColorPicker.reactData
712
+
713
+ const { selectColor } = reactData
714
+ if (selectColor) {
715
+ if (VxeUI.clipboard.copy(selectColor)) {
716
+ if (VxeUI.modal) {
717
+ VxeUI.modal.message({
718
+ content: getI18n('vxe.colorPicker.copySuccess', [selectColor]),
719
+ status: 'success'
720
+ })
721
+ }
722
+ }
723
+ }
724
+ },
725
+ handleGlobalMousewheelEvent (evnt: MouseEvent) {
726
+ const $xeColorPicker = this
727
+ const reactData = $xeColorPicker.reactData
728
+
729
+ const { visiblePanel } = reactData
730
+ const isDisabled = $xeColorPicker.computeIsDisabled
731
+ if (!isDisabled) {
732
+ if (visiblePanel) {
733
+ const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLDivElement
734
+ if (getEventTargetNode(evnt, panelElem).flag) {
735
+ $xeColorPicker.updatePlacement()
736
+ } else {
737
+ $xeColorPicker.hideOptionPanel()
738
+ }
739
+ }
740
+ }
741
+ },
742
+ handleGlobalMousedownEvent (evnt: MouseEvent) {
743
+ const $xeColorPicker = this
744
+ const reactData = $xeColorPicker.reactData
745
+
746
+ const { visiblePanel } = reactData
747
+ const isDisabled = $xeColorPicker.computeIsDisabled
748
+ if (!isDisabled) {
749
+ const el = $xeColorPicker.$refs.refElem as HTMLDivElement
750
+ const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLDivElement
751
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
752
+ if (visiblePanel && !reactData.isActivated) {
753
+ $xeColorPicker.hideOptionPanel()
754
+ }
755
+ }
756
+ },
757
+ handleGlobalBlurEvent () {
758
+ const $xeColorPicker = this
759
+ const reactData = $xeColorPicker.reactData
760
+
761
+ const { visiblePanel, isActivated } = reactData
762
+ if (visiblePanel) {
763
+ $xeColorPicker.hideOptionPanel()
764
+ }
765
+ if (isActivated) {
766
+ reactData.isActivated = false
767
+ }
768
+ if (visiblePanel || isActivated) {
769
+ const targetElem = $xeColorPicker.$refs.refInputTarget as HTMLInputElement
770
+ if (targetElem) {
771
+ targetElem.blur()
772
+ }
773
+ }
774
+ },
775
+ handleGlobalResizeEvent () {
776
+ const $xeColorPicker = this
777
+ const reactData = $xeColorPicker.reactData
778
+
779
+ const { visiblePanel } = reactData
780
+ if (visiblePanel) {
781
+ $xeColorPicker.updatePlacement()
782
+ }
783
+ },
784
+
785
+ //
786
+ // Render
787
+ //
788
+ renderColorWrapper (h: CreateElement) {
789
+ const $xeColorPicker = this
790
+ const props = $xeColorPicker
791
+ const reactData = $xeColorPicker.reactData
792
+
793
+ const { showColorExtractor } = props
794
+ const { panelColor } = reactData
795
+ if (showColorExtractor) {
796
+ return h('div', {
797
+ ref: 'refColorPanelElem',
798
+ class: 'vxe-color-picker--color-wrapper',
799
+ on: {
800
+ mousedown: $xeColorPicker.handleSelectColorMousedownEvent
801
+ }
802
+ }, [
803
+ h('div', {
804
+ class: 'vxe-color-picker--color-bg',
805
+ style: {
806
+ backgroundColor: panelColor
807
+ }
808
+ }),
809
+ h('div', {
810
+ class: 'vxe-color-picker--white-bg'
811
+ }),
812
+ h('div', {
813
+ class: 'vxe-color-picker--black-bg'
814
+ }),
815
+ h('div', {
816
+ ref: 'refColorActiveElem',
817
+ class: 'vxe-color-picker--color-active'
818
+ })
819
+ ])
820
+ }
821
+ return renderEmptyElement($xeColorPicker)
822
+ },
823
+ renderColorBar (h: CreateElement) {
824
+ const $xeColorPicker = this
825
+ const props = $xeColorPicker
826
+ const reactData = $xeColorPicker.reactData
827
+
828
+ const { showAlpha, clickToCopy, showEyeDropper } = props
829
+ const { selectTyle, showTypePopup, hexValue, rValue, gValue, bValue, aValue, selectColor, panelColor } = reactData
830
+ const isRgb = $xeColorPicker.computeIsRgb
831
+ const selectTypeItem = $xeColorPicker.computeSelectTypeItem
832
+ return h('div', {
833
+ class: 'vxe-color-picker--bar-wrapper'
834
+ }, [
835
+ h('div', {
836
+ class: 'vxe-color-picker--slider-wrapper'
837
+ }, [
838
+ showEyeDropper && WinEyeDropper
839
+ ? h('div', {
840
+ class: 'vxe-color-picker--color-dropper'
841
+ }, [
842
+ h('span', {
843
+ class: 'vxe-color-picker--color-dropper-btn',
844
+ on: {
845
+ click: $xeColorPicker.handleEyeDropperEvent
846
+ }
847
+ }, [
848
+ h('i', {
849
+ class: getIcon().COLOR_PICKER_EYE_DROPPER
850
+ })
851
+ ])
852
+ ])
853
+ : renderEmptyElement($xeColorPicker),
854
+ h('div', {
855
+ class: 'vxe-color-picker--slider-preview'
856
+ }, [
857
+ h('div', {
858
+ class: 'vxe-color-picker--preview-btn'
859
+ }, [
860
+ h('div', {
861
+ class: 'vxe-color-picker--preview-color',
862
+ style: {
863
+ backgroundColor: selectColor
864
+ }
865
+ }, clickToCopy
866
+ ? [
867
+ h('span', {
868
+ class: 'vxe-color-picker--preview-copy-btn',
869
+ on: {
870
+ click: $xeColorPicker.handleCopyColorEvent
871
+ }
872
+ }, [
873
+ h('i', {
874
+ class: getIcon().COLOR_PICKER_COLOR_COPY
875
+ })
876
+ ])
877
+ ]
878
+ : [])
879
+ ])
880
+ ]),
881
+ h('div', {
882
+ class: 'vxe-color-picker--slider-handle'
883
+ }, [
884
+ h('div', {
885
+ ref: 'refHueSliderElem',
886
+ class: 'vxe-color-picker--bar-hue-slider',
887
+ on: {
888
+ click: $xeColorPicker.handleHueBarEvent
889
+ }
890
+ }, [
891
+ h('div', {
892
+ ref: 'refHueSliderBtnElem',
893
+ class: 'vxe-color-picker--bar-hue-btn',
894
+ on: {
895
+ mousedown: $xeColorPicker.handleHueSliderMousedownEvent
896
+ }
897
+ })
898
+ ]),
899
+ showAlpha
900
+ ? h('div', {
901
+ ref: 'refAlphaSliderElem',
902
+ class: 'vxe-color-picker--bar-alpha-slider',
903
+ on: {
904
+ click: $xeColorPicker.handleAlphaBarEvent
905
+ }
906
+ }, [
907
+ h('div', {
908
+ class: 'vxe-color-picker--bar-alpha-bg',
909
+ style: {
910
+ background: `linear-gradient(to right, rgba(0, 0, 0, 0), ${panelColor})`
911
+ }
912
+ }),
913
+ h('div', {
914
+ ref: 'refAlphaSliderBtnElem',
915
+ class: 'vxe-color-picker--bar-alpha-btn',
916
+ on: {
917
+ mousedown: $xeColorPicker.handleAlphaSliderMousedownEvent
918
+ }
919
+ })
920
+ ])
921
+ : renderEmptyElement($xeColorPicker)
922
+ ])
923
+ ]),
924
+ h('div', {
925
+ class: 'vxe-color-picker--custom-wrapper'
926
+ }, [
927
+ h('div', {
928
+ class: 'vxe-color-picker--type-switch'
929
+ }, [
930
+ h('div', {
931
+ class: 'vxe-color-picker--type-label',
932
+ on: {
933
+ click: $xeColorPicker.toggleTypeVisibleEvent
934
+ }
935
+ }, [
936
+ h('span', `${selectTypeItem ? selectTypeItem.label : selectTyle}`),
937
+ h('span', {
938
+ class: 'vxe-color-picker--type-icon'
939
+ }, [
940
+ h('i', {
941
+ class: showTypePopup ? getIcon().COLOR_PICKER_TPTY_OPEN : getIcon().COLOR_PICKER_TPTY_CLOSE
942
+ })
943
+ ])
944
+ ]),
945
+ h('div', {
946
+ class: ['vxe-color-picker--type-popup', {
947
+ 'is--visible': showTypePopup
948
+ }]
949
+ }, typeList.map(item => {
950
+ return h('div', {
951
+ class: 'vxe-color-picker--type-item',
952
+ on: {
953
+ click (evnt: KeyboardEvent) {
954
+ evnt.stopPropagation()
955
+ $xeColorPicker.handleChangeType(item.value as VxeColorPickerPropTypes.Type)
956
+ }
957
+ }
958
+ }, item.label)
959
+ }))
960
+ ]),
961
+ h('div', {
962
+ class: `vxe-color-picker--${selectTyle}-wrapper`
963
+ }, isRgb
964
+ ? [
965
+ h('div', {
966
+ class: 'vxe-color-picker--input-wrapper'
967
+ }, [
968
+ h(VxeNumberInputComponent, {
969
+ props: {
970
+ type: 'integer',
971
+ size: 'mini',
972
+ align: 'center',
973
+ min: 0,
974
+ max: 255,
975
+ maxLength: 3,
976
+ placeholder: '',
977
+ value: rValue,
978
+ controlConfig: {
979
+ showButton: false
980
+ }
981
+ },
982
+ on: {
983
+ 'modelValue' (val: any) {
984
+ reactData.rValue = val
985
+ },
986
+ change: $xeColorPicker.handleInputRgbEvent
987
+ }
988
+ }),
989
+ h(VxeNumberInputComponent, {
990
+ props: {
991
+ type: 'integer',
992
+ size: 'mini',
993
+ align: 'center',
994
+ min: 0,
995
+ max: 255,
996
+ maxLength: 3,
997
+ placeholder: '',
998
+ value: gValue,
999
+ controlConfig: {
1000
+ showButton: false
1001
+ }
1002
+ },
1003
+ on: {
1004
+ 'modelValue' (val: any) {
1005
+ reactData.gValue = val
1006
+ },
1007
+ change: $xeColorPicker.handleInputRgbEvent
1008
+ }
1009
+ }),
1010
+ h(VxeNumberInputComponent, {
1011
+ props: {
1012
+ type: 'integer',
1013
+ size: 'mini',
1014
+ align: 'center',
1015
+ min: 0,
1016
+ max: 255,
1017
+ maxLength: 3,
1018
+ placeholder: '',
1019
+ value: bValue,
1020
+ controlConfig: {
1021
+ showButton: false
1022
+ }
1023
+ },
1024
+ on: {
1025
+ 'modelValue' (val: any) {
1026
+ reactData.bValue = val
1027
+ },
1028
+ change: $xeColorPicker.handleInputRgbEvent
1029
+ }
1030
+ }),
1031
+ h(VxeNumberInputComponent, {
1032
+ props: {
1033
+ type: 'number',
1034
+ size: 'mini',
1035
+ align: 'center',
1036
+ min: 0,
1037
+ max: 1,
1038
+ step: 0.01,
1039
+ maxLength: 4,
1040
+ placeholder: '',
1041
+ value: aValue,
1042
+ controlConfig: {
1043
+ showButton: false
1044
+ }
1045
+ },
1046
+ on: {
1047
+ 'modelValue' (val: any) {
1048
+ reactData.aValue = val
1049
+ },
1050
+ change: $xeColorPicker.handleInputAlphaEvent
1051
+ }
1052
+ })
1053
+ ]),
1054
+ h('div', {
1055
+ class: 'vxe-color-picker--input-title'
1056
+ }, [
1057
+ h('span', 'R'),
1058
+ h('span', 'G'),
1059
+ h('span', 'B'),
1060
+ h('span', 'A')
1061
+ ])]
1062
+ : [
1063
+ h('div', {
1064
+ class: 'vxe-color-picker--input-wrapper'
1065
+ }, [
1066
+ h(VxeInputComponent, {
1067
+ props: {
1068
+ type: 'text',
1069
+ size: 'mini',
1070
+ align: 'center',
1071
+ maxLength: 9,
1072
+ placeholder: '',
1073
+ value: hexValue
1074
+ },
1075
+ on: {
1076
+ 'modelValue' (val: any) {
1077
+ reactData.hexValue = val
1078
+ },
1079
+ change () {
1080
+ const colorRest = parseColor(reactData.hexValue)
1081
+ if (colorRest) {
1082
+ if (colorRest.value) {
1083
+ reactData.selectColor = colorRest.value
1084
+ $xeColorPicker.updateModelColor()
1085
+ }
1086
+ }
1087
+ }
1088
+ }
1089
+ })
1090
+ ]),
1091
+ h('div', {
1092
+ class: 'vxe-color-picker--input-title'
1093
+ }, getI18n('vxe.colorPicker.hex'))
1094
+ ])
1095
+ ])
1096
+ ])
1097
+ },
1098
+ renderQuickWrapper (h: CreateElement) {
1099
+ const $xeColorPicker = this
1100
+ const props = $xeColorPicker
1101
+
1102
+ const { showQuick } = props
1103
+ const colorList = $xeColorPicker.computeColorList
1104
+ if (showQuick && colorList.length) {
1105
+ return h('div', {
1106
+ class: 'vxe-color-picker--quick-wrapper'
1107
+ }, colorList.map((item, i) => {
1108
+ return h('div', {
1109
+ key: i,
1110
+ class: 'vxe-color-picker--quick-item',
1111
+ attrs: {
1112
+ title: item.label || ''
1113
+ },
1114
+ style: {
1115
+ backgroundColor: item.value
1116
+ },
1117
+ on: {
1118
+ click (evnt: MouseEvent) {
1119
+ $xeColorPicker.handleQuickEvent(evnt, item)
1120
+ }
1121
+ }
1122
+ })
1123
+ }))
1124
+ }
1125
+ return renderEmptyElement($xeColorPicker)
1126
+ },
1127
+ renderVN (h: CreateElement): VNode {
1128
+ const $xeColorPicker = this
1129
+ const props = $xeColorPicker
1130
+ const reactData = $xeColorPicker.reactData
1131
+
1132
+ const { className, popupClassName, clearable, value } = props
1133
+ const { initialized, isActivated, isAniVisible, visiblePanel } = reactData
1134
+ const vSize = $xeColorPicker.computeSize
1135
+ const isDisabled = $xeColorPicker.computeIsDisabled
1136
+ const btnTransfer = $xeColorPicker.computeBtnTransfer
1137
+ const formReadonly = $xeColorPicker.computeFormReadonly
1138
+
1139
+ if (formReadonly) {
1140
+ return h('div', {
1141
+ ref: 'refElem',
1142
+ class: ['vxe-color-picker--readonly', className]
1143
+ }, [
1144
+ h('div', {
1145
+ class: 'vxe-color-picker--readonly-color',
1146
+ style: {
1147
+ backgroundColor: value
1148
+ }
1149
+ })
1150
+ ])
1151
+ }
1152
+ return h('div', {
1153
+ ref: 'refElem',
1154
+ class: ['vxe-color-picker', className ? (XEUtils.isFunction(className) ? className({ $colorPicker: $xeColorPicker }) : className) : '', {
1155
+ [`size--${vSize}`]: vSize,
1156
+ 'is--selected': !!value,
1157
+ 'is--visible': visiblePanel,
1158
+ 'is--disabled': isDisabled,
1159
+ 'is--active': isActivated
1160
+ }]
1161
+ }, [
1162
+ h('input', {
1163
+ ref: 'refInputTarget',
1164
+ class: 'vxe-color-picker--input',
1165
+ on: {
1166
+ focus: $xeColorPicker.focusEvent,
1167
+ blur: $xeColorPicker.blurEvent
1168
+ }
1169
+ }),
1170
+ h('div', {
1171
+ class: 'vxe-color-picker--inner',
1172
+ on: {
1173
+ click: $xeColorPicker.clickEvent
1174
+ }
1175
+ }, [
1176
+ h('div', {
1177
+ class: 'vxe-color-picker--inner-color',
1178
+ style: {
1179
+ backgroundColor: value
1180
+ }
1181
+ })
1182
+ ]),
1183
+ h('div', {
1184
+ ref: 'refOptionPanel',
1185
+ class: ['vxe-table--ignore-clear vxe-color-picker--panel', popupClassName ? (XEUtils.isFunction(popupClassName) ? popupClassName({ $colorPicker: $xeColorPicker }) : popupClassName) : '', {
1186
+ [`size--${vSize}`]: vSize,
1187
+ 'is--transfer': btnTransfer,
1188
+ 'ani--leave': isAniVisible,
1189
+ 'ani--enter': visiblePanel
1190
+ }],
1191
+ attrs: {
1192
+ placement: reactData.panelPlacement
1193
+ },
1194
+ style: reactData.panelStyle
1195
+ }, [
1196
+ initialized && (visiblePanel || isAniVisible)
1197
+ ? h('div', {
1198
+ class: 'vxe-color-picker--panel-wrapper',
1199
+ on: {
1200
+ click: $xeColorPicker.handlePanelClickEvent
1201
+ }
1202
+ }, [
1203
+ $xeColorPicker.renderColorWrapper(h),
1204
+ $xeColorPicker.renderColorBar(h),
1205
+ $xeColorPicker.renderQuickWrapper(h),
1206
+ h('div', {
1207
+ class: 'vxe-color-picker--footer-wrapper'
1208
+ }, [
1209
+ clearable
1210
+ ? h(VxeButtonComponent, {
1211
+ props: {
1212
+ content: getI18n('vxe.colorPicker.clear'),
1213
+ size: 'mini'
1214
+ },
1215
+ on: {
1216
+ click: $xeColorPicker.clearEvent
1217
+ }
1218
+ })
1219
+ : renderEmptyElement($xeColorPicker),
1220
+ h(VxeButtonComponent, {
1221
+ props: {
1222
+ content: getI18n('vxe.colorPicker.confirm'),
1223
+ size: 'mini',
1224
+ status: 'primary'
1225
+ },
1226
+ on: {
1227
+ click: $xeColorPicker.confirmEvent
1228
+ }
1229
+ })
1230
+ ])
1231
+ ])
1232
+ : renderEmptyElement($xeColorPicker)
1233
+ ])
1234
+ ])
1235
+ }
1236
+ },
1237
+ watch: {
1238
+ value () {
1239
+ const $xeColorPicker = this
1240
+
1241
+ $xeColorPicker.updateMode()
1242
+ },
1243
+ type () {
1244
+ const $xeColorPicker = this
1245
+
1246
+ $xeColorPicker.updateType()
1247
+ }
1248
+ },
1249
+ created () {
1250
+ const $xeColorPicker = this
1251
+ const props = $xeColorPicker
1252
+ const reactData = $xeColorPicker.reactData
1253
+
1254
+ reactData.selectColor = `${props.value || ''}`
1255
+ $xeColorPicker.updateType()
1256
+
1257
+ globalEvents.on($xeColorPicker, 'mousewheel', $xeColorPicker.handleGlobalMousewheelEvent)
1258
+ globalEvents.on($xeColorPicker, 'mousedown', $xeColorPicker.handleGlobalMousedownEvent)
1259
+ globalEvents.on($xeColorPicker, 'blur', $xeColorPicker.handleGlobalBlurEvent)
1260
+ globalEvents.on($xeColorPicker, 'resize', $xeColorPicker.handleGlobalResizeEvent)
1261
+ },
1262
+ beforeDestroy () {
1263
+ const $xeColorPicker = this
1264
+
1265
+ const panelElem = $xeColorPicker.$refs.refOptionPanel as HTMLElement | undefined
1266
+ if (panelElem && panelElem.parentNode) {
1267
+ panelElem.parentNode.removeChild(panelElem)
1268
+ }
1269
+ globalEvents.off($xeColorPicker, 'mousewheel')
1270
+ globalEvents.off($xeColorPicker, 'mousedown')
1271
+ globalEvents.off($xeColorPicker, 'blur')
1272
+ globalEvents.off($xeColorPicker, 'resize')
1273
+ },
1274
+ render (this: any, h) {
1275
+ return this.renderVN(h)
1276
+ }
1277
+ }) /* define-vxe-component end */