<template>
|
<div class="app-container">
|
<!-- 页面标题 -->
|
<div class="page-header">
|
<h2>采购管理系统</h2>
|
<p>统一管理采购全流程,提升采购效率与质量</p>
|
</div>
|
|
<!-- 功能模块卡片 -->
|
<el-row :gutter="20" class="module-cards">
|
<el-col :span="8">
|
<el-card class="module-card" shadow="hover" @click="navigateTo('/procurementManagement/purchaseOrder')">
|
<div class="card-content">
|
<div class="card-icon">
|
<el-icon size="48" color="#409EFF"><Document /></el-icon>
|
</div>
|
<div class="card-info">
|
<h3>采购订单管理</h3>
|
<p>新建、编辑、删除采购订单,选择供应商,填写商品明细</p>
|
<div class="card-stats">
|
<span>待审核: {{ stats.pendingOrders }}</span>
|
<span>已审核: {{ stats.approvedOrders }}</span>
|
</div>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
|
<el-col :span="8">
|
<el-card class="module-card" shadow="hover" @click="navigateTo('/procurementManagement/arrivalManagement')">
|
<div class="card-content">
|
<div class="card-icon">
|
<el-icon size="48" color="#67C23A"><Box /></el-icon>
|
</div>
|
<div class="card-info">
|
<h3>到货管理</h3>
|
<p>自动关联采购订单,录入到货商品信息,支持打印查看</p>
|
<div class="card-stats">
|
<span>待收货: {{ stats.pendingArrivals }}</span>
|
<span>已收货: {{ stats.receivedArrivals }}</span>
|
</div>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
|
<el-col :span="8">
|
<el-card class="module-card" shadow="hover" @click="navigateTo('/procurementManagement/qualityInspection')">
|
<div class="card-content">
|
<div class="card-icon">
|
<el-icon size="48" color="#E6A23C"><Search /></el-icon>
|
</div>
|
<div class="card-info">
|
<h3>质检管理</h3>
|
<p>到货后自动生成质检单,填写合格与不合格商品数量及原因</p>
|
<div class="card-stats">
|
<span>待质检: {{ stats.pendingInspections }}</span>
|
<span>已完成: {{ stats.completedInspections }}</span>
|
</div>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
</el-row>
|
|
<el-row :gutter="20" class="module-cards">
|
<el-col :span="8">
|
<el-card class="module-card" shadow="hover" @click="navigateTo('/procurementManagement/returnManagement')">
|
<div class="card-content">
|
<div class="card-icon">
|
<el-icon size="48" color="#F56C6C"><RefreshLeft /></el-icon>
|
</div>
|
<div class="card-info">
|
<h3>退货管理</h3>
|
<p>生成采购退货单和质检退货单,支持筛选查询与单据详情</p>
|
<div class="card-stats">
|
<span>待审核: {{ stats.pendingReturns }}</span>
|
<span>已审核: {{ stats.approvedReturns }}</span>
|
</div>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
|
<el-col :span="8">
|
<el-card class="module-card" shadow="hover" @click="navigateTo('/procurementManagement/priceManagement')">
|
<div class="card-content">
|
<div class="card-icon">
|
<el-icon size="48" color="#909399"><Money /></el-icon>
|
</div>
|
<div class="card-info">
|
<h3>价格管理</h3>
|
<p>根据商品及市场价格变化进行采购价调整,自动更新采购单据</p>
|
<div class="card-stats">
|
<span>有效价格: {{ stats.activePrices }}</span>
|
<span>待生效: {{ stats.pendingPrices }}</span>
|
</div>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
|
<el-col :span="8">
|
<el-card class="module-card" shadow="hover" @click="navigateTo('/procurementManagement/procurementLedger')">
|
<div class="card-content">
|
<div class="card-icon">
|
<el-icon size="48" color="#9C27B0"><List /></el-icon>
|
</div>
|
<div class="card-info">
|
<h3>采购台账</h3>
|
<p>查看采购历史记录,统计分析采购数据,生成采购报表</p>
|
<div class="card-stats">
|
<span>总订单: {{ stats.totalOrders }}</span>
|
<span>总金额: ¥{{ stats.totalAmount.toFixed(2) }}</span>
|
</div>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
</el-row>
|
|
<!-- 统计概览 -->
|
<el-card class="stats-card" shadow="never">
|
<template #header>
|
<div class="card-header">
|
<span>采购统计概览</span>
|
<el-button type="primary" size="small" @click="refreshStats">刷新数据</el-button>
|
</div>
|
</template>
|
|
<el-row :gutter="20">
|
<el-col :span="6">
|
<div class="stat-item">
|
<div class="stat-number">{{ stats.totalOrders }}</div>
|
<div class="stat-label">采购订单总数</div>
|
</div>
|
</el-col>
|
<el-col :span="6">
|
<div class="stat-item">
|
<div class="stat-number">{{ stats.totalAmount.toFixed(2) }}</div>
|
<div class="stat-label">采购总金额(万元)</div>
|
</div>
|
</el-col>
|
<el-col :span="6">
|
<div class="stat-item">
|
<div class="stat-number">{{ stats.avgDeliveryTime }}</div>
|
<div class="stat-label">平均交付天数</div>
|
</div>
|
</el-col>
|
<el-col :span="6">
|
<div class="stat-item">
|
<div class="stat-number">{{ stats.qualityRate }}%</div>
|
<div class="stat-label">质检合格率</div>
|
</div>
|
</el-col>
|
</el-row>
|
</el-card>
|
|
<!-- 最近活动 -->
|
<el-card class="activity-card" shadow="never">
|
<template #header>
|
<span>最近活动</span>
|
</template>
|
|
<el-timeline>
|
<el-timeline-item
|
v-for="(activity, index) in recentActivities"
|
:key="index"
|
:timestamp="activity.time"
|
:type="activity.type"
|
>
|
{{ activity.content }}
|
</el-timeline-item>
|
</el-timeline>
|
</el-card>
|
</div>
|
</template>
|
|
<script setup>
|
import { ref, onMounted } from 'vue'
|
import { useRouter } from 'vue-router'
|
import { Document, Box, Search, RefreshLeft, Money, List } from '@element-plus/icons-vue'
|
|
const router = useRouter()
|
|
// 统计数据
|
const stats = ref({
|
pendingOrders: 5,
|
approvedOrders: 25,
|
pendingArrivals: 3,
|
receivedArrivals: 18,
|
pendingInspections: 2,
|
completedInspections: 15,
|
pendingReturns: 1,
|
approvedReturns: 3,
|
activePrices: 45,
|
pendingPrices: 2,
|
totalOrders: 30,
|
totalAmount: 125.8,
|
avgDeliveryTime: 7,
|
qualityRate: 96.5
|
})
|
|
// 最近活动
|
const recentActivities = ref([
|
{
|
time: '2024-12-01 18:30',
|
content: '新增采购订单 PO20241201004',
|
type: 'primary'
|
},
|
{
|
time: '2024-12-01 17:45',
|
content: '完成质检单 QI20241201002',
|
type: 'success'
|
},
|
{
|
time: '2024-12-01 16:20',
|
content: '到货单 AR20241201003 已收货',
|
type: 'success'
|
},
|
{
|
time: '2024-12-01 15:15',
|
content: '价格调整:商品B 从 ¥80 调整为 ¥75',
|
type: 'warning'
|
},
|
{
|
time: '2024-12-01 14:30',
|
content: '退货单 RT20241201003 已审核',
|
type: 'info'
|
}
|
])
|
|
// 导航到指定页面
|
const navigateTo = (path) => {
|
router.push(path)
|
}
|
|
// 刷新统计数据
|
const refreshStats = () => {
|
// 模拟刷新数据
|
stats.value.pendingOrders = Math.floor(Math.random() * 10) + 1
|
stats.value.totalAmount = (Math.random() * 100 + 100).toFixed(1)
|
}
|
|
onMounted(() => {
|
// 页面加载完成后的初始化逻辑
|
})
|
</script>
|
|
<style scoped>
|
.app-container {
|
padding: 20px;
|
background-color: #f5f7fa;
|
min-height: 100vh;
|
}
|
|
.page-header {
|
text-align: center;
|
margin-bottom: 30px;
|
padding: 20px;
|
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
border-radius: 10px;
|
color: white;
|
}
|
|
.page-header h2 {
|
margin: 0 0 10px 0;
|
font-size: 28px;
|
font-weight: 600;
|
}
|
|
.page-header p {
|
margin: 0;
|
font-size: 16px;
|
opacity: 0.9;
|
}
|
|
.module-cards {
|
margin-bottom: 20px;
|
}
|
|
.module-card {
|
cursor: pointer;
|
transition: all 0.3s ease;
|
border: none;
|
border-radius: 12px;
|
}
|
|
.module-card:hover {
|
transform: translateY(-5px);
|
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
|
}
|
|
.card-content {
|
display: flex;
|
align-items: center;
|
padding: 20px;
|
}
|
|
.card-icon {
|
margin-right: 20px;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
width: 80px;
|
height: 80px;
|
background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
|
border-radius: 50%;
|
color: white;
|
}
|
|
.card-info h3 {
|
margin: 0 0 10px 0;
|
font-size: 18px;
|
font-weight: 600;
|
color: #303133;
|
}
|
|
.card-info p {
|
margin: 0 0 15px 0;
|
font-size: 14px;
|
color: #606266;
|
line-height: 1.5;
|
}
|
|
.card-stats {
|
display: flex;
|
gap: 15px;
|
}
|
|
.card-stats span {
|
font-size: 12px;
|
color: #909399;
|
background-color: #f5f7fa;
|
padding: 4px 8px;
|
border-radius: 4px;
|
}
|
|
.stats-card {
|
margin-bottom: 20px;
|
border-radius: 12px;
|
}
|
|
.card-header {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
}
|
|
.stat-item {
|
text-align: center;
|
padding: 20px;
|
}
|
|
.stat-number {
|
font-size: 32px;
|
font-weight: 600;
|
color: #409EFF;
|
margin-bottom: 8px;
|
}
|
|
.stat-label {
|
font-size: 14px;
|
color: #606266;
|
}
|
|
.activity-card {
|
border-radius: 12px;
|
}
|
|
.el-timeline-item {
|
padding-bottom: 20px;
|
}
|
|
.el-timeline-item:last-child {
|
padding-bottom: 0;
|
}
|
</style>
|