117 lines
4.8 KiB
C#
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;
|
|
//}
|
|
}
|
|
}
|