huanghongfeng
2025-06-23 b7f53ba61fbc1844d7b92ff852762b140d46ab54
´úÂë¹ÜÀí/WMS/WIDESEA_WMSServer/WIDESEA_StockService/Service/StockInfoService.cs
@@ -4,6 +4,7 @@
using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup;
using SqlSugar;
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
@@ -13,6 +14,7 @@
using WIDESEA_Core.BaseServices;
using WIDESEA_Core.Enums;
using WIDESEA_Core.Helper;
using WIDESEA_Core.Utilities;
using WIDESEA_DTO.Stock;
using WIDESEA_IBasicRepository;
using WIDESEA_IRecordRepository;
@@ -20,6 +22,7 @@
using WIDESEA_IStockRepository;
using WIDESEA_IStockService;
using WIDESEA_Model.Models;
using WIDESEA_StockRepository;
namespace WIDESEA_StockService
{
@@ -184,6 +187,67 @@
            residueQuantity = needQuantity;
            return outStocks;
        }
        /// <summary>
        /// åˆ é™¤æ•°æ®
        /// </summary>
        /// <param name="keys">主键数组</param>
        /// <returns></returns>
        public virtual WebResponseContent DeleteData(object[] keys)
        {
            try
            {
                List<Dt_StockInfo> stockList = BaseDal.QureyDataByIds(keys);
                var stokd= stockList.Where(x=>x.StockStatus != (int)StockStatusEmun.组盘暂存).ToList();
                if(stokd.Count > 0 )
                {
                    return WebResponseContent.Instance.Error("删除失败!只能删除“组盘暂存”的信息");
                }
                foreach (var item in stockList)
                {
                    var stodet=_stockRepository.StockInfoDetailRepository.QueryFirst(x => x.StockId == item.Id);
                    _stockRepository.StockInfoDetailRepository.DeleteData(stodet);
                }
                if (typeof(Dt_StockInfodt).GetNavigatePro() == null)
                    return BaseDal.DeleteDataByIds(keys) ? WebResponseContent.Instance.OK() : WebResponseContent.Instance.Error();
                else
                {
                    if (keys != null)
                    {
                        Type detailType = typeof(Dt_StockInfodt).GetDetailType();
                        string name = typeof(Dt_StockInfodt).GetMainIdByDetail();
                        List<object> dynamicDelKeys = new List<object>();
                        for (int i = 0; i < keys.Length; i++)
                        {
                            dynamicDelKeys.Add(keys[i]);
                        }
                        ((SqlSugarClient)BaseDal.Db).BeginTran();
                        if (dynamicDelKeys.Count > 0)
                            BaseDal.Db.Deleteable<object>().AS(detailType.Name).Where($"{name} in (@id)", new { id = dynamicDelKeys.ToArray() }).ExecuteCommandHasChange();
                        BaseDal.DeleteDataByIds(keys);
                        ((SqlSugarClient)BaseDal.Db).CommitTran();
                        return WebResponseContent.Instance.OK();
                    }
                    else
                    {
                        return WebResponseContent.Instance.Error("参数错误");
                    }
                }
            }
            catch (Exception ex)
            {
                ((SqlSugarClient)BaseDal.Db).RollbackTran();
                return WebResponseContent.Instance.Error(ex.Message);
            }
        }
        //导出
        public override WebResponseContent Export(PageDataOptions options)
@@ -243,18 +307,18 @@
                    Dt_StockInfodt dt_ = new Dt_StockInfodt()
                    {
                        PalletCode= entities[i].PalletCode,
                        PalletCode = entities[i].PalletCode,
                        MaterialType = MaterialTypet,
                        LocationCode = entities[i].LocationCode,
                        Wlstatus = Wlstatust,
                        MaterielCode=dt_StockIndet.MaterielCode,
                        MaterielName = dt_StockIndet.MaterielName,
                        OrderNo = dt_StockIndet.OrderNo,
                        BatchNo = dt_StockIndet.BatchNo,
                        SerialNumber = dt_StockIndet.SerialNumber,
                        StockQuantity = dt_StockIndet.StockQuantity,
                        BatchNoName = dt_StockIndet.BatchNoName,
                        CreateDate = dt_StockIndet.CreateDate,
                        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_);