From f268121e9fe9116c19f84412b3ea992d68acf542 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期五, 18 七月 2025 14:05:26 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10105/r/ERP_override

---
 north-glass-erp/src/main/resources/mapper/mm/FinishedOperateLog.xml                         |    2 
 north-glass-erp/src/main/resources/mapper/sd/OrderDetailMapper.xml                          |   10 ++-
 north-glass-erp/northglass-erp/src/components/mm/PrintPackingListLuoyang.vue                |    6 +-
 north-glass-erp/northglass-erp/src/views/sd/order/CreateOrder.vue                           |   28 +++++++--
 north-glass-erp/northglass-erp/src/components/sd/order/UploadPicture.vue                    |    2 
 north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java |    9 ++
 north-glass-erp/src/main/java/com/example/erp/entity/sd/OrderDetail.java                    |    3 +
 north-glass-erp/src/main/resources/mapper/sd/OrderMapper.xml                                |   17 +++++
 north-glass-erp/src/main/java/com/example/erp/controller/sd/OrderController.java            |   10 +++
 north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderDetailMapper.java              |    2 
 north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderMapper.java                    |    6 ++
 north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java                  |   41 +++++++++++++
 12 files changed, 119 insertions(+), 17 deletions(-)

diff --git a/north-glass-erp/northglass-erp/src/components/mm/PrintPackingListLuoyang.vue b/north-glass-erp/northglass-erp/src/components/mm/PrintPackingListLuoyang.vue
index 170d531..e7f266d 100644
--- a/north-glass-erp/northglass-erp/src/components/mm/PrintPackingListLuoyang.vue
+++ b/north-glass-erp/northglass-erp/src/components/mm/PrintPackingListLuoyang.vue
@@ -194,12 +194,12 @@
                 <div style="width: 50%"><span style="font-weight: bold">鏈灦鏁伴噺</span>锛歿{customer.quantity}}</div>
               </div>
               <div style="display:flex;">
-                <div style="width: 50%"><span style="font-weight: bold">鍔犲伐鐝粍</span>锛歿{customer.teams_groups_name}}</div>
-                <div style="width: 50%"><span style="font-weight: bold">鍖呰鐝粍</span>锛歿{customer.teams_groups_name2}}</div>
+                <div style="width: 50%;font-size: 9px"><span style="font-weight: bold">鍔犲伐鐝粍</span>锛歿{customer.teams_groups_name2}}</div>
+                <div style="width: 50%;font-size: 9px"><span style="font-weight: bold">鍖呰鐝粍</span>锛歿{customer.teams_groups_name}}</div>
               </div>
               <div style="display:flex;">
                 <div style="width: 50%"><span style="font-weight: bold">璐ㄩ噺妫�楠�</span>锛氬垬鍖栬強</div>
-                <div style="width: 50%"><span style="font-weight: bold">鎴愬搧鍙戣揣</span>锛�</div>
+                <div style="width: 50%"><span style="font-weight: bold">鎴愬搧鍙戣揣</span>锛氶儜鐝婄強</div>
               </div>
 
 
diff --git a/north-glass-erp/northglass-erp/src/components/sd/order/UploadPicture.vue b/north-glass-erp/northglass-erp/src/components/sd/order/UploadPicture.vue
index c77013f..dac7efb 100644
--- a/north-glass-erp/northglass-erp/src/components/sd/order/UploadPicture.vue
+++ b/north-glass-erp/northglass-erp/src/components/sd/order/UploadPicture.vue
@@ -14,7 +14,7 @@
   console.log(file)
 }
 const handleChange = (uploadFile, uploadFiles) => {
-  emits('getUploadPicture', uploadFile.name)
+  emits('getUploadPicture', uploadFile.name,uploadFile)
   upload.value.clearFiles()
 }
 
diff --git a/north-glass-erp/northglass-erp/src/views/sd/order/CreateOrder.vue b/north-glass-erp/northglass-erp/src/views/sd/order/CreateOrder.vue
index 9e89320..0cee56d 100644
--- a/north-glass-erp/northglass-erp/src/views/sd/order/CreateOrder.vue
+++ b/north-glass-erp/northglass-erp/src/views/sd/order/CreateOrder.vue
@@ -129,7 +129,7 @@
           { code: 'sizeCheck', name: t('basicData.sizeReview'), prefixIcon: 'vxe-icon-eye-fill', visible: true, disabled: false },
           { code: 'updateOrderId', name: t('searchOrder.updateOrderId'), prefixIcon: 'vxe-icon-eye-fill', visible: true, disabled: false },
           { code: 'reportingTransfer', name: t('searchOrder.reportingTransfer'), prefixIcon: 'vxe-icon-send', visible: true, disabled: true },
-          /*{ code: 'uploadPicture', name: 'Upload Picture',  visible: true, }*/
+          { code: 'uploadPicture', name: 'Upload Picture',  visible: true, }
         ]
       ]
     }
@@ -182,6 +182,7 @@
     {field: 'bendRadius',width:160,  title: t('order.bendRadius'),editRender: { name: 'input'},filters:[{ data: '' }],slots: { filter: 'num1_filter' }, sortable: true,filterMethod:filterChanged},
     {field: 'edgingType',width:160,  title: t('order.edgingType'),editRender: { name: 'input'},filters:[{ data: '' }],slots: { filter: 'num1_filter' }, sortable: true,filterMethod:filterChanged},
     {field: 'processingNote',width:200,  title: t('order.processingNote'),editRender: { name: 'input'},filters:[{ data: '' }],slots: { filter: 'num1_filter' }, sortable: true,filterMethod:filterChanged},
+    {field: 'fileName',width:200,  title: t('鏂囦欢鍚嶇О'),filters:[{ data: '' }],slots: { filter: 'num1_filter' }, sortable: true,filterMethod:filterChanged},
     {field: 'remarks',width:140,  title: t('basicData.remarks'),editRender: { name: 'input'},filters:[{ data: '' }],slots: { filter: 'num1_filter' }, sortable: true,filterMethod:filterChanged},
 
 
@@ -925,6 +926,12 @@
       const orderDetails = res.data.orderDetails
       orderDetails.forEach(item => {
         item.otherColumns = JSON.parse(item.otherColumns)
+        if(res.data.orderFile!=null){
+          res.data.orderFile.forEach(items=>{
+            if(items.order_number==item.orderNumber)
+            item.fileData=items.file_data
+          })
+        }
       })
       otherMoney.value =res.data.orderOtherMoneyList
           //鍔犺浇鍓〃鏁版嵁
@@ -1631,15 +1638,24 @@
 }
 
 //鍥剧墖涓婁紶鍚嶇О
-const getUploadPicture = (name) => {
+const getUploadPicture = async (name, file) => {
   uploadPictureVisible.value = false
   const row = xGrid.value.getCurrentRecord()
-  if(!row.otherColumns){
-    row.otherColumns = {}
-  }
-  row.otherColumns.S02 = name
+
+  row.fileName = name
+  const base64 = await fileToBase64(file.raw);
+  row.fileData = base64.replace(/^data:.+;base64,/, "");
 }
 
+const fileToBase64 = (file) => {
+  return new Promise((resolve, reject) => {
+    const reader = new FileReader();
+    reader.onload = () => resolve(reader.result);
+    reader.onerror = reject;
+    reader.readAsDataURL(file);
+  });
+};
+
 </script>
 
 <template>
diff --git a/north-glass-erp/src/main/java/com/example/erp/controller/sd/OrderController.java b/north-glass-erp/src/main/java/com/example/erp/controller/sd/OrderController.java
index 08abee7..ac9c5ce 100644
--- a/north-glass-erp/src/main/java/com/example/erp/controller/sd/OrderController.java
+++ b/north-glass-erp/src/main/java/com/example/erp/controller/sd/OrderController.java
@@ -265,5 +265,15 @@
         return  Result.seccess(null);
     }
 
+    @PostMapping("/upload-dxf")
+    public Result uploadDxf(@RequestBody Map<String,Object> object) {
+        return  Result.seccess(orderService.uploadDxf(object));
+    }
+
+    @PostMapping("/selectUploadDxf")
+    public Result selectUploadDxf(@RequestBody Map<String,Object> object) {
+        return  Result.seccess(orderService.selectUploadDxf(object));
+    }
+
 
 }
diff --git a/north-glass-erp/src/main/java/com/example/erp/entity/sd/OrderDetail.java b/north-glass-erp/src/main/java/com/example/erp/entity/sd/OrderDetail.java
index 38fbe40..4da708b 100644
--- a/north-glass-erp/src/main/java/com/example/erp/entity/sd/OrderDetail.java
+++ b/north-glass-erp/src/main/java/com/example/erp/entity/sd/OrderDetail.java
@@ -46,6 +46,9 @@
     private Integer deliveryNum;
     private Integer returnNum;
     private Integer state;
+    private String fileName;
+    @TableField(select = false,exist= false)
+    private String fileData;
     private LocalDate createTime;
     private LocalDate updateTime;
     @TableField(select = false,exist= false)
diff --git a/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderDetailMapper.java b/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderDetailMapper.java
index 69266bb..2492db1 100644
--- a/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderDetailMapper.java
+++ b/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderDetailMapper.java
@@ -49,5 +49,7 @@
 
     List<Order> exportOrderSummary(List<LocalDate> dates);
 
+    boolean deleteOrderFile(String orderId);
+
 
 }
diff --git a/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderMapper.java b/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderMapper.java
index 41efa3e..855fd5c 100644
--- a/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderMapper.java
+++ b/north-glass-erp/src/main/java/com/example/erp/mapper/sd/OrderMapper.java
@@ -60,4 +60,10 @@
     Map<String,String> scannerGlassInfo(String projectNo, Integer layoutId, Integer sort, String orderId);
 
     String getProcessIdByOptimizeHeatDetail(String projectId, Integer layoutId, Integer sort);
+
+    Boolean saveOrderFile(String fileName,String dxfData,String orderId,Integer orderNumber);
+
+    Map<String,String> selectOrderFile( String orderId,Integer orderNumber);
+
+    List<Map<String,String>> selectOrderFileList( String orderId);
 }
diff --git a/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java b/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java
index 44224e4..0384f8b 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java
@@ -863,13 +863,18 @@
                 for(Map<String, Object> details:detailList){
                     Map<String, Object> detailsmap = new HashMap<>();
                     detailsmap.put("product_name",details.get("product_name").toString());
-                    detailsmap.put("detailList",finishedOperateLogMapper
+                    List<Map<String, Object>> orderDetailList = finishedOperateLogMapper
                             .getDetailLists(
                                     finishedOperateLog.getOrderId(),
                                     finishedOperateLog.getRemarks(),
                                     Integer.valueOf(details.get("product_id").toString()),
                                     details.get("thickness").toString()
-                            ));
+                            );
+                    /*for (Map<String, Object>orderDetail:orderDetailList){
+
+                    }*/
+
+                    detailsmap.put("detailList",orderDetailList);
                     detailsmaplist.add(detailsmap);
 
                 }
diff --git a/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java b/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java
index ba2e441..3e78377 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java
@@ -232,6 +232,8 @@
         //鍒犻櫎璁㈠崟宸ヨ壓琛�
         // orderProcessDetailMapper.delete(new LambdaQueryWrapper<OrderProcessDetail>().eq(OrderProcessDetail::getOrderId, order.getOrderId()));
 
+        orderDetailMapper.deleteOrderFile(order.getOrderId());
+
         insertOtherDetail(order.getOrderId(),OrderDetails,orderOtherMoneyList);
     }
 
@@ -287,6 +289,10 @@
                 });
             }else{
                 OrderDetails.get(i).setOtherColumns("{}");
+            }
+
+            if(OrderDetails.get(i).getFileName()!=null&&!OrderDetails.get(i).getFileName().trim().isEmpty()){
+                orderMapper.saveOrderFile(OrderDetails.get(i).getFileName(), OrderDetails.get(i).getFileData(),orderId,OrderDetails.get(i).getOrderNumber());
             }
 
         }
@@ -404,7 +410,8 @@
     }
     //鍒犻櫎璁㈠崟
     public Integer deleteOrder(String id) {
-        return  orderMapper.delete(
+        orderDetailMapper.deleteOrderFile(id);
+        return orderMapper.delete(
                 new QueryWrapper<Order>().eq("order_id",id)
         );
     }
@@ -415,12 +422,14 @@
         Order order = orderMapper.selectOne(new QueryWrapper<Order>().eq("order_id",id));
         List<OrderDetail> orderDetails = orderDetailMapper.selectList(new QueryWrapper<OrderDetail>().eq("order_id",id));
         List<OrderOtherMoney> orderOtherMoneyList = orderOtherMoneyMapper.findById(id);
+        List<Map<String,String>> orderFileList = orderMapper.selectOrderFileList(id);
 
 
         Map<String,Object> map = new HashMap<>();
         map.put("order",order);
         map.put("orderDetails",orderDetails);
         map.put("orderOtherMoneyList",orderOtherMoneyList);
+        map.put("orderFile",orderFileList);
         return map;
     }
     //璁㈠崟瀹℃牳
@@ -972,4 +981,34 @@
         }
 
     }
+
+    public Object uploadDxf(Map<String,Object> object)  {
+        String fileName = "";
+        if (object.get("fileName") != null) {
+            fileName = object.get("fileName").toString();
+        }
+        String fileData = "";
+        if (object.get("fileData") != null) {
+            fileData = object.get("fileData").toString();
+        }
+        byte[] dxfData = Base64.getDecoder().decode(fileData);
+        String orderId="NG25010101";
+        Integer orderNumber=1;
+        orderMapper.saveOrderFile(fileName, fileData,orderId,orderNumber);
+        return true;
+    }
+
+    public Map<String,Object> selectUploadDxf(Map<String,Object> object)  {
+        String orderId = "";
+        if (object.get("orderId") != null) {
+            orderId = object.get("orderId").toString();
+        }
+        int orderNumber =0;
+        if (object.get("orderNumber") != null) {
+            orderNumber = Integer.parseInt(object.get("orderNumber").toString());
+        }
+        Map<String,Object> map = new HashMap<>();
+        map.put("data",orderMapper.selectOrderFile(orderId,orderNumber));
+        return map;
+    }
 }
diff --git a/north-glass-erp/src/main/resources/mapper/mm/FinishedOperateLog.xml b/north-glass-erp/src/main/resources/mapper/mm/FinishedOperateLog.xml
index a471991..6324c01 100644
--- a/north-glass-erp/src/main/resources/mapper/mm/FinishedOperateLog.xml
+++ b/north-glass-erp/src/main/resources/mapper/mm/FinishedOperateLog.xml
@@ -926,7 +926,7 @@
 
     <select id="getDetailLists">
         SELECT
-            od.building_number,
+            ifnull(od.building_number,ifnull(JSON_UNQUOTE(JSON_EXTRACT(od.other_columns, '$.S02')),'')) as building_number,
             od.width,
             od.height,
             fol.quantity,
diff --git a/north-glass-erp/src/main/resources/mapper/sd/OrderDetailMapper.xml b/north-glass-erp/src/main/resources/mapper/sd/OrderDetailMapper.xml
index d08023b..9d88fdc 100644
--- a/north-glass-erp/src/main/resources/mapper/sd/OrderDetailMapper.xml
+++ b/north-glass-erp/src/main/resources/mapper/sd/OrderDetailMapper.xml
@@ -28,7 +28,8 @@
                             weight,
                             perimeter,
                             monolithic_perimeter,
-                            other_columns
+                            other_columns,
+                            file_name
                           )
         values
         <foreach collection ="orderDetails" item="orderDetail" separator =",">
@@ -55,7 +56,8 @@
             #{orderDetail.weight},
             #{orderDetail.perimeter},
             #{orderDetail.monolithicPerimeter},
-            #{orderDetail.otherColumns}
+            #{orderDetail.otherColumns},
+            #{orderDetail.fileName}
              )
         </foreach>
     </insert>
@@ -1066,7 +1068,9 @@
         group by od.product_id,pd.detail
     </select>
 
-
+    <delete id="deleteOrderFile" >
+        delete from sd.order_file where order_id = #{orderId}
+    </delete>
 
 
 
diff --git a/north-glass-erp/src/main/resources/mapper/sd/OrderMapper.xml b/north-glass-erp/src/main/resources/mapper/sd/OrderMapper.xml
index 4322a81..4a12860 100644
--- a/north-glass-erp/src/main/resources/mapper/sd/OrderMapper.xml
+++ b/north-glass-erp/src/main/resources/mapper/sd/OrderMapper.xml
@@ -415,4 +415,21 @@
         and a.layout_id = #{layoutId}
         and a.sort = #{sort}
     </select>
+
+
+    <insert id="saveOrderFile">
+        insert into sd.order_file (order_id,order_number,file_name,file_data,create_time) values(#{orderId},#{orderNumber},#{fileName},#{dxfData},now())
+    </insert>
+
+    <select id="selectOrderFile">
+        select  * from sd.order_file
+        where order_id = #{orderId} and order_number = #{orderNumber}
+
+    </select>
+
+    <select id="selectOrderFileList">
+        select  * from sd.order_file
+        where order_id = #{orderId}
+
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0