From 07eed00f004e384116a509bcaa25c77b25eb4e40 Mon Sep 17 00:00:00 2001 From: dlebee <36390643+dlebee@users.noreply.github.com> Date: Wed, 7 Mar 2018 19:59:37 -0600 Subject: [PATCH 1/2] Update README.md --- README.md | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/README.md b/README.md index b08224e..e6e22d9 100644 --- a/README.md +++ b/README.md @@ -117,3 +117,41 @@ var result = queryable.ToListAsync().Result; var first = result.FirstOrDefault() as Author; Assert.AreEqual(first?.FirstName, "David"); ``` + +### How it can be used in a web api + +```csharp +[HttpGet][Route("FindClients")] + public IHttpActionResult FindClients(string filterField = null, string filterValue = null, string sortProperty = "Id", int? page = null, int pageSize = 50) + { + var ctx = new MyDbContext(); + var query = ctx.Clients.AsQueryable(); + + if (!string.IsNullOrEmpty(filterField) && !string.IsNullOrEmpty(filterValue)) + query = query.Query(t => t.Contains(filterField, filterValue)).OrderBy(sortProperty); + + // count. + var clientCount = query.Count(); + int? pages = null; + + if (page.HasValue && pageSize > 0) + { + if (clientCount == 0) + pages = 0; + else + pages = clientCount / pageSize + (clientCount % pageSize != 0 ? 1 : 0); + } + + if (page.HasValue) + query = query.Skip((page.Value-1) * pageSize).Take(pageSize); + + var clients = query.ToList(); + + return Ok(new + { + total = clientCount, + pages = pages, + data = clients + }); + } +``` From 55afafa5ca21871d358629f95db154b007defafc Mon Sep 17 00:00:00 2001 From: dlebee <36390643+dlebee@users.noreply.github.com> Date: Wed, 7 Mar 2018 20:00:00 -0600 Subject: [PATCH 2/2] Update README.md --- README.md | 55 ++++++++++++++++++++++++++++--------------------------- 1 file changed, 28 insertions(+), 27 deletions(-) diff --git a/README.md b/README.md index e6e22d9..6723133 100644 --- a/README.md +++ b/README.md @@ -122,36 +122,37 @@ Assert.AreEqual(first?.FirstName, "David"); ```csharp [HttpGet][Route("FindClients")] - public IHttpActionResult FindClients(string filterField = null, string filterValue = null, string sortProperty = "Id", int? page = null, int pageSize = 50) - { - var ctx = new MyDbContext(); - var query = ctx.Clients.AsQueryable(); - - if (!string.IsNullOrEmpty(filterField) && !string.IsNullOrEmpty(filterValue)) - query = query.Query(t => t.Contains(filterField, filterValue)).OrderBy(sortProperty); +public IHttpActionResult FindClients(string filterField = null, string filterValue = null, +string sortProperty = "Id", int? page = null, int pageSize = 50) +{ + var ctx = new MyDbContext(); + var query = ctx.Clients.AsQueryable(); - // count. - var clientCount = query.Count(); - int? pages = null; + if (!string.IsNullOrEmpty(filterField) && !string.IsNullOrEmpty(filterValue)) + query = query.Query(t => t.Contains(filterField, filterValue)).OrderBy(sortProperty); - if (page.HasValue && pageSize > 0) - { - if (clientCount == 0) - pages = 0; - else - pages = clientCount / pageSize + (clientCount % pageSize != 0 ? 1 : 0); - } + // count. + var clientCount = query.Count(); + int? pages = null; - if (page.HasValue) - query = query.Skip((page.Value-1) * pageSize).Take(pageSize); + if (page.HasValue && pageSize > 0) + { + if (clientCount == 0) + pages = 0; + else + pages = clientCount / pageSize + (clientCount % pageSize != 0 ? 1 : 0); + } - var clients = query.ToList(); + if (page.HasValue) + query = query.Skip((page.Value-1) * pageSize).Take(pageSize); - return Ok(new - { - total = clientCount, - pages = pages, - data = clients - }); - } + var clients = query.ToList(); + + return Ok(new + { + total = clientCount, + pages = pages, + data = clients + }); +} ```