场景模型测试工具
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

690 lines
20 KiB

<template>
<div class="bod">
<div class="inp">
<div class="til">占比</div>
<el-form :model="addForm" label-width="88px">
<el-row>
<el-col :span="4.5" >
<el-form-item label="效率占比" prop="devPower" label-width="210px">
<el-input v-model="addForm.devPower" placeholder="效率占比,默认值为0.8"/>
</el-form-item>
</el-col>
<el-col :span="4.5" >
<el-form-item label="成本占比" prop="devPrice" label-width="280px">
<el-input v-model="addForm.devPrice" placeholder="成本占比,默认值为0.2"/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div class="til">需求信息</div>
<el-form :model="addForm" ref="ruleForm1" :rules="rules" label-width="88px">
<el-row>
<el-col :span="6">
<el-form-item label="工作容积(升):" prop="workArea" label-width="230px">
<el-input v-model="addForm.workArea"/>
</el-form-item>
</el-col>
<el-col :span="7">
<el-form-item label="预计年产量(吨):" prop="yearOutPut" label-width="290px">
<el-input v-model="addForm.yearOutPut"/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div class="til">原设备信息</div>
<el-form :model="addForm" ref="ruleForm3" :rules="rules" label-width="88px">
<el-row>
<el-col :span="6">
<el-form-item label="上年运行费用(元):" prop="lastYearFee" label-width="230px">
<el-input v-model="addForm.lastYearFee"/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div class="til">配电信息</div>
<el-form :model="addForm" ref="ruleForm2" :rules="rules" label-width="88px">
<el-row>
<el-col :span="6">
<el-form-item label="变压器运行总容量(kVA):" prop="runCapacity" label-width="230px">
<el-input v-model="addForm.runCapacity"/>
</el-form-item>
</el-col>
<el-col :span="7">
<el-form-item label="上年最大需量(kW):" prop="lastYearNeed" label-width="290px">
<el-input v-model="addForm.lastYearNeed"/>
</el-form-item>
</el-col>
<el-divider></el-divider>
<el-col :span="8">
<el-form-item label="密钥:" prop="key" label-width="110px">
<el-input v-model="addForm.key"/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div class="bot">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</div>
<div class="result" v-if="show2">
<div class="til">方案评分</div>
<div class="point">
<el-form ref="userRef" label-width="300px">
<el-row>
<el-col :span="8" v-for="(item,index) in result.matchedDeviceList" :key="index" >
<el-form-item :label="item.planName">
<el-rate
v-model="item.rat"
disabled
show-score
:score-template="item.rating"
text-color="#ffffff"
class="rate"
/>
</el-form-item>
</el-col>
</el-row>
</el-form>
</div>
</div>
<div class="result" v-if="show1">
<div class="til">
方案详情
</div>
<div class="info">
<div class="card">
整体情况
</div>
<div class="card">
<el-form :model="result" label-width="140px">
<el-row>
<el-col :span="4" style="margin-left: 70px">
<el-form-item label="初次投资费用(元):" prop="sceneName">
<el-input v-model="result.startCost" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="4">
<el-form-item label="年运行费用(元):" prop="sceneName">
<el-input v-model="result.yearRunCost" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="4">
<el-form-item label="年总费用(元):" prop="sceneName">
<el-input v-model="result.yearCost" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="4">
<el-form-item label="年减碳量(吨):" prop="sceneName">
<el-input v-model="result.calculate" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="4">
<el-form-item label="替代电量(千瓦时):" prop="sceneName">
<el-input v-model="result.electric" placeholder=""/>
</el-form-item>
</el-col>
</el-row>
</el-form>
</div>
<div class="card">
方案优势
</div>
<div class="card">
<el-form :model="result" label-width="140px">
<el-row>
<el-col :span="5">
<el-form-item label="安全性:" prop="sceneName">
<el-input v-model="result.safety" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="5">
<el-form-item label="环保性:" prop="sceneName">
<el-input v-model="result.environment" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="经济性:" prop="sceneName">
<el-input v-model="result.economy" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="智能性:" prop="sceneName">
<el-input v-model="result.intelligence" placeholder=""/>
</el-form-item>
</el-col>
</el-row>
</el-form>
</div>
<div class="card">
需配置设备情况
</div>
<div class="card">
<el-form :model="result" label-width="140px">
<el-row v-for="(item,index) in result.deviceList" :key="index">
<el-col :span="6">
<el-form-item label="设备细类:" prop="sceneName">
<el-input v-model="item.devSubType" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="技术类型:" prop="sceneName">
<el-input v-model="item.devTechType" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="数量(台/套):" prop="sceneName">
<el-input v-model="item.devCount" placeholder=""/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="设备单价(元):" prop="sceneName">
<el-input v-model="item.devPrice" placeholder=""/>
</el-form-item>
</el-col>
</el-row>
</el-form>
</div>
<div class="card">
Json
</div>
<div>
<json-viewer :value="textarea"></json-viewer>
</div>
</div>
</div>
<div class="inp">
<div class="til">产品库</div>
<el-form :model="addForm" ref="ruleForm1" :rules="rules" label-width="88px">
<el-row>
<el-col :span="4.5" v-for="(item,index) in options" :key="index">
<el-form-item :label="item.devTechType" prop="" label-width="300px">
</el-form-item>
</el-col>
</el-row>
</el-form>
</div>
</div>
</template>
<script setup>
import {ElMessage, ElMessageBox} from 'element-plus'
import {ref, reactive, watch, onMounted} from "vue";
import {modelTest,getDevList} from '../../../api/emonitor/api'
const textarea = ref('')
const open = ref(true)
const arr = ref([1])
const point = ref(3.7)
const point1 = ref('78')
const show1 = ref(false)
const show2 = ref(false)
const test1 = ref(null)
const test2= ref(null)
const test3 = ref(null)
const test4 = ref(null)
const test5 = ref(null)
const test6 = ref(null)
const test7 = ref(null)
const test8 = ref(null)
const test9 = ref(null)
const test10 = ref(null)
const test11 = ref(null)
const test12 = ref(null)
const test13 = ref(null)
const role1 = ref(false)
const role2 = ref(false)
const role3 = ref(false)
onMounted(()=>{
getDevList('0104').then((res)=>{
options.value=res.data
})
})
const devSpecList = ref([
{
"devType": '',
"heatEfficiency":'',
"devTechType": '',
"devSubstituteLaborCost":'',
"devReferenceArea":'',
"devPower":'' ,
"devSubType": '',
"devPrice":'' ,
"devServiceLife":'',
"laborCost":'' ,
"id": "1"
}
])
function addDev (){
devSpecList.value.push({
"devType": '',
"heatEfficiency":'',
"devTechType": '',
"devSubstituteLaborCost":'',
"devReferenceArea":'',
"devPower":'' ,
"devSubType": '',
"devPrice":'' ,
"devServiceLife":'',
"laborCost":'' ,
"id": "1"
})
}
function delDev (){
devSpecList.value.pop()
}
const options = ref([{
label: '电锅炉', value: 1
}, {label: '热泵', value: 2}])
const options3 = ref([{
label: '专变', value: 1
}, {label: '公变', value: 2}])
const options4 = ref([{
label: '机关', value: 1},
{label: '医院', value: 2},
{label: '学校', value: 3},
{label: '商业办公楼', value: 4},
{label: '酒店', value: 5},
{label: '其他', value: 6},
])
const options5 = ref([{
label: '风机盘管', value: 1},
{label: '地暖', value: 2},
{label: '暖气片', value: 3},
{label: '无末端', value: 4},
])
const options6 = ref([{
label: '是', value: 1
}, {label: '否', value: 2}])
const options7 = ref([{
label: '供暖', value: 1
}, {label: '供冷', value: 2},{label: '热水s', value: 3}])
const options8 = ref([{
label: '煤', value: 1},
{label: '油', value: 2},
{label: '气', value: 3},
{label: '汽', value: 4},
])
const options1 = ref([{
label: '供冷电锅炉', value: 1
},
{label: '供暖电锅炉', value: 2},
{label: '工业供热电锅炉', value: 3},
{label: '供暖', value: 4},
{label: '供冷', value: 5},
])
const options2 = ref([
{label: '直热式电锅炉(电阻类)', value: 1},
{label: '直热式电锅炉(电极类)', value: 2},
{label: '直热式电锅炉(电磁涡流类)', value: 3},
{label: '蓄热式电锅炉(固体蓄热)', value: 4},
{label: '蓄热式电锅炉(相变蓄热)', value: 5},
{label: '蓄热式电锅炉(水蓄)', value: 6},
{label: '水源热泵', value: 7},
{label: '土壤源热泵', value: 8},
{label: '空气源热泵', value: 9},
{label: '低品位余热源(如电厂低温循环水)热泵', value: 10},
{label: '高温蒸汽热泵', value: 11},
])
const ruleForm1 = ref({
key: '',
devType: '',
devSubType: '',
devTechType: '',
devPower: '',
devPrice: '',
devSubstituteLaborCost: '',
laborCost: '',
devReferenceArea: '',
devServiceLife: '',
devAnnualOperationTime: '',
heatEfficiency: '',
remarkInfo: '',
workArea: '',
yearOutPut: '',
})
const ruleForm2 = ref({
runCapacity: '',
lastYearNeed: '',
})
const ruleForm3 = ref({
heatingArea: '',
days: '',
lastYearFee: '',
hotMedium: '',
type: '',
previousYearEnergyUsage: '',
})
const rules = reactive({
devType: [
{ required: true, message: '请选择产品库', trigger: 'change' },
],
previousYearEnergyUsage: [
{ required: true, message: '请输入替代前年能源用量', trigger: 'blur' },
],
workArea: [
{ required: true, message: '请输入工作容积', trigger: 'blur' },
],
yearOutPut: [
{ required: true, message: '请输入预计年产量', trigger: 'blur' },
],
devSubType: [
{ required: true, message: '请选择设备细类', trigger: 'change' },
],
devTechType: [
{ required: true, message: '请选择技术类型', trigger: 'change' },
],
devPower: [
{ required: true, message: '请输入效率占比', trigger: 'blur' },
],
devPrice: [
{ required: true, message: '请输入成本占比', trigger: 'blur' },
],
devSubstituteLaborCost: [
{ required: true, message: '请输入电替代设备年人工费用', trigger: 'blur' },
],
laborCost: [
{ required: true, message: '请输入原设备的人工费用', trigger: 'blur' },
],
devReferenceArea: [
{ required: true, message: '请输入单台电设备参考的可供暖面积', trigger: 'blur' },
],
devServiceLife: [
{ required: true, message: '请输入设备使用年限', trigger: 'blur' },
],
devAnnualOperationTime: [
{ required: true, message: '请输入设备年运行时长', trigger: 'blur' },
],
heatEfficiency: [
{ required: true, message: '请输入热效率', trigger: 'blur' },
],
remarkInfo: [
{ required: true, message: '请输入备注', trigger: 'blur' },
],
runCapacity: [
{ required: true, message: '请输入变压器运行总容量', trigger: 'blur' },
],
lastYearNeed: [
{ required: true, message: '请输入上年最大需量', trigger: 'blur' },
],
heatingArea: [
{ required: true, message: '请输入建筑面积', trigger: 'blur' },
],
days: [
{ required: true, message: '请输入年采暖时间', trigger: 'blur' },
],
lastYearFee: [
{ required: true, message: '请输入上年运行费用', trigger: 'blur' },
],
hotMedium: [
{ required: true, message: '请输入模型编码', trigger: 'blur' },
],
type: [
{ required: true, message: '请输入场景编码', trigger: 'blur' },
],
key: [
{ required: true, message: '请输入密钥', trigger: 'blur' },
],
})
const addForm = reactive({
id: null,
key:"BEjYotMIsJnTb29NZPfk973npvgw8AXPGAoe1c4RQSL2MAlo0SVUiAL5SE5tEeWLVpzWpaQTY4iqakUY4CsKuVdVc/jeJNjHCoSCtXikiR8jdTDgwMP0AUIZBhFjfg3+80XK48inw2WYvDkH4NCsU2DbeEWGCrHFHl+usA6c/MTl2xbm9tt/4vETVcaUy4r5LuDIJ777lu6AIv9Lq7I392Dkx8+oEuzODBHYq2BNIN70+e/lgeYIm4lpEzzyRU47",
devType: null,//电锅炉or热泵
devSubType: null,
devTechType: null,
heatEfficiency: null,
devPower: 0.8,
devPrice: 0.2,
devSubstituteLaborCost: null,
laborCost: null,
devReferenceArea: null,
devServiceLife: null,
devAnnualOperationTime: null,
remarkInfo: null,
lastYearFee: null,
heatingArea: null,
days: null,
hotMedium: null,
type: null,
lastYearNeed: null,
workArea: null,
yearOutPut: null,
previousYearEnergyUsage: null,
runCapacity: null,
})
const result = ref({
calculate:'',
devCost:'',
devCount:'',
devPrice:'',
devSubType:'',
devTechType:'',
economy:'',
electric:'',
environment:'',
intelligence:'',
matchedDeviceList:[],
planInfos:'',
startCost:'',
yearCost:'',
yearRunCost:'',
safety:'',
deviceList:[],
})
watch(() => addForm.devType, (newVale, oldValue) => {
if (addForm.devType === 1) {
options1.value = [
{label: '供冷电锅炉', value: 1},
{label: '供暖电锅炉', value: 2},
{label: '工业供热电锅炉', value: 3},
]
options2.value = [
{label: '直热式电锅炉(电阻类)', value: 1},
{label: '直热式电锅炉(电极类)', value: 2},
{label: '直热式电锅炉(电磁涡流类)', value: 3},
{label: '蓄热式电锅炉(固体蓄热)', value: 4},
{label: '蓄热式电锅炉(相变蓄热)', value: 5},
{label: '蓄热式电锅炉(水蓄)', value: 6},
]
} else if (addForm.devType === 2) {
options1.value = [
{label: '供暖', value: 4},
{label: '供冷', value: 5},
]
options2.value = [
{label: '水源热泵', value: 7},
{label: '土壤源热泵', value: 8},
{label: '空气源热泵', value: 9},
{label: '低品位余热源(如电厂低温循环水)热泵', value: 10},
{label: '高温蒸汽热泵', value: 11},
]
}
})
const submitForm = () => {
ruleForm1.value.validate((valid) => {
if (valid) {
// 表单验证通过,执行计算逻辑
role1.value=true
// 你可以在这里调用计算函数或者进行其他操作
} else {
// 表单验证失败
role1.value=false
return false;
}
});
ruleForm2.value.validate((valid) => {
if (valid) {
// 表单验证通过,执行计算逻辑
role2.value=true
// 你可以在这里调用计算函数或者进行其他操作
} else {
// 表单验证失败
role2.value=false
return false;
}
});
ruleForm3.value.validate((valid) => {
if (valid) {
// 表单验证通过,执行计算逻辑
role3.value=true
// 你可以在这里调用计算函数或者进行其他操作
} else {
// 表单验证失败
role3.value=false
return false;
}
});
setTimeout(()=>{
addForm.devPower= +addForm.devPower
addForm.devPrice= +addForm.devPrice
console.log(addForm.devPower,addForm.devPrice,addForm.devPower+addForm.devPrice)
if(addForm.devPower+addForm.devPrice==1){
if (role1.value&&role2.value&&role3.value){
console.log('表单验证通过')
modelTest(
{
"param": {
"type": "0104",
"heatUseNeedInfo": {
"workArea": addForm.workArea,
"yearOutPut": addForm.yearOutPut
},
"originalDevInfo": {
"lastYearFee": addForm.lastYearFee
},
"distInfo": {
"lastYearNeed": addForm.lastYearNeed,
"runCapacity": addForm.runCapacity
}
},
"key": addForm.key
}
).then((res)=>{
console.log(res)
if(res.report.message){
ElMessage({
message: res.report.message,
type: 'error',
})
}else{
if(res.report===null || res.report==={}){
ElMessage({
message: '计算失败,请检查密钥是否准确',
type: 'error',
})
}else{
result.value=res.report
textarea.value=res.report
show1.value = true
}
}
})
}else{
console.log('表表单验证失败')
}
}else{
ElMessage({
message: '效率占比和成本占比相加必须为1',
type: 'error',
})
}
},1000)
};
function cancel() {
ruleForm1.value.resetFields();
ruleForm2.value.resetFields();
ruleForm3.value.resetFields();
show1.value = false
addForm.devType = null
addForm.heatEfficiency = null
addForm.devTechType = null
addForm.devSubstituteLaborCost = null
addForm.devReferenceArea = null
addForm.devPower = 0.8
addForm.devSubType = null
addForm.devPrice = 0.2
addForm.devServiceLife = null
addForm.laborCost = null
addForm.lastYearFee = null
addForm.heatingArea = null
addForm.days = null
addForm.hotMedium = null
addForm.type = null
addForm.lastYearNeed = null
addForm.runCapacity = null
addForm.key = null
addForm.workArea = null
addForm.yearOutPut = null
addForm.previousYearEnergyUsage = null
devSpecList.value=[
{
"devType": '',
"heatEfficiency":'',
"devTechType": '',
"devSubstituteLaborCost":'',
"devReferenceArea":'',
"devPower":'' ,
"devSubType": '',
"devPrice":'' ,
"devServiceLife":'',
"laborCost":'' ,
"id": "1"
}
]
};
</script>
<style scoped lang="scss">
.rate {
--el-rate-text-color: #ff9900;
}
.bod {
padding: 20px;
height: 91vh;
overflow-y: auto;
.inp {
border: 1px solid white;
padding: 20px;
.til {
font-size: 16px;
color: #ff9900;
margin-bottom: 20px;
}
.bot{
text-align: right;
}
}
.result {
margin-top: 20px;
border: 1px solid white;
padding: 20px;
.point {
}
.til {
font-size: 16px;
color: #ff9900;
margin-bottom: 20px;
}
.info {
.card {
margin-top: 20px;
}
}
}
}
</style>