Esempio n. 1
0
        public IActionResult Search([FromBody] CountrySearch model)
        {
            CountryListResult result = this.countryService.Search(model.Keywords, model.OrderBy, model.PageNo, model.PageSize, model.BlockSize);

            return(Ok(result));
        }
Esempio n. 2
0
        public CountryListResult Search(string keywords, int Orderby, int PageNo, int PageSize, int BlockSize)
        {
            CountryListResult result = new CountryListResult();

            Orderby   = Orderby <= 0 ? 0 : (Orderby > 2 ? 2: Orderby);
            PageSize  = PageSize <= 0 ? 10 : PageSize;
            BlockSize = BlockSize <= 0 ? 10 : BlockSize;

            int Start           = 0;
            int Stop            = 0;
            int NumberOfPages   = 0;
            int NumberOfBlocks  = 0;
            int BlockNo         = 0;
            int NumberOfRecords = 0;

            if (string.IsNullOrEmpty(keywords))
            {
                switch (Orderby)
                {
                case 0:     /* by Name */
                    NumberOfRecords = datacontext.Countries.OrderBy(o => o.Name).Count();
                    break;

                case 1:     /* by Code */
                    NumberOfRecords = datacontext.Countries.OrderBy(o => o.Code).Count();
                    break;

                default:     /* by Id */
                    NumberOfRecords = datacontext.Countries.OrderBy(o => o.CountryId).Count();
                    break;
                }
            }
            else
            {
                switch (Orderby)
                {
                case 0:     /* by Name */
                    NumberOfRecords = datacontext.Countries.Where(w => w.Name.StartsWith(keywords)).OrderBy(o => o.Name).Count();
                    break;

                case 1:     /* by Code */
                    NumberOfRecords = datacontext.Countries.Where(w => w.Name.StartsWith(keywords)).OrderBy(o => o.Code).Count();
                    break;

                default:     /* by Id */
                    NumberOfRecords = datacontext.Countries.Where(w => w.Name.StartsWith(keywords)).OrderBy(o => o.CountryId).Count();
                    break;
                }
            }

            if (NumberOfRecords == 0)
            {
                NumberOfPages  = 0;
                NumberOfBlocks = 0;
                PageNo         = 0;
                BlockNo        = 0;
            }
            else
            {
                if (NumberOfRecords <= PageSize)
                {
                    NumberOfPages  = 1;
                    NumberOfBlocks = 1;
                    PageNo         = 1;
                    BlockNo        = 1;
                }
                else
                {
                    NumberOfPages = NumberOfRecords / PageSize;
                    if (NumberOfRecords % PageSize > 0)
                    {
                        NumberOfPages++;
                    }

                    NumberOfBlocks = NumberOfPages / BlockSize;
                    if (NumberOfPages % BlockSize > 0)
                    {
                        NumberOfBlocks++;
                    }

                    if (PageNo > NumberOfPages)
                    {
                        PageNo = NumberOfPages;
                    }

                    if (PageNo <= BlockSize)
                    {
                        BlockNo = 1;
                    }
                    else
                    {
                        BlockNo = (int)Math.Abs(Math.Floor((decimal)PageNo / (decimal)BlockSize));
                        if (PageNo % BlockSize > 0)
                        {
                            BlockNo++;
                        }
                    }
                }

                Start = ((BlockNo - 1) * BlockSize) + 1;
                Stop  = BlockNo * BlockSize;

                if (Stop > NumberOfPages)
                {
                    Stop = NumberOfPages;
                }

                for (int i = Start; i <= Stop; i++)
                {
                    result.Pages.Add(i);
                }

                if (NumberOfBlocks == 1)
                {
                    result.First = null;
                    result.Prev  = null;
                    result.Next  = null;
                    result.Last  = null;
                }
                else
                {
                    if (BlockNo == NumberOfBlocks)
                    {
                        result.First = 1;
                        result.Prev  = PageNo - 1;
                        result.Next  = null;
                        result.Last  = null;
                    }
                    else if (BlockNo == 1)
                    {
                        result.First = null;
                        result.Prev  = null;
                        result.Next  = PageNo + 1;
                        result.Last  = NumberOfPages;
                    }
                    else
                    {
                        result.First = 1;
                        result.Prev  = PageNo - 1;
                        result.Next  = PageNo + 1;
                        result.Last  = NumberOfPages;
                    }
                }

                int Skip = (Start - 1) * PageSize;
                int Take = (Stop - (Start - 1)) * PageSize;
                List <CountrySimpleItem> temps;

                if (string.IsNullOrEmpty(keywords))
                {
                    switch (Orderby)
                    {
                    case 0:     /* by Name */
                        temps = datacontext.Countries.OrderBy(o => o.Name).Skip(Skip).Take(Take).Select(s => new CountrySimpleItem(s.CountryId, s.Name, s.Code)).ToList();
                        break;

                    case 1:     /* by Code */
                        temps = datacontext.Countries.OrderBy(o => o.Code).Skip(Skip).Take(Take).Select(s => new CountrySimpleItem(s.CountryId, s.Name, s.Code)).ToList();
                        break;

                    default:     /* by Id */
                        temps = datacontext.Countries.OrderBy(o => o.CountryId).Skip(Skip).Take(Take).Select(s => new CountrySimpleItem(s.CountryId, s.Name, s.Code)).ToList();
                        break;
                    }
                }
                else
                {
                    switch (Orderby)
                    {
                    case 0:     /* by Name */
                        temps = datacontext.Countries.Where(w => w.Name.StartsWith(keywords)).OrderBy(o => o.Name).Skip(Skip).Take(Take).Select(s => new CountrySimpleItem(s.CountryId, s.Name, s.Code)).ToList();
                        break;

                    case 1:     /* by Code */
                        temps = datacontext.Countries.Where(w => w.Name.StartsWith(keywords)).OrderBy(o => o.Code).Skip(Skip).Take(Take).Select(s => new CountrySimpleItem(s.CountryId, s.Name, s.Code)).ToList();
                        break;

                    default:     /* by Id */
                        temps = datacontext.Countries.Where(w => w.Name.StartsWith(keywords)).OrderBy(o => o.CountryId).Skip(Skip).Take(Take).Select(s => new CountrySimpleItem(s.CountryId, s.Name, s.Code)).ToList();
                        break;
                    }
                }

                List <CountrySimpleItem> collection = new List <CountrySimpleItem>();
                int count = 0;
                for (int i = 0; i < temps.Count(); i++)
                {
                    collection.Add(temps[i]);
                    count++;
                    if (count >= PageSize || i == temps.Count() - 1)
                    {
                        result.Countries.Add(collection);
                        collection = new List <CountrySimpleItem>();
                        count      = 0;
                    }
                }
            }
            result.NumberOfPages  = NumberOfPages;
            result.SelectedPageNo = PageNo;
            if (PageNo > result.Pages.Count)
            {
                result.SelectedIndex = (PageNo - ((BlockNo - 1) * BlockSize) - 1);
            }
            else
            {
                result.SelectedIndex = PageNo - 1;
            }
            return(result);
        }