diff options
Diffstat (limited to 'Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/VendedorUsuarioRepository.cs')
| -rw-r--r-- | Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/VendedorUsuarioRepository.cs | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/VendedorUsuarioRepository.cs b/Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/VendedorUsuarioRepository.cs new file mode 100644 index 0000000..49c552f --- /dev/null +++ b/Codemerx/Gestor.Infrastructure/Gestor.Infrastructure.Repository.Logic/VendedorUsuarioRepository.cs @@ -0,0 +1,94 @@ +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.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 VendedorUsuarioRepository : GenericRepository<VendedorUsuarioDb>, IVendedorUsuarioRepository, IGenericRepository<VendedorUsuarioDb>
+ {
+ private readonly GenericUnitOfWork _unitOfWork;
+
+ public VendedorUsuarioRepository(GenericUnitOfWork unitOfWork) : base(unitOfWork.Session)
+ {
+ this._unitOfWork = unitOfWork;
+ }
+
+ public void Delete(long id)
+ {
+ base.Delete(base.FindEntityById(id));
+ }
+
+ public bool Exist(long id)
+ {
+ return base.All().Any<VendedorUsuarioDb>((VendedorUsuarioDb v) => v.Vendedor.Id == id);
+ }
+
+ public bool ExistVinculoUsuario(long idUsuario)
+ {
+ return base.All().Any<VendedorUsuarioDb>((VendedorUsuarioDb v) => v.Usuario.Id == idUsuario);
+ }
+
+ public VendedorUsuario FindById(long id)
+ {
+ VendedorUsuarioDb vendedorUsuarioDb = base.FindEntityById(id);
+ return ApplicationMapper.Mapper.Map<VendedorUsuarioDb, VendedorUsuario>(vendedorUsuarioDb);
+ }
+
+ public IList<Vendedor> FindByUsuario(long idUsuario)
+ {
+ List<VendedorUsuarioDb> list = (
+ from x in base.All()
+ where x.Usuario.Id == idUsuario
+ select x).ToList<VendedorUsuarioDb>();
+ List<Vendedor> vendedors = new List<Vendedor>();
+ list.ForEach((VendedorUsuarioDb vu) => vendedors.Add((new VendedorRepository(this._unitOfWork)).FindById(vu.Vendedor.Id)));
+ return vendedors;
+ }
+
+ public List<VendedorUsuario> FindByVinculo(long idUsuario)
+ {
+ return (
+ from x in base.All()
+ where x.Usuario.Id == idUsuario
+ select x into u
+ select new VendedorUsuario()
+ {
+ Id = u.Id,
+ Usuario = new Usuario()
+ {
+ Id = u.Usuario.Id,
+ Nome = u.Usuario.Nome
+ },
+ Vendedor = new Vendedor()
+ {
+ Id = u.Vendedor.Id,
+ Nome = u.Vendedor.Nome
+ }
+ }).ToList<VendedorUsuario>();
+ }
+
+ public VendedorUsuario Merge(VendedorUsuario vendedorUsuario)
+ {
+ VendedorUsuarioDb vendedorUsuarioDb = ApplicationMapper.Mapper.Map<VendedorUsuario, VendedorUsuarioDb>(vendedorUsuario);
+ base.Merge(vendedorUsuarioDb);
+ return ApplicationMapper.Mapper.Map<VendedorUsuarioDb, VendedorUsuario>(vendedorUsuarioDb);
+ }
+
+ public VendedorUsuario SaveOrUpdate(VendedorUsuario vendedorUsuario)
+ {
+ VendedorUsuarioDb vendedorUsuarioDb = ApplicationMapper.Mapper.Map<VendedorUsuario, VendedorUsuarioDb>(vendedorUsuario);
+ this.SaveOrUpdate(vendedorUsuarioDb);
+ return ApplicationMapper.Mapper.Map<VendedorUsuarioDb, VendedorUsuario>(vendedorUsuarioDb);
+ }
+ }
+}
\ No newline at end of file |