@smallwei/avue 3.8.2 → 3.8.3

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 (374) hide show
  1. package/README.md +206 -86
  2. package/dist/avue.js +37301 -0
  3. package/dist/avue.js.map +1 -0
  4. package/dist/avue.min.js +6 -0
  5. package/dist/avue.min.mjs +2 -0
  6. package/dist/avue.mjs +2 -0
  7. package/dist/index.css +1 -0
  8. package/es/avue.min.mjs +2 -0
  9. package/es/avue.min.ts +2 -0
  10. package/es/avue.mjs +2 -0
  11. package/es/avue.ts +2 -0
  12. package/es/core/create.mjs +8 -0
  13. package/es/core/create.ts +16 -0
  14. package/es/core/dataformat.mjs +184 -0
  15. package/es/core/dataformat.ts +190 -0
  16. package/es/core/detail.mjs +74 -0
  17. package/es/core/detail.ts +81 -0
  18. package/es/core/dic.mjs +213 -0
  19. package/es/core/dic.ts +235 -0
  20. package/es/core/locale.mjs +8 -0
  21. package/es/core/locale.ts +9 -0
  22. package/es/core/packages.mjs +61 -0
  23. package/es/core/packages.ts +62 -0
  24. package/es/core/slot.mjs +32 -0
  25. package/es/core/slot.ts +30 -0
  26. package/es/global/variable.mjs +80 -0
  27. package/es/global/variable.ts +84 -0
  28. package/es/icon.mjs +9 -0
  29. package/es/icon.ts +11 -0
  30. package/es/index.mjs +127 -0
  31. package/es/index.ts +177 -0
  32. package/es/locale/browser/en.mjs +288 -0
  33. package/es/locale/browser/zh-cn.mjs +288 -0
  34. package/es/locale/browser/zh.mjs +288 -0
  35. package/es/locale/index.mjs +141 -0
  36. package/es/locale/index.ts +196 -0
  37. package/es/locale/lang/en.mjs +282 -0
  38. package/es/locale/lang/en.ts +282 -0
  39. package/es/locale/lang/zh-cn.mjs +282 -0
  40. package/es/locale/lang/zh-cn.ts +282 -0
  41. package/es/locale/lang/zh.mjs +282 -0
  42. package/es/locale/lang/zh.ts +282 -0
  43. package/es/packages/core/common/event.mjs +58 -0
  44. package/es/packages/core/common/event.ts +56 -0
  45. package/es/packages/core/common/init.mjs +134 -0
  46. package/es/packages/core/common/init.ts +133 -0
  47. package/es/packages/core/common/props.mjs +239 -0
  48. package/es/packages/core/common/props.ts +240 -0
  49. package/es/packages/core/components/dialog-form/index.mjs +29 -0
  50. package/es/packages/core/components/dialog-form/index.ts +29 -0
  51. package/es/packages/core/components/dialog-form/index.vue +108 -0
  52. package/es/packages/core/components/form/custom.mjs +41 -0
  53. package/es/packages/core/components/form/custom.ts +41 -0
  54. package/es/packages/core/components/form/index.vue +176 -0
  55. package/es/packages/core/components/icon/index.vue +37 -0
  56. package/es/packages/core/components/image-preview/index.mjs +34 -0
  57. package/es/packages/core/components/image-preview/index.ts +37 -0
  58. package/es/packages/core/components/image-preview/index.vue +215 -0
  59. package/es/packages/core/directive/contextmenu.mjs +92 -0
  60. package/es/packages/core/directive/contextmenu.ts +103 -0
  61. package/es/packages/core/directive/permission.mjs +19 -0
  62. package/es/packages/core/directive/permission.ts +18 -0
  63. package/es/packages/data/box/index.vue +66 -0
  64. package/es/packages/data/card/index.vue +62 -0
  65. package/es/packages/data/cardText/index.vue +56 -0
  66. package/es/packages/data/countdown/index.vue +81 -0
  67. package/es/packages/data/dashboard/index.vue +72 -0
  68. package/es/packages/data/display/index.vue +63 -0
  69. package/es/packages/data/icons/index.vue +68 -0
  70. package/es/packages/data/imgText/index.vue +72 -0
  71. package/es/packages/data/list/index.vue +69 -0
  72. package/es/packages/data/notice/index.vue +63 -0
  73. package/es/packages/data/operaText/index.vue +62 -0
  74. package/es/packages/data/panel/index.vue +62 -0
  75. package/es/packages/data/pay/index.vue +92 -0
  76. package/es/packages/data/price/index.vue +55 -0
  77. package/es/packages/data/product/index.vue +106 -0
  78. package/es/packages/data/profile/index.vue +91 -0
  79. package/es/packages/data/progress/index.vue +64 -0
  80. package/es/packages/data/rank/index.vue +92 -0
  81. package/es/packages/data/rotate/index.vue +69 -0
  82. package/es/packages/data/statistic/index.vue +71 -0
  83. package/es/packages/data/tabs/index.vue +64 -0
  84. package/es/packages/data/task/index.vue +82 -0
  85. package/es/packages/data/weather/index.vue +103 -0
  86. package/es/packages/element-plus/array/index.vue +115 -0
  87. package/es/packages/element-plus/article/index.vue +73 -0
  88. package/es/packages/element-plus/card/index.vue +103 -0
  89. package/es/packages/element-plus/cascader/index.vue +132 -0
  90. package/es/packages/element-plus/chat/index.vue +513 -0
  91. package/es/packages/element-plus/checkbox/index.vue +84 -0
  92. package/es/packages/element-plus/comment/index.vue +76 -0
  93. package/es/packages/element-plus/count-up/index.vue +107 -0
  94. package/es/packages/element-plus/crud/column/column-default.vue +128 -0
  95. package/es/packages/element-plus/crud/column/column-dynamic.vue +86 -0
  96. package/es/packages/element-plus/crud/column/column-menu.vue +267 -0
  97. package/es/packages/element-plus/crud/column/column-slot.vue +348 -0
  98. package/es/packages/element-plus/crud/column/column.vue +119 -0
  99. package/es/packages/element-plus/crud/column/menu.vue +78 -0
  100. package/es/packages/element-plus/crud/config.mjs +74 -0
  101. package/es/packages/element-plus/crud/config.ts +74 -0
  102. package/es/packages/element-plus/crud/dialog/dialog-column.vue +102 -0
  103. package/es/packages/element-plus/crud/dialog/dialog-excel.vue +204 -0
  104. package/es/packages/element-plus/crud/dialog/dialog-filter.vue +159 -0
  105. package/es/packages/element-plus/crud/dialog/dialog-form.vue +352 -0
  106. package/es/packages/element-plus/crud/grid/index.vue +271 -0
  107. package/es/packages/element-plus/crud/grid/item.vue +39 -0
  108. package/es/packages/element-plus/crud/index.vue +1018 -0
  109. package/es/packages/element-plus/crud/menu/header-menu.vue +175 -0
  110. package/es/packages/element-plus/crud/menu/header-search.vue +228 -0
  111. package/es/packages/element-plus/crud/menu/table-page.vue +108 -0
  112. package/es/packages/element-plus/date/index.vue +81 -0
  113. package/es/packages/element-plus/draggable/index.vue +444 -0
  114. package/es/packages/element-plus/dynamic/index.vue +353 -0
  115. package/es/packages/element-plus/flow/index.vue +339 -0
  116. package/es/packages/element-plus/flow/node.vue +84 -0
  117. package/es/packages/element-plus/form/config.mjs +6 -0
  118. package/es/packages/element-plus/form/config.ts +6 -0
  119. package/es/packages/element-plus/form/index.vue +954 -0
  120. package/es/packages/element-plus/form/menu.vue +63 -0
  121. package/es/packages/element-plus/group/index.vue +90 -0
  122. package/es/packages/element-plus/input/index.vue +1264 -0
  123. package/es/packages/element-plus/input-color/index.vue +70 -0
  124. package/es/packages/element-plus/input-cron/index.vue +363 -0
  125. package/es/packages/element-plus/input-icon/index.vue +143 -0
  126. package/es/packages/element-plus/input-map/index.vue +311 -0
  127. package/es/packages/element-plus/input-number/index.vue +91 -0
  128. package/es/packages/element-plus/input-table/index.vue +279 -0
  129. package/es/packages/element-plus/input-tag/index.vue +79 -0
  130. package/es/packages/element-plus/input-tree/index.vue +194 -0
  131. package/es/packages/element-plus/license/index.vue +155 -0
  132. package/es/packages/element-plus/login/index.vue +203 -0
  133. package/es/packages/element-plus/mention/index.vue +117 -0
  134. package/es/packages/element-plus/radio/index.vue +38 -0
  135. package/es/packages/element-plus/rate/index.vue +51 -0
  136. package/es/packages/element-plus/search/index.vue +129 -0
  137. package/es/packages/element-plus/select/index.vue +292 -0
  138. package/es/packages/element-plus/sign/index.vue +230 -0
  139. package/es/packages/element-plus/slider/index.vue +66 -0
  140. package/es/packages/element-plus/switch/index.vue +72 -0
  141. package/es/packages/element-plus/tabs/index.vue +62 -0
  142. package/es/packages/element-plus/text-ellipsis/index.vue +104 -0
  143. package/es/packages/element-plus/time/index.vue +81 -0
  144. package/es/packages/element-plus/title/index.vue +30 -0
  145. package/es/packages/element-plus/tree/index.vue +460 -0
  146. package/es/packages/element-plus/upload/index.vue +728 -0
  147. package/es/packages/element-plus/verify/index.vue +62 -0
  148. package/es/packages/element-plus/video/index.vue +90 -0
  149. package/es/plugin/ali/index.mjs +4 -0
  150. package/es/plugin/ali/index.ts +6 -0
  151. package/es/plugin/clipboard/index.mjs +61 -0
  152. package/es/plugin/clipboard/index.ts +67 -0
  153. package/es/plugin/export/_blob.mjs +151 -0
  154. package/es/plugin/export/_blob.ts +176 -0
  155. package/es/plugin/export/_export2Excel.mjs +141 -0
  156. package/es/plugin/export/_export2Excel.ts +166 -0
  157. package/es/plugin/export/index.mjs +263 -0
  158. package/es/plugin/export/index.ts +274 -0
  159. package/es/plugin/logs/index.mjs +46 -0
  160. package/es/plugin/logs/index.ts +66 -0
  161. package/es/plugin/print/index.mjs +145 -0
  162. package/es/plugin/print/index.ts +155 -0
  163. package/es/plugin/qiniu/index.mjs +78 -0
  164. package/es/plugin/qiniu/index.ts +88 -0
  165. package/es/plugin/screenshot/index.mjs +8 -0
  166. package/es/plugin/screenshot/index.ts +9 -0
  167. package/es/plugin/video/index.mjs +52 -0
  168. package/es/plugin/video/index.ts +60 -0
  169. package/es/plugin/watermark/index.mjs +114 -0
  170. package/es/plugin/watermark/index.ts +127 -0
  171. package/es/plugin/watermark/watermark.mjs +109 -0
  172. package/es/plugin/watermark/watermark.ts +121 -0
  173. package/es/ui/data/index.mjs +49 -0
  174. package/es/ui/data/index.ts +51 -0
  175. package/es/ui/element-plus/index.mjs +87 -0
  176. package/es/ui/element-plus/index.ts +89 -0
  177. package/es/ui/index.mjs +4 -0
  178. package/es/ui/index.ts +6 -0
  179. package/es/utils/bem.mjs +29 -0
  180. package/es/utils/bem.ts +36 -0
  181. package/es/utils/mock.mjs +137 -0
  182. package/es/utils/mock.ts +151 -0
  183. package/es/utils/util.mjs +370 -0
  184. package/es/utils/util.ts +392 -0
  185. package/es/utils/validate.mjs +18 -0
  186. package/es/utils/validate.ts +23 -0
  187. package/es/version.mjs +1 -0
  188. package/es/version.ts +1 -0
  189. package/lib/avue.js +11 -35880
  190. package/lib/avue.min.js +11 -6
  191. package/lib/avue.min.ts +2 -0
  192. package/lib/avue.ts +2 -0
  193. package/lib/core/create.js +14 -0
  194. package/lib/core/create.ts +16 -0
  195. package/lib/core/dataformat.js +194 -0
  196. package/lib/core/dataformat.ts +190 -0
  197. package/lib/core/detail.js +81 -0
  198. package/lib/core/detail.ts +81 -0
  199. package/lib/core/dic.js +220 -0
  200. package/lib/core/dic.ts +235 -0
  201. package/lib/core/locale.js +10 -0
  202. package/lib/core/locale.ts +9 -0
  203. package/lib/core/packages.js +66 -0
  204. package/lib/core/packages.ts +62 -0
  205. package/lib/core/slot.js +34 -0
  206. package/lib/core/slot.ts +30 -0
  207. package/lib/global/variable.js +83 -0
  208. package/lib/global/variable.ts +84 -0
  209. package/lib/icon.js +44 -0
  210. package/lib/icon.ts +11 -0
  211. package/lib/index.js +134 -0
  212. package/lib/index.ts +177 -0
  213. package/lib/locale/browser/en.js +288 -0
  214. package/lib/locale/browser/zh-cn.js +288 -0
  215. package/lib/locale/browser/zh.js +288 -0
  216. package/lib/locale/index.js +153 -47
  217. package/lib/locale/index.ts +196 -0
  218. package/lib/locale/lang/en.js +284 -100
  219. package/lib/locale/lang/en.ts +282 -0
  220. package/lib/locale/lang/zh-cn.js +284 -0
  221. package/lib/locale/lang/zh-cn.ts +282 -0
  222. package/lib/locale/lang/zh.js +284 -100
  223. package/lib/locale/lang/zh.ts +282 -0
  224. package/lib/packages/core/common/event.js +61 -0
  225. package/lib/packages/core/common/event.ts +56 -0
  226. package/lib/packages/core/common/init.js +140 -0
  227. package/lib/packages/core/common/init.ts +133 -0
  228. package/lib/packages/core/common/props.js +245 -0
  229. package/lib/packages/core/common/props.ts +240 -0
  230. package/lib/packages/core/components/dialog-form/index.js +35 -0
  231. package/lib/packages/core/components/dialog-form/index.ts +29 -0
  232. package/lib/packages/core/components/dialog-form/index.vue +108 -0
  233. package/lib/packages/core/components/form/custom.js +43 -0
  234. package/lib/packages/core/components/form/custom.ts +41 -0
  235. package/lib/packages/core/components/form/index.vue +176 -0
  236. package/lib/packages/core/components/icon/index.vue +37 -0
  237. package/lib/packages/core/components/image-preview/index.js +40 -0
  238. package/lib/packages/core/components/image-preview/index.ts +37 -0
  239. package/lib/packages/core/components/image-preview/index.vue +215 -0
  240. package/lib/packages/core/directive/contextmenu.js +94 -0
  241. package/lib/packages/core/directive/contextmenu.ts +103 -0
  242. package/lib/packages/core/directive/permission.js +21 -0
  243. package/lib/packages/core/directive/permission.ts +18 -0
  244. package/lib/packages/data/box/index.vue +66 -0
  245. package/lib/packages/data/card/index.vue +62 -0
  246. package/lib/packages/data/cardText/index.vue +56 -0
  247. package/lib/packages/data/countdown/index.vue +81 -0
  248. package/lib/packages/data/dashboard/index.vue +72 -0
  249. package/lib/packages/data/display/index.vue +63 -0
  250. package/lib/packages/data/icons/index.vue +68 -0
  251. package/lib/packages/data/imgText/index.vue +72 -0
  252. package/lib/packages/data/list/index.vue +69 -0
  253. package/lib/packages/data/notice/index.vue +63 -0
  254. package/lib/packages/data/operaText/index.vue +62 -0
  255. package/lib/packages/data/panel/index.vue +62 -0
  256. package/lib/packages/data/pay/index.vue +92 -0
  257. package/lib/packages/data/price/index.vue +55 -0
  258. package/lib/packages/data/product/index.vue +106 -0
  259. package/lib/packages/data/profile/index.vue +91 -0
  260. package/lib/packages/data/progress/index.vue +64 -0
  261. package/lib/packages/data/rank/index.vue +92 -0
  262. package/lib/packages/data/rotate/index.vue +69 -0
  263. package/lib/packages/data/statistic/index.vue +71 -0
  264. package/lib/packages/data/tabs/index.vue +64 -0
  265. package/lib/packages/data/task/index.vue +82 -0
  266. package/lib/packages/data/weather/index.vue +103 -0
  267. package/lib/packages/element-plus/array/index.vue +115 -0
  268. package/lib/packages/element-plus/article/index.vue +73 -0
  269. package/lib/packages/element-plus/card/index.vue +103 -0
  270. package/lib/packages/element-plus/cascader/index.vue +132 -0
  271. package/lib/packages/element-plus/chat/index.vue +513 -0
  272. package/lib/packages/element-plus/checkbox/index.vue +84 -0
  273. package/lib/packages/element-plus/comment/index.vue +76 -0
  274. package/lib/packages/element-plus/count-up/index.vue +107 -0
  275. package/lib/packages/element-plus/crud/column/column-default.vue +128 -0
  276. package/lib/packages/element-plus/crud/column/column-dynamic.vue +86 -0
  277. package/lib/packages/element-plus/crud/column/column-menu.vue +267 -0
  278. package/lib/packages/element-plus/crud/column/column-slot.vue +348 -0
  279. package/lib/packages/element-plus/crud/column/column.vue +119 -0
  280. package/lib/packages/element-plus/crud/column/menu.vue +78 -0
  281. package/lib/packages/element-plus/crud/config.js +76 -0
  282. package/lib/packages/element-plus/crud/config.ts +74 -0
  283. package/lib/packages/element-plus/crud/dialog/dialog-column.vue +102 -0
  284. package/lib/packages/element-plus/crud/dialog/dialog-excel.vue +204 -0
  285. package/lib/packages/element-plus/crud/dialog/dialog-filter.vue +159 -0
  286. package/lib/packages/element-plus/crud/dialog/dialog-form.vue +352 -0
  287. package/lib/packages/element-plus/crud/grid/index.vue +271 -0
  288. package/lib/packages/element-plus/crud/grid/item.vue +39 -0
  289. package/lib/packages/element-plus/crud/index.vue +1018 -0
  290. package/lib/packages/element-plus/crud/menu/header-menu.vue +175 -0
  291. package/lib/packages/element-plus/crud/menu/header-search.vue +228 -0
  292. package/lib/packages/element-plus/crud/menu/table-page.vue +108 -0
  293. package/lib/packages/element-plus/date/index.vue +81 -0
  294. package/lib/packages/element-plus/draggable/index.vue +444 -0
  295. package/lib/packages/element-plus/dynamic/index.vue +353 -0
  296. package/lib/packages/element-plus/flow/index.vue +339 -0
  297. package/lib/packages/element-plus/flow/node.vue +84 -0
  298. package/lib/packages/element-plus/form/config.js +8 -0
  299. package/lib/packages/element-plus/form/config.ts +6 -0
  300. package/lib/packages/element-plus/form/index.vue +954 -0
  301. package/lib/packages/element-plus/form/menu.vue +63 -0
  302. package/lib/packages/element-plus/group/index.vue +90 -0
  303. package/lib/packages/element-plus/input/index.vue +1264 -0
  304. package/lib/packages/element-plus/input-color/index.vue +70 -0
  305. package/lib/packages/element-plus/input-cron/index.vue +363 -0
  306. package/lib/packages/element-plus/input-icon/index.vue +143 -0
  307. package/lib/packages/element-plus/input-map/index.vue +311 -0
  308. package/lib/packages/element-plus/input-number/index.vue +91 -0
  309. package/lib/packages/element-plus/input-table/index.vue +279 -0
  310. package/lib/packages/element-plus/input-tag/index.vue +79 -0
  311. package/lib/packages/element-plus/input-tree/index.vue +194 -0
  312. package/lib/packages/element-plus/license/index.vue +155 -0
  313. package/lib/packages/element-plus/login/index.vue +203 -0
  314. package/lib/packages/element-plus/mention/index.vue +117 -0
  315. package/lib/packages/element-plus/radio/index.vue +38 -0
  316. package/lib/packages/element-plus/rate/index.vue +51 -0
  317. package/lib/packages/element-plus/search/index.vue +129 -0
  318. package/lib/packages/element-plus/select/index.vue +292 -0
  319. package/lib/packages/element-plus/sign/index.vue +230 -0
  320. package/lib/packages/element-plus/slider/index.vue +66 -0
  321. package/lib/packages/element-plus/switch/index.vue +72 -0
  322. package/lib/packages/element-plus/tabs/index.vue +62 -0
  323. package/lib/packages/element-plus/text-ellipsis/index.vue +104 -0
  324. package/lib/packages/element-plus/time/index.vue +81 -0
  325. package/lib/packages/element-plus/title/index.vue +30 -0
  326. package/lib/packages/element-plus/tree/index.vue +460 -0
  327. package/lib/packages/element-plus/upload/index.vue +728 -0
  328. package/lib/packages/element-plus/verify/index.vue +62 -0
  329. package/lib/packages/element-plus/video/index.vue +90 -0
  330. package/lib/plugin/ali/index.js +8 -0
  331. package/lib/plugin/ali/index.ts +6 -0
  332. package/lib/plugin/clipboard/index.js +64 -0
  333. package/lib/plugin/clipboard/index.ts +67 -0
  334. package/lib/plugin/export/_blob.js +151 -0
  335. package/lib/plugin/export/_blob.ts +176 -0
  336. package/lib/plugin/export/_export2Excel.js +145 -0
  337. package/lib/plugin/export/_export2Excel.ts +166 -0
  338. package/lib/plugin/export/index.js +268 -0
  339. package/lib/plugin/export/index.ts +274 -0
  340. package/lib/plugin/logs/index.js +48 -0
  341. package/lib/plugin/logs/index.ts +66 -0
  342. package/lib/plugin/print/index.js +147 -0
  343. package/lib/plugin/print/index.ts +155 -0
  344. package/lib/plugin/qiniu/index.js +82 -0
  345. package/lib/plugin/qiniu/index.ts +88 -0
  346. package/lib/plugin/screenshot/index.js +14 -0
  347. package/lib/plugin/screenshot/index.ts +9 -0
  348. package/lib/plugin/video/index.js +55 -0
  349. package/lib/plugin/video/index.ts +60 -0
  350. package/lib/plugin/watermark/index.js +121 -0
  351. package/lib/plugin/watermark/index.ts +127 -0
  352. package/lib/plugin/watermark/watermark.js +111 -0
  353. package/lib/plugin/watermark/watermark.ts +121 -0
  354. package/lib/ui/data/index.js +54 -0
  355. package/lib/ui/data/index.ts +51 -0
  356. package/lib/ui/element-plus/index.js +92 -0
  357. package/lib/ui/element-plus/index.ts +89 -0
  358. package/lib/ui/index.js +9 -0
  359. package/lib/ui/index.ts +6 -0
  360. package/lib/utils/bem.js +31 -0
  361. package/lib/utils/bem.ts +36 -0
  362. package/lib/utils/mock.js +142 -0
  363. package/lib/utils/mock.ts +151 -0
  364. package/lib/utils/util.js +403 -0
  365. package/lib/utils/util.ts +392 -0
  366. package/lib/utils/validate.js +21 -0
  367. package/lib/utils/validate.ts +23 -0
  368. package/lib/version.js +4 -0
  369. package/lib/version.ts +1 -0
  370. package/package.json +20 -10
  371. package/types/index.d.ts +139 -47
  372. package/types/shims-aliases.d.ts +4 -0
  373. package/lib/avue.js.map +0 -1
  374. package/lib/locale/format.js +0 -44
@@ -0,0 +1,107 @@
1
+ <template>
2
+ <span>{{end}}</span>
3
+ </template>
4
+
5
+ <script>
6
+ import CountUp from "countup.js";
7
+ import create from "../../../core/create.js";
8
+ export default create({
9
+ name: "count-up",
10
+ props: {
11
+ animation: {
12
+ type: Boolean,
13
+ default: true
14
+ },
15
+ start: {
16
+ type: Number,
17
+ required: false,
18
+ default: 0
19
+ },
20
+ end: {
21
+ required: true
22
+ },
23
+ decimals: {
24
+ type: Number,
25
+ required: false,
26
+ default: 0
27
+ },
28
+ duration: {
29
+ type: Number,
30
+ required: false,
31
+ default: 2
32
+ },
33
+ options: {
34
+ type: Object,
35
+ required: false,
36
+ default () {
37
+ return {};
38
+ }
39
+ },
40
+ callback: {
41
+ type: Function,
42
+ required: false,
43
+ default: () => { }
44
+ }
45
+ },
46
+ data () {
47
+ return {
48
+ c: null
49
+ };
50
+ },
51
+ watch: {
52
+ decimals () {
53
+ if (this.c && this.c.update) {
54
+ this.c.update(this.end);
55
+ }
56
+ },
57
+ end (value) {
58
+ if (this.c && this.c.update) {
59
+ this.c.update(value);
60
+ }
61
+ }
62
+ },
63
+ mounted () {
64
+ if (this.animation) {
65
+ this.init();
66
+ }
67
+
68
+ },
69
+ methods: {
70
+ init () {
71
+ if (!this.c) {
72
+ this.c = new CountUp(
73
+ this.$el,
74
+ this.start,
75
+ this.end,
76
+ this.decimals,
77
+ this.duration,
78
+ this.options
79
+ );
80
+ this.c.start();
81
+ }
82
+ },
83
+ pauseResume () {
84
+ if (this.c && this.c.pauseResume) {
85
+ this.c.pauseResume();
86
+ }
87
+ },
88
+ reset () {
89
+ if (this.c && this.c.reset) {
90
+ this.c.reset();
91
+ }
92
+ },
93
+ update (newEndVal) {
94
+ if (this.c && this.c.update) {
95
+ this.c.update(newEndVal);
96
+ }
97
+ },
98
+ destroy () {
99
+ this.c = null;
100
+ }
101
+ },
102
+ beforeUnmount () {
103
+ this.destroy();
104
+ },
105
+
106
+ });
107
+ </script>
@@ -0,0 +1,128 @@
1
+ <template>
2
+ <!-- 折叠面板 -->
3
+ <component :is="crud.tableColumnName"
4
+ v-if="crud.tableOption.expand"
5
+ type="expand"
6
+ :class-name="crud.tableOption.expandClassName"
7
+ :label-class-name="crud.tableOption.expandLabelClassName"
8
+ :width="crud.tableOption.expandWidth || config.expandWidth"
9
+ :fixed="validData(crud.tableOption.expandFixed,config.expandFixed)"
10
+ align="center">
11
+ <template #="{row}">
12
+ <slot :row="row"
13
+ :index="row.$index"
14
+ name="expand"></slot>
15
+ </template>
16
+ </component>
17
+
18
+ <!-- 选择框 -->
19
+ <component :is="crud.tableColumnName"
20
+ v-if="crud.tableOption.selection"
21
+ :fixed="validData(crud.tableOption.selectionFixed,config.selectionFixed)"
22
+ type="selection"
23
+ :class-name="crud.tableOption.selectionClassName"
24
+ :label-class-name="crud.tableOption.selectionLabelClassName"
25
+ :selectable="crud.tableOption.selectable"
26
+ :reserve-selection="validData(crud.tableOption.reserveSelection)"
27
+ :width="crud.tableOption.selectionWidth || config.selectionWidth"
28
+ align="center"></component>
29
+ <!-- 序号 -->
30
+ <component :is="crud.tableColumnName"
31
+ v-if="validData(crud.tableOption.index)"
32
+ :fixed="validData(crud.tableOption.indexFixed,config.indexFixed)"
33
+ :label="crud.tableOption.indexLabel || config.indexLabel"
34
+ type="index"
35
+ :class-name="crud.tableOption.indexClassName"
36
+ :label-class-name="crud.tableOption.indexLabelClassName"
37
+ :width="crud.tableOption.indexWidth || config.indexWidth"
38
+ :index="indexMethod"
39
+ align="center">
40
+ <template #="{$index}">
41
+ {{ indexMethod($index)}}
42
+ </template>
43
+ </component>
44
+ </template>
45
+
46
+ <script>
47
+
48
+ import create from "../../../../core/create.js";
49
+ import locale from "../../../../core/locale.js";
50
+ import config from "../config.js";
51
+ import tableItemCard from '../grid/item.vue'
52
+ export default create({
53
+ name: "crud",
54
+ data () {
55
+ return {
56
+ config: config,
57
+ rowSortable: null,
58
+ columnSortable: null,
59
+ }
60
+ },
61
+ components: {
62
+ tableItemCard
63
+ },
64
+ mixins: [locale],
65
+ inject: ["crud"],
66
+ watch: {
67
+ 'crud.isSortable' (val) {
68
+ this.rowDrop(val)
69
+ this.columnDrop(val)
70
+ },
71
+ 'crud.isRowSort' (val) {
72
+ this.rowDrop(val)
73
+ },
74
+ 'crud.isColumnSort' (val) {
75
+ this.columnDrop(val)
76
+ }
77
+ },
78
+ mounted () {
79
+ this.rowDrop()
80
+ this.columnDrop()
81
+ },
82
+ methods: {
83
+ indexMethod (index) {
84
+ return (
85
+ index +
86
+ 1 +
87
+ ((this.crud.page.currentPage || 1) - 1) *
88
+ (this.crud.page.pageSize || 10)
89
+ );
90
+ },
91
+ rowDrop (flag) {
92
+ this.$nextTick(() => {
93
+ if (flag == false) {
94
+ this.rowSortable && this.rowSortable.destroy();
95
+ return
96
+ }
97
+ if (!this.crud.$refs.table.$el) return
98
+ const el = this.crud.$refs.table.$el.querySelectorAll(this.config.dropRowClass)[0]
99
+ this.rowSortable = this.crud.tableDrop('row', el, evt => {
100
+ const oldIndex = evt.oldIndex;
101
+ const newIndex = evt.newIndex;
102
+ this.crud.$emit('sortable-change', oldIndex, newIndex)
103
+ })
104
+ })
105
+ },
106
+ columnDrop (flag) {
107
+ this.$nextTick(() => {
108
+ if (flag == false) {
109
+ this.columnSortable && this.columnSortable.destroy();
110
+ return
111
+ }
112
+ if (!this.crud.$refs.table.$el) return
113
+ const el = this.crud.$refs.table.$el.querySelector(this.config.dropColClass);
114
+ let noIndexCount = 0;
115
+ ['selection', 'index', 'expand'].forEach(ele => {
116
+ if (this.crud.tableOption[ele]) { noIndexCount += 1 }
117
+ })
118
+ this.columnSortable = this.crud.tableDrop('column', el, evt => {
119
+ const newIndex = evt.newIndex - noIndexCount
120
+ const oldIndex = evt.oldIndex - noIndexCount
121
+ this.crud.headerSort(oldIndex, newIndex)
122
+ this.crud.$emit('column-sortable-change', oldIndex, newIndex)
123
+ })
124
+ })
125
+ },
126
+ }
127
+ })
128
+ </script>
@@ -0,0 +1,86 @@
1
+ <template>
2
+ <component
3
+ :is="crud.tableColumnName"
4
+ v-if="getColumnProp(columnOption, 'hide')"
5
+ :prop="columnOption.prop"
6
+ :label="columnOption.label"
7
+ :class-name="columnOption.className"
8
+ :label-class-name="columnOption.labelClassName"
9
+ filter-placement="bottom-end"
10
+ :filters="getColumnProp(columnOption, 'filters')"
11
+ :filter-method="
12
+ columnOption.filters
13
+ ? (value, row) =>
14
+ getColumnProp(columnOption, 'filterMethod', {
15
+ value,
16
+ row,
17
+ column: columnOption,
18
+ })
19
+ : undefined
20
+ "
21
+ :filter-multiple="validData(columnOption.filterMultiple, true)"
22
+ :show-overflow-tooltip="
23
+ columnOption.showOverflowTooltip || columnOption.overHidden
24
+ "
25
+ :tooltip-formatter="columnOption.tooltipFormatter"
26
+ :min-width="columnOption.minWidth"
27
+ :sortable="getColumnProp(columnOption, 'sortable')"
28
+ :render-header="columnOption.renderHeader"
29
+ :align="columnOption.align || crud.tableOption.align"
30
+ :header-align="columnOption.headerAlign || crud.tableOption.headerAlign"
31
+ :width="getColumnProp(columnOption, 'width')"
32
+ :fixed="getColumnProp(columnOption, 'fixed')"
33
+ >
34
+ <template #header="{ $index }">
35
+ <slot
36
+ :name="crud.getSlotName(columnOption, 'H')"
37
+ v-if="crud.getSlotName(columnOption, 'H', crud.$slots)"
38
+ v-bind="{ column: columnOption, $index }"
39
+ ></slot>
40
+ <span v-else>{{ columnOption.label }}</span>
41
+ </template>
42
+ <template v-for="column in columnOption.children">
43
+ <column-dynamic
44
+ v-if="column.children && column.children.length > 0"
45
+ :key="column.label"
46
+ :columnOption="column"
47
+ >
48
+ <template v-for="item in crud.mainSlot" #[item]="scope">
49
+ <slot v-bind="scope" :name="item"></slot>
50
+ </template>
51
+ </column-dynamic>
52
+ <column-slot
53
+ v-else
54
+ :key="column.prop"
55
+ :column="column"
56
+ :column-option="columnOption.children"
57
+ >
58
+ <template v-for="item in crud.mainSlot" #[item]="scope">
59
+ <slot v-bind="scope" :name="item"></slot>
60
+ </template>
61
+ </column-slot>
62
+ </template>
63
+ </component>
64
+ </template>
65
+
66
+ <script>
67
+ import columnSlot from "./column-slot.vue";
68
+ import tableItemCard from "../grid/item.vue";
69
+ export default {
70
+ name: "column-dynamic",
71
+ components: {
72
+ columnSlot,
73
+ tableItemCard,
74
+ },
75
+ inject: ["dynamic", "crud"],
76
+ props: {
77
+ columnOption: Object,
78
+ },
79
+ created() {
80
+ const list = ["getColumnProp"];
81
+ list.forEach((ele) => {
82
+ if (this.dynamic) this[ele] = this.dynamic[ele];
83
+ });
84
+ },
85
+ };
86
+ </script>
@@ -0,0 +1,267 @@
1
+ <template>
2
+ <!-- 操作栏 -->
3
+ <component
4
+ :is="crud.tableColumnName"
5
+ prop="menu"
6
+ :class-name="crud.tableOption.menuClassName"
7
+ :label-class-name="crud.tableOption.menuLabelClassName"
8
+ :fixed="validData(crud.tableOption.menuFixed, config.menuFixed)"
9
+ v-if="
10
+ validData(crud.tableOption.menu, config.menu) &&
11
+ crud.getPermission('menu')
12
+ "
13
+ :label="crud.tableOption.menuTitle || t('crud.menu')"
14
+ :align="crud.tableOption.menuAlign || config.menuAlign"
15
+ :header-align="crud.tableOption.menuHeaderAlign || config.menuHeaderAlign"
16
+ :width="
17
+ crud.isMobile
18
+ ? crud.tableOption.menuXsWidth || config.menuXsWidth
19
+ : crud.tableOption.menuWidth || config.menuWidth
20
+ "
21
+ >
22
+ <template #header="scope">
23
+ <slot
24
+ name="menu-header"
25
+ v-bind="scope"
26
+ :size="crud.size"
27
+ v-if="crud.getSlotName({ prop: 'menu' }, 'H', crud.$slots)"
28
+ ></slot>
29
+ <span v-else>{{ crud.tableOption.menuTitle || t("crud.menu") }}</span>
30
+ </template>
31
+ <template #="{ row, column, $index }">
32
+ <div :class="b('menu')">
33
+ <slot
34
+ name="menu-before"
35
+ v-bind="menuParams({ row, column, $index })"
36
+ ></slot>
37
+ <el-dropdown v-if="isMenu" :size="crud.size">
38
+ <el-button text type="primary" :size="crud.size">
39
+ {{ crud.tableOption.menuBtnTitle || t("crud.menuBtn") }}
40
+ <el-icon class="el-icon--right&quot;">
41
+ <el-icon-arrow-down />
42
+ </el-icon>
43
+ </el-button>
44
+ <template #dropdown>
45
+ <el-dropdown-menu>
46
+ <slot
47
+ name="menu-btn-before"
48
+ v-bind="menuParams({ row, column, $index })"
49
+ ></slot>
50
+ <el-dropdown-item
51
+ :icon="crud.getBtnIcon('viewBtn')"
52
+ :class="b('viewBtn')"
53
+ v-if="validData(crud.tableOption.viewBtn, config.viewBtn) && crud.getPermission('viewBtn', row, $index)"
54
+ @click="crud.rowView(row, $index)"
55
+ >{{ crud.menuIcon("viewBtn") }}</el-dropdown-item
56
+ >
57
+ <el-dropdown-item
58
+ :icon="crud.getBtnIcon('copyBtn')"
59
+ :class="b('copyBtn')"
60
+ v-if="validData(crud.tableOption.copyBtn, config.copyBtn) && crud.getPermission('copyBtn', row, $index)"
61
+ @click="crud.rowCopy(row)"
62
+ >{{ crud.menuIcon("copyBtn") }}</el-dropdown-item
63
+ >
64
+ <el-dropdown-item
65
+ :icon="crud.getBtnIcon('editBtn')"
66
+ :class="b('editBtn')"
67
+ v-if="validData(crud.tableOption.editBtn, config.editBtn) && crud.getPermission('editBtn', row, $index)"
68
+ @click="crud.rowEdit(row, $index)"
69
+ >{{ crud.menuIcon("editBtn") }}</el-dropdown-item
70
+ >
71
+ <el-dropdown-item
72
+ :icon="crud.getBtnIcon('delBtn')"
73
+ :class="b('delBtn')"
74
+ v-if="validData(crud.tableOption.delBtn, config.delBtn) && crud.getPermission('delBtn', row, $index)"
75
+ @click="crud.rowDel(row, $index)"
76
+ >{{ crud.menuIcon("delBtn") }}</el-dropdown-item
77
+ >
78
+ <slot
79
+ name="menu-btn"
80
+ v-bind="menuParams({ row, column, $index })"
81
+ ></slot>
82
+ </el-dropdown-menu>
83
+ </template>
84
+ </el-dropdown>
85
+ <template v-else-if="['button', 'text', 'icon'].includes(menuType)">
86
+ <template v-if="validData(crud.tableOption.cellBtn, config.cellBtn)">
87
+ <el-button
88
+ :type="menuText('primary')"
89
+ :class="b('editBtn')"
90
+ :text="isTextMenu"
91
+ :icon="crud.getBtnIcon('editBtn')"
92
+ :size="crud.size"
93
+ :disabled="crud.btnDisabledList[$index]"
94
+ @click.stop="crud.rowCell(row, $index)"
95
+ v-if="
96
+ validData(crud.tableOption.editBtn, config.editBtn) &&
97
+ !row.$cellEdit
98
+ "
99
+ v-permission="crud.getPermission('editBtn', row, $index)"
100
+ >
101
+ <template v-if="!isIconMenu">
102
+ {{ crud.menuIcon("editBtn") }}
103
+ </template>
104
+ </el-button>
105
+ <el-button
106
+ :type="menuText('primary')"
107
+ :class="b('saveBtn')"
108
+ :text="isTextMenu"
109
+ :icon="crud.getBtnIcon('saveBtn')"
110
+ :size="crud.size"
111
+ :disabled="crud.btnDisabledList[$index]"
112
+ @click.stop="crud.rowCell(row, $index)"
113
+ v-else-if="
114
+ validData(crud.tableOption.saveBtn, config.saveBtn) &&
115
+ row.$cellEdit
116
+ "
117
+ v-permission="crud.getPermission('saveBtn', row, $index)"
118
+ >
119
+ <template v-if="!isIconMenu">
120
+ {{ crud.menuIcon("saveBtn") }}
121
+ </template>
122
+ </el-button>
123
+ <el-button
124
+ :type="menuText('primary')"
125
+ :class="b('cancelBtn')"
126
+ :text="isTextMenu"
127
+ :icon="crud.getBtnIcon('cancelBtn')"
128
+ :size="crud.size"
129
+ :disabled="crud.btnDisabledList[$index]"
130
+ v-permission="crud.getPermission('cancelBtn', row, $index)"
131
+ @click.stop="crud.rowCancel(row, $index)"
132
+ v-if="
133
+ row.$cellEdit &&
134
+ validData(crud.tableOption.cancelBtn, config.cancelBtn)
135
+ "
136
+ >
137
+ <template v-if="!isIconMenu">
138
+ {{ crud.menuIcon("cancelBtn") }}
139
+ </template>
140
+ </el-button>
141
+ </template>
142
+ <el-button
143
+ :type="menuText('primary')"
144
+ :class="b('viewBtn')"
145
+ :text="isTextMenu"
146
+ :icon="crud.getBtnIcon('viewBtn')"
147
+ :size="crud.size"
148
+ :disabled="crud.btnDisabled"
149
+ @click.stop="crud.rowView(row, $index)"
150
+ v-permission="crud.getPermission('viewBtn', row, $index)"
151
+ v-if="validData(crud.tableOption.viewBtn, config.viewBtn)"
152
+ >
153
+ <template v-if="!isIconMenu">
154
+ {{ crud.menuIcon("viewBtn") }}
155
+ </template>
156
+ </el-button>
157
+ <el-button
158
+ :type="menuText('primary')"
159
+ :class="b('copyBtn')"
160
+ :text="isTextMenu"
161
+ :icon="crud.getBtnIcon('copyBtn')"
162
+ :size="crud.size"
163
+ :disabled="crud.btnDisabled"
164
+ @click.stop="crud.rowCopy(row)"
165
+ v-permission="crud.getPermission('copyBtn', row, $index)"
166
+ v-if="validData(crud.tableOption.copyBtn, config.copyBtn)"
167
+ >
168
+ <template v-if="!isIconMenu">
169
+ {{ crud.menuIcon("copyBtn") }}
170
+ </template>
171
+ </el-button>
172
+ <el-button
173
+ :type="menuText('primary')"
174
+ :class="b('editBtn')"
175
+ :text="isTextMenu"
176
+ :icon="crud.getBtnIcon('editBtn')"
177
+ :size="crud.size"
178
+ :disabled="crud.btnDisabled"
179
+ @click.stop="crud.rowEdit(row, $index)"
180
+ v-permission="crud.getPermission('editBtn', row, $index)"
181
+ v-if="
182
+ validData(crud.tableOption.editBtn, config.editBtn) &&
183
+ !crud.tableOption.cellBtn
184
+ "
185
+ >
186
+ <template v-if="!isIconMenu">
187
+ {{ crud.menuIcon("editBtn") }}
188
+ </template>
189
+ </el-button>
190
+ <el-button
191
+ :type="menuText('primary')"
192
+ :class="b('delBtn')"
193
+ :text="isTextMenu"
194
+ :icon="crud.getBtnIcon('delBtn')"
195
+ :size="crud.size"
196
+ :disabled="crud.btnDisabled"
197
+ @click.stop="crud.rowDel(row, $index)"
198
+ v-permission="crud.getPermission('delBtn', row, $index)"
199
+ v-if="
200
+ validData(crud.tableOption.delBtn, config.delBtn) &&
201
+ !row.$cellEdit
202
+ "
203
+ >
204
+ <template v-if="!isIconMenu">
205
+ {{ crud.menuIcon("delBtn") }}
206
+ </template>
207
+ </el-button>
208
+ </template>
209
+ <slot name="menu" v-bind="menuParams({ row, column, $index })"></slot>
210
+ </div>
211
+ </template>
212
+ </component>
213
+ </template>
214
+
215
+ <script>
216
+ import create from "../../../../core/create.js";
217
+ import locale from "../../../../core/locale.js";
218
+ import permission from "../../../core/directive/permission.js";
219
+ import config from "../config.js";
220
+ import tableItemCard from "../grid/item.vue";
221
+ export default create({
222
+ name: "crud",
223
+ data() {
224
+ return {
225
+ config: config,
226
+ };
227
+ },
228
+ components: {
229
+ tableItemCard,
230
+ },
231
+ mixins: [locale],
232
+ inject: ["crud"],
233
+ directives: {
234
+ permission,
235
+ },
236
+ computed: {
237
+ menuType() {
238
+ return this.crud.tableOption.menuType || this.$AVUE.menuType;
239
+ },
240
+ isIconMenu() {
241
+ return this.menuType === "icon";
242
+ },
243
+ isTextMenu() {
244
+ return this.menuType === "text";
245
+ },
246
+ isMenu() {
247
+ return this.menuType === "menu";
248
+ },
249
+ },
250
+ methods: {
251
+ menuText(value) {
252
+ return value;
253
+ },
254
+ menuParams({ row, column, $index }) {
255
+ let parent = this.crud;
256
+ return {
257
+ row,
258
+ column,
259
+ type: this.menuText("primary"),
260
+ disabled: parent.btnDisabled,
261
+ size: parent.size,
262
+ index: $index,
263
+ };
264
+ },
265
+ },
266
+ });
267
+ </script>