Beispiel #1
0
        public async Task <PagingResponse <PersonTypeDto> > GetPersonTypesAsync(PersonTypeParametersDto personTypeParameters)
        {
            var queryStringParam = new Dictionary <string, string>
            {
                ["pageNumber"] = personTypeParameters.PageNumber.ToString(),
                ["pageSize"]   = personTypeParameters.PageSize.ToString(),
                ["sortOrder"]  = personTypeParameters.SortOrder.ToString(),
                ["filters"]    = String.IsNullOrEmpty(personTypeParameters.Filters) ? "" : $"Name @=* {personTypeParameters.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 <PersonTypeDto>
                        {
                            Items    = JsonConvert.DeserializeObject <PageListPersonType>(content).PersonTypes,
                            Metadata = JsonConvert.DeserializeObject <MetaData>(response.Headers.GetValues("x-pagination").First())
                        };

                        pagingResponse.Filters   = personTypeParameters.Filters;
                        pagingResponse.SortOrder = personTypeParameters.SortOrder;
                        return(pagingResponse);
                    }
                    return(null);
                }
            }
        }
        public async Task <IActionResult> GetPersonTypes([FromQuery] PersonTypeParametersDto personTypeParametersDto)
        {
            var personTypeFromRepo = await _personTypeRepository.GetPersonTypes(personTypeParametersDto);

            var paginationMetadata = new
            {
                totalCount        = personTypeFromRepo.MetaData.TotalCount,
                pageSize          = personTypeFromRepo.MetaData.PageSize,
                currentPageSize   = personTypeFromRepo.MetaData.CurrentPageSize,
                currentStartIndex = personTypeFromRepo.MetaData.CurrentStartIndex,
                currentEndIndex   = personTypeFromRepo.MetaData.CurrentEndIndex,
                pageNumber        = personTypeFromRepo.MetaData.PageNumber,
                totalPages        = personTypeFromRepo.MetaData.TotalPages,
                hasPrevious       = personTypeFromRepo.MetaData.HasPrevious,
                hasNext           = personTypeFromRepo.MetaData.HasNext
            };

            Response.Headers.Add("X-Pagination",
                                 JsonSerializer.Serialize(paginationMetadata));

            var personTypeDto = _mapper.Map <IEnumerable <PersonTypeDto> >(personTypeFromRepo);
            var response      = new Response <IEnumerable <PersonTypeDto> >(personTypeDto);

            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";

            PersonTypeParametersDto personTypeParameters = new PersonTypeParametersDto()
            {
                PageNumber = page,
                PageSize   = pageSize,
                SortOrder  = sortOrder,
                Filters    = filters
            };

            var pagingResponse = await _personTypeRepo.GetPersonTypesAsync(personTypeParameters);

            return(View(pagingResponse));
        }
        public async Task <PagedList <PersonType> > GetPersonTypes(PersonTypeParametersDto personTypeParameters)
        {
            if (personTypeParameters == null)
            {
                throw new ArgumentNullException(nameof(personTypeParameters));
            }

            // TODO: AsNoTracking() should increase performance, but will break the sort tests. need to investigate
            var collection = _context.PersonTypes
                             as IQueryable <PersonType>;

            var sieveModel = new SieveModel
            {
                Sorts   = personTypeParameters.SortOrder ?? "Id",
                Filters = personTypeParameters.Filters
            };

            collection = _sieveProcessor.Apply(sieveModel, collection);

            return(await PagedList <PersonType> .CreateAsync(collection,
                                                             personTypeParameters.PageNumber,
                                                             personTypeParameters.PageSize));
        }