| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- using SharedKernel.Extensions;
- using Application.Abstractions.Data;
- using MediatR;
- using Microsoft.EntityFrameworkCore;
- namespace Application.Features.Popup.Search;
- public sealed class Handler(IAppDbContext db) : IRequestHandler<Query, Response>
- {
- public async Task<Response> Handle(Query request, CancellationToken ct)
- {
- var query = db.Popup.AsNoTracking();
- var total = await query.CountAsync(ct);
- var skip = (request.PageNum - 1) * request.PerPage;
- var list = await query
- .OrderByDescending(x => x.ID)
- .Skip(skip)
- .Take(request.PerPage)
- .Select(x => new
- {
- x.ID,
- x.Subject,
- x.Link,
- x.StartAt,
- x.EndAt,
- x.Order,
- x.IsActive,
- x.UpdatedAt,
- x.CreatedAt
- })
- .ToListAsync(ct);
- var rows = list
- .Select((x, idx) => new Response.Row
- {
- Num = total - skip - idx,
- ID = x.ID,
- Subject = x.Subject,
- Link = x.Link,
- StartAt = x.StartAt?.ToString("yyyy-MM-dd HH:mm"),
- EndAt = x.EndAt?.ToString("yyyy-MM-dd HH:mm"),
- Order = x.Order,
- IsActive = x.IsActive,
- UpdatedAt = x.UpdatedAt.GetDateAt(),
- CreatedAt = x.CreatedAt.GetDateAt()
- })
- .ToList();
- return new Response
- {
- Total = total,
- List = rows
- };
- }
- }
|