This commit is contained in:
52
server/AyaNova/biz/SqlSelectBuilder.cs
Normal file
52
server/AyaNova/biz/SqlSelectBuilder.cs
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using System;
|
||||||
|
using System.Globalization;
|
||||||
|
using System.Text;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
|
using System.Linq;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
|
||||||
|
namespace AyaNova.Biz
|
||||||
|
{
|
||||||
|
public static class SqlSelectBuilder
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
public static string Build(AyaNova.Models.DataFilter dataFilter)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (string.IsNullOrWhiteSpace(dataFilter.Sort))
|
||||||
|
{
|
||||||
|
return DefaultGetManyOrderBy();
|
||||||
|
}
|
||||||
|
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
|
||||||
|
//iterate the datafilter and concatenate a sql query from it
|
||||||
|
var SortArray = JArray.Parse(dataFilter.Sort);
|
||||||
|
for (int i = 0; i < SortArray.Count; i++)
|
||||||
|
{
|
||||||
|
|
||||||
|
var SortItem = SortArray[i];
|
||||||
|
var fld = SortItem["fld"].Value<string>();
|
||||||
|
var dir = SortItem["dir"].Value<string>();
|
||||||
|
|
||||||
|
sb.Append(" ");
|
||||||
|
sb.Append(fld);
|
||||||
|
sb.Append(" ");
|
||||||
|
sb.Append(dir == "+" ? "ASC" : "DESC");
|
||||||
|
|
||||||
|
if (i < SortArray.Count - 1)
|
||||||
|
{
|
||||||
|
sb.Append(",");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return " ORDER BY" + sb.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}//eoc
|
||||||
|
}//ens
|
||||||
@@ -275,6 +275,15 @@ namespace AyaNova.Biz
|
|||||||
listOptions.Offset = listOptions.Offset ?? ListOptions.DefaultOffset;
|
listOptions.Offset = listOptions.Offset ?? ListOptions.DefaultOffset;
|
||||||
listOptions.Limit = listOptions.Limit ?? ListOptions.DefaultLimit;
|
listOptions.Limit = listOptions.Limit ?? ListOptions.DefaultLimit;
|
||||||
|
|
||||||
|
|
||||||
|
//TODO: Get template (MOCKED FOR NOW UNTIL PROOF OF CONCEPT)
|
||||||
|
var MOCK_WIDGET_DISPLAY_TEMPLATE_JSON = @"
|
||||||
|
{
|
||||||
|
""full"":[""WidgetName"",""WidgetSerial"",""WidgetDollarAmount"",""WidgetRoles"",""WidgetStartDate"",""Active""],
|
||||||
|
""mini"":[""WidgetName"",""WidgetSerial""]
|
||||||
|
}
|
||||||
|
";
|
||||||
|
|
||||||
//BUILD THE QUERY
|
//BUILD THE QUERY
|
||||||
//TODO: Turn this into a raw direct query
|
//TODO: Turn this into a raw direct query
|
||||||
//Build the select fragment from the template so only selected columns get fetched
|
//Build the select fragment from the template so only selected columns get fetched
|
||||||
@@ -323,13 +332,7 @@ namespace AyaNova.Biz
|
|||||||
|
|
||||||
|
|
||||||
//BUILD THE RETURN BASED ON TEMPLATE and MINI CONDITIONAL FORMAT
|
//BUILD THE RETURN BASED ON TEMPLATE and MINI CONDITIONAL FORMAT
|
||||||
//TODO: Get template (MOCKED FOR NOW UNTIL PROOF OF CONCEPT)
|
|
||||||
var MOCK_WIDGET_DISPLAY_TEMPLATE_JSON = @"
|
|
||||||
{
|
|
||||||
""full"":[""WidgetName"",""WidgetSerial"",""WidgetDollarAmount"",""WidgetRoles"",""WidgetStartDate"",""Active""],
|
|
||||||
""mini"":[""WidgetName"",""WidgetSerial""]
|
|
||||||
}
|
|
||||||
";
|
|
||||||
|
|
||||||
//BUILD THE COLUMNS RETURN PROPERTY JSON FRAGMENT
|
//BUILD THE COLUMNS RETURN PROPERTY JSON FRAGMENT
|
||||||
string ColumnsJSON = string.Empty;
|
string ColumnsJSON = string.Empty;
|
||||||
|
|||||||
Reference in New Issue
Block a user