|
|
using AutoMapper.Internal.Mappers;using Microsoft.AspNetCore.Mvc;using Shentun.Peis.ItemResultTemplates;using Shentun.Peis.GuidTypes;using Shentun.Peis.HelperDto;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using Volo.Abp.Application.Dtos;using Volo.Abp.Application.Services;using Volo.Abp.Domain.Repositories;using Volo.Abp.Identity;using Shentun.Peis.SexHormoneReferenceRanges;using Shentun.Peis.Models;using Microsoft.AspNetCore.Authorization;
namespace Shentun.Peis.ItemResultTemplates{
/// <summary>
/// 项目结果模板
/// </summary>
[ApiExplorerSettings(GroupName = "Work")] [Authorize] public class ItemResultTemplateAppService : CrudAppService< ItemResultTemplate, //The Book entity
ItemResultTemplateDto, //Used to show books
Guid, //Primary key of the book entity
PagedAndSortedResultRequestDto, //Used for paging/sorting
CreateItemResultTemplateDto, UpdateItemResultTemplateDto> { private readonly IRepository<IdentityUser, Guid> _userRepository; private readonly ItemResultTemplateManager _manager; public ItemResultTemplateAppService( IRepository<ItemResultTemplate, Guid> repository, IRepository<IdentityUser, Guid> userRepository, ItemResultTemplateManager manager) : base(repository) { this._userRepository = userRepository; _manager = manager; } /// <summary>
/// 获取通过主键
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public override async Task<ItemResultTemplateDto> GetAsync(Guid id) { var entity = await Repository.FindAsync(o => o.Id == id); //throw new Exception("标准异常测试");
//throw new BusinessException("业务异常测试");
//throw new UserFriendlyException("友好异常测试");
//throw new EntityNotFoundException("未发现实体异常测试");
//return null;
if (entity == null) return null; return ObjectMapper.Map<ItemResultTemplate, ItemResultTemplateDto>(entity);
} /// <summary>
/// 获取列表 项目结果模板
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
public override async Task<PagedResultDto<ItemResultTemplateDto>> GetListAsync(PagedAndSortedResultRequestDto input) { int totalCount = await Repository.CountAsync();
var entlist = await Repository.GetPagedListAsync(input.SkipCount, input.MaxResultCount, input.Sorting); var userList = await _userRepository.GetListAsync(); var entdto = entlist.Select(s => new ItemResultTemplateDto { CreationTime = s.CreationTime, CreatorId = s.CreatorId, ItemId = s.ItemId, Id = s.Id, LastModificationTime = s.LastModificationTime, LastModifierId = s.LastModifierId, DiagnosisId = s.DiagnosisId, SimpleCode = s.SimpleCode, ResultStatusId = s.ResultStatusId, Result = s.Result, IsResultIntoSummary = s.IsResultIntoSummary, DisplayOrder = s.DisplayOrder, IsNameIntoSummary = s.IsNameIntoSummary, CreatorName = EntityHelper.GetUserNameNoSql(userList, s.CreatorId), LastModifierName = EntityHelper.GetUserNameNoSql(userList, s.LastModifierId) }).ToList();
return new PagedResultDto<ItemResultTemplateDto>(totalCount, entdto);
}
/// <summary>
/// 获取项目结果模板列表 根据项目ID
/// </summary>
/// <param name="ItemId">项目ID</param>
/// <returns></returns>
public async Task<List<ItemResultTemplateDto>> GetListInItemIdAsync(Guid ItemId) {
var entlist = await Repository.GetListAsync(m => m.ItemId == ItemId);
var userList = await _userRepository.GetListAsync();
var entdto = entlist.Select(s => new ItemResultTemplateDto { CreationTime = s.CreationTime, CreatorId = s.CreatorId, ItemId = s.ItemId, Id = s.Id, LastModificationTime = s.LastModificationTime, LastModifierId = s.LastModifierId, DiagnosisId = s.DiagnosisId, SimpleCode = s.SimpleCode, ResultStatusId = s.ResultStatusId, Result = s.Result, IsResultIntoSummary = s.IsResultIntoSummary, DisplayOrder = s.DisplayOrder, IsNameIntoSummary = s.IsNameIntoSummary, CreatorName = EntityHelper.GetUserNameNoSql(userList, s.CreatorId), LastModifierName = EntityHelper.GetUserNameNoSql(userList, s.LastModifierId) }).ToList();
return entdto;
}
/// <summary>
/// 创建
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
public override async Task<ItemResultTemplateDto> CreateAsync(CreateItemResultTemplateDto input) { var createEntity = ObjectMapper.Map<CreateItemResultTemplateDto, ItemResultTemplate>(input); var entity = await _manager.CreateAsync(createEntity); entity = await Repository.InsertAsync(entity); var dto = ObjectMapper.Map<ItemResultTemplate, ItemResultTemplateDto>(entity); return dto; } /// <summary>
/// 更新
/// </summary>
/// <param name="id"></param>
/// <param name="input"></param>
/// <returns></returns>
public override async Task<ItemResultTemplateDto> UpdateAsync(Guid id, UpdateItemResultTemplateDto input) { var entity = await Repository.GetAsync(id); var sourceEntity = ObjectMapper.Map<UpdateItemResultTemplateDto, ItemResultTemplate>(input); _manager.UpdateAsync(sourceEntity, entity); entity = await Repository.UpdateAsync(entity); return ObjectMapper.Map<ItemResultTemplate, ItemResultTemplateDto>(entity); } /// <summary>
/// 删除
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public override Task DeleteAsync(Guid id) { return base.DeleteAsync(id); }
/// <summary>
/// 修改排序 置顶,置底
/// </summary>
/// <param name="id">需要修改的ID</param>
/// <param name="SortType">修改方式:1 置顶 2 置底</param>
/// <returns></returns>
[HttpPut("api/app/itemresulttemplate/updatemanysort")] public async Task UpdateManySortAsync(Guid id, int SortType) { await _manager.UpdateManySortAsync(id, SortType); }
/// <summary>
/// 修改排序 拖拽
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpPut("api/app/itemresulttemplate/updatesortmany")] public async Task UpdateSortManyAsync(UpdateSortManyDto input) { await _manager.UpdateSortManyAsync(input); } }}
|