2018-02-11 20:55:29 -05:00
|
|
|
|
using PoweredSoft.DynamicLinq.Fluent;
|
|
|
|
|
using PoweredSoft.DynamicLinq.Helpers;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2018-02-12 05:18:44 -05:00
|
|
|
|
using System.Data.SqlClient;
|
2018-02-11 20:55:29 -05:00
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Linq.Expressions;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace PoweredSoft.DynamicLinq.Extensions
|
|
|
|
|
{
|
|
|
|
|
public static class QueryableExtensions
|
|
|
|
|
{
|
2018-02-12 04:30:55 -05:00
|
|
|
|
public static IQueryable<T> Where<T>(this IQueryable<T> query, string path, ConditionOperators conditionOperator, object value,
|
|
|
|
|
QueryConvertStrategy convertStrategy = QueryConvertStrategy.ConvertConstantToComparedPropertyOrField)
|
2018-02-11 20:55:29 -05:00
|
|
|
|
{
|
2018-02-12 04:30:55 -05:00
|
|
|
|
query = query.Query(qb => qb.Compare(path, conditionOperator, value, convertStrategy: convertStrategy));
|
2018-02-11 20:55:29 -05:00
|
|
|
|
return query;
|
|
|
|
|
}
|
|
|
|
|
|
2018-02-12 05:18:44 -05:00
|
|
|
|
|
|
|
|
|
|
2018-02-11 20:55:29 -05:00
|
|
|
|
public static IQueryable<T> Query<T> (this IQueryable<T> query, Action<QueryBuilder<T>> callback)
|
|
|
|
|
{
|
|
|
|
|
var queryBuilder = new QueryBuilder<T>(query);
|
|
|
|
|
callback(queryBuilder);
|
|
|
|
|
var ret = queryBuilder.Build();
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
2018-02-12 05:18:44 -05:00
|
|
|
|
|
|
|
|
|
public static IQueryable<T> Sort<T>(this IQueryable<T> query, string path, SortOrder sortOrder, bool appendSort)
|
|
|
|
|
{
|
|
|
|
|
var qb = new QueryBuilder<T>(query);
|
|
|
|
|
qb.Sort(path, sortOrder, appendSort);
|
|
|
|
|
var ret = qb.Build();
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static IQueryable<T> OrderBy<T>(this IQueryable<T> query, string path)
|
|
|
|
|
{
|
|
|
|
|
var qb = new QueryBuilder<T>(query);
|
|
|
|
|
qb.OrderBy(path);
|
|
|
|
|
var ret = qb.Build();
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static IQueryable<T> OrderByDescending<T>(this IQueryable<T> query, string path)
|
|
|
|
|
{
|
|
|
|
|
var qb = new QueryBuilder<T>(query);
|
|
|
|
|
qb.OrderByDescending(path);
|
|
|
|
|
var ret = qb.Build();
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static IQueryable<T> ThenBy<T>(this IQueryable<T> query, string path)
|
|
|
|
|
{
|
|
|
|
|
var qb = new QueryBuilder<T>(query);
|
|
|
|
|
qb.ThenBy(path);
|
|
|
|
|
var ret = qb.Build();
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static IQueryable<T> ThenByDescending<T>(this IQueryable<T> query, string path)
|
|
|
|
|
{
|
|
|
|
|
var qb = new QueryBuilder<T>(query);
|
|
|
|
|
qb.ThenByDescending(path);
|
|
|
|
|
var ret = qb.Build();
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
2018-02-11 20:55:29 -05:00
|
|
|
|
}
|
|
|
|
|
}
|