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.ProjectGroups;
using ARW.Service.Business.IBusinessService.Project.ProjectGroups;
using ARW.Model.Dto.Business.Project.ProjectGroups;
using ARW.Model.Models.Business.Project.ProjectGroups;
using ARW.Model.Vo.Business.Project.ProjectGroups;
namespace ARW.Service.Business.BusinessService.Project.ProjectGroups
{
///
/// 项目分组接口实现类
///
[AppService(ServiceType = typeof(IProjectGroupService), ServiceLifetime = LifeTime.Transient)]
public class ProjectGroupServiceImpl : BaseService, IProjectGroupService
{
private readonly ProjectGroupRepository _ProjectGroupRepository;
public ProjectGroupServiceImpl(ProjectGroupRepository ProjectGroupRepository)
{
this._ProjectGroupRepository = ProjectGroupRepository;
}
#region 业务逻辑代码
///
/// 查询项目分组树形列表
///
public async Task> GetProjectGroupTreeList(ProjectGroupQueryDto parm)
{
//开始拼装查询条件
var predicate = Expressionable.Create();
var query = _ProjectGroupRepository
.Queryable()
.LeftJoin((s, c) => s.ProjectGroupParentGuid == c.ProjectGroupGuid)
.Where(predicate.ToExpression())
.OrderBy(s => s.ProjectGroupSort, OrderByType.Asc)
.Select((s, c) => new ProjectGroupVo
{
ProjectGroupId = s.ProjectGroupId,
ProjectGroupGuid = s.ProjectGroupGuid,
ProjectGroupParentGuid = s.ProjectGroupParentGuid,
ProjectGroupAncestralGuid = s.ProjectGroupAncestralGuid,
ProjectGroupCustomerGuid = s.ProjectGroupCustomerGuid,
ProjectGroupName = s.ProjectGroupName,
ProjectGroupSort = s.ProjectGroupSort,
ParentName = c.ProjectGroupName,
});
return await query.ToTreeAsync(it => it.Children, it => it.ProjectGroupParentGuid, 0);
}
///
/// 查询项目分组列表
///
public Task> GetProjectGroupList(ProjectGroupQueryDto parm)
{
//开始拼装查询条件d
var predicate = Expressionable.Create();
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.ProjectGroupName), it => it.ProjectGroupName == parm.ProjectGroupName);
var query = _ProjectGroupRepository
.Queryable()
.Where(predicate.ToExpression())
.OrderBy(s => s.ProjectGroupSort, OrderByType.Asc)
.Select(s => new ProjectGroupVo
{
ProjectGroupId = s.ProjectGroupId,
ProjectGroupGuid = s.ProjectGroupGuid,
ProjectGroupParentGuid = s.ProjectGroupParentGuid,
ProjectGroupAncestralGuid = s.ProjectGroupAncestralGuid,
ProjectGroupCustomerGuid = s.ProjectGroupCustomerGuid,
ProjectGroupName = s.ProjectGroupName,
ProjectGroupSort = s.ProjectGroupSort,
});
return query.ToListAsync();
}
///
/// 添加或修改项目分组
///
public async Task AddOrUpdateProjectGroup(ProjectGroup model)
{
if (model.ProjectGroupId != 0)
{
var type = await _ProjectGroupRepository.GetListAsync(s => s.ProjectGroupParentGuid == model.ProjectGroupGuid);
if (type != null)
{
foreach (var item in type)
{
if (model.ProjectGroupParentGuid == item.ProjectGroupGuid) throw new CustomException("上级菜单不能选择自己的子级!");
}
}
if (model.ProjectGroupParentGuid == model.ProjectGroupGuid) throw new CustomException("上级菜单不能选择与当前菜单一样的!");
var response = await _ProjectGroupRepository.UpdateAsync(model);
return "修改成功!";
}
else
{
var info = _ProjectGroupRepository.GetFirst(it => it.ProjectGroupGuid == model.ProjectGroupParentGuid);
model.ProjectGroupAncestralGuid = "0";
if (info != null) model.ProjectGroupAncestralGuid = info.ProjectGroupAncestralGuid + "," + model.ProjectGroupParentGuid;
var response = await _ProjectGroupRepository.InsertReturnSnowflakeIdAsync(model);
return "添加成功!";
}
}
#region Excel处理
///
/// 数据导入处理
///
public async Task HandleImportData(ProjectGroupVo ProjectGroup)
{
return ProjectGroup;
}
///
/// Excel导入
///
public async Task ImportExcel(ProjectGroup ProjectGroup, int index, bool isUpdateSupport, string user)
{
try
{
// 空值判断
// if (ProjectGroup.ProjectGroupId == null) throw new CustomException("项目分组不能为空");
if (isUpdateSupport)
{
// 判断唯一值
var model = await GetFirstAsync(s => s.ProjectGroupId == ProjectGroup.ProjectGroupId);
// 如果为空就新增数据
if (model == null)
{
// 开启事务
var res = await UseTranAsync(async () =>
{
var addRes = await AddOrUpdateProjectGroup(ProjectGroup);
});
var addStr = $"第 {index} 行 => 项目分组:【{ProjectGroup.ProjectGroupId}】新增成功!
";
return addStr;
}
else
{
// 如果有数据就进行修改
// 开启事务
await UseTranAsync(async () =>
{
ProjectGroup.ProjectGroupId = model.ProjectGroupId;
ProjectGroup.ProjectGroupGuid = model.ProjectGroupGuid;
ProjectGroup.Update_by = user;
ProjectGroup.Update_time = DateTime.Now;
var editRes = await AddOrUpdateProjectGroup(ProjectGroup);
});
var editStr = $"第 {index} 行 => 项目分组:【{ProjectGroup.ProjectGroupId}】更新成功!
";
return editStr;
}
}
else
{
// 开启事务
var res = await UseTranAsync(async () =>
{
var addRes = await AddOrUpdateProjectGroup(ProjectGroup);
});
//Console.WriteLine(res.IsSuccess);
var addStr = $"第 {index} 行 => 项目分组:【{ProjectGroup.ProjectGroupId}】新增成功!
";
return addStr;
}
}
catch (Exception ex)
{
var errorRes = $"第 {index} 行 => 项目分组:【{ProjectGroup.ProjectGroupId}】导入失败!{ex.Message}
";
return errorRes;
throw;
}
}
///
/// Excel数据导出处理
///
public async Task> HandleExportData(List data)
{
return data;
}
#endregion
#endregion
}
}