I have a following problem. I want to do nice paging and I do not want to download all records from WebService to my application.
Controller code:
public ActionResult Vacations(int? page)
{
int pageNumber = page ?? 1;
int quantity = 5;
using (MyWebService.MyWebServiceClient client = new MyWebService.MyWebServiceClient())
{
var vacations = client.GetUserAbsence(SessionManager.CurrentToken, quantity, pageNumber);
var onePageOfVacations = vacations.ToPagedList(pageNumber, quantity);
ViewBag.OnePageOfVacations = onePageOfVacations;
}
return View();
}
View Code:
<h2>Vacations</h2>
<div>
<table class="table tablesorter table-striped">
<thead>
<tr>
<th>Data od</th>
<th>Data do</th>
<th>Ilość dni</th>
</tr>
</thead>
<tbody>
@{
foreach (var v in ViewBag.OnePageOfVacations)
{
<tr>
<td>@v.From_Date</td>
<td>@v.To_Date</td>
<td>@v.Element_Name</td>
</tr>
}
}
</tbody>
<tfoot>
<tr>
<th>Data od</th>
<th>Data do</th>
<th>Ilość dni</th>
</tr>
</tfoot>
</table>
</div>
<!-- output a paging control that lets the user navigation to the previous page, next page, etc -->
@Html.PagedListPager((IPagedList)ViewBag.OnePageOfVacations, page => Url.Action("Vacations", new { page }))
I have a method in my webservice “GetUserAbsence()” which return to my only that number of records which I need. Now I have only one page and I cannot show other results. There is my question – how to connect this solution with PagedList or maybe how to create new paging on this solution?
Answers:
Thank you for visiting the Q&A section on Magenaut. Please note that all the answers may not help you solve the issue immediately. So please treat them as advisements. If you found the post helpful (or not), leave a comment & I’ll get back to you as soon as possible.
Method 1
MVC.PagedList has a StaticPagedList method that allow you to provide IEnumerable<T> rather than IQuerable<T>, but you must know the total number of records. In your case it would be
var vacations = client.GetUserAbsence(SessionManager.CurrentToken, quantity, pageNumber); int totalItems = .... // see following note ViewBag.OnePageOfVacations = new StaticPagedList<yourModel>(vacations, pageNumber, quantity, totalItems);
It means that your service would need to include another method that returns the count of total records (but that should be very fast), or you could modify the GetUserAbsence() method to return an object containing properties for the filtered collection plus a value for the total records.
Side note: I recommend that you pass a strongly typed model to the view rather that using ViewBag, so that the controller code is
.... var model = new StaticPagedList<yourModel>(vacations, pageNumber, quantity, totalItems); return View(model);
and in the view
@model PagedList.IPagedList<yourModel>
....
@foreach (var v in Model)
{
....
}
....
@Html.PagedListPager(Model, page => Url.Action("Vacations", new { page }))
All methods was sourced from stackoverflow.com or stackexchange.com, is licensed under cc by-sa 2.5, cc by-sa 3.0 and cc by-sa 4.0