baotian
2024-06-04 b959135a1139fb66646523d92e5bd20c5910f283
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
using Furion.DatabaseAccessor;
using Furion.DependencyInjection;
using Furion.DynamicApiController;
using iWare.Wms.Core;
using iWare.Wms.Core.Enum;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using StackExchange.Redis;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Xml.Linq;
 
namespace iWare.Wms.Application.Service.WmsBase.WmsSeed
{
    /// <summary>
    /// 获取种子数据
    /// </summary>
    //[ApiDescriptionSettings("种子数据", Name = "WmsSeed", Order = 100)]
    //[Route("api/[Controller]")]
    public class WmsSeed : IDynamicApiController, ITransient
    {
        private readonly IRepository<WmsTask, MasterDbContextLocator> _wmsTask;
        private readonly IRepository<WmsMaterialStock, MasterDbContextLocator> _wmsMaterialStock;
        private readonly IRepository<WmsContainerPlace, MasterDbContextLocator> _wmsContainerPlace;
        private readonly IRepository<WmsMaterialContainer, MasterDbContextLocator> _wmsMaterialContainer;
        private readonly IRepository<SysDictData, MasterDbContextLocator> _sysDictData;
        private readonly IRepository<SysMenu, MasterDbContextLocator> _sysMenu;
 
        public WmsSeed(
            IRepository<WmsTask, MasterDbContextLocator> wmsTask,
            IRepository<WmsMaterialStock, MasterDbContextLocator> wmsMaterialStock,
            IRepository<WmsContainerPlace, MasterDbContextLocator> wmsContainerPlace,
            IRepository<WmsMaterialContainer, MasterDbContextLocator> wmsMaterialContainer,
            IRepository<SysDictData, MasterDbContextLocator> sysDictData,
            IRepository<SysMenu, MasterDbContextLocator> sysMenu
        )
        {
            _wmsTask = wmsTask;
            _wmsMaterialStock = wmsMaterialStock;
            _wmsContainerPlace = wmsContainerPlace;
            _wmsMaterialContainer = wmsMaterialContainer;
            _sysDictData = sysDictData;
            _sysMenu = sysMenu;
        }
 
        /// <summary>
        /// 任务管理实体种子
        /// </summary>
        /// <returns></returns>
        [HttpGet("WmsTaskSeed")]
        [AllowAnonymous]
        public async Task<List<string>> WmsTaskSeed()
        {
            var taskList = await _wmsTask.Where(n => n.IsDeleted == false).ToListAsync();
            var newtaskList = new List<string>();
            var TaskModel1 = "";
            var TaskType1 = "";
            var TaskStatus1 = "";
            foreach (var item in taskList)
            {
                if (item.TaskModel == TaskModel.SHOUDONG) TaskModel1 = "TaskModel.SHOUDONG";
                if (item.TaskModel == TaskModel.ZIDONG) TaskModel1 = "TaskModel.ZIDONG";
                if (item.TaskType == TaskType.RUKU) TaskType1 = "TaskType.RUKU";
                if (item.TaskType == TaskType.CHUKU) TaskType1 = "TaskType.CHUKU";
                if (item.TaskType == TaskType.YIKU) TaskType1 = "TaskType.YIKU";
                if (item.TaskStatus == Core.Enum.TaskStatus.WEIZHIXING) TaskStatus1 = "Core.Enum.TaskStatus.WEIZHIXING";
                if (item.TaskStatus == Core.Enum.TaskStatus.ZHIXINGZHONG) TaskStatus1 = "Core.Enum.TaskStatus.ZHIXINGZHONG";
                if (item.TaskStatus == Core.Enum.TaskStatus.WANCHENG) TaskStatus1 = "Core.Enum.TaskStatus.WANCHENG";
                var task = string.Format("Id={0},TaskNo=\"{1}\",TaskModel={2},TaskType={3},TaskLevel={4},TaskStatus={5},ContainerCode=\"{6}\",SourcePlace=\"{7}\",ToPlace=\"{8}\",Aisle={9},AreaName=\"{10}\",OrderNo=\"{11}\",SendTimes={12}", item.Id, item.TaskNo, TaskModel1, TaskType1, item.TaskLevel, TaskStatus1, item.ContainerCode, item.SourcePlace, item.ToPlace, item.Aisle, item.AreaName, item.OrderNo, item.SendTimes);
                newtaskList.Add("new WmsTask{"+task+ "}");
            }
            return newtaskList;
        }
 
        /// <summary>
        /// 库存表实体种子
        /// </summary>
        /// <returns></returns>
        [HttpGet("WmsMaterialStockSeed")]
        [AllowAnonymous]
        public async Task<List<string>> WmsMaterialStockSeed()
        {
            var stockList = await _wmsMaterialStock.Where(n => n.IsDeleted == false).ToListAsync();
            var newstockList = new List<string>();
            var MaterialType1 = "";
            var MaterialInspection1 = "";
            var UnitType1 = "";
            var UnitnoType1 = "";
            foreach (var item in stockList)
            {
                if (item.MaterialType == MaterialType.YUANCAILIAO) MaterialType1 = "MaterialType.YUANCAILIAO";
                if (item.MaterialType == MaterialType.BANCHENGPING) MaterialType1 = "MaterialType.BANCHENGPING";
                if (item.MaterialType == MaterialType.CHENGPING) MaterialType1 = "MaterialType.CHENGPING";
                if (item.MaterialType == MaterialType.KONGTUO) MaterialType1 = "MaterialType.KONGTUO";
                if (item.InspectionMethod == MaterialInspection.MIANJIAN) MaterialInspection1 = "MaterialInspection.MIANJIAN";
                if (item.InspectionMethod == MaterialInspection.CHOUJIAN) MaterialInspection1 = "MaterialInspection.CHOUJIAN";
                if (item.UnitType == UnitType.CHANGDU) UnitType1 = "UnitType.CHANGDU";
                if (item.UnitType == UnitType.ZHONGLIANG) UnitType1 = "UnitType.ZHONGLIANG";
                if (item.UnitNo == UnitnoType.CM) UnitnoType1 = "UnitnoType.CM";
                if (item.UnitNo == UnitnoType.T) UnitnoType1 = "UnitnoType.T";
                var stock = string.Format("Id={0},MaterialNo=\"{1}\",MaterialType={2},MaterialBatch=\"{3}\",MaterialName=\"{4}\",MaterialSpec=\"{5}\",InspectionMethod={6},UnitType={7},UnitNo={8},StockNumber=(decimal){9},PlaceCode=\"{10}\",ContainerCode=\"{11}\",AreaId={12}", item.Id, item.MaterialNo, MaterialType1, item.MaterialBatch, item.MaterialName, item.MaterialSpec, MaterialInspection1, UnitType1, UnitnoType1, item.StockNumber, item.PlaceCode, item.ContainerCode, item.AreaId);
                newstockList.Add("new WmsMaterialStock{" + stock+ "}");
            }
            return newstockList;
        }
 
        /// <summary>
        /// 托盘库位关系表实体种子
        /// </summary>
        /// <returns></returns>
        [HttpGet("WmsContainerPlaceSeed")]
        [AllowAnonymous]
        public async Task<List<string>> WmsContainerPlaceSeed()
        {
            var placeList = await _wmsContainerPlace.Where(n => n.IsDeleted == false).ToListAsync();
            var newplaceList = new List<string>();
            var CommonStatus1 = "";
            foreach (var item in placeList)
            {
                if (item.ContainerPlaceStatus == CommonStatus.ENABLE) CommonStatus1 = "CommonStatus.ENABLE";
                if (item.ContainerPlaceStatus == CommonStatus.DISABLE) CommonStatus1 = "CommonStatus.DISABLE";
                if (item.ContainerPlaceStatus == CommonStatus.DELETED) CommonStatus1 = "CommonStatus.DELETED";
                var place = string.Format("Id={0},PlaceId={1},PlaceCode=\"{2}\",ContainerId={3},ContainerCode=\"{4}\",ContainerPlaceStatus={5}", item.Id, item.PlaceId, item.PlaceCode, item.ContainerId, item.ContainerCode, CommonStatus1);
                newplaceList.Add("new WmsContainerPlace{"+place+"}");
            }
            return newplaceList;
        }
 
        /// <summary>
        /// 物料托盘关系表实体种子
        /// </summary>
        /// <returns></returns>
        [HttpGet("WmsMaterialContainerSeed")]
        [AllowAnonymous]
        public async Task<List<string>> WmsMaterialContainerSeed()
        {
            var masterList = await _wmsMaterialContainer.Where(n => n.IsDeleted == false).ToListAsync();
            var newmasterList = new List<string>();
            var CommonStatus1 = "";
            foreach (var item in masterList)
            {
                if (item.BindStatus == CommonStatus.ENABLE) CommonStatus1 = "CommonStatus.ENABLE";
                if (item.BindStatus == CommonStatus.DISABLE) CommonStatus1 = "CommonStatus.DISABLE";
                if (item.BindStatus == CommonStatus.DELETED) CommonStatus1 = "CommonStatus.DELETED";
                var master = string.Format("Id={0},ContainerId={1},ContainerCode=\"{2}\",MaterialName=\"{3}\",MaterialNo=\"{4}\",MaterialBatch=\"{5}\",MaterialSpec=\"{6}\",MaterialId={7},BindQuantity=(decimal){8},BindStatus={9},SampleQty=(decimal){10},OrderNo=\"{11}\"", item.Id, item.ContainerId, item.ContainerCode, item.MaterialName, item.MaterialNo, item.MaterialBatch, item.MaterialSpec, item.MaterialId, item.BindQuantity, CommonStatus1, item.SampleQty, item.OrderNo);
                newmasterList.Add("new WmsMaterialContainer{"+master+"}");
            }
            return newmasterList;
        }
 
        /// <summary>
        /// 字典表实体种子
        /// </summary>
        /// <returns></returns>
        [HttpGet("SysDictDataSeed")]
        [AllowAnonymous]
        public async Task<List<string>> SysDictDataSeed()
        {
            var dictdataList = await _sysDictData.Where(n => n.IsDeleted == false).ToListAsync();
            var newdictdataList = new List<string>();
            foreach (var item in dictdataList)
            {
                var Zhi = string.Format("Id={0},TypeId={1},Value=\"{2}\",Code=\"{3}\",Sort={4},Remark=\"{5}\",Status={6}", item.Id, item.TypeId, item.Value, item.Code, item.Sort, item.Remark, item.Status);
                newdictdataList.Add("new SysDictData{" + Zhi + "}");
            }
            return newdictdataList;
        }
 
        /// <summary>
        /// 系统菜单表实体种子
        /// </summary>
        /// <returns></returns>
        [HttpGet("SysMenuSeed")]
        [AllowAnonymous]
        public async Task<List<string>> SysMenuSeed()
        {
            var menuList = await _sysMenu.Where(n => n.IsDeleted == false).ToListAsync();
            var newmenuList = new List<string>();
            var MenuType1 = "";
            var MenuOpenType1 = "";
            var MenuWeight1 = "";
            var CommonStatus1 = "";
            foreach (var item in menuList)
            {
                if (item.Type == MenuType.DIR) MenuType1 = "MenuType.DIR";
                if (item.Type == MenuType.MENU) MenuType1 = "MenuType.MENU";
                if (item.Type == MenuType.BTN) MenuType1 = "MenuType.BTN";
                if (item.OpenType == MenuOpenType.NONE) MenuOpenType1 = "MenuOpenType.NONE";
                if (item.OpenType == MenuOpenType.COMPONENT) MenuOpenType1 = "MenuOpenType.COMPONENT";
                if (item.OpenType == MenuOpenType.INNER) MenuOpenType1 = "MenuOpenType.INNER";
                if (item.OpenType == MenuOpenType.OUTER) MenuOpenType1 = "MenuOpenType.OUTER";
                if (item.Weight == MenuWeight.SUPER_ADMIN_WEIGHT) MenuWeight1 = "MenuWeight.SUPER_ADMIN_WEIGHT";
                if (item.Weight == MenuWeight.DEFAULT_WEIGHT) MenuWeight1 = "MenuWeight.DEFAULT_WEIGHT";
                if (item.Status == CommonStatus.ENABLE) CommonStatus1 = "CommonStatus.ENABLE";
                if (item.Status == CommonStatus.DISABLE) CommonStatus1 = "CommonStatus.DISABLE";
                if (item.Status == CommonStatus.DELETED) CommonStatus1 = "CommonStatus.DELETED";
                var Zhi = "";
                if (item.Pid == 0)
                {
                    Zhi = string.Format("Id={0},Pid={1},Pids=\"{2}\",Name=\"{3}\",Code=\"{4}\",Type={5},Icon=\"{6}\",Router=\"{7}\",Component=\"{8}\",Application=\"{9}\",OpenType={10},Visible=\"{11}\",Weight={12},Sort={13},Status={14}", item.Id, item.Pid, item.Pids, item.Name, item.Code, MenuType1, item.Icon, item.Router, item.Component, item.Application, MenuOpenType1, item.Visible, MenuWeight1, item.Sort, CommonStatus1);
                }
                else
                {
                    Zhi = string.Format("Id={0},Pid={1},Pids=\"{2}\",Name=\"{3}\",Code=\"{4}\",Type={5},Permission=\"{6}\",Application=\"{7}\",OpenType={8},Visible=\"{9}\",Weight={10},Sort={11},Status={12}", item.Id, item.Pid, item.Pids, item.Name, item.Code, MenuType1, item.Permission, item.Application, MenuOpenType1, item.Visible, MenuWeight1, item.Sort, CommonStatus1);
                }
                newmenuList.Add("new SysMenu{" + Zhi + "}");
            }
            return newmenuList;
        }
    }
}