diff options
Diffstat (limited to 'Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/DetalheExtratoRepository.cs')
| -rw-r--r-- | Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/DetalheExtratoRepository.cs | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/DetalheExtratoRepository.cs b/Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/DetalheExtratoRepository.cs new file mode 100644 index 0000000..54af174 --- /dev/null +++ b/Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/DetalheExtratoRepository.cs @@ -0,0 +1,99 @@ +using AutoMapper;
+using Gestor.Infrastructure.Entities.Generic;
+using Gestor.Infrastructure.Entities.Seguros;
+using Gestor.Infrastructure.Mappers;
+using Gestor.Infrastructure.Repository.Generic;
+using Gestor.Infrastructure.Repository.Interface;
+using Gestor.Infrastructure.UnitOfWork.Generic;
+using Gestor.Model.Common;
+using Gestor.Model.Domain.Seguros;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Linq.Expressions;
+using System.Runtime.CompilerServices;
+
+namespace Gestor.Infrastructure.Repository.Logic
+{
+ public class DetalheExtratoRepository : GenericRepository<DetalheExtratoDb>, IDetalheExtratoRepository, IGenericRepository<DetalheExtratoDb>
+ {
+ private readonly GenericUnitOfWork _unitOfWork;
+
+ public DetalheExtratoRepository(GenericUnitOfWork unitOfWork) : base(unitOfWork.Session)
+ {
+ this._unitOfWork = unitOfWork;
+ }
+
+ public bool Completo(long id)
+ {
+ List<StatusParcela> statusParcelas = new List<StatusParcela>()
+ {
+ StatusParcela.BaixadaCritica,
+ StatusParcela.Baixada,
+ StatusParcela.BaixadaDiferencaPercentual,
+ StatusParcela.BaixadaAnteriormente,
+ StatusParcela.BaixadaManualmente,
+ StatusParcela.DesconsideradaUsuario,
+ StatusParcela.DesconsideradaSistema
+ };
+ return (
+ from x in base.All()
+ where x.Extrato.Id == id
+ select x).All<DetalheExtratoDb>((DetalheExtratoDb x) => statusParcelas.Contains(x.Status.Value));
+ }
+
+ public void Delete(long id)
+ {
+ DetalheExtratoDb detalheExtratoDb = base.FindEntityById(id);
+ if (detalheExtratoDb == null)
+ {
+ return;
+ }
+ base.Delete(detalheExtratoDb);
+ }
+
+ public List<DetalheExtrato> Find(long id)
+ {
+ List<DetalheExtratoDb> list = (
+ from x in base.All()
+ where x.Extrato.Id == id
+ select x).ToList<DetalheExtratoDb>();
+ return ApplicationMapper.Mapper.Map<List<DetalheExtratoDb>, List<DetalheExtrato>>(list);
+ }
+
+ public DetalheExtrato FindById(long id)
+ {
+ DetalheExtratoDb detalheExtratoDb = base.FindEntityById(id);
+ return ApplicationMapper.Mapper.Map<DetalheExtratoDb, DetalheExtrato>(detalheExtratoDb);
+ }
+
+ public List<DetalheExtrato> FindByLongId(long? id)
+ {
+ List<DetalheExtratoDb> list = (
+ from x in base.All()
+ where (long?)x.Extrato.Id == id
+ select x).ToList<DetalheExtratoDb>();
+ return ApplicationMapper.Mapper.Map<List<DetalheExtratoDb>, List<DetalheExtrato>>(list);
+ }
+
+ public DetalheExtrato FindByParcelaId(long id)
+ {
+ DetalheExtratoDb detalheExtratoDb = base.All().FirstOrDefault<DetalheExtratoDb>((DetalheExtratoDb x) => x.Parcela == (long?)id);
+ return ApplicationMapper.Mapper.Map<DetalheExtratoDb, DetalheExtrato>(detalheExtratoDb);
+ }
+
+ public DetalheExtrato Merge(DetalheExtrato parcela)
+ {
+ DetalheExtratoDb detalheExtratoDb = ApplicationMapper.Mapper.Map<DetalheExtrato, DetalheExtratoDb>(parcela);
+ base.Merge(detalheExtratoDb);
+ return ApplicationMapper.Mapper.Map<DetalheExtratoDb, DetalheExtrato>(detalheExtratoDb);
+ }
+
+ public DetalheExtrato SaveOrUpdate(DetalheExtrato parcela)
+ {
+ DetalheExtratoDb detalheExtratoDb = ApplicationMapper.Mapper.Map<DetalheExtrato, DetalheExtratoDb>(parcela);
+ this.SaveOrUpdate(detalheExtratoDb);
+ return ApplicationMapper.Mapper.Map<DetalheExtratoDb, DetalheExtrato>(detalheExtratoDb);
+ }
+ }
+}
\ No newline at end of file |