using Attribute;
using Model;
using Model.Base;
using Repository;
using Service;
using Microsoft.AspNetCore.Mvc;
using Vo.Admin;
namespace Services
{
///
/// app上报记录Service业务层处理
///
[AppService(ServiceType = typeof(IAppReportRecordService), ServiceLifetime = LifeTime.Transient)]
public class AppReportRecordService : BaseService, IAppReportRecordService
{
///
/// app上报记录-列表
///
/// 参数请求体
/// 分页参数
/// 列表
public PagedInfo getAppReportRecordList([FromQuery] PagerInfo page, [FromQuery] AppReportRecord param)
{
//拼装查询条件
var predicate = Expressionable.Create();
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.appVersion), m => m.appVersion.Contains(param.appVersion));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.userTag), m => m.userTag.Contains(param.userTag));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.pageTitle), m => m.pageTitle.Contains(param.pageTitle));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.pageUrl), m => m.pageUrl.Contains(param.pageUrl));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.deviceSize), m => m.deviceSize.Contains(param.deviceSize));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.reportType), m => m.reportType.Contains(param.reportType));
var response = Queryable()
.Where(predicate.ToExpression())
.SplitTable(DateTime.Now.AddMonths(-3), DateTime.Now)
.OrderByDescending(m => m.id)
.ToPage(page);
return response;
}
}
}