| | | 1 | | using MechanicsSoftware.Application.Abstractions; |
| | | 2 | | using MechanicsSoftware.Application.UseCases.Customers.Queries; |
| | | 3 | | using MechanicsSoftware.Domain.Enums; |
| | | 4 | | using MechanicsSoftware.Domain.ValueObjects; |
| | | 5 | | using Microsoft.EntityFrameworkCore; |
| | | 6 | | |
| | | 7 | | namespace MechanicsSoftware.Application.UseCases.Customers.Handlers; |
| | | 8 | | |
| | 8 | 9 | | public sealed class ListCustomersHandler(IAppDbContext db) |
| | | 10 | | { |
| | | 11 | | public async Task<IReadOnlyList<CustomerResponse>> ExecuteAsync( |
| | | 12 | | ListCustomersQuery query, |
| | | 13 | | CancellationToken cancellationToken = default) |
| | 8 | 14 | | { |
| | 8 | 15 | | var customers = db.Customers.AsQueryable(); |
| | | 16 | | |
| | 8 | 17 | | if (!string.IsNullOrWhiteSpace(query.Name)) |
| | 2 | 18 | | customers = customers.Where(c => c.Name.Contains(query.Name.Trim())); |
| | | 19 | | |
| | 8 | 20 | | if (!string.IsNullOrWhiteSpace(query.Document)) |
| | 2 | 21 | | { |
| | 2 | 22 | | var digits = string.Concat(query.Document.Where(char.IsDigit)); |
| | 2 | 23 | | var pt = digits.Length == 14 ? PersonType.COMPANY : PersonType.INDIVIDUAL; |
| | 2 | 24 | | var documentVo = new TaxId(digits, pt); |
| | 2 | 25 | | customers = customers.Where(c => c.Document == documentVo); |
| | 2 | 26 | | } |
| | | 27 | | |
| | 8 | 28 | | return await customers |
| | 8 | 29 | | .Select(c => CustomerResponse.From(c)) |
| | 8 | 30 | | .ToListAsync(cancellationToken); |
| | 8 | 31 | | } |
| | | 32 | | } |