DeviationController.cs 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138
  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. _deviationService.UpdateStatus(claim);
  732. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  733. }
  734. return new JsonResult
  735. {
  736. Data = "success"
  737. };
  738. }
  739. catch (Exception ex)
  740. {
  741. _logger.Error("Fehler bei Speicherung eines VA-Status.", ex, _userHelper.FromCookies());
  742. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  743. }
  744. }
  745. /// <summary>
  746. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  747. /// </summary>
  748. /// <param name="disturbanceModel">Disturbance model to be saved.</param>
  749. [HttpPost, ValidateInput(false)]
  750. public ActionResult EditDisturbance(DisturbanceDataModel disturbanceModel)
  751. {
  752. try
  753. {
  754. if (!ModelState.IsValid)
  755. return PartialView("~/Views/Deviations/_DisturbanceEditPartial.cshtml", disturbanceModel);
  756. if (disturbanceModel.Id == -1)
  757. {
  758. var claim = disturbanceModel.ToDisturbance();
  759. _deviationService.InsertDisturbance(claim);
  760. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  761. }
  762. else
  763. {
  764. var disturbance = _deviationService.GetDisturbanceById(disturbanceModel.Id);
  765. disturbance.Description = disturbanceModel.Description;
  766. _deviationService.UpdateDisturbance(disturbance);
  767. _logger.Entity(disturbance, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  768. }
  769. return new JsonResult
  770. {
  771. Data = "success"
  772. };
  773. }
  774. catch (Exception ex)
  775. {
  776. _logger.Error("Fehler bei Speicherung einer VA-Kategorie.", ex, _userHelper.FromCookies());
  777. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  778. }
  779. }
  780. /// <summary>
  781. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  782. /// </summary>
  783. /// <param name="kindModel">Kind model to be saved.</param>
  784. [HttpPost, ValidateInput(false)]
  785. public ActionResult EditKind(KindDataModel kindModel)
  786. {
  787. try
  788. {
  789. if (!ModelState.IsValid)
  790. return PartialView("~/Views/Deviations/_KindEditPartial.cshtml", kindModel);
  791. var allKinds = _deviationService.GetAllKinds();
  792. if (kindModel.IsDefault)
  793. {
  794. foreach (var kind in allKinds)
  795. {
  796. kind.IsDefault = false;
  797. _deviationService.UpdateKind(kind);
  798. }
  799. }
  800. if (kindModel.Id == -1)
  801. {
  802. var claim = kindModel.ToKind();
  803. _deviationService.InsertKind(claim);
  804. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  805. }
  806. else
  807. {
  808. var kind = _deviationService.GetKindById(kindModel.Id);
  809. kind.Description = kindModel.Description;
  810. kind.IsDefault = kindModel.IsDefault;
  811. _deviationService.UpdateKind(kind);
  812. _logger.Entity(kind, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  813. }
  814. return new JsonResult
  815. {
  816. Data = "success"
  817. };
  818. }
  819. catch (Exception ex)
  820. {
  821. _logger.Error("Fehler bei Speicherung einer Art.", ex, _userHelper.FromCookies());
  822. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  823. }
  824. }
  825. /// <summary>
  826. /// Simple JSON result for deleting a specific claim
  827. /// </summary>
  828. /// <param name="claimType">Claim type.</param>
  829. /// <param name="id">Claim id.</param>
  830. /// <param name="replaceId">Id of claim which deviations get in place of deleting claim.</param>
  831. [HttpPost]
  832. public ActionResult DeleteClaim(string claimType, int id, int replaceId)
  833. {
  834. switch (claimType.ToLower())
  835. {
  836. case "status":
  837. try
  838. {
  839. var status = _deviationService.GetStatusById(id);
  840. var replaceStatus = _deviationService.GetStatusById(replaceId);
  841. var statusDeviations = _deviationService.GetDeviationsByStatus(id);
  842. foreach (var deviation in statusDeviations)
  843. {
  844. deviation.StatusId = replaceId;
  845. deviation.Status = replaceStatus;
  846. _deviationService.UpdateDeviation(deviation);
  847. }
  848. if (status != null)
  849. _deviationService.DeleteStatus(status);
  850. _logger.Entity(status, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  851. }
  852. catch (Exception ex)
  853. {
  854. _logger.Error("Fehler bei Löschung eines VA-Status.", ex, _userHelper.FromCookies());
  855. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  856. }
  857. break;
  858. case "kind":
  859. try
  860. {
  861. var kind = _deviationService.GetKindById(id);
  862. var replaceKind = _deviationService.GetKindById(replaceId);
  863. var kindDeviations = _deviationService.GetDeviationsByKind(id);
  864. foreach (var deviation in kindDeviations)
  865. {
  866. deviation.KindId = replaceId;
  867. deviation.Kind = replaceKind;
  868. _deviationService.UpdateDeviation(deviation);
  869. }
  870. if (kind != null)
  871. _deviationService.DeleteKind(kind);
  872. _logger.Entity(kind, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  873. }
  874. catch (Exception ex)
  875. {
  876. _logger.Error("Fehler bei Löschung einer Art.", ex, _userHelper.FromCookies());
  877. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  878. }
  879. break;
  880. case "disturbance":
  881. try
  882. {
  883. var disturbance = _deviationService.GetDisturbanceById(id);
  884. var replaceDisturbance = _deviationService.GetDisturbanceById(replaceId);
  885. var allDeviations = _deviationService.GetAllDeviations();
  886. foreach (var deviation in allDeviations)
  887. {
  888. foreach (var disturbanceValue in deviation.DisturbanceValues)
  889. {
  890. if (disturbanceValue.DisturbanceId == id)
  891. {
  892. disturbanceValue.Disturbance = replaceDisturbance;
  893. disturbanceValue.DisturbanceId = replaceDisturbance.Id;
  894. }
  895. }
  896. _deviationService.UpdateDeviation(deviation);
  897. }
  898. if (disturbance != null)
  899. _deviationService.DeleteDisturbance(disturbance);
  900. _logger.Entity(disturbance, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  901. }
  902. catch (Exception ex)
  903. {
  904. _logger.Error("Fehler bei Löschung einer VA-Kategorie.", ex, _userHelper.FromCookies());
  905. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  906. }
  907. break;
  908. default:
  909. return new EmptyResult();
  910. }
  911. return new JsonResult
  912. {
  913. Data = "success"
  914. };
  915. }
  916. #endregion
  917. #region Helper
  918. /// <summary>
  919. /// Uses a customFilter on a collection of deviation data models
  920. /// </summary>
  921. /// <param name="customFilters">Custom filter string.</param>
  922. /// <param name="models">Model list.</param>
  923. private void UseCustomFilters(string customFilters, List<DeviationDataModel> models)
  924. {
  925. var filters = JsonConvert.DeserializeObject(customFilters) as JObject;
  926. if (filters["DisturbanceValuesDescription"] != null && !String.IsNullOrEmpty(filters["DisturbanceValuesDescription"].Value<string>()))
  927. {
  928. var removables = new List<DeviationDataModel>();
  929. var filterVal = filters["DisturbanceValuesDescription"].Value<string>();
  930. foreach (var model in models)
  931. {
  932. var filterItemExists = model.DisturbanceValueEntities
  933. .Any(d => d.Description.ToLower().Contains(filterVal.ToLower()));
  934. if (!filterItemExists)
  935. removables.Add(model);
  936. else
  937. {
  938. var removeableValues = model.DisturbanceValueEntities
  939. .Where(d => !d.Description.ToLower().Contains(filterVal.ToLower()))
  940. .ToList();
  941. foreach (var removeableValue in removeableValues)
  942. model.DisturbanceValueEntities.Remove(removeableValue);
  943. if (removeableValues.Count > 0)
  944. model.DisturbanceValueEntities.Add(new DisturbanceValueDataModel { Description = "( ausgefilterte Kategorien )" });
  945. }
  946. }
  947. foreach (var removeable in removables)
  948. models.Remove(removeable);
  949. }
  950. }
  951. #endregion
  952. }
  953. }