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.
- package/README.md +184 -0
- package/bin/ylyx.js +95 -0
- package/lib/generator.js +192 -0
- package/lib/index.js +113 -0
- package/lib/interactive.js +87 -0
- package/lib/remote.js +179 -0
- package/lib/template.js +174 -0
- package/lib/utils.js +134 -0
- package/package.json +56 -0
- package/templates/react-app/files/README.md +23 -0
- package/templates/react-app/files/package.json +29 -0
- package/templates/react-app/files/public/index.html +11 -0
- package/templates/react-app/files/src/App.css +15 -0
- package/templates/react-app/files/src/App.js +15 -0
- package/templates/react-app/files/src/index.css +10 -0
- package/templates/react-app/files/src/index.js +11 -0
- package/templates/react-app/template.json +12 -0
- package/templates/react-component/files/Component.module.css +5 -0
- package/templates/react-component/files/Component.tsx +31 -0
- package/templates/react-component/files/index.ts +2 -0
- package/templates/react-component/template.json +49 -0
- package/templates/vue-app/files/.editorconfig +14 -0
- package/templates/vue-app/files/.env.development +21 -0
- package/templates/vue-app/files/.env.production +18 -0
- package/templates/vue-app/files/.eslintignore +5 -0
- package/templates/vue-app/files/.eslintrc.js +267 -0
- package/templates/vue-app/files/.prettierignore +12 -0
- package/templates/vue-app/files/.travis.yml +5 -0
- package/templates/vue-app/files/.vscode/extensions.json +7 -0
- package/templates/vue-app/files/.vscode/settings.json +39 -0
- package/templates/vue-app/files/LICENSE +191 -0
- package/templates/vue-app/files/README.md +87 -0
- package/templates/vue-app/files/babel.config.js +11 -0
- package/templates/vue-app/files/jest.config.js +24 -0
- package/templates/vue-app/files/package.json +136 -0
- package/templates/vue-app/files/plopfile.js +7 -0
- package/templates/vue-app/files/postcss.config.js +5 -0
- package/templates/vue-app/files/prettier.config.js +36 -0
- package/templates/vue-app/files/public/default.js +26 -0
- package/templates/vue-app/files/public/favicon.ico +0 -0
- package/templates/vue-app/files/public/index.html +26 -0
- package/templates/vue-app/files/src/App.vue +54 -0
- package/templates/vue-app/files/src/api/bigDataV/index.js +198 -0
- package/templates/vue-app/files/src/api/data.js +42 -0
- package/templates/vue-app/files/src/api/dataArchive/index.js +186 -0
- package/templates/vue-app/files/src/api/generator/genConfig.js +16 -0
- package/templates/vue-app/files/src/api/generator/generator.js +32 -0
- package/templates/vue-app/files/src/api/indexManagement/index.js +39 -0
- package/templates/vue-app/files/src/api/institutionMonitor/index.js +396 -0
- package/templates/vue-app/files/src/api/institutionSet/index.js +120 -0
- package/templates/vue-app/files/src/api/login.js +44 -0
- package/templates/vue-app/files/src/api/selfStatistics/index.js +50 -0
- package/templates/vue-app/files/src/api/system/code.js +15 -0
- package/templates/vue-app/files/src/api/system/dict.js +34 -0
- package/templates/vue-app/files/src/api/system/dictDetail.js +52 -0
- package/templates/vue-app/files/src/api/system/equipment.js +35 -0
- package/templates/vue-app/files/src/api/system/examManage.js +49 -0
- package/templates/vue-app/files/src/api/system/examProject.js +48 -0
- package/templates/vue-app/files/src/api/system/hosModel.js +35 -0
- package/templates/vue-app/files/src/api/system/hospital.js +88 -0
- package/templates/vue-app/files/src/api/system/job.js +40 -0
- package/templates/vue-app/files/src/api/system/menu.js +67 -0
- package/templates/vue-app/files/src/api/system/model.js +42 -0
- package/templates/vue-app/files/src/api/system/risConfig.js +9 -0
- package/templates/vue-app/files/src/api/system/role.js +64 -0
- package/templates/vue-app/files/src/api/system/sysSet.js +19 -0
- package/templates/vue-app/files/src/api/system/timing.js +41 -0
- package/templates/vue-app/files/src/api/system/user.js +121 -0
- package/templates/vue-app/files/src/api/tools/alipay.js +25 -0
- package/templates/vue-app/files/src/api/tools/email.js +24 -0
- package/templates/vue-app/files/src/api/tools/localStorage.js +27 -0
- package/templates/vue-app/files/src/api/tools/qiniu.js +40 -0
- package/templates/vue-app/files/src/assets/401_images/401.gif +0 -0
- package/templates/vue-app/files/src/assets/404_images/404.png +0 -0
- package/templates/vue-app/files/src/assets/404_images/404_cloud.png +0 -0
- package/templates/vue-app/files/src/assets/css/font-awesome.css +2342 -0
- package/templates/vue-app/files/src/assets/css/font-awesome.min.css +2336 -0
- package/templates/vue-app/files/src/assets/fonts/FontAwesome.otf +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.eot +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.svg +2671 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.ttf +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.woff +0 -0
- package/templates/vue-app/files/src/assets/fonts/fontawesome-webfont.woff2 +0 -0
- package/templates/vue-app/files/src/assets/icons/index.js +9 -0
- package/templates/vue-app/files/src/assets/icons/svg/Steve-Jobs.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/achive.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/alipay.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/anq.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/app.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/archive.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/backup.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/chain.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/chart.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/codeConsole.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dashboard.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/database.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/date.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/deploy.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dept.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dev.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/develop.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/dictionary.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/doc.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/download.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/edit.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/education.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/email.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/equSet.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/error.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/exit-fullscreen.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/fullscreen.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/fwb.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/github.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/goBack.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/gonggao.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/hospital.svg +2 -0
- package/templates/vue-app/files/src/assets/icons/svg/hospital1.svg +2 -0
- package/templates/vue-app/files/src/assets/icons/svg/hospitalTotal.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/icon.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/image.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/index.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/international.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/ipvisits.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/java.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/link.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/list.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/lock.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/log.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/login.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginOne.svg +35 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginOneWhite.svg +19 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginOr.svg +93 -0
- package/templates/vue-app/files/src/assets/icons/svg/loginUp.svg +96 -0
- package/templates/vue-app/files/src/assets/icons/svg/markdown.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/menu.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/message.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/mnt.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/money.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/monitor.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/nested.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/network.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/offline.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/online.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/password.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/people.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/peoples.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/perSet.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/permission.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/phone.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/piechart.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/qiniu.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/redis.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/resetpassword.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/resetpassword1.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/role.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/search.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/server.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/shopping.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/size.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/skill.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/source.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/sqlMonitor.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/statistical.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/swagger.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/sys-tools.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/system.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/system1.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tab.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/teams.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/theme.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/timing.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tools.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tree-table.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/tree.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/unlock.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/user.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/user1.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/validCode.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/visits.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/web.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/wechat.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/weixin.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svg/zujian.svg +1 -0
- package/templates/vue-app/files/src/assets/icons/svgo.yml +21 -0
- package/templates/vue-app/files/src/assets/images/archive.png +0 -0
- package/templates/vue-app/files/src/assets/images/archive_icon.png +0 -0
- package/templates/vue-app/files/src/assets/images/avatar.png +0 -0
- package/templates/vue-app/files/src/assets/images/background.jpg +0 -0
- package/templates/vue-app/files/src/assets/images/bg.png +0 -0
- package/templates/vue-app/files/src/assets/images/gongan.png +0 -0
- package/templates/vue-app/files/src/assets/images/hospital_icon.png +0 -0
- package/templates/vue-app/files/src/assets/images/location.png +0 -0
- package/templates/vue-app/files/src/assets/images/logintitle.jpg +0 -0
- package/templates/vue-app/files/src/assets/images/logo-copy1.png +0 -0
- package/templates/vue-app/files/src/assets/images/logo.png +0 -0
- package/templates/vue-app/files/src/assets/images/logoBg.png +0 -0
- package/templates/vue-app/files/src/assets/images/offline-bg.png +0 -0
- package/templates/vue-app/files/src/assets/images/position.png +0 -0
- package/templates/vue-app/files/src/assets/images/qualityBg.jpg +0 -0
- package/templates/vue-app/files/src/assets/images/self-bg.png +0 -0
- package/templates/vue-app/files/src/assets/images/self-bg2.png +0 -0
- package/templates/vue-app/files/src/assets/images/triAngel.png +0 -0
- package/templates/vue-app/files/src/assets/images/triAngelNormal.png +0 -0
- package/templates/vue-app/files/src/assets/styles/btn.scss +103 -0
- package/templates/vue-app/files/src/assets/styles/eladmin.scss +124 -0
- package/templates/vue-app/files/src/assets/styles/element-ui.scss +217 -0
- package/templates/vue-app/files/src/assets/styles/element-variables.scss +31 -0
- package/templates/vue-app/files/src/assets/styles/global.scss +73 -0
- package/templates/vue-app/files/src/assets/styles/index.scss +220 -0
- package/templates/vue-app/files/src/assets/styles/mixin.scss +60 -0
- package/templates/vue-app/files/src/assets/styles/publicStyle.scss +224 -0
- package/templates/vue-app/files/src/assets/styles/sidebar.scss +239 -0
- package/templates/vue-app/files/src/assets/styles/transition.scss +48 -0
- package/templates/vue-app/files/src/assets/styles/variables.scss +44 -0
- package/templates/vue-app/files/src/common/flexible.js +145 -0
- package/templates/vue-app/files/src/components/Breadcrumb/index.vue +87 -0
- package/templates/vue-app/files/src/components/Crud/CRUD.operation.vue +248 -0
- package/templates/vue-app/files/src/components/Crud/Pagination.vue +20 -0
- package/templates/vue-app/files/src/components/Crud/RR.operation.vue +39 -0
- package/templates/vue-app/files/src/components/Crud/UD.operation.vue +106 -0
- package/templates/vue-app/files/src/components/Crud/crud.js +907 -0
- package/templates/vue-app/files/src/components/Crud/user/UR.operation.vue +154 -0
- package/templates/vue-app/files/src/components/DateRangePicker/index.vue +42 -0
- package/templates/vue-app/files/src/components/DateRangePickerProhibitNext/index.vue +42 -0
- package/templates/vue-app/files/src/components/DateRangePickerProhibitTodayNext/index.vue +48 -0
- package/templates/vue-app/files/src/components/Dict/Dict.js +31 -0
- package/templates/vue-app/files/src/components/Dict/index.js +29 -0
- package/templates/vue-app/files/src/components/Doc/index.vue +16 -0
- package/templates/vue-app/files/src/components/Echarts/BarChart.vue +115 -0
- package/templates/vue-app/files/src/components/Echarts/Category.vue +768 -0
- package/templates/vue-app/files/src/components/Echarts/Funnel.vue +120 -0
- package/templates/vue-app/files/src/components/Echarts/Gauge.vue +74 -0
- package/templates/vue-app/files/src/components/Echarts/Graph.vue +101 -0
- package/templates/vue-app/files/src/components/Echarts/HeatMap.vue +301 -0
- package/templates/vue-app/files/src/components/Echarts/Line3D.vue +110 -0
- package/templates/vue-app/files/src/components/Echarts/PieChart.vue +84 -0
- package/templates/vue-app/files/src/components/Echarts/Point.vue +161 -0
- package/templates/vue-app/files/src/components/Echarts/RadarChart.vue +123 -0
- package/templates/vue-app/files/src/components/Echarts/Rich.vue +160 -0
- package/templates/vue-app/files/src/components/Echarts/Sankey.vue +114 -0
- package/templates/vue-app/files/src/components/Echarts/Scatter.vue +192 -0
- package/templates/vue-app/files/src/components/Echarts/Sunburst.vue +127 -0
- package/templates/vue-app/files/src/components/Echarts/ThemeRiver.vue +233 -0
- package/templates/vue-app/files/src/components/Echarts/WordCloud.vue +201 -0
- package/templates/vue-app/files/src/components/GithubCorner/index.vue +55 -0
- package/templates/vue-app/files/src/components/Hamburger/index.vue +44 -0
- package/templates/vue-app/files/src/components/HeaderSearch/index.vue +196 -0
- package/templates/vue-app/files/src/components/IconSelect/index.vue +74 -0
- package/templates/vue-app/files/src/components/IconSelect/requireIcons.js +10 -0
- package/templates/vue-app/files/src/components/Iframe/index.vue +30 -0
- package/templates/vue-app/files/src/components/JavaEdit/index.vue +78 -0
- package/templates/vue-app/files/src/components/Pagination/index.vue +100 -0
- package/templates/vue-app/files/src/components/PanThumb/index.vue +149 -0
- package/templates/vue-app/files/src/components/ParentView/index.vue +3 -0
- package/templates/vue-app/files/src/components/Permission/index.js +13 -0
- package/templates/vue-app/files/src/components/Permission/permission.js +21 -0
- package/templates/vue-app/files/src/components/RightPanel/index.vue +149 -0
- package/templates/vue-app/files/src/components/Screenfull/index.vue +60 -0
- package/templates/vue-app/files/src/components/SizeSelect/index.vue +60 -0
- package/templates/vue-app/files/src/components/SvgIcon/index.vue +66 -0
- package/templates/vue-app/files/src/components/ThemePicker/index.vue +177 -0
- package/templates/vue-app/files/src/components/UploadExcel/index.vue +149 -0
- package/templates/vue-app/files/src/components/WaterMark/setWaterMark.js +68 -0
- package/templates/vue-app/files/src/components/WaterMark/waterMark.vue +69 -0
- package/templates/vue-app/files/src/components/Xgplayer/index.vue +49 -0
- package/templates/vue-app/files/src/components/YamlEdit/index.vue +81 -0
- package/templates/vue-app/files/src/layout/components/AppMain.vue +67 -0
- package/templates/vue-app/files/src/layout/components/Navbar.vue +209 -0
- package/templates/vue-app/files/src/layout/components/Settings/index.vue +125 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/FixiOSBug.js +26 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/Item.vue +29 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/Link.vue +35 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/Logo.vue +93 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/SidebarItem.vue +104 -0
- package/templates/vue-app/files/src/layout/components/Sidebar/index.vue +79 -0
- package/templates/vue-app/files/src/layout/components/TagsView/ScrollPane.vue +90 -0
- package/templates/vue-app/files/src/layout/components/TagsView/index.vue +299 -0
- package/templates/vue-app/files/src/layout/components/index.js +5 -0
- package/templates/vue-app/files/src/layout/index.vue +119 -0
- package/templates/vue-app/files/src/layout/mixin/ResizeHandler.js +45 -0
- package/templates/vue-app/files/src/main.js +89 -0
- package/templates/vue-app/files/src/mixins/crud.js +348 -0
- package/templates/vue-app/files/src/router/index.js +156 -0
- package/templates/vue-app/files/src/router/routers.js +203 -0
- package/templates/vue-app/files/src/settings.js +57 -0
- package/templates/vue-app/files/src/store/getters.js +29 -0
- package/templates/vue-app/files/src/store/index.js +25 -0
- package/templates/vue-app/files/src/store/modules/api.js +33 -0
- package/templates/vue-app/files/src/store/modules/app.js +55 -0
- package/templates/vue-app/files/src/store/modules/permission.js +79 -0
- package/templates/vue-app/files/src/store/modules/register.js +17 -0
- package/templates/vue-app/files/src/store/modules/settings.js +46 -0
- package/templates/vue-app/files/src/store/modules/tagsView.js +168 -0
- package/templates/vue-app/files/src/store/modules/user.js +119 -0
- package/templates/vue-app/files/src/utils/auth.js +18 -0
- package/templates/vue-app/files/src/utils/base64ToFile.js +27 -0
- package/templates/vue-app/files/src/utils/clipboard.js +36 -0
- package/templates/vue-app/files/src/utils/datetime.js +289 -0
- package/templates/vue-app/files/src/utils/getBlobFile.js +10 -0
- package/templates/vue-app/files/src/utils/getTime.js +29 -0
- package/templates/vue-app/files/src/utils/index.js +520 -0
- package/templates/vue-app/files/src/utils/permission.js +29 -0
- package/templates/vue-app/files/src/utils/pinyin.js +450 -0
- package/templates/vue-app/files/src/utils/request.js +139 -0
- package/templates/vue-app/files/src/utils/rsaEncrypt.js +37 -0
- package/templates/vue-app/files/src/utils/shortcuts.js +210 -0
- package/templates/vue-app/files/src/utils/upload.js +12 -0
- package/templates/vue-app/files/src/utils/validate.js +262 -0
- package/templates/vue-app/files/src/views/components/Echarts.vue +124 -0
- package/templates/vue-app/files/src/views/components/Editor.vue +75 -0
- package/templates/vue-app/files/src/views/components/MarkDown.vue +44 -0
- package/templates/vue-app/files/src/views/components/UVideo.vue +37 -0
- package/templates/vue-app/files/src/views/components/YamlEdit.vue +206 -0
- package/templates/vue-app/files/src/views/components/camera/camera.vue +115 -0
- package/templates/vue-app/files/src/views/components/camera/cameraTest.vue +158 -0
- package/templates/vue-app/files/src/views/components/excel/upload-excel.vue +41 -0
- package/templates/vue-app/files/src/views/components/icons/element-icons.js +74 -0
- package/templates/vue-app/files/src/views/components/icons/index.vue +106 -0
- package/templates/vue-app/files/src/views/components/icons/svg-icons.js +10 -0
- package/templates/vue-app/files/src/views/components/scroll/index.vue +107 -0
- package/templates/vue-app/files/src/views/components/scrollFull/index.vue +99 -0
- package/templates/vue-app/files/src/views/dashboard/LineChart.vue +138 -0
- package/templates/vue-app/files/src/views/dashboard/PanelGroup.vue +173 -0
- package/templates/vue-app/files/src/views/dashboard/mixins/resize.js +57 -0
- package/templates/vue-app/files/src/views/dataArchive/delTable.vue +354 -0
- package/templates/vue-app/files/src/views/dataArchive/exportDetail.vue +121 -0
- package/templates/vue-app/files/src/views/dataArchive/exportList.vue +160 -0
- package/templates/vue-app/files/src/views/dataArchive/index.vue +2104 -0
- package/templates/vue-app/files/src/views/features/401.vue +83 -0
- package/templates/vue-app/files/src/views/features/404.vue +226 -0
- package/templates/vue-app/files/src/views/features/redirect.vue +12 -0
- package/templates/vue-app/files/src/views/generator/config.vue +348 -0
- package/templates/vue-app/files/src/views/generator/index.vue +143 -0
- package/templates/vue-app/files/src/views/generator/preview.vue +39 -0
- package/templates/vue-app/files/src/views/home.vue +80 -0
- package/templates/vue-app/files/src/views/indexManagement/index.vue +422 -0
- package/templates/vue-app/files/src/views/indexManagement/other.vue +286 -0
- package/templates/vue-app/files/src/views/institutionMonitor/components/LineChart.vue +191 -0
- package/templates/vue-app/files/src/views/institutionMonitor/index.scss +339 -0
- package/templates/vue-app/files/src/views/institutionMonitor/index.vue +1385 -0
- package/templates/vue-app/files/src/views/institutionMonitor/mixins/resize.js +57 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/checkProjectCode.vue +267 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/imageAbnormalMonitor.vue +361 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/index.vue +686 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/leakageAnomaly.vue +270 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/moveMonitore.vue +114 -0
- package/templates/vue-app/files/src/views/institutionMonitor/monitorDetail/qualityMonitore.vue +338 -0
- package/templates/vue-app/files/src/views/institutionSet/cloudSet.vue +534 -0
- package/templates/vue-app/files/src/views/institutionSet/index.vue +2550 -0
- package/templates/vue-app/files/src/views/login.vue +243 -0
- package/templates/vue-app/files/src/views/qualityLogin.vue +280 -0
- package/templates/vue-app/files/src/views/selfStatistics/components/LineChart.vue +296 -0
- package/templates/vue-app/files/src/views/selfStatistics/hospitalDetail/index.vue +533 -0
- package/templates/vue-app/files/src/views/selfStatistics/index.scss +447 -0
- package/templates/vue-app/files/src/views/selfStatistics/index.vue +903 -0
- package/templates/vue-app/files/src/views/selfStatistics/mixins/resize.js +57 -0
- package/templates/vue-app/files/src/views/selfStatistics/monitorDetail/index.vue +285 -0
- package/templates/vue-app/files/src/views/selfStatistics/offlineDetail/index.vue +104 -0
- package/templates/vue-app/files/src/views/selfStatistics/selfActiveDetail/index.vue +104 -0
- package/templates/vue-app/files/src/views/selfStatistics/selfMonitorDetail/index.vue +420 -0
- package/templates/vue-app/files/src/views/selfStatistics/setWaterMark/setWaterMark.js +68 -0
- package/templates/vue-app/files/src/views/selfStatistics/setWaterMark/waterMark.vue +69 -0
- package/templates/vue-app/files/src/views/system/dept/index.vue +144 -0
- package/templates/vue-app/files/src/views/system/dict/dictDetail.vue +146 -0
- package/templates/vue-app/files/src/views/system/dict/index.vue +159 -0
- package/templates/vue-app/files/src/views/system/examModality/index.vue +174 -0
- package/templates/vue-app/files/src/views/system/examPart/index.vue +184 -0
- package/templates/vue-app/files/src/views/system/examProject/index.vue +321 -0
- package/templates/vue-app/files/src/views/system/examine/index.vue +66 -0
- package/templates/vue-app/files/src/views/system/job/index.vue +119 -0
- package/templates/vue-app/files/src/views/system/job/module/form.vue +72 -0
- package/templates/vue-app/files/src/views/system/job/module/header.vue +48 -0
- package/templates/vue-app/files/src/views/system/menu/index.vue +327 -0
- package/templates/vue-app/files/src/views/system/model/index.vue +285 -0
- package/templates/vue-app/files/src/views/system/role/index.vue +434 -0
- package/templates/vue-app/files/src/views/system/sysSet/index.vue +84 -0
- package/templates/vue-app/files/src/views/system/timing/index.vue +289 -0
- package/templates/vue-app/files/src/views/system/timing/log.vue +143 -0
- package/templates/vue-app/files/src/views/system/user/admin.vue +414 -0
- package/templates/vue-app/files/src/views/system/user/center/updateEmail.vue +146 -0
- package/templates/vue-app/files/src/views/system/user/center/updatePass.vue +168 -0
- package/templates/vue-app/files/src/views/system/user/center.vue +140 -0
- package/templates/vue-app/files/src/views/system/user/index.vue +972 -0
- package/templates/vue-app/files/src/views/systemSet/role/index.vue +314 -0
- package/templates/vue-app/files/src/views/systemSet/user/admin.vue +414 -0
- package/templates/vue-app/files/src/views/systemSet/user/center/updateEmail.vue +146 -0
- package/templates/vue-app/files/src/views/systemSet/user/center/updatePass.vue +115 -0
- package/templates/vue-app/files/src/views/systemSet/user/center.vue +351 -0
- package/templates/vue-app/files/src/views/systemSet/user/index.vue +928 -0
- package/templates/vue-app/files/src/views/tools/aliPay/config.vue +102 -0
- package/templates/vue-app/files/src/views/tools/aliPay/index.vue +48 -0
- package/templates/vue-app/files/src/views/tools/aliPay/toPay.vue +91 -0
- package/templates/vue-app/files/src/views/tools/email/config.vue +91 -0
- package/templates/vue-app/files/src/views/tools/email/index.vue +42 -0
- package/templates/vue-app/files/src/views/tools/email/send.vue +159 -0
- package/templates/vue-app/files/src/views/tools/storage/index.vue +35 -0
- package/templates/vue-app/files/src/views/tools/storage/local/index.vue +207 -0
- package/templates/vue-app/files/src/views/tools/storage/qiniu/form.vue +108 -0
- package/templates/vue-app/files/src/views/tools/storage/qiniu/index.vue +241 -0
- package/templates/vue-app/files/src/views/tools/swagger/index.vue +14 -0
- package/templates/vue-app/files/vue.config.js +173 -0
- 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>
|