Преглед на файлове

根据所聊内容进行整改

Huanyi преди 1 седмица
родител
ревизия
e464d26358

+ 29 - 0
src/api/erp/goodsStock/index.ts

@@ -0,0 +1,29 @@
+import request from '@/utils/request';
+import { AxiosPromise } from 'axios';
+import { GoodsStockQuery, GoodsStockVO } from './types';
+
+/**
+ * 分页查询成品库存列表
+ * @param query
+ * @Author: Antigravity
+ */
+export function listGoodsStockPage(query: GoodsStockQuery): AxiosPromise<any> {
+  return request({
+    url: '/erp/goodsStock/page',
+    method: 'get',
+    params: query
+  });
+}
+
+/**
+ * 查询成品库存列表(不分页)
+ * @param query
+ * @Author: Antigravity
+ */
+export function listGoodsStock(query: GoodsStockQuery): AxiosPromise<GoodsStockVO[]> {
+  return request({
+    url: '/erp/goodsStock/list',
+    method: 'get',
+    params: query
+  });
+}

+ 112 - 0
src/api/erp/goodsStock/types.ts

@@ -0,0 +1,112 @@
+/**
+ * 成品库存类型定义
+ * @Author: Antigravity
+ */
+
+export interface GoodsStockVO {
+  /** 项目号 */
+  itemNo?: string;
+  /** 型材ID */
+  modelId?: string;
+  /** 型材型号 */
+  modelNum?: string;
+  /** 型材名称 */
+  modelName?: string;
+  /** 客户型号 */
+  clientModel?: string;
+  /** 表面ID */
+  colorId?: string;
+  /** 表面代码 */
+  colorNum?: string;
+  /** 表面名称 */
+  colorName?: string;
+  /** 表面分类 */
+  colorKind?: string;
+  /** 材质ID */
+  alloyId?: string;
+  /** 材质名称 */
+  alloyName?: string;
+  /** 壁厚 */
+  thick?: number;
+  /** 膜厚 */
+  film?: number;
+  /** 包装ID */
+  packId?: string;
+  /** 包装方式 */
+  packName?: string;
+  /** 仓库ID */
+  storeId?: string;
+  /** 仓库名称 */
+  storeName?: string;
+  /** 框ID */
+  frameId?: string;
+  /** 框名称 */
+  frameName?: string;
+  /** 框重 */
+  frameWt?: number;
+  /** 框条码 */
+  frameBar?: string;
+  /** 长度 */
+  flength?: number;
+  /** 米重 */
+  meterWt?: number;
+  /** 6米支重 */
+  sixMeterWt?: number;
+  /** 单据编号 */
+  docCode?: string;
+  /** 销售数量 */
+  saleQty?: number;
+  /** 数量 */
+  qty?: number;
+  /** 理论重量 */
+  theoryWt?: number;
+  /** 实际重量 */
+  wt?: number;
+  /** 支/扎 */
+  packPricks?: number;
+  /** 装扎数量 */
+  packPrickQty?: number;
+  /** 生产完成时间 */
+  finishDate?: string;
+  /** 库龄(天) */
+  stockDays?: number;
+  /** 客户ID */
+  clientId?: string;
+  /** 客户编号 */
+  clientNum?: string;
+  /** 客户名称 */
+  clientName?: string;
+  /** 平均重量 */
+  avgWt?: number;
+  /** 待字标志 */
+  dzsj?: number;
+  /** 订单状态 */
+  orderState?: string;
+  /** 是否减半 */
+  isHalf?: number;
+  /** 来源ID */
+  fromId?: string;
+  /** 首次排产时间 */
+  firstdate?: string;
+  /** 是否尾料 */
+  isSurplus?: number;
+  /** 来源单据 */
+  fromBill?: string;
+  /** 客户代码 */
+  clientCode?: string;
+  /** 销售代码 */
+  saleCode?: string;
+  /** 氧化料别 */
+  oxidModelSort?: string;
+}
+
+export interface GoodsStockQuery extends PageParam {
+  /** 型材型号 */
+  modelNum?: string;
+  /** 表面名称 */
+  colorName?: string;
+  /** 客户名称 */
+  clientName?: string;
+  /** 单据编号 */
+  docCode?: string;
+}

+ 1 - 12
src/api/erp/order/index.ts

@@ -40,18 +40,7 @@ export function addOrder(data: ErpOrderForm) {
   });
   });
 }
 }
 
 
-/**
- * 审核订单
- * @param data
- * @Author: Antigravity
- */
-export function auditOrder(data: any) {
-  return request({
-    url: '/erp/order/audit',
-    method: 'post',
-    data: data
-  });
-}
+
 
 
 /**
 /**
  * 按状态统计订单数量
  * 按状态统计订单数量

+ 10 - 3
src/api/erp/order/types.ts

@@ -6,7 +6,8 @@
 export interface ErpOrderQuery extends PageQuery {
 export interface ErpOrderQuery extends PageQuery {
   code?: string;
   code?: string;
   placer?: number | string;
   placer?: number | string;
-  status?: number | string;
+  isConfirmed?: number | string;
+  docCode?: string;
 }
 }
 
 
 export interface ErpOrderVo {
 export interface ErpOrderVo {
@@ -14,7 +15,8 @@ export interface ErpOrderVo {
   code: string;
   code: string;
   placer: number;
   placer: number;
   placeTime: string;
   placeTime: string;
-  status: number;
+  isConfirmed: number;
+  docCode?: string;
   createTime: string;
   createTime: string;
   totalCount: number;
   totalCount: number;
   details?: ErpOrderDetailVo[];
   details?: ErpOrderDetailVo[];
@@ -37,13 +39,16 @@ export interface ErpOrderDetailVo {
   colorName: string;
   colorName: string;
   count: number;
   count: number;
   remark: string;
   remark: string;
+  docCode?: string;
+  itemNo?: string;
 }
 }
 
 
 export interface ErpOrderForm {
 export interface ErpOrderForm {
   rowId?: string;
   rowId?: string;
   code?: string;
   code?: string;
   placer?: number;
   placer?: number;
-  status?: number;
+  isConfirmed?: number;
+  docCode?: string;
   details: ErpOrderDetailForm[];
   details: ErpOrderDetailForm[];
 }
 }
 
 
@@ -53,4 +58,6 @@ export interface ErpOrderDetailForm {
   colorId?: string;
   colorId?: string;
   count?: number;
   count?: number;
   remark?: string;
   remark?: string;
+  docCode?: string;
+  itemNo?: string;
 }
 }

+ 0 - 14
src/api/erp/orderAudit/index.ts

@@ -1,14 +0,0 @@
-import request from '@/utils/request';
-import { AxiosPromise } from 'axios';
-
-/**
- * 获取订单的审核历史
- * @param orderId 订单ID
- * @Author: Antigravity
- */
-export function getAuditHistory(orderId: string): AxiosPromise<any[]> {
-  return request({
-    url: '/erp/orderAudit/history/' + orderId,
-    method: 'get'
-  });
-}

+ 9 - 0
src/json/orderStatus.json

@@ -0,0 +1,9 @@
+{
+  "0": { "text": "待确认", "color": "#FF9900" },
+  "1": { "text": "已确认", "color": "#1890FF" },
+  "2": { "text": "已审核", "color": "#52C41A" },
+  "3": { "text": "已签批", "color": "#722ED1" },
+  "4": { "text": "挤压完成", "color": "#13C2C2" },
+  "5": { "text": "生产完成", "color": "#2F54EB" },
+  "6": { "text": "已取消", "color": "#F5222D" }
+}

+ 423 - 0
src/views/goodsStock/index.vue

@@ -0,0 +1,423 @@
+<template>
+  <!-- 
+    成品库存管理主页面
+    @Author: Antigravity
+  -->
+  <div class="app-container goods-stock-container">
+    <!-- 头部高格调数据看板区 -->
+    <el-row :gutter="20" class="mb20 summary-row">
+      <el-col :span="6">
+        <div class="summary-card total-stock">
+          <div class="card-icon"><el-icon><Box /></el-icon></div>
+          <div class="card-info">
+            <span class="label">当前总库存支数</span>
+            <h2 class="value">{{ summaryData.totalQty.toLocaleString() }} <small>支</small></h2>
+          </div>
+        </div>
+      </el-col>
+      <el-col :span="6">
+        <div class="summary-card total-weight">
+          <div class="card-icon"><el-icon><ScaleToOriginal /></el-icon></div>
+          <div class="card-info">
+            <span class="label">库存总重量</span>
+            <h2 class="value">{{ summaryData.totalWt.toFixed(2) }} <small>kg</small></h2>
+          </div>
+        </div>
+      </el-col>
+      <el-col :span="6">
+        <div class="summary-card aging-stock">
+          <div class="card-icon"><el-icon><Timer /></el-icon></div>
+          <div class="card-info">
+            <span class="label">超 30 天超龄库存</span>
+            <h2 class="value warning-text">{{ summaryData.agingCount }} <small>款</small></h2>
+          </div>
+        </div>
+      </el-col>
+      <el-col :span="6">
+        <div class="summary-card warehouse-stock">
+          <div class="card-icon"><el-icon><HomeFilled /></el-icon></div>
+          <div class="card-info">
+            <span class="label">关联单据数</span>
+            <h2 class="value info-text">{{ summaryData.docCount }} <small>个</small></h2>
+          </div>
+        </div>
+      </el-col>
+    </el-row>
+
+    <!-- 过滤搜索控制栏 -->
+    <el-card class="search-card mb20 shadow-sm" border="false">
+      <el-form :model="queryParams" ref="queryFormRef" :inline="true" label-width="80px">
+        <el-form-item label="型材型号" prop="modelNum">
+          <el-input
+            v-model="queryParams.modelNum"
+            placeholder="请输入型材型号"
+            clearable
+            style="width: 200px"
+            @keyup.enter="handleQuery"
+          />
+        </el-form-item>
+        <el-form-item label="表面名称" prop="colorName">
+          <el-input
+            v-model="queryParams.colorName"
+            placeholder="请输入表面名称"
+            clearable
+            style="width: 200px"
+            @keyup.enter="handleQuery"
+          />
+        </el-form-item>
+        <el-form-item label="客户名称" prop="clientName">
+          <el-input
+            v-model="queryParams.clientName"
+            placeholder="请输入客户名称"
+            clearable
+            style="width: 200px"
+            @keyup.enter="handleQuery"
+          />
+        </el-form-item>
+        <el-form-item label="单据编号" prop="docCode">
+          <el-input
+            v-model="queryParams.docCode"
+            placeholder="请输入单据编号"
+            clearable
+            style="width: 200px"
+            @keyup.enter="handleQuery"
+          />
+        </el-form-item>
+        <el-form-item class="btn-group">
+          <el-button type="primary" icon="Search" class="glow-btn" @click="handleQuery">搜索</el-button>
+          <el-button icon="Refresh" @click="resetQuery">重置</el-button>
+        </el-form-item>
+      </el-form>
+    </el-card>
+
+    <!-- 数据呈现主表格 -->
+    <el-card class="table-card shadow-sm" border="false">
+      <el-table
+        v-loading="loading"
+        :data="stockList"
+        stripe
+        row-key="itemNo"
+        border
+        highlight-current-row
+        class="premium-table"
+      >
+        <el-table-column type="index" label="序号" align="center" width="55" fixed />
+        <el-table-column label="单据编号" align="center" prop="docCode" width="130" show-overflow-tooltip fixed />
+        <el-table-column label="型材型号" align="left" prop="modelNum" width="130" show-overflow-tooltip fixed>
+          <template #default="scope">
+            <span class="bold-text">{{ scope.row.modelNum }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="型材名称" align="left" prop="modelName" width="150" show-overflow-tooltip />
+        <el-table-column label="客户型号" align="left" prop="clientModel" width="130" show-overflow-tooltip />
+        <el-table-column label="表面名称" align="center" prop="colorName" width="130" show-overflow-tooltip>
+          <template #default="scope">
+            <el-tag effect="plain" type="success" size="small">{{ scope.row.colorName }}</el-tag>
+          </template>
+        </el-table-column>
+        <el-table-column label="材质" align="center" prop="alloyName" width="90" />
+        <el-table-column label="壁厚(mm)" align="right" prop="thick" width="95">
+          <template #default="scope">
+            <span>{{ scope.row.thick ? Number(scope.row.thick).toFixed(2) : '-' }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="膜厚" align="right" prop="film" width="85">
+          <template #default="scope">
+            <span>{{ scope.row.film ? Number(scope.row.film).toFixed(2) : '-' }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="长度(mm)" align="right" prop="flength" width="95">
+          <template #default="scope">
+            <span class="highlight-value">{{ scope.row.flength ? Math.round(scope.row.flength) : '-' }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="现存支数" align="right" prop="qty" width="100">
+          <template #default="scope">
+            <span class="qty-text">{{ scope.row.qty ? scope.row.qty : 0 }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="实际重量(kg)" align="right" prop="wt" width="115">
+          <template #default="scope">
+            <span class="wt-text">{{ scope.row.wt ? Number(scope.row.wt).toFixed(2) : '0.00' }}</span>
+          </template>
+        </el-table-column>
+        <el-table-column label="存放框名" align="center" prop="frameName" width="120" show-overflow-tooltip />
+        <el-table-column label="仓库名称" align="center" prop="storeName" width="120" show-overflow-tooltip />
+        <el-table-column label="库龄" align="center" prop="stockDays" width="95">
+          <template #default="scope">
+            <el-tooltip :content="'生产完成日期: ' + parseTime(scope.row.finishDate)" placement="top">
+              <el-tag :type="getAgingTagType(scope.row.stockDays)" effect="dark" size="small">
+                {{ scope.row.stockDays }} 天
+              </el-tag>
+            </el-tooltip>
+          </template>
+        </el-table-column>
+        <el-table-column label="客户名称" align="left" prop="clientName" width="150" show-overflow-tooltip />
+        <el-table-column label="完成日期" align="center" prop="finishDate" width="160">
+          <template #default="scope">
+            <span>{{ parseTime(scope.row.finishDate, '{y}-{m}-{d} {h}:{i}') }}</span>
+          </template>
+        </el-table-column>
+      </el-table>
+
+      <pagination
+        v-show="total > 0"
+        :total="total"
+        v-model:page="queryParams.pageNum"
+        v-model:limit="queryParams.pageSize"
+        @pagination="getList"
+      />
+    </el-card>
+  </div>
+</template>
+
+<script setup name="GoodsStock">
+/**
+ * 成品库存组件逻辑
+ * @Author: Antigravity
+ */
+import { ref, onMounted, reactive } from 'vue';
+import { listGoodsStockPage } from '@/api/erp/goodsStock';
+import { parseTime } from '@/utils/ruoyi';
+
+const queryFormRef = ref();
+const loading = ref(false);
+const total = ref(0);
+const stockList = ref([]);
+
+// 汇总栏数据定义
+const summaryData = reactive({
+  totalQty: 0,
+  totalWt: 0,
+  agingCount: 0,
+  docCount: 0
+});
+
+// 查询参数配置
+const queryParams = ref({
+  pageNum: 1,
+  pageSize: 10,
+  modelNum: undefined,
+  colorName: undefined,
+  clientName: undefined,
+  docCode: undefined
+});
+
+/** 查询库存列表 */
+function getList() {
+  loading.value = true;
+  listGoodsStockPage(queryParams.value).then(response => {
+    stockList.value = response.rows;
+    total.value = response.total;
+    loading.value = false;
+    calculateSummary(response.rows);
+  }).catch(() => {
+    loading.value = false;
+  });
+}
+
+/** 动态统计当前页/当前汇总概览 */
+function calculateSummary(rows) {
+  if (!rows || rows.length === 0) {
+    summaryData.totalQty = 0;
+    summaryData.totalWt = 0;
+    summaryData.agingCount = 0;
+    summaryData.docCount = 0;
+    return;
+  }
+  let qty = 0;
+  let wt = 0;
+  let aging = 0;
+  const docs = new Set();
+  rows.forEach(r => {
+    qty += Number(r.qty || 0);
+    wt += Number(r.wt || 0);
+    if (Number(r.stockDays || 0) > 30) {
+      aging++;
+    }
+    if (r.docCode) {
+      docs.add(r.docCode);
+    }
+  });
+  summaryData.totalQty = qty;
+  summaryData.totalWt = wt;
+  summaryData.agingCount = aging;
+  summaryData.docCount = docs.size;
+}
+
+/** 库龄颜色渲染 */
+function getAgingTagType(days) {
+  const d = Number(days || 0);
+  if (d <= 7) return 'success'; // 新鲜库存
+  if (d <= 30) return 'info'; // 正常库存
+  if (d <= 90) return 'warning'; // 超龄中等库存
+  return 'danger'; // 呆滞库存
+}
+
+/** 搜索按钮操作 */
+function handleQuery() {
+  queryParams.value.pageNum = 1;
+  getList();
+}
+
+/** 重置查询 */
+function resetQuery() {
+  queryFormRef.value?.resetFields();
+  handleQuery();
+}
+
+onMounted(() => {
+  getList();
+});
+</script>
+
+<style scoped lang="scss">
+.goods-stock-container {
+  padding: 20px;
+  background-color: #f6f8fb;
+  min-height: calc(100vh - 84px);
+
+  // 1. 数据统计卡片区美化
+  .summary-row {
+    margin-bottom: 20px;
+
+    .summary-card {
+      display: flex;
+      align-items: center;
+      padding: 20px;
+      background: #ffffff;
+      border-radius: 12px;
+      box-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.03);
+      transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
+      border-left: 5px solid #409eff;
+
+      &:hover {
+        transform: translateY(-4px);
+        box-shadow: 0 8px 30px 0 rgba(64, 158, 255, 0.12);
+      }
+
+      &.total-stock {
+        border-left-color: #409eff;
+        .card-icon { background: rgba(64, 158, 255, 0.1); color: #409eff; }
+      }
+      &.total-weight {
+        border-left-color: #67c23a;
+        .card-icon { background: rgba(103, 194, 58, 0.1); color: #67c23a; }
+      }
+      &.aging-stock {
+        border-left-color: #f56c6c;
+        .card-icon { background: rgba(245, 108, 108, 0.1); color: #f56c6c; }
+      }
+      &.warehouse-stock {
+        border-left-color: #e6a23c;
+        .card-icon { background: rgba(230, 162, 60, 0.1); color: #e6a23c; }
+      }
+
+      .card-icon {
+        width: 54px;
+        height: 54px;
+        border-radius: 10px;
+        display: flex;
+        align-items: center;
+        justify-content: center;
+        font-size: 26px;
+        margin-right: 15px;
+      }
+
+      .card-info {
+        .label {
+          font-size: 13px;
+          color: #909399;
+          display: block;
+          margin-bottom: 5px;
+        }
+        .value {
+          margin: 0;
+          font-size: 22px;
+          font-weight: 700;
+          color: #303133;
+
+          small {
+            font-size: 12px;
+            font-weight: normal;
+            color: #909399;
+            margin-left: 2px;
+          }
+        }
+        .warning-text { color: #f56c6c; }
+        .info-text { color: #e6a23c; }
+      }
+    }
+  }
+
+  // 2. 搜索控制栏美化
+  .search-card {
+    background: #ffffff;
+    border-radius: 12px;
+    border: none;
+
+    :deep(.el-form-item) {
+      margin-bottom: 0;
+      margin-right: 18px;
+    }
+
+    .btn-group {
+      margin-left: 10px;
+    }
+
+    .glow-btn {
+      box-shadow: 0 4px 14px 0 rgba(64, 158, 255, 0.4);
+      transition: all 0.3s;
+
+      &:hover {
+        transform: translateY(-1px);
+        box-shadow: 0 6px 20px 0 rgba(64, 158, 255, 0.5);
+      }
+    }
+  }
+
+  // 3. 数据表格区美化
+  .table-card {
+    border-radius: 12px;
+    border: none;
+    background: #ffffff;
+
+    .premium-table {
+      font-size: 13px;
+
+      :deep(.el-table__header-wrapper) th {
+        background-color: #f8f9fc !important;
+        color: #606266;
+        font-weight: bold;
+        height: 48px;
+      }
+
+      :deep(.el-table__row) {
+        height: 44px;
+      }
+
+      .bold-text {
+        font-weight: 600;
+        color: #2c3e50;
+      }
+
+      .highlight-value {
+        color: #2c3e50;
+        font-weight: bold;
+      }
+
+      .qty-text {
+        font-weight: bold;
+        color: #2980b9;
+      }
+
+      .wt-text {
+        font-weight: bold;
+        color: #27ae60;
+      }
+    }
+  }
+
+  .mb20 { margin-bottom: 20px; }
+}
+</style>

+ 30 - 23
src/views/order/index.vue

@@ -10,6 +10,9 @@
           <el-form-item label="下单人" prop="placer">
           <el-form-item label="下单人" prop="placer">
             <el-input v-model="queryParams.placer" placeholder="请输入下单人" clearable @keyup.enter="handleQuery" />
             <el-input v-model="queryParams.placer" placeholder="请输入下单人" clearable @keyup.enter="handleQuery" />
           </el-form-item>
           </el-form-item>
+          <el-form-item label="单据编号" prop="docCode">
+            <el-input v-model="queryParams.docCode" placeholder="请输入单据编号" clearable @keyup.enter="handleQuery" />
+          </el-form-item>
 
 
           <el-form-item>
           <el-form-item>
             <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
             <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
@@ -35,6 +38,11 @@
 
 
       <el-table v-loading="loading" :data="orderList" border>
       <el-table v-loading="loading" :data="orderList" border>
         <el-table-column label="订单单号" align="center" prop="code" />
         <el-table-column label="订单单号" align="center" prop="code" />
+        <el-table-column label="单据编号" align="center" prop="docCode">
+          <template #default="scope">
+            <span>{{ scope.row.docCode || '-' }}</span>
+          </template>
+        </el-table-column>
         <el-table-column label="ERP 单号" align="center" prop="erpDocCode">
         <el-table-column label="ERP 单号" align="center" prop="erpDocCode">
           <template #default="scope">
           <template #default="scope">
             <span>{{ scope.row.erpDocCode || '-' }}</span>
             <span>{{ scope.row.erpDocCode || '-' }}</span>
@@ -47,15 +55,11 @@
           </template>
           </template>
         </el-table-column>
         </el-table-column>
         <el-table-column label="总支数" align="center" prop="totalCount" />
         <el-table-column label="总支数" align="center" prop="totalCount" />
-        <el-table-column label="状态" align="center" prop="status">
+        <el-table-column label="订单状态" align="center" prop="status">
           <template #default="scope">
           <template #default="scope">
-            <el-tag v-if="scope.row.status === -1" type="danger">已撤销</el-tag>
-            <el-tag v-else-if="scope.row.status === 0" type="warning">待审核</el-tag>
-            <el-tag v-else-if="scope.row.status === 1" type="danger">已驳回</el-tag>
-            <el-tag v-else-if="scope.row.status === 2" type="primary">待签批</el-tag>
-            <el-tag v-else-if="scope.row.status === 3" type="info">生产中</el-tag>
-            <el-tag v-else-if="scope.row.status === 4" type="success">已完成</el-tag>
-            <el-tag v-else type="info">未知</el-tag>
+            <el-tag :color="orderStatusJson[scope.row.status]?.color" style="color: #fff; border: none; font-weight: bold;">
+              {{ orderStatusJson[scope.row.status]?.text || '待确认' }}
+            </el-tag>
           </template>
           </template>
         </el-table-column>
         </el-table-column>
         <el-table-column label="创建时间" align="center" prop="createTime" width="180">
         <el-table-column label="创建时间" align="center" prop="createTime" width="180">
@@ -81,16 +85,12 @@
         <div class="section-title">订单信息</div>
         <div class="section-title">订单信息</div>
         <el-descriptions :column="2" border size="small">
         <el-descriptions :column="2" border size="small">
           <el-descriptions-item label="订单单号" :span="2">{{ detailOrder.code }}</el-descriptions-item>
           <el-descriptions-item label="订单单号" :span="2">{{ detailOrder.code }}</el-descriptions-item>
-          <el-descriptions-item label="ERP 单号" :span="2">{{ detailOrder.erpDocCode || '-' }}</el-descriptions-item>
+          <el-descriptions-item label="单据编号" :span="2">{{ detailOrder.docCode || '-' }}</el-descriptions-item>
           <el-descriptions-item label="下单人">{{ detailOrder.placerName }}</el-descriptions-item>
           <el-descriptions-item label="下单人">{{ detailOrder.placerName }}</el-descriptions-item>
           <el-descriptions-item label="订单状态">
           <el-descriptions-item label="订单状态">
-            <el-tag v-if="detailOrder.status === -1" type="danger">已撤销</el-tag>
-            <el-tag v-else-if="detailOrder.status === 0" type="warning">待审核</el-tag>
-            <el-tag v-else-if="detailOrder.status === 1" type="danger">已驳回</el-tag>
-            <el-tag v-else-if="detailOrder.status === 2" type="primary">待签批</el-tag>
-            <el-tag v-else-if="detailOrder.status === 3" type="info">生产中</el-tag>
-            <el-tag v-else-if="detailOrder.status === 4" type="success">已完成</el-tag>
-            <el-tag v-else type="info">未知</el-tag>
+            <el-tag :color="orderStatusJson[detailOrder.status]?.color" style="color: #fff; border: none; font-weight: bold;">
+              {{ orderStatusJson[detailOrder.status]?.text || '待确认' }}
+            </el-tag>
           </el-descriptions-item>
           </el-descriptions-item>
           <el-descriptions-item label="下单时间">{{ parseTime(detailOrder.placeTime) }}</el-descriptions-item>
           <el-descriptions-item label="下单时间">{{ parseTime(detailOrder.placeTime) }}</el-descriptions-item>
           <el-descriptions-item label="创建时间">{{ parseTime(detailOrder.createTime) }}</el-descriptions-item>
           <el-descriptions-item label="创建时间">{{ parseTime(detailOrder.createTime) }}</el-descriptions-item>
@@ -104,6 +104,8 @@
             <el-descriptions :column="2" border size="small">
             <el-descriptions :column="2" border size="small">
               <el-descriptions-item label="产品型号" :span="2">{{ detail.modelNum || '未知型号' }}</el-descriptions-item>
               <el-descriptions-item label="产品型号" :span="2">{{ detail.modelNum || '未知型号' }}</el-descriptions-item>
               <el-descriptions-item label="型号名称" :span="2">{{ detail.modelName || '铝型材主料' }}</el-descriptions-item>
               <el-descriptions-item label="型号名称" :span="2">{{ detail.modelName || '铝型材主料' }}</el-descriptions-item>
+              <el-descriptions-item label="单据编号">{{ detail.docCode || '-' }}</el-descriptions-item>
+              <el-descriptions-item label="项目号">{{ detail.itemNo || '-' }}</el-descriptions-item>
               <el-descriptions-item label="型材材质">{{ detail.material || '6063-T5' }}</el-descriptions-item>
               <el-descriptions-item label="型材材质">{{ detail.material || '6063-T5' }}</el-descriptions-item>
               <el-descriptions-item label="需求支数">
               <el-descriptions-item label="需求支数">
                 <span class="count-red">{{ detail.count || 0 }} 支</span>
                 <span class="count-red">{{ detail.count || 0 }} 支</span>
@@ -126,6 +128,7 @@
 
 
 <script setup name="Order">
 <script setup name="Order">
 import { listOrder, getOrder } from "@/api/erp/order";
 import { listOrder, getOrder } from "@/api/erp/order";
+import orderStatusJson from "@/json/orderStatus.json";
 
 
 /** @Author: Antigravity */
 /** @Author: Antigravity */
 
 
@@ -141,12 +144,13 @@ const currentTab = ref(undefined);
 
 
 const statusTabs = [
 const statusTabs = [
   { label: '全部', value: undefined },
   { label: '全部', value: undefined },
-  { label: '已撤销', value: -1 },
-  { label: '待审核', value: 0 },
-  { label: '已驳回', value: 1 },
-  { label: '待签批', value: 2 },
-  { label: '生产中', value: 3 },
-  { label: '已完成', value: 4 }
+  { label: '待确认', value: 0 },
+  { label: '已确认', value: 1 },
+  { label: '已审核', value: 2 },
+  { label: '已签批', value: 3 },
+  { label: '挤压完成', value: 4 },
+  { label: '生产完成', value: 5 },
+  { label: '已取消', value: 6 }
 ];
 ];
 
 
 const queryFormRef = ref();
 const queryFormRef = ref();
@@ -157,7 +161,8 @@ const data = reactive({
     pageSize: 10,
     pageSize: 10,
     code: undefined,
     code: undefined,
     placer: undefined,
     placer: undefined,
-    status: undefined
+    isConfirmed: undefined,
+    docCode: undefined
   }
   }
 });
 });
 
 
@@ -167,6 +172,7 @@ const { queryParams } = toRefs(data);
 function getList() {
 function getList() {
   loading.value = true;
   loading.value = true;
   queryParams.value.status = currentTab.value;
   queryParams.value.status = currentTab.value;
+  queryParams.value.isConfirmed = undefined;
   listOrder(queryParams.value).then(response => {
   listOrder(queryParams.value).then(response => {
     orderList.value = response.rows;
     orderList.value = response.rows;
     total.value = response.total;
     total.value = response.total;
@@ -178,6 +184,7 @@ function getList() {
 function handleQuery() {
 function handleQuery() {
   queryParams.value.pageNum = 1;
   queryParams.value.pageNum = 1;
   queryParams.value.status = currentTab.value;
   queryParams.value.status = currentTab.value;
+  queryParams.value.isConfirmed = undefined;
   getList();
   getList();
 }
 }