vTPagifyFilterLib 1.1.1

dotnet add package vTPagifyFilterLib --version 1.1.1
                    
NuGet\Install-Package vTPagifyFilterLib -Version 1.1.1
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="vTPagifyFilterLib" Version="1.1.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="vTPagifyFilterLib" Version="1.1.1" />
                    
Directory.Packages.props
<PackageReference Include="vTPagifyFilterLib" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add vTPagifyFilterLib --version 1.1.1
                    
#r "nuget: vTPagifyFilterLib, 1.1.1"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package vTPagifyFilterLib@1.1.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=vTPagifyFilterLib&version=1.1.1
                    
Install as a Cake Addin
#tool nuget:?package=vTPagifyFilterLib&version=1.1.1
                    
Install as a Cake Tool

PagifyFilter

Easy Pagination and Filter

Overview

PagifyFilter is a NuGet package that provides an extension method for IEnumerable<T> to enable asynchronous searching, filtering, and ordering of collections based on the properties of a PagifyFilter.Pagination object. This package is designed to simplify and optimize the process of querying collections in .NET applications.

Here's how the original code can be optimized:

var searchResults = people
    .Where(dto => 
        (string.IsNullOrEmpty(searchName) || dto.Name?.Contains(searchName, StringComparison.OrdinalIgnoreCase) == true) &&
        (!searchAge.HasValue || dto.Age == searchAge) &&
        (string.IsNullOrEmpty(searchAddress) || dto.Address?.Contains(searchAddress, StringComparison.OrdinalIgnoreCase) == true)
    ).ToList();

// Sorting
var sortedResults = searchResults
    .OrderBy(dto => dto.Name)
    .ThenBy(dto => dto.Age)
    .ToList();
Optimized Code using PagifyFilter
var result = await people.SearchAsync(searchDto);

Installation

These steps must be adhered to when using this package with IEnumerable collections.

To install the package, choose one of the following commands:

.NET CLI:
  dotnet add package vTPagifyFilterLib
Package manager:
Install-Package vTPagifyFilterLib

Usage

The code snippet public class YourSearchDto : PagifyFilter.Pagination { } defines a class named YourSearchDto that inherits from a base class called PagifyFilter.Pagination. Here’s a breakdown of what this means:

Inheritance in C#

In C#, inheritance allows a class to inherit the properties and methods of another class. The class that inherits is called the derived class (in this case, YourSearchDto), and the class being inherited from is called the base class (in this case, PagifyFilter.Pagination).

PagifyFilter.Pagination Class

The PagifyFilter.Pagination class is likely a class that contains properties and methods related to paginating data. Common properties in a Pagination class might include: CurrentPageNo: The current page number. ItemsPerPage: The number of items per page. TotalItems: The total number of items. SortColumn: Column for Sorting. IsAscendingSort: If true , it means ascending otherwise descending

YourSearchDto Class

By inheriting from PagifyFilter.Pagination, the YourSearchDto class will have all the properties and methods of the Pagination class. This means that YourSearchDto can be used to handle pagination-related data along with any additional properties or methods you might add to it.

Integration with PagifyFilter

The PagifyFilter package provides an extension method SearchAsync for IEnumerable<T> to enable asynchronous searching, filtering, and ordering of collections based on the properties of a SearchDto object. Here’s how YourDto can be used with PagifyFilter: Define YourDto: Inherit from Pagination to include pagination properties. Use YourDto with SearchAsync: Pass an instance of YourDto to the SearchAsync method to filter and paginate your data.

Example

Here’s an example to illustrate

Defining Your Search DTO

Create a class that inherits from PagifyFilter.Pagination to include pagination properties in your data transfer object (DTO): Note: all fields must be allowed to be null by using '?'.

public class YourSearchDto : PagifyFilter.Pagination
{
    public string? Name { get; set; }
    public int? Age { get; set; }
    public string? Address { get; set; }
}
Integrating with PagifyFilter

Use the SearchAsync extension method provided by PagifyFilter to filter and paginate your data

var searchDto = new YourSearchDto
    {
        PageNumber = 1,
        PageSize = 10,
        Name = "A"
    };

var result = await people.SearchAsync(searchDto);
Adding Sorting

If you need sorting, specify the column and sort direction:

var searchDto = new YourSearchDto
    {
        PageNumber = 1,
        PageSize = 10,
        Name = "A"
        SortColumn ="Age"
    };

var result = await people.SearchAsync(searchDto);
Return Value

The SearchAsync method returns a PagedResult<Tdata>, which contains the filtered and optionally ordered elements from the source collection

Practical Application

In a real-world scenario, YourSearchDto can be used to pass search criteria and pagination information to a method that retrieves data from a database or API. This approach helps manage large datasets efficiently, improving performance and user experience.

Summary

PagifyFilter simplifies pagination, filtering, and sorting in .NET applications. Extend PagifyFilter.Pagination to include custom search criteria in your search DTO. Use SearchAsync to efficiently retrieve and manage data.

If you have any more questions or need further clarification, feel free to ask!

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.1.1 224 8/24/2024
1.1.0 182 8/24/2024