1.飞行巡检和审核辅助页面中的对话框写成组件
2.增加了数据请求和异常分析配置参数的可视化页面
3.修改了站点输入框,使能够模糊匹配
| | |
| | | import axios from 'axios' |
| | | import { setInterceptors } from './config' |
| | | |
| | | // const url = 'http://localhost:8081/'; |
| | | const url = 'http://localhost:8081/' |
| | | // é¨ç½² |
| | | const url = 'http://114.215.109.124:8803/'; |
| | | // const url = 'http://114.215.109.124:8803/'; |
| | | // const url = 'http://192.168.0.123:8081/' |
| | | |
| | | //é£ç¾½ç管 |
| | |
| | | import { $http } from '@/api/index.js'; |
| | | import { $http } from '@/api/index.js' |
| | | |
| | | export default { |
| | | /** |
| | | * æäº¤ æ°æ®è·åçé
ç½®åæ°ä¿®æ¹ |
| | | * @paramï¼ é
置表对åºçåæ®µå¯¹è±¡ |
| | | * @returnsï¼ |
| | | */ |
| | | submitExceptionSetting(params){ |
| | | console.log('å¼å¸¸é
ç½®æäº¤çåæ°ä¸ºï¼',params); |
| | | return $http.post('/dust/requestSetting/modify',params) |
| | | } |
| | | /** |
| | | * æäº¤ æ°æ®è·åçé
ç½®åæ°ä¿®æ¹ |
| | | * @paramï¼ é
置表对åºçåæ®µå¯¹è±¡ |
| | | * @returnsï¼ |
| | | */ |
| | | submitExceptionSetting(params) { |
| | | return $http.post('/dust/exception/addSetting', params) |
| | | }, |
| | | |
| | | } |
| | | /** |
| | | * æ¥è¯¢å¼å¸¸æ°æ®é
ç½® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | queryExceptionSetting() { |
| | | return $http.get('/dust/exception/querySetting') |
| | | }, |
| | | |
| | | /** |
| | | * æäº¤ æ°æ®è·åçé
ç½®åæ°ä¿®æ¹ |
| | | * @paramï¼ é
置表对åºçåæ®µå¯¹è±¡ |
| | | * @returnsï¼ |
| | | */ |
| | | alertExceptionSetting(params) { |
| | | return $http.post('/dust/exception/alertSetting', params) |
| | | }, |
| | | |
| | | /** |
| | | * æ¥è¯¢æ°æ®è¯·æ±çé»è®¤é
ç½® 1.0çæ¬ |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | queryDefaultSetting() { |
| | | return $http.get('/dust/exception/byVersion', { params: { version: '1.0' } }) |
| | | } |
| | | } |
| | |
| | | import { $http } from '@/api/index.js'; |
| | | import { $http } from '@/api/index.js' |
| | | |
| | | export default { |
| | | /** |
| | | * æäº¤ æ°æ®è·åçé
ç½®åæ°ä¿®æ¹ |
| | | * @paramï¼ é
置表对åºçåæ®µå¯¹è±¡ |
| | | * @returnsï¼ |
| | | */ |
| | | submitRequestSetting(params){ |
| | | console.log('请æ±é
ç½®æäº¤çåæ°ä¸ºï¼',params); |
| | | // return $http.post('/dust/requestSetting/modify',params) |
| | | } |
| | | /** |
| | | * æäº¤ æ°æ®è·åçé
ç½®åæ°ä¿®æ¹ |
| | | * @paramï¼ é
置表对åºçåæ®µå¯¹è±¡ |
| | | * @returnsï¼ |
| | | */ |
| | | submitRequestSetting(params) { |
| | | return $http.post('/dust/request/addSetting', params) |
| | | }, |
| | | |
| | | } |
| | | /** |
| | | * æ¥è¯¢æ°æ®è¯·æ±é
ç½® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | queryRequestSetting() { |
| | | return $http.get('/dust/request/querySetting') |
| | | }, |
| | | |
| | | |
| | | /** |
| | | * æäº¤ æ°æ®è·åçé
ç½®åæ°ä¿®æ¹ |
| | | * @paramï¼ é
置表对åºçåæ®µå¯¹è±¡ |
| | | * @returnsï¼ |
| | | */ |
| | | alertRequestSetting(params) { |
| | | return $http.post('/dust/request/alertSetting', params) |
| | | }, |
| | | |
| | | |
| | | /** |
| | | * æ¥è¯¢æ°æ®è¯·æ±çé»è®¤é
ç½® 1.0çæ¬ |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | queryDefaultSetting(){ |
| | | return $http.get('/dust/request/byVersion',{params:{version:'1.0'}}) |
| | | } |
| | | |
| | | |
| | | |
| | | } |
| | | |
| | | |
| | | |
| | |
| | | 1代表éè¦é»è®¤å¼ ï¼0代表ä¸éè¦é»è®¤å¼ |
| | | --> |
| | | |
| | | |
| | | |
| | | <script> |
| | | import exceptionApi from '@/api/exceptionApi.js'; |
| | | import exceptionApi from '@/api/exceptionApi.js' |
| | | export default { |
| | | props: { |
| | | // 0代表ä¸éè¦é»è®¤å¼ï¼1代表éè¦é»è®¤å¼ |
| | |
| | | default: '0' |
| | | }, |
| | | // 0代表ä¸éè¦ï¼1ä»£è¡¨æ ¹æ®æ¶æ®µåå¼å¸¸æ¥ç»åºè¾å
¥å»ºè®® |
| | | isNeedRealTimeAdvice:{ |
| | | type:String, |
| | | default:'0' |
| | | isNeedRealTimeAdvice: { |
| | | type: String, |
| | | default: '0' |
| | | }, |
| | | exceptionType:{ |
| | | type:Array, |
| | | default:()=>{ |
| | | exceptionType: { |
| | | type: Array, |
| | | default: () => { |
| | | return [] |
| | | } |
| | | }, |
| | | beginTime:{ |
| | | type:String, |
| | | default:'' |
| | | beginTime: { |
| | | type: String, |
| | | default: '' |
| | | }, |
| | | endTime:{ |
| | | type:String, |
| | | default:'' |
| | | endTime: { |
| | | type: String, |
| | | default: '' |
| | | }, |
| | | siteName:{ |
| | | type:String, |
| | | default:'-1' |
| | | siteName: { |
| | | type: String, |
| | | default: '-1' |
| | | } |
| | | }, |
| | | emits: ['submitValue', 'submitSiteNums','submitMncode'], |
| | | emits: ['submitValue', 'submitSiteNums', 'submitMncode'], |
| | | data() { |
| | | return { |
| | | // ç¨æ·éä¸çå¼ |
| | |
| | | // ä¿åè¾å
¥å»ºè®®çç«ç¹åç§° |
| | | siteNames: [], |
| | | // ä¿åè¾å
¥å»ºè®®çç«ç¹è®¾å¤ç¼å· |
| | | siteNamesAndMnCode:[] |
| | | siteNamesAndMnCode: [] |
| | | } |
| | | }, |
| | | watch:{ |
| | | beginTime(val,oldVal){ |
| | | |
| | | if(this.isNeedRealTimeAdvice =='1' && oldVal != ''){ |
| | | exceptionApi.getExceptionName(this.exceptionType,this.beginTime,this.endTime).then( res=>{ |
| | | this.siteNames = [] |
| | | const sites = res.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | watch: { |
| | | beginTime(val, oldVal) { |
| | | if (this.isNeedRealTimeAdvice == '1' && oldVal != '') { |
| | | exceptionApi |
| | | .getExceptionName(this.exceptionType, this.beginTime, this.endTime) |
| | | .then((res) => { |
| | | this.siteNames = [] |
| | | const sites = res.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | }) |
| | | }) |
| | | }) |
| | | } |
| | | }, |
| | | exceptionType(){ |
| | | if(this.isNeedRealTimeAdvice =='1' ){ |
| | | exceptionApi.getExceptionName(this.exceptionType,this.beginTime,this.endTime).then( res=>{ |
| | | this.siteNames = [] |
| | | const sites = res.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | exceptionType() { |
| | | if (this.isNeedRealTimeAdvice == '1') { |
| | | exceptionApi |
| | | .getExceptionName(this.exceptionType, this.beginTime, this.endTime) |
| | | .then((res) => { |
| | | this.siteNames = [] |
| | | const sites = res.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | }) |
| | | }) |
| | | }) |
| | | } |
| | | }, |
| | | siteName(){ |
| | | if(this.siteName != '-1' && this.siteName != ''){ |
| | | siteName() { |
| | | if (this.siteName != '-1' && this.siteName != '') { |
| | | this.state = this.siteName |
| | | this.$emit('submitValue', this.state) |
| | | } |
| | | }, |
| | | state(){ |
| | | if(this.state != '' && this.state != null){ |
| | | state() { |
| | | if (this.state != '' && this.state != null) { |
| | | // æ¥æ¾å¯¹åºç设å¤ç¼å· |
| | | this.onSiteNameSelected(this.state) |
| | | } |
| | |
| | | } |
| | | }, |
| | | methods: { |
| | | obscureMatch(a, b) { |
| | | const pattern = new RegExp(a, 'i') |
| | | // 'i' 表示ä¸åºå大å°å |
| | | return pattern.test(b) |
| | | }, |
| | | |
| | | querySearch(queryString, cb) { |
| | | const results = queryString |
| | | ? this.siteNames.filter(this.createFilter(queryString)) |
| | | : this.siteNames |
| | | cb(results) |
| | | }, |
| | | |
| | | createFilter(queryString) { |
| | | return (restaurant) => { |
| | | return ( |
| | | // toLowerCase() æ¹æ³ç¨äºæå符串转æ¢ä¸ºå°åã |
| | | restaurant.toLowerCase().indexOf(queryString.toLowerCase()) === 0 |
| | | this.obscureMatch(queryString,restaurant) |
| | | ) |
| | | } |
| | | }, |
| | | // åå§åå è½½ææçç«ç¹åå |
| | | loadAll() { |
| | | if(this.isNeedRealTimeAdvice == '1'){ |
| | | exceptionApi.getExceptionName(this.exceptionType,this.beginTime,this.endTime).then( res=>{ |
| | | this.siteNames = [] |
| | | const sites = res.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | let temp = {} |
| | | temp.name = item.name |
| | | temp.mnCode = item.mnCode |
| | | this.siteNamesAndMnCode.push(temp) |
| | | if (this.isNeedRealTimeAdvice == '1') { |
| | | exceptionApi |
| | | .getExceptionName(this.exceptionType, this.beginTime, this.endTime) |
| | | .then((res) => { |
| | | this.siteNames = [] |
| | | const sites = res.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | let temp = {} |
| | | temp.name = item.name |
| | | temp.mnCode = item.mnCode |
| | | this.siteNamesAndMnCode.push(temp) |
| | | }) |
| | | }) |
| | | } else if (this.isNeedRealTimeAdvice == '0') { |
| | | exceptionApi.getSitesNum().then((response) => { |
| | | const sites = response.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | let temp = {} |
| | | temp.name = item.name |
| | | temp.mnCode = item.mnCode |
| | | this.siteNamesAndMnCode.push(temp) |
| | | }) |
| | | this.$emit('submitSiteNums', this.siteNames.length) |
| | | }) |
| | | |
| | | }else if(this.isNeedRealTimeAdvice == '0'){ |
| | | exceptionApi.getSitesNum().then((response) => { |
| | | const sites = response.data.data |
| | | sites.filter((item) => { |
| | | this.siteNames.push(item['name']) |
| | | let temp = {} |
| | | temp.name = item.name |
| | | temp.mnCode = item.mnCode |
| | | this.siteNamesAndMnCode.push(temp) |
| | | }) |
| | | this.$emit('submitSiteNums', this.siteNames.length) |
| | | }) |
| | | } |
| | | } |
| | | }, |
| | | // æ ¹æ®éä¸çç«ç¹æ¥è¯¢è®¾å¤ç¼å· |
| | | onSiteNameSelected(siteName) { |
| | | const selectedSite = this.siteNamesAndMnCode.find((site) => site.name == siteName); |
| | | if (selectedSite) { |
| | | this.$emit('submitMncode',selectedSite.mnCode) |
| | | }else{ |
| | | this.$emit('submitMncode','') |
| | | } |
| | | }, |
| | | |
| | | onSiteNameSelected(siteName) { |
| | | const selectedSite = this.siteNamesAndMnCode.find((site) => site.name == siteName) |
| | | if (selectedSite) { |
| | | this.$emit('submitMncode', selectedSite.mnCode) |
| | | } else { |
| | | this.$emit('submitMncode', '') |
| | | } |
| | | }, |
| | | |
| | | // ç¹å»éä¸å»ºè®®é¡¹æ¶è§¦å |
| | | handleSelect(item) { |
| | | this.state = item |
| | |
| | | this.state = '' |
| | | this.$emit('submitValue', this.state) |
| | | }, |
| | | |
| | | |
| | | } |
| | | } |
| | | </script> |
| | |
| | | .el-autocomplete { |
| | | width: 200px; |
| | | } |
| | | |
| | | </style> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <!-- æ¶é´éæ©å¨ç»ä»¶ |
| | | |
| | | å¼å§æ¶é´ï¼æ°æ®åºææ°ä¸æ¡æ°æ®æ¶é´ã |
| | | ç»ææ¶é´ï¼å½åæ¶é´ |
| | | ä¼å°èµ·å§æ¶é´åæ¹åçæ¶é´éè¿äºä»¶âsubmitTimeâä¼ éç»ç¶ç»ä»¶ |
| | | |
| | | åå§æ¸²ææ¶å°±å°æ¶é´ä¼ éç»ç¶ç»ä»¶ï¼ |
| | | ** |
| | | å¨ç¶ç»ä»¶ä¸è®¾ç½® |
| | | <TimeSelectCrawling @submit-time="giveTime"></TimeSelectCrawling> |
| | | giveTime(val) { |
| | | //å°ä¸å½æ åæ¶é´è½¬ä¸ºæå®æ ¼å¼(该ç»ä»¶è¿åçæ åæ¶é´çæ ¼å¼ï¼æä»¥å¿
é¡»çå è¿ä¸ªå½æ°) |
| | | this.beginTime = dayjs(val[0]).format('YYYY-MM-DD HH:mm:ss'); |
| | | this.endTime = dayjs(val[1]).format('YYYY-MM-DD HH:mm:ss'); |
| | | }, |
| | | *** |
| | | --> |
| | | |
| | | <script> |
| | | import time from '@/utils/time.js' |
| | | export default { |
| | | props: { |
| | | // ç¶ç»ä»¶ä¼ å
¥çæ¶é´ |
| | | selectedTime: { |
| | | type: String, |
| | | default: '' |
| | | }, |
| | | // æ¯å¦è®¾ç½®åªè¯»å±æ§ |
| | | readOnly: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | isUTC: { |
| | | type: Boolean, |
| | | default: false |
| | | } |
| | | }, |
| | | emits: ['submitTime'], |
| | | data() { |
| | | return { |
| | | time: '' |
| | | } |
| | | }, |
| | | watch: { |
| | | selectedTime(newVal) { |
| | | if (newVal != '') { |
| | | this.time = this.selectedTime |
| | | } |
| | | } |
| | | }, |
| | | mounted() { |
| | | this.time = this.selectedTime |
| | | }, |
| | | methods: { |
| | | change() { |
| | | let t = time.utcTime(this.time) |
| | | console.log('isUTC', this.isUTC) |
| | | console.log('æ¶é´', t) |
| | | this.isUTC ? this.$emit('submitTime', t) : this.$emit('submitTime', this.time) |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <template> |
| | | <el-time-picker v-model="time" placeholder="éæ©æ¶é´" editable @change="change" /> |
| | | </template> |
| | | |
| | | <style scoped></style> |
| | |
| | | <!-- å个 æ¥ææ¶é´éæ©å¨ç»ä»¶ 带æ¥å¨æå¿«æ·é项 |
| | | åä¸å¤©æ¯å½åæ¶é´çåä¸å¤©ç00ç¹å°23ï¼59ï¼59 |
| | | åä¸å¤© å ä¸ä¸ä¸ªæåæ · |
| | | ä¼å°åå§é»è®¤æ¶é´ï¼ä¸å¨åï¼åæ¹åçæ¶é´éè¿äºä»¶âsubmitTimeâä¼ éç»ç¶ç»ä»¶ |
| | | <!-- å个 æ¥ææ¶é´éæ©å¨ç»ä»¶ |
| | | å°åå§é»è®¤æ¶é´ï¼ä¸å¨åï¼åæ¹åçæ¶é´éè¿äºä»¶âsubmitTimeâä¼ éç»ç¶ç»ä»¶ |
| | | |
| | | åå§æ¸²ææ¶å°±å°æ¶é´ä¼ éç»ç¶ç»ä»¶ï¼ |
| | | ** |
| | |
| | | --> |
| | | |
| | | <script> |
| | | import dayjs from 'dayjs' |
| | | import time from '@/utils/time.js' |
| | | export default { |
| | | props: { |
| | | // ç¶ç»ä»¶ä¼ å
¥çæ¶é´ |
| | | selectedTime: { |
| | | type: String, |
| | | // type: [String,null], |
| | | default: '' |
| | | }, |
| | | // æ¯å¦è®¾ç½®åªè¯»å±æ§ |
| | | readOnly: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | isUTC: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | isDisabled: { |
| | | type: Boolean, |
| | | default: false |
| | | } |
| | |
| | | emits: ['submitTime'], |
| | | data() { |
| | | return { |
| | | time: '', |
| | | shortcuts: [] |
| | | time: '' |
| | | } |
| | | }, |
| | | // watch: { |
| | | // selectedTime(newVal) { |
| | | // console.log('time', this.selectedTime) |
| | | // if (newVal != '') { |
| | | // this.time = this.selectedTime |
| | | // } |
| | | // } |
| | | // }, |
| | | mounted() { |
| | | console.log('time', this.selectedTime) |
| | | |
| | | this.time = this.selectedTime |
| | | watch: { |
| | | selectedTime(newVal) { |
| | | if (newVal != '') { |
| | | // this.time = time.utcToStr(this.selectedTime) |
| | | this.time = this.selectedTime |
| | | } |
| | | } |
| | | }, |
| | | |
| | | mounted() { |
| | | this.time = time.utcToStr(this.selectedTime) |
| | | }, |
| | | |
| | | methods: { |
| | | |
| | | change() { |
| | | if (this.time != null) { |
| | | let t = time.utcTime(this.time) |
| | | this.isUTC ? this.$emit('submitTime', t) : this.$emit('submitTime', this.time) |
| | | } else { |
| | | this.$emit('submitTime', this.time) |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <template> |
| | | <el-date-picker |
| | | v-model="time" |
| | | type="datetime" |
| | | placeholder="éæ©æ¶é´" |
| | | :shortcuts="shortcuts" |
| | | value-format="YYYY-MM-DD HH:mm:ss" |
| | | @change="$emit('submitTime', time)" |
| | | /> |
| | | <el-date-picker v-model="time" type="datetime" placeholder="éæ©æ¶é´" @change="change" /> |
| | | </template> |
| | | |
| | | <style scoped></style> |
| | |
| | | // å è½½ç¶æçé»è¾ç®¡ç |
| | | |
| | | import { defineStore } from 'pinia' |
| | | import { ref, computed } from 'vue' |
| | | |
| | | export const useLoginUserStore = defineStore('loginUser',() => { |
| | | export const useLoginUserStore = defineStore('loginUser', () => { |
| | | // å½åç»éçç¨æ·å |
| | | const currentLoginUser = ref('-1') |
| | | // ä¿®æ¹ |
| | |
| | | currentLoginUser.value = user |
| | | } |
| | | |
| | | |
| | | |
| | | const getUserName = computed(()=>{ |
| | | return currentLoginUser.value == '-1' ? localStorage.getItem('currentUserName'): currentLoginUser.value |
| | | const getUserName = computed(() => { |
| | | return currentLoginUser.value == '-1' |
| | | ? localStorage.getItem('currentUserName') |
| | | : currentLoginUser.value |
| | | }) |
| | | return {currentLoginUser,setUser,getUserName} |
| | | return { currentLoginUser, setUser, getUserName } |
| | | }) |
| | | |
| | | |
| | |
| | | return Math.round(v * 100, 2) + '%' |
| | | } |
| | | |
| | | return { isExceedOneMonth, cmpp, exportToExcel, descFiftyTime, percentFormatter } |
| | | /** |
| | | * æ¾åºå符串æ°åçæå¤§å¼ |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | function findMaxValue(values) { |
| | | const numbers = values.map((value) => parseFloat(value)) |
| | | const max = Math.max(...numbers) |
| | | return max.toString() |
| | | } |
| | | |
| | | return { isExceedOneMonth, cmpp, exportToExcel, descFiftyTime, percentFormatter,findMaxValue } |
| | | } |
| | |
| | | } |
| | | } |
| | | return r |
| | | }, |
| | | /** |
| | | * æ ¹æ®æ¶é´å符串è¿åUTCæ¶é´ |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | utcTime(timeStr){ |
| | | return dayjs(timeStr).format() |
| | | }, |
| | | /** |
| | | * å°utcæ¶é´è½¬ä¸ºæ¶é´å符串 |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | utcToStr(dateTime){ |
| | | const r = dateTime ? dayjs(dateTime).format('YYYY-MM-DD HH:mm:ss') :false |
| | | return r |
| | | } |
| | | } |
| | |
| | | <script> |
| | | import TimeShortCuts from '@/sfc/TimeShortCuts.vue'; |
| | | import ScenarioType from '@/sfc/ScenarioType.vue'; |
| | | import InputSearch from '@/sfc/InputSearch.vue'; |
| | | import TimeShortCuts from '@/sfc/TimeShortCuts.vue' |
| | | import ScenarioType from '@/sfc/ScenarioType.vue' |
| | | import InputSearch from '@/sfc/InputSearch.vue' |
| | | import { ElMessage } from 'element-plus' |
| | | import AreaAndmonitorType from '@/sfc/AreaAndmonitorType.vue' |
| | | |
| | | import { useCommonFunction } from '../../utils/common.js'; |
| | | import { useCommonFunction } from '../../utils/common.js' |
| | | import requetsApi from '@/api/exportExcel/requetsApi.js' |
| | | import ButtonClick from '@/sfc/ButtonClick.vue' |
| | | import ButtonExportExcel from '@/sfc/ButtonExportExcel.vue' |
| | | import dayjs from 'dayjs'; |
| | | import dayjs from 'dayjs' |
| | | |
| | | export default { |
| | | components: { |
| | |
| | | endTime: '' |
| | | }, |
| | | // æç´¢æ¡ä¼ é䏿¥ç设å¤ç¼å· |
| | | tempMnCode :'', |
| | | tempMnCode: '', |
| | | // è¿åçæ°æ® |
| | | tableData: [], |
| | | // è¡¨æ ¼æ°æ® |
| | |
| | | // å è½½ä¸ |
| | | loading: false, |
| | | queryButton: false, |
| | | exportButton:false, |
| | | exportButton: false, |
| | | // ç©ºç¶æ |
| | | isNoData: false, |
| | | // å·²éä¸çåºæ¯ç±»å |
| | |
| | | // è¡¨æ ¼é«åº¦ |
| | | tableHeight: '500', |
| | | // ç«ç¹æ»æ°é |
| | | siteNums:0 |
| | | }; |
| | | siteNums: 0 |
| | | } |
| | | }, |
| | | setup() { |
| | | const { isExceedOneMonth, exportToExcel } = useCommonFunction() |
| | | return { isExceedOneMonth, exportToExcel } |
| | | }, |
| | | mounted() { |
| | | this.backMinuteDataAWeekAgo(); |
| | | this.calTableHeight(); |
| | | this.backMinuteDataAWeekAgo() |
| | | this.calTableHeight() |
| | | }, |
| | | |
| | | methods: { |
| | | exportDom() { |
| | | |
| | | let params = { |
| | | 'beginTime': this.form.beginTime, |
| | | 'endTime': this.form.endTime, |
| | | beginTime: this.form.beginTime, |
| | | endTime: this.form.endTime |
| | | } |
| | | if (this.form.name) { |
| | | params['siteName'] = this.form.name; |
| | | params['siteName'] = this.form.name |
| | | } |
| | | if (this.form.number) { |
| | | params['mnCode'] = this.form.numbe; |
| | | params['mnCode'] = this.form.numbe |
| | | } |
| | | if (this.scenarioType.length != 0) { |
| | | params['scenarioType'] = this.scenarioType; |
| | | params['scenarioType'] = this.scenarioType |
| | | } |
| | | this.exportButton = true |
| | | requetsApi.fetchAlSiteData(params).then(res => { |
| | | requetsApi.fetchAlSiteData(params).then((res) => { |
| | | const data = res.data.data |
| | | if (data.length != 0) { |
| | | const tableColumns = [ |
| | |
| | | 'noiseValue', |
| | | 'lst', |
| | | 'quality', |
| | | 'groupName', |
| | | |
| | | 'groupName' |
| | | ] |
| | | const excelColumns = [['A1', 'ç«ç¹åç§°'], |
| | | ['B1', 'å°å'], ['C1', 'ä¾åºå'], ['D1', '设å¤ç¼å·'], |
| | | ['E1', 'ç±»å'], ['F1', 'æ¬å°æµåº¦(mg/m³)'], ['G1', 'åªå£°(dB)'], |
| | | ['H1', 'ééæ¶é´'], ['I1', 'ç级'], ['J1', 'æå¨åºå¿']] |
| | | const excelColumns = [ |
| | | ['A1', 'ç«ç¹åç§°'], |
| | | ['B1', 'å°å'], |
| | | ['C1', 'ä¾åºå'], |
| | | ['D1', '设å¤ç¼å·'], |
| | | ['E1', 'ç±»å'], |
| | | ['F1', 'æ¬å°æµåº¦(mg/m³)'], |
| | | ['G1', 'åªå£°(dB)'], |
| | | ['H1', 'ééæ¶é´'], |
| | | ['I1', 'ç级'], |
| | | ['J1', 'æå¨åºå¿'] |
| | | ] |
| | | this.exportToExcel(data, tableColumns, excelColumns, 'å岿°æ®è¡¨.xlsx') |
| | | }else{ |
| | | } else { |
| | | ElMessage('æ æ°æ®éè¦å¯¼åº') |
| | | } |
| | | this.exportButton = false |
| | |
| | | }, |
| | | // åè½ï¼è¡¨æ ¼é«åº¦æ ¹æ®å
容èªéåº |
| | | calTableHeight() { |
| | | const h1 = this.$refs.h1.$el.offsetHeight; |
| | | const h2 = this.$refs.h2.$el.offsetHeight; |
| | | const h1 = this.$refs.h1.$el.offsetHeight |
| | | const h2 = this.$refs.h2.$el.offsetHeight |
| | | // å
¶ä¸ä¸ä¸ª40æ¯çåçæ»å¤è¾¹è· |
| | | this.tableHeight = `calc(100vh - ${h1}px - ${h2}px - 40px - 40px - var(--el-main-padding) * 2`; |
| | | this.tableHeight = `calc(100vh - ${h1}px - ${h2}px - 40px - 40px - var(--el-main-padding) * 2` |
| | | }, |
| | | giveTime(val) { |
| | | //å°ä¸å½æ åæ¶é´è½¬ä¸ºæå®æ ¼å¼(该ç»ä»¶è¿åçæ åæ¶é´çæ ¼å¼ï¼æä»¥å¿
é¡»çå è¿ä¸ªå½æ°) |
| | | this.form.beginTime = dayjs(val[0]).format('YYYY-MM-DD HH:mm:ss'); |
| | | this.form.endTime = dayjs(val[1]).format('YYYY-MM-DD HH:mm:ss'); |
| | | this.form.beginTime = dayjs(val[0]).format('YYYY-MM-DD HH:mm:ss') |
| | | this.form.endTime = dayjs(val[1]).format('YYYY-MM-DD HH:mm:ss') |
| | | }, |
| | | // 页大尿¹åæ¶è§¦å |
| | | handleSizeChange(val) { |
| | | this.pageSize = val; |
| | | this.pageSize = val |
| | | |
| | | // æ¹åæ¯é¡µæ¾ç¤ºæ°ç®æ¶è·³å°å½å页 |
| | | this.handleCurrentChange(1); |
| | | this.handleCurrentChange(1) |
| | | }, |
| | | |
| | | // 页巿¹åæ¶è§¦å |
| | | handleCurrentChange(val) { |
| | | // å°å½å页å·ç»currentPage |
| | | this.currentPage = val; |
| | | this.currentPage = val |
| | | |
| | | // 页é¢ååæ¶è°ç¨ æ¥è¯¢æ°æ®å½æ° |
| | | this.handleSubmit(); |
| | | this.handleSubmit() |
| | | }, |
| | | //åºå·éå¢ |
| | | indexMethod(index) { |
| | | return index + 1 + (this.currentPage - 1) * this.pageSize; |
| | | return index + 1 + (this.currentPage - 1) * this.pageSize |
| | | }, |
| | | |
| | | // æ¥è¯¢æ°æ® |
| | | handleSubmit() { |
| | | |
| | | this.loading = true; |
| | | this.loading = true |
| | | this.queryButton = true |
| | | let params = {}; |
| | | params['page'] = this.currentPage; |
| | | params['pageSize'] = this.pageSize; |
| | | let params = {} |
| | | params['page'] = this.currentPage |
| | | params['pageSize'] = this.pageSize |
| | | if (this.form.name) { |
| | | params['siteName'] = this.form.name; |
| | | params['siteName'] = this.form.name |
| | | } |
| | | if (this.form.number) { |
| | | params['mnCode'] = this.form.number; |
| | | params['mnCode'] = this.form.number |
| | | } |
| | | params['beginTime'] = this.form.beginTime; |
| | | params['endTime'] = this.form.endTime; |
| | | params['beginTime'] = this.form.beginTime |
| | | params['endTime'] = this.form.endTime |
| | | if (this.scenarioType.length != 0) { |
| | | params['scenarioType'] = this.scenarioType.join(); |
| | | params['scenarioType'] = this.scenarioType.join() |
| | | } |
| | | this.$http.get('/dust/history1', { params: params }).then((response) => { |
| | | // ä¿åè¿åç |
| | | this.tableData = response.data.data.rows; |
| | | this.displayData = this.tableData; |
| | | this.loading = false; |
| | | this.tableData = response.data.data.rows |
| | | this.displayData = this.tableData |
| | | this.loading = false |
| | | this.queryButton = false |
| | | if (response.data.data.total == 0) { |
| | | ElMessage('è¯¥æ¶æ®µæ æ°æ®'); |
| | | this.loading = false; |
| | | ElMessage('è¯¥æ¶æ®µæ æ°æ®') |
| | | this.loading = false |
| | | this.queryButton = false |
| | | this.isNoData = true; |
| | | return; |
| | | this.isNoData = true |
| | | return |
| | | } |
| | | this.total = response.data.data.total; |
| | | this.total = response.data.data.total |
| | | // ç§»é¤ç©ºæ°æ®ç¶æ |
| | | this.isNoData = false; |
| | | }); |
| | | this.isNoData = false |
| | | }) |
| | | }, |
| | | backMinuteDataAWeekAgo() { |
| | | // æå¼é¡µé¢å è½½æè¿ä¸å¨çæ°æ® |
| | | this.loading = true; |
| | | this.loading = true |
| | | // ç»è¾å
¥æ¡è®¾ç½®é»è®¤ç鿩项 |
| | | |
| | | let params = {}; |
| | | params['siteName'] = this.form.name; |
| | | params['beginTime'] = this.form.beginTime; |
| | | params['endTime'] = this.form.endTime; |
| | | let params = {} |
| | | params['siteName'] = this.form.name |
| | | params['beginTime'] = this.form.beginTime |
| | | params['endTime'] = this.form.endTime |
| | | |
| | | this.$http.get('/dust/history1', { params: params }).then((response) => { |
| | | // ä¿åè¿åç |
| | | this.tableData = response.data.data.rows; |
| | | this.displayData = this.tableData; |
| | | this.tableData = response.data.data.rows |
| | | this.displayData = this.tableData |
| | | |
| | | if (response.data.data.total == 0) { |
| | | ElMessage('è¯¥æ¶æ®µæ æ°æ®'); |
| | | this.isNoData = true; |
| | | return; |
| | | ElMessage('è¯¥æ¶æ®µæ æ°æ®') |
| | | this.isNoData = true |
| | | return |
| | | } |
| | | this.total = response.data.data.total; |
| | | this.loading = false; |
| | | }); |
| | | } |
| | | this.total = response.data.data.total |
| | | this.loading = false |
| | | }) |
| | | } |
| | | } |
| | | }; |
| | | } |
| | | </script> |
| | | |
| | | <template> |
| | | <div class="history-container"> |
| | | <el-row> |
| | | <el-col ref="h1" class="head-row"> |
| | | <el-card> |
| | | <el-form :inline="true"> |
| | | <div class="demo-form-inline"> |
| | | <el-row> |
| | | <el-col> |
| | | <el-form-item> |
| | | <AreaAndmonitorType></AreaAndmonitorType> |
| | | </el-form-item> |
| | | <div class="history-container"> |
| | | <el-row> |
| | | <el-col ref="h1" class="head-row"> |
| | | <el-card> |
| | | <el-form :inline="true"> |
| | | <div class="demo-form-inline"> |
| | | <el-row> |
| | | <el-col> |
| | | <el-form-item> |
| | | <AreaAndmonitorType></AreaAndmonitorType> |
| | | </el-form-item> |
| | | |
| | | <el-form-item> |
| | | <InputSearch isNeedDefaultSite="1" @submit-value="(n) => (form.name = n)" @submit-site-nums="(n)=>(siteNums=n)"> |
| | | </InputSearch> |
| | | </el-form-item> |
| | | |
| | | <el-form-item> |
| | | <template #label> |
| | | <span class="font-label">设å¤ç¼å·:</span> |
| | | </template> |
| | | <el-input v-model="form.number" clearable placeholder="请è¾å
¥"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-form-item> |
| | | <InputSearch |
| | | isNeedDefaultSite="1" |
| | | @submit-value="(n) => (form.name = n)" |
| | | @submit-site-nums="(n) => (siteNums = n)" |
| | | > |
| | | </InputSearch> |
| | | </el-form-item> |
| | | |
| | | <el-col> |
| | | <el-form-item> |
| | | <TimeShortCuts time-type="week" @submit-time="giveTime"></TimeShortCuts> |
| | | <el-form-item> |
| | | <template #label> |
| | | <span class="font-label">设å¤ç¼ç :</span> |
| | | </template> |
| | | <el-input v-model="form.number" clearable placeholder="请è¾å
¥"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | |
| | | <el-col> |
| | | <el-form-item> |
| | | <TimeShortCuts time-type="week" @submit-time="giveTime"></TimeShortCuts> |
| | | </el-form-item> |
| | | |
| | | <el-form-item> |
| | | <ScenarioType @submitScenarioType="(val) => (scenarioType = val)"> |
| | | </ScenarioType> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | <div class="button-and-export"> |
| | | <el-form-item> |
| | | <el-tag class="ml-2" type="success" size="large">ç¹ä½æ»æ°</el-tag> |
| | | <span class="tag-text">{{ siteNums }}</span> |
| | | </el-form-item> |
| | | |
| | | <el-form-item> |
| | | <ScenarioType @submitScenarioType="(val) => (scenarioType = val)"> |
| | | </ScenarioType> |
| | | </el-form-item> |
| | | <ButtonClick |
| | | style="margin-right: 12px" |
| | | content="æç´¢" |
| | | type="primary" |
| | | :loading="queryButton" |
| | | @do-search="handleSubmit" |
| | | ></ButtonClick> |
| | | <ButtonExportExcel |
| | | content="å¯¼åºæ°æ®" |
| | | type="success" |
| | | :loading="exportButton" |
| | | @do-export="exportDom" |
| | | ></ButtonExportExcel> |
| | | </el-form-item> |
| | | </div> |
| | | </el-form> |
| | | </el-card> |
| | | </el-col> |
| | | <el-col> </el-col> |
| | | </el-row> |
| | | |
| | | </el-col> |
| | | |
| | | |
| | | </el-row> |
| | | </div> |
| | | <div class="button-and-export"> |
| | | <el-form-item> |
| | | <el-tag class="ml-2" type="success" size="large">ç«ç¹æ»æ°</el-tag> |
| | | <span class="tag-text">{{ siteNums }}</span> |
| | | </el-form-item> |
| | | |
| | | <el-form-item> |
| | | <ButtonClick style="margin-right: 12px;" content="æç´¢" type="primary" :loading="queryButton" @do-search="handleSubmit"></ButtonClick> |
| | | <ButtonExportExcel content="å¯¼åºæ°æ®" type="success" :loading="exportButton" @do-export="exportDom"></ButtonExportExcel> |
| | | </el-form-item> |
| | | </div> |
| | | </el-form> |
| | | |
| | | </el-card> |
| | | </el-col> |
| | | <el-col> |
| | | |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-row> |
| | | <el-col v-show="!isNoData"> |
| | | |
| | | <el-table border size="default" :highlight-current-row="true" :data="displayData" :height="tableHeight" |
| | | v-loading="loading"> |
| | | <!--ç»å®ä¸ä¸ªæ¹æ³ï¼å°è¿åå¼èµç»index,å³è¡¨æ ¼æ¯è¡æ°æ®ç䏿 --> |
| | | <el-table-column type="index" label="åºå·" align="center" fixed :index="indexMethod"></el-table-column> |
| | | <el-table-column prop="name" label="ç¹ä½åç§°" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="address" label="å°å" align="center" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="dutyCompany" label="è¿ç»´å" align="center" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="mnCode" label="设å¤ç¼ç " show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="typeName" label="ç±»å" align="center" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="dustValue" label="TSP(mg/m³)" align="center" sortable |
| | | show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="noiseValue" label="åªå£°(dB)" align="center" sortable show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="lst" label="ééæ¶é´" sortable align="center" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="quality" label="ç级" align="center" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="groupName" label="æå¨åºå¿" align="center" show-overflow-tooltip> |
| | | </el-table-column> |
| | | </el-table> |
| | | <!--size-change æ¯pageSize æ¹åæ¶ä¼è§¦åçäºä»¶,handleSizeChangeæ¯äºä»¶å¤ç彿° |
| | | <el-row> |
| | | <el-col v-show="!isNoData"> |
| | | <el-table |
| | | border |
| | | size="default" |
| | | :highlight-current-row="true" |
| | | :data="displayData" |
| | | :height="tableHeight" |
| | | v-loading="loading" |
| | | > |
| | | <!--ç»å®ä¸ä¸ªæ¹æ³ï¼å°è¿åå¼èµç»index,å³è¡¨æ ¼æ¯è¡æ°æ®ç䏿 --> |
| | | <el-table-column |
| | | type="index" |
| | | label="åºå·" |
| | | align="center" |
| | | fixed |
| | | :index="indexMethod" |
| | | ></el-table-column> |
| | | <el-table-column prop="name" label="ç¹ä½åç§°" show-overflow-tooltip></el-table-column> |
| | | <el-table-column |
| | | prop="address" |
| | | label="å°å" |
| | | align="center" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | prop="dutyCompany" |
| | | label="è¿ç»´å" |
| | | align="center" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column prop="mnCode" label="设å¤ç¼ç " show-overflow-tooltip></el-table-column> |
| | | <el-table-column |
| | | prop="typeName" |
| | | label="ç±»å" |
| | | align="center" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | prop="dustValue" |
| | | label="TSP(mg/m³)" |
| | | align="center" |
| | | sortable |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | prop="noiseValue" |
| | | label="åªå£°(dB)" |
| | | align="center" |
| | | sortable |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | prop="lst" |
| | | label="ééæ¶é´" |
| | | sortable |
| | | align="center" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | prop="quality" |
| | | label="ç级" |
| | | align="center" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column prop="groupName" label="æå¨åºå¿" align="center" show-overflow-tooltip> |
| | | </el-table-column> |
| | | </el-table> |
| | | <!--size-change æ¯pageSize æ¹åæ¶ä¼è§¦åçäºä»¶,handleSizeChangeæ¯äºä»¶å¤ç彿° |
| | | current-change æ¯currentPage æ¹åæ¶ä¼è§¦åçäºä»¶ --> |
| | | |
| | | <el-pagination ref="h2" background @size-change="handleSizeChange" @current-change="handleCurrentChange" |
| | | :page-sizes="[10, 20, 50, 100]" :page-size="pageSize" :total="total" |
| | | layout="total,sizes, prev, pager, next, jumper" :current-page="currentPage"></el-pagination> |
| | | |
| | | </el-col> |
| | | <el-empty v-show="isNoData" :image-size="200" /> |
| | | |
| | | </el-row> |
| | | </div> |
| | | <el-pagination |
| | | ref="h2" |
| | | background |
| | | @size-change="handleSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | :page-sizes="[10, 20, 50, 100]" |
| | | :page-size="pageSize" |
| | | :total="total" |
| | | layout="total,sizes, prev, pager, next, jumper" |
| | | :current-page="currentPage" |
| | | ></el-pagination> |
| | | </el-col> |
| | | <el-empty v-show="isNoData" :image-size="200" /> |
| | | </el-row> |
| | | </div> |
| | | </template> |
| | | |
| | | <style scoped> |
| | | <style scoped> |
| | | .history-container { |
| | | min-width: 1200px; |
| | | } |
| | |
| | | |
| | | .el-table { |
| | | /* color: #303133 */ |
| | | color: rgb(59, 60, 63) |
| | | color: rgb(59, 60, 63); |
| | | } |
| | | .el-pagination { |
| | | margin: 10px 10px; |
| | | } |
| | | .tag-text{ |
| | | .tag-text { |
| | | margin-left: 10px; |
| | | font-size: 14px; |
| | | } |
| | |
| | | import TimeSinglePicker from '@/sfc/TimeSinglePicker.vue' |
| | | import CompEditRequest from '@/views/data_management/components/CompEditRequest.vue' |
| | | import CompEditException from '@/views/data_management/components/CompEditException.vue' |
| | | import dayjs from 'dayjs' |
| | | import exceptionSetting from '@/api/setting/exceptionSetting.js' |
| | | import requestTaskSetting from '@/api/setting/requestTaskSetting.js' |
| | | import { useLoginUserStore } from '@/stores/user' |
| | | export default { |
| | | components: { |
| | | TimeSinglePicker, |
| | |
| | | return { |
| | | activeName: 'first', |
| | | // å¯¹è¯æ¡æ¾ç¤º |
| | | dialog:{ |
| | | dialog: { |
| | | formRequestVisible: false, |
| | | formExceptionVisible: false |
| | | }, |
| | | request: [ |
| | | { |
| | | user: 'admin', |
| | | updateTime: '2023-10-10 09:16:41', |
| | | region: 'éå±±åº', |
| | | version: '1.0', |
| | | requestStartTime: '2023-10-12 08:43:00', |
| | | requestEndTime: null, |
| | | requestIntervalSeconds: 43200, |
| | | requestRangeHour: 8, |
| | | requestRangeIntervalSeconds: 5, |
| | | requestFailWaitSeconds: 120, |
| | | requestRetryTimes: 4, |
| | | requestCookieValidDuration: 48, |
| | | staticsDailyTime: '2023-10-11 09:00:00', |
| | | staticsMonthlyTime: '2023-10-01 10:00:00', |
| | | loginFailWaitSeconds: 5, |
| | | loginRetryTimes: 5, |
| | | taskRetryWaitSeconds: 120, |
| | | firstRequestOffsetDays: 30 |
| | | } |
| | | ], |
| | | exceptionSetting: [{ |
| | | user: 'admin', |
| | | updateTime: '2023-10-10 09:16:41', |
| | | region: 'éå±±åº', |
| | | version: '1.0', |
| | | missDataMinutes: 45, |
| | | dataLow: 0.02, |
| | | longTimeNoChange: 5, |
| | | mutationNum: 2, |
| | | mutationRate: 1, |
| | | nearExceedLowValue: 0.7, |
| | | nearExceedHighValue: 1, |
| | | nearExceedNum: 4, |
| | | dayExceedBorderlineLowNum: 6, |
| | | dayExceedBorderlineHighNum: 7, |
| | | changeTrendGroup: 12, |
| | | changeTrendInterval: 12, |
| | | changeTrendRate: 1, |
| | | changeTrendTimes: 3, |
| | | exceedingStandard: 1 |
| | | }], |
| | | // 请æ±ä»»å¡é
ç½®æ°æ® |
| | | requestData: [], |
| | | // å¼å¸¸åæé
ç½®æ°æ® |
| | | exceptionSettingData: [], |
| | | form_1: { |
| | | user: '11', |
| | | requestStartTime: '', |
| | |
| | | staticsDailyTime: '', |
| | | staticsMonthlyTime: '' |
| | | }, |
| | | loading:false, |
| | | |
| | | // å è½½ä¸ |
| | | loading: { |
| | | request: '', |
| | | exception: '' |
| | | } |
| | | } |
| | | }, |
| | | setup() { |
| | | const userName = useLoginUserStore() |
| | | return { |
| | | userName |
| | | } |
| | | }, |
| | | watch: { |
| | | |
| | | }, |
| | | mounted() {}, |
| | | methods: { |
| | | handleClick(tab, event) { |
| | | // console.log(tab, event) |
| | | }, |
| | | fetchData(){ |
| | | console.log('è·åè¡¨æ ¼æ°æ®'); |
| | | this.loading = true |
| | | setTimeout(() => { |
| | | this.loading = false |
| | | }, 700); |
| | | }, |
| | | // åæ¶ |
| | | cancel_1() { |
| | | this.dialogTableVisible = false |
| | | }, |
| | | // æäº¤ |
| | | submit() { |
| | | this.dialogTableVisible = false |
| | | }, |
| | | render() { |
| | | ElMessageBox.alert( |
| | | h('div', ['this is', h('em', { style: { color: 'teal', fontSize: '14px' } }, 'Vnode')]) |
| | | ) |
| | | }, |
| | | |
| | | /** |
| | | * åæ¶æé® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | cancelEvent() { |
| | | this.$message.info('已忶') |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | |
| | | <template> |
| | | <el-row> |
| | | <el-col> |
| | | <em>åæ°é
ç½®</em> |
| | | <el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick"> |
| | | <el-tab-pane label="æ°æ®è·å" name="first" > |
| | | <div>å±ç¤º</div> |
| | | <div>ä¿®æ¹</div> |
| | | <el-table :data="request" border> |
| | | <el-table-column prop="user" label="ç¨æ·å"> </el-table-column> |
| | | <el-table-column prop="updateTime" label="æ´æ°æ¶é´"> </el-table-column> |
| | | <el-table-column prop="region" label="åºå"> </el-table-column> |
| | | <el-table-column prop="version" label="çæ¬"> </el-table-column> |
| | | <el-table-column prop="requestStartTime" label="æ°æ®è·åå¼å§æ¶é´"> </el-table-column> |
| | | <el-table-column prop="requestEndTime" label="æ°æ®è·åç»ææ¶é´"> </el-table-column> |
| | | <el-table-column prop="requestIntervalSeconds" label="æ°æ®è·åé¢ç"> </el-table-column> |
| | | <el-table-column prop="requestRangeHour" label="ä»»å¡å段æ¶é¿"> </el-table-column> |
| | | <el-table-column prop="requestRangeIntervalSeconds" label="åæ®µæ§è¡æ¶çæ¯æ®µçé´éæ¶é´"> </el-table-column> |
| | | <el-table-column prop="requestFailWaitSeconds" label="è·åæ°æ®ä»»å¡å¼å¸¸æ¶å次å°è¯é´é"> </el-table-column> |
| | | <el-table-column prop="requestRetryTimes" label="è·åæ°æ®å¤±è´¥æ¶å次å°è¯çæ»æ¬¡æ°"> </el-table-column> |
| | | <el-table-column prop="requestCookieValidDuration" label="cookieæææ¶å¸¸é¿"> </el-table-column> |
| | | <el-table-column prop="staticsDailyTime" label="æ¥ç»è®¡æ§è¡æ¶é´"> </el-table-column> |
| | | <el-table-column prop="staticsMonthlyTime" label="æç»è®¡æ§è¡æ¶é´"> </el-table-column> |
| | | <el-table-column prop="loginFailWaitSeconds" label="ç»å½å¤±è´¥çå¾
æ¶é¿"> </el-table-column> |
| | | <el-table-column prop="loginRetryTimes" label="ç»å½å¤±è´¥å°è¯æ¬¡æ°"> </el-table-column> |
| | | <el-table-column prop="taskRetryWaitSeconds" label="æ°æ®è·åä»»å¡éæ°å¼å§å°è¯çå¾
æ¶é´"> </el-table-column> |
| | | <el-table-column prop="firstRequestOffsetDays" label=" æ°æ®è·åå¼å§æ¶é´ç¸å¯¹å½æ¥å¾ååç§»"> </el-table-column> |
| | | </el-table> |
| | | <el-button type="primary" size="small" @click="dialog.formRequestVisible = !dialog.formRequestVisible"> |
| | | ä¿®æ¹é
ç½®</el-button |
| | | > |
| | | |
| | | <CompEditRequest v-model="dialog.formRequestVisible" :tableData="request[0]"> |
| | | </CompEditRequest> |
| | | |
| | | <el-tabs v-model="activeName" class="demo-tabs"> |
| | | <el-tab-pane label="æ°æ®è·å" name="first"> |
| | | <CompEditRequest :user-name="userName.getUserName"></CompEditRequest> |
| | | </el-tab-pane> |
| | | |
| | | |
| | | <el-tab-pane label="å¼å¸¸åæ" name="second" |
| | | ><div>å±ç¤º</div> |
| | | <el-table :data="exceptionSetting" border> |
| | | <el-table-column prop="user" label="ç¨æ·å"> </el-table-column> |
| | | <el-table-column prop="updateTime" label="æ´æ°æ¶é´"> </el-table-column> |
| | | <el-table-column prop="region" label="åºå"> </el-table-column> |
| | | <el-table-column prop="version" label="çæ¬"> </el-table-column> |
| | | |
| | | <el-table-column prop="missDataMinutes" label="æ°æ®è·åå¼å§æ¶é´"> </el-table-column> |
| | | <el-table-column prop="dataLow" label="æ°æ®è·åç»ææ¶é´"> </el-table-column> |
| | | <el-table-column prop="longTimeNoChange" label="æ°æ®è·åé¢ç"> </el-table-column> |
| | | <el-table-column prop="mutationNum" label="ä»»å¡å段æ¶é¿"> </el-table-column> |
| | | <el-table-column prop="mutationRate" label="åæ®µæ§è¡æ¶çæ¯æ®µçé´éæ¶é´"> </el-table-column> |
| | | <el-table-column prop="nearExceedLowValue" label="è·åæ°æ®ä»»å¡å¼å¸¸æ¶å次å°è¯é´é"> </el-table-column> |
| | | <el-table-column prop="nearExceedHighValue" label="è·åæ°æ®å¤±è´¥æ¶å次å°è¯çæ»æ¬¡æ°"> </el-table-column> |
| | | <el-table-column prop="nearExceedNum" label="cookieæææ¶å¸¸é¿"> </el-table-column> |
| | | <el-table-column prop="dayExceedBorderlineLowNum" label="æ¥ç»è®¡æ§è¡æ¶é´"> </el-table-column> |
| | | <el-table-column prop="dayExceedBorderlineHighNum" label="æç»è®¡æ§è¡æ¶é´"> </el-table-column> |
| | | <el-table-column prop="changeTrendGroup" label="ç»å½å¤±è´¥çå¾
æ¶é¿"> </el-table-column> |
| | | <el-table-column prop="changeTrendInterval" label="ç»å½å¤±è´¥å°è¯æ¬¡æ°"> </el-table-column> |
| | | <el-table-column prop="changeTrendRate" label="æ°æ®è·åä»»å¡éæ°å¼å§å°è¯çå¾
æ¶é´"> </el-table-column> |
| | | <el-table-column prop="changeTrendTimes" label=" æ°æ®è·åå¼å§æ¶é´ç¸å¯¹å½æ¥å¾ååç§»"> </el-table-column> |
| | | <el-table-column prop="exceedingStandard" label=" æ°æ®è·åå¼å§æ¶é´ç¸å¯¹å½æ¥å¾ååç§»"> </el-table-column> |
| | | </el-table> |
| | | |
| | | |
| | | <div>ä¿®æ¹</div> |
| | | |
| | | <CompEditException v-model="dialog.formExceptionVisible" ></CompEditException> |
| | | |
| | | <el-button type="primary" size="small" @click="dialog.formExceptionVisible = !dialog.formExceptionVisible"> |
| | | ä¿®æ¹é
ç½®</el-button |
| | | > |
| | | <el-tab-pane label="å¼å¸¸åæ" name="second"> |
| | | <CompEditException :user-name="userName.getUserName"></CompEditException> |
| | | </el-tab-pane> |
| | | </el-tabs> |
| | | |
| | | <!-- <el-button @click="render"> 渲æhtml</el-button> --> |
| | | <!-- <el-button @click="addObj"> å¢å 对象</el-button> --> |
| | | </el-col> |
| | | </el-row> |
| | | </template> |
| | |
| | | font-size: 30px; |
| | | color: #333333; |
| | | } |
| | | </style> |
| | | |
| | | <!-- <script> |
| | | export default { |
| | | data() { |
| | | return{ |
| | | inputValue:null |
| | | } |
| | | }, |
| | | mounted() { |
| | | |
| | | }, |
| | | methods: { |
| | | |
| | | } |
| | | .el-button { |
| | | margin-top: 20px; |
| | | } |
| | | </script> |
| | | |
| | | <template> |
| | | {{inputValue}} |
| | | è¾å
¥<el-input v-model.number="inputValue" maxlength="10"> |
| | | </el-input> |
| | | </template> --> |
| | | .el-table { |
| | | color: #333333; |
| | | } |
| | | </style> |
| | |
| | | <script> |
| | | import TimeSinglePicker from '@/sfc/TimeSinglePicker.vue' |
| | | import exceptionSetting from '@/api/setting/exceptionSetting.js' |
| | | import { useCommonFunction } from '@/utils/common.js' |
| | | export default { |
| | | props: ['modelValue'], |
| | | emits: ['update:modelValue'], |
| | | components: { |
| | | TimeSinglePicker |
| | | props: { |
| | | userName: { |
| | | type: String, |
| | | default: '' |
| | | } |
| | | }, |
| | | |
| | | computed: { |
| | | visible: { |
| | | get() { |
| | | return this.modelValue |
| | | }, |
| | | set(value) { |
| | | this.$emit('update:modelValue', value) |
| | | formDataAfterCal() { |
| | | return { |
| | | user: this.userName, |
| | | region: this.form.region, |
| | | // æ¯ä¿®æ¹ç¶æ-->该记å½ççæ¬å· æ¯æ°å¢ç¶æ--> é
置表表æå¤§ççæ¬å· |
| | | version: this.modify ? this.form.version : this.maxVersion, |
| | | |
| | | missDataMinutes: this.form.missDataMinutes, |
| | | dataLow: this.form.dataLow, |
| | | longTimeNoChange: this.form.longTimeNoChange, |
| | | mutationNum: this.form.mutationNum, |
| | | mutationRate: this.form.mutationRate, |
| | | nearExceedLowValue: this.form.nearExceedLowValue, |
| | | nearExceedHighValue: this.form.nearExceedHighValue, |
| | | nearExceedNum: this.form.nearExceedNum, |
| | | dayExceedBorderlineLowNum: this.form.dayExceedBorderlineLowNum, |
| | | dayExceedBorderlineHighNum: this.form.dayExceedBorderlineHighNum, |
| | | changeTrendGroup: this.form.changeTrendGroup, |
| | | changeTrendInterval: this.form.changeTrendInterval, |
| | | changeTrendRate: this.form.changeTrendRate, |
| | | changeTrendTimes: this.form.changeTrendTimes, |
| | | exceedingStandard: this.form.exceedingStandard |
| | | } |
| | | } |
| | | }, |
| | | watch: { |
| | | formData: { |
| | | handler() { |
| | | if (Object.keys(this.formData).length != 0) |
| | | this.form = JSON.parse(JSON.stringify(this.formData)) |
| | | }, |
| | | deep: true |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | form: { |
| | | user: 'admin', |
| | | updateTime: '2023-10-10 09:16:41', |
| | | region: 'éå±±åº', |
| | | version: '1.0', |
| | | |
| | | missDataMinutes: 45, |
| | | dataLow: 0.02, |
| | | longTimeNoChange: 5, |
| | | mutationNum: 2, |
| | | mutationRate: 1, |
| | | nearExceedLowValue: 0.7, |
| | | nearExceedHighValue: 1, |
| | | nearExceedNum: 4, |
| | | dayExceedBorderlineLowNum: 6, |
| | | dayExceedBorderlineHighNum: 7, |
| | | changeTrendGroup: 12, |
| | | changeTrendInterval: 12, |
| | | changeTrendRate: 1, |
| | | changeTrendTimes: 3, |
| | | exceedingStandard: 1 |
| | | }, |
| | | describe: null |
| | | form: {}, |
| | | // æé«ççæ¬å· |
| | | maxVersion: null, |
| | | loading: false, |
| | | // ä¿®æ¹ç¶æ |
| | | modify: false |
| | | } |
| | | }, |
| | | |
| | | mounted() { |
| | | this.operation() |
| | | setup() { |
| | | const { findMaxValue } = useCommonFunction() |
| | | return { findMaxValue } |
| | | }, |
| | | mounted() { |
| | | this.queryException() |
| | | }, |
| | | |
| | | methods: { |
| | | // æäº¤ |
| | | submit() { |
| | | this.visible = false |
| | | async submitForm() { |
| | | // åéä¿®æ¹çè¯·æ± |
| | | await exceptionSetting.submitExceptionSetting(this.formDataAfterCal) |
| | | |
| | | this.$message.success('æäº¤æå') |
| | | |
| | | // æ°æ®æäº¤åå·æ°è¡¨å |
| | | this.queryException() |
| | | }, |
| | | // åæ¶ |
| | | cancel_1() { |
| | | this.visible = false |
| | | }, |
| | | // 对象å¤ç |
| | | operation() { |
| | | // console.log(Object.keys(this.form)); |
| | | // console.log(Object.values(this.form)); |
| | | console.log(Object.entries(this.form)) |
| | | let temp = [] |
| | | let arr = Object.entries(this.form) |
| | | for (let item of arr) { |
| | | let obj = {} |
| | | obj.label = item[0] |
| | | obj.value = item[1] |
| | | temp.push(obj) |
| | | |
| | | /** |
| | | * åéå°é»è®¤é
ç½® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | async defaultSetting() { |
| | | if (this.form.version == '1.0') { |
| | | this.$message.info('å½åå·²ç»æ¯é»è®¤ççæ¬') |
| | | return |
| | | } |
| | | this.describe = temp |
| | | console.log(temp) |
| | | this.loading = true |
| | | await exceptionSetting.queryDefaultSetting().then((Response) => { |
| | | this.form = {} |
| | | this.form = Response.data.data[0] |
| | | }) |
| | | |
| | | this.modify = true |
| | | // è®¾ç½®çæ¬1.0 çæ´æ°æ¶é´ |
| | | exceptionSetting.alertExceptionSetting(this.formDataAfterCal) |
| | | this.modify = false |
| | | this.loading = false |
| | | |
| | | this.$message.success('åéæå') |
| | | }, |
| | | |
| | | /** |
| | | * æ¥è¯¢è¯·æ±è®¾ç½®çæ°æ® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | queryException() { |
| | | this.loading = true |
| | | exceptionSetting.queryExceptionSetting().then((Response) => { |
| | | this.loading = false |
| | | this.form = Response.data.data[0] |
| | | |
| | | // æ¾å°æå¤§ççæ¬ |
| | | const versions = Response.data.data.map((item) => item.version) |
| | | this.maxVersion = this.findMaxValue(versions) |
| | | }) |
| | | }, |
| | | /** |
| | | * åæ¶æé® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | cancelEvent() { |
| | | this.$message.info('已忶') |
| | | } |
| | | |
| | | } |
| | | } |
| | | </script> |
| | | <template> |
| | | <el-dialog v-model="visible" title="è¯·æ±æ°æ®" align-center> |
| | | <el-form :model="form" label-width="120px"> |
| | | <el-form-item label="ç¨æ·å"> |
| | | <el-input v-model="form.user" disabled /> |
| | | </el-form-item> |
| | | <el-form-item label="å¼å§æ¶é´"> |
| | | <TimeSinglePicker @submit-time="(n) => (form.requestStartTime = n)"></TimeSinglePicker> |
| | | </el-form-item> |
| | | <el-form-item label="ç»ææ¶é´"> |
| | | <TimeSinglePicker @submit-time="(n) => (form.requestEndTime = n)"></TimeSinglePicker> |
| | | </el-form-item> |
| | | <el-form-item label="è·åé¢ç"> |
| | | <el-input-number v-model="num" :min="1" :max="24" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="åæ®µæ¶é¿"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="åæ®µæ§è¡æ¶çæ¯æ®µçé´éæ¶é´"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="è·åæ°æ®ä»»å¡å¼å¸¸æ¶å次å°è¯é´é"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="è·åæ°æ®å¤±è´¥æ¶å次å°è¯çæ»æ¬¡æ°"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="æ¥ç»è®¡"> |
| | | <TimeSinglePicker @submit-time="(n) => (form.staticsDailyTime = n)" /> |
| | | </el-form-item> |
| | | <el-form-item label="æç»è®¡"> |
| | | <TimeSinglePicker @submit-time="(n) => (form.staticsMonthlyTime = n)" /> |
| | | </el-form-item> |
| | | <el-form-item label="ç»å½å¤±è´¥çå¾
æ¶é¿"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="ç»å½å¤±è´¥å°è¯æ¬¡æ°"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="ä»»å¡éæ°å¼å§å°è¯çå¾
æ¶é´"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | <el-form-item label="æ°æ®è·åå¼å§æ¶é´ç¸å¯¹å½æ¥å¾ååç§»"> |
| | | <el-input-number v-model="num" :min="1" :max="10" @change="handleChange" /> |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <template #footer> |
| | | <el-button @click="cancel_1">åæ¶</el-button> |
| | | <el-button type="primary" @click="submit">æäº¤</el-button> |
| | | <div class="my-header"> |
| | | <el-text tag="b"> æ£å¨ä½¿ç¨ççæ¬ï¼{{ form.version }}</el-text> |
| | | </div> |
| | | <el-form :model="form" label-width="230px" v-loading="loading"> |
| | | <el-form-item label="ç¨æ·å"> |
| | | <el-input :value="userName" disabled /> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="åºå¿"> |
| | | <el-input :value="form.region" disabled /> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="(æ°æ®ç¼ºå¤±)缺失çåéæ°"> |
| | | <el-input v-model.number="form.missDataMinutes"> |
| | | <template #append>åé</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(æ°æ®è¶
ä½)é¢ç²ç©æµåº¦å¼å°äºX"> |
| | | <el-input v-model="form.dataLow"> |
| | | <template #append>mg/m³</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(æ°æ®é¿æ¶é´æ æ³¢å¨)è¿ç»X个å¼ç¸ç"> |
| | | <el-input v-model.number="form.longTimeNoChange"> |
| | | <template #append>个</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(é级çªå)è¿ç»N个15åé"> |
| | | <el-input v-model.number="form.mutationNum"> |
| | | <template #append>åé</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(é级çªå)ååçè¶
è¿X"> |
| | | <el-input v-model="form.mutationRate"> |
| | | <template #append>æ¯ç</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(临è¿è¶
æ å¼å¸¸)å¤äº[a,b]ç左边ç"> |
| | | <el-input v-model="form.nearExceedLowValue"> |
| | | <template #append>mg/m³</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(临è¿è¶
æ )å¤äº[a,b]çå³è¾¹ç"> |
| | | <el-input v-model="form.nearExceedHighValue"> |
| | | <template #append>mg/m³</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(临è¿è¶
æ )次æ°è¶
è¿X个"> |
| | | <el-input v-model.number="form.nearExceedNum"> |
| | | <template #append>次</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(忥è¶
æ æ¬¡æ°ä¸´ç)è¶
æ æ¬¡æ°è¾¾X次"> |
| | | <el-input v-model.number="form.dayExceedBorderlineLowNum"> |
| | | <template #append>次</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(忥è¶
æ æ¬¡æ°ä¸´ç)使ªè¾¾å°Y次"> |
| | | <el-input v-model.number="form.dayExceedBorderlineHighNum"> |
| | | <template #append>次</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(ååè¶å¿å¼å¸¸)N个ä¸ç»"> |
| | | <el-input v-model.number="form.changeTrendGroup"> |
| | | <template #append>个</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(ååè¶å¿å¼å¸¸)é´éM"> |
| | | <el-input v-model.number="form.changeTrendInterval"> |
| | | <template #append>个</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="(ååè¶å¿å¼å¸¸)å¹³åå¼ç¸å·®Y"> |
| | | <el-input v-model="form.changeTrendRate"> |
| | | <template #append>mg/m³</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="(ååè¶å¿å¼å¸¸)è¿ç»ç次æ°"> |
| | | <el-input v-model.number="form.changeTrendTimes"> |
| | | <template #append>次</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="(è¶
æ )è¶
è¿æ åå¼"> |
| | | <el-input v-model="form.exceedingStandard"> |
| | | <template #append>mg/m³</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <el-popconfirm |
| | | confirm-button-text="ç¡®å®" |
| | | cancel-button-text="åæ¶" |
| | | icon-color="#626AEF" |
| | | title="确认åéåï¼" |
| | | @confirm="defaultSetting" |
| | | @cancel="cancelEvent" |
| | | > |
| | | <template #reference> |
| | | <el-button :disabled="form.version=='1.0'">åéå°é»è®¤è®¾ç½®</el-button> |
| | | </template> |
| | | </el-dialog> |
| | | </el-popconfirm> |
| | | |
| | | <!-- <el-button @click="operation">对象å¤ç</el-button> --> |
| | | |
| | | <el-descriptions title="å¼å¸¸åæé
ç½®" :column="4" size="large" border> |
| | | <el-descriptions-item |
| | | v-for="item in describe" |
| | | :key="item.label" |
| | | :label="item.label" |
| | | label-align="left" |
| | | align="center" |
| | | class-name="content-text" |
| | | label-class-name="label-text" |
| | | > |
| | | {{ item.value }} |
| | | </el-descriptions-item> |
| | | </el-descriptions> |
| | | <el-popconfirm |
| | | confirm-button-text="ç¡®å®" |
| | | cancel-button-text="åæ¶" |
| | | icon-color="#626AEF" |
| | | title="确认修æ¹åï¼" |
| | | @confirm="submitForm" |
| | | @cancel="cancelEvent" |
| | | > |
| | | <template #reference> |
| | | <el-button type="primary">ä¿®æ¹</el-button> |
| | | </template> |
| | | </el-popconfirm> |
| | | </template> |
| | | |
| | | <style scoped> |
| | | :deep(.label-text) { |
| | | font-size: 14px !important; |
| | | font-weight: bold !important; |
| | | color: #333333 !important; |
| | | .my-header { |
| | | margin-bottom: 20px; |
| | | } |
| | | :deep(.content-text) { |
| | | color: #333333 !important; |
| | | span { |
| | | font-size: 16px; |
| | | color: #0a0a0a; |
| | | } |
| | | .version-text { |
| | | margin-left: 20px; |
| | | } |
| | | .el-input { |
| | | width: 50%; |
| | | } |
| | | </style> |
| | |
| | | <script> |
| | | import TimeSinglePicker from '@/sfc/TimeSinglePicker.vue' |
| | | import OnlyTimePick from '@/sfc/OnlyTimePick.vue' |
| | | import requestTaskSetting from '@/api/setting/requestTaskSetting.js' |
| | | import { useCommonFunction } from '@/utils/common.js' |
| | | export default { |
| | | components: { |
| | | TimeSinglePicker |
| | | TimeSinglePicker, |
| | | OnlyTimePick |
| | | }, |
| | | props: { |
| | | modelValue: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | tableData: { |
| | | type: Object, |
| | | default: {} |
| | | userName: { |
| | | type: String, |
| | | default: '' |
| | | } |
| | | }, |
| | | emits: ['update:modelValue'], |
| | | |
| | | computed: { |
| | | value: { |
| | | get() { |
| | | return this.modelValue |
| | | }, |
| | | set(value) { |
| | | this.$emit('update:modelValue', value) |
| | | } |
| | | }, |
| | | formDataAfterCal() { |
| | | return { |
| | | user: this.form.user, |
| | | updateTime: this.form.updateTime, |
| | | user: this.userName, |
| | | region: this.form.region, |
| | | version: this.form.version, |
| | | // æ¯ä¿®æ¹ç¶æ-->该记å½ççæ¬å· æ¯æ°å¢ç¶æ--> é
置表表æå¤§ççæ¬å· |
| | | version: this.modify ? this.form.version : this.maxVersion, |
| | | |
| | | requestStartTime: this.form.requestStartTime, |
| | | requestEndTime: this.form.requestEndTime, |
| | | |
| | | requestIntervalSeconds: this.form.requestIntervalSeconds * 3600, |
| | | requestIntervalSeconds: this.requestIntervalSeconds, |
| | | requestRangeHour: this.form.requestRangeHour, |
| | | requestRangeIntervalSeconds: this.form.requestRangeIntervalSeconds, |
| | | requestFailWaitSeconds: this.form.requestFailWaitSeconds, |
| | |
| | | } |
| | | }, |
| | | |
| | | watch: { |
| | | 'form.requestIntervalSeconds': function (val, oldVal) { |
| | | if (this.form.requestIntervalSeconds != '' && this.form.requestIntervalSeconds != null) { |
| | | this.requestIntervalSeconds = this.form.requestIntervalSeconds / 3600 |
| | | } |
| | | } |
| | | }, |
| | | setup() { |
| | | const { findMaxValue } = useCommonFunction() |
| | | return { findMaxValue } |
| | | }, |
| | | data() { |
| | | return { |
| | | form: { |
| | | user: 'admin', |
| | | updateTime: '2023-10-10 09:16:41', |
| | | region: 'éå±±åº', |
| | | version: '1.0', |
| | | requestStartTime: '2023-10-12 08:43:00', |
| | | requestEndTime: null, |
| | | requestIntervalSeconds: 12, |
| | | requestRangeHour: 8, |
| | | requestRangeIntervalSeconds: 5, |
| | | requestFailWaitSeconds: 120, |
| | | requestRetryTimes: 4, |
| | | requestCookieValidDuration: 48, |
| | | staticsDailyTime: '2023-10-11 09:00:00', |
| | | staticsMonthlyTime: '2023-10-01 10:00:00', |
| | | loginFailWaitSeconds: 5, |
| | | loginRetryTimes: 5, |
| | | taskRetryWaitSeconds: 120, |
| | | firstRequestOffsetDays: 30 |
| | | }, |
| | | rules: { |
| | | requestIntervalSeconds: [{ validator: this.checkRequestIntervalSeconds, trigger: 'blur' }], |
| | | requestRangeHour: [ |
| | | { type: 'number', pattern: '/^\d+$/', message: '请è¾å
¥æ°å', trigger: 'blur' } |
| | | // {pattern:'/^[0-9]+$/'} |
| | | ] |
| | | // requestRangeIntervalSeconds: [{ validator: this.checkRequestRangeIntervalSeconds, trigger: 'blur' }], |
| | | // requestFailWaitSeconds: [{ validator: this.checkRequestFailWaitSeconds, trigger: 'blur' }], |
| | | // requestRetryTimes: [{ validator: this.checkRequestRetryTimes, trigger: 'blur' }], |
| | | // loginFailWaitSeconds: [{ validator: this.checkLoginFailWaitSeconds, trigger: 'blur' }], |
| | | // loginRetryTimes: [{ validator: this.checkLoginRetryTimes, trigger: 'blur' }], |
| | | // taskRetryWaitSeconds: [{ validator: this.checkTaskRetryWaitSeconds, trigger: 'blur' }], |
| | | // firstRequestOffsetDays: [{ validator: this.checkFirstRequestOffsetDays, trigger: 'blur' }], |
| | | } |
| | | form: {}, |
| | | requestIntervalSeconds: null, |
| | | maxVersion: null, |
| | | loading: false, |
| | | // ä¿®æ¹ç¶æ |
| | | modify: false, |
| | | // // è¡¨åæ°æ®æ¯å¦è¢«ä¿®æ¹ |
| | | // isFormModify:false, |
| | | } |
| | | }, |
| | | |
| | | mounted() { |
| | | // const { ...temp } = this.tableData |
| | | // this.form = temp |
| | | this.queryRequest() |
| | | }, |
| | | methods: { |
| | | // æäº¤ |
| | | /* submitForm() { |
| | | // åéä¿®æ¹çè¯·æ± |
| | | requestTaskSetting.submitRequestSetting(this.form) |
| | | /** |
| | | * æäº¤ |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | async submitForm() { |
| | | await requestTaskSetting.submitRequestSetting(this.formDataAfterCal) |
| | | |
| | | this.$message.success('æäº¤æå') |
| | | |
| | | |
| | | this.value = false |
| | | this.$message.success('æäº¤æå') |
| | | |
| | | |
| | | // æ°æ®æäº¤åå·æ°è¡¨å |
| | | this.queryRequest() |
| | | |
| | | }, */ |
| | | // ç½® 表åä¿®æ¹ç»ææ è®° |
| | | this.isFormModify = false |
| | | |
| | | async submitForm(formEl) { |
| | | if (!formEl) return |
| | | await formEl.validate((valid, fields) => { |
| | | if (valid) { |
| | | console.log('submit!') |
| | | } else { |
| | | console.log('error submit!', fields) |
| | | } |
| | | }, |
| | | |
| | | // åéå°é»è®¤é
ç½® |
| | | async defaultSetting() { |
| | | if (this.form.version == '1.0') { |
| | | this.$message.info('å½åå·²ç»æ¯é»è®¤ççæ¬') |
| | | return |
| | | } |
| | | this.loading = true |
| | | await requestTaskSetting.queryDefaultSetting().then((Response) => { |
| | | this.form = Response.data.data[0] |
| | | }) |
| | | this.modify = true |
| | | // 设置请æ±é
ç½®è¡¨çæ¬1.0 çæ´æ°æ¶é´ |
| | | requestTaskSetting.alertRequestSetting(this.formDataAfterCal) |
| | | this.modify = false |
| | | this.loading = false |
| | | |
| | | this.$message.success('åéæå') |
| | | }, |
| | | |
| | | /** |
| | | * æ¥è¯¢è¯·æ±è®¾ç½®çæ°æ® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | queryRequest() { |
| | | this.loading = true |
| | | requestTaskSetting.queryRequestSetting().then((Response) => { |
| | | this.loading = false |
| | | this.form = Response.data.data[0] |
| | | |
| | | // æ¾å°æå¤§ççæ¬ |
| | | const versions = Response.data.data.map((item) => item.version) |
| | | this.maxVersion = this.findMaxValue(versions) |
| | | }) |
| | | }, |
| | | |
| | | // åæ¶ |
| | | cancel_1() { |
| | | this.value = false |
| | | }, |
| | | |
| | | checkRequestIntervalSeconds(rule, value, callback) { |
| | | if (!value) { |
| | | return callback(new Error('请è¾å
¥ææå¼')) |
| | | } |
| | | setTimeout(() => { |
| | | if (!Number.isInteger(value)) { |
| | | callback(new Error('请è¾å
¥æ°å')) |
| | | } else { |
| | | if (value < 2 || value > 24) { |
| | | callback(new Error('èå´å¨2~24')) |
| | | } else { |
| | | callback() |
| | | } |
| | | } |
| | | }, 300) |
| | | /** |
| | | * åæ¶æé® |
| | | * @paramï¼ |
| | | * @returnsï¼ |
| | | */ |
| | | cancelEvent() { |
| | | this.$message.info('已忶') |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <template> |
| | | <el-dialog v-model="value" title="æ°æ®è·åé
ç½®åæ°ä¿®æ¹" close-delay="200" align-center> |
| | | <el-form :model="form" ref="ruleFormRef" label-width="210px" status-icon :rules="rules"> |
| | | |
| | | <div class="my-header"> |
| | | <el-text tag="b"> æ£å¨ä½¿ç¨ççæ¬ï¼{{ form.version }}</el-text> |
| | | </div> |
| | | <el-form :model="form" label-width="210px" status-icon v-loading="loading" > |
| | | <el-form-item label="ç¨æ·å"> |
| | | <el-input v-model="form.user" disabled /> |
| | | <el-input :value="userName" disabled /> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="åºå¿"> |
| | | <el-input :value="form.region" disabled /> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="å¼å§æ¶é´"> |
| | | <TimeSinglePicker |
| | | :selectedTime="form.requestStartTime" |
| | | :selected-time="form.requestStartTime" |
| | | :isUTC="true" |
| | | @submit-time="(n) => (form.requestStartTime = n)" |
| | | ></TimeSinglePicker> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="ç»ææ¶é´"> |
| | | <TimeSinglePicker |
| | | @submit-time="(n) => (form.requestEndTime = n)" |
| | | :selected-time="form.requestEndTime" |
| | | :isUTC="true" |
| | | @submit-time="(n) => (form.requestEndTime = n)" |
| | | ></TimeSinglePicker> |
| | | </el-form-item> |
| | | |
| | | <!-- ---------------------------------------------------------- --> |
| | | <el-form-item label="è·åé¢ç" prop="requestIntervalSeconds"> |
| | | <el-input v-model.number="form.requestIntervalSeconds"> |
| | | <el-input v-model.number="requestIntervalSeconds"> |
| | | <template #append>å°æ¶/次</template> |
| | | </el-input> |
| | | </el-form-item> |
| | |
| | | <template #append>次æ°</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="cookieæææ¶é¿" prop="requestCookieValidDuration"> |
| | | <el-input v-model.number="form.requestCookieValidDuration" :min="1" :max="10"> |
| | | <template #append>å°æ¶</template> |
| | | </el-input> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="æ¥ç»è®¡"> |
| | | <TimeSinglePicker |
| | | <OnlyTimePick |
| | | @submit-time="(n) => (form.staticsDailyTime = n)" |
| | | :isUTC="true" |
| | | :selected-time="form.staticsDailyTime" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="æç»è®¡"> |
| | | <TimeSinglePicker |
| | | <OnlyTimePick |
| | | @submit-time="(n) => (form.staticsMonthlyTime = n)" |
| | | :isUTC="true" |
| | | :selected-time="form.staticsMonthlyTime" |
| | | /> |
| | | </el-form-item> |
| | |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <template #footer> |
| | | <el-button @click="cancel_1">åæ¶</el-button> |
| | | <el-button type="primary" @click="submitForm(ruleFormRef)">æäº¤</el-button> |
| | | <el-popconfirm |
| | | confirm-button-text="ç¡®å®" |
| | | cancel-button-text="åæ¶" |
| | | icon-color="#626AEF" |
| | | title="确认åéåï¼" |
| | | @confirm="defaultSetting" |
| | | @cancel="cancelEvent" |
| | | > |
| | | <template #reference> |
| | | <el-button :disabled="form.version=='1.0'">åéå°é»è®¤è®¾ç½®</el-button> |
| | | </template> |
| | | </el-dialog> |
| | | </el-popconfirm> |
| | | |
| | | <el-popconfirm |
| | | confirm-button-text="ç¡®å®" |
| | | cancel-button-text="åæ¶" |
| | | icon-color="#626AEF" |
| | | title="确认修æ¹åï¼" |
| | | @confirm="submitForm" |
| | | @cancel="cancelEvent" |
| | | > |
| | | <template #reference> |
| | | <el-button type="primary">ä¿®æ¹</el-button> |
| | | </template> |
| | | </el-popconfirm> |
| | | </template> |
| | | |
| | | <style scoped> |
| | | /* .el-form { |
| | | display: flex; |
| | | flex-direction: column; |
| | | } |
| | | */ |
| | | /* .el-form-item { |
| | | display: flex; |
| | | margin-top: 5px; |
| | | } */ |
| | | /* .el-input { |
| | | width: 700px; |
| | | } |
| | | */ |
| | | .my-header { |
| | | margin-bottom: 20px; |
| | | } |
| | | span { |
| | | font-size: 16px; |
| | | color: #0a0a0a; |
| | | } |
| | | .version-text { |
| | | margin-left: 20px; |
| | | } |
| | | .el-input { |
| | | width: 50%; |
| | | } |
| | | </style> |
| | | |
| | | |