移动系统liao
2024-11-12 1cb49b04ae6709e6054c328f5ed12bff9ca014c8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/***********************************************************************
 *            Project: baifenBinfa
 *        ProjectName: 百分兵法管理系统                               
 *                Web: http://chuanyin.com                     
 *             Author:                                        
 *              Email:                               
 *         CreateTime: 202403/02   
 *        Description: 暂无
 ***********************************************************************/
 
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using CoreCms.Net.Configuration;
using CoreCms.Net.IRepository;
using CoreCms.Net.IRepository.UnitOfWork;
using CoreCms.Net.IServices;
using CoreCms.Net.Model.Entities;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
 
 
namespace CoreCms.Net.Services
{
    /// <summary>
    /// 订单明细表 接口实现
    /// </summary>
    public class CoreCmsOrderItemServices : BaseServices<CoreCmsOrderItem>, ICoreCmsOrderItemServices
    {
        private readonly ICoreCmsOrderItemRepository _dal;
        private readonly IUnitOfWork _unitOfWork;
        private readonly IServiceProvider _serviceProvider;
 
        public CoreCmsOrderItemServices(IUnitOfWork unitOfWork,
            IServiceProvider serviceProvider,
            ICoreCmsOrderItemRepository dal)
        {
            _serviceProvider = serviceProvider;
            this._dal = dal;
            base.BaseDal = dal;
            _unitOfWork = unitOfWork;
        }
 
        /// <summary>
        /// 发货数量
        /// </summary>
        /// <param name="orderId"></param>
        /// <param name="item">发货明细</param>
        /// <returns></returns>
        public async Task<bool> ship(string orderId, Dictionary<int, int> item)
        {
            using (var container = _serviceProvider.CreateScope())
            {
                var goodsRepository = container.ServiceProvider.GetService<ICoreCmsGoodsRepository>();
 
                var isOver = true;     //是否发完了,true发完了,false未发完
                var list = await base.QueryListByClauseAsync(p => p.orderId == orderId);
                foreach (var child in list)
                {
                    if (item.ContainsKey(child.productId))
                    {
                        var maxNum = child.nums - child.sendNums; //还需要减掉已发数量
 
                        //还需要减掉已退的数量
                        var reshipNums = _dal.GetaftersalesNums(orderId, child.sn);
                        maxNum = maxNum - reshipNums;
 
                        if (item[child.productId] > maxNum)  //如果发超了怎么办
                        {
                            throw new System.Exception(orderId + "的" + child.sn + "发超了");
                        }
 
                        if (isOver && item[child.productId] < maxNum)  //判断是否订单发完了,有一个没发完,就是未发完
                        {
                            isOver = false;
                        }
 
                        //await _dal.UpdateAsync(p => new CoreCmsOrderItem() { sendNums = item[child.productId] },
                        //    p => p.id == child.id);
 
                        var updateSendNums = item[child.productId] + child.sendNums;
                        await _dal.UpdateAsync(p => new CoreCmsOrderItem() { sendNums = updateSendNums }, p => p.id == child.id);
 
 
                        //发货后,减库存
                        goodsRepository.ChangeStock(child.productId, GlobalEnumVars.OrderChangeStockType.send.ToString(), item[child.productId]);
 
                        item.Remove(child.productId);
                    }
                }
                //如果没发完,也报错
                if (item.Count > 0)
                {
                    throw new System.Exception("发货明细里包含订单之外的商品");
                }
                return isOver;
            }
 
 
        }
 
    }
}