From 75b2904fbaf4fab6a9fb3baf065d2c927cc7a7a2 Mon Sep 17 00:00:00 2001
From: zouyu <2723363702@qq.com>
Date: 星期三, 27 九月 2023 18:16:34 +0800
Subject: [PATCH] 基础数据-物料清单维护-导出

---
 inventory-server/src/main/java/com/yuanchu/mom/service/impl/SaleServiceImpl.java |   71 ++++++++++++++++++++++++++++++-----
 1 files changed, 61 insertions(+), 10 deletions(-)

diff --git a/inventory-server/src/main/java/com/yuanchu/mom/service/impl/SaleServiceImpl.java b/inventory-server/src/main/java/com/yuanchu/mom/service/impl/SaleServiceImpl.java
index ea3ff9d..4f61f64 100644
--- a/inventory-server/src/main/java/com/yuanchu/mom/service/impl/SaleServiceImpl.java
+++ b/inventory-server/src/main/java/com/yuanchu/mom/service/impl/SaleServiceImpl.java
@@ -1,29 +1,35 @@
 package com.yuanchu.mom.service.impl;
 
 import cn.hutool.core.date.DateUtil;
+import com.alibaba.excel.EasyExcel;
+import com.alibaba.excel.support.ExcelTypeEnum;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.yuanchu.mom.Task.SyncOrder;
+import com.yuanchu.mom.mapper.SaleMapper;
 import com.yuanchu.mom.mapper.SaleMaterialMapper;
 import com.yuanchu.mom.pojo.Sale;
-import com.yuanchu.mom.mapper.SaleMapper;
 import com.yuanchu.mom.pojo.SaleMaterial;
-import com.yuanchu.mom.pojo.dto.ConsignmentDto1;
-import com.yuanchu.mom.pojo.dto.ConsignmentDto2;
-import com.yuanchu.mom.pojo.dto.SaleDto;
-import com.yuanchu.mom.pojo.dto.SaleMaterialDto;
+import com.yuanchu.mom.pojo.dto.*;
 import com.yuanchu.mom.pojo.vo.SaleVo;
 import com.yuanchu.mom.service.SaleMaterialService;
 import com.yuanchu.mom.service.SaleService;
-import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import com.yuanchu.mom.vo.Result;
+import com.yuanchu.mom.utils.easyexcel.CustemHandler;
+import com.yuanchu.mom.utils.easyexcel.EasyExcelUtils;
+import com.yuanchu.mom.utils.easyexcel.converter.LocalDateConverter;
+import com.yuanchu.mom.utils.easyexcel.template.ExportSaleTemplate;
 import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.net.URLEncoder;
+import java.nio.charset.StandardCharsets;
 import java.time.LocalDateTime;
 import java.time.LocalTime;
 import java.time.format.DateTimeFormatter;
@@ -63,6 +69,7 @@
         Sale sale = new Sale();
         BeanUtils.copyProperties(saleDto, sale);
         sale.setSaleman(saleman);
+        sale.setOrderType("鎵嬪伐璁㈠崟");
         saleMapper.insert(sale);
         //娣诲姞閿�鍞骇鍝佸崟
         List<SaleMaterialDto> saleMaterialDtoList = saleDto.getSaleMaterialList();
@@ -186,9 +193,6 @@
                 .orderCode(orderNumber)
                 .customerCode(sale.getCode())
                 .proname(sale.getProname())
-                //.adress(sale.getAdress())
-                //.username(sale.getUsername())
-                //.phone(sale.getPhone())
                 .messages(dto2List)
                 .build();
         return consignmentDto1;
@@ -215,6 +219,8 @@
             sale.setDelTime(DateUtil.parseDate(orde.get("wantedDeliveryDate").toString()));//浜よ揣鏃ユ湡
             sale.setCreateTime(DateUtil.parseDate(orde.get("orderDate").toString()));//涓嬪崟鏃ユ湡
             sale.setNote(String.valueOf(orde.get("comment")));//澶囨敞
+            sale.setOrderId((Integer) orde.get("id"));  //otc璁㈠崟id
+            sale.setOrderType(orde.get("orderClassification").toString()); //璁㈠崟绫诲瀷
             return sale;
         }).collect(Collectors.toList());
         //鍘婚噸
@@ -239,4 +245,49 @@
         }
         return "鍚屾鎴愬姛!";
     }
+
+
+    //涓嬭浇闄勪欢
+    @Override
+    public List<String> download(Integer id) {
+        Integer orderId = saleMapper.selectById(id).getOrderId();
+        List<Map<String, Object>> attachment = SyncOrder.getAttachmentByOrderId(orderId);
+        List<String> list = new ArrayList<>();
+        if (ObjectUtils.isEmpty(attachment)) {
+            list.add("璇ヨ鍗曟病鏈夐檮浠�");
+            return list;
+        }
+        for (Map<String, Object> attch : attachment) {
+            String path = attch.get("path").toString();
+            list.add(path);
+        }
+        return list;
+    }
+
+    @Override
+    public void exportSale(ExportSaleDto dto, HttpServletResponse response) {
+        try{
+            List<ExportSaleTemplate> exportSaleTemplates = saleMapper.selectSaleListByExport(dto.getOrderNumber(), dto.getName(), dto.getType(), dto.getDelTime());
+            for (int i = 0; i < exportSaleTemplates.size(); i++) {
+                exportSaleTemplates.get(i).setId(i+1);
+            }
+            EasyExcel.write(EasyExcelUtils.getResponse(response,"閿�鍞鍗�").getOutputStream())
+                    .head(ExportSaleTemplate.class)
+                    .registerConverter(new LocalDateConverter())
+                    .autoCloseStream(true)
+                    .excelType(ExcelTypeEnum.XLS)
+                    .registerWriteHandler(new CustemHandler())
+                    .registerWriteHandler(EasyExcelUtils.getStyleStrategy())
+                    .sheet("Sheet1")
+                    .doWrite(exportSaleTemplates);
+        }catch (IOException e) {
+            e.printStackTrace();
+        } finally {
+            try {
+                response.getOutputStream().close();
+            } catch (IOException e) {
+                e.printStackTrace();
+            }
+        }
+    }
 }

--
Gitblit v1.9.3