DeviationController.cs 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140
  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.Percentage = deviationModel.Percentage;
  561. deviation.Value = deviationModel.Value;
  562. deviation.AppendixId = deviationModel.AppendixId;
  563. deviation.StatusId = deviationModel.StatusId;
  564. deviation.KindId = deviationModel.KindId;
  565. deviation.Comment = deviationModel.Comment;
  566. deviation.SetDisturbanceValues(disturbanceValues);
  567. _deviationService.UpdateDeviation(deviation);
  568. _logger.Entity(deviation, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  569. }
  570. return new JsonResult
  571. {
  572. Data = "success"
  573. };
  574. }
  575. catch (Exception ex)
  576. {
  577. _logger.Error("Fehler bei Speicherung einer Vertragsabweichung.", ex, _userHelper.FromCookies());
  578. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  579. }
  580. }
  581. /// <summary>
  582. /// Simple JSON result for deleting a specific deviation
  583. /// </summary>
  584. /// <param name="id">Deviation id.</param>
  585. [HttpPost]
  586. public ActionResult DeleteDeviation(int id)
  587. {
  588. try
  589. {
  590. var deviation = _deviationService.GetDeviationById(id);
  591. if (deviation != null)
  592. _deviationService.DeleteDeviation(deviation);
  593. _logger.Entity(deviation, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  594. return new JsonResult
  595. {
  596. Data = "success"
  597. };
  598. }
  599. catch (Exception ex)
  600. {
  601. _logger.Error("Fehler bei Löschung einer Vertragsabweichung.", ex, _userHelper.FromCookies());
  602. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  603. }
  604. }
  605. #endregion
  606. #region Claims
  607. /// <summary>
  608. /// Basic claim view function
  609. /// </summary>
  610. [FunctionAuthorize(true, "Deviation-Claims")]
  611. public ActionResult ViewClaims()
  612. {
  613. return View("~/Views/Deviations/Claims.cshtml");
  614. }
  615. /// <summary>
  616. /// Get JSON data of specific claim
  617. /// </summary>
  618. /// <param name="claimType">Claim type.</param>
  619. /// <param name="id">Claim id.</param>
  620. public ActionResult GetClaim(string claimType, int id = -1)
  621. {
  622. switch (claimType.ToLower())
  623. {
  624. case "status":
  625. var status = _deviationService.GetStatusById(id);
  626. if (status == null)
  627. return new JsonResult { Data = "notFound", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  628. else
  629. return new JsonResult {
  630. Data = JsonConvert.SerializeObject(status),
  631. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  632. };
  633. case "disturbance":
  634. var disturbance = _deviationService.GetDisturbanceById(id);
  635. if (disturbance == null)
  636. return new JsonResult { Data = "notFound", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  637. else
  638. return new JsonResult
  639. {
  640. Data = JsonConvert.SerializeObject(disturbance),
  641. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  642. };
  643. case "kind":
  644. var kind = _deviationService.GetKindById(id);
  645. if (kind == null)
  646. return new JsonResult { Data = "notFound", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  647. else
  648. return new JsonResult
  649. {
  650. Data = JsonConvert.SerializeObject(kind),
  651. JsonRequestBehavior = JsonRequestBehavior.AllowGet
  652. };
  653. default:
  654. return new JsonResult { Data = "unknownClaimType", JsonRequestBehavior = JsonRequestBehavior.AllowGet };
  655. }
  656. }
  657. /// <summary>
  658. /// Callback result for claim grid
  659. /// </summary>
  660. /// <param name="claimType">Claim type.</param>
  661. public ActionResult PartialClaims(string claimType)
  662. {
  663. switch (claimType.ToLower())
  664. {
  665. case "status":
  666. return PartialView("~/Views/Deviations/_StatusListPartial.cshtml", ViewData["AllStatuses"]);
  667. case "disturbance":
  668. return PartialView("~/Views/Deviations/_DisturbanceListPartial.cshtml", ViewData["AllDisturbances"]);
  669. case "kind":
  670. return PartialView("~/Views/Deviations/_KindListPartial.cshtml", ViewData["AllKinds"]);
  671. default:
  672. return new EmptyResult();
  673. }
  674. }
  675. /// <summary>
  676. /// Partial edit for editing of existing or for new claim
  677. /// </summary>
  678. /// <param name="claimType">Claim type.</param>
  679. /// <param name="id">Id for existing claim, otherweise -1.</param>
  680. public ActionResult EditClaim(string claimType = "", int id = -1)
  681. {
  682. switch (claimType.ToLower())
  683. {
  684. case "status":
  685. var status = _deviationService.GetStatusById(id);
  686. var statusModel = StatusDataModel.FromStatus(status, true);
  687. return PartialView("~/Views/Deviations/_StatusEditPartial.cshtml", statusModel);
  688. case "disturbance":
  689. var disturbance = _deviationService.GetDisturbanceById(id);
  690. var disturbanceModel = DisturbanceDataModel.FromDisturbance(disturbance, true);
  691. return PartialView("~/Views/Deviations/_DisturbanceEditPartial.cshtml", disturbanceModel);
  692. case "kind":
  693. var kind = _deviationService.GetKindById(id);
  694. var kindModel = KindDataModel.FromKind(kind, true);
  695. return PartialView("~/Views/Deviations/_KindEditPartial.cshtml", kindModel);
  696. default:
  697. return new EmptyResult();
  698. }
  699. }
  700. /// <summary>
  701. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  702. /// </summary>
  703. /// <param name="statusModel">Status model to be saved.</param>
  704. [HttpPost, ValidateInput(false)]
  705. public ActionResult EditStatus(StatusDataModel statusModel)
  706. {
  707. try
  708. {
  709. if (!ModelState.IsValid)
  710. return PartialView("~/Views/Deviations/_StatusEditPartial.cshtml", statusModel);
  711. var allStatuses = _deviationService.GetAllStatuses();
  712. if (statusModel.IsDefault)
  713. {
  714. foreach (var status in allStatuses)
  715. {
  716. status.IsDefault = false;
  717. _deviationService.UpdateStatus(status);
  718. }
  719. }
  720. if (statusModel.Id == -1)
  721. {
  722. var claim = statusModel.ToStatus();
  723. _deviationService.InsertStatus(claim);
  724. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  725. }
  726. else
  727. {
  728. var claim = _deviationService.GetStatusById(statusModel.Id);
  729. claim.Description = statusModel.Description;
  730. claim.IsDefault = statusModel.IsDefault;
  731. claim.IsZeroValue = statusModel.IsZeroValue;
  732. claim.IsZeroSummarize = statusModel.IsZeroSummarize;
  733. _deviationService.UpdateStatus(claim);
  734. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  735. }
  736. return new JsonResult
  737. {
  738. Data = "success"
  739. };
  740. }
  741. catch (Exception ex)
  742. {
  743. _logger.Error("Fehler bei Speicherung eines VA-Status.", ex, _userHelper.FromCookies());
  744. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  745. }
  746. }
  747. /// <summary>
  748. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  749. /// </summary>
  750. /// <param name="disturbanceModel">Disturbance model to be saved.</param>
  751. [HttpPost, ValidateInput(false)]
  752. public ActionResult EditDisturbance(DisturbanceDataModel disturbanceModel)
  753. {
  754. try
  755. {
  756. if (!ModelState.IsValid)
  757. return PartialView("~/Views/Deviations/_DisturbanceEditPartial.cshtml", disturbanceModel);
  758. if (disturbanceModel.Id == -1)
  759. {
  760. var claim = disturbanceModel.ToDisturbance();
  761. _deviationService.InsertDisturbance(claim);
  762. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  763. }
  764. else
  765. {
  766. var disturbance = _deviationService.GetDisturbanceById(disturbanceModel.Id);
  767. disturbance.Description = disturbanceModel.Description;
  768. _deviationService.UpdateDisturbance(disturbance);
  769. _logger.Entity(disturbance, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  770. }
  771. return new JsonResult
  772. {
  773. Data = "success"
  774. };
  775. }
  776. catch (Exception ex)
  777. {
  778. _logger.Error("Fehler bei Speicherung einer VA-Kategorie.", ex, _userHelper.FromCookies());
  779. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  780. }
  781. }
  782. /// <summary>
  783. /// Partial edit result if ModelState is valid, otherwise simple JSON result for success
  784. /// </summary>
  785. /// <param name="kindModel">Kind model to be saved.</param>
  786. [HttpPost, ValidateInput(false)]
  787. public ActionResult EditKind(KindDataModel kindModel)
  788. {
  789. try
  790. {
  791. if (!ModelState.IsValid)
  792. return PartialView("~/Views/Deviations/_KindEditPartial.cshtml", kindModel);
  793. var allKinds = _deviationService.GetAllKinds();
  794. if (kindModel.IsDefault)
  795. {
  796. foreach (var kind in allKinds)
  797. {
  798. kind.IsDefault = false;
  799. _deviationService.UpdateKind(kind);
  800. }
  801. }
  802. if (kindModel.Id == -1)
  803. {
  804. var claim = kindModel.ToKind();
  805. _deviationService.InsertKind(claim);
  806. _logger.Entity(claim, Core.Domain.Logging.LogEntityActivity.Insert, _userHelper.FromCookies());
  807. }
  808. else
  809. {
  810. var kind = _deviationService.GetKindById(kindModel.Id);
  811. kind.Description = kindModel.Description;
  812. kind.IsDefault = kindModel.IsDefault;
  813. _deviationService.UpdateKind(kind);
  814. _logger.Entity(kind, Core.Domain.Logging.LogEntityActivity.Update, _userHelper.FromCookies());
  815. }
  816. return new JsonResult
  817. {
  818. Data = "success"
  819. };
  820. }
  821. catch (Exception ex)
  822. {
  823. _logger.Error("Fehler bei Speicherung einer Art.", ex, _userHelper.FromCookies());
  824. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  825. }
  826. }
  827. /// <summary>
  828. /// Simple JSON result for deleting a specific claim
  829. /// </summary>
  830. /// <param name="claimType">Claim type.</param>
  831. /// <param name="id">Claim id.</param>
  832. /// <param name="replaceId">Id of claim which deviations get in place of deleting claim.</param>
  833. [HttpPost]
  834. public ActionResult DeleteClaim(string claimType, int id, int replaceId)
  835. {
  836. switch (claimType.ToLower())
  837. {
  838. case "status":
  839. try
  840. {
  841. var status = _deviationService.GetStatusById(id);
  842. var replaceStatus = _deviationService.GetStatusById(replaceId);
  843. var statusDeviations = _deviationService.GetDeviationsByStatus(id);
  844. foreach (var deviation in statusDeviations)
  845. {
  846. deviation.StatusId = replaceId;
  847. deviation.Status = replaceStatus;
  848. _deviationService.UpdateDeviation(deviation);
  849. }
  850. if (status != null)
  851. _deviationService.DeleteStatus(status);
  852. _logger.Entity(status, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  853. }
  854. catch (Exception ex)
  855. {
  856. _logger.Error("Fehler bei Löschung eines VA-Status.", ex, _userHelper.FromCookies());
  857. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  858. }
  859. break;
  860. case "kind":
  861. try
  862. {
  863. var kind = _deviationService.GetKindById(id);
  864. var replaceKind = _deviationService.GetKindById(replaceId);
  865. var kindDeviations = _deviationService.GetDeviationsByKind(id);
  866. foreach (var deviation in kindDeviations)
  867. {
  868. deviation.KindId = replaceId;
  869. deviation.Kind = replaceKind;
  870. _deviationService.UpdateDeviation(deviation);
  871. }
  872. if (kind != null)
  873. _deviationService.DeleteKind(kind);
  874. _logger.Entity(kind, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  875. }
  876. catch (Exception ex)
  877. {
  878. _logger.Error("Fehler bei Löschung einer Art.", ex, _userHelper.FromCookies());
  879. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  880. }
  881. break;
  882. case "disturbance":
  883. try
  884. {
  885. var disturbance = _deviationService.GetDisturbanceById(id);
  886. var replaceDisturbance = _deviationService.GetDisturbanceById(replaceId);
  887. var allDeviations = _deviationService.GetAllDeviations();
  888. foreach (var deviation in allDeviations)
  889. {
  890. foreach (var disturbanceValue in deviation.DisturbanceValues)
  891. {
  892. if (disturbanceValue.DisturbanceId == id)
  893. {
  894. disturbanceValue.Disturbance = replaceDisturbance;
  895. disturbanceValue.DisturbanceId = replaceDisturbance.Id;
  896. }
  897. }
  898. _deviationService.UpdateDeviation(deviation);
  899. }
  900. if (disturbance != null)
  901. _deviationService.DeleteDisturbance(disturbance);
  902. _logger.Entity(disturbance, Core.Domain.Logging.LogEntityActivity.Delete, _userHelper.FromCookies());
  903. }
  904. catch (Exception ex)
  905. {
  906. _logger.Error("Fehler bei Löschung einer VA-Kategorie.", ex, _userHelper.FromCookies());
  907. return PartialView("~/Views/Shared/_PopupError.cshtml", ex);
  908. }
  909. break;
  910. default:
  911. return new EmptyResult();
  912. }
  913. return new JsonResult
  914. {
  915. Data = "success"
  916. };
  917. }
  918. #endregion
  919. #region Helper
  920. /// <summary>
  921. /// Uses a customFilter on a collection of deviation data models
  922. /// </summary>
  923. /// <param name="customFilters">Custom filter string.</param>
  924. /// <param name="models">Model list.</param>
  925. private void UseCustomFilters(string customFilters, List<DeviationDataModel> models)
  926. {
  927. var filters = JsonConvert.DeserializeObject(customFilters) as JObject;
  928. if (filters["DisturbanceValuesDescription"] != null && !String.IsNullOrEmpty(filters["DisturbanceValuesDescription"].Value<string>()))
  929. {
  930. var removables = new List<DeviationDataModel>();
  931. var filterVal = filters["DisturbanceValuesDescription"].Value<string>();
  932. foreach (var model in models)
  933. {
  934. var filterItemExists = model.DisturbanceValueEntities
  935. .Any(d => d.Description.ToLower().Contains(filterVal.ToLower()));
  936. if (!filterItemExists)
  937. removables.Add(model);
  938. else
  939. {
  940. var removeableValues = model.DisturbanceValueEntities
  941. .Where(d => !d.Description.ToLower().Contains(filterVal.ToLower()))
  942. .ToList();
  943. foreach (var removeableValue in removeableValues)
  944. model.DisturbanceValueEntities.Remove(removeableValue);
  945. if (removeableValues.Count > 0)
  946. model.DisturbanceValueEntities.Add(new DisturbanceValueDataModel { Description = "( ausgefilterte Kategorien )" });
  947. }
  948. }
  949. foreach (var removeable in removables)
  950. models.Remove(removeable);
  951. }
  952. }
  953. #endregion
  954. }
  955. }