JinanCementFactory/JinanCementFactoryAPI/Controllers/api/GetTemperatureMonitoringOne...

103 lines
4.8 KiB
C#

using DataServer.api;
using Microsoft.Ajax.Utilities;
using Newtonsoft.Json;
using System;
using System.CodeDom;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Text;
using System.Web.Http;
namespace JinanCementFactoryAPI.Controllers.api
{
/// <summary>
/// 温度监测1
/// </summary>
public class GetTemperatureMonitoringOneController : ApiController
{
DataServer.BLL.test_temperature bll=new DataServer.BLL.test_temperature();
// GET api/<controller>
public HttpResponseMessage Get(string type="")
{
var res = new get_temperature_monitoring_one();
try
{
var list = bll.GetModelList("");
var alist = new List<monitoring_oneData>();
if (type == "线路测温")
{
var list1 = bll.GetModelList("").Where(x => x.TemperatureType == 1).DistinctBy(x=>x.ThermometryName).ToList();
var amodel = new monitoring_oneData();
amodel.Type = "线路测温";
//var list4 = bll.GetModelList("").Where(x=>x.TemperatureType==1).DistinctBy(x => x.ThermometryName ).ToList();
var blist = new List<temperature_monitoring>();
foreach (var item in list1)
{
var clist = new List<monitoring_one>();
var list3 = bll.GetModelList("").Where(x => x.ThermometryName == item.ThermometryName&&x.TemperatureType==1).ToList();
var bmodel = new temperature_monitoring();
bmodel.ThermometryName = item.ThermometryName;
foreach (var aitem in list3)
{
//bmodel = new temperature_monitoring();
var cmodel = new monitoring_one();
cmodel.TemperatureDescription = aitem.TemperatureDescription;
cmodel.TemperatureValue = aitem.TemperatureValue;
cmodel.SerialNumber = aitem.ThermometryId;
clist.Add(cmodel);
}
bmodel.list = clist;
blist.Add(bmodel);
}
amodel.data = blist;
alist.Add(amodel);
}
if (type == "设备测温")
{
var list1 = bll.GetModelList("").Where(x => x.TemperatureType == 2).DistinctBy(x => x.ThermometryName).ToList();
var amodel = new monitoring_oneData();
amodel.Type = "设备测温";
//var list4 = bll.GetModelList("").Where(x => x.TemperatureType == 2).DistinctBy(x => x.ThermometryName).ToList();
var blist = new List<temperature_monitoring>();
foreach (var item in list1)
{
var clist = new List<monitoring_one>();
var list3 = bll.GetModelList("").Where(x => x.ThermometryName == item.ThermometryName && x.TemperatureType == 2).ToList();
var bmodel = new temperature_monitoring();
bmodel.ThermometryName = item.ThermometryName;
foreach (var aitem in list3)
{
//bmodel = new temperature_monitoring();
var cmodel = new monitoring_one();
cmodel.TemperatureDescription = aitem.TemperatureDescription;
cmodel.TemperatureValue = aitem.TemperatureValue;
cmodel.SerialNumber = aitem.ThermometryId;
clist.Add(cmodel);
}
bmodel.list = clist;
blist.Add(bmodel);
}
amodel.data = blist;
alist.Add(amodel);
}
res.code = 200;
res.msg = "成功";
res.data = alist;
}
catch (Exception ex)
{
res.code = 500;
res.msg = ex.Message;
}
HttpResponseMessage result = new HttpResponseMessage { Content = new StringContent(JsonConvert.SerializeObject(res), Encoding.GetEncoding("UTF-8"), "application/json") };
return result;
}
}
}