dengjunjie
2025-10-17 55142f3214485c7ec12c5e414a56519f66a1eb1d
н¨Îļþ¼Ð/WIDESEA_WMSServer/WIDESEA_SquareCabinServices/MedicineGoodsServices.cs
@@ -24,6 +24,7 @@
        public MedicineGoodsServices(IRepository<Dt_MedicineGoods> BaseDal) : base(BaseDal)
        {
        }
        public IRepository<Dt_MedicineGoods> Repository => BaseDal;
        static string SearchDate = "";
@@ -44,7 +45,7 @@
                //请求参数
                var requestData = new
                {
                    searchDate = "2022-10-10 20:45:16"  // æ­£ç¡®çš„æ ¼å¼
                    searchDate = "2009-01-10 20:45:16"  // æ­£ç¡®çš„æ ¼å¼
                };
                //if (string.IsNullOrEmpty(SearchDate))
                //{
@@ -75,28 +76,29 @@
                }
                //获取所有已存在的商品编号
                var existingGoodsNos = BaseDal.Db.Queryable<Dt_MedicineGoods>()
                    .Select(g => g.Goods_no)
                var existingGoodsNos = BaseDal.Db.Queryable<Dt_MaterielInfo>()
                    .Select(g => g.MaterielCode)
                    .ToList();
                // æ”¶é›†æ‰€æœ‰è¦æ’入的实体
                var entityList = response.data.Where(Medicat => !existingGoodsNos.Contains(Medicat.goods_no)).Select(Medicat => new Dt_MedicineGoods
                var entityList = response.data.Where(Medicat => !existingGoodsNos.Contains(Medicat.goods_no)).Select(Medicat => new Dt_MaterielInfo
                {
                    Goods_no = Medicat.goods_no,
                    MaterialCode=Medicat.materialCode,
                    Goods_spm = Medicat.goods_spm,
                    Model = Medicat.model,
                    MaterielCode = Medicat.goods_no,
                    MaterielErpType = Medicat.materialCode,
                    item = Medicat.goods_tym, //通用名
                    MaterielName = Medicat.goods_spm,//物料名称
                    MaterielSpec = Medicat.model,
                    Factory = Medicat.factory,
                    Unit = Medicat.unit,
                    MaterielUnit = Medicat.unit,//单位
                    // ä½¿ç”¨ ?? è¿ç®—符提供默认值
                    Item_Iength = Medicat.item_length ,
                    Item_width = Medicat.item_width,
                    Item_hight = Medicat.item_hight,
                    Item_volumn = Medicat.item_volumn,
                    Item_weight = Medicat.item_weight,
                    Storage_cond = Medicat.storage_cond,
                    MaterielLength = (float?)Medicat.item_length ,
                    MaterielWide = (float?)Medicat.item_width,
                    MaterielHeight = (float?)Medicat.item_hight,
                    MaterielVolume = (float?)Medicat.item_volumn,
                    MaterielWeight = (float?)Medicat.item_weight,
                    MaterielStoragecondition = float.TryParse(Medicat.storage_confition, out var val) ? val : null, //储存条件
                    Remark = Medicat.remark,
                    GoodStatus = "未下发",
                    GoodStatusState = "未下发",
                    ModifyDate = Medicat.modify_date
                }).ToList();
                // ä¸€æ¬¡æ€§æ‰¹é‡æ’入数据库
@@ -123,7 +125,8 @@
            try
            {
                //先找到所有未下发的药品
                var list = BaseDal.QueryData(x => x.GoodStatus == "未下发").ToList();
                //var list = BaseDal.QueryData(x => x.GoodStatus == "未下发").ToList();
                var list =BaseDal.Db.Queryable<Dt_MaterielInfo>().Where(x => x.GoodStatusState == "未下发").ToList();
                if (list == null || !list.Any())
                {
                    return new WebResponseContent().OK("无未下发药品");
@@ -136,28 +139,28 @@
                        //用户code
                        customerCode = "905",
                        //物料类型
                        materialCode =item.MaterialCode,
                        materialCode =item.MaterielErpType,
                        //产品编码
                        productCode= item.Goods_no,
                        productCode= item.MaterielCode,
                        //产品名
                        productName =item.Goods_spm ,
                        productName =item.MaterielName,
                        //产品条码
                        productBarCode= item.Goods_no,
                        productBarCode= item.MaterielCode,
                        //规格
                        productSpecifications=item.Model,
                        productSpecifications=item.MaterielSpec,
                        //单位
                        unit = item.Unit,
                        unit = item.MaterielUnit,
                        //长
                        singleProductLongNum = item.Item_Iength.ToString(),
                        singleProductLongNum = item.MaterielLength.ToString(),
                        //宽
                        singleProductWideNum = item.Item_weight.ToString(),
                        singleProductWideNum = item.MaterielWide.ToString(),
                        //高
                        singleProductHighNum = item.Item_hight.ToString(),
                        singleProductHighNum = item.MaterielHeight.ToString(),
                        //重量
                        singleProductWeight = item.Item_weight.ToString(),
                        singleProductWeight = item.MaterielWeight.ToString(),
                        //体积
                        singleProductVolume = item.Item_volumn.ToString(),
                        singleProductVolume = item.MaterielVolume.ToString(),
                        //是否取消 0是不删除,1删除
                        isDelete = "0"
                    };
@@ -168,9 +171,9 @@
                    if (resp!=null&&resp.code=="0")
                    {
                        //更新药品状态-已完成
                        BaseDal.Db.Updateable<Dt_MedicineGoods>()
                            .SetColumns(x => x.GoodStatus == "下发完成")
                            .Where(x => x.Goods_no == item.Goods_no)
                        BaseDal.Db.Updateable<Dt_MaterielInfo>()
                            .SetColumns(x => x.GoodStatusState == "下发完成")
                            .Where(x => x.GoodStatusState == item.MaterielCode)
                            .ExecuteCommand();  
                    }
                    else
@@ -198,10 +201,9 @@
        /// <returns></returns>
        public WebResponseContent DeleteProduct(string goodsno)
        {
            try
            {
                var goods = BaseDal.QueryData(x => x.Goods_no == goodsno).FirstOrDefault();
                var goods = BaseDal.Db.Queryable< Dt_MaterielInfo >().Where(x => x.MaterielCode == goodsno).First();
                if (goods == null)
                {
                    return new WebResponseContent
@@ -217,26 +219,26 @@
                    //物料类型
                    materialCode = "YY",
                    //产品编码
                    productCode = goods.Goods_no,
                    productCode = goods.MaterielCode,
                    //产品名
                    productName = goods.Goods_spm,
                    productName = goods.MaterielName,
                    //产品条码
                    productBarCode = goods.Goods_no,
                    productBarCode = goods.MaterielCode,
                    //规格
                    productSpecifications = goods.Model,
                    productSpecifications = goods.MaterielSpec,
                    //单位
                    unit = goods.Unit,
                    unit = goods.MaterielUnit,
                    //长
                    singleProductLongNum = goods.Item_Iength.ToString(),
                    singleProductLongNum = goods.MaterielLength.ToString(),
                    //宽
                    singleProductWideNum = goods.Item_weight.ToString(),
                    singleProductWideNum = goods.MaterielWide.ToString(),
                    //高
                    singleProductHighNum = goods.Item_hight.ToString(),
                    singleProductHighNum = goods.MaterielHeight.ToString(),
                    //重量
                    singleProductWeight = goods.Item_weight.ToString(),
                    singleProductWeight = goods.MaterielWeight.ToString(),
                    //体积
                    singleProductVolume = goods.Item_volumn.ToString(),
                    singleProductVolume = goods.MaterielVolume.ToString(),
                    //是否取消 0是不删除,1删除
                    isDelete = "1"
                };
@@ -248,12 +250,10 @@
                if (resp != null && resp.code == "0")
                {
                    //我自己也删除
                    BaseDal.DeleteData(goods);
                    base.Db.Deleteable<Dt_MaterielInfo>().Where(x => x.MaterielCode == goodsno);
                    return new WebResponseContent { Status = true, Message = "删除成功" };
                }
                return new WebResponseContent { Status = false, Message = "删除失败请重试" };
            }
            catch (Exception ex)
            {