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;
}
}
}