using Infrastructure.Attribute;
using Microsoft.AspNetCore.Http;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Infrastructure;
using ARW.Model;
using ARW.Repository;
using ARW.Repository.Business.Project.Projects;
using ARW.Service.Business.IBusinessService.Project.Projects;
using ARW.Model.Dto.Business.Project.Projects;
using ARW.Model.Models.Business.Project.Projects;
using ARW.Model.Vo.Business.Project.Projects;
using ARW.Model.Models.Business.Project.ProjectGroups;
using ARW.Model.Models.Business.ToolCustomers;
namespace ARW.Service.Business.BusinessService.Project.Projects
{
///
/// 项目接口实现类
///
[AppService(ServiceType = typeof(IProjectesService), ServiceLifetime = LifeTime.Transient)]
public class ProjectesServiceImpl : BaseService, IProjectesService
{
private readonly ProjectesRepository _ProjectesRepository;
public ProjectesServiceImpl(ProjectesRepository ProjectesRepository)
{
this._ProjectesRepository = ProjectesRepository;
}
#region 业务逻辑代码
///
/// 查询项目分页列表
///
public Task> GetProjectesList(ProjectesQueryDto parm)
{
//开始拼装查询条件d
var predicate = Expressionable.Create();
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.ProjectName), it => it.ProjectName == parm.ProjectName);
var query = _ProjectesRepository
.Queryable()
.Where(predicate.ToExpression())
.LeftJoin((s, c) => s.ProjectGroupGuid == c.ProjectGroupGuid)
.LeftJoin((s, c, d) => s.ProjectCustomerGuid == d.ToolCustomerGuid)
.OrderBy(s => s.ProjectSort, OrderByType.Desc)
.Select((s,c,d) => new ProjectesVo
{
ProjectId = s.ProjectId,
ProjectGuid = s.ProjectGuid,
ProjectCustomerGuid = s.ProjectCustomerGuid,
ProjectGroupGuid = s.ProjectGroupGuid,
ProjectGroupName = c.ProjectGroupName,
CustomerName = d.ToolCustomerName,
ProjectName = s.ProjectName,
ProjectImg = s.ProjectImg,
ProjectIntro = s.ProjectIntro,
ProjectSort = s.ProjectSort,
});
return query.ToPageAsync(parm);
}
///
/// 添加或修改项目
///
public async Task AddOrUpdateProjectes(Projectes model)
{
if (model.ProjectId != 0)
{
var response = await _ProjectesRepository.UpdateAsync(model);
return "修改成功!";
}
else
{
var response = await _ProjectesRepository.InsertReturnSnowflakeIdAsync(model);
return "添加成功!";
}
}
#region Excel处理
///
/// 数据导入处理
///
public async Task HandleImportData(ProjectesVo Projectes)
{
return Projectes;
}
///
/// Excel导入
///
public async Task ImportExcel(Projectes Projectes, int index, bool isUpdateSupport, string user)
{
try
{
// 空值判断
// if (Projectes.ProjectId == null) throw new CustomException("项目不能为空");
if (isUpdateSupport)
{
// 判断唯一值
var model = await GetFirstAsync(s => s.ProjectId == Projectes.ProjectId);
// 如果为空就新增数据
if (model == null)
{
// 开启事务
var res = await UseTranAsync(async () =>
{
var addRes = await AddOrUpdateProjectes(Projectes);
});
var addStr = $"第 {index} 行 => 项目:【{Projectes.ProjectId}】新增成功!
";
return addStr;
}
else
{
// 如果有数据就进行修改
// 开启事务
await UseTranAsync(async () =>
{
Projectes.ProjectId = model.ProjectId;
Projectes.ProjectGuid = model.ProjectGuid;
Projectes.Update_by = user;
Projectes.Update_time = DateTime.Now;
var editRes = await AddOrUpdateProjectes(Projectes);
});
var editStr = $"第 {index} 行 => 项目:【{Projectes.ProjectId}】更新成功!
";
return editStr;
}
}
else
{
// 开启事务
var res = await UseTranAsync(async () =>
{
var addRes = await AddOrUpdateProjectes(Projectes);
});
//Console.WriteLine(res.IsSuccess);
var addStr = $"第 {index} 行 => 项目:【{Projectes.ProjectId}】新增成功!
";
return addStr;
}
}
catch (Exception ex)
{
var errorRes = $"第 {index} 行 => 项目:【{Projectes.ProjectId}】导入失败!{ex.Message}
";
return errorRes;
throw;
}
}
///
/// Excel数据导出处理
///
public async Task> HandleExportData(List data)
{
return data;
}
#endregion
#endregion
}
}