GridViewSettingsHelper.cs 85 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939
  1. using DevExpress.Data;
  2. using DevExpress.Utils;
  3. using DevExpress.Web;
  4. using DevExpress.Web.ASPxThemes;
  5. using DevExpress.Web.Mvc;
  6. using DevExpress.Web.Mvc.UI;
  7. using GreenTree.Nachtragsmanagement.Core.Authentication;
  8. using GreenTree.Nachtragsmanagement.Web.Models.Appendix;
  9. using System;
  10. using System.Linq;
  11. using System.Collections.Generic;
  12. using System.Web.UI;
  13. using System.Web.UI.WebControls;
  14. using System.Web.Mvc.Html;
  15. using GreenTree.Nachtragsmanagement.Web.Models.Deviation;
  16. using GreenTree.Nachtragsmanagement.Core;
  17. using GreenTree.Nachtragsmanagement.Services.Configuration;
  18. namespace GreenTree.Nachtragsmanagement.Web.Extensions
  19. {
  20. public static class GridViewSettingsHelper
  21. {
  22. /// <summary>
  23. /// Current user context
  24. /// </summary>
  25. public static UserContext _userContext = Core.CommonHelper.UserContext();
  26. /// <summary>
  27. /// Global configuration service
  28. /// </summary>
  29. public static IConfigurationService _configurationService;
  30. /// <summary>
  31. /// Creates GridViewSettings for the site gridView
  32. /// </summary>
  33. /// <param name="html">Current HtmlHelper context.</param>
  34. public static GridViewSettings SiteGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  35. {
  36. var s = new GridViewSettings();
  37. s.Name = "devGridViewSite";
  38. s.KeyFieldName = "Id";
  39. s.CallbackRouteValues = new { Controller = "Site", Action = "PartialSites" };
  40. s.Width = Unit.Percentage(99);
  41. s.Settings.ShowHeaderFilterButton = true;
  42. s.Settings.ShowFilterRow = true;
  43. s.Settings.ShowFilterRowMenu = false;
  44. s.Settings.ShowFooter = true;
  45. s.Settings.ShowGroupPanel = true;
  46. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  47. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  48. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  49. s.Settings.VerticalScrollableHeight =
  50. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  51. ? 400
  52. : (int)html.ViewData["ScrollHeight"];
  53. s.SettingsExport.Landscape = true;
  54. s.SettingsExport.FileName = "Baustellenliste";
  55. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  56. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  57. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  58. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  59. s.SettingsBehavior.EnableCustomizationWindow = true;
  60. s.SettingsBehavior.AllowHeaderFilter = true;
  61. s.SettingsPager.AlwaysShowPager = true;
  62. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  63. s.SettingsPager.Position = PagerPosition.Bottom;
  64. s.SettingsPager.PageSizeItemSettings.Visible = true;
  65. s.SettingsPager.FirstPageButton.Visible = true;
  66. s.SettingsPager.LastPageButton.Visible = true;
  67. s.SettingsPager.NumericButtonCount = 5;
  68. s.Toolbars.Add(t =>
  69. {
  70. if (_userContext.CurrentUser.HasFunction("Site-Sites-Edit"))
  71. {
  72. t.Items.Add(i =>
  73. {
  74. i.Text = "Baustelle anlegen";
  75. i.Name = "AddSite";
  76. i.Image.IconID = IconID.ActionsAdd16x16;
  77. });
  78. }
  79. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  80. refreshItem.Text = "Aktualisieren";
  81. var expandItem = t.Items.Add(GridViewToolbarCommand.FullExpand);
  82. expandItem.Text = "Alle aufklappen";
  83. var collapseItem = t.Items.Add(GridViewToolbarCommand.FullCollapse);
  84. collapseItem.Text = "Alle einklappen";
  85. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  86. filterItem.Text = "Filter entfernen";
  87. t.Items.Add(i =>
  88. {
  89. i.Text = "Spalten anzeigen / ausblenden";
  90. i.Name = "ToggleColumnChooser";
  91. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  92. i.BeginGroup = true;
  93. });
  94. t.Items.Add(i =>
  95. {
  96. i.Text = "Drucken";
  97. i.Name = "Print";
  98. i.Image.IconID = IconID.PrintDefaultprinter16x16;
  99. i.BeginGroup = true;
  100. });
  101. t.Items.Add(i =>
  102. {
  103. i.Text = "Zurücksetzen";
  104. i.Name = "ResetSettings";
  105. i.Image.IconID = IconID.ActionsReset16x16;
  106. i.BeginGroup = true;
  107. });
  108. });
  109. if (_userContext.CurrentUser.HasFunction("Site-Sites-Edit") || _userContext.CurrentUser.HasFunction("Site-Sites-Delete"))
  110. {
  111. s.Columns.Add(column =>
  112. {
  113. column.Caption = "#";
  114. column.SetDataItemTemplateContent(c =>
  115. {
  116. if (_userContext.CurrentUser.HasFunction("Site-Sites-Edit"))
  117. html.ViewContext.Writer.Write(
  118. "<a href=\"#\" onclick=\"editSite(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Bearbeiten</a>");
  119. if (_userContext.CurrentUser.HasFunction("Site-Sites-Delete"))
  120. html.ViewContext.Writer.Write(
  121. "<br /><a href=\"#\" onclick=\"confirmDelete(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Löschen</a>");
  122. });
  123. column.Caption = "#";
  124. column.Settings.AllowDragDrop = DefaultBoolean.False;
  125. column.Settings.AllowSort = DefaultBoolean.False;
  126. column.Width = new Unit(100, UnitType.Pixel);
  127. });
  128. }
  129. s.Columns.Add(column =>
  130. {
  131. column.Caption = "Kostenstelle";
  132. column.FieldName = "CustomNumber";
  133. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  134. column.MinWidth = 120;
  135. column.Width = new Unit(130, UnitType.Pixel);
  136. column.Settings.SortMode = DevExpress.XtraGrid.ColumnSortMode.Custom;
  137. });
  138. s.Columns.Add(column =>
  139. {
  140. column.Caption = "Bauvorhaben";
  141. column.FieldName = "Description";
  142. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  143. column.MinWidth = 150;
  144. column.Width = new Unit(150, UnitType.Pixel);
  145. });
  146. s.Columns.Add(column =>
  147. {
  148. column.Caption = "Start";
  149. column.FieldName = "Start";
  150. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  151. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.DateRangePicker;
  152. column.MinWidth = 90;
  153. column.Width = new Unit(90, UnitType.Pixel);
  154. });
  155. s.Columns.Add(column =>
  156. {
  157. column.Caption = "Ende";
  158. column.FieldName = "End";
  159. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  160. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.DateRangePicker;
  161. column.MinWidth = 90;
  162. column.Width = new Unit(90, UnitType.Pixel);
  163. });
  164. s.Columns.Add(column =>
  165. {
  166. column.Caption = "Abgeschl.";
  167. column.FieldName = "Finished";
  168. column.MinWidth = 70;
  169. column.Width = new Unit(70, UnitType.Pixel);
  170. });
  171. s.Columns.Add(column =>
  172. {
  173. column.Caption = "Offene VA";
  174. column.FieldName = "DeviationDescription";
  175. column.MinWidth = 230;
  176. column.Width = new Unit(230, UnitType.Pixel);
  177. column.SetDataItemTemplateContent(c =>
  178. {
  179. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  180. var deviationDescription = DataBinder.Eval(c.DataItem, "DeviationDescription");
  181. var text = deviationDescription == null
  182. ? String.Empty
  183. : deviationDescription.ToString();
  184. var isLongText = text.ToString().Length > 80;
  185. if (isLongText)
  186. {
  187. html.ViewContext.Writer.Write(text.Substring(0, 80) + " ...");
  188. html.ViewContext.Writer.Write(
  189. "<a href=\"#\" onclick='showDeviationDescription(" + id + ",this)'><br />Anzeigen</a>");
  190. }
  191. else
  192. html.ViewContext.Writer.Write(text);
  193. });
  194. });
  195. s.Columns.Add(column =>
  196. {
  197. column.Caption = "Ges. VA-Sum.";
  198. column.FieldName = "DeviationValue";
  199. column.PropertiesEdit.DisplayFormatString = "c2";
  200. column.MinWidth = 120;
  201. column.Width = new Unit(120, UnitType.Pixel);
  202. });
  203. s.Columns.Add(column =>
  204. {
  205. column.Caption = "Off. VA-Sum.";
  206. column.FieldName = "SiteDeviationValue";
  207. column.PropertiesEdit.DisplayFormatString = "c2";
  208. column.MinWidth = 120;
  209. column.Width = new Unit(120, UnitType.Pixel);
  210. });
  211. s.Columns.Add(column =>
  212. {
  213. column.Caption = "Nachträge";
  214. column.FieldName = "AppendixDescription";
  215. column.MinWidth = 130;
  216. column.Width = new Unit(130, UnitType.Pixel);
  217. });
  218. s.Columns.Add(column =>
  219. {
  220. column.Caption = "Off. NT-Sum.";
  221. column.FieldName = "AppendixValueRemaining";
  222. column.PropertiesEdit.DisplayFormatString = "c2";
  223. column.MinWidth = 120;
  224. column.Width = new Unit(120, UnitType.Pixel);
  225. });
  226. s.Columns.Add(column =>
  227. {
  228. column.Caption = "Bew. NT-Sum.";
  229. column.FieldName = "AppendixValueCalculated";
  230. column.PropertiesEdit.DisplayFormatString = "c2";
  231. column.MinWidth = 120;
  232. column.Width = new Unit(120, UnitType.Pixel);
  233. });
  234. s.Columns.Add(column =>
  235. {
  236. column.Caption = "Pot. NT-Sum.";
  237. column.FieldName = "AppendixValueCleared";
  238. column.PropertiesEdit.DisplayFormatString = "c2";
  239. column.MinWidth = 120;
  240. column.Width = new Unit(120, UnitType.Pixel);
  241. });
  242. s.Columns.Add(column =>
  243. {
  244. column.Caption = "Verh. NT-Sum.";
  245. column.FieldName = "AppendixValueNegotiated";
  246. column.PropertiesEdit.DisplayFormatString = "c2";
  247. column.MinWidth = 120;
  248. column.Width = new Unit(120, UnitType.Pixel);
  249. });
  250. s.Columns.Add(column =>
  251. {
  252. column.Caption = "Mitarbeiter";
  253. column.FieldName = "UserDescription";
  254. column.MinWidth = 245;
  255. column.Width = new Unit(245, UnitType.Pixel);
  256. column.SetDataItemTemplateContent(c =>
  257. {
  258. var userDescriptions = DataBinder.Eval(c.DataItem, "UserDescriptions") as List<string>;
  259. var formattedUserDescription = FormatUserDescriptions(userDescriptions);
  260. html.ViewContext.Writer.Write(formattedUserDescription);
  261. });
  262. });
  263. s.Columns.Add(column =>
  264. {
  265. column.Caption = "Kommentar";
  266. column.FieldName = "Comment";
  267. column.CellStyle.Wrap = DefaultBoolean.True;
  268. column.SetDataItemTemplateContent(c =>
  269. {
  270. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  271. var comment = DataBinder.Eval(c.DataItem, "Comment");
  272. var text = comment == null
  273. ? String.Empty
  274. : comment.ToString();
  275. var isLongText = text.ToString().Length > 40;
  276. if (isLongText)
  277. {
  278. html.ViewContext.Writer.Write(text.Substring(0, 40) + " ...");
  279. html.ViewContext.Writer.Write(
  280. "<a href=\"#\" onclick='showComment(\"site\"," + id + ",this)'><br />Anzeigen</a>");
  281. }
  282. else
  283. html.ViewContext.Writer.Write(text);
  284. if (_userContext.CurrentUser.HasFunction("Site-Sites-Edit-Comment"))
  285. html.ViewContext.Writer.Write(
  286. (isLongText ? "&nbsp;" : "<br/>") +
  287. "<a href=\"#\" onclick='editComment(\"site\"," + id + ",function() { devGridViewSite.PerformCallback(); })'>Bearbeiten</a>");
  288. });
  289. column.MinWidth = 120;
  290. column.Width = new Unit(120, UnitType.Pixel);
  291. });
  292. s.TotalSummary.Add(new ASPxSummaryItem
  293. {
  294. SummaryType = DevExpress.Data.SummaryItemType.Count,
  295. FieldName = "Description",
  296. DisplayFormat = "Anzahl<br/><i>{0:n0}</i>"
  297. });
  298. s.GroupSummary.Add(new ASPxSummaryItem
  299. {
  300. SummaryType = DevExpress.Data.SummaryItemType.Count,
  301. FieldName = "Description",
  302. DisplayFormat = "Anzahl = {0:n0}"
  303. });
  304. s.TotalSummary.Add(new ASPxSummaryItem
  305. {
  306. FieldName = "DeviationValue",
  307. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  308. DisplayFormat = "VA ∑<br/><i>{0:c2}</i>"
  309. });
  310. s.GroupSummary.Add(new ASPxSummaryItem
  311. {
  312. FieldName = "DeviationValue",
  313. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  314. DisplayFormat = "VA ∑ = <i>{0:c2}</i>"
  315. });
  316. s.TotalSummary.Add(new ASPxSummaryItem
  317. {
  318. FieldName = "SiteDeviationValue",
  319. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  320. DisplayFormat = "Off.VA ∑<br/><i>{0:c2}</i>"
  321. });
  322. s.GroupSummary.Add(new ASPxSummaryItem
  323. {
  324. FieldName = "SiteDeviationValue",
  325. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  326. DisplayFormat = "Off.VA ∑ = <i>{0:c2}</i>"
  327. });
  328. s.TotalSummary.Add(new ASPxSummaryItem
  329. {
  330. FieldName = "AppendixValueRemaining",
  331. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  332. DisplayFormat = "Off.NT ∑<br/><i>{0:c2}</i>"
  333. });
  334. s.GroupSummary.Add(new ASPxSummaryItem
  335. {
  336. FieldName = "AppendixValueRemaining",
  337. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  338. DisplayFormat = "Off.NT ∑ = <i>{0:c2}</i>"
  339. });
  340. s.TotalSummary.Add(new ASPxSummaryItem
  341. {
  342. FieldName = "AppendixValueCalculated",
  343. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  344. DisplayFormat = "Bew.NT ∑<br/><i>{0:c2}</i>"
  345. });
  346. s.GroupSummary.Add(new ASPxSummaryItem
  347. {
  348. FieldName = "AppendixValueCalculated",
  349. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  350. DisplayFormat = "Bew.NT ∑ = <i>{0:c2}</i>"
  351. });
  352. s.TotalSummary.Add(new ASPxSummaryItem
  353. {
  354. FieldName = "AppendixValueCleared",
  355. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  356. DisplayFormat = "Pot.NT ∑<br/><i>{0:c2}</i>"
  357. });
  358. s.GroupSummary.Add(new ASPxSummaryItem
  359. {
  360. FieldName = "AppendixValueCleared",
  361. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  362. DisplayFormat = "Pot.NT ∑ = <i>{0:c2}</i>"
  363. });
  364. s.TotalSummary.Add(new ASPxSummaryItem
  365. {
  366. FieldName = "AppendixValueNegotiated",
  367. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  368. DisplayFormat = "Verh.NT ∑<br/><i>{0:c2}</i>"
  369. });
  370. s.GroupSummary.Add(new ASPxSummaryItem
  371. {
  372. FieldName = "AppendixValueNegotiated",
  373. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  374. DisplayFormat = "Verh.NT ∑ = <i>{0:c2}</i>"
  375. });
  376. s.ClientLayout = (sender, e) =>
  377. {
  378. if (e.LayoutMode == ClientLayoutMode.Loading)
  379. {
  380. if (System.Web.HttpContext.Current.Session["SiteGridState"] != null)
  381. e.LayoutData = (string)System.Web.HttpContext.Current.Session["SiteGridState"];
  382. else
  383. {
  384. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("SiteGridLayoutState",
  385. _userContext.CurrentUser.Id);
  386. if (userConfigItem != null)
  387. {
  388. System.Web.HttpContext.Current.Session["SiteGridState"] = userConfigItem.Value;
  389. e.LayoutData = (string)System.Web.HttpContext.Current.Session["SiteGridState"];
  390. }
  391. else
  392. ((MVCxGridView)sender).SortBy(((MVCxGridView)sender).Columns[0], ColumnSortOrder.Ascending);
  393. }
  394. }
  395. else
  396. {
  397. System.Web.HttpContext.Current.Session["SiteGridState"] = e.LayoutData;
  398. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  399. {
  400. UserId = _userContext.CurrentUser.Id,
  401. Name = "SiteGridLayoutState",
  402. Value = e.LayoutData
  403. });
  404. }
  405. };
  406. s.PreRender = s.BeforeGetCallbackResult = (sender, e) => {
  407. MVCxGridView gridView = sender as MVCxGridView;
  408. System.Web.HttpContext.Current.Session["SiteGridViewState"] = new MVCxGridViewState(gridView);
  409. };
  410. s.CustomColumnSort = (sender, e) =>
  411. {
  412. if (e.Column.FieldName != "CustomNumber") return;
  413. int.TryParse(e.GetRow1Value("CustomNumber").ToString(), out int rowVal1);
  414. int.TryParse(e.GetRow2Value("CustomNumber").ToString(), out int rowVal2);
  415. e.Result = (rowVal1).CompareTo(rowVal2);
  416. e.Handled = true;
  417. };
  418. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  419. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  420. s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  421. s.Styles.Footer.CssClass += "devExGridFooterPanel";
  422. s.Styles.GroupRow.CssClass += "devExGridGroupRow";
  423. return s;
  424. }
  425. /// <summary>
  426. /// Creates GridViewSettings for the deviation gridView
  427. /// </summary>
  428. /// <param name="html">Current HtmlHelper context.</param>
  429. public static GridViewSettings DeviationGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  430. {
  431. var s = new GridViewSettings();
  432. s.Name = "devGridViewDeviation";
  433. s.KeyFieldName = "Id";
  434. s.CallbackRouteValues = new { Controller = "Deviation", Action = "PartialDeviations" };
  435. s.Width = Unit.Percentage(99);
  436. s.Settings.ShowHeaderFilterButton = true;
  437. s.Settings.ShowFilterRow = true;
  438. s.Settings.ShowFilterRowMenu = true;
  439. s.Settings.ShowFooter = true;
  440. s.Settings.ShowGroupPanel = true;
  441. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  442. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  443. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  444. s.Settings.VerticalScrollableHeight =
  445. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  446. ? 400
  447. : (int)html.ViewData["ScrollHeight"];
  448. s.SettingsExport.Landscape = true;
  449. s.SettingsExport.FileName = "Vertragsabweichungsliste";
  450. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  451. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  452. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  453. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  454. s.SettingsBehavior.EnableCustomizationWindow = true;
  455. s.SettingsBehavior.AllowHeaderFilter = true;
  456. s.SettingsPager.AlwaysShowPager = true;
  457. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  458. s.SettingsPager.Position = PagerPosition.Bottom;
  459. s.SettingsPager.PageSizeItemSettings.Visible = true;
  460. s.SettingsPager.FirstPageButton.Visible = true;
  461. s.SettingsPager.LastPageButton.Visible = true;
  462. s.SettingsPager.NumericButtonCount = 5;
  463. s.Toolbars.Add(t =>
  464. {
  465. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  466. refreshItem.Text = "Aktualisieren";
  467. var expandItem = t.Items.Add(GridViewToolbarCommand.FullExpand);
  468. expandItem.Text = "Alle aufklappen";
  469. var collapseItem = t.Items.Add(GridViewToolbarCommand.FullCollapse);
  470. collapseItem.Text = "Alle einklappen";
  471. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  472. filterItem.Text = "Filter entfernen";
  473. t.Items.Add(i =>
  474. {
  475. i.Text = "Spalten anzeigen / ausblenden";
  476. i.Name = "ToggleColumnChooser";
  477. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  478. i.BeginGroup = true;
  479. });
  480. t.Items.Add(i =>
  481. {
  482. i.Text = "Drucken";
  483. i.Name = "Print";
  484. i.Image.IconID = IconID.PrintDefaultprinter16x16;
  485. i.BeginGroup = true;
  486. });
  487. t.Items.Add(i =>
  488. {
  489. i.Text = "Zurücksetzen";
  490. i.Name = "ResetSettings";
  491. i.Image.IconID = IconID.ActionsReset16x16;
  492. i.BeginGroup = true;
  493. });
  494. });
  495. s.Columns.Add(column =>
  496. {
  497. column.Caption = "#";
  498. column.FieldName = "CustomNumber";
  499. column.MinWidth = 50;
  500. column.Width = new Unit(60, UnitType.Pixel);
  501. column.Settings.AutoFilterCondition = AutoFilterCondition.Equals;
  502. column.Settings.ShowFilterRowMenu = DefaultBoolean.False;
  503. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  504. column.Settings.SortMode = DevExpress.XtraGrid.ColumnSortMode.Custom;
  505. });
  506. s.Columns.Add(column =>
  507. {
  508. column.Caption = "Bezeichnung";
  509. column.FieldName = "Description";
  510. column.MinWidth = 220;
  511. column.Width = new Unit(250, UnitType.Pixel);
  512. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  513. });
  514. s.Columns.Add(column =>
  515. {
  516. column.Caption = "Baustelle";
  517. column.FieldName = "SiteDescription";
  518. column.MinWidth = 150;
  519. column.Width = new Unit(150, UnitType.Pixel);
  520. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  521. });
  522. s.Columns.Add(column =>
  523. {
  524. column.Caption = "Kst.-Stelle";
  525. column.FieldName = "SiteCustomNumber";
  526. column.MinWidth = 120;
  527. column.Width = new Unit(130, UnitType.Pixel);
  528. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  529. });
  530. s.Columns.Add(column =>
  531. {
  532. column.Caption = "Mitarbeiter";
  533. column.FieldName = "UserDescription";
  534. column.MinWidth = 250;
  535. column.Width = new Unit(250, UnitType.Pixel);
  536. column.SetDataItemTemplateContent(c =>
  537. {
  538. var userDescriptions = DataBinder.Eval(c.DataItem, "UserDescriptions") as List<string>;
  539. var formattedUserDescription = FormatUserDescriptions(userDescriptions);
  540. html.ViewContext.Writer.Write(formattedUserDescription);
  541. });
  542. });
  543. s.Columns.Add(column =>
  544. {
  545. column.Caption = "Nachtrag";
  546. column.FieldName = "AppendixDescription";
  547. column.MinWidth = 100;
  548. column.Width = new Unit(100, UnitType.Pixel);
  549. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  550. });
  551. s.Columns.Add(column =>
  552. {
  553. column.Caption = "Einreichung";
  554. column.FieldName = "ReceiptDate";
  555. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  556. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.DateRangePicker;
  557. column.MinWidth = 110;
  558. column.Width = new Unit(110, UnitType.Pixel);
  559. });
  560. s.Columns.Add(column =>
  561. {
  562. column.Caption = "Tage VA-NT";
  563. column.FieldName = "DaysReceiptToAppendixOffering";
  564. column.MinWidth = 100;
  565. column.Width = new Unit(110, UnitType.Pixel);
  566. column.HeaderStyle.Wrap = DefaultBoolean.True;
  567. });
  568. s.Columns.Add(column =>
  569. {
  570. column.Caption = "Schätzung";
  571. column.FieldName = "Value";
  572. column.PropertiesEdit.DisplayFormatString = "c2";
  573. column.MinWidth = 100;
  574. column.Width = new Unit(120, UnitType.Pixel);
  575. });
  576. s.Columns.Add(column =>
  577. {
  578. column.Caption = "Bewert.";
  579. column.FieldName = "Percentage";
  580. column.PropertiesEdit.DisplayFormatString = "p0";
  581. column.MinWidth = 70;
  582. column.Width = new Unit(80, UnitType.Pixel);
  583. });
  584. s.Columns.Add(column =>
  585. {
  586. column.Caption = "Schätzung bew.";
  587. column.FieldName = "PercentageValue";
  588. column.PropertiesEdit.DisplayFormatString = "c2";
  589. column.MinWidth = 100;
  590. column.Width = new Unit(120, UnitType.Pixel);
  591. column.HeaderStyle.Wrap = DefaultBoolean.True;
  592. });
  593. s.Columns.Add(column =>
  594. {
  595. column.Caption = "Status";
  596. column.FieldName = "StatusDescription";
  597. column.MinWidth = 110;
  598. column.Width = new Unit(120, UnitType.Pixel);
  599. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  600. });
  601. s.Columns.Add(column =>
  602. {
  603. column.Caption = "VA-Kategorien";
  604. column.FieldName = "DisturbanceValuesDescription";
  605. column.MinWidth = 190;
  606. column.Width = new Unit(220, UnitType.Pixel);
  607. column.SetFilterTemplateContent(f =>
  608. {
  609. html.DevExpress().TextBox(t =>
  610. {
  611. t.Name = "devTextBoxFilterDisturbanceValuesDescription";
  612. t.Width = new Unit(100, UnitType.Percentage);
  613. t.Properties.ClientSideEvents.Init =
  614. "function (s, e) { " +
  615. " if (customFilters != null && customFilters['DisturbanceValuesDescription'] != null) {" +
  616. " s.SetText(customFilters['DisturbanceValuesDescription']); }}";
  617. t.Properties.ClientSideEvents.KeyUp =
  618. "function (s, e) { " +
  619. " customFilters['DisturbanceValuesDescription'] = s.GetValue(); " +
  620. " setFilterTimer(customFilterDelay, function () { devGridViewDeviation.PerformCallback(); }); }";
  621. }).Render();
  622. });
  623. column.UnboundType = DevExpress.Data.UnboundColumnType.Decimal;
  624. column.UnboundExpression = "[DisturbanceValueSum]";
  625. });
  626. s.Columns.Add(column =>
  627. {
  628. column.Caption = "Art";
  629. column.FieldName = "KindDescription";
  630. column.MinWidth = 140;
  631. column.Width = new Unit(140, UnitType.Pixel);
  632. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  633. });
  634. s.Columns.Add(column =>
  635. {
  636. column.Caption = "Kommentar";
  637. column.FieldName = "Comment";
  638. column.CellStyle.Wrap = DefaultBoolean.True;
  639. column.SetDataItemTemplateContent(c =>
  640. {
  641. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  642. var comment = DataBinder.Eval(c.DataItem, "Comment");
  643. var text = comment == null
  644. ? String.Empty
  645. : comment.ToString();
  646. var isLongText = text.ToString().Length > 40;
  647. if (isLongText)
  648. {
  649. html.ViewContext.Writer.Write(text.Substring(0, 40) + " ...");
  650. html.ViewContext.Writer.Write(
  651. "<a href=\"#\" onclick='showComment(\"deviation\"," + id + ",this)'><br />Anzeigen</a>");
  652. }
  653. else
  654. html.ViewContext.Writer.Write(text);
  655. if (_userContext.CurrentUser.HasFunction("Deviation-Deviations-Edit-Comment"))
  656. html.ViewContext.Writer.Write(
  657. (isLongText ? "&nbsp;" : "<br/>") +
  658. "&nbsp;<a href=\"#\" onclick='editComment(\"deviation\"," + id + ",function() { devGridViewDeviation.PerformCallback(); })'>Bearbeiten</a>");
  659. });
  660. column.MinWidth = 180;
  661. column.Width = new Unit(180, UnitType.Pixel);
  662. });
  663. //s.SetDataRowTemplateContent(t =>
  664. //{
  665. // var list = t.Grid.DataSource as List<DeviationDataModel>;
  666. // var model = list.First(l => l.Id == (int)t.KeyValue);
  667. // html.RenderPartial("~/Views/Deviations/_DeviationDataRowPartial.cshtml", model, html.ViewData);
  668. //});
  669. var totalDaysReceiptToAppendixOfferingSum = 0;
  670. var totalDaysReceiptToAppendixOfferingCount = 0;
  671. var totalDisturbanceSum = default(decimal);
  672. var totalPercentageValueSumZeroSummarize = default(decimal);
  673. s.CustomSummaryCalculate = (sender, e) =>
  674. {
  675. if (e.SummaryProcess == CustomSummaryProcess.Start)
  676. {
  677. totalDaysReceiptToAppendixOfferingSum = 0;
  678. totalDaysReceiptToAppendixOfferingCount = 0;
  679. totalDisturbanceSum = 0;
  680. totalPercentageValueSumZeroSummarize = 0;
  681. }
  682. if (e.SummaryProcess == CustomSummaryProcess.Calculate)
  683. {
  684. var daysReceiptToAppendixOfferingVal = e.GetValue("DaysReceiptToAppendixOffering");
  685. if (daysReceiptToAppendixOfferingVal != null)
  686. {
  687. totalDaysReceiptToAppendixOfferingCount++;
  688. totalDaysReceiptToAppendixOfferingSum += Convert.ToInt32(daysReceiptToAppendixOfferingVal);
  689. }
  690. var disturbanceVal = e.GetValue("DisturbanceValueSum");
  691. if (disturbanceVal != null)
  692. totalDisturbanceSum += Convert.ToDecimal(disturbanceVal);
  693. var isZeroValueSum = e.GetValue("IsZeroSummarize");
  694. if (isZeroValueSum == null || (isZeroValueSum != null && !Convert.ToBoolean(isZeroValueSum)))
  695. {
  696. var percentageValue = e.GetValue("PercentageValue");
  697. if (percentageValue != null)
  698. totalPercentageValueSumZeroSummarize += (decimal)percentageValue;
  699. }
  700. }
  701. if (e.SummaryProcess == CustomSummaryProcess.Finalize)
  702. {
  703. var summaryItem = (ASPxSummaryItem)e.Item;
  704. if (summaryItem.FieldName == "DaysReceiptToAppendixOffering")
  705. {
  706. if (totalDaysReceiptToAppendixOfferingSum == 0 || totalDaysReceiptToAppendixOfferingCount == 0)
  707. e.TotalValue = 0;
  708. else
  709. e.TotalValue = totalDaysReceiptToAppendixOfferingSum / totalDaysReceiptToAppendixOfferingCount;
  710. }
  711. else if (summaryItem.FieldName == "DisturbanceValuesDescription")
  712. e.TotalValue = totalDisturbanceSum;
  713. else if (summaryItem.FieldName == "StatusDescription")
  714. e.TotalValue = totalPercentageValueSumZeroSummarize;
  715. }
  716. };
  717. s.TotalSummary.Add(new ASPxSummaryItem
  718. {
  719. SummaryType = DevExpress.Data.SummaryItemType.Count,
  720. FieldName = "SiteDescription",
  721. DisplayFormat = "Anzahl<br/><i>{0:n0}</i>"
  722. });
  723. s.GroupSummary.Add(new ASPxSummaryItem
  724. {
  725. SummaryType = DevExpress.Data.SummaryItemType.Count,
  726. FieldName = "SiteDescription",
  727. DisplayFormat = "Anzahl = {0:n0}"
  728. });
  729. s.TotalSummary.Add(new ASPxSummaryItem
  730. {
  731. FieldName = "Value",
  732. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  733. DisplayFormat = "Schätzung ∑<br/><i>{0:c2}</i>"
  734. });
  735. s.GroupSummary.Add(new ASPxSummaryItem
  736. {
  737. FieldName = "Value",
  738. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  739. DisplayFormat = "Schätzung ∑ = <i>{0:c2}</i>"
  740. });
  741. s.TotalSummary.Add(new ASPxSummaryItem
  742. {
  743. FieldName = "Percentage",
  744. SummaryType = DevExpress.Data.SummaryItemType.Average,
  745. DisplayFormat = "Bew. Ø<br/><i>{0:p0}</i>"
  746. });
  747. s.GroupSummary.Add(new ASPxSummaryItem
  748. {
  749. FieldName = "Percentage",
  750. SummaryType = DevExpress.Data.SummaryItemType.Average,
  751. DisplayFormat = "Bew. Ø = <i>{0:p0}</i>"
  752. });
  753. s.TotalSummary.Add(new ASPxSummaryItem
  754. {
  755. FieldName = "PercentageValue",
  756. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  757. DisplayFormat = "Schätz. bew. ∑<br/><i>{0:c2}</i>"
  758. });
  759. s.GroupSummary.Add(new ASPxSummaryItem
  760. {
  761. FieldName = "PercentageValue",
  762. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  763. DisplayFormat = "Schätz. bew. ∑ = <i>{0:c2}</i>"
  764. });
  765. s.TotalSummary.Add(new ASPxSummaryItem
  766. {
  767. FieldName = "StatusDescription",
  768. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  769. DisplayFormat = "Schätz. o. Sta. ∑<br/><i>{0:c2}</i>"
  770. });
  771. s.GroupSummary.Add(new ASPxSummaryItem
  772. {
  773. FieldName = "StatusDescription",
  774. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  775. DisplayFormat = "Schätz. o. Sta. ∑ = <i>{0:c2}</i>"
  776. });
  777. s.TotalSummary.Add(new ASPxSummaryItem
  778. {
  779. FieldName = "DaysReceiptToAppendixOffering",
  780. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  781. DisplayFormat = "T. VA-NT Ø<br/><i>{0:n0}</i>"
  782. });
  783. s.GroupSummary.Add(new ASPxSummaryItem
  784. {
  785. FieldName = "DaysReceiptToAppendixOffering",
  786. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  787. DisplayFormat = "Tage VA-NT Ø = <i>{0:n0}</i>"
  788. });
  789. s.TotalSummary.Add(new ASPxSummaryItem
  790. {
  791. FieldName = "DisturbanceValuesDescription",
  792. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  793. DisplayFormat = "Kat. ∑<br/><i>{0:c2}</i>"
  794. });
  795. s.GroupSummary.Add(new ASPxSummaryItem
  796. {
  797. FieldName = "DisturbanceValuesDescription",
  798. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  799. DisplayFormat = "Kat. ∑ = <i>{0:c2}</i>"
  800. });
  801. s.HtmlRowPrepared = (sender, e) =>
  802. {
  803. var displayColor = e.GetValue("DisplayColor");
  804. if (displayColor != null && e.RowType == GridViewRowType.Data)
  805. e.Row.BackColor = System.Drawing.ColorTranslator.FromHtml(displayColor.ToString());
  806. };
  807. s.ClientLayout = (sender, e) =>
  808. {
  809. if (e.LayoutMode == ClientLayoutMode.Loading)
  810. {
  811. if (System.Web.HttpContext.Current.Session["DeviationGridState"] != null)
  812. e.LayoutData = (string)System.Web.HttpContext.Current.Session["DeviationGridState"];
  813. else
  814. {
  815. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("DeviationGridLayoutState",
  816. _userContext.CurrentUser.Id);
  817. if (userConfigItem != null)
  818. {
  819. System.Web.HttpContext.Current.Session["DeviationGridState"] = userConfigItem.Value;
  820. e.LayoutData = (string)System.Web.HttpContext.Current.Session["DeviationGridState"];
  821. }
  822. else
  823. ((MVCxGridView)sender).SortBy(((MVCxGridView)sender).Columns[0], ColumnSortOrder.Ascending);
  824. }
  825. }
  826. else
  827. {
  828. System.Web.HttpContext.Current.Session["DeviationGridState"] = e.LayoutData;
  829. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  830. {
  831. UserId = _userContext.CurrentUser.Id,
  832. Name = "DeviationGridLayoutState",
  833. Value = e.LayoutData
  834. });
  835. }
  836. };
  837. s.PreRender = s.BeforeGetCallbackResult = (sender, e) => {
  838. MVCxGridView gridView = sender as MVCxGridView;
  839. System.Web.HttpContext.Current.Session["DeviationGridViewState"] = new MVCxGridViewState(gridView);
  840. };
  841. s.CustomColumnSort = (sender, e) =>
  842. {
  843. if (e.Column.FieldName != "CustomNumber") return;
  844. int.TryParse(e.GetRow1Value("CustomNumber").ToString(), out int rowVal1);
  845. int.TryParse(e.GetRow2Value("CustomNumber").ToString(), out int rowVal2);
  846. e.Result = (rowVal1).CompareTo(rowVal2);
  847. e.Handled = true;
  848. };
  849. s.ClientSideEvents.BeginCallback = "function (s, e) { " +
  850. "e.customArgs['scrollHeight'] = [ gridScrollHeight ]; " +
  851. "e.customArgs['customFilters'] = [ JSON.stringify(customFilters) ]; }";
  852. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  853. s.Styles.Footer.CssClass += "devExGridFooterPanel";
  854. s.Styles.GroupRow.CssClass += "devExGridGroupRow";
  855. s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  856. return s;
  857. }
  858. /// <summary>
  859. /// Creates GridViewSettings for the appendix gridView
  860. /// </summary>
  861. /// <param name="html">Current HtmlHelper context.</param>
  862. public static GridViewSettings AppendixGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  863. {
  864. var s = new GridViewSettings();
  865. s.Name = "devGridViewAppendix";
  866. s.KeyFieldName = "Id";
  867. s.CallbackRouteValues = new { Controller = "Appendix", Action = "PartialAppendices" };
  868. s.Width = Unit.Percentage(99);
  869. s.Settings.ShowHeaderFilterButton = true;
  870. s.Settings.ShowFilterRow = true;
  871. s.Settings.ShowFilterRowMenu = true;
  872. s.Settings.ShowFooter = true;
  873. s.Settings.ShowGroupPanel = true;
  874. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  875. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  876. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  877. s.Settings.VerticalScrollableHeight =
  878. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  879. ? 400
  880. : (int)html.ViewData["ScrollHeight"];
  881. s.SettingsExport.Landscape = true;
  882. s.SettingsExport.FileName = "Nachtragsliste";
  883. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  884. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  885. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  886. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  887. s.SettingsBehavior.EnableCustomizationWindow = true;
  888. s.SettingsBehavior.AllowHeaderFilter = true;
  889. s.SettingsPager.AlwaysShowPager = true;
  890. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  891. s.SettingsPager.Position = PagerPosition.Bottom;
  892. s.SettingsPager.PageSizeItemSettings.Visible = true;
  893. s.SettingsPager.FirstPageButton.Visible = true;
  894. s.SettingsPager.LastPageButton.Visible = true;
  895. s.SettingsPager.NumericButtonCount = 5;
  896. s.Toolbars.Add(t =>
  897. {
  898. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  899. refreshItem.Text = "Aktualisieren";
  900. var expandItem = t.Items.Add(GridViewToolbarCommand.FullExpand);
  901. expandItem.Text = "Alle aufklappen";
  902. var collapseItem = t.Items.Add(GridViewToolbarCommand.FullCollapse);
  903. collapseItem.Text = "Alle einklappen";
  904. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  905. filterItem.Text = "Filter entfernen";
  906. t.Items.Add(i =>
  907. {
  908. i.Text = "Spalten anzeigen / ausblenden";
  909. i.Name = "ToggleColumnChooser";
  910. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  911. i.BeginGroup = true;
  912. });
  913. t.Items.Add(i =>
  914. {
  915. i.Text = "Drucken";
  916. i.Name = "Print";
  917. i.Image.IconID = IconID.PrintDefaultprinter16x16;
  918. i.BeginGroup = true;
  919. });
  920. t.Items.Add(i =>
  921. {
  922. i.Text = "Zurücksetzen";
  923. i.Name = "ResetSettings";
  924. i.Image.IconID = IconID.ActionsReset16x16;
  925. i.BeginGroup = true;
  926. });
  927. });
  928. s.Columns.Add(column =>
  929. {
  930. column.Caption = "#";
  931. column.FieldName = "CustomNumber";
  932. column.MinWidth = 80;
  933. column.Width = new Unit(80, UnitType.Pixel);
  934. column.Settings.AutoFilterCondition = AutoFilterCondition.Equals;
  935. column.Settings.ShowFilterRowMenu = DefaultBoolean.False;
  936. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  937. column.Settings.SortMode = DevExpress.XtraGrid.ColumnSortMode.Custom;
  938. });
  939. s.Columns.Add(column =>
  940. {
  941. column.Caption = "Bezeichnung";
  942. column.FieldName = "Description";
  943. column.MinWidth = 200;
  944. column.Width = new Unit(200, UnitType.Pixel);
  945. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  946. column.SetDataItemTemplateContent(c =>
  947. {
  948. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  949. var description = DataBinder.Eval(c.DataItem, "Description");
  950. html.ViewContext.Writer.Write(description +
  951. "<br/><a href=\"#\" onclick='viewAppendix(" + id + ")'>Details anzeigen</a>");
  952. });
  953. });
  954. s.Columns.Add(column =>
  955. {
  956. column.Caption = "Baustelle";
  957. column.FieldName = "SiteDescription";
  958. column.MinWidth = 150;
  959. column.Width = new Unit(150, UnitType.Pixel);
  960. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  961. });
  962. s.Columns.Add(column =>
  963. {
  964. column.Caption = "Kst.-Stelle";
  965. column.FieldName = "SiteCustomNumber";
  966. column.MinWidth = 120;
  967. column.Width = new Unit(120, UnitType.Pixel);
  968. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  969. });
  970. s.Columns.Add(column =>
  971. {
  972. column.Caption = "Mitarbeiter";
  973. column.FieldName = "UserDescription";
  974. column.MinWidth = 245;
  975. column.Width = new Unit(245, UnitType.Pixel);
  976. column.SetDataItemTemplateContent(c =>
  977. {
  978. var userDescriptions = DataBinder.Eval(c.DataItem, "UserDescriptions") as List<string>;
  979. var formattedUserDescription = FormatUserDescriptions(userDescriptions);
  980. html.ViewContext.Writer.Write(formattedUserDescription);
  981. });
  982. });
  983. s.Columns.Add(column =>
  984. {
  985. column.Caption = "Einreichung";
  986. column.FieldName = "OfferingDate";
  987. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  988. column.MinWidth = 100;
  989. column.Width = new Unit(110, UnitType.Pixel);
  990. });
  991. s.Columns.Add(column =>
  992. {
  993. column.Caption = "Angeb. -Summe";
  994. column.FieldName = "OfferingValue";
  995. column.PropertiesEdit.DisplayFormatString = "c2";
  996. column.MinWidth = 100;
  997. column.Width = new Unit(110, UnitType.Pixel);
  998. column.HeaderStyle.Wrap = DefaultBoolean.True;
  999. });
  1000. s.Columns.Add(column =>
  1001. {
  1002. column.Caption = "Bewert.";
  1003. column.FieldName = "Percentage";
  1004. column.PropertiesEdit.DisplayFormatString = "p0";
  1005. column.MinWidth = 70;
  1006. column.Width = new Unit(60, UnitType.Pixel);
  1007. });
  1008. s.Columns.Add(column =>
  1009. {
  1010. column.Caption = "Angebot bew.";
  1011. column.FieldName = "PercentageValue";
  1012. column.PropertiesEdit.DisplayFormatString = "c2";
  1013. column.MinWidth = 100;
  1014. column.Width = new Unit(120, UnitType.Pixel);
  1015. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1016. });
  1017. s.Columns.Add(column =>
  1018. {
  1019. column.Caption = "Verhandlung";
  1020. column.FieldName = "NegotiationDate";
  1021. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1022. column.MinWidth = 100;
  1023. column.Width = new Unit(110, UnitType.Pixel);
  1024. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1025. });
  1026. s.Columns.Add(column =>
  1027. {
  1028. column.Caption = "Tage Einr./Verh.";
  1029. column.FieldName = "OfferingToNegotiationDate";
  1030. column.MinWidth = 80;
  1031. column.Width = new Unit(90, UnitType.Pixel);
  1032. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1033. column.SetDataItemTemplateContent(c =>
  1034. {
  1035. var time = (TimeSpan?)DataBinder.Eval(c.DataItem, "OfferingToNegotiationDate");
  1036. html.ViewContext.Writer.Write(time.HasValue ? time.Value.TotalDays + " Tag(e)" : "");
  1037. });
  1038. });
  1039. s.Columns.Add(column =>
  1040. {
  1041. column.Caption = "Verhand.-Summe";
  1042. column.FieldName = "NegotiationValue";
  1043. column.PropertiesEdit.DisplayFormatString = "c2";
  1044. column.MinWidth = 110;
  1045. column.Width = new Unit(110, UnitType.Pixel);
  1046. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1047. });
  1048. s.Columns.Add(column =>
  1049. {
  1050. column.Caption = "Verh.-Quote";
  1051. column.FieldName = "RelationOfferingToNegotiation";
  1052. column.PropertiesEdit.DisplayFormatString = "p2";
  1053. column.MinWidth = 115;
  1054. column.Width = new Unit(115, UnitType.Pixel);
  1055. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1056. });
  1057. s.Columns.Add(column =>
  1058. {
  1059. column.Caption = "VA";
  1060. column.FieldName = "DeviationDescription";
  1061. column.MinWidth = 80;
  1062. column.Width = new Unit(80, UnitType.Pixel);
  1063. });
  1064. s.Columns.Add(column =>
  1065. {
  1066. column.Caption = "Fak. Ang. zu VA";
  1067. column.FieldName = "RelationOfferingToDeviations";
  1068. column.PropertiesEdit.DisplayFormatString = "n2";
  1069. column.MinWidth = 100;
  1070. column.Width = new Unit(100, UnitType.Pixel);
  1071. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1072. });
  1073. s.Columns.Add(column =>
  1074. {
  1075. column.Caption = "AR gestellt";
  1076. column.FieldName = "OrderInvoiceCreatedDescription";
  1077. column.MinWidth = 60;
  1078. column.Width = new Unit(80, UnitType.Pixel);
  1079. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1080. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1081. column.SetDataItemTemplateContent(c =>
  1082. {
  1083. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  1084. var description = DataBinder.Eval(c.DataItem, "OrderInvoiceCreatedDescription");
  1085. if (_userContext.CurrentUser.HasFunction("Appendix-Appendices-Edit"))
  1086. html.ViewContext.Writer.Write(description +
  1087. "<br/><a href=\"#\" onclick='editOrderInvoiceCreated(" + id + "," +
  1088. " function() { devGridViewAppendix.PerformCallback(); })'>Ändern</a>");
  1089. });
  1090. });
  1091. s.Columns.Add(column =>
  1092. {
  1093. column.Caption = "Status";
  1094. column.FieldName = "StateDescription";
  1095. column.MinWidth = 100;
  1096. column.Width = new Unit(100, UnitType.Pixel);
  1097. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1098. });
  1099. s.Columns.Add(column =>
  1100. {
  1101. column.Caption = "Offen";
  1102. column.FieldName = "IsRemaining";
  1103. column.MinWidth = 40;
  1104. column.Width = new Unit(50, UnitType.Pixel);
  1105. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1106. });
  1107. s.Columns.Add(column =>
  1108. {
  1109. column.Caption = "Bestellsch.-Datum";
  1110. column.FieldName = "OrderDate";
  1111. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1112. column.MinWidth = 110;
  1113. column.Width = new Unit(110, UnitType.Pixel);
  1114. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1115. });
  1116. s.Columns.Add(column =>
  1117. {
  1118. column.Caption = "Bestellsch.-Nummer";
  1119. column.FieldName = "OrderNumber";
  1120. column.MinWidth = 90;
  1121. column.Width = new Unit(110, UnitType.Pixel);
  1122. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1123. });
  1124. s.Columns.Add(column =>
  1125. {
  1126. column.Caption = "NT-Kategorien";
  1127. column.FieldName = "CategoryValuesDescription";
  1128. column.MinWidth = 200;
  1129. column.Width = new Unit(200, UnitType.Pixel);
  1130. });
  1131. s.Columns.Add(column =>
  1132. {
  1133. column.Caption = "Kommentar";
  1134. column.FieldName = "Comment";
  1135. column.CellStyle.Wrap = DefaultBoolean.True;
  1136. column.SetDataItemTemplateContent(c =>
  1137. {
  1138. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  1139. var comment = DataBinder.Eval(c.DataItem, "Comment");
  1140. var text = comment == null
  1141. ? String.Empty
  1142. : comment.ToString();
  1143. var isLongText = text.ToString().Length > 40;
  1144. if (isLongText)
  1145. {
  1146. html.ViewContext.Writer.Write(text.Substring(0, 40) + " ...");
  1147. html.ViewContext.Writer.Write(
  1148. "<a href=\"#\" onclick='showComment(\"appendix\"," + id + ",this)'><br />Anzeigen</a>");
  1149. }
  1150. else
  1151. html.ViewContext.Writer.Write(text);
  1152. if (_userContext.CurrentUser.HasFunction("Deviation-Deviations-Edit-Comment"))
  1153. html.ViewContext.Writer.Write(
  1154. (isLongText ? "&nbsp;" : "<br/>") +
  1155. "<a href=\"#\" onclick='editComment(\"appendix\"," + id + ",function() { devGridViewAppendix.PerformCallback(); })'>Bearbeiten</a>");
  1156. });
  1157. column.MinWidth = 200;
  1158. column.Width = new Unit(200, UnitType.Pixel);
  1159. });
  1160. var totalRelationOfferingToDeviationsSum = (decimal)0;
  1161. var totalRelationOfferingToDeviationsCount = 0;
  1162. var totalPercentageValueSum = (decimal)0;
  1163. var totalNegotiationValueSum = (decimal)0;
  1164. s.CustomSummaryCalculate = (sender, e) =>
  1165. {
  1166. if (e.SummaryProcess == CustomSummaryProcess.Start)
  1167. {
  1168. totalRelationOfferingToDeviationsSum = 0;
  1169. totalRelationOfferingToDeviationsCount = 0;
  1170. totalPercentageValueSum = 0;
  1171. totalNegotiationValueSum = 0;
  1172. }
  1173. if (e.SummaryProcess == CustomSummaryProcess.Calculate)
  1174. {
  1175. var relationOfferingToDeviationsVal = e.GetValue("RelationOfferingToDeviations");
  1176. if (relationOfferingToDeviationsVal != null)
  1177. {
  1178. totalRelationOfferingToDeviationsCount++;
  1179. totalRelationOfferingToDeviationsSum += Convert.ToDecimal(relationOfferingToDeviationsVal);
  1180. }
  1181. var percentageVal = e.GetValue("PercentageValue");
  1182. if (percentageVal != null)
  1183. totalPercentageValueSum += Convert.ToDecimal(percentageVal);
  1184. var negotiationVal = e.GetValue("NegotiationValue");
  1185. if (negotiationVal != null)
  1186. totalNegotiationValueSum += Convert.ToDecimal(negotiationVal);
  1187. }
  1188. if (e.SummaryProcess == CustomSummaryProcess.Finalize)
  1189. {
  1190. var summaryItem = (ASPxSummaryItem)e.Item;
  1191. if (summaryItem.FieldName == "PercentageValue")
  1192. e.TotalValue = totalPercentageValueSum;
  1193. if (summaryItem.FieldName == "NegotiationValue")
  1194. e.TotalValue = totalNegotiationValueSum;
  1195. if (summaryItem.FieldName == "RelationOfferingToDeviations")
  1196. {
  1197. if (totalRelationOfferingToDeviationsSum == 0 || totalRelationOfferingToDeviationsCount == 0)
  1198. e.TotalValue = 0;
  1199. else
  1200. e.TotalValue =
  1201. totalRelationOfferingToDeviationsSum /
  1202. (totalRelationOfferingToDeviationsCount == 0
  1203. ? 1
  1204. : totalRelationOfferingToDeviationsCount);
  1205. }
  1206. if (summaryItem.FieldName == "RelationOfferingToNegotiation")
  1207. e.TotalValue =
  1208. totalNegotiationValueSum /
  1209. (totalPercentageValueSum == 0
  1210. ? 1
  1211. : totalPercentageValueSum);
  1212. }
  1213. };
  1214. s.TotalSummary.Add(new ASPxSummaryItem
  1215. {
  1216. SummaryType = DevExpress.Data.SummaryItemType.Count,
  1217. FieldName = "Description",
  1218. DisplayFormat = "Anzahl<br/><i>{0:n0}</i>"
  1219. });
  1220. s.GroupSummary.Add(new ASPxSummaryItem
  1221. {
  1222. SummaryType = DevExpress.Data.SummaryItemType.Count,
  1223. FieldName = "Description",
  1224. DisplayFormat = "Anzahl = {0:n0}"
  1225. });
  1226. s.TotalSummary.Add(new ASPxSummaryItem
  1227. {
  1228. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  1229. FieldName = "OfferingValue",
  1230. DisplayFormat = "Angeb. ∑<br/><i>{0:c2}</i>"
  1231. });
  1232. s.GroupSummary.Add(new ASPxSummaryItem
  1233. {
  1234. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  1235. FieldName = "OfferingValue",
  1236. DisplayFormat = "Angeb.-∑ = {0:c2}"
  1237. });
  1238. s.TotalSummary.Add(new ASPxSummaryItem
  1239. {
  1240. FieldName = "Percentage",
  1241. SummaryType = DevExpress.Data.SummaryItemType.Average,
  1242. DisplayFormat = "Bew. Ø<br/><i>{0:p0}</i>"
  1243. });
  1244. s.GroupSummary.Add(new ASPxSummaryItem
  1245. {
  1246. FieldName = "Percentage",
  1247. SummaryType = DevExpress.Data.SummaryItemType.Average,
  1248. DisplayFormat = "Bew. Ø = <i>{0:p0}</i>"
  1249. });
  1250. s.TotalSummary.Add(new ASPxSummaryItem
  1251. {
  1252. FieldName = "PercentageValue",
  1253. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1254. DisplayFormat = "Schätz. bew. ∑<br/><i>{0:c2}</i>"
  1255. });
  1256. s.GroupSummary.Add(new ASPxSummaryItem
  1257. {
  1258. FieldName = "PercentageValue",
  1259. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1260. DisplayFormat = "Schätz. bew. ∑ = <i>{0:c2}</i>"
  1261. });
  1262. s.TotalSummary.Add(new ASPxSummaryItem
  1263. {
  1264. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1265. FieldName = "NegotiationValue",
  1266. DisplayFormat = "Verhand. ∑<br/><i>{0:c2}</i>"
  1267. });
  1268. s.GroupSummary.Add(new ASPxSummaryItem
  1269. {
  1270. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1271. FieldName = "NegotiationValue",
  1272. DisplayFormat = "Verhand.-∑ = {0:c2}"
  1273. });
  1274. s.TotalSummary.Add(new ASPxSummaryItem
  1275. {
  1276. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1277. FieldName = "RelationOfferingToNegotiation",
  1278. DisplayFormat = "Verh. Quo. Ø<br/><i>{0:p2}</i>"
  1279. });
  1280. s.GroupSummary.Add(new ASPxSummaryItem
  1281. {
  1282. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1283. FieldName = "RelationOfferingToNegotiation",
  1284. DisplayFormat = "Verh. Quo. Ø = {0:p2}"
  1285. });
  1286. s.TotalSummary.Add(new ASPxSummaryItem
  1287. {
  1288. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1289. FieldName = "RelationOfferingToDeviations",
  1290. DisplayFormat = "Fak. A./VA Ø<br/><i>{0:n2}</i>"
  1291. });
  1292. s.GroupSummary.Add(new ASPxSummaryItem
  1293. {
  1294. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1295. FieldName = "RelationOfferingToDeviations",
  1296. DisplayFormat = "Fak. A./VA Ø = {0:n2}"
  1297. });
  1298. s.HtmlRowPrepared = (sender, e) =>
  1299. {
  1300. var state = e.GetValue("State") as StateDataModel;
  1301. if (e.RowType == GridViewRowType.Data && state != null && !state.IsDefault)
  1302. e.Row.BackColor = System.Drawing.ColorTranslator.FromHtml(state.HexColor);
  1303. };
  1304. s.ClientLayout = (sender, e) =>
  1305. {
  1306. if (e.LayoutMode == ClientLayoutMode.Loading)
  1307. {
  1308. if (System.Web.HttpContext.Current.Session["AppendixGridState"] != null)
  1309. e.LayoutData = (string)System.Web.HttpContext.Current.Session["AppendixGridState"];
  1310. else
  1311. {
  1312. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("AppendixGridLayoutState",
  1313. _userContext.CurrentUser.Id);
  1314. if (userConfigItem != null)
  1315. {
  1316. System.Web.HttpContext.Current.Session["AppendixGridState"] = userConfigItem.Value;
  1317. e.LayoutData = (string)System.Web.HttpContext.Current.Session["AppendixGridState"];
  1318. }
  1319. else
  1320. ((MVCxGridView)sender).SortBy(((MVCxGridView)sender).Columns[0], ColumnSortOrder.Ascending);
  1321. }
  1322. }
  1323. else
  1324. {
  1325. System.Web.HttpContext.Current.Session["AppendixGridState"] = e.LayoutData;
  1326. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  1327. {
  1328. UserId = _userContext.CurrentUser.Id,
  1329. Name = "AppendixGridLayoutState",
  1330. Value = e.LayoutData
  1331. });
  1332. }
  1333. };
  1334. s.PreRender = s.BeforeGetCallbackResult = (sender, e) => {
  1335. MVCxGridView gridView = sender as MVCxGridView;
  1336. System.Web.HttpContext.Current.Session["AppendixGridViewState"] = new MVCxGridViewState(gridView);
  1337. };
  1338. s.CustomColumnSort = (sender, e) =>
  1339. {
  1340. if (e.Column.FieldName != "CustomNumber") return;
  1341. int.TryParse(e.GetRow1Value("CustomNumber").ToString(), out int rowVal1);
  1342. int.TryParse(e.GetRow2Value("CustomNumber").ToString(), out int rowVal2);
  1343. e.Result = (rowVal1).CompareTo(rowVal2);
  1344. e.Handled = true;
  1345. };
  1346. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  1347. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  1348. s.ClientSideEvents.ColumnResized = "function (s, e) { setGridScrollHeight(); }";
  1349. //s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  1350. s.Styles.Footer.CssClass += "devExGridFooterPanel";
  1351. s.Styles.GroupRow.CssClass += "devExGridGroupRow";
  1352. return s;
  1353. }
  1354. /// <summary>
  1355. /// Creates GridViewSettings for the mailNotifications gridView
  1356. /// </summary>
  1357. /// <param name="html">Current HtmlHelper context.</param>
  1358. public static GridViewSettings MailNotificationGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  1359. {
  1360. var s = new GridViewSettings();
  1361. s.Name = "devGridViewMailNotifications";
  1362. s.KeyFieldName = "Id";
  1363. s.CallbackRouteValues = new { Controller = "Misc", Action = "PartialMailNotifications" };
  1364. s.Width = Unit.Percentage(99);
  1365. s.Settings.ShowHeaderFilterButton = true;
  1366. s.Settings.ShowFilterRow = true;
  1367. s.Settings.ShowFilterRowMenu = true;
  1368. s.Settings.ShowFooter = true;
  1369. s.Settings.ShowGroupPanel = true;
  1370. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  1371. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  1372. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  1373. s.Settings.VerticalScrollableHeight =
  1374. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  1375. ? 400
  1376. : (int)html.ViewData["ScrollHeight"];
  1377. s.SettingsExport.Landscape = true;
  1378. s.SettingsExport.FileName = "Benachrichtigungsliste";
  1379. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  1380. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  1381. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  1382. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  1383. s.SettingsBehavior.EnableCustomizationWindow = true;
  1384. s.SettingsBehavior.AllowHeaderFilter = true;
  1385. s.SettingsPager.AlwaysShowPager = true;
  1386. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  1387. s.SettingsPager.Position = PagerPosition.Bottom;
  1388. s.SettingsPager.PageSizeItemSettings.Visible = true;
  1389. s.SettingsPager.FirstPageButton.Visible = true;
  1390. s.SettingsPager.LastPageButton.Visible = true;
  1391. s.SettingsPager.NumericButtonCount = 5;
  1392. s.Toolbars.Add(t =>
  1393. {
  1394. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  1395. refreshItem.Text = "Aktualisieren";
  1396. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  1397. filterItem.Text = "Filter entfernen";
  1398. t.Items.Add(i =>
  1399. {
  1400. i.Text = "Spalten anzeigen / ausblenden";
  1401. i.Name = "ToggleColumnChooser";
  1402. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  1403. i.BeginGroup = true;
  1404. });
  1405. t.Items.Add(i =>
  1406. {
  1407. i.Text = "Zurücksetzen";
  1408. i.Name = "ResetSettings";
  1409. i.Image.IconID = IconID.ActionsReset16x16;
  1410. i.BeginGroup = true;
  1411. });
  1412. });
  1413. if (_userContext.CurrentUser.HasFunction("Misc-MailNotifications-Edit"))
  1414. {
  1415. s.Columns.Add(column =>
  1416. {
  1417. column.Caption = "#";
  1418. column.SetDataItemTemplateContent(c =>
  1419. {
  1420. html.ViewContext.Writer.Write(
  1421. "<a href=\"#\" onclick=\"editMailNotification(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Bearbeiten</a>&nbsp;");
  1422. html.ViewContext.Writer.Write(
  1423. "<a href=\"#\" onclick=\"confirmDelete(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Löschen</a><br />");
  1424. html.ViewContext.Writer.Write(
  1425. "<a href=\"#\" onclick=\"confirmProcess(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Sofort ausführen</a>");
  1426. });
  1427. column.SetHeaderTemplateContent(c =>
  1428. {
  1429. html.ViewContext.Writer.Write(
  1430. "<a href=\"#\" onclick=\"editMailNotification(-1)\">Neu</a>&nbsp;");
  1431. });
  1432. column.Settings.AllowDragDrop = DefaultBoolean.False;
  1433. column.Settings.AllowSort = DefaultBoolean.False;
  1434. column.Width = new Unit(150, UnitType.Pixel);
  1435. });
  1436. }
  1437. s.Columns.Add(column =>
  1438. {
  1439. column.Caption = "Zeitplan";
  1440. column.FieldName = "CronExpressionDescription";
  1441. column.MinWidth = 200;
  1442. column.Width = new Unit(200, UnitType.Pixel);
  1443. });
  1444. s.Columns.Add(column =>
  1445. {
  1446. column.Caption = "Benachrichtigungs-Plugin";
  1447. column.FieldName = "NotificationPluginSystemNameDescription";
  1448. column.MinWidth = 200;
  1449. column.Width = new Unit(280, UnitType.Pixel);
  1450. });
  1451. s.Columns.Add(column =>
  1452. {
  1453. column.Caption = "Benachrichtigungs-Job";
  1454. column.FieldName = "NotificationJobSystemNameDescription";
  1455. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1456. column.MinWidth = 200;
  1457. column.Width = new Unit(280, UnitType.Pixel);
  1458. });
  1459. s.Columns.Add(column =>
  1460. {
  1461. column.Caption = "Mitarbeiter";
  1462. column.FieldName = "UserDescriptions";
  1463. column.MinWidth = 200;
  1464. column.Width = new Unit(250, UnitType.Pixel);
  1465. column.SetDataItemTemplateContent(c =>
  1466. {
  1467. var userDescriptions = DataBinder.Eval(c.DataItem, "UserDescriptions") as List<string>;
  1468. if (userDescriptions != null)
  1469. {
  1470. foreach (var description in userDescriptions)
  1471. {
  1472. var split = description.Split('|');
  1473. if (split.Length > 1)
  1474. html.ViewContext.Writer.Write(
  1475. "<span style=\"float: left\">" + split[0] + "</span>" +
  1476. "<span style=\"float: right\">" + split[1] + "</span><br />");
  1477. else
  1478. html.ViewContext.Writer.Write(
  1479. "<span>" + split[0] + "</span><br />");
  1480. }
  1481. }
  1482. });
  1483. });
  1484. s.Columns.Add(column =>
  1485. {
  1486. column.Caption = "Nächste Ausführung";
  1487. column.FieldName = "NextExecutionTime";
  1488. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1489. column.MinWidth = 150;
  1490. column.Width = new Unit(200, UnitType.Pixel);
  1491. });
  1492. s.ClientLayout = (sender, e) =>
  1493. {
  1494. if (e.LayoutMode == ClientLayoutMode.Loading)
  1495. {
  1496. if (System.Web.HttpContext.Current.Session["MailNotificationsGridState"] != null)
  1497. e.LayoutData = (string)System.Web.HttpContext.Current.Session["MailNotificationsGridState"];
  1498. else
  1499. {
  1500. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("MailNotificationsGridLayoutState",
  1501. _userContext.CurrentUser.Id);
  1502. if (userConfigItem != null)
  1503. {
  1504. System.Web.HttpContext.Current.Session["MailNotificationsGridState"] = userConfigItem.Value;
  1505. e.LayoutData = (string)System.Web.HttpContext.Current.Session["MailNotificationsGridState"];
  1506. }
  1507. }
  1508. }
  1509. else
  1510. {
  1511. System.Web.HttpContext.Current.Session["MailNotificationsGridState"] = e.LayoutData;
  1512. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  1513. {
  1514. UserId = _userContext.CurrentUser.Id,
  1515. Name = "MailNotificationsGridLayoutState",
  1516. Value = e.LayoutData
  1517. });
  1518. }
  1519. };
  1520. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  1521. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  1522. s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  1523. return s;
  1524. }
  1525. /// <summary>
  1526. /// Creates GridViewSettings for the logs gridView
  1527. /// </summary>
  1528. /// <param name="html">Current HtmlHelper context.</param>
  1529. public static GridViewSettings LogGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  1530. {
  1531. var s = new GridViewSettings();
  1532. s.Name = "devGridViewLog";
  1533. s.KeyFieldName = "Id";
  1534. s.CallbackRouteValues = new { Controller = "Misc", Action = "PartialLogs" };
  1535. s.Width = Unit.Percentage(99);
  1536. s.Settings.ShowHeaderFilterButton = true;
  1537. s.Settings.ShowFilterRow = true;
  1538. s.Settings.ShowFilterRowMenu = true;
  1539. s.Settings.ShowFooter = true;
  1540. s.Settings.ShowGroupPanel = true;
  1541. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  1542. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  1543. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  1544. s.Settings.VerticalScrollableHeight =
  1545. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  1546. ? 400
  1547. : (int)html.ViewData["ScrollHeight"];
  1548. s.SettingsExport.Landscape = true;
  1549. s.SettingsExport.FileName = "Logliste";
  1550. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  1551. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  1552. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  1553. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  1554. s.SettingsBehavior.EnableCustomizationWindow = true;
  1555. s.SettingsBehavior.AllowHeaderFilter = true;
  1556. s.SettingsPager.AlwaysShowPager = true;
  1557. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  1558. s.SettingsPager.Position = PagerPosition.Bottom;
  1559. s.SettingsPager.PageSizeItemSettings.Visible = true;
  1560. s.SettingsPager.FirstPageButton.Visible = true;
  1561. s.SettingsPager.LastPageButton.Visible = true;
  1562. s.SettingsPager.NumericButtonCount = 5;
  1563. s.Toolbars.Add(t =>
  1564. {
  1565. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  1566. refreshItem.Text = "Aktualisieren";
  1567. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  1568. filterItem.Text = "Filter entfernen";
  1569. t.Items.Add(i =>
  1570. {
  1571. i.Text = "Spalten anzeigen / ausblenden";
  1572. i.Name = "ToggleColumnChooser";
  1573. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  1574. i.BeginGroup = true;
  1575. });
  1576. t.Items.Add(i =>
  1577. {
  1578. i.Text = "Drucken";
  1579. i.Name = "Print";
  1580. i.Image.IconID = IconID.PrintDefaultprinter16x16;
  1581. i.BeginGroup = true;
  1582. });
  1583. t.Items.Add(i =>
  1584. {
  1585. i.Text = "Zurücksetzen";
  1586. i.Name = "ResetSettings";
  1587. i.Image.IconID = IconID.ActionsReset16x16;
  1588. i.BeginGroup = true;
  1589. });
  1590. });
  1591. s.Columns.Add(column =>
  1592. {
  1593. column.Caption = "#";
  1594. column.SetDataItemTemplateContent(c =>
  1595. {
  1596. html.ViewContext.Writer.Write(
  1597. "<a href=\"#\" onclick=\"viewLog(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Betrachten</a>&nbsp;");
  1598. if (_userContext.CurrentUser.HasFunction("Misc-Logs-Delete"))
  1599. {
  1600. html.ViewContext.Writer.Write(
  1601. "<a href=\"#\" onclick=\"deleteLog(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Löschen</a><br />");
  1602. }
  1603. });
  1604. column.Settings.AllowDragDrop = DefaultBoolean.False;
  1605. column.Settings.AllowSort = DefaultBoolean.False;
  1606. column.MinWidth = 130;
  1607. column.Width = new Unit(160, UnitType.Pixel);
  1608. });
  1609. s.Columns.Add(column =>
  1610. {
  1611. column.Caption = "Level";
  1612. column.FieldName = "LogLevelDescription";
  1613. column.MinWidth = 100;
  1614. column.Width = new Unit(100, UnitType.Pixel);
  1615. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1616. });
  1617. s.Columns.Add(column =>
  1618. {
  1619. column.Caption = "Betreff";
  1620. column.FieldName = "ShortMessage";
  1621. column.MinWidth = 200;
  1622. column.Width = new Unit(220, UnitType.Pixel);
  1623. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1624. });
  1625. s.Columns.Add(column =>
  1626. {
  1627. column.Caption = "Nachricht";
  1628. column.FieldName = "FullMessage";
  1629. column.MinWidth = 200;
  1630. column.Width = new Unit(250, UnitType.Pixel);
  1631. column.SetDataItemTemplateContent(c =>
  1632. {
  1633. var fullMessage = DataBinder.Eval(c.DataItem, "FullMessage");
  1634. var text = fullMessage == null
  1635. ? String.Empty
  1636. : fullMessage.ToString();
  1637. if (text.ToString().Length > 80)
  1638. html.ViewContext.Writer.Write(text.Substring(0, 80) + " ...");
  1639. else
  1640. html.ViewContext.Writer.Write(text);
  1641. });
  1642. });
  1643. s.Columns.Add(column =>
  1644. {
  1645. column.Caption = "IP-Adresse";
  1646. column.FieldName = "IpAddress";
  1647. column.MinWidth = 130;
  1648. column.Width = new Unit(130, UnitType.Pixel);
  1649. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1650. });
  1651. s.Columns.Add(column =>
  1652. {
  1653. column.Caption = "Mitarbeiter";
  1654. column.FieldName = "UserDescription";
  1655. column.MinWidth = 130;
  1656. column.Width = new Unit(160, UnitType.Pixel);
  1657. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1658. });
  1659. s.Columns.Add(column =>
  1660. {
  1661. column.Caption = "Datentyp";
  1662. column.FieldName = "EntityType";
  1663. column.MinWidth = 100;
  1664. column.Width = new Unit(130, UnitType.Pixel);
  1665. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1666. });
  1667. s.Columns.Add(column =>
  1668. {
  1669. column.Caption = "Daten ID";
  1670. column.FieldName = "EntityId";
  1671. column.MinWidth = 100;
  1672. column.Width = new Unit(100, UnitType.Pixel);
  1673. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1674. });
  1675. s.Columns.Add(column =>
  1676. {
  1677. column.Caption = "Seiten URL";
  1678. column.FieldName = "PageUrl";
  1679. column.MinWidth = 150;
  1680. column.Width = new Unit(150, UnitType.Pixel);
  1681. column.Visible = false;
  1682. });
  1683. s.Columns.Add(column =>
  1684. {
  1685. column.Caption = "Relative URL";
  1686. column.FieldName = "ReferrerUrl";
  1687. column.MinWidth = 100;
  1688. column.Width = new Unit(100, UnitType.Pixel);
  1689. column.Visible = false;
  1690. });
  1691. s.Columns.Add(column =>
  1692. {
  1693. column.Caption = "Zeitpunkt";
  1694. column.FieldName = "CreatedOnLocal";
  1695. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy - HH:mm:ss";
  1696. column.MinWidth = 150;
  1697. column.Width = new Unit(160, UnitType.Pixel);
  1698. });
  1699. s.ClientLayout = (sender, e) =>
  1700. {
  1701. if (e.LayoutMode == ClientLayoutMode.Loading)
  1702. {
  1703. if (System.Web.HttpContext.Current.Session["LogGridState"] != null)
  1704. e.LayoutData = (string)System.Web.HttpContext.Current.Session["LogGridState"];
  1705. else
  1706. {
  1707. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("LogGridLayoutState",
  1708. _userContext.CurrentUser.Id);
  1709. if (userConfigItem != null)
  1710. {
  1711. System.Web.HttpContext.Current.Session["LogGridState"] = userConfigItem.Value;
  1712. e.LayoutData = (string)System.Web.HttpContext.Current.Session["LogGridState"];
  1713. }
  1714. }
  1715. }
  1716. else
  1717. {
  1718. System.Web.HttpContext.Current.Session["LogGridState"] = e.LayoutData;
  1719. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  1720. {
  1721. UserId = _userContext.CurrentUser.Id,
  1722. Name = "LogGridLayoutState",
  1723. Value = e.LayoutData
  1724. });
  1725. }
  1726. };
  1727. s.PreRender = s.BeforeGetCallbackResult = (sender, e) => {
  1728. MVCxGridView gridView = sender as MVCxGridView;
  1729. System.Web.HttpContext.Current.Session["LogGridViewState"] = new MVCxGridViewState(gridView);
  1730. };
  1731. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  1732. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  1733. s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  1734. return s;
  1735. }
  1736. /// <summary>
  1737. /// Formats the UserDescriptions to single string format
  1738. /// </summary>
  1739. /// <param name="userDescriptions">The UserDescription (Name and Role).</param>
  1740. private static string FormatUserDescriptions(List<string> userDescriptions)
  1741. {
  1742. if (userDescriptions == null) return null;
  1743. var result = String.Empty;
  1744. var counter = 0;
  1745. foreach (var description in userDescriptions)
  1746. {
  1747. if (counter > 1)
  1748. {
  1749. var remainingDescriptions =
  1750. String.Join(
  1751. ", ",
  1752. userDescriptions
  1753. .Skip(2)
  1754. .Take(userDescriptions.Count - 2)
  1755. .Select(u => u.Split('|').Length > 1
  1756. ? String.Format("{0} {1}", u.Split('|')[0], u.Split('|')[1])
  1757. : String.Format("{0}", u.Split('|')[0])));
  1758. result += "<a href='#' title='" + remainingDescriptions + "'>...</a>";
  1759. break;
  1760. }
  1761. else
  1762. {
  1763. var split = description.Split('|');
  1764. if (split.Length > 1)
  1765. result +=
  1766. "<span style=\"float: left\">" + split[0] + "</span>" +
  1767. "<span style=\"float: right\">" + split[1] + "</span><br />";
  1768. else
  1769. result +=
  1770. "<span>" + split[0] + "</span><br />";
  1771. }
  1772. counter++;
  1773. }
  1774. return result;
  1775. }
  1776. }
  1777. }