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 ARW.Model;
using ARW.Repository;
using ARW.Repository.Business.${genTable.moduleName};
using ARW.Service.Api.IBusinessService.${genTable.moduleName};
using ARW.Model.Dto.Api.${genTable.moduleName};
using ARW.Model.Models.Business.${genTable.moduleName};
using ARW.Model.Vo.Api.${genTable.moduleName};
namespace ARW.Service.Api.BusinessService.${genTable.moduleName}
{
///
/// ${genTable.FunctionName}接口实现类Api
///
/// @author ${replaceDto.Author}
/// @date ${replaceDto.AddTime}
///
[AppService(ServiceType = typeof(I${replaceDto.ModelTypeName}ServiceApi), ServiceLifetime = LifeTime.Transient)]
public class ${replaceDto.ModelTypeName}ServiceImplApi : BaseService<${replaceDto.ModelTypeName}>, I${replaceDto.ModelTypeName}ServiceApi
{
private readonly ${replaceDto.ModelTypeName}Repository _${replaceDto.ModelTypeName}Repository;
public ${replaceDto.ModelTypeName}ServiceImplApi(${replaceDto.ModelTypeName}Repository ${replaceDto.ModelTypeName}Repository)
{
this._${replaceDto.ModelTypeName}Repository = ${replaceDto.ModelTypeName}Repository;
}
#region Api接口代码
$if(genTable.TplCategory == "tree")
///
/// 查询${genTable.FunctionName}树形列表(Api)
///
///
///
public async Task> Get${replaceDto.ModelTypeName}TreeListApi(${replaceDto.ModelTypeName}QueryDtoApi parm)
{
//开始拼装查询条件d
var predicate = Expressionable.Create<${replaceDto.ModelTypeName}>();
$foreach(column in genTable.Columns)
$if(column.IsQuery)
$if(column.CsharpType == "string")
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.${column.CsharpField}), ${codeTool.QueryExp(column.CsharpField, column.QueryType)};
$elseif(column.CsharpType == "DateTime")
predicate = predicate.AndIF(parm.Begin${column.CsharpField} == null, it => it.${column.CsharpField} >= DateTime.Now.AddDays(-1));
predicate = predicate.AndIF(parm.Begin${column.CsharpField} != null, it => it.${column.CsharpField} >= parm.Begin${column.CsharpField} && it.${column.CsharpField} <= parm.End${column.CsharpField});
$elseif(column.CsharpType == "int" || column.CsharpType == "long")
predicate = predicate.AndIF(parm.${column.CsharpField} != null, ${codeTool.QueryExp(column.CsharpField, column.QueryType)};
$end
$end
${end}
var query = _${replaceDto.ModelTypeName}Repository
.Queryable()
.Where(predicate.ToExpression())
.LeftJoin<${replaceDto.ModelTypeName}>((s, c) => s.${genTable.Options.TreeParentCode} == c.${replaceDto.ModelTypeName}Guid)
$if(genTable.Options.SortField != "" && genTable.Options.SortField != null)
.OrderBy(s => s.${genTable.Options.SortField},OrderByType.${genTable.Options.SortType})
$end
.Select((s,c) => new ${replaceDto.ModelTypeName}VoApi
{
$foreach(item in genTable.Columns)
$if(item.IsInit != true)
$if((item.IsList || item.IsPk))
${item.CsharpField} = s.${item.CsharpField},
$end
$end
$end
ParentName = c.${replaceDto.ModelTypeName}Name,
});
return await query.ToTreeAsync(it => it.Children, it => it.${genTable.Options.TreeParentCode}, 0);
}
$else
///
/// 查询${genTable.FunctionName}列表(Api)
///
///
///
public async Task> Get${replaceDto.ModelTypeName}ListApi(${replaceDto.ModelTypeName}QueryDtoApi parm)
{
//开始拼装查询条件d
var predicate = Expressionable.Create<${replaceDto.ModelTypeName}>();
$foreach(column in genTable.Columns)
$if(column.IsQuery)
$if(column.CsharpType == "string")
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.${column.CsharpField}), ${codeTool.QueryExp(column.CsharpField, column.QueryType)};
$elseif(column.CsharpType == "DateTime")
predicate = predicate.AndIF(parm.Begin${column.CsharpField} == null, it => it.${column.CsharpField} >= DateTime.Now.AddDays(-1));
predicate = predicate.AndIF(parm.Begin${column.CsharpField} != null, it => it.${column.CsharpField} >= parm.Begin${column.CsharpField} && it.${column.CsharpField} <= parm.End${column.CsharpField});
$elseif(column.CsharpType == "int" || column.CsharpType == "long")
predicate = predicate.AndIF(parm.${column.CsharpField} != null, ${codeTool.QueryExp(column.CsharpField, column.QueryType)};
$end
$end
${end}
var query = _${replaceDto.ModelTypeName}Repository
.Queryable()
.Where(predicate.ToExpression())
$if(genTable.Options.SortField != "" && genTable.Options.SortField != null)
.OrderBy(s => s.${genTable.Options.SortField},OrderByType.Desc)
$end
.Select(s => new ${replaceDto.ModelTypeName}VoApi
{
$foreach(item in genTable.Columns)
$if(item.IsInit != true)
$if((item.IsList || item.IsPk))
${item.CsharpField} = s.${item.CsharpField},
$end
$end
$end
});
return await query.ToPageAsync(parm);
}
$end
///
/// 查询${genTable.FunctionName}详情(Api)
///
///
///
public Task Get${replaceDto.ModelTypeName}Details(${replaceDto.ModelTypeName}DtoApi parm)
{
var query = _${replaceDto.ModelTypeName}Repository
.Queryable()
.Where(s => s.${replaceDto.ModelTypeName}Guid == parm.${replaceDto.ModelTypeName}Guid)
.Select(s => new ${replaceDto.ModelTypeName}ApiDetailsVo
{
$foreach(item in genTable.Columns)
$if(item.IsInit != true)
$if((item.IsList || item.IsPk))
${item.CsharpField} = s.${item.CsharpField},
$end
$end
$end
}).Take(1);
return query.ToJsonAsync();
}
#endregion
}
}