Compare commits
7 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 39093641d8 | |||
|
|
c88484caf7 | ||
| bb7eb039b5 | |||
| b317bf9c7d | |||
| 0a521bdcb7 | |||
| 263cd764f3 | |||
| a04bb33206 |
328
package.json
328
package.json
@@ -1,166 +1,168 @@
|
||||
{
|
||||
"name": "vue-pc-admin",
|
||||
"version": "0.1.0",
|
||||
"description": "这是一个基于 vue admin 管理后台",
|
||||
"author": "caojinwei",
|
||||
"license": "NJCN",
|
||||
"scripts": {
|
||||
"dev": "vue-cli-service serve",
|
||||
"dev-zoom": "cross-env VUE_APP_ZOOM=1 vue-cli-service serve",
|
||||
"dev-cgyqr": "cross-env VUE_APP_MODE=cgyqr vue-cli-service serve",
|
||||
"dev-hbqr": "cross-env VUE_APP_MODE=cgyqr VUE_APP_HB=hbqr vue-cli-service serve",
|
||||
"dev-jbqr": "cross-env VUE_APP_MODE=jbqr vue-cli-service serve",
|
||||
"build": "vue-cli-service build",
|
||||
"build-zoom": "cross-env VUE_APP_ZOOM=1 vue-cli-service build",
|
||||
"build-hbqr": "cross-env VUE_APP_MODE=cgyqr VUE_APP_HB=hbqr vue-cli-service build",
|
||||
"build-cgyqr": "cross-env VUE_APP_MODE=cgyqr vue-cli-service build",
|
||||
"build-jbqr": "cross-env VUE_APP_MODE=jbqr vue-cli-service build",
|
||||
"preview": "node build/index.js --preview",
|
||||
"deploy-18": "cross-env VUE_APP_ZOOM=1 vue-cli-service build && ./upload_script/upload_18.sh"
|
||||
},
|
||||
"dependencies": {
|
||||
"@ckeditor/ckeditor5-vue": "^1.0.1",
|
||||
"@jiaminghi/data-view": "^2.10.0",
|
||||
"@riophae/vue-treeselect": "^0.4.0",
|
||||
"@toast-ui/editor": "^2.0.1",
|
||||
"@toast-ui/vue-editor": "^2.0.1",
|
||||
"@vue/composition-api": "^1.3.0",
|
||||
"@wangeditor/editor": "^5.1.23",
|
||||
"@wangeditor/editor-for-vue": "^1.0.2",
|
||||
"axios": "^0.27.2",
|
||||
"baidu-map": "^0.1.4",
|
||||
"bpmn-js": "^11.1.0",
|
||||
"bpmn-js-bpmnlint": "^0.15.0",
|
||||
"bpmnlint": "^6.4.0",
|
||||
"bpmnlint-loader": "^0.1.4",
|
||||
"codemirror": "5.39.2",
|
||||
"core-js": "^2.6.12",
|
||||
"cross-storage": "^1.0.0",
|
||||
"crypto-js": "^4.2.0",
|
||||
"deepmerge": "^4.2.2",
|
||||
"driver.js": "^0.9.8",
|
||||
"echarts": "^5.4.3",
|
||||
"echarts-gl": "^2.0.9",
|
||||
"echarts-liquidfill": "^3.1.0",
|
||||
"el-tree-transfer": "^2.4.7",
|
||||
"element-resize-detector": "^1.2.4",
|
||||
"element-ui": "^2.15.9",
|
||||
"exceljs": "^4.3.0",
|
||||
"fabric": "^5.3.0",
|
||||
"file-saver": "^2.0.5",
|
||||
"form-gen-parser": "^1.0.3",
|
||||
"highcharts": "^10.0.0",
|
||||
"highcharts-vue": "^1.4.0",
|
||||
"html2canvas": "^1.4.1",
|
||||
"jquery": "^3.6.0",
|
||||
"jquery.panzoom": "^3.2.3",
|
||||
"js-cookie": "2.2.0",
|
||||
"json2csv": "^5.0.6",
|
||||
"less": "^4.1.2",
|
||||
"less-loader": "^5.0.0",
|
||||
"lib-flexible": "^0.3.2",
|
||||
"lodash.clonedeep": "^4.5.0",
|
||||
"luckyexcel": "^1.0.1",
|
||||
"mqtt": "^4.3.6",
|
||||
"normalize.css": "7.0.0",
|
||||
"nprogress": "0.2.0",
|
||||
"path-to-regexp": "2.4.0",
|
||||
"qiniu-js": "^3.1.2",
|
||||
"qrcodejs2": "^0.0.2",
|
||||
"sanitizer": "^0.1.3",
|
||||
"screenfull": "^5.0.2",
|
||||
"session-storage-sync": "^0.6.0",
|
||||
"sortablejs": "^1.10.2",
|
||||
"spin.js": "^4.1.1",
|
||||
"sync-session-storage": "^0.0.13",
|
||||
"throttle-debounce": "^1.1.0",
|
||||
"timeline-slider-vue": "^1.0.6",
|
||||
"umy-ui": "^1.1.6",
|
||||
"v-loading-plugin": "^1.0.7",
|
||||
"vue": "2.6.10",
|
||||
"vue-baidu-map": "^0.21.22",
|
||||
"vue-drag-resize": "^1.5.4",
|
||||
"vue-echarts": "^6.6.2",
|
||||
"vue-grid-layout": "^2.3.12",
|
||||
"vue-jsonp": "^2.0.0",
|
||||
"vue-masonry": "^0.16.0",
|
||||
"vue-particles": "^1.0.9",
|
||||
"vue-resize-observer": "^2.0.16",
|
||||
"vue-router": "3.0.6",
|
||||
"vue-slider-component": "^3.2.24",
|
||||
"vue-svg-filler": "^1.0.6",
|
||||
"vuedraggable": "^2.24.3",
|
||||
"vuex": "3.1.0",
|
||||
"vxe-table": "3.6.6",
|
||||
"vxe-table-plugin-export-xlsx": "2.2.2",
|
||||
"webpack-theme-color-replacer": "^1.3.7",
|
||||
"xe-utils": "^3.5.14",
|
||||
"xlsx": "^0.15.6"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/core": "7.0.0",
|
||||
"@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
|
||||
"@babel/plugin-proposal-optional-chaining": "^7.21.0",
|
||||
"@babel/plugin-transform-modules-commonjs": "^7.9.0",
|
||||
"@babel/register": "7.0.0",
|
||||
"@vue/cli-plugin-babel": "3.6.0",
|
||||
"@vue/cli-service": "^3.12.1",
|
||||
"@vue/test-utils": "1.0.0-beta.29",
|
||||
"autoprefixer": "^9.5.1",
|
||||
"babel-core": "7.0.0-bridge.0",
|
||||
"babel-plugin-transform-es2015-modules-commonjs": "^6.26.2",
|
||||
"babel-plugin-transform-remove-console": "^6.9.4",
|
||||
"chalk": "2.4.2",
|
||||
"compression-webpack-plugin": "^3.1.0",
|
||||
"connect": "3.6.6",
|
||||
"cross-env": "^7.0.3",
|
||||
"css-properties-sorting": "^1.0.10",
|
||||
"d3": "^7.1.1",
|
||||
"default-passive-events": "^2.0.0",
|
||||
"highlight.js": "9.18.5",
|
||||
"html-webpack-plugin": "3.2.0",
|
||||
"less": "^4.1.1",
|
||||
"less-loader": "^5.0.0",
|
||||
"lint-staged": "8.1.5",
|
||||
"open": "^7.0.3",
|
||||
"postcss-loader": "^3.0.0",
|
||||
"px2rem-loader": "^0.1.9",
|
||||
"raw-loader": "^0.5.1",
|
||||
"runjs": "^4.3.2",
|
||||
"sass": "^1.62.0",
|
||||
"sass-loader": "^7.1.0",
|
||||
"sass-resources-loader": "^2.0.3",
|
||||
"script-ext-html-webpack-plugin": "2.1.3",
|
||||
"script-loader": "0.7.2",
|
||||
"serve-static": "^1.13.2",
|
||||
"stylelint": "^12.0.1",
|
||||
"stylelint-config-standard": "^20.0.0",
|
||||
"stylelint-order": "^4.1.0",
|
||||
"stylelint-scss": "^3.18.0",
|
||||
"svg-sprite-loader": "4.1.3",
|
||||
"svgo": "1.2.2",
|
||||
"vkbeautify": "^0.99.3",
|
||||
"vue-particles": "^1.0.9",
|
||||
"vue-template-compiler": "2.6.10",
|
||||
"vue2-ace-editor": "^0.0.15",
|
||||
"xcrud": "^0.4.19"
|
||||
},
|
||||
"lint-staged": {
|
||||
"src/**/*.{js,vue}": [
|
||||
"git add"
|
||||
],
|
||||
"src/**/*.{html,vue,css,sass,scss}": [
|
||||
"stylelint --fix",
|
||||
"git add"
|
||||
"name": "vue-pc-admin",
|
||||
"version": "0.1.0",
|
||||
"description": "这是一个基于 vue admin 管理后台",
|
||||
"author": "caojinwei",
|
||||
"license": "NJCN",
|
||||
"scripts": {
|
||||
"dev": "vue-cli-service serve",
|
||||
"dev-zoom": "cross-env VUE_APP_ZOOM=1 vue-cli-service serve",
|
||||
"dev-cgyqr": "cross-env VUE_APP_MODE=cgyqr vue-cli-service serve",
|
||||
"dev-cgyqr1": "cross-env VUE_APP_MODE=cgyqr VUE_APP_KEY=scqr vue-cli-service serve",
|
||||
"dev-hbqr": "cross-env VUE_APP_MODE=cgyqr VUE_APP_HB=hbqr VUE_APP_KEY=scqr vue-cli-service serve",
|
||||
"dev-jbqr": "cross-env VUE_APP_MODE=jbqr vue-cli-service serve",
|
||||
"build": "vue-cli-service build",
|
||||
"build-zoom": "cross-env VUE_APP_ZOOM=1 vue-cli-service build",
|
||||
"build-hbqr": "cross-env VUE_APP_MODE=cgyqr VUE_APP_HB=hbqr VUE_APP_KEY=scqr vue-cli-service build",
|
||||
"build-cgyqr": "cross-env VUE_APP_MODE=cgyqr vue-cli-service build",
|
||||
"build-cgyqr1": "cross-env VUE_APP_MODE=cgyqr VUE_APP_KEY=scqr vue-cli-service build",
|
||||
"build-jbqr": "cross-env VUE_APP_MODE=jbqr vue-cli-service build",
|
||||
"preview": "node build/index.js --preview",
|
||||
"deploy-18": "cross-env VUE_APP_ZOOM=1 vue-cli-service build && ./upload_script/upload_18.sh"
|
||||
},
|
||||
"dependencies": {
|
||||
"@ckeditor/ckeditor5-vue": "^1.0.1",
|
||||
"@jiaminghi/data-view": "^2.10.0",
|
||||
"@riophae/vue-treeselect": "^0.4.0",
|
||||
"@toast-ui/editor": "^2.0.1",
|
||||
"@toast-ui/vue-editor": "^2.0.1",
|
||||
"@vue/composition-api": "^1.3.0",
|
||||
"@wangeditor/editor": "^5.1.23",
|
||||
"@wangeditor/editor-for-vue": "^1.0.2",
|
||||
"axios": "^0.27.2",
|
||||
"baidu-map": "^0.1.4",
|
||||
"bpmn-js": "^11.1.0",
|
||||
"bpmn-js-bpmnlint": "^0.15.0",
|
||||
"bpmnlint": "^6.4.0",
|
||||
"bpmnlint-loader": "^0.1.4",
|
||||
"codemirror": "5.39.2",
|
||||
"core-js": "^2.6.12",
|
||||
"cross-storage": "^1.0.0",
|
||||
"crypto-js": "^4.2.0",
|
||||
"deepmerge": "^4.2.2",
|
||||
"driver.js": "^0.9.8",
|
||||
"echarts": "^5.4.3",
|
||||
"echarts-gl": "^2.0.9",
|
||||
"echarts-liquidfill": "^3.1.0",
|
||||
"el-tree-transfer": "^2.4.7",
|
||||
"element-resize-detector": "^1.2.4",
|
||||
"element-ui": "^2.15.9",
|
||||
"exceljs": "^4.3.0",
|
||||
"fabric": "^5.3.0",
|
||||
"file-saver": "^2.0.5",
|
||||
"form-gen-parser": "^1.0.3",
|
||||
"highcharts": "^10.0.0",
|
||||
"highcharts-vue": "^1.4.0",
|
||||
"html2canvas": "^1.4.1",
|
||||
"jquery": "^3.6.0",
|
||||
"jquery.panzoom": "^3.2.3",
|
||||
"js-cookie": "2.2.0",
|
||||
"json2csv": "^5.0.6",
|
||||
"less": "^4.1.2",
|
||||
"less-loader": "^5.0.0",
|
||||
"lib-flexible": "^0.3.2",
|
||||
"lodash.clonedeep": "^4.5.0",
|
||||
"luckyexcel": "^1.0.1",
|
||||
"mqtt": "^4.3.6",
|
||||
"normalize.css": "7.0.0",
|
||||
"nprogress": "0.2.0",
|
||||
"path-to-regexp": "2.4.0",
|
||||
"qiniu-js": "^3.1.2",
|
||||
"qrcodejs2": "^0.0.2",
|
||||
"sanitizer": "^0.1.3",
|
||||
"screenfull": "^5.0.2",
|
||||
"session-storage-sync": "^0.6.0",
|
||||
"sortablejs": "^1.10.2",
|
||||
"spin.js": "^4.1.1",
|
||||
"sync-session-storage": "^0.0.13",
|
||||
"throttle-debounce": "^1.1.0",
|
||||
"timeline-slider-vue": "^1.0.6",
|
||||
"umy-ui": "^1.1.6",
|
||||
"v-loading-plugin": "^1.0.7",
|
||||
"vue": "2.6.10",
|
||||
"vue-baidu-map": "^0.21.22",
|
||||
"vue-drag-resize": "^1.5.4",
|
||||
"vue-echarts": "^6.6.2",
|
||||
"vue-grid-layout": "^2.3.12",
|
||||
"vue-jsonp": "^2.0.0",
|
||||
"vue-masonry": "^0.16.0",
|
||||
"vue-particles": "^1.0.9",
|
||||
"vue-resize-observer": "^2.0.16",
|
||||
"vue-router": "3.0.6",
|
||||
"vue-slider-component": "^3.2.24",
|
||||
"vue-svg-filler": "^1.0.6",
|
||||
"vuedraggable": "^2.24.3",
|
||||
"vuex": "3.1.0",
|
||||
"vxe-table": "3.6.6",
|
||||
"vxe-table-plugin-export-xlsx": "2.2.2",
|
||||
"webpack-theme-color-replacer": "^1.3.7",
|
||||
"xe-utils": "^3.5.14",
|
||||
"xlsx": "^0.15.6"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/core": "7.0.0",
|
||||
"@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
|
||||
"@babel/plugin-proposal-optional-chaining": "^7.21.0",
|
||||
"@babel/plugin-transform-modules-commonjs": "^7.9.0",
|
||||
"@babel/register": "7.0.0",
|
||||
"@vue/cli-plugin-babel": "3.6.0",
|
||||
"@vue/cli-service": "^3.12.1",
|
||||
"@vue/test-utils": "1.0.0-beta.29",
|
||||
"autoprefixer": "^9.5.1",
|
||||
"babel-core": "7.0.0-bridge.0",
|
||||
"babel-plugin-transform-es2015-modules-commonjs": "^6.26.2",
|
||||
"babel-plugin-transform-remove-console": "^6.9.4",
|
||||
"chalk": "2.4.2",
|
||||
"compression-webpack-plugin": "^3.1.0",
|
||||
"connect": "3.6.6",
|
||||
"cross-env": "^7.0.3",
|
||||
"css-properties-sorting": "^1.0.10",
|
||||
"d3": "^7.1.1",
|
||||
"default-passive-events": "^2.0.0",
|
||||
"highlight.js": "9.18.5",
|
||||
"html-webpack-plugin": "3.2.0",
|
||||
"less": "^4.1.1",
|
||||
"less-loader": "^5.0.0",
|
||||
"lint-staged": "8.1.5",
|
||||
"open": "^7.0.3",
|
||||
"postcss-loader": "^3.0.0",
|
||||
"px2rem-loader": "^0.1.9",
|
||||
"raw-loader": "^0.5.1",
|
||||
"runjs": "^4.3.2",
|
||||
"sass": "^1.62.0",
|
||||
"sass-loader": "^7.1.0",
|
||||
"sass-resources-loader": "^2.0.3",
|
||||
"script-ext-html-webpack-plugin": "2.1.3",
|
||||
"script-loader": "0.7.2",
|
||||
"serve-static": "^1.13.2",
|
||||
"stylelint": "^12.0.1",
|
||||
"stylelint-config-standard": "^20.0.0",
|
||||
"stylelint-order": "^4.1.0",
|
||||
"stylelint-scss": "^3.18.0",
|
||||
"svg-sprite-loader": "4.1.3",
|
||||
"svgo": "1.2.2",
|
||||
"vkbeautify": "^0.99.3",
|
||||
"vue-particles": "^1.0.9",
|
||||
"vue-template-compiler": "2.6.10",
|
||||
"vue2-ace-editor": "^0.0.15",
|
||||
"xcrud": "^0.4.19"
|
||||
},
|
||||
"lint-staged": {
|
||||
"src/**/*.{js,vue}": [
|
||||
"git add"
|
||||
],
|
||||
"src/**/*.{html,vue,css,sass,scss}": [
|
||||
"stylelint --fix",
|
||||
"git add"
|
||||
]
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=8.9",
|
||||
"npm": ">= 3.0.0"
|
||||
},
|
||||
"browserslist": [
|
||||
"> 1%",
|
||||
"last 2 versions",
|
||||
"not ie <= 11"
|
||||
]
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=8.9",
|
||||
"npm": ">= 3.0.0"
|
||||
},
|
||||
"browserslist": [
|
||||
"> 1%",
|
||||
"last 2 versions",
|
||||
"not ie <= 11"
|
||||
]
|
||||
}
|
||||
|
||||
@@ -72,21 +72,21 @@ export function getDicTree() {
|
||||
}
|
||||
export function getDicTreeAdd(data) {
|
||||
return request({
|
||||
url: '/system-boot/dic/add',
|
||||
url: '/system-boot/dictTree/add',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
export function getDicTreeUpdate(data) {
|
||||
return request({
|
||||
url: '/system-boot/dic/update',
|
||||
url: '/system-boot/dictTree/update',
|
||||
method: 'put',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
export function getDicTreeDelete(data) {
|
||||
return request({
|
||||
url: '/system-boot/dic/delete',
|
||||
url: '/system-boot/dictTree/delete',
|
||||
method: 'delete',
|
||||
params: data
|
||||
})
|
||||
|
||||
@@ -15,6 +15,14 @@ export function heBeiToken(data) {
|
||||
params: data,
|
||||
});
|
||||
}
|
||||
// /超高压嵌入token校验
|
||||
export function productionManagementCheck(data) {
|
||||
return request({
|
||||
url: "/pqs-auth/judgeToken/productionManagementCheck",
|
||||
method: "post",
|
||||
params: data,
|
||||
});
|
||||
}
|
||||
//登录获取token
|
||||
export function login(data) {
|
||||
return request({
|
||||
|
||||
@@ -3,8 +3,7 @@ import store from './store'
|
||||
import NProgress from 'nprogress' // progress bar
|
||||
import 'nprogress/nprogress.css' // progress bar style
|
||||
import getPageTitle from '@/utils/get-page-title'
|
||||
import { logout } from '@/api/user.js'
|
||||
|
||||
import { productionManagementCheck } from '@/api/user.js'
|
||||
// NProgress.configure({ showSpinner: false }) // NProgress Configuration
|
||||
// && from.path === '/agreement' && from.path === '/policy'
|
||||
const whiteList = ['/login', '/agreement', '/policy'] // no redirect whitelist
|
||||
@@ -19,7 +18,12 @@ const cgyList = [
|
||||
'/Statistical-analysis/baselineLevelAssessment',
|
||||
'/Statistical-analysis/substationBackgroundHarmonic',
|
||||
'/Statistical-analysis/steadyStateIndicators',
|
||||
'/Statistical-analysis/transientIndicators'
|
||||
'/Statistical-analysis/transientIndicators',
|
||||
'/harmonicWave/homePage',
|
||||
'/harmonicWave/pointmonitoring',
|
||||
'/harmonicWave/regionalmonitoring',
|
||||
'/harmonicWave/comprehensiveanalysis',
|
||||
'/harmonicWave/CVT'
|
||||
]
|
||||
// 免登录判断
|
||||
import { sm2, encrypt } from '@/assets/commjs/sm2.js'
|
||||
@@ -27,7 +31,11 @@ import { sm3Digest } from '@/assets/commjs/sm3'
|
||||
import { setDictype, setSysConfig } from '@/utils/auth'
|
||||
import { gongkey, CodeSr, heBeiToken, menulist, updateFirstPassword, dictypeData, getSysConfig } from '@/api/user'
|
||||
let routerPath = ''
|
||||
let flag = false
|
||||
router.beforeEach(async (to, from, next) => {
|
||||
console.log('🚀 ~ to:', to)
|
||||
console.log('🚀 ~ getURLParameter ~ window.location.href:', window.location.href)
|
||||
|
||||
// start progress bar
|
||||
// NProgress.start()
|
||||
|
||||
@@ -43,6 +51,10 @@ router.beforeEach(async (to, from, next) => {
|
||||
// 超高压河北免登录功能
|
||||
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
if (flag) {
|
||||
flag = false
|
||||
return next()
|
||||
}
|
||||
if (process.env.VUE_APP_HB == 'hbqr') {
|
||||
// let data = JSON.parse(sessionStorage.getItem('userInfo1'))
|
||||
// if (data.userToken == sessionStorage.getItem('HB_TOKEN')) {
|
||||
@@ -54,7 +66,10 @@ router.beforeEach(async (to, from, next) => {
|
||||
// window.sessionStorage.removeItem('cntoken')
|
||||
// sessionStorage.setItem('HB_TOKEN', data.userToken)
|
||||
// setTimeout(() => {
|
||||
proceed(to, from, next, 'cdf')
|
||||
|
||||
// console.log('🚀 ~ getURLParameter ~ url:', url)
|
||||
|
||||
proceed({ path: window.location.href.split('#')[1].split('&')[0] }, from, next, 'cdf')
|
||||
// }, 10)
|
||||
// }
|
||||
|
||||
@@ -87,7 +102,25 @@ router.beforeEach(async (to, from, next) => {
|
||||
// })
|
||||
// }
|
||||
} else {
|
||||
proceed(to, from, next)
|
||||
// const response = await fetch('/')
|
||||
// const flag = response.headers.get('X-Xbqr')
|
||||
|
||||
let { accessToken, pathname } = getURLParameter('accessToken')
|
||||
console.log('🚀 ~ accessToken:', accessToken, pathname)
|
||||
// getURLParameter
|
||||
if (accessToken) {
|
||||
// 超高压嵌入 接受父应用传参
|
||||
console.log('超高压嵌入')
|
||||
productionManagementCheck({
|
||||
token: accessToken
|
||||
}).then(res => {
|
||||
if (res.code == 'A0000') {
|
||||
proceed({ path: pathname || to.path }, from, next, 'cdf1')
|
||||
}
|
||||
})
|
||||
} else {
|
||||
proceed(to, from, next)
|
||||
}
|
||||
}
|
||||
|
||||
// else {
|
||||
@@ -131,11 +164,54 @@ router.beforeEach(async (to, from, next) => {
|
||||
}
|
||||
}
|
||||
})
|
||||
// 解析 URL 参数
|
||||
function getURLParameter(name) {
|
||||
// 获取当前页面的 URL
|
||||
const url = window.location.href
|
||||
// console.log('🚀 ~ getURLParameter ~ url:', url)
|
||||
|
||||
// 使用 URL 对象解析 URL
|
||||
const urlObj = new URL(url)
|
||||
console.log('🚀 ~ getURLParameter ~ urlObj:', urlObj)
|
||||
|
||||
// 获取查询参数
|
||||
const params = new URLSearchParams(urlObj.search)
|
||||
console.log(params.get(name)) // 输出: 123
|
||||
console.log('pathname', urlObj.pathname) // 输出: 123
|
||||
// 获取 id 参数
|
||||
return {
|
||||
accessToken: params.get('accessToken'),
|
||||
pathname: urlObj.pathname
|
||||
}
|
||||
}
|
||||
function getURLParameterHb(name) {
|
||||
// 获取当前页面的 URL
|
||||
const url = window.location.href
|
||||
// console.log('🚀 ~ getURLParameter ~ url:', url)
|
||||
|
||||
// 使用 URL 对象解析 URL
|
||||
const urlObj = new URL(url)
|
||||
console.log('🚀 ~ getURLParameter ~ urlObj:', urlObj)
|
||||
|
||||
// 获取查询参数
|
||||
const params = new URLSearchParams(urlObj.search)
|
||||
console.log(params.get(name)) // 输出: 123
|
||||
console.log('pathname', urlObj.pathname) // 输出: 123
|
||||
// 获取 id 参数
|
||||
return {
|
||||
accessToken: params.get('accessToken'),
|
||||
pathname: urlObj.pathname
|
||||
}
|
||||
}
|
||||
|
||||
async function proceed(to, from, next, HB_NAME) {
|
||||
// 打印当前 name 和 sessionStorage 中 cntoken 是否为空的日志
|
||||
let name = HB_NAME || 'cdf'
|
||||
// 检查 sessionStorage 中是否没有 cntoken
|
||||
console.log('🚀 ~ proceed ~ name:', name, window.sessionStorage.getItem('cntoken') == null)
|
||||
// 定义默认密码
|
||||
if (window.sessionStorage.getItem('cntoken') == null) {
|
||||
// 初始化登录表单
|
||||
let password = '@#001njcnpqs'
|
||||
let loginjmForm = {
|
||||
username: '',
|
||||
@@ -143,47 +219,69 @@ async function proceed(to, from, next, HB_NAME) {
|
||||
grant_type: 'captcha',
|
||||
verifyCode: 0,
|
||||
imageCode: ''
|
||||
// 对 name 进行加密处理
|
||||
}
|
||||
let username = encrypt(name)
|
||||
// 设置登录表单的用户名
|
||||
|
||||
// 将应用高度存储到 sessionStorage 中
|
||||
loginjmForm.username = username
|
||||
// 调用 gongkey 函数获取公钥
|
||||
window.sessionStorage.setItem('appheight', document.body.offsetHeight - 10)
|
||||
await gongkey({ loginName: username }).then(async response => {
|
||||
window.publicKey = response.data
|
||||
// 将公钥存储到全局变量和 localStorage 中
|
||||
window.localStorage.setItem('publicKey', response.data)
|
||||
|
||||
var sm3Pwd = sm3Digest(password)
|
||||
// 使用 SM3 算法对密码进行摘要处理
|
||||
var jiamipassword = ''
|
||||
// 使用 SM2 算法对密码进行加密
|
||||
jiamipassword = sm2(sm3Pwd + '|' + password, publicKey, 0)
|
||||
loginjmForm.password = jiamipassword
|
||||
// 设置登录表单的加密密码
|
||||
|
||||
store
|
||||
// 调用 Vuex 的 login 方法进行登录
|
||||
.dispatch('user/login', loginjmForm)
|
||||
.then(async response => {
|
||||
if (response.code === 'A0101' && response.message === '登录认证,密码失效,请重置') {
|
||||
// 如果登录响应需要重置密码
|
||||
CodeSr().then(response => {
|
||||
// 调用 CodeSr 函数获取验证码图片
|
||||
let blob = new Blob([response], { type: 'image/jpg' })
|
||||
let url = window.URL.createObjectURL(blob)
|
||||
})
|
||||
}
|
||||
await store.dispatch('user/getInfo')
|
||||
// 获取用户信息
|
||||
// 根据角色生成可访问的路线图
|
||||
const accessRoutes = await store.dispatch('permission/generateRoutes')
|
||||
// 动态添加可访问的路由
|
||||
setTimeout(() => {
|
||||
router.addRoutes(accessRoutes)
|
||||
if (response.code === 'A0000') {
|
||||
// 如果登录成功
|
||||
loginjmForm.verifyCode = 0
|
||||
// 重置验证码
|
||||
SysConfig()
|
||||
// 调用 SysConfig 函数进行系统配置
|
||||
// cgyList.indexOf(to.path) !== -1
|
||||
store.dispatch('user/getmenu').then(async response => {
|
||||
await getmuen(response.data[0])
|
||||
|
||||
router.push({
|
||||
path: cgyList.indexOf(to.path) !== -1 ? to.path : to.path //routerPath
|
||||
})
|
||||
})
|
||||
}
|
||||
next()
|
||||
|
||||
if (process.env.VUE_APP_KEY == 'scqr') {
|
||||
flag = true
|
||||
next(to.path)
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
}, 500)
|
||||
})
|
||||
.catch(error => {
|
||||
@@ -195,7 +293,12 @@ async function proceed(to, from, next, HB_NAME) {
|
||||
})
|
||||
})
|
||||
} else {
|
||||
next()
|
||||
if (process.env.VUE_APP_KEY == 'scqr') {
|
||||
flag = true
|
||||
next(to.path)
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -86,6 +86,37 @@ export const constantRoutes = [
|
||||
component: () => import('@/views/cgy-harmonic-boot/UPHomePage'),
|
||||
meta: { title: '信息概览', icon: 'user' }
|
||||
},
|
||||
// 生产管控
|
||||
{
|
||||
path: '/harmonicWave/pointmonitoring',
|
||||
name: 'pointmonitoring',
|
||||
component: () => import('@/views/cgy-harmonic-boot/line/pointmonitoring'),
|
||||
meta: { title: '详细数据', icon: '' }
|
||||
},
|
||||
{
|
||||
path: '/harmonicWave/regionalmonitoring',
|
||||
name: 'regionalmonitoring',
|
||||
component: () => import('@/views/cgy-harmonic-boot/region/regionalmonitoring'),
|
||||
meta: { title: '告警统计', icon: '' }
|
||||
},
|
||||
{
|
||||
path: '/harmonicWave/comprehensiveanalysis',
|
||||
name: 'comprehensiveanalysis',
|
||||
component: () => import('@/views/cgy-harmonic-boot/comper/comprehensiveanalysis'),
|
||||
meta: { title: '综合分析', icon: '' }
|
||||
},
|
||||
{
|
||||
path: '/harmonicWave/CVT',
|
||||
name: 'CVT',
|
||||
component: () => import('@/views/cgy-harmonic-boot/CVT'),
|
||||
meta: { title: 'CVT台账管理', icon: '' }
|
||||
},
|
||||
{
|
||||
path: '/harmonicWave/homePage',
|
||||
name: 'homePage',
|
||||
component: () => import('@/views/cgy-harmonic-boot/UPHomePage'),
|
||||
meta: { title: '信息概览', icon: 'user' }
|
||||
},
|
||||
|
||||
// 冀北嵌入
|
||||
{
|
||||
@@ -192,9 +223,9 @@ export const asyncRoutes = [
|
||||
path: '/dashboard/index',
|
||||
name: 'index',
|
||||
component: () =>
|
||||
// import ("@/views/dashboard/index"),
|
||||
import('@/views/harmonic-boot/detailed/qypowerpollutionzs'),
|
||||
//import('@/views/energy-system/operationalCenter/airManageReadOnly.vue'),
|
||||
import ("@/views/dashboard/index"),
|
||||
// import('@/views/harmonic-boot/detailed/qypowerpollutionzs'),
|
||||
// import('@/views/energy-system/operationalCenter/airManageReadOnly.vue'),
|
||||
meta: { title: '首页概览', icon: '', affix: true }
|
||||
},
|
||||
{
|
||||
|
||||
@@ -7,10 +7,11 @@ import { CodeSr } from '@/api/user'
|
||||
axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8'
|
||||
|
||||
const service = axios.create({
|
||||
// baseURL: '/harmonicWaveApi',//超高压生产嵌入
|
||||
// baseURL: '/PMS3/Application/third/aqcp-dnzl/harmonicWaveApi',//河北嵌入
|
||||
baseURL: '/api',
|
||||
timeout: 150000
|
||||
})
|
||||
|
||||
// service.interceptors.request.use(
|
||||
// config => {
|
||||
// if(config.url !=='/pqs-oauth2/oauth/token' || config.params.grant_type=='refresh_token'){
|
||||
|
||||
@@ -615,21 +615,24 @@ export default {
|
||||
//台区台账表头
|
||||
tableHeaderMonitoring: [
|
||||
// { prop: 'id', label: '监测点编号', width: 120 },
|
||||
{ prop: 'monitorObjectName', label: '监测对象名称', width: 250 },
|
||||
|
||||
{ prop: 'name', label: '测点名称', width: 220 },
|
||||
{ prop: 'monitorId', label: '测点编号', width: 220 },
|
||||
{ prop: 'orgName', label: '组织机构名称', width: 170 },
|
||||
{ prop: 'operationName', label: '运维单位名称', width: 170 },
|
||||
{ prop: 'midStation', label: '变电站编号', width: 150 },
|
||||
{ prop: 'powerrName', label: '变电站名称', width: 120 },
|
||||
//{ prop: "generatrixName", label: "母线名称", width: 120 },
|
||||
{ prop: 'busId', label: '母线编号', width: 180 },
|
||||
{ prop: 'lineName', label: '母线名称', width: 180 },
|
||||
// { prop: "lineId", label: "监测线路ID", width: 180 },
|
||||
{ prop: "lineNum", label: "装置接线序号", width: 180 },
|
||||
{ prop: 'voltageLevel', label: '电压等级', width: 100 },
|
||||
{ prop: 'monitorState', label: '监测点状态', width: 120 },
|
||||
{ prop: 'monitorObjectName', label: '监测对象名称', width: 250 },
|
||||
{ prop: 'monitorType', label: '监测点类型', width: 120 },
|
||||
{ prop: 'minShortCircuitCapacity', label: '最小短路容量', width: 120 },
|
||||
{ prop: 'powerSupplyEqCapacity', label: '供电设备容量', width: 120 },
|
||||
{ prop: 'userAgreementCapacity', label: '用户协议容量', width: 120 },
|
||||
{ prop: 'putDate', label: '投运日期', width: 120 },
|
||||
{
|
||||
prop: 'voltageDeviationUpperLimit',
|
||||
label: '电压偏差限值(上)',
|
||||
@@ -1384,7 +1387,7 @@ export default {
|
||||
form.pageSize = this.total
|
||||
getAllMonitorPageList(form).then(res => {
|
||||
this.$refs.Monitoringpoint.exportData({
|
||||
filename: '监测点台账', // 文件名字
|
||||
filename: '监测点台账'+new Date().getTime(), // 文件名字
|
||||
sheetName: 'Sheet1',
|
||||
type: 'xlsx', //导出文件类型 xlsx 和 csv
|
||||
useStyle: true,
|
||||
|
||||
@@ -88,7 +88,7 @@ export default {
|
||||
{ prop: 'effectiveAccessRate', label: '有效接入率(%)' },
|
||||
{ prop: 'dataIntegrityRate', label: '数据完整率(%)' },
|
||||
{ prop: 'indexIntegrityRate', label: '指标完整率(%)' },
|
||||
{ prop: 'isUnusual', label: '数据是否异常' }
|
||||
{ prop: 'isUnusual', label: '异常监测点数' }
|
||||
],
|
||||
qualitystatisticsData: [],
|
||||
device: '',
|
||||
@@ -154,13 +154,13 @@ export default {
|
||||
//判断数据是否异常
|
||||
cellStyle(row) {
|
||||
console.log(row)
|
||||
if (row.columnIndex == 6) {
|
||||
if (row.row.isUnusual == 0) {
|
||||
row.row.isUnusual = '正常 '
|
||||
} else if (row.row.isUnusual == 1) {
|
||||
row.row.isUnusual = '异常'
|
||||
}
|
||||
}
|
||||
// if (row.columnIndex == 6) {
|
||||
// if (row.row.isUnusual == 0) {
|
||||
// row.row.isUnusual = '正常 '
|
||||
// } else if (row.row.isUnusual == 1) {
|
||||
// row.row.isUnusual = '异常'
|
||||
// }
|
||||
// }
|
||||
},
|
||||
//导出
|
||||
exportEvent() {
|
||||
|
||||
@@ -2024,12 +2024,22 @@ export default {
|
||||
this.$refs.ruleform.validate(value => {
|
||||
// console.log(value);
|
||||
if (value == true) {
|
||||
if(this.ruleform.ifReleaseWarning == 1){
|
||||
//需要提示预告警单不能为空
|
||||
if(this.ruleform.workAlarmId == null || this.ruleform.workAlarmId == ''){
|
||||
this.$message.warning("关联告预警单不可为空!");
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
this.$confirm('是否确认新增?', '提示', {
|
||||
confirmButtonText: '确定',
|
||||
cancelButtonText: '取消',
|
||||
type: 'warning'
|
||||
})
|
||||
.then(() => {
|
||||
|
||||
|
||||
addProblem(this.ruleform).then(res => {
|
||||
if (res.code == 'A0000') {
|
||||
this.$message({
|
||||
@@ -2194,6 +2204,14 @@ export default {
|
||||
this.$refs.ruleform.validate(value => {
|
||||
// console.log(value);
|
||||
if (value == true) {
|
||||
if(this.ruleform.ifReleaseWarning == 1){
|
||||
//需要提示预告警单不能为空
|
||||
if(this.ruleform.workAlarmId == null || this.ruleform.workAlarmId == ''){
|
||||
this.$message.warning("关联告预警单不可为空!");
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
this.$confirm('是否确认修改?', '提示', {
|
||||
confirmButtonText: '确定',
|
||||
cancelButtonText: '取消',
|
||||
|
||||
@@ -29,7 +29,7 @@
|
||||
<el-col :span="24">
|
||||
<div class="button" style="float: left">
|
||||
<el-button type="primary" icon="el-icon-circle-plus" @click="planAdditionFn">新增计划</el-button>
|
||||
<el-button type="primary" icon="el-icon-s-claim" @click="planReviewFn">提交审核</el-button>
|
||||
<!-- <el-button type="primary" icon="el-icon-s-claim" @click="planReviewFn">提交审核</el-button>-->
|
||||
</div>
|
||||
<div class="button">
|
||||
|
||||
@@ -667,7 +667,7 @@ export default {
|
||||
|
||||
//获取审核人列表
|
||||
getAuditUser() {
|
||||
let param = {roleType: 3}
|
||||
let param = {roleType: 1}
|
||||
getAuditUser(param).then(res => {
|
||||
if (res && res.code === 'A0000') {
|
||||
this.auditUserList = res.data
|
||||
|
||||
@@ -1195,7 +1195,7 @@ export default {
|
||||
|
||||
//获取审核人列表
|
||||
getAuditUser() {
|
||||
let param = {roleType: 3}
|
||||
let param = {roleType: 1}
|
||||
getAuditUser(param).then(res => {
|
||||
if (res && res.code === 'A0000') {
|
||||
this.auditUserList = res.data
|
||||
|
||||
@@ -6,9 +6,9 @@
|
||||
<el-tab-pane label="普测计划管理" name="1" :style="'height:' + vh + 'px;'">
|
||||
<Planmanagement v-if="activeName == '1'"></Planmanagement>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="普测计划审批" name="2" :style="'height:' + vh + 'px;'">
|
||||
<!-- <el-tab-pane label="普测计划审批" name="2" :style="'height:' + vh + 'px;'">
|
||||
<Planapproval v-if="activeName == '2'" ref="planapprovalRef" :son="planId"></Planapproval>
|
||||
</el-tab-pane>
|
||||
</el-tab-pane>-->
|
||||
<!-- <el-tab-pane label="普测结果管理" name="3" :style="'height:' + vh + 'px;'">
|
||||
<Resultsmanagement v-if="activeName == '3'"></Resultsmanagement>
|
||||
</el-tab-pane>
|
||||
|
||||
@@ -35,13 +35,13 @@
|
||||
<influence v-if="activeName == '4'"></influence>
|
||||
</el-tab-pane>
|
||||
|
||||
<!-- <el-tab-pane
|
||||
<el-tab-pane
|
||||
label="详细数据表"
|
||||
name="5"
|
||||
:style="'height:' + vh + ';'"
|
||||
>
|
||||
<dataSheet v-if="activeName == '5'"></dataSheet>
|
||||
</el-tab-pane> -->
|
||||
</el-tab-pane>
|
||||
</el-tabs>
|
||||
</el-col>
|
||||
</el-row>
|
||||
|
||||
@@ -539,7 +539,7 @@ export default {
|
||||
}
|
||||
option1 = {
|
||||
title: {
|
||||
text: '变电站稳态超标数量',
|
||||
text: '变电站暂态超标数量',
|
||||
left: 'center',
|
||||
top: 10
|
||||
},
|
||||
@@ -777,7 +777,7 @@ export default {
|
||||
}
|
||||
option2 = {
|
||||
title: {
|
||||
text: '变电站稳态超标天数',
|
||||
text: '变电站暂态超标天数',
|
||||
left: 'center',
|
||||
top: 20
|
||||
},
|
||||
|
||||
@@ -38,11 +38,7 @@
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<timeindex
|
||||
:id="id"
|
||||
ref="fff"
|
||||
:interval="interval"
|
||||
></timeindex>
|
||||
<timeindex :id="id" ref="fff" :interval="interval" :pushForward="true"></timeindex>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button type="primary" @click="querfromdata" icon="el-icon-search">查询</el-button>
|
||||
@@ -93,7 +89,7 @@
|
||||
<template slot-scope="scope">
|
||||
<span>
|
||||
{{
|
||||
scope.row.number
|
||||
scope.row.number
|
||||
? scope.row.number + `次 ` + scope.row.targetName
|
||||
: scope.row.targetName
|
||||
}}
|
||||
@@ -235,7 +231,7 @@
|
||||
<script>
|
||||
import { getheight } from '../../assets/commjs/common'
|
||||
import { A, B, C, AB, BC, CA } from '../../assets/commjs/color'
|
||||
import timeindex from'@/views/cgy-components/cgytree/TimeintervalTemplat.vue'
|
||||
import timeindex from '@/views/cgy-components/cgytree/TimeintervalTemplat.vue'
|
||||
import pagination from '@/views/cgy-components/pagination/index'
|
||||
import api from '@/api/harmonic/onlineData'
|
||||
import FileSaver from 'file-saver'
|
||||
@@ -351,7 +347,7 @@ export default {
|
||||
searchBeginTime: '',
|
||||
searchEndTime: ''
|
||||
},
|
||||
interval: 4,
|
||||
interval: 5,
|
||||
device: 1,
|
||||
limit: 8,
|
||||
limit2: 8,
|
||||
@@ -554,6 +550,8 @@ export default {
|
||||
},
|
||||
mounted() {
|
||||
this.vh = window.sessionStorage.getItem('appheight') - 120
|
||||
this.$refs.fff.buttonShow=false
|
||||
this.$refs.fff.interchange(5)
|
||||
this.querfromdata()
|
||||
},
|
||||
methods: {
|
||||
@@ -693,12 +691,10 @@ export default {
|
||||
|
||||
// this.formData.searchBeginTime = this.$refs.fff.timeValue[0];
|
||||
// this.formData.searchEndTime = this.$refs.fff.timeValue[1];
|
||||
this.formData.searchBeginTime =this.$refs.fff.intervald == 5
|
||||
? this.$refs.fff.DayTime
|
||||
: this.$refs.fff.timeValue[0]
|
||||
this.formData.searchEndTime =this.$refs.fff.intervald == 5
|
||||
? this.$refs.fff.DayTime
|
||||
: this.$refs.fff.timeValue[1]
|
||||
this.formData.searchBeginTime =
|
||||
this.$refs.fff.intervald == 5 ? this.$refs.fff.DayTime : this.$refs.fff.timeValue[0]
|
||||
this.formData.searchEndTime =
|
||||
this.$refs.fff.intervald == 5 ? this.$refs.fff.DayTime : this.$refs.fff.timeValue[1]
|
||||
this.formData.condition = this.value
|
||||
this.formData.inHarmonics = this.inharmonic
|
||||
if (this.number == 111) {
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -25,7 +25,9 @@ export default {
|
||||
},
|
||||
created() {
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
this.guanzhou()
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
}
|
||||
},
|
||||
mounted() {},
|
||||
|
||||
@@ -335,7 +335,9 @@ export default {
|
||||
},
|
||||
created() {
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
this.guanzhou()
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
}
|
||||
this.getIndexType()
|
||||
//this.time()
|
||||
|
||||
@@ -31,7 +31,9 @@ export default {
|
||||
},
|
||||
created() {
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
this.guanzhou()
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
|
||||
@@ -1,73 +1,75 @@
|
||||
<template>
|
||||
<div class="pa10">
|
||||
<el-tabs type="border-card" v-model="activeName" @tab-click="handleClick" style="height:calc(100vh - 20px)">
|
||||
<el-tab-pane label="监测点数据查询" name="first">
|
||||
<onlineData ></onlineData>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="监测点台账信息" name="second">
|
||||
<devicemessage ></devicemessage>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="终端台账信息" name="third">
|
||||
<terminalmessage > </terminalmessage>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="数据完整性统计" name="sen">
|
||||
<integralitytable ></integralitytable>
|
||||
</el-tab-pane>
|
||||
</el-tabs>
|
||||
</div>
|
||||
<div class="pa10">
|
||||
<el-tabs type="border-card" v-model="activeName" @tab-click="handleClick" style="height: calc(100vh - 20px)">
|
||||
<el-tab-pane label="监测点数据查询" name="first">
|
||||
<onlineData></onlineData>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="监测点台账信息" name="second">
|
||||
<devicemessage></devicemessage>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="终端台账信息" name="third">
|
||||
<terminalmessage></terminalmessage>
|
||||
</el-tab-pane>
|
||||
<el-tab-pane label="数据完整性统计" name="sen">
|
||||
<integralitytable></integralitytable>
|
||||
</el-tab-pane>
|
||||
</el-tabs>
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import onlineData from "@/views/cgy-harmonic-boot/monitor/onlineData";
|
||||
import terminalmessage from "@/views/cgy-harmonic-boot/runmange/terminalmessage";
|
||||
import devicemessage from "@/views/cgy-harmonic-boot/runmange/devicemessage";
|
||||
import integralitytable from "@/views/cgy-harmonic-boot/area/integralitytable";
|
||||
import onlineData from '@/views/cgy-harmonic-boot/monitor/onlineData'
|
||||
import terminalmessage from '@/views/cgy-harmonic-boot/runmange/terminalmessage'
|
||||
import devicemessage from '@/views/cgy-harmonic-boot/runmange/devicemessage'
|
||||
import integralitytable from '@/views/cgy-harmonic-boot/area/integralitytable'
|
||||
import api1 from '@/api/pollution/pollution'
|
||||
export default {
|
||||
components: {
|
||||
onlineData,
|
||||
devicemessage,
|
||||
terminalmessage,
|
||||
integralitytable,
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
activeName:'first',
|
||||
vh:null
|
||||
};
|
||||
},
|
||||
created() {
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.vh = window.sessionStorage.getItem('appheight')-12+'px'
|
||||
},
|
||||
methods: {
|
||||
guanzhou(){
|
||||
var data ={
|
||||
token:this.$route.query.token
|
||||
}
|
||||
api1.guanzhou(data).then(res=>{
|
||||
if(res.code=='A0000'){
|
||||
return
|
||||
}else{
|
||||
this.$router.push('/error/massege/403')
|
||||
}
|
||||
})
|
||||
},
|
||||
handleClick(tab, event) {
|
||||
// console.log(tab, event);
|
||||
this.activeName = tab.name
|
||||
}
|
||||
},
|
||||
};
|
||||
</script>
|
||||
components: {
|
||||
onlineData,
|
||||
devicemessage,
|
||||
terminalmessage,
|
||||
integralitytable
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
activeName: 'first',
|
||||
vh: null
|
||||
}
|
||||
},
|
||||
created() {
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.vh = window.sessionStorage.getItem('appheight') - 12 + 'px'
|
||||
},
|
||||
methods: {
|
||||
guanzhou() {
|
||||
var data = {
|
||||
token: this.$route.query.token
|
||||
}
|
||||
api1.guanzhou(data).then(res => {
|
||||
if (res.code == 'A0000') {
|
||||
return
|
||||
} else {
|
||||
this.$router.push('/error/massege/403')
|
||||
}
|
||||
})
|
||||
},
|
||||
handleClick(tab, event) {
|
||||
// console.log(tab, event);
|
||||
this.activeName = tab.name
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style lang="less" scoped>
|
||||
.pa10 {
|
||||
padding: 10px;
|
||||
padding: 10px;
|
||||
}
|
||||
::v-deep .el-tabs--border-card>.el-tabs__content {
|
||||
::v-deep .el-tabs--border-card > .el-tabs__content {
|
||||
padding: 10px;
|
||||
}
|
||||
</style>
|
||||
|
||||
@@ -37,7 +37,10 @@ export default {
|
||||
},
|
||||
created() {
|
||||
if (process.env.VUE_APP_MODE === 'cgyqr') {
|
||||
this.guanzhou()
|
||||
// this.guanzhou()
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
}
|
||||
},
|
||||
mounted() {},
|
||||
|
||||
@@ -202,14 +202,14 @@
|
||||
type="danger"
|
||||
size="small"
|
||||
v-if="scope.row.type === 1"
|
||||
style="color: red"
|
||||
style="color: #008000"
|
||||
>开机策略</el-tag
|
||||
>
|
||||
<el-tag
|
||||
type="primary"
|
||||
size="small"
|
||||
v-if="scope.row.type === 2"
|
||||
style="color: green"
|
||||
style="color: #991717"
|
||||
>关机策略</el-tag
|
||||
>
|
||||
</template>
|
||||
@@ -256,24 +256,24 @@
|
||||
}}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column
|
||||
width="150"
|
||||
align="center"
|
||||
prop="wind"
|
||||
label="状态"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
<span type="primary" size="small">{{
|
||||
statusGet(scope.row.status)
|
||||
}}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<!-- <el-table-column align="center" prop="sjfw" label="涉及范围" >
|
||||
<template slot-scope="scope">
|
||||
<el-button v-if="scope.row.sjfw==0" @click="confingview(scope.row)" type="primary" size="mini">配置</el-button>
|
||||
<el-button v-if="scope.row.sjfw==1" type="primary" size="mini">查看</el-button>
|
||||
</template>
|
||||
</el-table-column> -->
|
||||
<!-- <el-table-column
|
||||
width="150"
|
||||
align="center"
|
||||
prop="wind"
|
||||
label="状态"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
<span type="primary" size="small">{{
|
||||
statusGet(scope.row.status)
|
||||
}}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column align="center" prop="sjfw" label="涉及范围" >
|
||||
<template slot-scope="scope">
|
||||
<el-button v-if="scope.row.sjfw==0" @click="confingview(scope.row)" type="primary" size="mini">配置</el-button>
|
||||
<el-button v-if="scope.row.sjfw==1" type="primary" size="mini">查看</el-button>
|
||||
</template>
|
||||
</el-table-column> -->
|
||||
<el-table-column align="center" prop="caozuo" label="操作">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
@@ -283,12 +283,18 @@
|
||||
>查看</el-button
|
||||
>
|
||||
<el-button
|
||||
v-if="scope.row.status === 0"
|
||||
type="primary"
|
||||
size="mini"
|
||||
@click="edit(scope.row.id)"
|
||||
>修改</el-button
|
||||
>
|
||||
<el-button
|
||||
v-if="scope.row.status === 1"
|
||||
type="primary"
|
||||
@click="stopAirStrategy(scope.row.id)"
|
||||
size="mini"
|
||||
>停止</el-button
|
||||
>
|
||||
<!-- <el-button
|
||||
v-if="scope.row.status !== 1"
|
||||
type="primary"
|
||||
@@ -303,20 +309,14 @@
|
||||
size="mini"
|
||||
>执行</el-button
|
||||
>
|
||||
<el-button
|
||||
v-if="scope.row.status === 1"
|
||||
type="primary"
|
||||
@click="stopAirStrategy(scope.row.id)"
|
||||
size="mini"
|
||||
>停止</el-button
|
||||
>-->
|
||||
|
||||
<el-button
|
||||
v-if="scope.row.status === 2"
|
||||
@click="querydata(scope.row)"
|
||||
type="primary"
|
||||
size="mini"
|
||||
>趋势查看
|
||||
</el-button>
|
||||
</el-button>-->
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
@@ -1330,64 +1330,7 @@ export default {
|
||||
this.get_bodyHeight();
|
||||
this.connectMqtt();
|
||||
|
||||
this.globalMqtt.ws.on("connect", (e) => {
|
||||
this.$message.success("连接mqtt服务器成功!");
|
||||
console.log("mqtt客户端已连接....");
|
||||
this.globalMqtt.ws.subscribe("/platform/devack/#");
|
||||
});
|
||||
|
||||
this.globalMqtt.ws.on("error", (error) => {
|
||||
console.log("mqtt连接失败...", error);
|
||||
this.mqtt.end();
|
||||
});
|
||||
|
||||
this.globalMqtt.ws.on("close", function () {
|
||||
console.log("mqtt客户端已断开连接.....");
|
||||
});
|
||||
|
||||
let index = 0;
|
||||
this.globalMqtt.ws.on("message", (topic, message) => {
|
||||
let that = this;
|
||||
if (message) {
|
||||
let json = JSON.parse(message);
|
||||
if (json.code === 200) {
|
||||
if (json.param.action === "ACInMode") {
|
||||
this.$message.success("内机模式调节成功!");
|
||||
} else if (json.param.action === "ACInSpeed") {
|
||||
this.$message.success("内机风速调节成功!");
|
||||
} else if (json.param.action === "ACInSetTmp") {
|
||||
this.$message.success("内机温度调节成功!");
|
||||
} else if (json.param.action === "ACInStat") {
|
||||
this.$message.success("内机开关机操作成功!");
|
||||
} else {
|
||||
this.$message.success("操作成功!");
|
||||
}
|
||||
|
||||
window.setTimeout(function () {
|
||||
that.getStatisTemplateById();
|
||||
}, 10000);
|
||||
} else {
|
||||
this.$message.error(json.msg);
|
||||
if (this.userIndex === json.userId) {
|
||||
this.mqttSendCount++;
|
||||
if (this.mqttSendCount > 2) {
|
||||
return;
|
||||
} else {
|
||||
this.globalMqtt.ws.publish(
|
||||
"/platform/devcmd/v1/" + this.devInfo.ndid,
|
||||
JSON.stringify(this.mqttSendMsg)
|
||||
);
|
||||
}
|
||||
|
||||
console.log("错误+++进行重发" + this.mqttSendCount);
|
||||
}
|
||||
}
|
||||
|
||||
this.buttonDisable = false;
|
||||
}
|
||||
|
||||
console.log("收到消息:" + topic + message);
|
||||
});
|
||||
|
||||
//如果别的页面路由过来的进行路由参数处理
|
||||
},
|
||||
@@ -1412,10 +1355,11 @@ export default {
|
||||
},
|
||||
methods: {
|
||||
connectMqtt() {
|
||||
this.globalMqtt.ws = {};
|
||||
let this_ = this
|
||||
this_.globalMqtt.ws = {};
|
||||
let mqttWs = null;
|
||||
|
||||
let userName = this.$store.state.user.userInfo.loginName;
|
||||
let userName = this_.$store.state.user.userInfo.loginName;
|
||||
const options = {
|
||||
qos: 2,
|
||||
clean: true,
|
||||
@@ -1424,9 +1368,69 @@ export default {
|
||||
username: "t_user",
|
||||
password: "njcnpqs",
|
||||
};
|
||||
const url = "wss://pqmcn.com:8087/mqtt";
|
||||
const url = "ws://192.168.1.24:8085/mqtt";
|
||||
mqttWs = mqtt.connect(url, options);
|
||||
this.globalMqtt.setWs(mqttWs);
|
||||
this_.globalMqtt.setWs(mqttWs);
|
||||
|
||||
|
||||
this_.globalMqtt.ws.on("connect", (e) => {
|
||||
this_.$message.success("连接mqtt服务器成功!");
|
||||
console.log("mqtt客户端已连接....");
|
||||
this_.globalMqtt.ws.subscribe("/platform/devack/#");
|
||||
});
|
||||
|
||||
this_.globalMqtt.ws.on("error", (error) => {
|
||||
console.log("mqtt连接失败...", error);
|
||||
this.mqtt.end();
|
||||
});
|
||||
|
||||
this_.globalMqtt.ws.on("close", function () {
|
||||
console.log("mqtt客户端已断开连接.....");
|
||||
});
|
||||
|
||||
|
||||
this_.globalMqtt.ws.on("message", (topic, message) => {
|
||||
let that = this;
|
||||
if (message) {
|
||||
let json = JSON.parse(message);
|
||||
if (json.code === 200) {
|
||||
if (json.param.action === "ACInMode") {
|
||||
this_.$message.success("内机模式调节成功!");
|
||||
} else if (json.param.action === "ACInSpeed") {
|
||||
this_.$message.success("内机风速调节成功!");
|
||||
} else if (json.param.action === "ACInSetTmp") {
|
||||
this_.$message.success("内机温度调节成功!");
|
||||
} else if (json.param.action === "ACInStat") {
|
||||
this_.$message.success("内机开关机操作成功!");
|
||||
} else {
|
||||
this_.$message.success("操作成功!");
|
||||
}
|
||||
|
||||
window.setTimeout(function () {
|
||||
that.getStatisTemplateById();
|
||||
}, 10000);
|
||||
} else {
|
||||
this_.$message.error(json.msg);
|
||||
if (this_.userIndex === json.userId) {
|
||||
this_.mqttSendCount++;
|
||||
if (this_.mqttSendCount > 2) {
|
||||
return;
|
||||
} else {
|
||||
this_.globalMqtt.ws.publish(
|
||||
"/platform/devcmd/v1/" + this.devInfo.ndid,
|
||||
JSON.stringify(this.mqttSendMsg)
|
||||
);
|
||||
}
|
||||
|
||||
console.log("错误+++进行重发" + this.mqttSendCount);
|
||||
}
|
||||
}
|
||||
|
||||
this_.buttonDisable = false;
|
||||
}
|
||||
|
||||
console.log("收到消息:" + topic + message);
|
||||
});
|
||||
},
|
||||
//子节点树点击事件
|
||||
getTreeText(data, level) {
|
||||
@@ -1694,7 +1698,7 @@ export default {
|
||||
},
|
||||
|
||||
querfromdata(data, timehbValue, type, interval) {
|
||||
|
||||
|
||||
this.interval = interval;
|
||||
this.timeRange = data;
|
||||
if (type == 1) {
|
||||
@@ -2009,7 +2013,7 @@ window.echartsArr.push(myChart);
|
||||
switchChange(item, type) {
|
||||
console.log(item);
|
||||
console.log(type);
|
||||
console.log(this.devInfo.ndid);
|
||||
|
||||
|
||||
let msg = {
|
||||
mid: 1,
|
||||
@@ -2025,10 +2029,14 @@ window.echartsArr.push(myChart);
|
||||
},
|
||||
};
|
||||
|
||||
this.globalMqtt.ws.publish(
|
||||
"/platform/devcmd/v1/" + this.devInfo.ndid,
|
||||
JSON.stringify(msg)
|
||||
);
|
||||
let topic = "/platform/devcmd/v1/" + this.devInfo.ndid;
|
||||
console.log(topic);
|
||||
this.globalMqtt.ws.publish(topic, JSON.stringify(msg), { qos: 0 }, (err) => {
|
||||
if (err) console.error("发送失败:", err);
|
||||
else console.log("发送成功");
|
||||
})
|
||||
|
||||
|
||||
|
||||
this.mqttSendMsg = msg;
|
||||
this.mqttSendCount = 0;
|
||||
|
||||
@@ -264,7 +264,7 @@ export default {
|
||||
|
||||
//获取审核人列表
|
||||
getAuditUser() {
|
||||
let param = {roleType: 3}
|
||||
let param = {roleType: 1}
|
||||
getAuditUser(param).then(res => {
|
||||
if (res && res.code === 'A0000') {
|
||||
this.auditUserList = res.data
|
||||
|
||||
@@ -51,7 +51,9 @@ export default {
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.guanzhou()
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
|
||||
|
||||
@@ -69,7 +69,7 @@
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item style="float: right;margin-right: 50px">
|
||||
<el-button :disabled="store.params.dataType === '01'" type="primary" @click="reCalUpload(activeName)">
|
||||
<el-button :disabled="store.params.dataType === '01'" type="primary" @click="reCalUpload('1')">
|
||||
{{ storeList[activeName].label + '重新计算' }}
|
||||
</el-button>
|
||||
</el-form-item>
|
||||
@@ -605,7 +605,7 @@ export default {
|
||||
let dateMonth = this.store.params.searchBeginTime.substring(0, 7)
|
||||
//月
|
||||
request
|
||||
.get('/prepare-boot/dimGlobal/reCalMonthUploadAlgorithm?statisticDate=' + dateMonth + '&type=' + type)
|
||||
.get('/prepare-boot/dimGlobal/reCalMonthUploadAlgorithm?statisticDate=' + dateMonth + '&type=1')
|
||||
.then(res => {
|
||||
if (res && res.code === 'A0000') {
|
||||
this.$message({
|
||||
@@ -617,7 +617,7 @@ export default {
|
||||
})
|
||||
} else {
|
||||
request
|
||||
.get('/prepare-boot/dimGlobal/reCalUploadAlgorithm?statisticDate=' + this.store.params.searchBeginTime + '&type=' + type)
|
||||
.get('/prepare-boot/dimGlobal/reCalUploadAlgorithm?statisticDate=' + this.store.params.searchBeginTime + '&type=1')
|
||||
.then(res => {
|
||||
if (res && res.code === 'A0000') {
|
||||
this.$message({
|
||||
|
||||
@@ -48,7 +48,9 @@ export default {
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.guanzhou()
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.setHeight()
|
||||
|
||||
@@ -75,7 +75,9 @@ export default {
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.guanzhou();
|
||||
if (process.env.VUE_APP_KEY != 'scqr') {
|
||||
this.guanzhou()
|
||||
}
|
||||
},
|
||||
mounted() {},
|
||||
methods: {
|
||||
|
||||
@@ -10,7 +10,7 @@
|
||||
<el-button @click="queryData()" type="primary" size="mini" style="margin-left:1%;" icon="el-icon-search">查询</el-button> -->
|
||||
<el-form :inline="true" :model="form" class="demo-form-inline">
|
||||
<el-form-item>
|
||||
<el-button @click="AddTypeClick" type="primary" icon="el-icon-plus">新增字典类型</el-button>
|
||||
<el-button @click="AddTypeClick" type="primary" icon="el-icon-plus">新增字典树类型</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<el-select
|
||||
|
||||
@@ -18,7 +18,7 @@ module.exports = {
|
||||
// publicPath: 'https://fuphoenixes.github.io/example/dist/',
|
||||
//publicPath: "./",
|
||||
// publicPath: process.env.VUE_APP_PATH,
|
||||
publicPath: process.env.NODE_ENV === 'development' ? './' : process.env.VUE_APP_MODE == 'jbqr' ? './' : '/',
|
||||
publicPath: './', //process.env.NODE_ENV === 'development' ? './' : process.env.VUE_APP_MODE == 'jbqr' ? './' : '/',
|
||||
outputDir: 'dist',
|
||||
assetsDir: 'static',
|
||||
// lintOnSave: process.env.NODE_ENV === 'development',
|
||||
@@ -37,9 +37,9 @@ module.exports = {
|
||||
'/api': {
|
||||
// target: 'http://18028358809.gnway.cc', //hsw
|
||||
// target: 'http://192.168.120.210:10215', //hsw
|
||||
target: 'http://192.168.1.29:10215', //超高压
|
||||
// target: 'http://192.168.1.28:10215', //超高压
|
||||
// target: "'https://pqmcn.com:8092/api", //治理
|
||||
// target: 'http://192.168.1.24:10215', // 河北
|
||||
target: 'http://192.168.1.24:10215', // 河北
|
||||
// target: "http://192.168.1.31:10215", // 海南
|
||||
// target: "http://192.168.1.29:10215", // 冀北
|
||||
changeOrigin: true,
|
||||
|
||||
Reference in New Issue
Block a user