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

92 lines
2.8 KiB
Vue
Raw Normal View History

2025-07-28 18:25:02 +08:00
<template>
<div>
<el-popover
trigger="hover"
placement="top"
width="400"
:visible-arrow="true"
append-to-body
popper-class="product-info-popover"
2025-07-29 15:16:51 +08:00
>
<!-- popover 内容原dialog中的描述列表 -->
<el-descriptions :column="2" class="popover-content">
2025-07-31 18:07:51 +08:00
<el-descriptions-item label="产品名称">
{{ productFull.productName || '--' }}
2025-07-29 15:16:51 +08:00
</el-descriptions-item>
<!-- <el-descriptions-item label="产品编码">
{{ productFull.productCode || '--' }}
</el-descriptions-item> -->
<el-descriptions-item label="规格">
{{ productFull.specification || '--' }}
</el-descriptions-item>
<el-descriptions-item label="材质">
{{ productFull.material || '--' }}
</el-descriptions-item>
<el-descriptions-item label="表面处理">
{{ productFull.surfaceTreatment || '--' }}
</el-descriptions-item>
<el-descriptions-item label="镀层质量">
{{ productFull.zincLayer || '--' }}
</el-descriptions-item>
<el-descriptions-item label="厂家">
{{ productFull.manufacturer || '--' }}
</el-descriptions-item>
2025-07-29 15:16:51 +08:00
</el-descriptions>
<!-- 触发元素原产品名称文本 -->
<span slot="reference" class="product-name">
<slot name="default" :product="productFull">
{{ productFull.productName || '未知' }}[{{ productFull.specification || '无规格' }}]({{ productFull.material || '无材质' }})-{{ productFull.manufacturer || '无厂家' }}-{{ productFull.zincLayer || '无镀层' }}
</slot>
</span>
</el-popover>
2025-07-28 18:25:02 +08:00
</div>
</template>
<script>
export default {
name: 'ProductInfo',
props: {
product: {
type: Object,
default: () => ({})
2025-07-29 15:00:15 +08:00
},
2025-07-28 18:25:02 +08:00
},
data() {
return {
// 移除showDetail无需弹窗控制
2025-07-28 18:25:02 +08:00
};
},
computed: {
productFull() {
// 完整的product, 确保每个字段都有值
if (!this.product) {
return {};
}
return {
productId: this.product.itemId || this.product.productId || '',
productName: this.product.itemName || this.product.productName || '',
// productCode: this.product.productCode || '',
specification: this.product.specification || '',
material: this.product.material || '',
surfaceTreatment: this.product.surfaceTreatmentDesc || '',
zincLayer: this.product.zincLayer || '',
manufacturer: this.product.manufacturer || '',
};
}
},
2025-07-29 15:00:15 +08:00
methods: {
// 移除clickHandle方法无需点击触发
2025-07-29 15:00:15 +08:00
},
2025-07-28 18:25:02 +08:00
};
</script>
<style scoped>
.product-name {
color: #1890ff;
cursor: pointer;
text-decoration: underline;
/* 增加内边距,优化悬停触发区域 */
padding: 2px 4px;
2025-07-29 15:16:51 +08:00
}
</style>