Bladeren bron

首页修改

aleyds 1 jaar geleden
bovenliggende
commit
097a06207b

+ 1 - 0
report-ui/.gitignore

@@ -5,6 +5,7 @@ npm-debug.log*
 yarn-debug.log*
 yarn-error.log*
 package-lock.json
+.history/
 
 # Editor directories and files
 .idea

+ 26 - 0
report-ui/.history/index_20220902135315.html

@@ -0,0 +1,26 @@
+<!DOCTYPE html>
+<html>
+
+<head>
+  <meta charset="utf-8">
+  <meta name="viewport" content="width=device-width,initial-scale=1.0">
+  <title>退役军人大屏管理后台</title>
+  <link rel='stylesheet' href='./static/luckysheet/plugins/css/pluginsCss.css' />
+  <link rel='stylesheet' href='./static/luckysheet/plugins/plugins.css' />
+  <link rel='stylesheet' href='./static/luckysheet/css/luckysheet.css' />
+  <!-- <link rel='stylesheet' href='./static/luckysheet/assets/iconfont/iconfont.css' /> -->
+  <script src="./static/luckysheet/plugins/js/plugin.js"></script>
+  <script src="./static/luckysheet/luckysheet.umd.js"></script>
+  <script src="https://webapi.amap.com/maps?v=2.0&key=2f006bc5e3baf5e4c81680f0538d3917&plugin=AMap.PolygonEditor"></script>
+
+
+
+
+
+</head>
+
+<body>
+  <div id="app"></div>
+</body>
+
+</html>

+ 26 - 0
report-ui/.history/index_20220902141212.html

@@ -0,0 +1,26 @@
+<!DOCTYPE html>
+<html>
+
+<head>
+  <meta charset="utf-8">
+  <meta name="viewport" content="width=device-width,initial-scale=1.0">
+  <title>远程制药大屏管理后台</title>
+  <link rel='stylesheet' href='./static/luckysheet/plugins/css/pluginsCss.css' />
+  <link rel='stylesheet' href='./static/luckysheet/plugins/plugins.css' />
+  <link rel='stylesheet' href='./static/luckysheet/css/luckysheet.css' />
+  <!-- <link rel='stylesheet' href='./static/luckysheet/assets/iconfont/iconfont.css' /> -->
+  <script src="./static/luckysheet/plugins/js/plugin.js"></script>
+  <script src="./static/luckysheet/luckysheet.umd.js"></script>
+  <script src="https://webapi.amap.com/maps?v=2.0&key=2f006bc5e3baf5e4c81680f0538d3917&plugin=AMap.PolygonEditor"></script>
+
+
+
+
+
+</head>
+
+<body>
+  <div id="app"></div>
+</body>
+
+</html>

+ 110 - 0
report-ui/.history/package_20220902135315.json

@@ -0,0 +1,110 @@
+{
+  "name": "mirror-manager",
+  "version": "3.8.0",
+  "description": "mirror-manager",
+  "author": "mirror-team@anji-plus.com",
+  "scripts": {
+    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
+    "start": "npm run dev",
+    "build": "cross-env NODE_ENV=production node build/build.js",
+    "build:dev": "cross-env NODE_ENV=development node build/build.js",
+    "build:test": "cross-env NODE_ENV=testing node build/build.js",
+    "build:prod": "cross-env NODE_ENV=production node build/build.js"
+  },
+  "dependencies": {
+    "@ckeditor/ckeditor5-build-decoupled-document": "^23.1.0",
+    "@smallwei/avue": "^2.8.23",
+    "amap-echarts": "^2.0.0",
+    "axios": "0.18.0",
+    "chokidar": "^3.5.2",
+    "codemirror": "^5.58.1",
+    "crypto-js": "^3.1.9-1",
+    "echarts": "^4.9.0",
+    "echarts-extension-amap": "^1.10.1",
+    "echarts-gl": "^1.1.1",
+    "echarts-wordcloud": "^1.1.3",
+    "element-ui": "^2.9.2",
+    "js-cookie": "2.2.0",
+    "jsbarcode": "^3.11.4",
+    "miment": "^0.0.9",
+    "moment": "^2.29.1",
+    "monaco-editor": "^0.20.0",
+    "normalize.css": "7.0.0",
+    "nprogress": "0.2.0",
+    "qrcodejs2": "0.0.2",
+    "sortablejs": "^1.10.2",
+    "uninstall": "0.0.0",
+    "v-chart": "^1.0.0",
+    "vue": "2.6.11",
+    "vue-codemirror": "^4.0.6",
+    "vue-color": "^2.8.1",
+    "vue-drag-resize": "^1.5.4",
+    "vue-echarts": "^5.0.0-beta.0",
+    "vue-json-editor": "^1.4.3",
+    "vue-router": "3.0.1",
+    "vue-ruler-tool": "^1.2.4",
+    "vue-seamless-scroll": "^1.1.23",
+    "vue-superslide": "^0.1.1",
+    "vue-video-player": "^5.0.2",
+    "vue-wordcloud": "^1.1.1",
+    "vuedraggable": "^2.24.1",
+    "vuex": "3.0.1"
+  },
+  "devDependencies": {
+    "autoprefixer": "8.5.0",
+    "babel-core": "6.26.0",
+    "babel-helper-vue-jsx-merge-props": "2.0.3",
+    "babel-loader": "7.1.5",
+    "babel-plugin-syntax-jsx": "6.18.0",
+    "babel-plugin-transform-runtime": "6.23.0",
+    "babel-plugin-transform-vue-jsx": "3.7.0",
+    "babel-preset-env": "1.7.0",
+    "babel-preset-stage-2": "6.24.1",
+    "chalk": "2.4.1",
+    "copy-webpack-plugin": "4.5.2",
+    "cross-env": "^5.2.0",
+    "css-loader": "1.0.0",
+    "eventsource-polyfill": "0.9.6",
+    "file-loader": "1.1.11",
+    "friendly-errors-webpack-plugin": "1.7.0",
+    "html-webpack-plugin": "4.0.0-alpha",
+    "js-md5": "^0.7.3",
+    "mini-css-extract-plugin": "0.4.1",
+    "monaco-editor-webpack-plugin": "^4.1.1",
+    "node-notifier": "5.2.1",
+    "node-sass": "^4.7.2",
+    "optimize-css-assets-webpack-plugin": "5.0.0",
+    "ora": "3.0.0",
+    "path-to-regexp": "2.4.0",
+    "portfinder": "1.0.16",
+    "postcss-import": "12.0.0",
+    "postcss-loader": "2.1.6",
+    "postcss-url": "7.3.2",
+    "rimraf": "2.6.2",
+    "sass-loader": "7.0.3",
+    "script-ext-html-webpack-plugin": "2.0.1",
+    "semver": "5.5.0",
+    "shelljs": "0.8.2",
+    "svg-sprite-loader": "3.8.0",
+    "svgo": "1.0.5",
+    "uglifyjs-webpack-plugin": "1.2.7",
+    "url-loader": "1.0.1",
+    "vue-loader": "15.3.0",
+    "vue-style-loader": "4.1.2",
+    "vue-template-compiler": "2.6.11",
+    "webpack": "4.16.5",
+    "webpack-bundle-analyzer": "2.13.1",
+    "webpack-cli": "3.1.0",
+    "webpack-dev-server": "3.1.5",
+    "webpack-merge": "4.1.4"
+  },
+  "engines": {
+    "node": ">= 6.0.0",
+    "npm": ">= 3.0.0"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions",
+    "not ie <= 8"
+  ]
+}

+ 110 - 0
report-ui/.history/package_20220902140229.json

@@ -0,0 +1,110 @@
+{
+  "name": "mirror-manager",
+  "version": "3.8.0",
+  "description": "mirror-manager",
+  "author": "mirror-team@anji-plus.com",
+  "scripts": {
+    "dev": "webpack-dev-server --inline --progress --config build/webpack.conf.js",
+    "start": "npm run dev",
+    "build": "cross-env NODE_ENV=production node build/build.js",
+    "build:dev": "cross-env NODE_ENV=development node build/build.js",
+    "build:test": "cross-env NODE_ENV=testing node build/build.js",
+    "build:prod": "cross-env NODE_ENV=production node build/build.js"
+  },
+  "dependencies": {
+    "@ckeditor/ckeditor5-build-decoupled-document": "^23.1.0",
+    "@smallwei/avue": "^2.8.23",
+    "amap-echarts": "^2.0.0",
+    "axios": "0.18.0",
+    "chokidar": "^3.5.2",
+    "codemirror": "^5.58.1",
+    "crypto-js": "^3.1.9-1",
+    "echarts": "^4.9.0",
+    "echarts-extension-amap": "^1.10.1",
+    "echarts-gl": "^1.1.1",
+    "echarts-wordcloud": "^1.1.3",
+    "element-ui": "^2.9.2",
+    "js-cookie": "2.2.0",
+    "jsbarcode": "^3.11.4",
+    "miment": "^0.0.9",
+    "moment": "^2.29.1",
+    "monaco-editor": "^0.20.0",
+    "normalize.css": "7.0.0",
+    "nprogress": "0.2.0",
+    "qrcodejs2": "0.0.2",
+    "sortablejs": "^1.10.2",
+    "uninstall": "0.0.0",
+    "v-chart": "^1.0.0",
+    "vue": "2.6.11",
+    "vue-codemirror": "^4.0.6",
+    "vue-color": "^2.8.1",
+    "vue-drag-resize": "^1.5.4",
+    "vue-echarts": "^5.0.0-beta.0",
+    "vue-json-editor": "^1.4.3",
+    "vue-router": "3.0.1",
+    "vue-ruler-tool": "^1.2.4",
+    "vue-seamless-scroll": "^1.1.23",
+    "vue-superslide": "^0.1.1",
+    "vue-video-player": "^5.0.2",
+    "vue-wordcloud": "^1.1.1",
+    "vuedraggable": "^2.24.1",
+    "vuex": "3.0.1"
+  },
+  "devDependencies": {
+    "autoprefixer": "8.5.0",
+    "babel-core": "6.26.0",
+    "babel-helper-vue-jsx-merge-props": "2.0.3",
+    "babel-loader": "7.1.5",
+    "babel-plugin-syntax-jsx": "6.18.0",
+    "babel-plugin-transform-runtime": "6.23.0",
+    "babel-plugin-transform-vue-jsx": "3.7.0",
+    "babel-preset-env": "1.7.0",
+    "babel-preset-stage-2": "6.24.1",
+    "chalk": "2.4.1",
+    "copy-webpack-plugin": "4.5.2",
+    "cross-env": "^5.2.0",
+    "css-loader": "1.0.0",
+    "eventsource-polyfill": "0.9.6",
+    "file-loader": "1.1.11",
+    "friendly-errors-webpack-plugin": "1.7.0",
+    "html-webpack-plugin": "4.0.0-alpha",
+    "js-md5": "^0.7.3",
+    "mini-css-extract-plugin": "0.4.1",
+    "monaco-editor-webpack-plugin": "^4.1.1",
+    "node-notifier": "5.2.1",
+    "node-sass": "^4.7.2",
+    "optimize-css-assets-webpack-plugin": "5.0.0",
+    "ora": "3.0.0",
+    "path-to-regexp": "2.4.0",
+    "portfinder": "1.0.16",
+    "postcss-import": "12.0.0",
+    "postcss-loader": "2.1.6",
+    "postcss-url": "7.3.2",
+    "rimraf": "2.6.2",
+    "sass-loader": "7.0.3",
+    "script-ext-html-webpack-plugin": "2.0.1",
+    "semver": "5.5.0",
+    "shelljs": "0.8.2",
+    "svg-sprite-loader": "3.8.0",
+    "svgo": "1.0.5",
+    "uglifyjs-webpack-plugin": "1.2.7",
+    "url-loader": "1.0.1",
+    "vue-loader": "15.3.0",
+    "vue-style-loader": "4.1.2",
+    "vue-template-compiler": "2.6.11",
+    "webpack": "4.16.5",
+    "webpack-bundle-analyzer": "2.13.1",
+    "webpack-cli": "3.1.0",
+    "webpack-dev-server": "3.1.5",
+    "webpack-merge": "4.1.4"
+  },
+  "engines": {
+    "node": ">= 6.0.0",
+    "npm": ">= 3.0.0"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions",
+    "not ie <= 8"
+  ]
+}

+ 110 - 0
report-ui/.history/package_20220902140238.json

@@ -0,0 +1,110 @@
+{
+  "name": "mirror-manager",
+  "version": "3.8.0",
+  "description": "mirror-manager",
+  "author": "mirror-team@anji-plus.com",
+  "scripts": {
+    "dev": "webpack-dev-server --inline --progress --config build/webpack.config.js",
+    "start": "npm run dev",
+    "build": "cross-env NODE_ENV=production node build/build.js",
+    "build:dev": "cross-env NODE_ENV=development node build/build.js",
+    "build:test": "cross-env NODE_ENV=testing node build/build.js",
+    "build:prod": "cross-env NODE_ENV=production node build/build.js"
+  },
+  "dependencies": {
+    "@ckeditor/ckeditor5-build-decoupled-document": "^23.1.0",
+    "@smallwei/avue": "^2.8.23",
+    "amap-echarts": "^2.0.0",
+    "axios": "0.18.0",
+    "chokidar": "^3.5.2",
+    "codemirror": "^5.58.1",
+    "crypto-js": "^3.1.9-1",
+    "echarts": "^4.9.0",
+    "echarts-extension-amap": "^1.10.1",
+    "echarts-gl": "^1.1.1",
+    "echarts-wordcloud": "^1.1.3",
+    "element-ui": "^2.9.2",
+    "js-cookie": "2.2.0",
+    "jsbarcode": "^3.11.4",
+    "miment": "^0.0.9",
+    "moment": "^2.29.1",
+    "monaco-editor": "^0.20.0",
+    "normalize.css": "7.0.0",
+    "nprogress": "0.2.0",
+    "qrcodejs2": "0.0.2",
+    "sortablejs": "^1.10.2",
+    "uninstall": "0.0.0",
+    "v-chart": "^1.0.0",
+    "vue": "2.6.11",
+    "vue-codemirror": "^4.0.6",
+    "vue-color": "^2.8.1",
+    "vue-drag-resize": "^1.5.4",
+    "vue-echarts": "^5.0.0-beta.0",
+    "vue-json-editor": "^1.4.3",
+    "vue-router": "3.0.1",
+    "vue-ruler-tool": "^1.2.4",
+    "vue-seamless-scroll": "^1.1.23",
+    "vue-superslide": "^0.1.1",
+    "vue-video-player": "^5.0.2",
+    "vue-wordcloud": "^1.1.1",
+    "vuedraggable": "^2.24.1",
+    "vuex": "3.0.1"
+  },
+  "devDependencies": {
+    "autoprefixer": "8.5.0",
+    "babel-core": "6.26.0",
+    "babel-helper-vue-jsx-merge-props": "2.0.3",
+    "babel-loader": "7.1.5",
+    "babel-plugin-syntax-jsx": "6.18.0",
+    "babel-plugin-transform-runtime": "6.23.0",
+    "babel-plugin-transform-vue-jsx": "3.7.0",
+    "babel-preset-env": "1.7.0",
+    "babel-preset-stage-2": "6.24.1",
+    "chalk": "2.4.1",
+    "copy-webpack-plugin": "4.5.2",
+    "cross-env": "^5.2.0",
+    "css-loader": "1.0.0",
+    "eventsource-polyfill": "0.9.6",
+    "file-loader": "1.1.11",
+    "friendly-errors-webpack-plugin": "1.7.0",
+    "html-webpack-plugin": "4.0.0-alpha",
+    "js-md5": "^0.7.3",
+    "mini-css-extract-plugin": "0.4.1",
+    "monaco-editor-webpack-plugin": "^4.1.1",
+    "node-notifier": "5.2.1",
+    "node-sass": "^4.7.2",
+    "optimize-css-assets-webpack-plugin": "5.0.0",
+    "ora": "3.0.0",
+    "path-to-regexp": "2.4.0",
+    "portfinder": "1.0.16",
+    "postcss-import": "12.0.0",
+    "postcss-loader": "2.1.6",
+    "postcss-url": "7.3.2",
+    "rimraf": "2.6.2",
+    "sass-loader": "7.0.3",
+    "script-ext-html-webpack-plugin": "2.0.1",
+    "semver": "5.5.0",
+    "shelljs": "0.8.2",
+    "svg-sprite-loader": "3.8.0",
+    "svgo": "1.0.5",
+    "uglifyjs-webpack-plugin": "1.2.7",
+    "url-loader": "1.0.1",
+    "vue-loader": "15.3.0",
+    "vue-style-loader": "4.1.2",
+    "vue-template-compiler": "2.6.11",
+    "webpack": "4.16.5",
+    "webpack-bundle-analyzer": "2.13.1",
+    "webpack-cli": "3.1.0",
+    "webpack-dev-server": "3.1.5",
+    "webpack-merge": "4.1.4"
+  },
+  "engines": {
+    "node": ">= 6.0.0",
+    "npm": ">= 3.0.0"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions",
+    "not ie <= 8"
+  ]
+}

+ 110 - 0
report-ui/.history/package_20220902140240.json

@@ -0,0 +1,110 @@
+{
+  "name": "mirror-manager",
+  "version": "3.8.0",
+  "description": "mirror-manager",
+  "author": "mirror-team@anji-plus.com",
+  "scripts": {
+    "dev": "webpack-dev-server --inline --progress --config build/webpack.config.js",
+    "start": "npm run dev",
+    "build": "cross-env NODE_ENV=production node build/build.js",
+    "build:dev": "cross-env NODE_ENV=development node build/build.js",
+    "build:test": "cross-env NODE_ENV=testing node build/build.js",
+    "build:prod": "cross-env NODE_ENV=production node build/build.js"
+  },
+  "dependencies": {
+    "@ckeditor/ckeditor5-build-decoupled-document": "^23.1.0",
+    "@smallwei/avue": "^2.8.23",
+    "amap-echarts": "^2.0.0",
+    "axios": "0.18.0",
+    "chokidar": "^3.5.2",
+    "codemirror": "^5.58.1",
+    "crypto-js": "^3.1.9-1",
+    "echarts": "^4.9.0",
+    "echarts-extension-amap": "^1.10.1",
+    "echarts-gl": "^1.1.1",
+    "echarts-wordcloud": "^1.1.3",
+    "element-ui": "^2.9.2",
+    "js-cookie": "2.2.0",
+    "jsbarcode": "^3.11.4",
+    "miment": "^0.0.9",
+    "moment": "^2.29.1",
+    "monaco-editor": "^0.20.0",
+    "normalize.css": "7.0.0",
+    "nprogress": "0.2.0",
+    "qrcodejs2": "0.0.2",
+    "sortablejs": "^1.10.2",
+    "uninstall": "0.0.0",
+    "v-chart": "^1.0.0",
+    "vue": "2.6.11",
+    "vue-codemirror": "^4.0.6",
+    "vue-color": "^2.8.1",
+    "vue-drag-resize": "^1.5.4",
+    "vue-echarts": "^5.0.0-beta.0",
+    "vue-json-editor": "^1.4.3",
+    "vue-router": "3.0.1",
+    "vue-ruler-tool": "^1.2.4",
+    "vue-seamless-scroll": "^1.1.23",
+    "vue-superslide": "^0.1.1",
+    "vue-video-player": "^5.0.2",
+    "vue-wordcloud": "^1.1.1",
+    "vuedraggable": "^2.24.1",
+    "vuex": "3.0.1"
+  },
+  "devDependencies": {
+    "autoprefixer": "8.5.0",
+    "babel-core": "6.26.0",
+    "babel-helper-vue-jsx-merge-props": "2.0.3",
+    "babel-loader": "7.1.5",
+    "babel-plugin-syntax-jsx": "6.18.0",
+    "babel-plugin-transform-runtime": "6.23.0",
+    "babel-plugin-transform-vue-jsx": "3.7.0",
+    "babel-preset-env": "1.7.0",
+    "babel-preset-stage-2": "6.24.1",
+    "chalk": "2.4.1",
+    "copy-webpack-plugin": "4.5.2",
+    "cross-env": "^5.2.0",
+    "css-loader": "1.0.0",
+    "eventsource-polyfill": "0.9.6",
+    "file-loader": "1.1.11",
+    "friendly-errors-webpack-plugin": "1.7.0",
+    "html-webpack-plugin": "4.0.0-alpha",
+    "js-md5": "^0.7.3",
+    "mini-css-extract-plugin": "0.4.1",
+    "monaco-editor-webpack-plugin": "^4.1.1",
+    "node-notifier": "5.2.1",
+    "node-sass": "^4.7.2",
+    "optimize-css-assets-webpack-plugin": "5.0.0",
+    "ora": "3.0.0",
+    "path-to-regexp": "2.4.0",
+    "portfinder": "1.0.16",
+    "postcss-import": "12.0.0",
+    "postcss-loader": "2.1.6",
+    "postcss-url": "7.3.2",
+    "rimraf": "2.6.2",
+    "sass-loader": "7.0.3",
+    "script-ext-html-webpack-plugin": "2.0.1",
+    "semver": "5.5.0",
+    "shelljs": "0.8.2",
+    "svg-sprite-loader": "3.8.0",
+    "svgo": "1.0.5",
+    "uglifyjs-webpack-plugin": "1.2.7",
+    "url-loader": "1.0.1",
+    "vue-loader": "15.3.0",
+    "vue-style-loader": "4.1.2",
+    "vue-template-compiler": "2.6.11",
+    "webpack": "4.16.5",
+    "webpack-bundle-analyzer": "2.13.1",
+    "webpack-cli": "3.1.0",
+    "webpack-dev-server": "3.1.5",
+    "webpack-merge": "4.1.4"
+  },
+  "engines": {
+    "node": ">= 6.0.0",
+    "npm": ">= 3.0.0"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions",
+    "not ie <= 8"
+  ]
+}

+ 110 - 0
report-ui/.history/package_20220902140407.json

@@ -0,0 +1,110 @@
+{
+  "name": "mirror-manager",
+  "version": "3.8.0",
+  "description": "mirror-manager",
+  "author": "mirror-team@anji-plus.com",
+  "scripts": {
+    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
+    "start": "npm run dev",
+    "build": "cross-env NODE_ENV=production node build/build.js",
+    "build:dev": "cross-env NODE_ENV=development node build/build.js",
+    "build:test": "cross-env NODE_ENV=testing node build/build.js",
+    "build:prod": "cross-env NODE_ENV=production node build/build.js"
+  },
+  "dependencies": {
+    "@ckeditor/ckeditor5-build-decoupled-document": "^23.1.0",
+    "@smallwei/avue": "^2.8.23",
+    "amap-echarts": "^2.0.0",
+    "axios": "0.18.0",
+    "chokidar": "^3.5.2",
+    "codemirror": "^5.58.1",
+    "crypto-js": "^3.1.9-1",
+    "echarts": "^4.9.0",
+    "echarts-extension-amap": "^1.10.1",
+    "echarts-gl": "^1.1.1",
+    "echarts-wordcloud": "^1.1.3",
+    "element-ui": "^2.9.2",
+    "js-cookie": "2.2.0",
+    "jsbarcode": "^3.11.4",
+    "miment": "^0.0.9",
+    "moment": "^2.29.1",
+    "monaco-editor": "^0.20.0",
+    "normalize.css": "7.0.0",
+    "nprogress": "0.2.0",
+    "qrcodejs2": "0.0.2",
+    "sortablejs": "^1.10.2",
+    "uninstall": "0.0.0",
+    "v-chart": "^1.0.0",
+    "vue": "2.6.11",
+    "vue-codemirror": "^4.0.6",
+    "vue-color": "^2.8.1",
+    "vue-drag-resize": "^1.5.4",
+    "vue-echarts": "^5.0.0-beta.0",
+    "vue-json-editor": "^1.4.3",
+    "vue-router": "3.0.1",
+    "vue-ruler-tool": "^1.2.4",
+    "vue-seamless-scroll": "^1.1.23",
+    "vue-superslide": "^0.1.1",
+    "vue-video-player": "^5.0.2",
+    "vue-wordcloud": "^1.1.1",
+    "vuedraggable": "^2.24.1",
+    "vuex": "3.0.1"
+  },
+  "devDependencies": {
+    "autoprefixer": "8.5.0",
+    "babel-core": "6.26.0",
+    "babel-helper-vue-jsx-merge-props": "2.0.3",
+    "babel-loader": "7.1.5",
+    "babel-plugin-syntax-jsx": "6.18.0",
+    "babel-plugin-transform-runtime": "6.23.0",
+    "babel-plugin-transform-vue-jsx": "3.7.0",
+    "babel-preset-env": "1.7.0",
+    "babel-preset-stage-2": "6.24.1",
+    "chalk": "2.4.1",
+    "copy-webpack-plugin": "4.5.2",
+    "cross-env": "^5.2.0",
+    "css-loader": "1.0.0",
+    "eventsource-polyfill": "0.9.6",
+    "file-loader": "1.1.11",
+    "friendly-errors-webpack-plugin": "1.7.0",
+    "html-webpack-plugin": "4.0.0-alpha",
+    "js-md5": "^0.7.3",
+    "mini-css-extract-plugin": "0.4.1",
+    "monaco-editor-webpack-plugin": "^4.1.1",
+    "node-notifier": "5.2.1",
+    "node-sass": "^4.7.2",
+    "optimize-css-assets-webpack-plugin": "5.0.0",
+    "ora": "3.0.0",
+    "path-to-regexp": "2.4.0",
+    "portfinder": "1.0.16",
+    "postcss-import": "12.0.0",
+    "postcss-loader": "2.1.6",
+    "postcss-url": "7.3.2",
+    "rimraf": "2.6.2",
+    "sass-loader": "7.0.3",
+    "script-ext-html-webpack-plugin": "2.0.1",
+    "semver": "5.5.0",
+    "shelljs": "0.8.2",
+    "svg-sprite-loader": "3.8.0",
+    "svgo": "1.0.5",
+    "uglifyjs-webpack-plugin": "1.2.7",
+    "url-loader": "1.0.1",
+    "vue-loader": "15.3.0",
+    "vue-style-loader": "4.1.2",
+    "vue-template-compiler": "2.6.11",
+    "webpack": "4.16.5",
+    "webpack-bundle-analyzer": "2.13.1",
+    "webpack-cli": "3.1.0",
+    "webpack-dev-server": "3.1.5",
+    "webpack-merge": "4.1.4"
+  },
+  "engines": {
+    "node": ">= 6.0.0",
+    "npm": ">= 3.0.0"
+  },
+  "browserslist": [
+    "> 1%",
+    "last 2 versions",
+    "not ie <= 8"
+  ]
+}

+ 493 - 0
report-ui/.history/src/views/login_20220902135315.vue

@@ -0,0 +1,493 @@
+<!--
+ * @Author: qianlishi
+ * @Date: 2020-07-13 11:04:24
+ * @Last Modified by:   qianlishi
+ * @Last Modified time: 2020-07-13 11:04:24
+ !-->
+<template>
+  <div class="login_container">
+    <!-- 顶部logo -->
+<!--    <div class="login_title">-->
+<!--      <img src="@/assets/images/home-logo.png" alt="logo" />-->
+<!--    </div>-->
+    <div class="login_contant">
+      <img ref="loginContantBgImage" src="@/assets/images/login-background.png" alt="image" class="login_img" />
+      <el-form
+        ref="loginForm"
+        :model="loginForm"
+        :rules="loginRules"
+        class="login_form"
+        autocomplete="on"
+        label-position="left"
+        @keyup.enter.native="handleLogin"
+      >
+        <div class="title_container">
+          <div v-if="isShowImageTip" class="titleIcon">
+            <img src="@/assets/svg/bayi.svg" width="80%" style="display: run-in">
+          </div>
+          <div class="title">
+
+            {{ this.systemName }}
+          </div>
+        </div>
+        <div class="form_fields">
+          <!-- 黄色条条 -->
+          <i :style="{ top: activeTop + '%' }" />
+          <!-- 中间条条 -->
+          <b />
+          <div>
+            <p>用户名</p>
+            <el-form-item prop="loginName">
+              <el-input
+                ref="loginName"
+                v-model="loginForm.loginName"
+                placeholder="用户名"
+                name="loginName"
+                type="text"
+                tabindex="1"
+                autocomplete="on"
+                @focus="setTop('0')"
+                @change="getPsw"
+              />
+            </el-form-item>
+          </div>
+          <div>
+            <p>密码</p>
+            <input
+              name="password"
+              type="password"
+              autocomplete="off"
+              class="take"
+            />
+            <el-tooltip
+              v-model="capsTooltip"
+              content="Caps lock is On"
+              placement="right"
+              manual
+            >
+              <el-form-item prop="password">
+                <el-input
+                  :key="passwordType"
+                  ref="password"
+                  v-model="loginForm.password"
+                  :type="passwordType"
+                  placeholder="用户密码"
+                  name="password"
+                  tabindex="2"
+                  autocomplete="on"
+                  @blur="capsTooltip = false"
+                  @focus="setTop('50')"
+                  @keyup.native="checkCapslock"
+                />
+                <span class="show_pwd" @click="showPwd">
+                  <i class="el-icon-view" />
+                </span>
+              </el-form-item>
+            </el-tooltip>
+          </div>
+        </div>
+        <div class="control">
+          <div class="remember">
+            <input v-model="rememberPsw" type="checkbox" />
+            <p>记住密码</p>
+          </div>
+        </div>
+        <el-button
+          :loading="loading"
+          type="primary"
+          class="login_btn"
+          @click.native.prevent="handleLogin"
+          >登录</el-button
+        >
+      </el-form>
+    </div>
+    <!--  验证码  -->
+    <Verify
+      v-if="needCaptcha"
+      ref="verify"
+      :captcha-type="'blockPuzzle'"
+      :img-size="{ width: '400px', height: '200px' }"
+      @success="verifylogin"
+    />
+  </div>
+</template>
+
+<script>
+import Verify from "@/components/verifition/Verify";
+import cookies from "js-cookie";
+import { Decrypt, Encrypt } from "@/utils/index";
+import { login } from "@/api/login";
+import { transPsw } from "@/utils/encrypted";
+import { setToken, setAccessUser } from "@/utils/auth";
+export default {
+  name: "Login",
+  components: {
+    Verify
+  },
+  data() {
+    return {
+      systemName:"大屏管理系统",//退役军人大屏管理后台
+      isShowImageTip: false,
+      activeTop: "-50%", // 色条滑块控制
+      rememberPsw: false, // 记住密码选择框
+      loginForm: {
+        loginName: "",
+        password: "",
+        verifyCode: ""
+      }, // 登录表单
+      loginRules: {
+        loginName: [{ required: true, message: "用户名必填", trigger: "blur" }],
+        password: [{ required: true, message: "用户密码必填", trigger: "blur" }]
+      }, // 登录表单验证
+      passwordType: "password", // 用来控制查看密码操作时的输入框类型
+      capsTooltip: false, // 键盘大写是否打开
+      loading: false, // 登录loding
+      redirect: undefined, // 记录重定向地址
+      otherQuery: {}, // 记录重定向地址中的参数
+      needCaptcha: false
+    };
+  },
+  watch: {
+    $route: {
+      // 监听路由获取上个路由(from)的地址和参数
+      handler: function(route) {
+        const query = route.query;
+        if (query) {
+          this.redirect = query.redirect;
+          this.otherQuery = this.getOtherQuery(query);
+        }
+      },
+      immediate: true
+    }
+  },
+  mounted() {
+    // 获取焦点
+    if (this.loginForm.loginName === "") {
+      this.$refs.loginName.focus();
+    } else if (this.loginForm.password === "") {
+      this.$refs.password.focus();
+    }
+    this.getSystemInfo();
+  },
+  methods: {
+    // 获取存储的密码并解密
+    getPsw() {
+      const cookVal = cookies.get(`u_${this.loginForm.loginName}`);
+      this.loginForm.password = cookVal && Decrypt(cookVal);
+    },
+    getSystemInfo(){
+      let systemName = this.getDictItemByCode ("SYSTEM_SET", "system_name").text;
+      let systemUrl = this.getDictItemByCode ("SYSTEM_SET", "bgImageUrl").text;
+      let isShowTip = this.getDictItemByCode ("SYSTEM_SET", "isShowTip").text;
+      if (systemName){
+        this.systemName =  systemName;
+      }
+      if (systemUrl&&systemUrl!="#"){
+          this.$refs.loginContantBgImage.src= systemUrl;
+      }
+      if (isShowTip=="0"){
+        this.isShowImageTip = true;
+      }
+    },
+    // 滑动条块的top控制
+    setTop(val) {
+      this.activeTop = val;
+    },
+    // 检测大写锁定键是否开启
+    checkCapslock(e) {
+      const { key } = e;
+      this.capsTooltip = key && key.length === 1 && key >= "A" && key <= "Z";
+    },
+    // 查看密码
+    showPwd() {
+      if (this.passwordType === "password") {
+        this.passwordType = "";
+      } else {
+        this.passwordType = "password";
+      }
+      this.$nextTick(() => {
+        this.$refs.password.focus();
+      });
+    },
+    // 滑动验证码
+    useVerify() {
+      this.$refs.loginForm.validate(valid => {
+        if (valid) {
+          this.$refs.verify.show();
+        } else {
+          return false;
+        }
+      });
+    },
+    // 验证成功的回调
+    verifylogin(params) {
+      this.loginForm.verifyCode = params.captchaVerification;
+      if (this.loginForm.verifyCode) {
+        this.loginApi();
+      }
+    },
+    // 登录操作
+    handleLogin() {
+      this.$refs.loginForm.validate(valid => {
+        if (valid) {
+          this.loading = true;
+          // 登录失败次数过多需要展示滑动验证码
+          if (this.needCaptcha) {
+            this.useVerify();
+            return;
+          }
+          this.loginApi();
+        } else {
+          return false;
+        }
+      });
+    },
+    async loginApi() {
+      let obj = {
+        loginName: this.loginForm.loginName,
+        password: transPsw(this.loginForm.password),
+        verifyCode: ""
+      };
+      const { code, data } = await login(obj);
+      this.loading = false;
+      if (code != "200") return;
+      setToken(data.token);
+      setAccessUser(data);
+      // 选中记住密码时 把密码存到cookie里,时效15天
+      this.rememberPsw &&
+        cookies.set(
+          `u_${this.loginForm.loginName}`,
+          Encrypt(this.loginForm.password),
+          { expires: 15 }
+        );
+      if (data && data.captcha) {
+        this.needCaptcha = true;
+      } else {
+        this.needCaptcha = false;
+        this.$router.push({
+          path: this.redirect || "/index",
+          query: this.otherQuery
+        });
+      }
+    },
+    getOtherQuery(query) {
+      return Object.keys(query).reduce((acc, cur) => {
+        if (cur !== "redirect") {
+          acc[cur] = query[cur];
+        }
+        return acc;
+      }, {});
+    }
+  }
+};
+</script>
+
+<style lang="scss">
+.login_container .el-input input {
+  color: #000;
+  background: #fff;
+}
+
+/* reset element-ui css */
+.login_container {
+  .el-input {
+    display: inline-block;
+    width: 100%;
+    input {
+      -webkit-appearance: none;
+      caret-color: rgba($color: #000000, $alpha: 0.3);
+      border: 1px solid #fff;
+      &:-webkit-autofill {
+        box-shadow: 0 0 0px 1000px #eee inset !important;
+        -webkit-text-fill-color: #666 !important;
+      }
+    }
+  }
+
+  .el-form-item {
+    border-radius: 5px;
+    color: #454545;
+  }
+}
+.verifybox {
+  position: absolute;
+  left: auto;
+  right: 30%;
+  transform: translate(50%, -50%);
+}
+</style>
+
+<style lang="scss" scoped>
+.take {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: -1;
+}
+.login_container {
+  height: 100%;
+  width: 100%;
+  overflow: hidden;
+  .login_title {
+    width: 100%;
+    height: 60px;
+    padding: 10px 60px;
+    display: flex;
+    align-items: center;
+    img {
+      width: 10%;
+      display: block;
+    }
+  }
+  .login_contant {
+    position: relative;
+    width: 100%;
+    //height: calc(100% - 60px);
+     height: 100%;
+    .login_img {
+      display: block;
+      width: 100%;
+      height: 100%;
+    }
+    .login_form {
+      position: absolute;
+      top: 50%;
+      right: 50%;
+      transform: translate(50%, -50%);
+      min-width: 400px;
+      width: 35%;
+      height: 460px;
+      background-color: #ffffff;
+      border-radius: 11px;
+      padding: 30px;
+      overflow: hidden;
+      .title_container {
+        //position: relative;
+        width: 100%;
+        display: flex;
+        justify-content: center;
+        text-align: center;
+        .title {
+          height: 100%;
+          font-size: 24px;
+          color: #1a1a1a;
+          .title_name {
+            margin: 0;
+            font-size: 18px;
+          }
+
+        }
+        .titleIcon{
+          height: 100%;
+          width: 30px;
+        }
+        .set_language {
+          color: #fff;
+          position: absolute;
+          top: 3px;
+          font-size: 18px;
+          right: 0px;
+          cursor: pointer;
+        }
+      }
+      .form_fields {
+        position: relative;
+        width: 100%;
+        overflow: hidden;
+        margin-top: 40px;
+        padding: 5px 16px;
+        background: #ffffff;
+        border: 1px solid #e0e0e0;
+        box-shadow: 0 0 14px 4px rgba(230, 229, 229, 0.5);
+        border-radius: 4px 10px 10px 4px;
+        i {
+          position: absolute;
+          top: -50%;
+          left: 0;
+          width: 4px;
+          height: 50%;
+          transition: top 0.2s;
+          background: rgba(61,93,76,1);
+          border-radius: 14px;
+        }
+        b {
+          position: absolute;
+          top: 50%;
+          left: 0;
+          width: 100%;
+          height: 1px;
+          background: #e0e0e0;
+          border-radius: 2px;
+          margin-top: -0.5px;
+        }
+        p {
+          margin: 0;
+          padding: 0;
+          line-height: 32px;
+          height: 32px;
+          font-size: 12px;
+          color: #666;
+        }
+        .show_pwd {
+          position: absolute;
+          right: 20px;
+          top: 25%;
+          font-size: 16px;
+          color: #889aa4;
+          cursor: pointer;
+          user-select: none;
+        }
+      }
+      .control {
+        width: 100%;
+        height: 70px;
+        display: flex;
+        align-items: center;
+        justify-content: space-between;
+        font-size: 14px;
+        color: #919191;
+        .remember {
+          width: 36%;
+          display: flex;
+          align-items: center;
+          p {
+            padding-left: 8px;
+          }
+          // justify-content: space-between;
+          & > input {
+            position: relative;
+            width: 14px;
+            height: 14px;
+          }
+          & > input:checked::before {
+            content: "\2713";
+            background-color: rgba(61,93,76,1);
+            position: absolute;
+            top: 0;
+            left: 0px;
+            padding-left: 1.5px;
+            width: 100%;
+            height: 100%;
+            border: 1px solid rgba(61,93,76,1);
+            border-radius: 2px;
+            font-size: 12px;
+            color: white;
+            font-weight: bold;
+          }
+        }
+      }
+      .login_btn {
+        width: 100%;
+        height: 60px;
+        //margin-left: 25%;
+        background: rgba(61,93,76,1);
+        border: none;
+        border-radius: 10px;
+        font-size: 20px;
+        color: #ffffff;
+        text-align: center;
+      }
+    }
+  }
+}
+</style>

+ 493 - 0
report-ui/.history/src/views/login_20220902141117.vue

@@ -0,0 +1,493 @@
+<!--
+ * @Author: qianlishi
+ * @Date: 2020-07-13 11:04:24
+ * @Last Modified by:   qianlishi
+ * @Last Modified time: 2020-07-13 11:04:24
+ !-->
+<template>
+  <div class="login_container">
+    <!-- 顶部logo -->
+<!--    <div class="login_title">-->
+<!--      <img src="@/assets/images/home-logo.png" alt="logo" />-->
+<!--    </div>-->
+    <div class="login_contant">
+      <img ref="loginContantBgImage" src="@/assets/images/login-background.png" alt="image" class="login_img" />
+      <el-form
+        ref="loginForm"
+        :model="loginForm"
+        :rules="loginRules"
+        class="login_form"
+        autocomplete="on"
+        label-position="left"
+        @keyup.enter.native="handleLogin"
+      >
+        <div class="title_container">
+          <div v-if="isShowImageTip" class="titleIcon">
+            <img src="@/assets/svg/bayi.svg" width="80%" style="display: run-in">
+          </div>
+          <div class="title">
+
+            {{ this.systemName }}
+          </div>
+        </div>
+        <div class="form_fields">
+          <!-- 黄色条条 -->
+          <i :style="{ top: activeTop + '%' }" />
+          <!-- 中间条条 -->
+          <b />
+          <div>
+            <p>用户名</p>
+            <el-form-item prop="loginName">
+              <el-input
+                ref="loginName"
+                v-model="loginForm.loginName"
+                placeholder="用户名"
+                name="loginName"
+                type="text"
+                tabindex="1"
+                autocomplete="on"
+                @focus="setTop('0')"
+                @change="getPsw"
+              />
+            </el-form-item>
+          </div>
+          <div>
+            <p>密码</p>
+            <input
+              name="password"
+              type="password"
+              autocomplete="off"
+              class="take"
+            />
+            <el-tooltip
+              v-model="capsTooltip"
+              content="Caps lock is On"
+              placement="right"
+              manual
+            >
+              <el-form-item prop="password">
+                <el-input
+                  :key="passwordType"
+                  ref="password"
+                  v-model="loginForm.password"
+                  :type="passwordType"
+                  placeholder="用户密码"
+                  name="password"
+                  tabindex="2"
+                  autocomplete="on"
+                  @blur="capsTooltip = false"
+                  @focus="setTop('50')"
+                  @keyup.native="checkCapslock"
+                />
+                <span class="show_pwd" @click="showPwd">
+                  <i class="el-icon-view" />
+                </span>
+              </el-form-item>
+            </el-tooltip>
+          </div>
+        </div>
+        <div class="control">
+          <div class="remember">
+            <input v-model="rememberPsw" type="checkbox" />
+            <p>记住密码</p>
+          </div>
+        </div>
+        <el-button
+          :loading="loading"
+          type="primary"
+          class="login_btn"
+          @click.native.prevent="handleLogin"
+          >登录</el-button
+        >
+      </el-form>
+    </div>
+    <!--  验证码  -->
+    <Verify
+      v-if="needCaptcha"
+      ref="verify"
+      :captcha-type="'blockPuzzle'"
+      :img-size="{ width: '400px', height: '200px' }"
+      @success="verifylogin"
+    />
+  </div>
+</template>
+
+<script>
+import Verify from "@/components/verifition/Verify";
+import cookies from "js-cookie";
+import { Decrypt, Encrypt } from "@/utils/index";
+import { login } from "@/api/login";
+import { transPsw } from "@/utils/encrypted";
+import { setToken, setAccessUser } from "@/utils/auth";
+export default {
+  name: "Login",
+  components: {
+    Verify
+  },
+  data() {
+    return {
+      systemName:"大屏管理系统",//远程制药大屏管理后台
+      isShowImageTip: false,
+      activeTop: "-50%", // 色条滑块控制
+      rememberPsw: false, // 记住密码选择框
+      loginForm: {
+        loginName: "",
+        password: "",
+        verifyCode: ""
+      }, // 登录表单
+      loginRules: {
+        loginName: [{ required: true, message: "用户名必填", trigger: "blur" }],
+        password: [{ required: true, message: "用户密码必填", trigger: "blur" }]
+      }, // 登录表单验证
+      passwordType: "password", // 用来控制查看密码操作时的输入框类型
+      capsTooltip: false, // 键盘大写是否打开
+      loading: false, // 登录loding
+      redirect: undefined, // 记录重定向地址
+      otherQuery: {}, // 记录重定向地址中的参数
+      needCaptcha: false
+    };
+  },
+  watch: {
+    $route: {
+      // 监听路由获取上个路由(from)的地址和参数
+      handler: function(route) {
+        const query = route.query;
+        if (query) {
+          this.redirect = query.redirect;
+          this.otherQuery = this.getOtherQuery(query);
+        }
+      },
+      immediate: true
+    }
+  },
+  mounted() {
+    // 获取焦点
+    if (this.loginForm.loginName === "") {
+      this.$refs.loginName.focus();
+    } else if (this.loginForm.password === "") {
+      this.$refs.password.focus();
+    }
+    this.getSystemInfo();
+  },
+  methods: {
+    // 获取存储的密码并解密
+    getPsw() {
+      const cookVal = cookies.get(`u_${this.loginForm.loginName}`);
+      this.loginForm.password = cookVal && Decrypt(cookVal);
+    },
+    getSystemInfo(){
+      let systemName = this.getDictItemByCode ("SYSTEM_SET", "system_name").text;
+      let systemUrl = this.getDictItemByCode ("SYSTEM_SET", "bgImageUrl").text;
+      let isShowTip = this.getDictItemByCode ("SYSTEM_SET", "isShowTip").text;
+      if (systemName){
+        this.systemName =  systemName;
+      }
+      if (systemUrl&&systemUrl!="#"){
+          this.$refs.loginContantBgImage.src= systemUrl;
+      }
+      if (isShowTip=="0"){
+        this.isShowImageTip = true;
+      }
+    },
+    // 滑动条块的top控制
+    setTop(val) {
+      this.activeTop = val;
+    },
+    // 检测大写锁定键是否开启
+    checkCapslock(e) {
+      const { key } = e;
+      this.capsTooltip = key && key.length === 1 && key >= "A" && key <= "Z";
+    },
+    // 查看密码
+    showPwd() {
+      if (this.passwordType === "password") {
+        this.passwordType = "";
+      } else {
+        this.passwordType = "password";
+      }
+      this.$nextTick(() => {
+        this.$refs.password.focus();
+      });
+    },
+    // 滑动验证码
+    useVerify() {
+      this.$refs.loginForm.validate(valid => {
+        if (valid) {
+          this.$refs.verify.show();
+        } else {
+          return false;
+        }
+      });
+    },
+    // 验证成功的回调
+    verifylogin(params) {
+      this.loginForm.verifyCode = params.captchaVerification;
+      if (this.loginForm.verifyCode) {
+        this.loginApi();
+      }
+    },
+    // 登录操作
+    handleLogin() {
+      this.$refs.loginForm.validate(valid => {
+        if (valid) {
+          this.loading = true;
+          // 登录失败次数过多需要展示滑动验证码
+          if (this.needCaptcha) {
+            this.useVerify();
+            return;
+          }
+          this.loginApi();
+        } else {
+          return false;
+        }
+      });
+    },
+    async loginApi() {
+      let obj = {
+        loginName: this.loginForm.loginName,
+        password: transPsw(this.loginForm.password),
+        verifyCode: ""
+      };
+      const { code, data } = await login(obj);
+      this.loading = false;
+      if (code != "200") return;
+      setToken(data.token);
+      setAccessUser(data);
+      // 选中记住密码时 把密码存到cookie里,时效15天
+      this.rememberPsw &&
+        cookies.set(
+          `u_${this.loginForm.loginName}`,
+          Encrypt(this.loginForm.password),
+          { expires: 15 }
+        );
+      if (data && data.captcha) {
+        this.needCaptcha = true;
+      } else {
+        this.needCaptcha = false;
+        this.$router.push({
+          path: this.redirect || "/index",
+          query: this.otherQuery
+        });
+      }
+    },
+    getOtherQuery(query) {
+      return Object.keys(query).reduce((acc, cur) => {
+        if (cur !== "redirect") {
+          acc[cur] = query[cur];
+        }
+        return acc;
+      }, {});
+    }
+  }
+};
+</script>
+
+<style lang="scss">
+.login_container .el-input input {
+  color: #000;
+  background: #fff;
+}
+
+/* reset element-ui css */
+.login_container {
+  .el-input {
+    display: inline-block;
+    width: 100%;
+    input {
+      -webkit-appearance: none;
+      caret-color: rgba($color: #000000, $alpha: 0.3);
+      border: 1px solid #fff;
+      &:-webkit-autofill {
+        box-shadow: 0 0 0px 1000px #eee inset !important;
+        -webkit-text-fill-color: #666 !important;
+      }
+    }
+  }
+
+  .el-form-item {
+    border-radius: 5px;
+    color: #454545;
+  }
+}
+.verifybox {
+  position: absolute;
+  left: auto;
+  right: 30%;
+  transform: translate(50%, -50%);
+}
+</style>
+
+<style lang="scss" scoped>
+.take {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: -1;
+}
+.login_container {
+  height: 100%;
+  width: 100%;
+  overflow: hidden;
+  .login_title {
+    width: 100%;
+    height: 60px;
+    padding: 10px 60px;
+    display: flex;
+    align-items: center;
+    img {
+      width: 10%;
+      display: block;
+    }
+  }
+  .login_contant {
+    position: relative;
+    width: 100%;
+    //height: calc(100% - 60px);
+     height: 100%;
+    .login_img {
+      display: block;
+      width: 100%;
+      height: 100%;
+    }
+    .login_form {
+      position: absolute;
+      top: 50%;
+      right: 50%;
+      transform: translate(50%, -50%);
+      min-width: 400px;
+      width: 35%;
+      height: 460px;
+      background-color: #ffffff;
+      border-radius: 11px;
+      padding: 30px;
+      overflow: hidden;
+      .title_container {
+        //position: relative;
+        width: 100%;
+        display: flex;
+        justify-content: center;
+        text-align: center;
+        .title {
+          height: 100%;
+          font-size: 24px;
+          color: #1a1a1a;
+          .title_name {
+            margin: 0;
+            font-size: 18px;
+          }
+
+        }
+        .titleIcon{
+          height: 100%;
+          width: 30px;
+        }
+        .set_language {
+          color: #fff;
+          position: absolute;
+          top: 3px;
+          font-size: 18px;
+          right: 0px;
+          cursor: pointer;
+        }
+      }
+      .form_fields {
+        position: relative;
+        width: 100%;
+        overflow: hidden;
+        margin-top: 40px;
+        padding: 5px 16px;
+        background: #ffffff;
+        border: 1px solid #e0e0e0;
+        box-shadow: 0 0 14px 4px rgba(230, 229, 229, 0.5);
+        border-radius: 4px 10px 10px 4px;
+        i {
+          position: absolute;
+          top: -50%;
+          left: 0;
+          width: 4px;
+          height: 50%;
+          transition: top 0.2s;
+          background: rgba(61,93,76,1);
+          border-radius: 14px;
+        }
+        b {
+          position: absolute;
+          top: 50%;
+          left: 0;
+          width: 100%;
+          height: 1px;
+          background: #e0e0e0;
+          border-radius: 2px;
+          margin-top: -0.5px;
+        }
+        p {
+          margin: 0;
+          padding: 0;
+          line-height: 32px;
+          height: 32px;
+          font-size: 12px;
+          color: #666;
+        }
+        .show_pwd {
+          position: absolute;
+          right: 20px;
+          top: 25%;
+          font-size: 16px;
+          color: #889aa4;
+          cursor: pointer;
+          user-select: none;
+        }
+      }
+      .control {
+        width: 100%;
+        height: 70px;
+        display: flex;
+        align-items: center;
+        justify-content: space-between;
+        font-size: 14px;
+        color: #919191;
+        .remember {
+          width: 36%;
+          display: flex;
+          align-items: center;
+          p {
+            padding-left: 8px;
+          }
+          // justify-content: space-between;
+          & > input {
+            position: relative;
+            width: 14px;
+            height: 14px;
+          }
+          & > input:checked::before {
+            content: "\2713";
+            background-color: rgba(61,93,76,1);
+            position: absolute;
+            top: 0;
+            left: 0px;
+            padding-left: 1.5px;
+            width: 100%;
+            height: 100%;
+            border: 1px solid rgba(61,93,76,1);
+            border-radius: 2px;
+            font-size: 12px;
+            color: white;
+            font-weight: bold;
+          }
+        }
+      }
+      .login_btn {
+        width: 100%;
+        height: 60px;
+        //margin-left: 25%;
+        background: rgba(61,93,76,1);
+        border: none;
+        border-radius: 10px;
+        font-size: 20px;
+        color: #ffffff;
+        text-align: center;
+      }
+    }
+  }
+}
+</style>

+ 45 - 0
report-ui/build/build.js

@@ -0,0 +1,45 @@
+'use strict'
+require('./check-versions')()
+
+//process.env.NODE_ENV = 'production'
+
+const ora = require('ora')
+const rm = require('rimraf')
+const path = require('path')
+const chalk = require('chalk')
+const webpack = require('webpack')
+const config = require('../config')
+const webpackConfig = require('./webpack.prod.conf')
+
+const spinner = ora('building for ' + process.env.NODE_ENV + '...')
+spinner.start()
+
+rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
+  if (err) throw err
+  webpack(webpackConfig, (err, stats) => {
+    spinner.stop()
+    if (err) throw err
+    process.stdout.write(
+      stats.toString({
+        colors: true,
+        modules: false,
+        children: false,
+        chunks: false,
+        chunkModules: false
+      }) + '\n\n'
+    )
+
+    if (stats.hasErrors()) {
+      console.log(chalk.red('  Build failed with errors.\n'))
+      process.exit(1)
+    }
+
+    console.log(chalk.cyan('  Build complete.\n'))
+    console.log(
+      chalk.yellow(
+        '  Tip: built files are meant to be served over an HTTP server.\n' +
+        "  Opening index.html over file:// won't work.\n"
+      )
+    )
+  })
+})

+ 64 - 0
report-ui/build/check-versions.js

@@ -0,0 +1,64 @@
+'use strict'
+const chalk = require('chalk')
+const semver = require('semver')
+const packageConfig = require('../package.json')
+const shell = require('shelljs')
+
+function exec(cmd) {
+  return require('child_process')
+    .execSync(cmd)
+    .toString()
+    .trim()
+}
+
+const versionRequirements = [
+  {
+    name: 'node',
+    currentVersion: semver.clean(process.version),
+    versionRequirement: packageConfig.engines.node
+  }
+]
+
+if (shell.which('npm')) {
+  versionRequirements.push({
+    name: 'npm',
+    currentVersion: exec('npm --version'),
+    versionRequirement: packageConfig.engines.npm
+  })
+}
+
+module.exports = function() {
+  const warnings = []
+
+  for (let i = 0; i < versionRequirements.length; i++) {
+    const mod = versionRequirements[i]
+
+    if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
+      warnings.push(
+        mod.name +
+          ': ' +
+          chalk.red(mod.currentVersion) +
+          ' should be ' +
+          chalk.green(mod.versionRequirement)
+      )
+    }
+  }
+
+  if (warnings.length) {
+    console.log('')
+    console.log(
+      chalk.yellow(
+        'To use this template, you must update following to modules:'
+      )
+    )
+    console.log()
+
+    for (let i = 0; i < warnings.length; i++) {
+      const warning = warnings[i]
+      console.log('  ' + warning)
+    }
+
+    console.log()
+    process.exit(1)
+  }
+}

BIN
report-ui/build/logo.png


+ 108 - 0
report-ui/build/utils.js

@@ -0,0 +1,108 @@
+'use strict'
+const path = require('path')
+const config = require('../config')
+const MiniCssExtractPlugin = require('mini-css-extract-plugin')
+const packageConfig = require('../package.json')
+
+exports.assetsPath = function(_path) {
+  const assetsSubDirectory =
+    process.env.NODE_ENV === 'production'
+      ? config.build.assetsSubDirectory
+      : config.dev.assetsSubDirectory
+
+  return path.posix.join(assetsSubDirectory, _path)
+}
+
+exports.cssLoaders = function(options) {
+  options = options || {}
+
+  const cssLoader = {
+    loader: 'css-loader',
+    options: {
+      sourceMap: options.sourceMap
+    }
+  }
+
+  const postcssLoader = {
+    loader: 'postcss-loader',
+    options: {
+      sourceMap: options.sourceMap
+    }
+  }
+
+  // generate loader string to be used with extract text plugin
+  function generateLoaders(loader, loaderOptions) {
+    const loaders = []
+
+    // Extract CSS when that option is specified
+    // (which is the case during production build)
+    if (options.extract) {
+      loaders.push(MiniCssExtractPlugin.loader)
+    } else {
+      loaders.push('vue-style-loader')
+    }
+
+    loaders.push(cssLoader)
+
+    if (options.usePostCSS) {
+      loaders.push(postcssLoader)
+    }
+
+    if (loader) {
+      loaders.push({
+        loader: loader + '-loader',
+        options: Object.assign({}, loaderOptions, {
+          sourceMap: options.sourceMap
+        })
+      })
+    }
+
+    return loaders
+  }
+  // https://vue-loader.vuejs.org/en/configurations/extract-css.html
+  return {
+    css: generateLoaders(),
+    postcss: generateLoaders(),
+    less: generateLoaders('less'),
+    sass: generateLoaders('sass', {
+      indentedSyntax: true
+    }),
+    scss: generateLoaders('sass'),
+    stylus: generateLoaders('stylus'),
+    styl: generateLoaders('stylus')
+  }
+}
+
+// Generate loaders for standalone style files (outside of .vue)
+exports.styleLoaders = function(options) {
+  const output = []
+  const loaders = exports.cssLoaders(options)
+
+  for (const extension in loaders) {
+    const loader = loaders[extension]
+    output.push({
+      test: new RegExp('\\.' + extension + '$'),
+      use: loader
+    })
+  }
+
+  return output
+}
+
+exports.createNotifierCallback = () => {
+  const notifier = require('node-notifier')
+
+  return (severity, errors) => {
+    if (severity !== 'error') return
+
+    const error = errors[0]
+    const filename = error.file && error.file.split('!').pop()
+
+    notifier.notify({
+      title: packageConfig.name,
+      message: severity + ': ' + error.name,
+      subtitle: filename || '',
+      icon: path.join(__dirname, 'logo.png')
+    })
+  }
+}

+ 5 - 0
report-ui/build/vue-loader.conf.js

@@ -0,0 +1,5 @@
+'use strict'
+
+module.exports = {
+  //You can set the vue-loader configuration by yourself.
+}

+ 93 - 0
report-ui/build/webpack.base.conf.js

@@ -0,0 +1,93 @@
+'use strict'
+const path = require('path')
+const utils = require('./utils')
+const config = require('../config')
+const {
+  VueLoaderPlugin
+} = require('vue-loader')
+const vueLoaderConfig = require('./vue-loader.conf')
+
+function resolve(dir) {
+  return path.join(__dirname, '..', dir)
+}
+
+module.exports = {
+  context: path.resolve(__dirname, '../'),
+  entry: {
+    app: './src/main.js'
+  },
+  output: {
+    path: config.build.assetsRoot,
+    filename: '[name].js',
+    publicPath: config.build.assetsPublicPath //process.env.NODE_ENV === 'production' ? config.build.assetsPublicPath : config.dev.assetsPublicPath
+  },
+  resolve: {
+    extensions: ['.js', '.vue', '.json'],
+    alias: {
+      '@': resolve('src')
+    }
+  },
+  module: {
+    rules: [{
+        test: /\.vue$/,
+        loader: 'vue-loader',
+        options: vueLoaderConfig
+      },
+      {
+        test: /\.js$/,
+        loader: 'babel-loader',
+        include: [
+          resolve('src'),
+          resolve('test'),
+          resolve('node_modules/webpack-dev-server/client')
+        ]
+      },
+      {
+        test: /\.svg$/,
+        loader: 'svg-sprite-loader',
+        include: [resolve('src/icons')],
+        options: {
+          symbolId: 'icon-[name]'
+        }
+      },
+      {
+        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
+        loader: 'url-loader',
+        exclude: [resolve('src/icons')],
+        options: {
+          limit: 10000,
+          name: utils.assetsPath('img/[name].[hash:7].[ext]')
+        }
+      },
+      {
+        test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
+        loader: 'url-loader',
+        options: {
+          limit: 10000,
+          name: utils.assetsPath('media/[name].[hash:7].[ext]')
+        }
+      },
+      {
+        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
+        loader: 'url-loader',
+        options: {
+          limit: 10000,
+          name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
+        }
+      }
+    ]
+  },
+  plugins: [new VueLoaderPlugin()],
+  node: {
+    // prevent webpack from injecting useless setImmediate polyfill because Vue
+    // source contains it (although only uses it if it's native).
+    setImmediate: false,
+    // prevent webpack from injecting mocks to Node native modules
+    // that does not make sense for the client
+    dgram: 'empty',
+    fs: 'empty',
+    net: 'empty',
+    tls: 'empty',
+    child_process: 'empty'
+  }
+}

+ 100 - 0
report-ui/build/webpack.dev.conf.js

@@ -0,0 +1,100 @@
+'use strict'
+const path = require('path')
+const utils = require('./utils')
+const webpack = require('webpack')
+const config = require('../config')
+const merge = require('webpack-merge')
+const baseWebpackConfig = require('./webpack.base.conf')
+const HtmlWebpackPlugin = require('html-webpack-plugin')
+const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
+const portfinder = require('portfinder')
+
+function resolve(dir) {
+  return path.join(__dirname, '..', dir)
+}
+
+const HOST = process.env.HOST
+const PORT = process.env.PORT && Number(process.env.PORT)
+
+const devWebpackConfig = merge(baseWebpackConfig, {
+  mode: 'development',
+  output: {
+    path: config.build.assetsRoot,
+    filename: '[name].js',
+    publicPath: config.dev.assetsPublicPath
+  },
+  module: {
+    rules: utils.styleLoaders({
+      sourceMap: config.dev.cssSourceMap,
+      usePostCSS: true
+    })
+  },
+  // cheap-module-eval-source-map is faster for development
+  devtool: config.dev.devtool,
+
+  // these devServer options should be customized in /config/index.js
+  devServer: {
+    clientLogLevel: 'warning',
+    historyApiFallback: true,
+    hot: true,
+    compress: true,
+    host: HOST || config.dev.host,
+    port: PORT || config.dev.port,
+    open: config.dev.autoOpenBrowser,
+    overlay: config.dev.errorOverlay
+      ? { warnings: false, errors: true }
+      : false,
+    publicPath: config.dev.assetsPublicPath,
+    proxy: config.dev.proxyTable,
+    quiet: true, // necessary for FriendlyErrorsPlugin
+    watchOptions: {
+      poll: config.dev.poll
+    }
+  },
+  plugins: [
+    new webpack.DefinePlugin({
+      'process.env': require('../config/dev.env')
+    }),
+    new webpack.HotModuleReplacementPlugin(),
+    // https://github.com/ampedandwired/html-webpack-plugin
+    new HtmlWebpackPlugin({
+      filename: 'index.html',
+      template: 'index.html',
+      inject: true,
+      favicon: resolve('static/favicon.ico'),
+      title: 'vue-admin-template'
+    })
+  ]
+})
+
+module.exports = new Promise((resolve, reject) => {
+  portfinder.basePort = process.env.PORT || config.dev.port
+  portfinder.getPort((err, port) => {
+    if (err) {
+      reject(err)
+    } else {
+      // publish the new Port, necessary for e2e tests
+      process.env.PORT = port
+      // add port to devServer config
+      devWebpackConfig.devServer.port = port
+
+      // Add FriendlyErrorsPlugin
+      devWebpackConfig.plugins.push(
+        new FriendlyErrorsPlugin({
+          compilationSuccessInfo: {
+            messages: [
+              `Your application is running here: http://${
+                devWebpackConfig.devServer.host
+              }:${port}`
+            ]
+          },
+          onErrors: config.dev.notifyOnErrors
+            ? utils.createNotifierCallback()
+            : undefined
+        })
+      )
+
+      resolve(devWebpackConfig)
+    }
+  })
+})

+ 182 - 0
report-ui/build/webpack.prod.conf.js

@@ -0,0 +1,182 @@
+'use strict'
+const path = require('path')
+const utils = require('./utils')
+const webpack = require('webpack')
+const config = require('../config')
+const merge = require('webpack-merge')
+const baseWebpackConfig = require('./webpack.base.conf')
+const CopyWebpackPlugin = require('copy-webpack-plugin')
+const HtmlWebpackPlugin = require('html-webpack-plugin')
+const ScriptExtHtmlWebpackPlugin = require('script-ext-html-webpack-plugin')
+const MiniCssExtractPlugin = require('mini-css-extract-plugin')
+const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin')
+const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
+
+function resolve(dir) {
+  return path.join(__dirname, '..', dir)
+}
+
+var env = require('../config/dev.env')
+if (process.env.NODE_ENV === 'testing') {
+  env = require('../config/test.env')
+}
+if (process.env.NODE_ENV === 'production') {
+  env = require('../config/prod.env')
+}
+
+// For NamedChunksPlugin
+const seen = new Set()
+const nameLength = 4
+
+const webpackConfig = merge(baseWebpackConfig, {
+  mode: 'production',
+  module: {
+    rules: utils.styleLoaders({
+      sourceMap: config.build.productionSourceMap,
+      extract: true,
+      usePostCSS: true
+    })
+  },
+  devtool: config.build.productionSourceMap ? config.build.devtool : false,
+  output: {
+    path: config.build.assetsRoot,
+    filename: utils.assetsPath('js/[name].[chunkhash:8].js'),
+    chunkFilename: utils.assetsPath('js/[name].[chunkhash:8].js')
+  },
+  plugins: [
+    // http://vuejs.github.io/vue-loader/en/workflow/production.html
+    new webpack.DefinePlugin({
+      'process.env': env
+    }),
+    // extract css into its own file
+    new MiniCssExtractPlugin({
+      filename: utils.assetsPath('css/[name].[contenthash:8].css'),
+      chunkFilename: utils.assetsPath('css/[name].[contenthash:8].css')
+    }),
+    // generate dist index.html with correct asset hash for caching.
+    // you can customize output by editing /index.html
+    // see https://github.com/ampedandwired/html-webpack-plugin
+    new HtmlWebpackPlugin({
+      filename: config.build.index,
+      template: 'index.html',
+      inject: true,
+      favicon: resolve('static/favicon.ico'),
+      title: 'vue-admin-template',
+      minify: {
+        removeComments: true,
+        collapseWhitespace: true,
+        removeAttributeQuotes: true
+        // more options:
+        // https://github.com/kangax/html-minifier#options-quick-reference
+      }
+      // default sort mode uses toposort which cannot handle cyclic deps
+      // in certain cases, and in webpack 4, chunk order in HTML doesn't
+      // matter anyway
+    }),
+    new ScriptExtHtmlWebpackPlugin({
+      //`runtime` must same as runtimeChunk name. default is `runtime`
+      inline: /runtime\..*\.js$/
+    }),
+    // keep chunk.id stable when chunk has no name
+    new webpack.NamedChunksPlugin(chunk => {
+      if (chunk.name) {
+        return chunk.name
+      }
+      const modules = Array.from(chunk.modulesIterable)
+      if (modules.length > 1) {
+        const hash = require('hash-sum')
+        const joinedHash = hash(modules.map(m => m.id).join('_'))
+        let len = nameLength
+        while (seen.has(joinedHash.substr(0, len))) len++
+        seen.add(joinedHash.substr(0, len))
+        return `chunk-${joinedHash.substr(0, len)}`
+      } else {
+        return modules[0].id
+      }
+    }),
+    // keep module.id stable when vender modules does not change
+    new webpack.HashedModuleIdsPlugin(),
+    // copy custom static assets
+    new CopyWebpackPlugin([{
+      from: path.resolve(__dirname, '../static'),
+      to: config.build.assetsSubDirectory,
+      ignore: ['.*']
+    }])
+  ],
+  optimization: {
+    splitChunks: {
+      chunks: 'all',
+      cacheGroups: {
+        libs: {
+          name: 'chunk-libs',
+          test: /[\\/]node_modules[\\/]/,
+          priority: 10,
+          chunks: 'initial' // 只打包初始时依赖的第三方
+        },
+        elementUI: {
+          name: 'chunk-elementUI', // 单独将 elementUI 拆包
+          priority: 20, // 权重要大于 libs 和 app 不然会被打包进 libs 或者 app
+          test: /[\\/]node_modules[\\/]element-ui[\\/]/
+        }
+      }
+    },
+    runtimeChunk: 'single',
+    minimizer: [
+      new UglifyJsPlugin({
+        uglifyOptions: {
+          mangle: {
+            safari10: true
+          }
+        },
+        sourceMap: config.build.productionSourceMap,
+        cache: true,
+        parallel: true
+      }),
+      // Compress extracted CSS. We are using this plugin so that possible
+      // duplicated CSS from different components can be deduped.
+      new OptimizeCSSAssetsPlugin()
+    ]
+  }
+})
+
+if (config.build.productionGzip) {
+  const CompressionWebpackPlugin = require('compression-webpack-plugin')
+
+  webpackConfig.plugins.push(
+    new CompressionWebpackPlugin({
+      asset: '[path].gz[query]',
+      algorithm: 'gzip',
+      test: new RegExp(
+        '\\.(' + config.build.productionGzipExtensions.join('|') + ')$'
+      ),
+      threshold: 10240,
+      minRatio: 0.8
+    })
+  )
+}
+
+if (config.build.generateAnalyzerReport || config.build.bundleAnalyzerReport) {
+  const BundleAnalyzerPlugin = require('webpack-bundle-analyzer')
+    .BundleAnalyzerPlugin
+
+  if (config.build.bundleAnalyzerReport) {
+    webpackConfig.plugins.push(
+      new BundleAnalyzerPlugin({
+        analyzerPort: 8080,
+        generateStatsFile: false
+      })
+    )
+  }
+
+  if (config.build.generateAnalyzerReport) {
+    webpackConfig.plugins.push(
+      new BundleAnalyzerPlugin({
+        analyzerMode: 'static',
+        reportFilename: 'bundle-report.html',
+        openAnalyzer: false
+      })
+    )
+  }
+}
+
+module.exports = webpackConfig

+ 2 - 2
report-ui/src/views/layout/components/Sidebar/index.vue

@@ -1,8 +1,8 @@
 <template>
   <el-scrollbar wrap-class="scrollbar-wrapper">
     <div class="admin-title" @click="goBigScreen">
-<!--      <img src="../../../../../static/logo-dp.png" width="50" class="mt10" />-->
-      <img src="@/assets/svg/bayi.svg" width="50" class="mt10" />
+     <img src="../../../../../static/logo-dp.png" width="50" class="mt10" />
+      <!-- <img src="@/assets/svg/bayi.svg" width="50" class="mt10" /> -->
     </div>
     <el-menu :show-timeout="200" :default-active="$route.path" :collapse="isCollapse" mode="vertical">
       <sidebar-item v-for="route in routes" :key="route.path" :item="route" :base-path="route.path" />