325 lines
9.8 KiB
C#
325 lines
9.8 KiB
C#
|
|
using APT.BaseData.Domain.ApiModel;
|
|||
|
|
using APT.BaseData.Domain.Entities;
|
|||
|
|
using APT.BaseData.Domain.Enums;
|
|||
|
|
using APT.BaseData.Domain.IServices;
|
|||
|
|
using APT.Infrastructure.Core;
|
|||
|
|
using Microsoft.AspNetCore.Mvc;
|
|||
|
|
using System;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Linq;
|
|||
|
|
using System.Linq.Expressions;
|
|||
|
|
|
|||
|
|
using APT.Utility;namespace APT.PF.WebApiControllers.Api.PF
|
|||
|
|
{
|
|||
|
|
[Route("api/PF/PageChart")]
|
|||
|
|
[APT.Infrastructure.Api.RootOrg]
|
|||
|
|
public class PageChartController : AuthorizeApiController<T_PF_PAGE_CHART>
|
|||
|
|
{
|
|||
|
|
/// <summary>
|
|||
|
|
/// 查询
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="pageFilter"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("Entities")]
|
|||
|
|
public JsonActionResult<IEnumerable<T_PF_PAGE_CHART>> Entities([FromBody]KeywordFilter filter)
|
|||
|
|
{
|
|||
|
|
return WitEntities(null, filter);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 查询
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="pageFilter"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("Paged")]
|
|||
|
|
public PagedActionResult<T_PF_PAGE_CHART> Paged([FromBody]KeywordPageFilter pageFilter)
|
|||
|
|
{
|
|||
|
|
return WitPaged(null, pageFilter);
|
|||
|
|
}
|
|||
|
|
/// <summary>
|
|||
|
|
/// 查询
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="pageFilter"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("OrderPaged")]
|
|||
|
|
public PagedActionResult<T_PF_PAGE_CHART> OrderPaged([FromBody]KeywordPageFilter pageFilter)
|
|||
|
|
{
|
|||
|
|
return WitOrderPaged(null, pageFilter);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
[HttpPost, Route("Update")]
|
|||
|
|
public JsonActionResult<bool> Update([FromBody]T_PF_PAGE_CHART entity)
|
|||
|
|
{
|
|||
|
|
return SafeExecute<bool>(() =>
|
|||
|
|
{
|
|||
|
|
|
|||
|
|
this.UpdateEntity(entity);
|
|||
|
|
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
|
|||
|
|
formService.CreateFormConfigVersion(PFFormConfigVersionEnum.PageChart, entity.ID.ToString());
|
|||
|
|
return true;
|
|||
|
|
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
/// <summary>
|
|||
|
|
/// 删除
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="id"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpGet, Route("Delete")]
|
|||
|
|
public JsonActionResult<bool> Delete(string id)
|
|||
|
|
{
|
|||
|
|
return SafeExecute<bool>(() =>
|
|||
|
|
{
|
|||
|
|
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
|
|||
|
|
formService.CreateFormConfigVersion(PFFormConfigVersionEnum.PageChart, id);
|
|||
|
|
List<Guid> ids = new List<Guid>();
|
|||
|
|
ids.Add(new Guid(id));
|
|||
|
|
this.DoDelete(ids);
|
|||
|
|
return true;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
private void DoDelete(List<Guid> ids)
|
|||
|
|
{
|
|||
|
|
this.DeleteEntity<T_PF_PAGE_CHART_PARAM>(t => ids.Contains(t.PAGE_CHART_ID));
|
|||
|
|
this.DeleteEntity<T_PF_PAGE_CHART>(t => ids.Contains(t.ID));
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 批量删除
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="ids"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpGet, Route("BatchDelete")]
|
|||
|
|
public JsonActionResult<bool> BatchDelete(string ids)
|
|||
|
|
{
|
|||
|
|
return SafeExecute<bool>(() =>
|
|||
|
|
{
|
|||
|
|
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
|
|||
|
|
formService.CreateFormConfigVersion(PFFormConfigVersionEnum.PageChart, ids);
|
|||
|
|
var arrays = string.IsNullOrEmpty(ids) ? null : ids.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries)
|
|||
|
|
.Select(t => new Guid(t)).ToList();
|
|||
|
|
if (arrays != null && arrays.Count > 0)
|
|||
|
|
this.DoDelete(arrays);
|
|||
|
|
return true;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
/// <summary>
|
|||
|
|
/// 根据ID获得实体数据
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="id"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("Get")]
|
|||
|
|
public JsonActionResult<T_PF_PAGE_CHART> Get([FromBody] KeywordFilter filter)
|
|||
|
|
{
|
|||
|
|
return WitEntity(null, filter);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 所有表
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="filter"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("GetChartPageConfigInfo")]
|
|||
|
|
public JsonActionResult<ChartPageModel> GetChartPageConfigInfo([FromBody] KeywordFilter filter)
|
|||
|
|
{
|
|||
|
|
return SafeExecute<ChartPageModel>(() =>
|
|||
|
|
{
|
|||
|
|
string formCode = filter.Keyword;
|
|||
|
|
string formId = filter.Parameter1;
|
|||
|
|
filter.OrgType = FilterOrgTypeEnum.仅本组织;
|
|||
|
|
Expression<Func<T_PF_FORM, bool>> expression = t => true;
|
|||
|
|
T_PF_FORM form = null;
|
|||
|
|
if (!string.IsNullOrEmpty(formCode))
|
|||
|
|
form = this.GetEntityByRedis<T_PF_FORM>(formCode, filter.GetOrgId());
|
|||
|
|
else if (!string.IsNullOrEmpty(formId))
|
|||
|
|
form = this.GetEntityByRedis<T_PF_FORM>(formId, filter.GetOrgId());
|
|||
|
|
else
|
|||
|
|
return null;
|
|||
|
|
if (form == null)
|
|||
|
|
return null;
|
|||
|
|
ChartPageModel model = new ChartPageModel();
|
|||
|
|
model.Nav_PageForm = form;
|
|||
|
|
//
|
|||
|
|
var pageChars = this.GetEntitiesByRedis<T_PF_PAGE_CHART>(filter);
|
|||
|
|
pageChars = pageChars.Where(t => t.PAGE_FORM_ID == form.ID).ToList();
|
|||
|
|
|
|||
|
|
var pageCharParams = this.GetEntitiesByRedis<T_PF_PAGE_CHART_PARAM>(filter);
|
|||
|
|
foreach(var ch in pageChars)
|
|||
|
|
{
|
|||
|
|
ch.Nav_Params= pageCharParams.Where(t => t.PAGE_CHART_ID == ch.ID).ToList();
|
|||
|
|
}
|
|||
|
|
model.Nav_PageCharts = pageChars;
|
|||
|
|
|
|||
|
|
//model.Nav_PageCharts = this.GetEntities<T_PF_PAGE_CHART>(t => t.PAGE_FORM_ID == form.ID,
|
|||
|
|
// new BaseFilter(), new string[] { "Nav_Params" }).OrderBy(t => t.NUM).ToList();
|
|||
|
|
return model;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
[HttpPost, Route("GetChartDataTest")]
|
|||
|
|
public JsonActionResult<ChartDataModel> GetChartDataTest([FromBody] KeywordFilter filter)
|
|||
|
|
{
|
|||
|
|
return SafeExecute<ChartDataModel>(() =>
|
|||
|
|
{
|
|||
|
|
//ChartDataModel model = new ChartDataModel();
|
|||
|
|
|
|||
|
|
////model.XAxis
|
|||
|
|
//ChartDataXAxisModel xAxisModel = new ChartDataXAxisModel();
|
|||
|
|
//xAxisModel.Data.Add("北京");
|
|||
|
|
//xAxisModel.Data.Add("上海");
|
|||
|
|
//xAxisModel.Data.Add("广东");
|
|||
|
|
//xAxisModel.Data.Add("南京");
|
|||
|
|
//xAxisModel.Data.Add("天津");
|
|||
|
|
//model.XAxis.Add(xAxisModel);
|
|||
|
|
|
|||
|
|
//for (int i = 0; i < 5; i++)
|
|||
|
|
//{
|
|||
|
|
// ChartDataDetailModel detail = new ChartDataDetailModel();
|
|||
|
|
// detail.Name = "测试" + (i + 1);
|
|||
|
|
|
|||
|
|
// for (int j = 0; j < xAxisModel.Data.Count; j++)
|
|||
|
|
// {
|
|||
|
|
// ChartDataValueModel value = new ChartDataValueModel();
|
|||
|
|
// var r = new Random(Guid.NewGuid().GetHashCode());
|
|||
|
|
// value.Value = r.Next(0, 900);
|
|||
|
|
// if (j == 0)
|
|||
|
|
// {
|
|||
|
|
// value.Heads.Add("天气");
|
|||
|
|
// value.Heads.Add("天数");
|
|||
|
|
// value.Heads.Add("比率");
|
|||
|
|
// List<string> xx1 = new List<string>();
|
|||
|
|
// xx1.Add("晴天");
|
|||
|
|
// xx1.Add("201");
|
|||
|
|
// xx1.Add("10%");
|
|||
|
|
// value.Data.Add(xx1);
|
|||
|
|
// List<string> xx2 = new List<string>();
|
|||
|
|
// xx2.Add("雨天");
|
|||
|
|
// xx2.Add("202");
|
|||
|
|
// xx2.Add("12%");
|
|||
|
|
// value.Data.Add(xx2);
|
|||
|
|
// List<string> xx3 = new List<string>();
|
|||
|
|
// xx3.Add("雾天");
|
|||
|
|
// xx3.Add("203");
|
|||
|
|
// xx3.Add("13%");
|
|||
|
|
// value.Data.Add(xx3);
|
|||
|
|
|
|||
|
|
// }
|
|||
|
|
|
|||
|
|
// detail.Data.Add(value);
|
|||
|
|
// }
|
|||
|
|
// model.Data.Add(detail);
|
|||
|
|
//}
|
|||
|
|
|
|||
|
|
|
|||
|
|
//return model;
|
|||
|
|
|
|||
|
|
|
|||
|
|
//多个Y轴
|
|||
|
|
|
|||
|
|
ChartDataModel model = new ChartDataModel();
|
|||
|
|
|
|||
|
|
//model.XAxis
|
|||
|
|
ChartDataXAxisModel xAxisModel = new ChartDataXAxisModel();
|
|||
|
|
xAxisModel.Data.Add("北京");
|
|||
|
|
xAxisModel.Data.Add("上海");
|
|||
|
|
xAxisModel.Data.Add("广东");
|
|||
|
|
xAxisModel.Data.Add("南京");
|
|||
|
|
xAxisModel.Data.Add("天津");
|
|||
|
|
model.XAxis.Add(xAxisModel);
|
|||
|
|
|
|||
|
|
ChartDataYAxisModel y = new ChartDataYAxisModel();
|
|||
|
|
y.Name = "测试1";
|
|||
|
|
y.Max = 1800;
|
|||
|
|
model.YAxis.Add(y);
|
|||
|
|
|
|||
|
|
ChartDataYAxisModel y1 = new ChartDataYAxisModel();
|
|||
|
|
y1.Name = "测试2";
|
|||
|
|
y1.Max = 100;
|
|||
|
|
model.YAxis.Add(y1);
|
|||
|
|
|
|||
|
|
ChartDataDetailModel detail = new ChartDataDetailModel();
|
|||
|
|
detail.Name = "测试1组1";
|
|||
|
|
|
|||
|
|
for (int j = 0; j < xAxisModel.Data.Count; j++)
|
|||
|
|
{
|
|||
|
|
ChartDataValueModel value = new ChartDataValueModel();
|
|||
|
|
var r = new Random(Guid.NewGuid().GetHashCode());
|
|||
|
|
value.Value = r.Next(0, 900);
|
|||
|
|
detail.Data.Add(value);
|
|||
|
|
}
|
|||
|
|
model.Data.Add(detail);
|
|||
|
|
|
|||
|
|
|
|||
|
|
ChartDataDetailModel detail1 = new ChartDataDetailModel();
|
|||
|
|
detail1.Name = "测试1组2";
|
|||
|
|
//detail1.YAxisIndex = 1;
|
|||
|
|
|
|||
|
|
for (int j = 0; j < xAxisModel.Data.Count; j++)
|
|||
|
|
{
|
|||
|
|
ChartDataValueModel value = new ChartDataValueModel();
|
|||
|
|
var r = new Random(Guid.NewGuid().GetHashCode());
|
|||
|
|
value.Value = r.Next(0, 900);
|
|||
|
|
|
|||
|
|
detail1.Data.Add(value);
|
|||
|
|
}
|
|||
|
|
model.Data.Add(detail1);
|
|||
|
|
|
|||
|
|
ChartDataDetailModel detail11 = new ChartDataDetailModel();
|
|||
|
|
detail11.Name = "测试1组11";
|
|||
|
|
//detail1.YAxisIndex = 1;
|
|||
|
|
detail11.Stack = "广告类";
|
|||
|
|
for (int j = 0; j < xAxisModel.Data.Count; j++)
|
|||
|
|
{
|
|||
|
|
ChartDataValueModel value = new ChartDataValueModel();
|
|||
|
|
var r = new Random(Guid.NewGuid().GetHashCode());
|
|||
|
|
value.Value = r.Next(0, 900);
|
|||
|
|
|
|||
|
|
detail11.Data.Add(value);
|
|||
|
|
}
|
|||
|
|
model.Data.Add(detail11);
|
|||
|
|
|
|||
|
|
|
|||
|
|
ChartDataDetailModel detail12 = new ChartDataDetailModel();
|
|||
|
|
detail12.Name = "测试1组12";
|
|||
|
|
//detail1.YAxisIndex = 1;
|
|||
|
|
detail12.Stack = "广告类";
|
|||
|
|
for (int j = 0; j < xAxisModel.Data.Count; j++)
|
|||
|
|
{
|
|||
|
|
ChartDataValueModel value = new ChartDataValueModel();
|
|||
|
|
var r = new Random(Guid.NewGuid().GetHashCode());
|
|||
|
|
value.Value = r.Next(0, 900);
|
|||
|
|
|
|||
|
|
detail12.Data.Add(value);
|
|||
|
|
}
|
|||
|
|
model.Data.Add(detail12);
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
ChartDataDetailModel detail2 = new ChartDataDetailModel();
|
|||
|
|
detail2.Name = "测试2组1";
|
|||
|
|
detail2.YAxisIndex = 1;
|
|||
|
|
detail2.ChartType =(int)PFChartTypeEnum.line;
|
|||
|
|
|
|||
|
|
for (int j = 0; j < xAxisModel.Data.Count; j++)
|
|||
|
|
{
|
|||
|
|
ChartDataValueModel value = new ChartDataValueModel();
|
|||
|
|
var r = new Random(Guid.NewGuid().GetHashCode());
|
|||
|
|
value.Value = r.Next(0, 100);
|
|||
|
|
|
|||
|
|
detail2.Data.Add(value);
|
|||
|
|
}
|
|||
|
|
model.Data.Add(detail2);
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
return model;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
}
|