Files
klp-oa/klp-ui/src/components/KLPService/Renderer/RawMaterialInfo.vue

84 lines
2.8 KiB
Vue
Raw Normal View History

2025-07-28 18:25:02 +08:00
<template>
<div>
<!-- 原材料名称仅hover触发popover -->
<el-popover
trigger="hover"
placement="top"
width="400"
:visible-arrow="true"
append-to-body
popper-class="raw-material-info-popover"
>
<!-- popover 内容两列布局的描述列表 -->
<el-descriptions :column="2" class="popover-content">
<el-descriptions-item label="原材料名称">{{ materialFull.rawMaterialName || '--' }}</el-descriptions-item>
<el-descriptions-item label="原材料编码">{{ materialFull.rawMaterialCode || '--' }}</el-descriptions-item>
<el-descriptions-item label="规格">{{ materialFull.specification || '--' }}</el-descriptions-item>
<el-descriptions-item label="材质">{{ materialFull.material || '--' }}</el-descriptions-item>
<el-descriptions-item label="表面处理">{{ materialFull.surfaceTreatment || '--' }}</el-descriptions-item>
<el-descriptions-item label="锌层">{{ materialFull.zincLayer || '--' }}</el-descriptions-item>
<el-descriptions-item label="厂家">{{ materialFull.manufacturer || '--' }}</el-descriptions-item>
2025-07-29 15:16:51 +08:00
</el-descriptions>
<!-- 触发元素原材料名称文本 -->
<span slot="reference" class="material-name">
<slot name="default" :material="materialFull">
{{ materialFull.rawMaterialName || '未知' }}[{{ materialFull.specification || '无规格' }}] - (材质{{ materialFull.material || '无材质' }})
</slot>
</span>
</el-popover>
2025-07-28 18:25:02 +08:00
</div>
</template>
<script>
import BomInfo from './BomInfo.vue'; // 保留导入(如需使用可解除注释)
2025-07-29 16:57:16 +08:00
2025-07-28 18:25:02 +08:00
export default {
name: 'RawMaterialInfo',
2025-07-29 16:57:16 +08:00
components: {
BomInfo
},
2025-07-28 18:25:02 +08:00
props: {
material: {
type: Object,
default: () => ({})
2025-07-28 18:25:02 +08:00
}
},
data() {
return {
// 移除showDetailhover触发无需弹窗控制变量
2025-07-28 18:25:02 +08:00
};
},
computed: {
materialFull() {
// 完整的material确保每个字段有默认值
if (!this.material) {
return {};
}
return {
rawMaterialId: this.material.rawMaterialId || '',
rawMaterialName: this.material.rawMaterialName || '',
rawMaterialCode: this.material.rawMaterialCode || '',
specification: this.material.specification || '',
material: this.material.material || '',
surfaceTreatment: this.material.surfaceTreatment || '',
zincLayer: this.material.zincLayer || '',
manufacturer: this.material.manufacturer || '',
};
}
},
methods: {
// 移除click事件相关方法无需点击触发
},
};
2025-07-28 18:25:02 +08:00
</script>
<style scoped>
.material-name {
color: #1890ff;
cursor: pointer;
text-decoration: underline;
/* 优化hover触发区域 */
padding: 2px 4px;
2025-07-28 18:25:02 +08:00
}
</style>