QueryLink 0.1.0-alpha
See the version list below for details.
dotnet add package QueryLink --version 0.1.0-alpha
NuGet\Install-Package QueryLink -Version 0.1.0-alpha
<PackageReference Include="QueryLink" Version="0.1.0-alpha" />
paket add QueryLink --version 0.1.0-alpha
#r "nuget: QueryLink, 0.1.0-alpha"
// Install QueryLink as a Cake Addin #addin nuget:?package=QueryLink&version=0.1.0-alpha&prerelease // Install QueryLink as a Cake Tool #tool nuget:?package=QueryLink&version=0.1.0-alpha&prerelease
QueryLink
QueryLink is a NuGet package designed to simplify the integration of UI components such as datagrids and datatables with backend IQueryable
-based data sources. This library provides a seamless way to link these two parts of a system with minimal code, making it easier to manage filters and sorting operations.
Features
- Filter Definitions: Define filters with various operators to refine your data queries.
- Order Definitions: Specify sorting criteria to order your data.
- Overrides: Customize filter and order operations with expression-based overrides.
- Query String Conversion: Easily convert filter and order definitions to and from query strings.
- IQueryable Extensions: Apply filter and order definitions directly to
IQueryable
sources.
Installation
You can install the package via NuGet:
dotnet add package QueryLink
Usage
Definitions
The Definitions
class allows you to specify filters and orders for your data queries.
This example demonstrates how to create filter and order definitions using the Definitions
class.
var definitions = new Definitions
{
Filters = [
new("Name", FilterOperator.Eq, "John"),
new("Age", FilterOperator.Gt, 30)
],
Orders = [
new("Name", false),
new("Age", true)
]
};
Overrides
The Overrides
class allows you to customize filter and order operations using expression-based overrides.
This example shows how to create overrides for filter and order operations using the Overrides
class.
var overrides = new Overrides<Person>
{
Filter = [
new(p => p.Name, p => p.FullName)
],
Order = [
new(p => p.Name, p => p.FullName)
]
};
Query String Conversion
Convert filter and order definitions to and from query strings using the HttpExtensions
class.
This example demonstrates how to convert filter and order definitions to and from query strings using the HttpExtensions
class.
string queryString = definitions.ToQueryString();
Definitions parsedDefinitions = Definitions.FromQueryString(queryString);
Applying Definitions to IQueryable
Apply filter and order definitions directly to IQueryable
sources using the QueryableExtensions
class.
This example shows how to apply filter and order definitions to an IQueryable
source using the QueryableExtensions
class.
IQueryable<Person> query = dbContext.People.AsQueryable();
query = query.Apply(definitions, overrides);
Examples
Filtering and Sorting
This example demonstrates filtering and sorting using the Definitions
class and applying them to an IQueryable
source.
var definitions = new Definitions
{
Filters = [
new("Name", FilterOperator.Eq, "John"),
new("Age", FilterOperator.Gt, 30)
],
Orders = [
new("Name", false),
new("Age", true)
]
};
IQueryable<Person> query = dbContext.People.AsQueryable();
query = query.Apply(definitions);
Using Overrides
This example shows how to use overrides to customize filter and order operations and apply them to an IQueryable
source.
var overrides = new Overrides<Person>
{
Filter = [
new(p => p.Name, p => p.FullName)
],
Order = [
new(p => p.Name, p => p.FullName)
]
};
IQueryable<Person> query = dbContext.People.AsQueryable();
query = query.Apply(definitions, overrides);
Filter Operators
The library provides a variety of filter operators to refine your data queries. Here is a list of all the available filter operators:
- Eq
=
: Equals - Neq
!=
: Not equals - Gt
>
: Greater than - Gte
>=
: Greater than or equal to - Lt
<
: Less than - Lte
<=
: Less than or equal to - Has
=*
: Contains - Nhas
!*
: Does not contain - In
[]
: In a list - Nin
![]
: Not in a list - Sw
^
: Starts with - Nsw
!^
: Does not start with - Ew
$
: Ends with - New
!$
: Does not end with
FAQ
Why is there no pagination support?
Pagination depends heavily on the underlying data persistence technology and requires specific implementations for each technology. It is easy to write your own pagination logic and apply it to IQueryable
on top of what our library provides.
How can I create my own custom conditions?
The full functionality of LINQ is still available. You are free to write any .Where()
conditions and apply them to IQueryable
. Our library does not block you from doing that.
I need projections; the raw data models are not enough for me.
You can use any library that can map objects from one to another. Our library does not limit you in any way and will work with the dataset you provide in the form of IQueryable<T>
, whatever the T
may be.
Contributing
Contributions are welcome! Please open an issue or submit a pull request if you have any suggestions or improvements.
License
This project is licensed under the MIT License. See the LICENSE file for details.
QueryLink simplifies the integration of UI components with backend data sources, making it easier to manage filters and sorting operations with minimal code.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. 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. |
-
net8.0
- No dependencies.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
0.1.2-alpha | 1 | 8/2/2024 | |
0.1.1-alpha | 1 | 8/1/2024 | |
0.1.0-alpha | 1 | 8/1/2024 |
Initial release.