This commit is contained in:
白菜
2025-07-13 16:13:45 +08:00
parent be1fb382ff
commit d0a31f9ee8
9 changed files with 521 additions and 258 deletions

View File

@ -1,19 +1,21 @@
<template>
<el-dialog :visible.sync="dialogTableVisible" class="ems-dialog" :title="mode === 'add'?'新增模板':`编辑${editTempName}` ">
<el-dialog :visible.sync="dialogTableVisible" class="ems-dialog" :title="mode === 'add'?'新增模板':`编辑模板` ">
<el-form ref="addTempForm" :model="formData" :rules="rules" size="medium" label-width="100px">
<el-form-item label="模板名称" prop="tempName">
<el-input v-model="formData.tempName" placeholder="请输入" clearable :style="{width: '100%'}">
<el-form-item label="模板名称" prop="templateName">
<el-input v-model="formData.templateName" placeholder="请输入" clearable :style="{width: '100%'}">
</el-input>
</el-form-item>
<el-form-item label="soc限制" prop="socStatus" required>
<el-switch v-model="formData.socStatus"></el-switch>
</el-form-item>
<el-form-item label="soc下限" prop="min">
<el-input v-model="formData.min" placeholder="请输入" clearable :style="{width: '100%'}"></el-input>
</el-form-item>
<el-form-item label="soc上限" prop="max">
<el-input v-model="formData.max" placeholder="请输入" clearable :style="{width: '100%'}"></el-input>
<el-form-item label="soc限制" prop="sdcLimit" required>
<el-switch :active-value="1" :inactive-value="0" v-model="formData.sdcLimit"></el-switch>
</el-form-item>
<!-- <template v-if="formData.sdcLimit === 1">-->
<el-form-item label="soc下限" prop="sdcDown">
<el-input v-model="formData.sdcDown" placeholder="请输入" clearable :style="{width: '100%'}"></el-input>
</el-form-item>
<el-form-item label="soc上限" prop="sdcUp">
<el-input v-model="formData.sdcUp" placeholder="请输入" clearable :style="{width: '100%'}"></el-input>
</el-form-item>
<!-- </template>-->
</el-form>
<el-button type="primary" size="mini" @click="addTime">新增</el-button>
<!-- 新增时间段表单-->
@ -38,17 +40,17 @@
:picker-options="{
start: '00:00',
step: '01:00',
end: '24:00',
minTime: formInline.startTime
end: '23:00',
}">
<!-- minTime: formInline.startTime-->
</el-time-select>
</el-form-item>
<el-form-item label="冲放功率" prop="cfgl">
<el-input v-model="formInline.cfgl" placeholder="请输入"></el-input>
<el-form-item label="冲放功率" prop="chargeDischargePower">
<el-input v-model="formInline.chargeDischargePower" placeholder="请输入"></el-input>
</el-form-item>
<el-form-item label="充电状态" prop="powerStatus">
<el-select v-model="formInline.powerStatus" placeholder="请选择">
<el-option v-for="(item,index) in powerStatusOptions" :key="index+'powerStatusOptions'" :label="item.label" :value="item.value"></el-option>
<el-form-item label="充电状态" prop="chargeStatus">
<el-select v-model="formInline.chargeStatus" placeholder="请选择">
<el-option v-for="(value,key) in chargeStatusOptions" :key="key+'chargeStatusOptions'" :label="value" :value="key"></el-option>
</el-select>
</el-form-item>
<el-form-item>
@ -72,14 +74,14 @@
label="结束时间">
</el-table-column>
<el-table-column
prop="cfgl"
prop="chargeDischargePower"
label="充放功率kW">
</el-table-column>
<el-table-column
prop="powerStatus"
prop="chargeStatus"
label="充电状态">
<template slot-scope="scope">
{{scope.row.powerStatus === 1 ? '充电' :'放电'}}
{{chargeStatusOptions[scope.row.chargeStatus]}}
</template>
</el-table-column>
<el-table-column
@ -103,50 +105,39 @@
</el-dialog>
</template>
<script>
import {mapState} from 'vuex'
import {addStrategyTemp,editStrategyTemp,getStrategyTempDetail} from '@/api/ems/dzjk'
export default {
props:{
mode:{
type:String,
default:"add"
},
editTempId:{
type:Number,
default:''
},
editTempName:{
type:String,
default:''
}
},
inject:['$home'],
data() {
return {
mode:'',
editTempId:'',
dialogTableVisible:false,
formData: {
tempName: '',
socStatus: false,
min: '',
max: '',
templateName: '',
sdcLimit: false,
sdcDown: '',
sdcUp: '',
},
rules: {
tempName: [{
required: true,
message: '请输入',
trigger: 'blur'
}],
min: [{
required: true,
message: '请输入',
trigger: 'blur'
}],
max: [{
templateName: [{
required: true,
message: '请输入',
trigger: 'blur'
}],
sdcDown: [
{required: true,message: '请输入', trigger: 'blur'},
{ pattern: /^(0|[1-9]\d*)(\.\d+)?$/, message: '请输入合法数字或小数' }
],
sdcUp: [
{required: true,message: '请输入', trigger: 'blur'},
{ pattern: /^(0|[1-9]\d*)(\.\d+)?$/, message: '请输入合法数字或小数' }
],
},
showAddTime: false,
formInline:{
startTime:'',endTime:'',cfgl:'',powerStatus:1
startTime:'',endTime:'',chargeDischargePower:'',chargeStatus:''
},
formInlineRule:{
startTime: [{
@ -159,17 +150,28 @@ export default {
message: '请选择结束时间',
trigger: 'change'
}],
cfgl: [{
chargeDischargePower: [{
required: true,
message: '请输入冲放功率',
trigger: 'blur'
},
{ pattern: /^(0|[1-9]\d*)(\.\d+)?$/, message: '请输入合法数字或小数' }
],
chargeStatus:[{
required: true,
message: '请输入冲放功率',
trigger: 'blur'
}],
message: '请选择充放状态',
trigger: ['blur','change']
}
]
},
tableData:[],
powerStatusOptions:[{label:'充电',value:1},{label:'放电',value:2}],
}
},
computed: {},
computed: {
...mapState({
chargeStatusOptions: state => state?.ems?.chargeStatusOptions || {},
})
},
watch: {
"formInline.startTime":{
handler(newVal,oldVal){
@ -182,18 +184,61 @@ export default {
}
},
deep:true
}
},
},
created() {},
mounted() {},
methods: {
changeSiteId(){
this.dialogTableVisible=false
this.mode=''
this.editTempId=''
this.formData={
templateName: '',
sdcLimit: false,
sdcDown: '',
sdcUp: '',
}
this.formInline={
startTime:'',endTime:'',chargeDischargePower:'',chargeStatus:''
}
this.showAddTime = false
this.tableData=[]
},
show({mode = 'add', editTempId = ''}){
this.$nextTick(() => {
this.dialogTableVisible = true
this.mode = mode
this.editTempId=editTempId
if(mode === 'edit' && editTempId){
getStrategyTempDetail(this.editTempId).then(response => {
const data=JSON.parse(JSON.stringify(response?.data || []));
if(data.length>0){
const {templateName,sdcLimit,sdcDown,sdcUp} =JSON.parse(JSON.stringify( data[0]));
this.formData.templateName=templateName
this.formData.sdcLimit=sdcLimit
this.formData.sdcDown=sdcDown
this.formData.sdcUp=sdcUp
}
if(data.length === 1){
const {startTime,endTime}=data;
if(!startTime || !endTime){
this.tableData = []
}else{
this.tableData= data
}
}else{
this.tableData= data
}
})
}
})
},
addTime(){
this.showAddTime=true
},
cancelAddTime(){
this.$refs.addTimeForm.resetFields()
this.showAddTime=false
this.formInline = {startTime:'',endTime:'',cfgl:'',powerStatus:1}
this.formInline = {startTime:'',endTime:'',chargeDischargePower:'',chargeStatus:''}
},
saveTime(){
//表单校验校验成功添加到tableData里
@ -209,17 +254,36 @@ export default {
saveDialog() {
this.$refs.addTempForm.validate(valid => {
if (!valid) return
this.closeDialog()
const {templateName,sdcLimit,sdcDown,sdcUp} = this.formData
const {siteId,updateStrategyId} =this.$home
const {tableData} = this
if(this.mode==='edit'){
editStrategyTemp({siteId,strategyId:updateStrategyId,templateId:this.editTempId,templateName,sdcLimit,sdcDown,sdcUp,timeConfigList:tableData}).then(response=>{
if(response?.code === 200){
this.closeDialog()
this.$emit('update')
this.$emit('updateTimeSetting')
}
})
}else{
addStrategyTemp({siteId,strategyId:updateStrategyId,templateName,sdcLimit,sdcDown,sdcUp,timeConfigList:tableData}).then(response=>{
if(response?.code === 200){
this.closeDialog()
this.$emit('update')
}
})
}
})
},
closeDialog(){
// 清空所有数据
this.$refs.addTempForm.resetFields()
this.formData={
tempName: '',
socStatus: false,
min: '',
max: '',
templateName: '',
sdcLimit:0,
sdcDown: '',
sdcUp: '',
}
this.tableData=[]
this.cancelAddTime()
@ -229,15 +293,3 @@ export default {
}
</script>
<style scoped>
.ems-dialog{
.el-dialog{
max-width: 700px;
}
.add-time-form{
.el-input{
width: 220px;
}
}
}
</style>