1
huanghongfeng
2024-12-08 885bd60ed54a0642c48c57a3d685cba24e4c763b
´úÂë¹ÜÀí/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs
@@ -1,9 +1,12 @@
using AutoMapper;
using Magicodes.ExporterAndImporter.Core;
using Magicodes.ExporterAndImporter.Excel;
using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using WIDESEA_Core;
@@ -181,5 +184,110 @@
            residueQuantity = needQuantity;
            return outStocks;
        }
        //导出
        public override WebResponseContent Export(PageDataOptions options)
        {
            WebResponseContent content = new WebResponseContent();
            try
            {
                string savePath = AppDomain.CurrentDomain.BaseDirectory + $"ExcelExport";
                IExporter exporter = new ExcelExporter();
                //添加条件
                string wheres = options.ValidatePageOptions(TProperties);
                //获取排序字段
                Dictionary<string, OrderByType> orderbyDic = options.GetPageDataSort(TProperties);
                List<Dt_StockInfo> entities = BaseDal.QueryData(wheres, orderbyDic);
                List<Dt_StockInfoDetail> detdata = _stockInfoDetail.QueryData();
                List<Dt_StockInfodt> stolist= new List<Dt_StockInfodt>();
                for (int i = 0; i < entities.Count; i++)
                {
                    Dt_StockInfoDetail dt_StockIndet = detdata.Where(x => x.StockId == entities[i].Id).FirstOrDefault();
                    string MaterialTypet = "原材料";
                    if (entities[i].MaterialType == (int)InventoryMaterialType.成品)
                    {
                        MaterialTypet = "成品";
                    }
                    else if(entities[i].MaterialType == (int)InventoryMaterialType.空托)
                    {
                        MaterialTypet = "空托";
                    }
                    string Wlstatust = "待检";
                    if (entities[i].Wlstatus== (int)InventoryMaterialStatus.合格)
                    {
                        Wlstatust = "合格";
                    }
                    else if (entities[i].Wlstatus == (int)InventoryMaterialStatus.不合格)
                    {
                        Wlstatust = "不合格";
                    }
                    else if (entities[i].Wlstatus == (int)InventoryMaterialStatus.空托)
                    {
                        Wlstatust = "空托";
                    }
                    else if (entities[i].Wlstatus == (int)InventoryMaterialStatus.退货)
                    {
                        Wlstatust = "退货";
                    }
                    else if (entities[i].Wlstatus == (int)InventoryMaterialStatus.返工)
                    {
                        Wlstatust = "返工";
                    }
                    else if (entities[i].Wlstatus == (int)InventoryMaterialStatus.特采)
                    {
                        Wlstatust = "特采";
                    }
                    Dt_StockInfodt dt_ = new Dt_StockInfodt()
                    {
                        PalletCode = entities[i].PalletCode,
                        MaterialType = MaterialTypet,
                        LocationCode = entities[i].LocationCode,
                        Wlstatus = Wlstatust,
                        MaterielCode = dt_StockIndet?.MaterielCode ?? "", // å¦‚æžœ dt_StockIndet ä¸º null,使用空字符串作为默认值
                        MaterielName = dt_StockIndet?.MaterielName ?? "",
                        OrderNo = dt_StockIndet?.OrderNo ?? "",
                        BatchNo = dt_StockIndet?.BatchNo ?? "",
                        SerialNumber = dt_StockIndet?.SerialNumber ?? "",
                        StockQuantity = dt_StockIndet?.StockQuantity ?? 0, // å‡è®¾ StockQuantity æ˜¯æ•°å€¼ç±»åž‹ï¼Œä½¿ç”¨ 0 ä½œä¸ºé»˜è®¤å€¼
                        BatchNoName = dt_StockIndet?.BatchNoName ?? "",
                        CreateDate = dt_StockIndet?.CreateDate ?? DateTime.MinValue, // å‡è®¾ CreateDate æ˜¯æ—¥æœŸç±»åž‹ï¼Œä½¿ç”¨é»˜è®¤æ—¶é—´
                        Remark = entities[i].Remark,
                    };
                    stolist.Add(dt_);
                }
                byte[] data = exporter.ExportAsByteArray(stolist).Result;
                string fileName = "1.xlsx";
                FileHelper.WriteFile(savePath, fileName, data);
                content = WebResponseContent.Instance.OK(data: savePath + "\\" + fileName);
            }
            catch (Exception ex)
            {
                content = WebResponseContent.Instance.Error(ex.Message);
            }
            return content;
        }
        public class Dt_StockInfodt: Dt_StockInfoDetail
        {
            [ExporterHeader(DisplayName = "托盘编号")]
            public string PalletCode { get; set; }
            [ExporterHeader(DisplayName = "类型")]
            public string MaterialType { get; set; }
            [ExporterHeader(DisplayName = "货位编号")]
            public string LocationCode { get; set; }
            [ExporterHeader(DisplayName = "物料状态")]
            public string Wlstatus { get; set; }
        }
    }
}