<template>
|
<view class="production-plan-detail">
|
<PageHeader title="计划详情"
|
@back="goBack" />
|
<view class="detail-container"
|
v-if="detailData">
|
<!-- 基本信息卡片 -->
|
<view class="detail-card">
|
<view class="card-title">
|
<up-icon name="info-circle"
|
size="18"
|
color="#3c9cff"></up-icon>
|
<text class="title-text">基本信息</text>
|
</view>
|
<view class="card-content">
|
<view class="info-item">
|
<text class="label">主生产计划号</text>
|
<text class="value">{{ detailData.mpsNo || '-' }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">来源</text>
|
<up-tag :text="detailData.source === '销售' ? '销售' : '内部'"
|
:type="detailData.source === '销售' ? 'primary' : 'info'"
|
size="mini" />
|
</view>
|
<view class="info-item">
|
<text class="label">下发状态</text>
|
<up-tag :text="getStatusText(detailData.status)"
|
:type="getStatusType(detailData.status)"
|
size="mini" />
|
</view>
|
</view>
|
</view>
|
<!-- 产品信息卡片 -->
|
<view class="detail-card">
|
<view class="card-title">
|
<up-icon name="order"
|
size="18"
|
color="#3c9cff"></up-icon>
|
<text class="title-text">产品信息</text>
|
</view>
|
<view class="card-content">
|
<view class="info-item">
|
<text class="label">产品名称</text>
|
<text class="value font-bold">{{ detailData.productName || '-' }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">规格型号</text>
|
<text class="value">{{ detailData.model || '-' }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">所需数量</text>
|
<text class="value highlight">{{ detailData.qtyRequired || 0 }} {{ detailData.unit || '方' }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">已下发数量</text>
|
<text class="value">{{ detailData.quantityIssued || 0 }} {{ detailData.unit || '方' }}</text>
|
</view>
|
</view>
|
</view>
|
<!-- 日期与关联卡片 -->
|
<view class="detail-card">
|
<view class="card-title">
|
<up-icon name="calendar"
|
size="18"
|
color="#3c9cff"></up-icon>
|
<text class="title-text">日期与关联</text>
|
</view>
|
<view class="card-content">
|
<view class="info-item">
|
<text class="label">需求日期</text>
|
<text class="value">{{ formatDate(detailData.requiredDate) }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">承诺日期</text>
|
<text class="value">{{ formatDate(detailData.promisedDeliveryDate) }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">销售合同号</text>
|
<text class="value">{{ detailData.salesContractNo || '-' }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">客户名称</text>
|
<text class="value">{{ detailData.customerName || '-' }}</text>
|
</view>
|
<view class="info-item">
|
<text class="label">项目名称</text>
|
<text class="value">{{ detailData.projectName || '-' }}</text>
|
</view>
|
</view>
|
</view>
|
<!-- 备注信息 -->
|
<view class="detail-card">
|
<view class="card-title">
|
<up-icon name="edit-pen"
|
size="18"
|
color="#3c9cff"></up-icon>
|
<text class="title-text">备注</text>
|
</view>
|
<view class="card-content">
|
<view class="remark-box">
|
<text class="remark-text">{{ detailData.remark || '无备注' }}</text>
|
</view>
|
</view>
|
</view>
|
</view>
|
<view v-else
|
class="no-data">
|
<up-empty mode="data"
|
text="暂无详情数据"></up-empty>
|
</view>
|
</view>
|
</template>
|
|
<script setup>
|
import { ref, reactive, onMounted } from "vue";
|
import { onLoad } from "@dcloudio/uni-app";
|
import dayjs from "dayjs";
|
import PageHeader from "@/components/PageHeader.vue";
|
|
const detailData = ref(null);
|
|
// 返回上一页
|
const goBack = () => {
|
uni.navigateBack();
|
};
|
|
// 格式化日期
|
const formatDate = date => {
|
return date ? dayjs(date).format("YYYY-MM-DD") : "-";
|
};
|
|
// 获取状态文本
|
const getStatusText = status => {
|
const statusMap = {
|
0: "待下发",
|
1: "部分下发",
|
2: "已下发",
|
};
|
return statusMap[status] || "未知";
|
};
|
|
// 获取状态类型
|
const getStatusType = status => {
|
const typeMap = {
|
0: "warning",
|
1: "primary",
|
2: "info",
|
};
|
return typeMap[status] || "info";
|
};
|
|
onLoad(options => {
|
if (options.data) {
|
try {
|
detailData.value = JSON.parse(decodeURIComponent(options.data));
|
} catch (e) {
|
console.error("解析数据失败", e);
|
uni.showToast({
|
title: "数据加载失败",
|
icon: "error",
|
});
|
}
|
}
|
});
|
</script>
|
|
<style scoped lang="scss">
|
.production-plan-detail {
|
min-height: 100vh;
|
background: #f8f9fa;
|
padding-bottom: 40rpx;
|
}
|
|
.detail-container {
|
padding: 20rpx;
|
}
|
|
.detail-card {
|
background: #fff;
|
border-radius: 16rpx;
|
margin-bottom: 24rpx;
|
overflow: hidden;
|
box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.03);
|
|
.card-title {
|
display: flex;
|
align-items: center;
|
padding: 24rpx;
|
border-bottom: 1rpx solid #f0f0f0;
|
background: #fafafa;
|
|
.title-text {
|
font-size: 28rpx;
|
font-weight: bold;
|
color: #333;
|
margin-left: 12rpx;
|
}
|
}
|
|
.card-content {
|
padding: 10rpx 24rpx;
|
|
.info-item {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
padding: 20rpx 0;
|
border-bottom: 1rpx solid #f9f9f9;
|
|
&:last-child {
|
border-bottom: none;
|
}
|
|
.label {
|
font-size: 26rpx;
|
color: #999;
|
}
|
|
.value {
|
font-size: 26rpx;
|
color: #333;
|
text-align: right;
|
max-width: 70%;
|
|
&.font-bold {
|
font-weight: bold;
|
}
|
|
&.highlight {
|
color: #f56c6c;
|
font-weight: bold;
|
}
|
}
|
}
|
|
.remark-box {
|
padding: 20rpx 0;
|
|
.remark-text {
|
font-size: 26rpx;
|
color: #666;
|
line-height: 1.5;
|
}
|
}
|
}
|
}
|
|
.no-data {
|
padding-top: 200rpx;
|
}
|
</style>
|