using Myshipping.Core; using Furion.DependencyInjection; using Furion.DynamicApiController; using Mapster; using Microsoft.AspNetCore.Mvc; using SqlSugar; using System.Linq; using System.Threading.Tasks; using Myshipping.Core.Entity; using System.Collections.Generic; namespace Myshipping.Core.Service { /// /// 用户自定义配置服务 /// [ApiDescriptionSettings(Name = "DjyUserConfig", Order = 1)] public class DjyUserConfigService : IDjyUserConfigService, IDynamicApiController, ITransient { private readonly SqlSugarRepository _rep; public DjyUserConfigService(SqlSugarRepository rep) { _rep = rep; } /// /// 分页查询用户自定义配置 /// /// /// [HttpGet("/DjyUserConfig/page")] public async Task Page([FromQuery] QueryDjyUserConfigInput input) { var entities = await _rep.AsQueryable() .Where(m => m.TenantId == UserManager.TENANT_ID) .WhereIF(!string.IsNullOrWhiteSpace(input.Type), u => u.Type == input.Type) .WhereIF(!string.IsNullOrWhiteSpace(input.ConfigJson), u => u.ConfigJson == input.ConfigJson) .ToPagedListAsync(input.PageNo, input.PageSize); return entities.XnPagedResult(); } /// /// 增加用户自定义配置(同用户、同类型的会更新) /// /// /// [HttpPost("/DjyUserConfig/add")] public async Task Add(AddDjyUserConfigInput input) { var entity = _rep.FirstOrDefault(x => x.Type == input.Type && x.CreatedUserId == UserManager.UserId); if (entity == null) { entity = input.Adapt(); await _rep.InsertAsync(entity); } else { entity.ConfigJson = input.ConfigJson; await _rep.UpdateAsync(entity); } } /// /// 更新用户自定义配置 /// /// /// [HttpPost("/DjyUserConfig/edit")] public async Task Update(UpdateDjyUserConfigInput input) { var entity = input.Adapt(); await _rep.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); } /// /// 删除用户自定义配置 /// /// /// [HttpPost("/DjyUserConfig/delete")] public async Task Delete(GetDjyUserConfigInput input) { var entity = await _rep.FirstOrDefaultAsync(u => u.Id == input.Id); await _rep.DeleteAsync(entity); } /// /// 获取用户自定义配置 /// /// /// [HttpGet("/DjyUserConfig/get")] public async Task Get([FromQuery] string type) { return await _rep.FirstOrDefaultAsync(u => u.CreatedUserId == UserManager.UserId && u.Type == type); } /// /// 获取用户自定义配置(批量) /// /// /// [HttpGet("/DjyUserConfig/multi")] public async Task> Multi(string[] typeArr) { //return await _rep.ToListAsync(u => u.CreatedUserId == UserManager.UserId && typeArr.Contains(u.Type)); List data = new List(); string[] typelist = { "BC", "PER_BILL", "TRUCK_DISPATCH", "CUT_MODIFY", "ROLLING_NOMINATION", "DRAFT", "ROUTE_CUT_CHANGE", "CAUTION_NOTICE", "POD_DISCHARGE_FULL", "basic" }; foreach (var type in typeArr) { if (typelist.Contains(type)) { var datainfo = _rep.Where(u => u.CreatedUserId == UserManager.UserId && u.Type == type).First(); if (datainfo == null) { string typestr = type + "_default"; var dataitem = _rep.AsQueryable().Filter(null, true).Where(u => u.Type == typestr).First(); if (dataitem!=null) { dataitem.Type = type; data.Add(dataitem); } } else { if (datainfo != null) data.Add(datainfo); } } else { var userconfig = _rep.Where(u => u.CreatedUserId == UserManager.UserId && u.Type == type).First(); if (userconfig != null) { data.Add(userconfig); } } } return data; } } }