GridViewSettingsHelper.cs 79 KB

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