demo20230512/Controllers/Api/ProductLCA/WaterUsageController.cs
2023-05-12 10:20:28 +08:00

117 lines
4.8 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Http;
using Weee.DAL;
using Weee.Models;
using Weee.Service;
using Weee.Models.ExtensionMethods;
using Weee.Filter;
using System.Net.Http;
using Microsoft.AspNet.Identity;
namespace Weee.Controllers
{
public class WaterUsageController : ApiControllerBase
{
private readonly WeeeMonthlyDataService service;
private readonly WeeeParameterDataService parameterservice;
private readonly WeeeDataContext _db;
private WeeeLCADataService serviceLCA;
public WaterUsageController(WeeeMonthlyDataService d, WeeeParameterDataService s, WeeeDataContext db, WeeeLCADataService serviceLCA)
: base(d)
{
service = d;
parameterservice = s;
_db = db;
this.serviceLCA = serviceLCA;
}
[Route("api/WaterUsage/GetWaterUsages/{LCAID}")]
//[Filter.ApiMultilanguage]disable obsolete warning, not sure OK or not
public object Get(int LCAID)
{
LCA lca = service.GetLCA(LCAID);
object ret = new
{
WaterUsages = service.GetSheet<ProductLCAFabSurveyForm_WaterUsages>(LCAID),
//options = parameterservice.GetYearlyParameterOptions(Models.Paramemter.Categories.Water),
//SheetHeader = service.GetSheetHeader(LCAID, Weee.Models.Paramemter.Categories.Water)
// 檢查目前的盤查是否為產品型,用於讀取不同的係數
options = parameterservice.GetYearlyParameterOptions((lca.LCAType.Name == "ProductLCA") ? Models.Paramemter.Categories.WaterProduct : Models.Paramemter.Categories.Water),
SheetHeader = service.GetSheetHeader(LCAID, (lca.LCAType.Name == "ProductLCA") ? Models.Paramemter.Categories.WaterProduct : Models.Paramemter.Categories.Water),
ActivityOptions = activityItems,
EmitParaOptions = emitParaItems,
factor = parameterservice.LCAID2waterPara(LCAID)
};
return ret;
}
[Route("api/WaterUsage/SaveSheetHeader")]
[HttpPost]
public HttpResponseMessage SaveHeader(SheetHeader header)
{
return this.SaveSheetHeader(service, Weee.Models.Paramemter.Categories.Water, header);
}
//[Route("api/WaterUsage/SaveWaterUsages")]
[Route("api/WaterUsage/SaveWaterUsages/{LCAID}/{activity}/{emitPara}")]
[HttpPost]
[ApiEditableAttribute("ToBeSave", true)]
//public object SaveAll(IEnumerable<ProductLCAFabSurveyForm_WaterUsages> ToBeSave)
public object SaveAll(int LCAID, int activity, int emitPara,
IEnumerable<ProductLCAFabSurveyForm_WaterUsages> ToBeSave)
{
if (!ModelState.IsValid)
{
throw new Exception("error");
}
if (ToBeSave == null || ToBeSave.Count() == 0) return null;
serviceLCA.Initialize(User.Identity.GetUserId());
LCA lca = serviceLCA.GetLCA(LCAID);
lca.activityDataTypeWaterUsage = (ActivityDataType)activity;
lca.emitParaTypeWaterUsage = (EmitParaType)emitPara;
_db.SaveChanges();
var parameterIDs = ToBeSave
.Select(x => x.ParameterID)
.Where(x => x != null)
.Distinct()
.Cast<int>();
var parameters = _db.Parameters
.Where(x => parameterIDs.Contains(x.ID))
.Select(x => new { x.ID, x.Value });
//string curArea = "";
//string curYear = "";
//foreach (var item in ToBeSave.Where(x => x.ParameterID != null))
foreach (var item in ToBeSave)
{
//curArea = item.Area;
//curYear = item.Year;//.Parameter.Year;
item.ID = 0;
item.Scalar = Math.Round(item.Scalar, 4);
if (item.ParameterID != null)
item.UpdateKgCO2e(parameters.First(x => x.ID == item.ParameterID).Value);
else
item.KgCO2e = 0;
}
service.DeleteSheet<ProductLCAFabSurveyForm_WaterUsages>(ToBeSave.First().LCAID);
var result = service.SaveSheet(ToBeSave);
return new { result = result };
}
//[Route("api/WaterUsage/SaveWaterUsage/{LCAID}/{id}")]
//[HttpPost]
//public int Save(int LCAID, int id, WaterUsage ToBeSave)
//{
// if (!ModelState.IsValid) { return -1; }
// if (id != ToBeSave.ID || LCAID != ToBeSave.LCAID) { return -1; }
// service.SaveMonthlyData(ToBeSave);
// return ToBeSave.ID;
//}
}
}