<template>
|
<div class="params-container">
|
<el-form
|
ref="ruleForm"
|
size="mini"
|
label-position="top"
|
:model="params"
|
:rules="rules"
|
class="params-dialog bg-white"
|
>
|
<el-form-item label="机房名称" prop="StationName">
|
<el-input
|
placeholder="请输入机房名称"
|
v-model="batt.StationName"
|
readonly="readonly"
|
>
|
</el-input>
|
</el-form-item>
|
<el-row :gutter="layout.gutter">
|
<el-col :span="layout.span" v-if="isSuperUser">
|
<el-form-item label="均衡类型">
|
<el-select v-model="junhengStyle">
|
<el-option label="单充" :value="0"></el-option>
|
<el-option label="可充可放" :value="1"></el-option>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="layout.span">
|
<el-form-item :label="junHengEnabledLabel" prop="junHengVol">
|
<el-input v-model="params.junHengVol"></el-input>
|
</el-form-item>
|
</el-col>
|
<el-col :span="layout.span">
|
<el-form-item label="均衡停止电压阀值(0~20)" prop="junHengStVol">
|
<el-input v-model="params.junHengStVol"></el-input>
|
</el-form-item>
|
</el-col>
|
<el-col :span="layout.span">
|
<el-form-item label="均衡停止电流阀值(0~5)" prop="junHengStCurr">
|
<el-input v-model="params.junHengStCurr"></el-input>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<div class="form-footer">
|
<three-btn @click="getParams(true)">读取</three-btn>
|
<three-btn :disabled="!setTestFlag" @click="submitFrom">设定</three-btn>
|
</div>
|
</el-form>
|
</div>
|
</template>
|
|
<script>
|
import { testVal } from "@/assets/js/tools";
|
import { const_system } from "@/assets/js/const";
|
|
export default {
|
props: {
|
batt: {
|
type: Object,
|
default() {
|
return {};
|
},
|
},
|
visible: {
|
type: Boolean,
|
default: false,
|
},
|
},
|
data() {
|
let cmd = const_system.balanceControl.cmd;
|
let rules = const_system.rules;
|
let max = (this.batt.MonVolStd * 1.1).toFixed(1);
|
rules.junHengVol.max = max;
|
rules.junHengVol.msg = "取值范围0~" + max + "V(保留三位小数)";
|
this.junHengEnabledLabel = "均衡电压(0~" + max + "V)";
|
let isSuperUser = sessionStorage.getItem("userId") == "1002" ? true : false;
|
return {
|
isSuperUser: isSuperUser,
|
high: 32768,
|
cmd: cmd,
|
setTestFlag: false, // 设置参数的状态
|
layout: {
|
span: 12,
|
gutter: 16,
|
},
|
params: {
|
op_cmd: 0,
|
junHengEnabled: 0, // 均衡功能启用状态(0:禁用)
|
junHengVol: 0, // 均衡电压
|
junHengStVol: 0, // 均衡停止电压阀值
|
junHengStCurr: 0, // 均衡停止电流阀值
|
},
|
junhengStyle: 0,
|
junHengEnabledLabel: "",
|
rules: {
|
junHengVol: [
|
{
|
validator(rule, value, callback) {
|
testVal(rule, value, callback, rules.junHengVol);
|
},
|
trigger: "change",
|
},
|
],
|
junHengStVol: [
|
{
|
validator(rule, value, callback) {
|
testVal(rule, value, callback, rules.junHengStVol);
|
},
|
trigger: "change",
|
},
|
],
|
junHengStCurr: [
|
{
|
validator(rule, value, callback) {
|
testVal(rule, value, callback, rules.junHengStCurr);
|
},
|
trigger: "change",
|
},
|
],
|
},
|
};
|
},
|
watch: {
|
junhengStyle(n) {
|
this.changeJunHengRange(n);
|
},
|
},
|
methods: {
|
// 初始化参数
|
initParams() {
|
this.params = {
|
op_cmd: 0,
|
junHengEnabled: 0, // 均衡功能启用状态(0:禁用)
|
junHengVol: 0, // 均衡电压值
|
junHengStVol: 0, // 均衡停止电压阀值
|
junHengStCurr: 0, // 均衡停止电流阀值
|
};
|
},
|
// 读取参数
|
getParams(showLoad) {
|
// 定义等待框
|
let loading;
|
if (showLoad) {
|
loading = this.$layer.loading(1);
|
}
|
|
// 查询后台
|
this.$apis.system.balanceControl
|
.getParams({
|
op_cmd: this.cmd.get,
|
dev_id: this.batt.FBSDeviceId,
|
})
|
.then((res) => {
|
let rs = JSON.parse(res.data.result);
|
if (rs.code == 1) {
|
let data = rs.data[0];
|
// 遍历参数属性并赋值
|
for (let key in this.params) {
|
if (key == "junHengVol") {
|
// 可充可放模式
|
if (data.junHengEnabled * 1000 > this.high) {
|
this.params.junHengVol =
|
(data.junHengEnabled * 1000 - this.high) / 1000;
|
this.junhengStyle = 1;
|
} else {
|
this.params.junHengVol = data.junHengEnabled;
|
this.junhengStyle = 0;
|
}
|
} else {
|
let value = data[key];
|
this.params[key] = value;
|
}
|
}
|
|
// 设置的命令和dev_id
|
this.params.num = this.cmd.set;
|
this.params.dev_id = this.batt.FBSDeviceId;
|
this.$layer.msg("读取成功!");
|
// 设置按钮可点击
|
this.setTestFlag = true;
|
} else {
|
// 初始化参数
|
this.initParams();
|
// 设置按钮不可点击
|
this.setTestFlag = false;
|
this.$layer.msg("读取失败!");
|
}
|
|
// 关闭等待框
|
this.$layer.close(loading);
|
})
|
.catch((error) => {
|
console.log(error);
|
// 初始化参数
|
this.initParams();
|
// 设置按钮不可点击
|
this.setTestFlag = false;
|
// 关闭等待框
|
this.$layer.close(loading);
|
this.$layer.msg("读取失败,读取请求异常!");
|
});
|
},
|
// 提交表单设置参数
|
submitFrom() {
|
this.$refs.ruleForm.validate((valid) => {
|
// 校验通过
|
if (valid) {
|
// 设置参数
|
this.setParams();
|
} else {
|
this.$layer.msg("存在校验未通过的数据!");
|
return false;
|
}
|
});
|
},
|
// 设置参数
|
setParams() {
|
let params = {};
|
let isSuperUser = this.isSuperUser;
|
// 遍历参数属性并赋值
|
for (let key in this.params) {
|
let value = this.params[key];
|
params[key] = value;
|
}
|
|
// 可充可放模式且必须为超级用户
|
if (this.junhengStyle && isSuperUser) {
|
params.junHengEnabled = (params.junHengVol * 1000 + this.high) / 1000;
|
} else {
|
params.junHengEnabled = params.junHengVol;
|
}
|
|
// 设置命令
|
params.op_cmd = this.cmd.set;
|
// 等待框
|
let loading = this.$layer.loading(1);
|
// 请求后台
|
this.$apis.system.balanceControl
|
.setParams(params)
|
.then((res) => {
|
let rs = JSON.parse(res.data.result);
|
if (rs.code == 1) {
|
// 启动按钮可点击
|
this.startTestFlag = true;
|
// 提示信息
|
this.$layer.msg("设置成功");
|
} else {
|
// 启动按钮不可点击
|
this.startTestFlag = false;
|
// 提示信息
|
this.$layer.msg("设置失败!");
|
}
|
// 关闭等待框
|
this.$layer.close(loading);
|
})
|
.catch((error) => {
|
console.log(error);
|
// 关闭等待框
|
this.$layer.close(loading);
|
// 启动按钮不可点击
|
this.startTestFlag = false;
|
// 提示信息
|
this.$layer.msg("设置失败,设置请求异常!");
|
});
|
},
|
changeJunHengRange(type) {
|
let rules = const_system.rules;
|
let isSuperUser = this.isSuperUser;
|
if (type && isSuperUser) {
|
rules.junHengVol.max = 30;
|
rules.junHengVol.msg = "取值范围0~" + 30 + "V(保留三位小数)";
|
this.junHengEnabledLabel = "均衡电压(0~" + 30 + "V)";
|
} else {
|
let max = (this.batt.MonVolStd * 1.1).toFixed(1);
|
rules.junHengVol.max = max;
|
rules.junHengVol.msg = "取值范围0~" + max + "V(保留三位小数)";
|
this.junHengEnabledLabel = "均衡电压(0~" + max + "V)";
|
}
|
|
this.rules.junHengVol = [
|
{
|
validator(rule, value, callback) {
|
testVal(rule, value, callback, rules.junHengVol);
|
},
|
trigger: "change",
|
},
|
];
|
// 清除提示
|
this.$refs.ruleForm.clearValidate();
|
},
|
},
|
mounted() {
|
// 获取参数
|
this.getParams(true);
|
this.changeJunHengRange(0);
|
},
|
beforeDestroy() {},
|
};
|
</script>
|
|
<style scoped>
|
.params-container {
|
width: 700px;
|
background-color: #ffffff;
|
}
|
.table-layout {
|
margin-top: 16px;
|
}
|
.bg-white .table-cell {
|
color: #000000;
|
}
|
</style>
|