ylyx-cli 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (402) hide show
  1. package/README.md +184 -0
  2. package/bin/ylyx.js +95 -0
  3. package/lib/generator.js +192 -0
  4. package/lib/index.js +113 -0
  5. package/lib/interactive.js +87 -0
  6. package/lib/remote.js +179 -0
  7. package/lib/template.js +174 -0
  8. package/lib/utils.js +134 -0
  9. package/package.json +56 -0
  10. package/templates/react-app/files/README.md +23 -0
  11. package/templates/react-app/files/package.json +29 -0
  12. package/templates/react-app/files/public/index.html +11 -0
  13. package/templates/react-app/files/src/App.css +15 -0
  14. package/templates/react-app/files/src/App.js +15 -0
  15. package/templates/react-app/files/src/index.css +10 -0
  16. package/templates/react-app/files/src/index.js +11 -0
  17. package/templates/react-app/template.json +12 -0
  18. package/templates/react-component/files/Component.module.css +5 -0
  19. package/templates/react-component/files/Component.tsx +31 -0
  20. package/templates/react-component/files/index.ts +2 -0
  21. package/templates/react-component/template.json +49 -0
  22. package/templates/vue-app/files/.editorconfig +14 -0
  23. package/templates/vue-app/files/.env.development +21 -0
  24. package/templates/vue-app/files/.env.production +18 -0
  25. package/templates/vue-app/files/.eslintignore +5 -0
  26. package/templates/vue-app/files/.eslintrc.js +267 -0
  27. package/templates/vue-app/files/.prettierignore +12 -0
  28. package/templates/vue-app/files/.travis.yml +5 -0
  29. package/templates/vue-app/files/.vscode/extensions.json +7 -0
  30. package/templates/vue-app/files/.vscode/settings.json +39 -0
  31. package/templates/vue-app/files/LICENSE +191 -0
  32. package/templates/vue-app/files/README.md +87 -0
  33. package/templates/vue-app/files/babel.config.js +11 -0
  34. package/templates/vue-app/files/jest.config.js +24 -0
  35. package/templates/vue-app/files/package.json +136 -0
  36. package/templates/vue-app/files/plopfile.js +7 -0
  37. package/templates/vue-app/files/postcss.config.js +5 -0
  38. package/templates/vue-app/files/prettier.config.js +36 -0
  39. package/templates/vue-app/files/public/default.js +26 -0
  40. package/templates/vue-app/files/public/favicon.ico +0 -0
  41. package/templates/vue-app/files/public/index.html +26 -0
  42. package/templates/vue-app/files/src/App.vue +54 -0
  43. package/templates/vue-app/files/src/api/bigDataV/index.js +198 -0
  44. package/templates/vue-app/files/src/api/data.js +42 -0
  45. package/templates/vue-app/files/src/api/dataArchive/index.js +186 -0
  46. package/templates/vue-app/files/src/api/generator/genConfig.js +16 -0
  47. package/templates/vue-app/files/src/api/generator/generator.js +32 -0
  48. package/templates/vue-app/files/src/api/indexManagement/index.js +39 -0
  49. package/templates/vue-app/files/src/api/institutionMonitor/index.js +396 -0
  50. package/templates/vue-app/files/src/api/institutionSet/index.js +120 -0
  51. package/templates/vue-app/files/src/api/login.js +44 -0
  52. package/templates/vue-app/files/src/api/selfStatistics/index.js +50 -0
  53. package/templates/vue-app/files/src/api/system/code.js +15 -0
  54. package/templates/vue-app/files/src/api/system/dict.js +34 -0
  55. package/templates/vue-app/files/src/api/system/dictDetail.js +52 -0
  56. package/templates/vue-app/files/src/api/system/equipment.js +35 -0
  57. package/templates/vue-app/files/src/api/system/examManage.js +49 -0
  58. package/templates/vue-app/files/src/api/system/examProject.js +48 -0
  59. package/templates/vue-app/files/src/api/system/hosModel.js +35 -0
  60. package/templates/vue-app/files/src/api/system/hospital.js +88 -0
  61. package/templates/vue-app/files/src/api/system/job.js +40 -0
  62. package/templates/vue-app/files/src/api/system/menu.js +67 -0
  63. package/templates/vue-app/files/src/api/system/model.js +42 -0
  64. package/templates/vue-app/files/src/api/system/risConfig.js +9 -0
  65. package/templates/vue-app/files/src/api/system/role.js +64 -0
  66. package/templates/vue-app/files/src/api/system/sysSet.js +19 -0
  67. package/templates/vue-app/files/src/api/system/timing.js +41 -0
  68. package/templates/vue-app/files/src/api/system/user.js +121 -0
  69. package/templates/vue-app/files/src/api/tools/alipay.js +25 -0
  70. package/templates/vue-app/files/src/api/tools/email.js +24 -0
  71. package/templates/vue-app/files/src/api/tools/localStorage.js +27 -0
  72. package/templates/vue-app/files/src/api/tools/qiniu.js +40 -0
  73. package/templates/vue-app/files/src/assets/401_images/401.gif +0 -0
  74. package/templates/vue-app/files/src/assets/404_images/404.png +0 -0
  75. package/templates/vue-app/files/src/assets/404_images/404_cloud.png +0 -0
  76. package/templates/vue-app/files/src/assets/css/font-awesome.css +2342 -0
  77. package/templates/vue-app/files/src/assets/css/font-awesome.min.css +2336 -0
  78. package/templates/vue-app/files/src/assets/fonts/FontAwesome.otf +0 -0
  79. package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.eot +0 -0
  80. package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.svg +2671 -0
  81. package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.ttf +0 -0
  82. package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.woff +0 -0
  83. package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.woff2 +0 -0
  84. package/templates/vue-app/files/src/assets/icons/index.js +9 -0
  85. package/templates/vue-app/files/src/assets/icons/svg/Steve-Jobs.svg +1 -0
  86. package/templates/vue-app/files/src/assets/icons/svg/achive.svg +1 -0
  87. package/templates/vue-app/files/src/assets/icons/svg/alipay.svg +1 -0
  88. package/templates/vue-app/files/src/assets/icons/svg/anq.svg +1 -0
  89. package/templates/vue-app/files/src/assets/icons/svg/app.svg +1 -0
  90. package/templates/vue-app/files/src/assets/icons/svg/archive.svg +1 -0
  91. package/templates/vue-app/files/src/assets/icons/svg/backup.svg +1 -0
  92. package/templates/vue-app/files/src/assets/icons/svg/chain.svg +1 -0
  93. package/templates/vue-app/files/src/assets/icons/svg/chart.svg +1 -0
  94. package/templates/vue-app/files/src/assets/icons/svg/codeConsole.svg +1 -0
  95. package/templates/vue-app/files/src/assets/icons/svg/dashboard.svg +1 -0
  96. package/templates/vue-app/files/src/assets/icons/svg/database.svg +1 -0
  97. package/templates/vue-app/files/src/assets/icons/svg/date.svg +1 -0
  98. package/templates/vue-app/files/src/assets/icons/svg/deploy.svg +1 -0
  99. package/templates/vue-app/files/src/assets/icons/svg/dept.svg +1 -0
  100. package/templates/vue-app/files/src/assets/icons/svg/dev.svg +1 -0
  101. package/templates/vue-app/files/src/assets/icons/svg/develop.svg +1 -0
  102. package/templates/vue-app/files/src/assets/icons/svg/dictionary.svg +1 -0
  103. package/templates/vue-app/files/src/assets/icons/svg/doc.svg +1 -0
  104. package/templates/vue-app/files/src/assets/icons/svg/download.svg +1 -0
  105. package/templates/vue-app/files/src/assets/icons/svg/edit.svg +1 -0
  106. package/templates/vue-app/files/src/assets/icons/svg/education.svg +1 -0
  107. package/templates/vue-app/files/src/assets/icons/svg/email.svg +1 -0
  108. package/templates/vue-app/files/src/assets/icons/svg/equSet.svg +1 -0
  109. package/templates/vue-app/files/src/assets/icons/svg/error.svg +1 -0
  110. package/templates/vue-app/files/src/assets/icons/svg/exit-fullscreen.svg +1 -0
  111. package/templates/vue-app/files/src/assets/icons/svg/fullscreen.svg +1 -0
  112. package/templates/vue-app/files/src/assets/icons/svg/fwb.svg +1 -0
  113. package/templates/vue-app/files/src/assets/icons/svg/github.svg +1 -0
  114. package/templates/vue-app/files/src/assets/icons/svg/goBack.svg +1 -0
  115. package/templates/vue-app/files/src/assets/icons/svg/gonggao.svg +1 -0
  116. package/templates/vue-app/files/src/assets/icons/svg/hospital.svg +2 -0
  117. package/templates/vue-app/files/src/assets/icons/svg/hospital1.svg +2 -0
  118. package/templates/vue-app/files/src/assets/icons/svg/hospitalTotal.svg +1 -0
  119. package/templates/vue-app/files/src/assets/icons/svg/icon.svg +1 -0
  120. package/templates/vue-app/files/src/assets/icons/svg/image.svg +1 -0
  121. package/templates/vue-app/files/src/assets/icons/svg/index.svg +1 -0
  122. package/templates/vue-app/files/src/assets/icons/svg/international.svg +1 -0
  123. package/templates/vue-app/files/src/assets/icons/svg/ipvisits.svg +1 -0
  124. package/templates/vue-app/files/src/assets/icons/svg/java.svg +1 -0
  125. package/templates/vue-app/files/src/assets/icons/svg/link.svg +1 -0
  126. package/templates/vue-app/files/src/assets/icons/svg/list.svg +1 -0
  127. package/templates/vue-app/files/src/assets/icons/svg/lock.svg +1 -0
  128. package/templates/vue-app/files/src/assets/icons/svg/log.svg +1 -0
  129. package/templates/vue-app/files/src/assets/icons/svg/login.svg +1 -0
  130. package/templates/vue-app/files/src/assets/icons/svg/loginOne.svg +35 -0
  131. package/templates/vue-app/files/src/assets/icons/svg/loginOneWhite.svg +19 -0
  132. package/templates/vue-app/files/src/assets/icons/svg/loginOr.svg +93 -0
  133. package/templates/vue-app/files/src/assets/icons/svg/loginUp.svg +96 -0
  134. package/templates/vue-app/files/src/assets/icons/svg/markdown.svg +1 -0
  135. package/templates/vue-app/files/src/assets/icons/svg/menu.svg +1 -0
  136. package/templates/vue-app/files/src/assets/icons/svg/message.svg +1 -0
  137. package/templates/vue-app/files/src/assets/icons/svg/mnt.svg +1 -0
  138. package/templates/vue-app/files/src/assets/icons/svg/money.svg +1 -0
  139. package/templates/vue-app/files/src/assets/icons/svg/monitor.svg +1 -0
  140. package/templates/vue-app/files/src/assets/icons/svg/nested.svg +1 -0
  141. package/templates/vue-app/files/src/assets/icons/svg/network.svg +1 -0
  142. package/templates/vue-app/files/src/assets/icons/svg/offline.svg +1 -0
  143. package/templates/vue-app/files/src/assets/icons/svg/online.svg +1 -0
  144. package/templates/vue-app/files/src/assets/icons/svg/password.svg +1 -0
  145. package/templates/vue-app/files/src/assets/icons/svg/people.svg +1 -0
  146. package/templates/vue-app/files/src/assets/icons/svg/peoples.svg +1 -0
  147. package/templates/vue-app/files/src/assets/icons/svg/perSet.svg +1 -0
  148. package/templates/vue-app/files/src/assets/icons/svg/permission.svg +1 -0
  149. package/templates/vue-app/files/src/assets/icons/svg/phone.svg +1 -0
  150. package/templates/vue-app/files/src/assets/icons/svg/piechart.svg +1 -0
  151. package/templates/vue-app/files/src/assets/icons/svg/qiniu.svg +1 -0
  152. package/templates/vue-app/files/src/assets/icons/svg/redis.svg +1 -0
  153. package/templates/vue-app/files/src/assets/icons/svg/resetpassword.svg +1 -0
  154. package/templates/vue-app/files/src/assets/icons/svg/resetpassword1.svg +1 -0
  155. package/templates/vue-app/files/src/assets/icons/svg/role.svg +1 -0
  156. package/templates/vue-app/files/src/assets/icons/svg/search.svg +1 -0
  157. package/templates/vue-app/files/src/assets/icons/svg/server.svg +1 -0
  158. package/templates/vue-app/files/src/assets/icons/svg/shopping.svg +1 -0
  159. package/templates/vue-app/files/src/assets/icons/svg/size.svg +1 -0
  160. package/templates/vue-app/files/src/assets/icons/svg/skill.svg +1 -0
  161. package/templates/vue-app/files/src/assets/icons/svg/source.svg +1 -0
  162. package/templates/vue-app/files/src/assets/icons/svg/sqlMonitor.svg +1 -0
  163. package/templates/vue-app/files/src/assets/icons/svg/statistical.svg +1 -0
  164. package/templates/vue-app/files/src/assets/icons/svg/swagger.svg +1 -0
  165. package/templates/vue-app/files/src/assets/icons/svg/sys-tools.svg +1 -0
  166. package/templates/vue-app/files/src/assets/icons/svg/system.svg +1 -0
  167. package/templates/vue-app/files/src/assets/icons/svg/system1.svg +1 -0
  168. package/templates/vue-app/files/src/assets/icons/svg/tab.svg +1 -0
  169. package/templates/vue-app/files/src/assets/icons/svg/teams.svg +1 -0
  170. package/templates/vue-app/files/src/assets/icons/svg/theme.svg +1 -0
  171. package/templates/vue-app/files/src/assets/icons/svg/timing.svg +1 -0
  172. package/templates/vue-app/files/src/assets/icons/svg/tools.svg +1 -0
  173. package/templates/vue-app/files/src/assets/icons/svg/tree-table.svg +1 -0
  174. package/templates/vue-app/files/src/assets/icons/svg/tree.svg +1 -0
  175. package/templates/vue-app/files/src/assets/icons/svg/unlock.svg +1 -0
  176. package/templates/vue-app/files/src/assets/icons/svg/user.svg +1 -0
  177. package/templates/vue-app/files/src/assets/icons/svg/user1.svg +1 -0
  178. package/templates/vue-app/files/src/assets/icons/svg/validCode.svg +1 -0
  179. package/templates/vue-app/files/src/assets/icons/svg/visits.svg +1 -0
  180. package/templates/vue-app/files/src/assets/icons/svg/web.svg +1 -0
  181. package/templates/vue-app/files/src/assets/icons/svg/wechat.svg +1 -0
  182. package/templates/vue-app/files/src/assets/icons/svg/weixin.svg +1 -0
  183. package/templates/vue-app/files/src/assets/icons/svg/zujian.svg +1 -0
  184. package/templates/vue-app/files/src/assets/icons/svgo.yml +21 -0
  185. package/templates/vue-app/files/src/assets/images/archive.png +0 -0
  186. package/templates/vue-app/files/src/assets/images/archive_icon.png +0 -0
  187. package/templates/vue-app/files/src/assets/images/avatar.png +0 -0
  188. package/templates/vue-app/files/src/assets/images/background.jpg +0 -0
  189. package/templates/vue-app/files/src/assets/images/bg.png +0 -0
  190. package/templates/vue-app/files/src/assets/images/gongan.png +0 -0
  191. package/templates/vue-app/files/src/assets/images/hospital_icon.png +0 -0
  192. package/templates/vue-app/files/src/assets/images/location.png +0 -0
  193. package/templates/vue-app/files/src/assets/images/logintitle.jpg +0 -0
  194. package/templates/vue-app/files/src/assets/images/logo-copy1.png +0 -0
  195. package/templates/vue-app/files/src/assets/images/logo.png +0 -0
  196. package/templates/vue-app/files/src/assets/images/logoBg.png +0 -0
  197. package/templates/vue-app/files/src/assets/images/offline-bg.png +0 -0
  198. package/templates/vue-app/files/src/assets/images/position.png +0 -0
  199. package/templates/vue-app/files/src/assets/images/qualityBg.jpg +0 -0
  200. package/templates/vue-app/files/src/assets/images/self-bg.png +0 -0
  201. package/templates/vue-app/files/src/assets/images/self-bg2.png +0 -0
  202. package/templates/vue-app/files/src/assets/images/triAngel.png +0 -0
  203. package/templates/vue-app/files/src/assets/images/triAngelNormal.png +0 -0
  204. package/templates/vue-app/files/src/assets/styles/btn.scss +103 -0
  205. package/templates/vue-app/files/src/assets/styles/eladmin.scss +124 -0
  206. package/templates/vue-app/files/src/assets/styles/element-ui.scss +217 -0
  207. package/templates/vue-app/files/src/assets/styles/element-variables.scss +31 -0
  208. package/templates/vue-app/files/src/assets/styles/global.scss +73 -0
  209. package/templates/vue-app/files/src/assets/styles/index.scss +220 -0
  210. package/templates/vue-app/files/src/assets/styles/mixin.scss +60 -0
  211. package/templates/vue-app/files/src/assets/styles/publicStyle.scss +224 -0
  212. package/templates/vue-app/files/src/assets/styles/sidebar.scss +239 -0
  213. package/templates/vue-app/files/src/assets/styles/transition.scss +48 -0
  214. package/templates/vue-app/files/src/assets/styles/variables.scss +44 -0
  215. package/templates/vue-app/files/src/common/flexible.js +145 -0
  216. package/templates/vue-app/files/src/components/Breadcrumb/index.vue +87 -0
  217. package/templates/vue-app/files/src/components/Crud/CRUD.operation.vue +248 -0
  218. package/templates/vue-app/files/src/components/Crud/Pagination.vue +20 -0
  219. package/templates/vue-app/files/src/components/Crud/RR.operation.vue +39 -0
  220. package/templates/vue-app/files/src/components/Crud/UD.operation.vue +106 -0
  221. package/templates/vue-app/files/src/components/Crud/crud.js +907 -0
  222. package/templates/vue-app/files/src/components/Crud/user/UR.operation.vue +154 -0
  223. package/templates/vue-app/files/src/components/DateRangePicker/index.vue +42 -0
  224. package/templates/vue-app/files/src/components/DateRangePickerProhibitNext/index.vue +42 -0
  225. package/templates/vue-app/files/src/components/DateRangePickerProhibitTodayNext/index.vue +48 -0
  226. package/templates/vue-app/files/src/components/Dict/Dict.js +31 -0
  227. package/templates/vue-app/files/src/components/Dict/index.js +29 -0
  228. package/templates/vue-app/files/src/components/Doc/index.vue +16 -0
  229. package/templates/vue-app/files/src/components/Echarts/BarChart.vue +115 -0
  230. package/templates/vue-app/files/src/components/Echarts/Category.vue +768 -0
  231. package/templates/vue-app/files/src/components/Echarts/Funnel.vue +120 -0
  232. package/templates/vue-app/files/src/components/Echarts/Gauge.vue +74 -0
  233. package/templates/vue-app/files/src/components/Echarts/Graph.vue +101 -0
  234. package/templates/vue-app/files/src/components/Echarts/HeatMap.vue +301 -0
  235. package/templates/vue-app/files/src/components/Echarts/Line3D.vue +110 -0
  236. package/templates/vue-app/files/src/components/Echarts/PieChart.vue +84 -0
  237. package/templates/vue-app/files/src/components/Echarts/Point.vue +161 -0
  238. package/templates/vue-app/files/src/components/Echarts/RadarChart.vue +123 -0
  239. package/templates/vue-app/files/src/components/Echarts/Rich.vue +160 -0
  240. package/templates/vue-app/files/src/components/Echarts/Sankey.vue +114 -0
  241. package/templates/vue-app/files/src/components/Echarts/Scatter.vue +192 -0
  242. package/templates/vue-app/files/src/components/Echarts/Sunburst.vue +127 -0
  243. package/templates/vue-app/files/src/components/Echarts/ThemeRiver.vue +233 -0
  244. package/templates/vue-app/files/src/components/Echarts/WordCloud.vue +201 -0
  245. package/templates/vue-app/files/src/components/GithubCorner/index.vue +55 -0
  246. package/templates/vue-app/files/src/components/Hamburger/index.vue +44 -0
  247. package/templates/vue-app/files/src/components/HeaderSearch/index.vue +196 -0
  248. package/templates/vue-app/files/src/components/IconSelect/index.vue +74 -0
  249. package/templates/vue-app/files/src/components/IconSelect/requireIcons.js +10 -0
  250. package/templates/vue-app/files/src/components/Iframe/index.vue +30 -0
  251. package/templates/vue-app/files/src/components/JavaEdit/index.vue +78 -0
  252. package/templates/vue-app/files/src/components/Pagination/index.vue +100 -0
  253. package/templates/vue-app/files/src/components/PanThumb/index.vue +149 -0
  254. package/templates/vue-app/files/src/components/ParentView/index.vue +3 -0
  255. package/templates/vue-app/files/src/components/Permission/index.js +13 -0
  256. package/templates/vue-app/files/src/components/Permission/permission.js +21 -0
  257. package/templates/vue-app/files/src/components/RightPanel/index.vue +149 -0
  258. package/templates/vue-app/files/src/components/Screenfull/index.vue +60 -0
  259. package/templates/vue-app/files/src/components/SizeSelect/index.vue +60 -0
  260. package/templates/vue-app/files/src/components/SvgIcon/index.vue +66 -0
  261. package/templates/vue-app/files/src/components/ThemePicker/index.vue +177 -0
  262. package/templates/vue-app/files/src/components/UploadExcel/index.vue +149 -0
  263. package/templates/vue-app/files/src/components/WaterMark/setWaterMark.js +68 -0
  264. package/templates/vue-app/files/src/components/WaterMark/waterMark.vue +69 -0
  265. package/templates/vue-app/files/src/components/Xgplayer/index.vue +49 -0
  266. package/templates/vue-app/files/src/components/YamlEdit/index.vue +81 -0
  267. package/templates/vue-app/files/src/layout/components/AppMain.vue +67 -0
  268. package/templates/vue-app/files/src/layout/components/Navbar.vue +209 -0
  269. package/templates/vue-app/files/src/layout/components/Settings/index.vue +125 -0
  270. package/templates/vue-app/files/src/layout/components/Sidebar/FixiOSBug.js +26 -0
  271. package/templates/vue-app/files/src/layout/components/Sidebar/Item.vue +29 -0
  272. package/templates/vue-app/files/src/layout/components/Sidebar/Link.vue +35 -0
  273. package/templates/vue-app/files/src/layout/components/Sidebar/Logo.vue +93 -0
  274. package/templates/vue-app/files/src/layout/components/Sidebar/SidebarItem.vue +104 -0
  275. package/templates/vue-app/files/src/layout/components/Sidebar/index.vue +79 -0
  276. package/templates/vue-app/files/src/layout/components/TagsView/ScrollPane.vue +90 -0
  277. package/templates/vue-app/files/src/layout/components/TagsView/index.vue +299 -0
  278. package/templates/vue-app/files/src/layout/components/index.js +5 -0
  279. package/templates/vue-app/files/src/layout/index.vue +119 -0
  280. package/templates/vue-app/files/src/layout/mixin/ResizeHandler.js +45 -0
  281. package/templates/vue-app/files/src/main.js +89 -0
  282. package/templates/vue-app/files/src/mixins/crud.js +348 -0
  283. package/templates/vue-app/files/src/router/index.js +156 -0
  284. package/templates/vue-app/files/src/router/routers.js +203 -0
  285. package/templates/vue-app/files/src/settings.js +57 -0
  286. package/templates/vue-app/files/src/store/getters.js +29 -0
  287. package/templates/vue-app/files/src/store/index.js +25 -0
  288. package/templates/vue-app/files/src/store/modules/api.js +33 -0
  289. package/templates/vue-app/files/src/store/modules/app.js +55 -0
  290. package/templates/vue-app/files/src/store/modules/permission.js +79 -0
  291. package/templates/vue-app/files/src/store/modules/register.js +17 -0
  292. package/templates/vue-app/files/src/store/modules/settings.js +46 -0
  293. package/templates/vue-app/files/src/store/modules/tagsView.js +168 -0
  294. package/templates/vue-app/files/src/store/modules/user.js +119 -0
  295. package/templates/vue-app/files/src/utils/auth.js +18 -0
  296. package/templates/vue-app/files/src/utils/base64ToFile.js +27 -0
  297. package/templates/vue-app/files/src/utils/clipboard.js +36 -0
  298. package/templates/vue-app/files/src/utils/datetime.js +289 -0
  299. package/templates/vue-app/files/src/utils/getBlobFile.js +10 -0
  300. package/templates/vue-app/files/src/utils/getTime.js +29 -0
  301. package/templates/vue-app/files/src/utils/index.js +520 -0
  302. package/templates/vue-app/files/src/utils/permission.js +29 -0
  303. package/templates/vue-app/files/src/utils/pinyin.js +450 -0
  304. package/templates/vue-app/files/src/utils/request.js +139 -0
  305. package/templates/vue-app/files/src/utils/rsaEncrypt.js +37 -0
  306. package/templates/vue-app/files/src/utils/shortcuts.js +210 -0
  307. package/templates/vue-app/files/src/utils/upload.js +12 -0
  308. package/templates/vue-app/files/src/utils/validate.js +262 -0
  309. package/templates/vue-app/files/src/views/components/Echarts.vue +124 -0
  310. package/templates/vue-app/files/src/views/components/Editor.vue +75 -0
  311. package/templates/vue-app/files/src/views/components/MarkDown.vue +44 -0
  312. package/templates/vue-app/files/src/views/components/UVideo.vue +37 -0
  313. package/templates/vue-app/files/src/views/components/YamlEdit.vue +206 -0
  314. package/templates/vue-app/files/src/views/components/camera/camera.vue +115 -0
  315. package/templates/vue-app/files/src/views/components/camera/cameraTest.vue +158 -0
  316. package/templates/vue-app/files/src/views/components/excel/upload-excel.vue +41 -0
  317. package/templates/vue-app/files/src/views/components/icons/element-icons.js +74 -0
  318. package/templates/vue-app/files/src/views/components/icons/index.vue +106 -0
  319. package/templates/vue-app/files/src/views/components/icons/svg-icons.js +10 -0
  320. package/templates/vue-app/files/src/views/components/scroll/index.vue +107 -0
  321. package/templates/vue-app/files/src/views/components/scrollFull/index.vue +99 -0
  322. package/templates/vue-app/files/src/views/dashboard/LineChart.vue +138 -0
  323. package/templates/vue-app/files/src/views/dashboard/PanelGroup.vue +173 -0
  324. package/templates/vue-app/files/src/views/dashboard/mixins/resize.js +57 -0
  325. package/templates/vue-app/files/src/views/dataArchive/delTable.vue +354 -0
  326. package/templates/vue-app/files/src/views/dataArchive/exportDetail.vue +121 -0
  327. package/templates/vue-app/files/src/views/dataArchive/exportList.vue +160 -0
  328. package/templates/vue-app/files/src/views/dataArchive/index.vue +2104 -0
  329. package/templates/vue-app/files/src/views/features/401.vue +83 -0
  330. package/templates/vue-app/files/src/views/features/404.vue +226 -0
  331. package/templates/vue-app/files/src/views/features/redirect.vue +12 -0
  332. package/templates/vue-app/files/src/views/generator/config.vue +348 -0
  333. package/templates/vue-app/files/src/views/generator/index.vue +143 -0
  334. package/templates/vue-app/files/src/views/generator/preview.vue +39 -0
  335. package/templates/vue-app/files/src/views/home.vue +80 -0
  336. package/templates/vue-app/files/src/views/indexManagement/index.vue +422 -0
  337. package/templates/vue-app/files/src/views/indexManagement/other.vue +286 -0
  338. package/templates/vue-app/files/src/views/institutionMonitor/components/LineChart.vue +191 -0
  339. package/templates/vue-app/files/src/views/institutionMonitor/index.scss +339 -0
  340. package/templates/vue-app/files/src/views/institutionMonitor/index.vue +1385 -0
  341. package/templates/vue-app/files/src/views/institutionMonitor/mixins/resize.js +57 -0
  342. package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/checkProjectCode.vue +267 -0
  343. package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/imageAbnormalMonitor.vue +361 -0
  344. package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/index.vue +686 -0
  345. package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/leakageAnomaly.vue +270 -0
  346. package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/moveMonitore.vue +114 -0
  347. package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/qualityMonitore.vue +338 -0
  348. package/templates/vue-app/files/src/views/institutionSet/cloudSet.vue +534 -0
  349. package/templates/vue-app/files/src/views/institutionSet/index.vue +2550 -0
  350. package/templates/vue-app/files/src/views/login.vue +243 -0
  351. package/templates/vue-app/files/src/views/qualityLogin.vue +280 -0
  352. package/templates/vue-app/files/src/views/selfStatistics/components/LineChart.vue +296 -0
  353. package/templates/vue-app/files/src/views/selfStatistics/hospitalDetail/index.vue +533 -0
  354. package/templates/vue-app/files/src/views/selfStatistics/index.scss +447 -0
  355. package/templates/vue-app/files/src/views/selfStatistics/index.vue +903 -0
  356. package/templates/vue-app/files/src/views/selfStatistics/mixins/resize.js +57 -0
  357. package/templates/vue-app/files/src/views/selfStatistics/monitorDetail/index.vue +285 -0
  358. package/templates/vue-app/files/src/views/selfStatistics/offlineDetail/index.vue +104 -0
  359. package/templates/vue-app/files/src/views/selfStatistics/selfActiveDetail/index.vue +104 -0
  360. package/templates/vue-app/files/src/views/selfStatistics/selfMonitorDetail/index.vue +420 -0
  361. package/templates/vue-app/files/src/views/selfStatistics/setWaterMark/setWaterMark.js +68 -0
  362. package/templates/vue-app/files/src/views/selfStatistics/setWaterMark/waterMark.vue +69 -0
  363. package/templates/vue-app/files/src/views/system/dept/index.vue +144 -0
  364. package/templates/vue-app/files/src/views/system/dict/dictDetail.vue +146 -0
  365. package/templates/vue-app/files/src/views/system/dict/index.vue +159 -0
  366. package/templates/vue-app/files/src/views/system/examModality/index.vue +174 -0
  367. package/templates/vue-app/files/src/views/system/examPart/index.vue +184 -0
  368. package/templates/vue-app/files/src/views/system/examProject/index.vue +321 -0
  369. package/templates/vue-app/files/src/views/system/examine/index.vue +66 -0
  370. package/templates/vue-app/files/src/views/system/job/index.vue +119 -0
  371. package/templates/vue-app/files/src/views/system/job/module/form.vue +72 -0
  372. package/templates/vue-app/files/src/views/system/job/module/header.vue +48 -0
  373. package/templates/vue-app/files/src/views/system/menu/index.vue +327 -0
  374. package/templates/vue-app/files/src/views/system/model/index.vue +285 -0
  375. package/templates/vue-app/files/src/views/system/role/index.vue +434 -0
  376. package/templates/vue-app/files/src/views/system/sysSet/index.vue +84 -0
  377. package/templates/vue-app/files/src/views/system/timing/index.vue +289 -0
  378. package/templates/vue-app/files/src/views/system/timing/log.vue +143 -0
  379. package/templates/vue-app/files/src/views/system/user/admin.vue +414 -0
  380. package/templates/vue-app/files/src/views/system/user/center/updateEmail.vue +146 -0
  381. package/templates/vue-app/files/src/views/system/user/center/updatePass.vue +168 -0
  382. package/templates/vue-app/files/src/views/system/user/center.vue +140 -0
  383. package/templates/vue-app/files/src/views/system/user/index.vue +972 -0
  384. package/templates/vue-app/files/src/views/systemSet/role/index.vue +314 -0
  385. package/templates/vue-app/files/src/views/systemSet/user/admin.vue +414 -0
  386. package/templates/vue-app/files/src/views/systemSet/user/center/updateEmail.vue +146 -0
  387. package/templates/vue-app/files/src/views/systemSet/user/center/updatePass.vue +115 -0
  388. package/templates/vue-app/files/src/views/systemSet/user/center.vue +351 -0
  389. package/templates/vue-app/files/src/views/systemSet/user/index.vue +928 -0
  390. package/templates/vue-app/files/src/views/tools/aliPay/config.vue +102 -0
  391. package/templates/vue-app/files/src/views/tools/aliPay/index.vue +48 -0
  392. package/templates/vue-app/files/src/views/tools/aliPay/toPay.vue +91 -0
  393. package/templates/vue-app/files/src/views/tools/email/config.vue +91 -0
  394. package/templates/vue-app/files/src/views/tools/email/index.vue +42 -0
  395. package/templates/vue-app/files/src/views/tools/email/send.vue +159 -0
  396. package/templates/vue-app/files/src/views/tools/storage/index.vue +35 -0
  397. package/templates/vue-app/files/src/views/tools/storage/local/index.vue +207 -0
  398. package/templates/vue-app/files/src/views/tools/storage/qiniu/form.vue +108 -0
  399. package/templates/vue-app/files/src/views/tools/storage/qiniu/index.vue +241 -0
  400. package/templates/vue-app/files/src/views/tools/swagger/index.vue +14 -0
  401. package/templates/vue-app/files/vue.config.js +173 -0
  402. package/templates/vue-app/template.json +30 -0
@@ -0,0 +1,74 @@
1
+ const elementIcons = [
2
+ 'info',
3
+ 'error',
4
+ 'success',
5
+ 'warning',
6
+ 'question',
7
+ 'back',
8
+ 'arrow-left',
9
+ 'arrow-down',
10
+ 'arrow-right',
11
+ 'arrow-up',
12
+ 'caret-left',
13
+ 'caret-bottom',
14
+ 'caret-top',
15
+ 'caret-right',
16
+ 'd-arrow-left',
17
+ 'd-arrow-right',
18
+ 'minus',
19
+ 'plus',
20
+ 'remove',
21
+ 'circle-plus',
22
+ 'remove-outline',
23
+ 'circle-plus-outline',
24
+ 'close',
25
+ 'check',
26
+ 'circle-close',
27
+ 'circle-check',
28
+ 'circle-close-outline',
29
+ 'circle-check-outline',
30
+ 'zoom-out',
31
+ 'zoom-in',
32
+ 'd-caret',
33
+ 'sort',
34
+ 'sort-down',
35
+ 'sort-up',
36
+ 'tickets',
37
+ 'document',
38
+ 'goods',
39
+ 'sold-out',
40
+ 'news',
41
+ 'message',
42
+ 'date',
43
+ 'printer',
44
+ 'time',
45
+ 'bell',
46
+ 'mobile-phone',
47
+ 'service',
48
+ 'view',
49
+ 'menu',
50
+ 'more',
51
+ 'more-outline',
52
+ 'star-on',
53
+ 'star-off',
54
+ 'location',
55
+ 'location-outline',
56
+ 'phone',
57
+ 'phone-outline',
58
+ 'picture',
59
+ 'picture-outline',
60
+ 'delete',
61
+ 'search',
62
+ 'edit',
63
+ 'edit-outline',
64
+ 'rank',
65
+ 'refresh',
66
+ 'share',
67
+ 'setting',
68
+ 'upload',
69
+ 'upload2',
70
+ 'download',
71
+ 'loading',
72
+ ];
73
+
74
+ export default elementIcons;
@@ -0,0 +1,106 @@
1
+ <template>
2
+ <div class="icons-container">
3
+ <aside>
4
+ <a
5
+ href="https://panjiachen.github.io/vue-element-admin-site/guide/advanced/icon.html"
6
+ target="_blank"
7
+ >Add and use
8
+ </a>
9
+ </aside>
10
+ <el-tabs type="border-card">
11
+ <el-tab-pane label="Icons">
12
+ <div class="grid">
13
+ <div
14
+ v-for="item of svgIcons"
15
+ :key="item"
16
+ @click="handleClipboard(generateIconCode(item), $event)">
17
+ <el-tooltip placement="top">
18
+ <div slot="content">
19
+ {{ generateIconCode(item) }}
20
+ </div>
21
+ <div class="icon-item">
22
+ <svg-icon :icon-class="item" class-name="disabled" />
23
+ <span>{{ item }}</span>
24
+ </div>
25
+ </el-tooltip>
26
+ </div>
27
+ </div>
28
+ </el-tab-pane>
29
+ <el-tab-pane label="Element-UI Icons">
30
+ <div class="grid">
31
+ <div
32
+ v-for="item of elementIcons"
33
+ :key="item"
34
+ @click="handleClipboard(generateElementIconCode(item), $event)">
35
+ <el-tooltip placement="top">
36
+ <div slot="content">
37
+ {{ generateElementIconCode(item) }}
38
+ </div>
39
+ <div class="icon-item">
40
+ <i :class="'el-icon-' + item" />
41
+ <span>{{ item }}</span>
42
+ </div>
43
+ </el-tooltip>
44
+ </div>
45
+ </div>
46
+ </el-tab-pane>
47
+ </el-tabs>
48
+ </div>
49
+ </template>
50
+
51
+ <script>
52
+ import clipboard from '@/utils/clipboard';
53
+ import svgIcons from './svg-icons';
54
+ import elementIcons from './element-icons';
55
+ export default {
56
+ name: 'Icons',
57
+ data() {
58
+ return {
59
+ svgIcons,
60
+ elementIcons,
61
+ };
62
+ },
63
+ methods: {
64
+ generateIconCode(symbol) {
65
+ return `<svg-icon icon-class="${symbol}" />`;
66
+ },
67
+ generateElementIconCode(symbol) {
68
+ return `<i class="el-icon-${symbol}" />`;
69
+ },
70
+ handleClipboard(text, event) {
71
+ clipboard(text, event);
72
+ },
73
+ },
74
+ };
75
+ </script>
76
+
77
+ <style lang="scss" scoped>
78
+ .icons-container {
79
+ margin: 10px 20px 0;
80
+ overflow: hidden;
81
+
82
+ .grid {
83
+ position: relative;
84
+ display: grid;
85
+ grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
86
+ }
87
+ .icon-item {
88
+ margin: 20px;
89
+ height: 85px;
90
+ text-align: center;
91
+ width: 100px;
92
+ float: left;
93
+ font-size: 30px;
94
+ color: #24292e;
95
+ cursor: pointer;
96
+ }
97
+ span {
98
+ display: block;
99
+ font-size: 16px;
100
+ margin-top: 10px;
101
+ }
102
+ .disabled {
103
+ pointer-events: none;
104
+ }
105
+ }
106
+ </style>
@@ -0,0 +1,10 @@
1
+ const req = require.context('../../../assets/icons/svg', false, /\.svg$/);
2
+ const requireAll = requireContext => requireContext.keys();
3
+
4
+ const re = /\.\/(.*)\.svg/;
5
+
6
+ const svgIcons = requireAll(req).map(i => {
7
+ return i.match(re)[1];
8
+ });
9
+
10
+ export default svgIcons;
@@ -0,0 +1,107 @@
1
+ <template>
2
+ <div class="number">
3
+ <ul id="dataNums">
4
+ <li v-for="(item, index) in list" :key="index" :class="{ douhao: item === ',' }">
5
+ <div class="dataBoc">
6
+ <div
7
+ class="tt"
8
+ :style="{ transition: 'all 2.5s ease-in-out 0s', top: '-' + item.top + 'px' }">
9
+ <em v-for="(item2, index2) in numList" :key="index2">{{ item2 }} </em>
10
+ </div>
11
+ </div>
12
+ </li>
13
+ </ul>
14
+ </div>
15
+ </template>
16
+ <script>
17
+ export default {
18
+ props: {
19
+ number: {
20
+ type: Number,
21
+ require: true,
22
+ },
23
+ },
24
+ data() {
25
+ return {
26
+ list: [],
27
+ numList: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, ','],
28
+ };
29
+ },
30
+ watch: {
31
+ //
32
+ number(val) {
33
+ // console.log(val, '[1,2,3,4,5,6,7,8,9,0]')
34
+ this.scroll();
35
+ },
36
+ },
37
+ methods: {
38
+ scroll() {
39
+ this.list = this.number
40
+ .toString()
41
+ .replace(/\B(?=(\d{3})+$)/g, ',')
42
+ .split('');
43
+
44
+ let arr = [];
45
+ this.list.forEach(value => {
46
+ arr.push({ num: value, top: 0 });
47
+ });
48
+ this.list = arr;
49
+ let Hei = parseFloat(getComputedStyle(document.getElementById('dataNums')).height);
50
+ this.list.forEach((value, index) => {
51
+ if (value.num == ',') {
52
+ value.top = parseFloat(20 * Hei);
53
+ } else {
54
+ setTimeout(() => {
55
+ value.top = parseFloat(value.num * Hei + Hei * 10);
56
+ }, index * 300);
57
+ }
58
+ });
59
+ },
60
+ },
61
+ };
62
+ </script>
63
+ <style lang="scss" scoped>
64
+ .number {
65
+ text-align: center;
66
+ display: inline-block;
67
+ ul {
68
+ display: inline-block;
69
+ height: 50px;
70
+ text-align: center;
71
+ margin: 0;
72
+ padding: 0;
73
+ position: relative;
74
+ top: 7px;
75
+ li {
76
+ float: left;
77
+ width: 13px;
78
+ height: 50px;
79
+ text-align: center;
80
+ list-style: none;
81
+ .dataBoc {
82
+ position: relative;
83
+ width: 100%;
84
+ height: 100%;
85
+ overflow: hidden;
86
+ .tt {
87
+ position: absolute;
88
+ top: 0;
89
+ left: 0;
90
+ width: 100%;
91
+ height: 100%;
92
+ em {
93
+ width: 100%;
94
+ height: 100%;
95
+ float: left;
96
+ line-height: 50px;
97
+ font-style: normal;
98
+ text-align: center;
99
+ font-size: 22px;
100
+ color: #66e8e5;
101
+ }
102
+ }
103
+ }
104
+ }
105
+ }
106
+ }
107
+ </style>
@@ -0,0 +1,99 @@
1
+ <template>
2
+ <div class="number">
3
+ <ul id="dataNums">
4
+ <li v-for="(item, index) in list" :key="index">
5
+ <div class="dataBoc">
6
+ <div
7
+ class="tt"
8
+ :style="{ transition: 'all 2.5s ease-in-out 0s', top: '-' + item.top + 'px' }">
9
+ <em v-for="(item2, index2) in numList" :key="index2">{{ item2 }} </em>
10
+ </div>
11
+ </div>
12
+ </li>
13
+ </ul>
14
+ </div>
15
+ </template>
16
+ <script>
17
+ export default {
18
+ props: {
19
+ number: {
20
+ type: Number,
21
+ require: true,
22
+ },
23
+ },
24
+ data() {
25
+ return {
26
+ list: [],
27
+ numList: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, '.'],
28
+ };
29
+ },
30
+ watch: {
31
+ //
32
+ number(val) {
33
+ // console.log(val, '[1,2,3,4,5,6,7,8,9,0]')
34
+ this.scroll();
35
+ },
36
+ },
37
+ methods: {
38
+ scroll() {
39
+ this.list = this.number.toString().split('');
40
+ let arr = [];
41
+ this.list.forEach(value => {
42
+ arr.push({ num: value, top: 0 });
43
+ });
44
+ this.list = arr;
45
+ let Hei = parseFloat(getComputedStyle(document.getElementById('dataNums')).height);
46
+ this.list.forEach((value, index) => {
47
+ setTimeout(() => {
48
+ value.top = parseFloat(value.num * Hei + Hei * 10);
49
+ }, index * 300);
50
+ });
51
+ },
52
+ },
53
+ };
54
+ </script>
55
+ <style lang="scss" scoped>
56
+ .number {
57
+ text-align: center;
58
+ display: inline-block;
59
+ ul {
60
+ display: inline-block;
61
+ height: 50px;
62
+ text-align: center;
63
+ margin: 0;
64
+ padding: 0;
65
+ position: relative;
66
+ top: 7px;
67
+ li {
68
+ float: left;
69
+ width: 13px;
70
+ height: 50px;
71
+ text-align: center;
72
+ list-style: none;
73
+ .dataBoc {
74
+ position: relative;
75
+ width: 100%;
76
+ height: 100%;
77
+ overflow: hidden;
78
+ .tt {
79
+ position: absolute;
80
+ top: 0;
81
+ left: 0;
82
+ width: 100%;
83
+ height: 100%;
84
+ em {
85
+ width: 100%;
86
+ height: 100%;
87
+ float: left;
88
+ line-height: 50px;
89
+ font-style: normal;
90
+ text-align: center;
91
+ font-size: 22px;
92
+ color: #66e8e5;
93
+ }
94
+ }
95
+ }
96
+ }
97
+ }
98
+ }
99
+ </style>
@@ -0,0 +1,138 @@
1
+ <template>
2
+ <div :class="className" :style="{ height: height, width: width }" />
3
+ </template>
4
+
5
+ <script>
6
+ import echarts from 'echarts';
7
+ require('echarts/theme/macarons'); // echarts theme
8
+ import resize from './mixins/resize';
9
+
10
+ export default {
11
+ mixins: [resize],
12
+ props: {
13
+ className: {
14
+ type: String,
15
+ default: 'chart',
16
+ },
17
+ width: {
18
+ type: String,
19
+ default: '100%',
20
+ },
21
+ height: {
22
+ type: String,
23
+ default: '350px',
24
+ },
25
+ autoResize: {
26
+ type: Boolean,
27
+ default: true,
28
+ },
29
+ chartData: {
30
+ type: Object,
31
+ required: true,
32
+ },
33
+ },
34
+ data() {
35
+ return {
36
+ chart: null,
37
+ };
38
+ },
39
+ watch: {
40
+ chartData: {
41
+ deep: true,
42
+ handler(val) {
43
+ this.setOptions(val);
44
+ },
45
+ },
46
+ },
47
+ mounted() {
48
+ this.$nextTick(() => {
49
+ this.initChart();
50
+ });
51
+ },
52
+ beforeDestroy() {
53
+ if (!this.chart) {
54
+ return;
55
+ }
56
+ this.chart.dispose();
57
+ this.chart = null;
58
+ },
59
+ methods: {
60
+ initChart() {
61
+ this.chart = echarts.init(this.$el, 'macarons');
62
+ this.setOptions(this.chartData);
63
+ },
64
+ setOptions({ expectedData, actualData } = {}) {
65
+ this.chart.setOption({
66
+ xAxis: {
67
+ data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
68
+ boundaryGap: false,
69
+ axisTick: {
70
+ show: false,
71
+ },
72
+ },
73
+ grid: {
74
+ left: 10,
75
+ right: 10,
76
+ bottom: 20,
77
+ top: 30,
78
+ containLabel: true,
79
+ },
80
+ tooltip: {
81
+ trigger: 'axis',
82
+ axisPointer: {
83
+ type: 'cross',
84
+ },
85
+ padding: [5, 10],
86
+ },
87
+ yAxis: {
88
+ axisTick: {
89
+ show: false,
90
+ },
91
+ },
92
+ legend: {
93
+ data: ['expected', 'actual'],
94
+ },
95
+ series: [
96
+ {
97
+ name: 'expected',
98
+ itemStyle: {
99
+ normal: {
100
+ color: '#FF005A',
101
+ lineStyle: {
102
+ color: '#FF005A',
103
+ width: 2,
104
+ },
105
+ },
106
+ },
107
+ smooth: true,
108
+ type: 'line',
109
+ data: expectedData,
110
+ animationDuration: 2800,
111
+ animationEasing: 'cubicInOut',
112
+ },
113
+ {
114
+ name: 'actual',
115
+ smooth: true,
116
+ type: 'line',
117
+ itemStyle: {
118
+ normal: {
119
+ color: '#3888fa',
120
+ lineStyle: {
121
+ color: '#3888fa',
122
+ width: 2,
123
+ },
124
+ areaStyle: {
125
+ color: '#f3f8ff',
126
+ },
127
+ },
128
+ },
129
+ data: actualData,
130
+ animationDuration: 2800,
131
+ animationEasing: 'quadraticOut',
132
+ },
133
+ ],
134
+ });
135
+ },
136
+ },
137
+ };
138
+ </script>
@@ -0,0 +1,173 @@
1
+ <template>
2
+ <el-row :gutter="40" class="panel-group">
3
+ <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
4
+ <div class="card-panel" @click="handleSetLineChartData('newVisitis')">
5
+ <div class="card-panel-icon-wrapper icon-people">
6
+ <svg-icon icon-class="peoples" class-name="card-panel-icon" />
7
+ </div>
8
+ <div class="card-panel-description">
9
+ <div class="card-panel-text">New Visits</div>
10
+ <count-to :start-val="0" :end-val="102400" :duration="2600" class="card-panel-num" />
11
+ </div>
12
+ </div>
13
+ </el-col>
14
+ <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
15
+ <div class="card-panel" @click="handleSetLineChartData('messages')">
16
+ <div class="card-panel-icon-wrapper icon-message">
17
+ <svg-icon icon-class="message" class-name="card-panel-icon" />
18
+ </div>
19
+ <div class="card-panel-description">
20
+ <div class="card-panel-text">Messages</div>
21
+ <count-to :start-val="0" :end-val="81212" :duration="3000" class="card-panel-num" />
22
+ </div>
23
+ </div>
24
+ </el-col>
25
+ <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
26
+ <div class="card-panel" @click="handleSetLineChartData('purchases')">
27
+ <div class="card-panel-icon-wrapper icon-money">
28
+ <svg-icon icon-class="money" class-name="card-panel-icon" />
29
+ </div>
30
+ <div class="card-panel-description">
31
+ <div class="card-panel-text">Purchases</div>
32
+ <count-to :start-val="0" :end-val="9280" :duration="3200" class="card-panel-num" />
33
+ </div>
34
+ </div>
35
+ </el-col>
36
+ <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
37
+ <div class="card-panel" @click="handleSetLineChartData('shoppings')">
38
+ <div class="card-panel-icon-wrapper icon-shopping">
39
+ <svg-icon icon-class="shopping" class-name="card-panel-icon" />
40
+ </div>
41
+ <div class="card-panel-description">
42
+ <div class="card-panel-text">Shoppings</div>
43
+ <count-to :start-val="0" :end-val="13600" :duration="3600" class="card-panel-num" />
44
+ </div>
45
+ </div>
46
+ </el-col>
47
+ </el-row>
48
+ </template>
49
+
50
+ <script>
51
+ import CountTo from 'vue-count-to';
52
+
53
+ export default {
54
+ components: {
55
+ CountTo,
56
+ },
57
+ methods: {
58
+ handleSetLineChartData(type) {
59
+ this.$emit('handleSetLineChartData', type);
60
+ },
61
+ },
62
+ };
63
+ </script>
64
+
65
+ <style lang="scss" scoped>
66
+ .panel-group {
67
+ margin-top: 18px;
68
+
69
+ .card-panel-col {
70
+ margin-bottom: 32px;
71
+ }
72
+
73
+ .card-panel {
74
+ height: 108px;
75
+ cursor: pointer;
76
+ font-size: 12px;
77
+ position: relative;
78
+ overflow: hidden;
79
+ color: #666;
80
+ background: #fff;
81
+ box-shadow: 4px 4px 40px rgba(0, 0, 0, 0.05);
82
+ border-color: rgba(0, 0, 0, 0.05);
83
+
84
+ &:hover {
85
+ .card-panel-icon-wrapper {
86
+ color: #fff;
87
+ }
88
+
89
+ .icon-people {
90
+ background: #40c9c6;
91
+ }
92
+
93
+ .icon-message {
94
+ background: #36a3f7;
95
+ }
96
+
97
+ .icon-money {
98
+ background: #f4516c;
99
+ }
100
+
101
+ .icon-shopping {
102
+ background: #34bfa3;
103
+ }
104
+ }
105
+
106
+ .icon-people {
107
+ color: #40c9c6;
108
+ }
109
+
110
+ .icon-message {
111
+ color: #36a3f7;
112
+ }
113
+
114
+ .icon-money {
115
+ color: #f4516c;
116
+ }
117
+
118
+ .icon-shopping {
119
+ color: #34bfa3;
120
+ }
121
+
122
+ .card-panel-icon-wrapper {
123
+ float: left;
124
+ margin: 14px 0 0 14px;
125
+ padding: 16px;
126
+ transition: all 0.38s ease-out;
127
+ border-radius: 6px;
128
+ }
129
+
130
+ .card-panel-icon {
131
+ float: left;
132
+ font-size: 48px;
133
+ }
134
+
135
+ .card-panel-description {
136
+ float: right;
137
+ font-weight: bold;
138
+ margin: 26px;
139
+ margin-left: 0px;
140
+
141
+ .card-panel-text {
142
+ line-height: 18px;
143
+ color: rgba(0, 0, 0, 0.45);
144
+ font-size: 16px;
145
+ margin-bottom: 12px;
146
+ }
147
+
148
+ .card-panel-num {
149
+ font-size: 20px;
150
+ }
151
+ }
152
+ }
153
+ }
154
+
155
+ @media (max-width: 550px) {
156
+ .card-panel-description {
157
+ display: none;
158
+ }
159
+
160
+ .card-panel-icon-wrapper {
161
+ float: none !important;
162
+ width: 100%;
163
+ height: 100%;
164
+ margin: 0 !important;
165
+
166
+ .svg-icon {
167
+ display: block;
168
+ margin: 14px auto !important;
169
+ float: none !important;
170
+ }
171
+ }
172
+ }
173
+ </style>