|
|
<template>
|
|
|
<div class="container">
|
|
|
<!-- 顶部信息 -->
|
|
|
<div class="containertop">
|
|
|
<div class="topleft">
|
|
|
<img src="../../../assets/images/detailsicon/1.png" alt="">
|
|
|
<span>五要素模型信息</span>
|
|
|
</div>
|
|
|
<div class="topright" v-if="action === 'fill' || !action">
|
|
|
<el-button type="primary" size="medium" plain
|
|
|
style="border: none;background-color: rgba(43,98,241,0.1);color: #2B62F1;" @click="toggleEditAll">
|
|
|
<img src="../../../assets/images/detailsicon/icon-bj@2x.png" alt="编辑"
|
|
|
style="width: 0.6rem; height: 0.6rem; margin-right: 4px;">
|
|
|
{{ isEditingAll ? '保存' : '编辑' }}
|
|
|
</el-button>
|
|
|
</div>
|
|
|
</div>
|
|
|
<!-- 内容区 -->
|
|
|
<div class="content">
|
|
|
<div class="descriptionsdiv">
|
|
|
<div>
|
|
|
<table class="custom-table">
|
|
|
<tr v-for="(row, rowIndex) in form" :key="rowIndex" style="border: 1px solid #E5E5E5;">
|
|
|
<td class="left-column">{{ row.ysmc }}</td>
|
|
|
<td class="right-columns" v-for="(item, itemIndex) in row.list" :key="itemIndex">
|
|
|
<div v-if="item.isEditing">
|
|
|
<span class="label-color">{{ item.zdname }}:</span>
|
|
|
<el-input v-model="item.zdinfor" size="small" style="width: 12rem;"></el-input>
|
|
|
</div>
|
|
|
<div v-else>
|
|
|
<span class="label-color">{{ item.zdname }}:</span> {{ item.zdinfor || '无' }}
|
|
|
</div>
|
|
|
</td>
|
|
|
</tr>
|
|
|
</table>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
export default {
|
|
|
name: "Models",
|
|
|
props: {
|
|
|
wysmxInfo: {
|
|
|
type: Array,
|
|
|
required: true,
|
|
|
},
|
|
|
action: {
|
|
|
type: String,
|
|
|
required: true
|
|
|
}
|
|
|
},
|
|
|
data() {
|
|
|
return {
|
|
|
isEditingAll: false,
|
|
|
form: []
|
|
|
};
|
|
|
},
|
|
|
watch: {
|
|
|
wysmxInfo: {
|
|
|
immediate: true,
|
|
|
handler(newVal) {
|
|
|
console.log('接收到的 wysmxInfo 数据:', newVal);
|
|
|
this.form = newVal.map(item => ({
|
|
|
id: item.id,
|
|
|
xmId: item.xmId,
|
|
|
ysmc: item.ysmc,
|
|
|
list: item.list.map(subItem => ({
|
|
|
zdname: subItem.zdname,
|
|
|
zdinfor: subItem.zdinfor,
|
|
|
isEditing: false
|
|
|
}))
|
|
|
}));
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
methods: {
|
|
|
toggleEditAll() {
|
|
|
if (this.isEditingAll) {
|
|
|
// 保存模式:过滤掉 isEditing 字段
|
|
|
const cleanedForm = this.form.map(row => ({
|
|
|
ysmc: row.ysmc,
|
|
|
id: row.id,
|
|
|
xmId: row.xmId,
|
|
|
list: row.list.map(item => ({
|
|
|
zdname: item.zdname,
|
|
|
zdinfor: item.zdinfor,
|
|
|
}))
|
|
|
}));
|
|
|
this.$emit('updata-data', cleanedForm); // 传递过滤后的数据
|
|
|
} else {
|
|
|
// 编辑模式:开启所有字段的编辑状态
|
|
|
this.form.forEach(row => {
|
|
|
row.list.forEach(item => {
|
|
|
item.isEditing = true;
|
|
|
});
|
|
|
});
|
|
|
}
|
|
|
this.isEditingAll = !this.isEditingAll;
|
|
|
}
|
|
|
},
|
|
|
created() {
|
|
|
console.log('wysmxInfo 内容:', this.wysmxInfo); // 初始化时打印数据
|
|
|
}
|
|
|
};
|
|
|
</script>
|
|
|
|
|
|
<style scoped>
|
|
|
.container {
|
|
|
display: flex;
|
|
|
flex-direction: column;
|
|
|
width: 100%;
|
|
|
background-color: #FFFFFF;
|
|
|
box-shadow: 0rem 0.13rem 0.63rem 0rem rgba(177, 177, 177, 0.1);
|
|
|
border-radius: 0.5rem 0.5rem 0.5rem 0.5rem;
|
|
|
}
|
|
|
|
|
|
.content {
|
|
|
padding: 1rem;
|
|
|
display: flex;
|
|
|
}
|
|
|
|
|
|
.containertop {
|
|
|
height: auto;
|
|
|
display: flex;
|
|
|
justify-content: space-between;
|
|
|
padding: .7rem 0;
|
|
|
padding: .5rem;
|
|
|
border-bottom: 1px solid #E5E5E5;
|
|
|
}
|
|
|
|
|
|
.topleft {
|
|
|
width: 8rem;
|
|
|
height: 2rem;
|
|
|
display: flex;
|
|
|
gap: 0.4rem;
|
|
|
align-items: center;
|
|
|
}
|
|
|
|
|
|
.topleft img {
|
|
|
width: 0.81rem;
|
|
|
height: 0.81rem;
|
|
|
}
|
|
|
|
|
|
.topleft span {
|
|
|
width: auto;
|
|
|
height: 0.88rem;
|
|
|
font-family: AlibabaPuHuiTi, AlibabaPuHuiTi;
|
|
|
font-weight: 500;
|
|
|
font-size: 0.88rem;
|
|
|
color: #3D424C;
|
|
|
line-height: 0.88rem;
|
|
|
text-align: right;
|
|
|
font-style: normal;
|
|
|
text-transform: none;
|
|
|
}
|
|
|
|
|
|
.picturediv {
|
|
|
width: 18.31rem;
|
|
|
height: 25.31rem;
|
|
|
background-color: lightblue;
|
|
|
}
|
|
|
|
|
|
.descriptionsdiv {
|
|
|
width: 100%;
|
|
|
margin-left: 1rem;
|
|
|
height: auto;
|
|
|
}
|
|
|
|
|
|
.two-row-item {
|
|
|
height: 20rem;
|
|
|
}
|
|
|
|
|
|
.custom-table {
|
|
|
width: 100%;
|
|
|
border-collapse: collapse;
|
|
|
border: 1px solid #E6EAF2;
|
|
|
}
|
|
|
|
|
|
.custom-table th,
|
|
|
.custom-table td {
|
|
|
padding: 8px;
|
|
|
text-align: left;
|
|
|
border-top: 1px solid #E6EAF2;
|
|
|
border-bottom: 1px solid #E6EAF2;
|
|
|
}
|
|
|
|
|
|
.left-column {
|
|
|
border-right: 1px solid #E6EAF2;
|
|
|
background-color: #F4F7FE;
|
|
|
}
|
|
|
|
|
|
.right-columns {
|
|
|
border-right: none;
|
|
|
}
|
|
|
|
|
|
.label-color {
|
|
|
color: #808080;
|
|
|
}
|
|
|
</style> |