DeviationController.cs 48 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139
  1. using DevExpress.Web.Mvc;
  2. using DevExpress.XtraReports.UI;
  3. using GreenTree.Nachtragsmanagement.Core;
  4. using GreenTree.Nachtragsmanagement.Core.Authentication;
  5. using GreenTree.Nachtragsmanagement.Core.Domain.Appendix;
  6. using GreenTree.Nachtragsmanagement.Core.Domain.Deviation;
  7. using GreenTree.Nachtragsmanagement.Services.Appendix;
  8. using GreenTree.Nachtragsmanagement.Services.Configuration;
  9. using GreenTree.Nachtragsmanagement.Services.Deviation;
  10. using GreenTree.Nachtragsmanagement.Services.Logging;
  11. using GreenTree.Nachtragsmanagement.Services.Site;
  12. using GreenTree.Nachtragsmanagement.Web.Extensions;
  13. using GreenTree.Nachtragsmanagement.Web.Framework.Authorization;
  14. using GreenTree.Nachtragsmanagement.Web.Models.Appendix;
  15. using GreenTree.Nachtragsmanagement.Web.Models.Deviation;
  16. using GreenTree.Nachtragsmanagement.Web.Models.Global;
  17. using Newtonsoft.Json;
  18. using Newtonsoft.Json.Linq;
  19. using System;
  20. using System.Collections.Generic;
  21. using System.Drawing;
  22. using System.Linq;
  23. using System.Net.Mime;
  24. using System.Web;
  25. using System.Web.Mvc;
  26. using static GreenTree.Nachtragsmanagement.Web.Extensions.MVCxGridViewGeneratorHelper;
  27. namespace GreenTree.Nachtragsmanagement.Web.Controllers
  28. {
  29. public class DeviationController : Controller
  30. {
  31. private readonly IDeviationService _deviationService;
  32. private readonly IAppendixService _appendixService;
  33. private readonly ISiteService _siteService;
  34. private readonly IUserHelper _userHelper;
  35. private readonly ILogger _logger;
  36. private readonly IConfigurationService _configurationService;
  37. public DeviationController(
  38. IDeviationService deviationService,
  39. IAppendixService appendixService,
  40. ISiteService siteService,
  41. IUserHelper userHelper,
  42. ILogger logger,
  43. IConfigurationService configurationService)
  44. {
  45. _deviationService = deviationService;
  46. _appendixService = appendixService;
  47. _siteService = siteService;
  48. _userHelper = userHelper;
  49. _logger = logger;
  50. _configurationService = configurationService;
  51. ViewData["AllDisturbances"] = _deviationService.GetAllDisturbances();
  52. ViewData["AllStatuses"] = _deviationService.GetAllStatuses();
  53. ViewData["AllKinds"] = _deviationService.GetAllKinds();
  54. }
  55. #region Deviations
  56. /// <summary>
  57. /// Basic deviation view function
  58. /// </summary>
  59. [FunctionAuthorize(true, "Deviation-Deviations")]
  60. public ActionResult ViewDeviations()
  61. {
  62. var currentUser = _userHelper.FromCookies();
  63. var deviations = _deviationService.GetAllUserAssignedDeviations(currentUser);
  64. var deviationModels = deviations
  65. .Select(u => DeviationDataModel.FromDeviation(u, false, _configurationService))
  66. .ToList();
  67. return View("~/Views/Deviations/View.cshtml", deviationModels);
  68. }
  69. /// <summary>
  70. /// Get JSON data of specific deviation
  71. /// </summary>
  72. /// <param name="id">Deviation id.</param>
  73. public ActionResult GetDeviation(int id = -1)
  74. {
  75. var deviation = _deviationService.GetDeviationById(id);
  76. if (deviation == null)
  77. return new JsonResult
  78. {
  79. Data = "notFound",
  80. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  81. };
  82. var deviationModel = DeviationDataModel.FromDeviation(deviation, false, _configurationService);
  83. return new JsonResult
  84. {
  85. Data = JsonConvert.SerializeObject(deviationModel),
  86. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  87. };
  88. }
  89. /// <summary>
  90. /// Callback result for deviation grid
  91. /// </summary>
  92. /// <param name="scrollHeight">The height of the grid scrollable component.</param>
  93. public ActionResult PartialDeviations(string customFilters, int scrollHeight = -1)
  94. {
  95. var currentUser = _userHelper.FromCookies();
  96. var deviations = _deviationService.GetAllUserAssignedDeviations(currentUser);
  97. var deviationModels = deviations
  98. .Select(u => DeviationDataModel.FromDeviation(u, false, _configurationService))
  99. .ToList();
  100. if (!String.IsNullOrEmpty(customFilters))
  101. UseCustomFilters(customFilters, deviationModels);
  102. ViewData["ScrollHeight"] = scrollHeight;
  103. return PartialView("~/Views/Deviations/_DeviationGridPartial.cshtml", deviationModels);
  104. }
  105. /// <summary>
  106. /// Export result for deviation grid
  107. /// </summary>
  108. [HttpPost]
  109. public ActionResult ExportPartialDeviations(string customFilters, string displayMode, string exportformat)
  110. {
  111. if (String.IsNullOrEmpty(displayMode))
  112. return new EmptyResult();
  113. var currentUser = _userHelper.FromCookies();
  114. var deviations = _deviationService.GetAllUserAssignedDeviations(currentUser);
  115. var deviationModels = deviations
  116. .Select(u => DeviationDataModel.FromDeviation(u, false, _configurationService))
  117. .ToList();
  118. if (!String.IsNullOrEmpty(customFilters))
  119. UseCustomFilters(customFilters, deviationModels);
  120. var viewContext = new ViewContext();
  121. var viewPage = new ViewPage();
  122. var htmlHelper = new System.Web.Mvc.HtmlHelper(viewContext, viewPage);
  123. MVCxGridViewState gridViewState = (MVCxGridViewState)Session["DeviationGridViewState"];
  124. var settings = GridViewSettingsHelper.DeviationGridViewSettings(htmlHelper);
  125. if (gridViewState != null)
  126. {
  127. var generator = new MVCReportGeneratonHelper();
  128. generator.CustomizeFormattingRules += new CustomizeFormattingRulesEventHandler(generator_CustomizeFormattingRules);
  129. generator.CustomizeColumnsCollection += new CustomizeColumnsCollectionEventHandler(generator_CustomizeColumnsCollection);
  130. generator.CustomizeGroupColumnSummary += new CustomizeColumnGroupSummaryEventHandler(generator_CustomizeGroupColumnSummary);
  131. generator.CustomizeTotalColumnSummary += new CustomizeColumnTotalSummaryEventHandler(generator_CustomizeTotalColumnSummary);
  132. generator.SummaryReset += new SummaryResetEventHandler(generator_SummaryReset);
  133. generator.SummaryRowChanged += new SummaryRowChangedEventHandler(generator_SummaryRowChanged);
  134. generator.PageSummaryGetResult += new SummaryGetResultHandler(generator_PageSummaryGetResult);
  135. generator.TotalSummaryGetResult += new SummaryGetResultHandler(generator_TotalSummaryGetResult);
  136. var report = generator.GenerateMVCReport(gridViewState, deviationModels, "Vertragsabweichungsliste");
  137. if (displayMode == "popup")
  138. {
  139. return PartialView("~/Views/Shared/_PrintPopupPartial.cshtml",
  140. new PrintGridModel(report, "devGridViewDeviation",
  141. new { Controller = "Deviation", Action = "ExportPartialDeviations",
  142. customFilters = customFilters, displayMode = "callback", exportformat = String.Empty },
  143. new { Controller = "Deviation", Action = "ExportPartialDeviations",
  144. customFilters = customFilters, displayMode = "export", exportformat = String.Empty }));
  145. }
  146. else if (displayMode == "callback")
  147. {
  148. return PartialView("~/Views/Shared/_PrintDocumentViewerPartial.cshtml",
  149. new PrintGridModel(report, "devGridViewDeviation",
  150. new { Controller = "Deviation", Action = "ExportPartialDeviations",
  151. customFilters = customFilters, displayMode = "callback", exportformat = String.Empty },
  152. new { Controller = "Deviation", Action = "ExportPartialDeviations",
  153. customFilters = customFilters, displayMode = "export", exportformat = String.Empty }));
  154. }
  155. else if (displayMode == "export")
  156. {
  157. switch (exportformat.ToLower())
  158. {
  159. case "xlsx":
  160. settings.TotalSummary["Value"].DisplayFormat = "{0:c2}";
  161. settings.TotalSummary["Percentage"].DisplayFormat = "{0:p0}";
  162. settings.TotalSummary["PercentageValue"].DisplayFormat = "{0:c2}";
  163. settings.TotalSummary["DaysReceiptToAppendixOffering"].DisplayFormat = "Schnitt = {0:n0}";
  164. settings.TotalSummary["SiteDescription"].DisplayFormat = "Anzahl = {0:n0}";
  165. settings.TotalSummary["DisturbanceValuesDescription"].DisplayFormat = "{0:c2}";
  166. return GridViewExtension.ExportToXlsx(settings, deviationModels);
  167. case "xls":
  168. settings.TotalSummary["Value"].DisplayFormat = "{0:c2}";
  169. settings.TotalSummary["Percentage"].DisplayFormat = "{0:p0}";
  170. settings.TotalSummary["PercentageValue"].DisplayFormat = "{0:c2}";
  171. settings.TotalSummary["DaysReceiptToAppendixOffering"].DisplayFormat = "Schnitt = {0:n0}";
  172. settings.TotalSummary["SiteDescription"].DisplayFormat = "Anzahl = {0:n0}";
  173. settings.TotalSummary["DisturbanceValuesDescription"].DisplayFormat = "{0:c2}";
  174. return GridViewExtension.ExportToXls(settings, deviationModels);
  175. case "pdf":
  176. report.Name = "VA-Liste";
  177. return DocumentViewerExtension.ExportTo(report);
  178. }
  179. }
  180. return new EmptyResult();
  181. }
  182. else
  183. return new EmptyResult();
  184. }
  185. private decimal totalCustomSummaryValueDaysReceiptToAppendixOffering = 0;
  186. private decimal totalCustomSummaryValueDaysReceiptToAppendixOfferingCount = 0;
  187. private decimal totalCustomSummaryValueDisturbanceValueSum = 0;
  188. private decimal accumulatedCustomSummaryValueDaysReceiptToAppendixOffering = 0;
  189. private int accumulatedCustomSummaryValueDaysReceiptToAppendixOfferingCount = 0;
  190. private decimal accumulatedCustomSummaryPercentage = 0;
  191. private int accumulatedCustomSummaryPercentageCount = 0;
  192. private decimal accumulatedCustomSummaryValueDisturbanceValueSum = 0;
  193. private decimal accumulatedCustomSummaryPercentageValue = 0;
  194. private decimal accumulatedCustomSummaryValue = 0;
  195. private decimal accumulatedCustomSummaryCount = 0;
  196. /// <summary>
  197. /// Reset custom summaries for corresponding group type
  198. /// </summary>
  199. /// <param name="source"></param>
  200. /// <param name="e"></param>
  201. private void generator_SummaryReset(object source, CustomSummaryResetEventArgs e)
  202. {
  203. if (e.FieldName == "DaysReceiptToAppendixOffering")
  204. {
  205. totalCustomSummaryValueDaysReceiptToAppendixOffering = 0;
  206. totalCustomSummaryValueDaysReceiptToAppendixOfferingCount = 0;
  207. }
  208. if (e.FieldName == "DisturbanceValuesDescription")
  209. totalCustomSummaryValueDisturbanceValueSum = 0;
  210. }
  211. /// <summary>
  212. /// Get custom summary values
  213. /// </summary>
  214. /// <param name="source"></param>
  215. /// <param name="e"></param>
  216. private void generator_SummaryRowChanged(object source, CustomSummaryRowChangedEventArgs e)
  217. {
  218. if (e.FieldName == "DaysReceiptToAppendixOffering")
  219. {
  220. var val = ((XtraReport)source).GetCurrentColumnValue("DaysReceiptToAppendixOffering");
  221. if (val != null)
  222. {
  223. totalCustomSummaryValueDaysReceiptToAppendixOffering += Convert.ToDecimal(val);
  224. totalCustomSummaryValueDaysReceiptToAppendixOfferingCount++;
  225. }
  226. }
  227. if (e.FieldName == "DisturbanceValuesDescription")
  228. {
  229. totalCustomSummaryValueDisturbanceValueSum +=
  230. Convert.ToDecimal(((XtraReport)source).GetCurrentColumnValue("DisturbanceValueSum"));
  231. }
  232. }
  233. /// <summary>
  234. /// Set custom summary result for page
  235. /// </summary>
  236. /// <param name="source"></param>
  237. /// <param name="e"></param>
  238. private void generator_PageSummaryGetResult(object source, SummaryGetResultEventArgs e)
  239. {
  240. var label = (XRLabel)source;
  241. if (label.Tag.ToString() == "DaysReceiptToAppendixOffering")
  242. {
  243. accumulatedCustomSummaryValueDaysReceiptToAppendixOffering += e.CalculatedValues.OfType<int?>()
  244. .Where(c => c.HasValue)
  245. .Select(c => Convert.ToDecimal(c))
  246. .Sum();
  247. accumulatedCustomSummaryValueDaysReceiptToAppendixOfferingCount += e.CalculatedValues.OfType<int?>()
  248. .Where(c => c.HasValue)
  249. .Count();
  250. e.Result = accumulatedCustomSummaryValueDaysReceiptToAppendixOffering /
  251. (accumulatedCustomSummaryValueDaysReceiptToAppendixOfferingCount == 0
  252. ? 1
  253. : accumulatedCustomSummaryValueDaysReceiptToAppendixOfferingCount);
  254. }
  255. if (label.Tag.ToString() == "DisturbanceValuesDescription")
  256. {
  257. var vals = e.CalculatedValues.OfType<string>()
  258. .Where(s => !String.IsNullOrEmpty(s))
  259. .SelectMany(s => s.Split(new[] { ", " }, StringSplitOptions.None))
  260. .Select(s => s.Split(new[] { " - " }, StringSplitOptions.None)[1])
  261. .Select(s => s.Take(s.Length - 2))
  262. .Select(c => String.Join("", c))
  263. .ToArray();
  264. accumulatedCustomSummaryValueDisturbanceValueSum += vals
  265. .Select(v => Convert.ToDecimal(v))
  266. .Sum();
  267. e.Result = accumulatedCustomSummaryValueDisturbanceValueSum;
  268. }
  269. if (label.Tag.ToString() == "Value")
  270. {
  271. accumulatedCustomSummaryValue += e.CalculatedValues.OfType<decimal>().Sum();
  272. e.Result = accumulatedCustomSummaryValue;
  273. }
  274. if (label.Tag.ToString() == "SiteDescription")
  275. {
  276. accumulatedCustomSummaryCount += e.CalculatedValues.Count;
  277. e.Result = accumulatedCustomSummaryCount;
  278. }
  279. if (label.Tag.ToString() == "Percentage")
  280. {
  281. accumulatedCustomSummaryPercentage += e.CalculatedValues.OfType<decimal>().Sum();
  282. accumulatedCustomSummaryPercentageCount += e.CalculatedValues.Count;
  283. e.Result = accumulatedCustomSummaryPercentage /
  284. ((accumulatedCustomSummaryPercentageCount == 0
  285. ? 1
  286. : accumulatedCustomSummaryPercentage));
  287. }
  288. if (label.Tag.ToString() == "PercentageValue")
  289. {
  290. accumulatedCustomSummaryPercentageValue += e.CalculatedValues.OfType<decimal>().Sum();
  291. e.Result = accumulatedCustomSummaryPercentageValue;
  292. }
  293. e.Handled = true;
  294. }
  295. /// <summary>
  296. /// Set custom summary result for full report
  297. /// </summary>
  298. /// <param name="source"></param>
  299. /// <param name="e"></param>
  300. private void generator_TotalSummaryGetResult(object source, SummaryGetResultEventArgs e)
  301. {
  302. var label = (XRLabel)source;
  303. if (label.Tag.ToString() == "DaysReceiptToAppendixOffering")
  304. {
  305. e.Result = Convert.ToInt32(totalCustomSummaryValueDaysReceiptToAppendixOffering /
  306. (totalCustomSummaryValueDaysReceiptToAppendixOfferingCount == 0
  307. ? 1
  308. : totalCustomSummaryValueDaysReceiptToAppendixOfferingCount));
  309. e.Handled = true;
  310. }
  311. if (label.Tag.ToString() == "DisturbanceValuesDescription")
  312. {
  313. e.Result = totalCustomSummaryValueDisturbanceValueSum;
  314. e.Handled = true;
  315. }
  316. }
  317. /// <summary>
  318. /// Customize formatting
  319. /// </summary>
  320. /// <param name="source"></param>
  321. /// <param name="e"></param>
  322. private void generator_CustomizeFormattingRules(object source, CustomFormattingRulesEventArgs e)
  323. {
  324. var colorLevel1 = _configurationService.TryGetConfigItemValue<string>(
  325. "GreenTree.Nachtragsmanagement.DeviationNotificationPlugin.ProcessDeviationReceipt.HexColorLevel1", "#FFD800");
  326. var ageDaysLevel1 = _configurationService.TryGetConfigItemValue<int>(
  327. "GreenTree.Nachtragsmanagement.DeviationNotificationPlugin.ProcessDeviationReceipt.AgeDaysLevel1", 40);
  328. var colorLevel2 = _configurationService.TryGetConfigItemValue<string>(
  329. "GreenTree.Nachtragsmanagement.DeviationNotificationPlugin.ProcessDeviationReceipt.HexColorLevel2", "#FF6A00");
  330. var ageDaysLevel2 = _configurationService.TryGetConfigItemValue<int>(
  331. "GreenTree.Nachtragsmanagement.DeviationNotificationPlugin.ProcessDeviationReceipt.AgeDaysLevel2", 60);
  332. var ageDaysLevel1Rule = new FormattingRule
  333. {
  334. Condition = String.Format("[DaysReceiptDateToday] >= {0}", ageDaysLevel1),
  335. Name = "AgeDaysLevel1BackColor"
  336. };
  337. ageDaysLevel1Rule.Formatting.BackColor = ColorTranslator.FromHtml(colorLevel1);
  338. var ageDaysLevel2Rule = new FormattingRule
  339. {
  340. Condition = String.Format("[DaysReceiptDateToday] >= {0}", ageDaysLevel2),
  341. Name = "AgeDaysLevel2BackColor"
  342. };
  343. ageDaysLevel2Rule.Formatting.BackColor = ColorTranslator.FromHtml(colorLevel2);
  344. e.Rules.Add(ageDaysLevel1Rule);
  345. e.Rules.Add(ageDaysLevel2Rule);
  346. }
  347. /// <summary>
  348. /// Customize created columns
  349. /// </summary>
  350. private void generator_CustomizeColumnsCollection(object source, ColumnsCreationEventArgs e)
  351. {
  352. foreach (var column in e.ColumnsInfo)
  353. {
  354. if (column.FieldName == "CustomNumber") { column.ColumnWidth = 30; }
  355. if (column.FieldName == "Description") { column.IsVisible = false; column.IsDetail = true; }
  356. if (column.FieldName == "SiteCustomNumber") { column.IsVisible = false; column.IsDetail = true; }
  357. if (column.FieldName == "SiteDescription") { column.IsVisible = false; column.IsDetail = true; }
  358. if (column.FieldName == "UserDescription") { column.IsVisible = false; column.IsDetail = true; }
  359. if (column.FieldName == "AppendixDescription") { column.ColumnWidth = 50; }
  360. if (column.FieldName == "StatusDescription") { column.ColumnWidth = 60; }
  361. }
  362. }
  363. /// <summary>
  364. /// Customize column summary
  365. /// </summary>
  366. private void generator_CustomizeGroupColumnSummary(object source, ColumnSummaryCreationEventArgs e)
  367. {
  368. if (e.FieldName == "SiteDescription") { e.Summary.FormatString = "Alle = {0:n0}"; }
  369. if (e.FieldName == "Value") { e.Summary.FormatString = "Schätzung ∑ = {0:c2}"; }
  370. if (e.FieldName == "Percentage") { e.Summary.FormatString = "Bew. Ø = {0:p0}"; }
  371. if (e.FieldName == "PercentageValue") { e.Summary.FormatString = "S. Bew. ∑ = {0:c2}"; }
  372. if (e.FieldName == "DaysReceiptToAppendixOffering") { e.Summary.FormatString = "Tage VA-NT = {0:n0}"; }
  373. if (e.FieldName == "DisturbanceValuesDescription") { e.Summary.FormatString = "Kat. ∑ = {0:c2}"; }
  374. }
  375. /// <summary>
  376. /// Customize column summary
  377. /// </summary>
  378. private void generator_CustomizeTotalColumnSummary(object source, ColumnSummaryCreationEventArgs e)
  379. {
  380. if (e.FieldName == "SiteDescription") { e.Summary.FormatString = "Alle = {0:n0}"; }
  381. if (e.FieldName == "Value") { e.Summary.FormatString = "{0:c2}"; }
  382. if (e.FieldName == "Percentage") { e.Summary.FormatString = "{0:p0}"; }
  383. if (e.FieldName == "PercentageValue") { e.Summary.FormatString = "{0:c2}"; }
  384. if (e.FieldName == "DaysReceiptToAppendixOffering") { e.Summary.FormatString = "{0:n0}"; }
  385. if (e.FieldName == "DisturbanceValuesDescription") { e.Summary.FormatString = "{0:c2}"; }
  386. }
  387. /// <summary>
  388. /// Partial edit for editing of existing or for new deviation
  389. /// </summary>
  390. /// <param name="id">Id for existing deviation, otherweise -1.</param>
  391. public ActionResult EditDeviation(int id = -1)
  392. {
  393. var deviation = _deviationService.GetDeviationById(id);
  394. var deviationModel = DeviationDataModel.FromDeviation(deviation, true, _configurationService);
  395. var defaultKind = _deviationService.GetDefaultKind();
  396. var defaultStatus = _deviationService.GetDefaultStatus();
  397. if (defaultKind != null)
  398. ViewData["DefaultKind"] = defaultKind.Id;
  399. if (defaultStatus != null)
  400. ViewData["DefaultStatus"] = defaultStatus.Id;
  401. return PartialView("~/Views/Deviations/_DeviationEditPartial.cshtml", deviationModel);
  402. }
  403. /// <summary>
  404. /// Partial edit for creating a new deviation for a site
  405. /// </summary>
  406. /// <param name="siteId">Id of the site which the deviation should be appended to.</param>
  407. public ActionResult AppendDeviationToSite(int siteId)
  408. {
  409. var site = _siteService.GetSiteById(siteId);
  410. var allDeviations = new List<Deviation>();
  411. allDeviations.AddRange(
  412. site.Appendices
  413. .SelectMany(a => a.Deviations));
  414. allDeviations.AddRange(
  415. site.Deviations);
  416. var lastCustomNumber = 0;
  417. if (allDeviations.Any())
  418. lastCustomNumber = allDeviations
  419. .Max(d => StaticHelper.TryParseInt(d.CustomNumber));
  420. var deviationModel = new DeviationDataModel
  421. {
  422. Id = -1,
  423. SiteId = siteId,
  424. CustomNumber = (lastCustomNumber + 1).ToString(),
  425. Percentage = 1,
  426. };
  427. var defaultKind = _deviationService.GetDefaultKind();
  428. var defaultStatus = _deviationService.GetDefaultStatus();
  429. if (defaultKind != null)
  430. ViewData["DefaultKind"] = defaultKind.Id;
  431. if (defaultStatus != null)
  432. ViewData["DefaultStatus"] = defaultStatus.Id;
  433. return PartialView("~/Views/Deviations/_DeviationEditPartial.cshtml", deviationModel);
  434. }
  435. /// <summary>
  436. /// Partial edit for creating a new deviation for an appendix
  437. /// </summary>
  438. /// <param name="appendixId">Id of the appendix which the deviation should be appended to.</param>
  439. public ActionResult AppendDeviationToAppendix(int appendixId)
  440. {
  441. var appendix = _appendixService.GetAppendixById(appendixId);
  442. var site = appendix.Site;
  443. var allDeviations = new List<Deviation>();
  444. allDeviations.AddRange(
  445. site.Appendices
  446. .SelectMany(a => a.Deviations));
  447. allDeviations.AddRange(
  448. site.Deviations);
  449. var lastCustomNumber = allDeviations
  450. .Max(d => StaticHelper.TryParseInt(d.CustomNumber));
  451. var deviationModel = new DeviationDataModel
  452. {
  453. Id = -1,
  454. AppendixId = appendixId,
  455. CustomNumber = (lastCustomNumber + 1).ToString(),
  456. Percentage = 1,
  457. };
  458. var defaultKind = _deviationService.GetDefaultKind();
  459. var defaultStatus = _deviationService.GetDefaultStatus();
  460. if (defaultKind != null)
  461. ViewData["DefaultKind"] = defaultKind.Id;
  462. if (defaultStatus != null)
  463. ViewData["DefaultStatus"] = defaultStatus.Id;
  464. return PartialView("~/Views/Deviations/_DeviationEditPartial.cshtml", deviationModel);
  465. }
  466. /// <summary>
  467. /// Partial Edit result for assigning a deviation to a new appendix
  468. /// </summary>
  469. /// <param name="id">Id of deviation.</param>
  470. public ActionResult AssignDeviationToAppendix(int id)
  471. {
  472. var deviation = _deviationService.GetDeviationById(id);
  473. var availableAppendices = new List<Appendix>();
  474. if (deviation.Site != null)
  475. availableAppendices.AddRange(
  476. deviation.Site.Appendices);
  477. else if (deviation.Appendix != null && deviation.Appendix.Site != null)
  478. {
  479. availableAppendices.AddRange(
  480. deviation.Appendix.Site.Appendices
  481. .Where(a => a.Id != deviation.AppendixId));
  482. }
  483. var appendixModels = availableAppendices
  484. .Select(a => AppendixDataModel.FromAppendix(a, false))
  485. .ToList();
  486. if (deviation.Appendix != null && deviation.Appendix.Site != null)
  487. appendixModels.Insert(0, new AppendixDataModel { Id = -1, Description = "Keinem (Als \"Offen\" markieren)" });
  488. ViewData["DeviationId"] = id;
  489. return PartialView("~/Views/Deviations/_DeviationAssignPartial.cshtml", appendixModels);
  490. }
  491. /// <summary>
  492. /// Assigns a deviation to the specified appendix
  493. /// </summary>
  494. /// <param name="id">Id of deviation.</param>
  495. [HttpPost]
  496. public ActionResult AssignDeviation(int id, int appendixId)
  497. {
  498. try
  499. {
  500. var deviation = _deviationService.GetDeviationById(id);
  501. if (appendixId == -1 && deviation.Appendix != null && deviation.Appendix.Site != null)
  502. {
  503. deviation.SiteId = deviation.Appendix.SiteId;
  504. deviation.Appendix = null;
  505. deviation.AppendixId = null;
  506. }
  507. else
  508. {
  509. deviation.AppendixId = appendixId;
  510. deviation.Site = null;
  511. deviation.SiteId = null;
  512. }
  513. _deviationService.UpdateDeviation(deviation);
  514. return new JsonResult
  515. {
  516. Data = "success"
  517. };
  518. }
  519. catch (Exception ex)
  520. {
  521. _logger.Error("Fehler bei Zuweisung einer Vertragsabweichung zu einem Nachtrag.", ex, _userHelper.FromCookies());
  522. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  523. }
  524. }
  525. /// <summary>
  526. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  527. /// </summary>
  528. /// <param name="deviationModel">Deviation model to be saved.</param>
  529. [HttpPost, ValidateInput(false)]
  530. public ActionResult EditDeviation(DeviationDataModel deviationModel)
  531. {
  532. try
  533. {
  534. deviationModel.DisturbanceValueEntities =
  535. deviationModel.DisturbanceEntities
  536. .Select(r => JsonConvert.DeserializeObject<DisturbanceValueDataModel>(r))
  537. .ToList();
  538. for (int i = 0; i < deviationModel.DisturbanceValueEntities.Count; i++)
  539. deviationModel.DisturbanceValueEntities.ElementAt(i).Json = deviationModel.DisturbanceEntities.ElementAt(i);
  540. deviationModel.PercentageValue = deviationModel.Value * deviationModel.Percentage;
  541. if (!ModelState.IsValid)
  542. return PartialView("~/Views/Deviations/_DeviationEditPartial.cshtml", deviationModel);
  543. var disturbanceValues = deviationModel.DisturbanceValueEntities
  544. .Select(r => r.ToDisturbanceValue())
  545. .ToList();
  546. if (deviationModel.Id == -1)
  547. {
  548. var deviation = deviationModel.ToDeviation();
  549. deviation.SetDisturbanceValues(disturbanceValues);
  550. _deviationService.InsertDeviation(deviation);
  551. _logger.Entity(deviation, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  552. }
  553. else
  554. {
  555. var deviation = _deviationService.GetDeviationById(deviationModel.Id);
  556. deviation.CustomNumber = deviationModel.CustomNumber;
  557. deviation.Description = deviationModel.Description;
  558. deviation.ReceiptDate = deviationModel.ReceiptDate;
  559. deviation.AppendixDate = deviationModel.AppendixDate;
  560. deviation.Value = deviationModel.Value;
  561. deviation.AppendixId = deviationModel.AppendixId;
  562. deviation.StatusId = deviationModel.StatusId;
  563. deviation.KindId = deviationModel.KindId;
  564. deviation.Comment = deviationModel.Comment;
  565. deviation.SetDisturbanceValues(disturbanceValues);
  566. _deviationService.UpdateDeviation(deviation);
  567. _logger.Entity(deviation, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  568. }
  569. return new JsonResult
  570. {
  571. Data = "success"
  572. };
  573. }
  574. catch (Exception ex)
  575. {
  576. _logger.Error("Fehler bei Speicherung einer Vertragsabweichung.", ex, _userHelper.FromCookies());
  577. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  578. }
  579. }
  580. /// <summary>
  581. /// Simple JSON result for deleting a specific deviation
  582. /// </summary>
  583. /// <param name="id">Deviation id.</param>
  584. [HttpPost]
  585. public ActionResult DeleteDeviation(int id)
  586. {
  587. try
  588. {
  589. var deviation = _deviationService.GetDeviationById(id);
  590. if (deviation != null)
  591. _deviationService.DeleteDeviation(deviation);
  592. _logger.Entity(deviation, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  593. return new JsonResult
  594. {
  595. Data = "success"
  596. };
  597. }
  598. catch (Exception ex)
  599. {
  600. _logger.Error("Fehler bei Löschung einer Vertragsabweichung.", ex, _userHelper.FromCookies());
  601. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  602. }
  603. }
  604. #endregion
  605. #region Claims
  606. /// <summary>
  607. /// Basic claim view function
  608. /// </summary>
  609. [FunctionAuthorize(true, "Deviation-Claims")]
  610. public ActionResult ViewClaims()
  611. {
  612. return View("~/Views/Deviations/Claims.cshtml");
  613. }
  614. /// <summary>
  615. /// Get JSON data of specific claim
  616. /// </summary>
  617. /// <param name="claimType">Claim type.</param>
  618. /// <param name="id">Claim id.</param>
  619. public ActionResult GetClaim(string claimType, int id = -1)
  620. {
  621. switch (claimType.ToLower())
  622. {
  623. case "status":
  624. var status = _deviationService.GetStatusById(id);
  625. if (status == null)
  626. return new JsonResult { Data = "notFound", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  627. else
  628. return new JsonResult {
  629. Data = JsonConvert.SerializeObject(status),
  630. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  631. };
  632. case "disturbance":
  633. var disturbance = _deviationService.GetDisturbanceById(id);
  634. if (disturbance == null)
  635. return new JsonResult { Data = "notFound", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  636. else
  637. return new JsonResult
  638. {
  639. Data = JsonConvert.SerializeObject(disturbance),
  640. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  641. };
  642. case "kind":
  643. var kind = _deviationService.GetKindById(id);
  644. if (kind == null)
  645. return new JsonResult { Data = "notFound", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  646. else
  647. return new JsonResult
  648. {
  649. Data = JsonConvert.SerializeObject(kind),
  650. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  651. };
  652. default:
  653. return new JsonResult { Data = "unknownClaimType", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  654. }
  655. }
  656. /// <summary>
  657. /// Callback result for claim grid
  658. /// </summary>
  659. /// <param name="claimType">Claim type.</param>
  660. public ActionResult PartialClaims(string claimType)
  661. {
  662. switch (claimType.ToLower())
  663. {
  664. case "status":
  665. return PartialView("~/Views/Deviations/_StatusListPartial.cshtml", ViewData["AllStatuses"]);
  666. case "disturbance":
  667. return PartialView("~/Views/Deviations/_DisturbanceListPartial.cshtml", ViewData["AllDisturbances"]);
  668. case "kind":
  669. return PartialView("~/Views/Deviations/_KindListPartial.cshtml", ViewData["AllKinds"]);
  670. default:
  671. return new EmptyResult();
  672. }
  673. }
  674. /// <summary>
  675. /// Partial edit for editing of existing or for new claim
  676. /// </summary>
  677. /// <param name="claimType">Claim type.</param>
  678. /// <param name="id">Id for existing claim, otherweise -1.</param>
  679. public ActionResult EditClaim(string claimType = "", int id = -1)
  680. {
  681. switch (claimType.ToLower())
  682. {
  683. case "status":
  684. var status = _deviationService.GetStatusById(id);
  685. var statusModel = StatusDataModel.FromStatus(status, true);
  686. return PartialView("~/Views/Deviations/_StatusEditPartial.cshtml", statusModel);
  687. case "disturbance":
  688. var disturbance = _deviationService.GetDisturbanceById(id);
  689. var disturbanceModel = DisturbanceDataModel.FromDisturbance(disturbance, true);
  690. return PartialView("~/Views/Deviations/_DisturbanceEditPartial.cshtml", disturbanceModel);
  691. case "kind":
  692. var kind = _deviationService.GetKindById(id);
  693. var kindModel = KindDataModel.FromKind(kind, true);
  694. return PartialView("~/Views/Deviations/_KindEditPartial.cshtml", kindModel);
  695. default:
  696. return new EmptyResult();
  697. }
  698. }
  699. /// <summary>
  700. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  701. /// </summary>
  702. /// <param name="statusModel">Status model to be saved.</param>
  703. [HttpPost, ValidateInput(false)]
  704. public ActionResult EditStatus(StatusDataModel statusModel)
  705. {
  706. try
  707. {
  708. if (!ModelState.IsValid)
  709. return PartialView("~/Views/Deviations/_StatusEditPartial.cshtml", statusModel);
  710. var allStatuses = _deviationService.GetAllStatuses();
  711. if (statusModel.IsDefault)
  712. {
  713. foreach (var status in allStatuses)
  714. {
  715. status.IsDefault = false;
  716. _deviationService.UpdateStatus(status);
  717. }
  718. }
  719. if (statusModel.Id == -1)
  720. {
  721. var claim = statusModel.ToStatus();
  722. _deviationService.InsertStatus(claim);
  723. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  724. }
  725. else
  726. {
  727. var claim = _deviationService.GetStatusById(statusModel.Id);
  728. claim.Description = statusModel.Description;
  729. claim.IsDefault = statusModel.IsDefault;
  730. claim.IsZeroValue = statusModel.IsZeroValue;
  731. claim.IsZeroSummarize = statusModel.IsZeroSummarize;
  732. _deviationService.UpdateStatus(claim);
  733. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  734. }
  735. return new JsonResult
  736. {
  737. Data = "success"
  738. };
  739. }
  740. catch (Exception ex)
  741. {
  742. _logger.Error("Fehler bei Speicherung eines VA-Status.", ex, _userHelper.FromCookies());
  743. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  744. }
  745. }
  746. /// <summary>
  747. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  748. /// </summary>
  749. /// <param name="disturbanceModel">Disturbance model to be saved.</param>
  750. [HttpPost, ValidateInput(false)]
  751. public ActionResult EditDisturbance(DisturbanceDataModel disturbanceModel)
  752. {
  753. try
  754. {
  755. if (!ModelState.IsValid)
  756. return PartialView("~/Views/Deviations/_DisturbanceEditPartial.cshtml", disturbanceModel);
  757. if (disturbanceModel.Id == -1)
  758. {
  759. var claim = disturbanceModel.ToDisturbance();
  760. _deviationService.InsertDisturbance(claim);
  761. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  762. }
  763. else
  764. {
  765. var disturbance = _deviationService.GetDisturbanceById(disturbanceModel.Id);
  766. disturbance.Description = disturbanceModel.Description;
  767. _deviationService.UpdateDisturbance(disturbance);
  768. _logger.Entity(disturbance, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  769. }
  770. return new JsonResult
  771. {
  772. Data = "success"
  773. };
  774. }
  775. catch (Exception ex)
  776. {
  777. _logger.Error("Fehler bei Speicherung einer VA-Kategorie.", ex, _userHelper.FromCookies());
  778. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  779. }
  780. }
  781. /// <summary>
  782. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  783. /// </summary>
  784. /// <param name="kindModel">Kind model to be saved.</param>
  785. [HttpPost, ValidateInput(false)]
  786. public ActionResult EditKind(KindDataModel kindModel)
  787. {
  788. try
  789. {
  790. if (!ModelState.IsValid)
  791. return PartialView("~/Views/Deviations/_KindEditPartial.cshtml", kindModel);
  792. var allKinds = _deviationService.GetAllKinds();
  793. if (kindModel.IsDefault)
  794. {
  795. foreach (var kind in allKinds)
  796. {
  797. kind.IsDefault = false;
  798. _deviationService.UpdateKind(kind);
  799. }
  800. }
  801. if (kindModel.Id == -1)
  802. {
  803. var claim = kindModel.ToKind();
  804. _deviationService.InsertKind(claim);
  805. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  806. }
  807. else
  808. {
  809. var kind = _deviationService.GetKindById(kindModel.Id);
  810. kind.Description = kindModel.Description;
  811. kind.IsDefault = kindModel.IsDefault;
  812. _deviationService.UpdateKind(kind);
  813. _logger.Entity(kind, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  814. }
  815. return new JsonResult
  816. {
  817. Data = "success"
  818. };
  819. }
  820. catch (Exception ex)
  821. {
  822. _logger.Error("Fehler bei Speicherung einer Art.", ex, _userHelper.FromCookies());
  823. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  824. }
  825. }
  826. /// <summary>
  827. /// Simple JSON result for deleting a specific claim
  828. /// </summary>
  829. /// <param name="claimType">Claim type.</param>
  830. /// <param name="id">Claim id.</param>
  831. /// <param name="replaceId">Id of claim which deviations get in place of deleting claim.</param>
  832. [HttpPost]
  833. public ActionResult DeleteClaim(string claimType, int id, int replaceId)
  834. {
  835. switch (claimType.ToLower())
  836. {
  837. case "status":
  838. try
  839. {
  840. var status = _deviationService.GetStatusById(id);
  841. var replaceStatus = _deviationService.GetStatusById(replaceId);
  842. var statusDeviations = _deviationService.GetDeviationsByStatus(id);
  843. foreach (var deviation in statusDeviations)
  844. {
  845. deviation.StatusId = replaceId;
  846. deviation.Status = replaceStatus;
  847. _deviationService.UpdateDeviation(deviation);
  848. }
  849. if (status != null)
  850. _deviationService.DeleteStatus(status);
  851. _logger.Entity(status, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  852. }
  853. catch (Exception ex)
  854. {
  855. _logger.Error("Fehler bei Löschung eines VA-Status.", ex, _userHelper.FromCookies());
  856. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  857. }
  858. break;
  859. case "kind":
  860. try
  861. {
  862. var kind = _deviationService.GetKindById(id);
  863. var replaceKind = _deviationService.GetKindById(replaceId);
  864. var kindDeviations = _deviationService.GetDeviationsByKind(id);
  865. foreach (var deviation in kindDeviations)
  866. {
  867. deviation.KindId = replaceId;
  868. deviation.Kind = replaceKind;
  869. _deviationService.UpdateDeviation(deviation);
  870. }
  871. if (kind != null)
  872. _deviationService.DeleteKind(kind);
  873. _logger.Entity(kind, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  874. }
  875. catch (Exception ex)
  876. {
  877. _logger.Error("Fehler bei Löschung einer Art.", ex, _userHelper.FromCookies());
  878. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  879. }
  880. break;
  881. case "disturbance":
  882. try
  883. {
  884. var disturbance = _deviationService.GetDisturbanceById(id);
  885. var replaceDisturbance = _deviationService.GetDisturbanceById(replaceId);
  886. var allDeviations = _deviationService.GetAllDeviations();
  887. foreach (var deviation in allDeviations)
  888. {
  889. foreach (var disturbanceValue in deviation.DisturbanceValues)
  890. {
  891. if (disturbanceValue.DisturbanceId == id)
  892. {
  893. disturbanceValue.Disturbance = replaceDisturbance;
  894. disturbanceValue.DisturbanceId = replaceDisturbance.Id;
  895. }
  896. }
  897. _deviationService.UpdateDeviation(deviation);
  898. }
  899. if (disturbance != null)
  900. _deviationService.DeleteDisturbance(disturbance);
  901. _logger.Entity(disturbance, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  902. }
  903. catch (Exception ex)
  904. {
  905. _logger.Error("Fehler bei Löschung einer VA-Kategorie.", ex, _userHelper.FromCookies());
  906. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  907. }
  908. break;
  909. default:
  910. return new EmptyResult();
  911. }
  912. return new JsonResult
  913. {
  914. Data = "success"
  915. };
  916. }
  917. #endregion
  918. #region Helper
  919. /// <summary>
  920. /// Uses a customFilter on a collection of deviation data models
  921. /// </summary>
  922. /// <param name="customFilters">Custom filter string.</param>
  923. /// <param name="models">Model list.</param>
  924. private void UseCustomFilters(string customFilters, List<DeviationDataModel> models)
  925. {
  926. var filters = JsonConvert.DeserializeObject(customFilters) as JObject;
  927. if (filters["DisturbanceValuesDescription"] != null && !String.IsNullOrEmpty(filters["DisturbanceValuesDescription"].Value<string>()))
  928. {
  929. var removables = new List<DeviationDataModel>();
  930. var filterVal = filters["DisturbanceValuesDescription"].Value<string>();
  931. foreach (var model in models)
  932. {
  933. var filterItemExists = model.DisturbanceValueEntities
  934. .Any(d => d.Description.ToLower().Contains(filterVal.ToLower()));
  935. if (!filterItemExists)
  936. removables.Add(model);
  937. else
  938. {
  939. var removeableValues = model.DisturbanceValueEntities
  940. .Where(d => !d.Description.ToLower().Contains(filterVal.ToLower()))
  941. .ToList();
  942. foreach (var removeableValue in removeableValues)
  943. model.DisturbanceValueEntities.Remove(removeableValue);
  944. if (removeableValues.Count > 0)
  945. model.DisturbanceValueEntities.Add(new DisturbanceValueDataModel { Description = "( ausgefilterte Kategorien )" });
  946. }
  947. }
  948. foreach (var removeable in removables)
  949. models.Remove(removeable);
  950. }
  951. }
  952. #endregion
  953. }
  954. }