public async Task <PagingResponse <VehicleTypeDto> > GetVehicleTypesAsync(VehicleTypeParametersDto vehicleTypeParameters) { var queryStringParam = new Dictionary <string, string> { ["pageNumber"] = vehicleTypeParameters.PageNumber.ToString(), ["pageSize"] = vehicleTypeParameters.PageSize.ToString(), ["sortOrder"] = vehicleTypeParameters.SortOrder.ToString(), ["filters"] = String.IsNullOrEmpty(vehicleTypeParameters.Filters) ? "" : $"Name @=* {vehicleTypeParameters.Filters}" }; using (var httpClient = new HttpClient()) { using (var response = await httpClient.GetAsync(QueryHelpers.AddQueryString(uri.ToString(), queryStringParam))) { if (response.IsSuccessStatusCode) { var content = await response.Content.ReadAsStringAsync(); var pagingResponse = new PagingResponse <VehicleTypeDto> { Items = JsonConvert.DeserializeObject <PageListVehicleType>(content).VehicleTypes, Metadata = JsonConvert.DeserializeObject <MetaData>(response.Headers.GetValues("x-pagination").First()) }; pagingResponse.Filters = vehicleTypeParameters.Filters; pagingResponse.SortOrder = vehicleTypeParameters.SortOrder; return(pagingResponse); } return(null); } } }
public async Task <IActionResult> GetVehicleTypesAsync([FromQuery] VehicleTypeParametersDto vehicleTypeParameters) { var vehicleTypesFromRepo = await _vehicleTypeRepo.GetVehicleTypesAsync(vehicleTypeParameters); var paginationMetadata = new { totalCount = vehicleTypesFromRepo.MetaData.TotalCount, pageSize = vehicleTypesFromRepo.MetaData.PageSize, currentPageSize = vehicleTypesFromRepo.MetaData.CurrentPageSize, currentStartIndex = vehicleTypesFromRepo.MetaData.CurrentStartIndex, currentEndIndex = vehicleTypesFromRepo.MetaData.CurrentEndIndex, pageNumber = vehicleTypesFromRepo.MetaData.PageNumber, totalPages = vehicleTypesFromRepo.MetaData.TotalPages, hasPrevious = vehicleTypesFromRepo.MetaData.HasPrevious, hasNext = vehicleTypesFromRepo.MetaData.HasNext }; Response.Headers.Add("X-Pagination", JsonSerializer.Serialize(paginationMetadata)); var vehicleTypesDto = _mapper.Map <IEnumerable <VehicleTypeDto> >(vehicleTypesFromRepo); var response = new Response <IEnumerable <VehicleTypeDto> >(vehicleTypesDto); return(Ok(response)); }
public async Task <IActionResult> Index(int page = 1, int pageSize = 10, String filters = "", String sortOrder = "") { ViewBag.pageSize = pageSize; ViewBag.filter = filters; ViewData["IdSortParm"] = sortOrder == "Id" ? "-Id" : "Id"; ViewData["NameSortParm"] = sortOrder == "Name" ? "-Name" : "Name"; VehicleTypeParametersDto vehicleTypeParameters = new VehicleTypeParametersDto() { PageNumber = page, PageSize = pageSize, SortOrder = sortOrder, Filters = filters }; var pagingResponse = await _vehicleTypeRepo.GetVehicleTypesAsync(vehicleTypeParameters); return(View(pagingResponse)); }
public async Task <PagedList <VehicleType> > GetVehicleTypesAsync(VehicleTypeParametersDto vehicleTypeParameters) { if (vehicleTypeParameters == null) { throw new ArgumentNullException(nameof(vehicleTypeParameters)); } // TODO: AsNoTracking() should increase performance, but will break the sort tests. need to investigate var collection = _context.VehicleTypes as IQueryable <VehicleType>; var sieveModel = new SieveModel { Sorts = vehicleTypeParameters.SortOrder ?? "Id", Filters = vehicleTypeParameters.Filters }; collection = _sieveProcessor.Apply(sieveModel, collection); return(await PagedList <VehicleType> .CreateAsync(collection, vehicleTypeParameters.PageNumber, vehicleTypeParameters.PageSize)); }