GridViewSettingsHelper.cs 85 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925
  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 = "Verhand.-Summe";
  1029. column.FieldName = "NegotiationValue";
  1030. column.PropertiesEdit.DisplayFormatString = "c2";
  1031. column.MinWidth = 110;
  1032. column.Width = new Unit(110, UnitType.Pixel);
  1033. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1034. });
  1035. s.Columns.Add(column =>
  1036. {
  1037. column.Caption = "Verh.-Quote";
  1038. column.FieldName = "RelationOfferingToNegotiation";
  1039. column.PropertiesEdit.DisplayFormatString = "p2";
  1040. column.MinWidth = 115;
  1041. column.Width = new Unit(115, UnitType.Pixel);
  1042. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1043. });
  1044. s.Columns.Add(column =>
  1045. {
  1046. column.Caption = "VA";
  1047. column.FieldName = "DeviationDescription";
  1048. column.MinWidth = 80;
  1049. column.Width = new Unit(80, UnitType.Pixel);
  1050. });
  1051. s.Columns.Add(column =>
  1052. {
  1053. column.Caption = "Fak. Ang. zu VA";
  1054. column.FieldName = "RelationOfferingToDeviations";
  1055. column.PropertiesEdit.DisplayFormatString = "n2";
  1056. column.MinWidth = 100;
  1057. column.Width = new Unit(100, UnitType.Pixel);
  1058. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1059. });
  1060. s.Columns.Add(column =>
  1061. {
  1062. column.Caption = "AR gestellt";
  1063. column.FieldName = "OrderInvoiceCreatedDescription";
  1064. column.MinWidth = 60;
  1065. column.Width = new Unit(80, UnitType.Pixel);
  1066. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1067. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1068. column.SetDataItemTemplateContent(c =>
  1069. {
  1070. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  1071. var description = DataBinder.Eval(c.DataItem, "OrderInvoiceCreatedDescription");
  1072. if (_userContext.CurrentUser.HasFunction("Appendix-Appendices-Edit"))
  1073. html.ViewContext.Writer.Write(description +
  1074. "<br/><a href=\"#\" onclick='editOrderInvoiceCreated(" + id + "," +
  1075. " function() { devGridViewAppendix.PerformCallback(); })'>Ändern</a>");
  1076. });
  1077. });
  1078. s.Columns.Add(column =>
  1079. {
  1080. column.Caption = "Status";
  1081. column.FieldName = "StateDescription";
  1082. column.MinWidth = 100;
  1083. column.Width = new Unit(100, UnitType.Pixel);
  1084. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1085. });
  1086. s.Columns.Add(column =>
  1087. {
  1088. column.Caption = "Offen";
  1089. column.FieldName = "IsRemaining";
  1090. column.MinWidth = 40;
  1091. column.Width = new Unit(50, UnitType.Pixel);
  1092. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1093. });
  1094. s.Columns.Add(column =>
  1095. {
  1096. column.Caption = "Bestellsch.-Datum";
  1097. column.FieldName = "OrderDate";
  1098. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1099. column.MinWidth = 110;
  1100. column.Width = new Unit(110, UnitType.Pixel);
  1101. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1102. });
  1103. s.Columns.Add(column =>
  1104. {
  1105. column.Caption = "Bestellsch.-Nummer";
  1106. column.FieldName = "OrderNumber";
  1107. column.MinWidth = 90;
  1108. column.Width = new Unit(110, UnitType.Pixel);
  1109. column.HeaderStyle.Wrap = DefaultBoolean.True;
  1110. });
  1111. s.Columns.Add(column =>
  1112. {
  1113. column.Caption = "NT-Kategorien";
  1114. column.FieldName = "CategoryValuesDescription";
  1115. column.MinWidth = 200;
  1116. column.Width = new Unit(200, UnitType.Pixel);
  1117. });
  1118. s.Columns.Add(column =>
  1119. {
  1120. column.Caption = "Kommentar";
  1121. column.FieldName = "Comment";
  1122. column.CellStyle.Wrap = DefaultBoolean.True;
  1123. column.SetDataItemTemplateContent(c =>
  1124. {
  1125. var id = Convert.ToInt32(DataBinder.Eval(c.DataItem, "Id"));
  1126. var comment = DataBinder.Eval(c.DataItem, "Comment");
  1127. var text = comment == null
  1128. ? String.Empty
  1129. : comment.ToString();
  1130. var isLongText = text.ToString().Length > 40;
  1131. if (isLongText)
  1132. {
  1133. html.ViewContext.Writer.Write(text.Substring(0, 40) + " ...");
  1134. html.ViewContext.Writer.Write(
  1135. "<a href=\"#\" onclick='showComment(\"appendix\"," + id + ",this)'><br />Anzeigen</a>");
  1136. }
  1137. else
  1138. html.ViewContext.Writer.Write(text);
  1139. if (_userContext.CurrentUser.HasFunction("Deviation-Deviations-Edit-Comment"))
  1140. html.ViewContext.Writer.Write(
  1141. (isLongText ? "&nbsp;" : "<br/>") +
  1142. "<a href=\"#\" onclick='editComment(\"appendix\"," + id + ",function() { devGridViewAppendix.PerformCallback(); })'>Bearbeiten</a>");
  1143. });
  1144. column.MinWidth = 200;
  1145. column.Width = new Unit(200, UnitType.Pixel);
  1146. });
  1147. var totalRelationOfferingToDeviationsSum = (decimal)0;
  1148. var totalRelationOfferingToDeviationsCount = 0;
  1149. var totalPercentageValueSum = (decimal)0;
  1150. var totalNegotiationValueSum = (decimal)0;
  1151. s.CustomSummaryCalculate = (sender, e) =>
  1152. {
  1153. if (e.SummaryProcess == CustomSummaryProcess.Start)
  1154. {
  1155. totalRelationOfferingToDeviationsSum = 0;
  1156. totalRelationOfferingToDeviationsCount = 0;
  1157. totalPercentageValueSum = 0;
  1158. totalNegotiationValueSum = 0;
  1159. }
  1160. if (e.SummaryProcess == CustomSummaryProcess.Calculate)
  1161. {
  1162. var relationOfferingToDeviationsVal = e.GetValue("RelationOfferingToDeviations");
  1163. if (relationOfferingToDeviationsVal != null)
  1164. {
  1165. totalRelationOfferingToDeviationsCount++;
  1166. totalRelationOfferingToDeviationsSum += Convert.ToDecimal(relationOfferingToDeviationsVal);
  1167. }
  1168. var percentageVal = e.GetValue("PercentageValue");
  1169. if (percentageVal != null)
  1170. totalPercentageValueSum += Convert.ToDecimal(percentageVal);
  1171. var negotiationVal = e.GetValue("NegotiationValue");
  1172. if (negotiationVal != null)
  1173. totalNegotiationValueSum += Convert.ToDecimal(negotiationVal);
  1174. }
  1175. if (e.SummaryProcess == CustomSummaryProcess.Finalize)
  1176. {
  1177. var summaryItem = (ASPxSummaryItem)e.Item;
  1178. if (summaryItem.FieldName == "PercentageValue")
  1179. e.TotalValue = totalPercentageValueSum;
  1180. if (summaryItem.FieldName == "NegotiationValue")
  1181. e.TotalValue = totalNegotiationValueSum;
  1182. if (summaryItem.FieldName == "RelationOfferingToDeviations")
  1183. {
  1184. if (totalRelationOfferingToDeviationsSum == 0 || totalRelationOfferingToDeviationsCount == 0)
  1185. e.TotalValue = 0;
  1186. else
  1187. e.TotalValue =
  1188. totalRelationOfferingToDeviationsSum /
  1189. (totalRelationOfferingToDeviationsCount == 0
  1190. ? 1
  1191. : totalRelationOfferingToDeviationsCount);
  1192. }
  1193. if (summaryItem.FieldName == "RelationOfferingToNegotiation")
  1194. e.TotalValue =
  1195. totalNegotiationValueSum /
  1196. (totalPercentageValueSum == 0
  1197. ? 1
  1198. : totalPercentageValueSum);
  1199. }
  1200. };
  1201. s.TotalSummary.Add(new ASPxSummaryItem
  1202. {
  1203. SummaryType = DevExpress.Data.SummaryItemType.Count,
  1204. FieldName = "Description",
  1205. DisplayFormat = "Anzahl<br/><i>{0:n0}</i>"
  1206. });
  1207. s.GroupSummary.Add(new ASPxSummaryItem
  1208. {
  1209. SummaryType = DevExpress.Data.SummaryItemType.Count,
  1210. FieldName = "Description",
  1211. DisplayFormat = "Anzahl = {0:n0}"
  1212. });
  1213. s.TotalSummary.Add(new ASPxSummaryItem
  1214. {
  1215. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  1216. FieldName = "OfferingValue",
  1217. DisplayFormat = "Angeb. ∑<br/><i>{0:c2}</i>"
  1218. });
  1219. s.GroupSummary.Add(new ASPxSummaryItem
  1220. {
  1221. SummaryType = DevExpress.Data.SummaryItemType.Sum,
  1222. FieldName = "OfferingValue",
  1223. DisplayFormat = "Angeb.-∑ = {0:c2}"
  1224. });
  1225. s.TotalSummary.Add(new ASPxSummaryItem
  1226. {
  1227. FieldName = "Percentage",
  1228. SummaryType = DevExpress.Data.SummaryItemType.Average,
  1229. DisplayFormat = "Bew. Ø<br/><i>{0:p0}</i>"
  1230. });
  1231. s.GroupSummary.Add(new ASPxSummaryItem
  1232. {
  1233. FieldName = "Percentage",
  1234. SummaryType = DevExpress.Data.SummaryItemType.Average,
  1235. DisplayFormat = "Bew. Ø = <i>{0:p0}</i>"
  1236. });
  1237. s.TotalSummary.Add(new ASPxSummaryItem
  1238. {
  1239. FieldName = "PercentageValue",
  1240. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1241. DisplayFormat = "Schätz. bew. ∑<br/><i>{0:c2}</i>"
  1242. });
  1243. s.GroupSummary.Add(new ASPxSummaryItem
  1244. {
  1245. FieldName = "PercentageValue",
  1246. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1247. DisplayFormat = "Schätz. bew. ∑ = <i>{0:c2}</i>"
  1248. });
  1249. s.TotalSummary.Add(new ASPxSummaryItem
  1250. {
  1251. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1252. FieldName = "NegotiationValue",
  1253. DisplayFormat = "Verhand. ∑<br/><i>{0:c2}</i>"
  1254. });
  1255. s.GroupSummary.Add(new ASPxSummaryItem
  1256. {
  1257. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1258. FieldName = "NegotiationValue",
  1259. DisplayFormat = "Verhand.-∑ = {0:c2}"
  1260. });
  1261. s.TotalSummary.Add(new ASPxSummaryItem
  1262. {
  1263. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1264. FieldName = "RelationOfferingToNegotiation",
  1265. DisplayFormat = "Verh. Quo. Ø<br/><i>{0:p2}</i>"
  1266. });
  1267. s.GroupSummary.Add(new ASPxSummaryItem
  1268. {
  1269. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1270. FieldName = "RelationOfferingToNegotiation",
  1271. DisplayFormat = "Verh. Quo. Ø = {0:p2}"
  1272. });
  1273. s.TotalSummary.Add(new ASPxSummaryItem
  1274. {
  1275. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1276. FieldName = "RelationOfferingToDeviations",
  1277. DisplayFormat = "Fak. A./VA Ø<br/><i>{0:n2}</i>"
  1278. });
  1279. s.GroupSummary.Add(new ASPxSummaryItem
  1280. {
  1281. SummaryType = DevExpress.Data.SummaryItemType.Custom,
  1282. FieldName = "RelationOfferingToDeviations",
  1283. DisplayFormat = "Fak. A./VA Ø = {0:n2}"
  1284. });
  1285. s.HtmlRowPrepared = (sender, e) =>
  1286. {
  1287. var state = e.GetValue("State") as StateDataModel;
  1288. if (e.RowType == GridViewRowType.Data && state != null && !state.IsDefault)
  1289. e.Row.BackColor = System.Drawing.ColorTranslator.FromHtml(state.HexColor);
  1290. };
  1291. s.ClientLayout = (sender, e) =>
  1292. {
  1293. if (e.LayoutMode == ClientLayoutMode.Loading)
  1294. {
  1295. if (System.Web.HttpContext.Current.Session["AppendixGridState"] != null)
  1296. e.LayoutData = (string)System.Web.HttpContext.Current.Session["AppendixGridState"];
  1297. else
  1298. {
  1299. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("AppendixGridLayoutState",
  1300. _userContext.CurrentUser.Id);
  1301. if (userConfigItem != null)
  1302. {
  1303. System.Web.HttpContext.Current.Session["AppendixGridState"] = userConfigItem.Value;
  1304. e.LayoutData = (string)System.Web.HttpContext.Current.Session["AppendixGridState"];
  1305. }
  1306. else
  1307. ((MVCxGridView)sender).SortBy(((MVCxGridView)sender).Columns[0], ColumnSortOrder.Ascending);
  1308. }
  1309. }
  1310. else
  1311. {
  1312. System.Web.HttpContext.Current.Session["AppendixGridState"] = e.LayoutData;
  1313. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  1314. {
  1315. UserId = _userContext.CurrentUser.Id,
  1316. Name = "AppendixGridLayoutState",
  1317. Value = e.LayoutData
  1318. });
  1319. }
  1320. };
  1321. s.PreRender = s.BeforeGetCallbackResult = (sender, e) => {
  1322. MVCxGridView gridView = sender as MVCxGridView;
  1323. System.Web.HttpContext.Current.Session["AppendixGridViewState"] = new MVCxGridViewState(gridView);
  1324. };
  1325. s.CustomColumnSort = (sender, e) =>
  1326. {
  1327. if (e.Column.FieldName != "CustomNumber") return;
  1328. int.TryParse(e.GetRow1Value("CustomNumber").ToString(), out int rowVal1);
  1329. int.TryParse(e.GetRow2Value("CustomNumber").ToString(), out int rowVal2);
  1330. e.Result = (rowVal1).CompareTo(rowVal2);
  1331. e.Handled = true;
  1332. };
  1333. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  1334. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  1335. s.ClientSideEvents.ColumnResized = "function (s, e) { setGridScrollHeight(); }";
  1336. //s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  1337. s.Styles.Footer.CssClass += "devExGridFooterPanel";
  1338. s.Styles.GroupRow.CssClass += "devExGridGroupRow";
  1339. return s;
  1340. }
  1341. /// <summary>
  1342. /// Creates GridViewSettings for the mailNotifications gridView
  1343. /// </summary>
  1344. /// <param name="html">Current HtmlHelper context.</param>
  1345. public static GridViewSettings MailNotificationGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  1346. {
  1347. var s = new GridViewSettings();
  1348. s.Name = "devGridViewMailNotifications";
  1349. s.KeyFieldName = "Id";
  1350. s.CallbackRouteValues = new { Controller = "Misc", Action = "PartialMailNotifications" };
  1351. s.Width = Unit.Percentage(99);
  1352. s.Settings.ShowHeaderFilterButton = true;
  1353. s.Settings.ShowFilterRow = true;
  1354. s.Settings.ShowFilterRowMenu = true;
  1355. s.Settings.ShowFooter = true;
  1356. s.Settings.ShowGroupPanel = true;
  1357. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  1358. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  1359. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  1360. s.Settings.VerticalScrollableHeight =
  1361. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  1362. ? 400
  1363. : (int)html.ViewData["ScrollHeight"];
  1364. s.SettingsExport.Landscape = true;
  1365. s.SettingsExport.FileName = "Benachrichtigungsliste";
  1366. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  1367. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  1368. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  1369. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  1370. s.SettingsBehavior.EnableCustomizationWindow = true;
  1371. s.SettingsBehavior.AllowHeaderFilter = true;
  1372. s.SettingsPager.AlwaysShowPager = true;
  1373. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  1374. s.SettingsPager.Position = PagerPosition.Bottom;
  1375. s.SettingsPager.PageSizeItemSettings.Visible = true;
  1376. s.SettingsPager.FirstPageButton.Visible = true;
  1377. s.SettingsPager.LastPageButton.Visible = true;
  1378. s.SettingsPager.NumericButtonCount = 5;
  1379. s.Toolbars.Add(t =>
  1380. {
  1381. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  1382. refreshItem.Text = "Aktualisieren";
  1383. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  1384. filterItem.Text = "Filter entfernen";
  1385. t.Items.Add(i =>
  1386. {
  1387. i.Text = "Spalten anzeigen / ausblenden";
  1388. i.Name = "ToggleColumnChooser";
  1389. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  1390. i.BeginGroup = true;
  1391. });
  1392. t.Items.Add(i =>
  1393. {
  1394. i.Text = "Zurücksetzen";
  1395. i.Name = "ResetSettings";
  1396. i.Image.IconID = IconID.ActionsReset16x16;
  1397. i.BeginGroup = true;
  1398. });
  1399. });
  1400. if (_userContext.CurrentUser.HasFunction("Misc-MailNotifications-Edit"))
  1401. {
  1402. s.Columns.Add(column =>
  1403. {
  1404. column.Caption = "#";
  1405. column.SetDataItemTemplateContent(c =>
  1406. {
  1407. html.ViewContext.Writer.Write(
  1408. "<a href=\"#\" onclick=\"editMailNotification(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Bearbeiten</a>&nbsp;");
  1409. html.ViewContext.Writer.Write(
  1410. "<a href=\"#\" onclick=\"confirmDelete(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Löschen</a><br />");
  1411. html.ViewContext.Writer.Write(
  1412. "<a href=\"#\" onclick=\"confirmProcess(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Sofort ausführen</a>");
  1413. });
  1414. column.SetHeaderTemplateContent(c =>
  1415. {
  1416. html.ViewContext.Writer.Write(
  1417. "<a href=\"#\" onclick=\"editMailNotification(-1)\">Neu</a>&nbsp;");
  1418. });
  1419. column.Settings.AllowDragDrop = DefaultBoolean.False;
  1420. column.Settings.AllowSort = DefaultBoolean.False;
  1421. column.Width = new Unit(150, UnitType.Pixel);
  1422. });
  1423. }
  1424. s.Columns.Add(column =>
  1425. {
  1426. column.Caption = "Zeitplan";
  1427. column.FieldName = "CronExpressionDescription";
  1428. column.MinWidth = 200;
  1429. column.Width = new Unit(200, UnitType.Pixel);
  1430. });
  1431. s.Columns.Add(column =>
  1432. {
  1433. column.Caption = "Benachrichtigungs-Plugin";
  1434. column.FieldName = "NotificationPluginSystemNameDescription";
  1435. column.MinWidth = 200;
  1436. column.Width = new Unit(280, UnitType.Pixel);
  1437. });
  1438. s.Columns.Add(column =>
  1439. {
  1440. column.Caption = "Benachrichtigungs-Job";
  1441. column.FieldName = "NotificationJobSystemNameDescription";
  1442. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1443. column.MinWidth = 200;
  1444. column.Width = new Unit(280, UnitType.Pixel);
  1445. });
  1446. s.Columns.Add(column =>
  1447. {
  1448. column.Caption = "Mitarbeiter";
  1449. column.FieldName = "UserDescriptions";
  1450. column.MinWidth = 200;
  1451. column.Width = new Unit(250, UnitType.Pixel);
  1452. column.SetDataItemTemplateContent(c =>
  1453. {
  1454. var userDescriptions = DataBinder.Eval(c.DataItem, "UserDescriptions") as List<string>;
  1455. if (userDescriptions != null)
  1456. {
  1457. foreach (var description in userDescriptions)
  1458. {
  1459. var split = description.Split('|');
  1460. if (split.Length > 1)
  1461. html.ViewContext.Writer.Write(
  1462. "<span style=\"float: left\">" + split[0] + "</span>" +
  1463. "<span style=\"float: right\">" + split[1] + "</span><br />");
  1464. else
  1465. html.ViewContext.Writer.Write(
  1466. "<span>" + split[0] + "</span><br />");
  1467. }
  1468. }
  1469. });
  1470. });
  1471. s.Columns.Add(column =>
  1472. {
  1473. column.Caption = "Nächste Ausführung";
  1474. column.FieldName = "NextExecutionTime";
  1475. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy";
  1476. column.MinWidth = 150;
  1477. column.Width = new Unit(200, UnitType.Pixel);
  1478. });
  1479. s.ClientLayout = (sender, e) =>
  1480. {
  1481. if (e.LayoutMode == ClientLayoutMode.Loading)
  1482. {
  1483. if (System.Web.HttpContext.Current.Session["MailNotificationsGridState"] != null)
  1484. e.LayoutData = (string)System.Web.HttpContext.Current.Session["MailNotificationsGridState"];
  1485. else
  1486. {
  1487. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("MailNotificationsGridLayoutState",
  1488. _userContext.CurrentUser.Id);
  1489. if (userConfigItem != null)
  1490. {
  1491. System.Web.HttpContext.Current.Session["MailNotificationsGridState"] = userConfigItem.Value;
  1492. e.LayoutData = (string)System.Web.HttpContext.Current.Session["MailNotificationsGridState"];
  1493. }
  1494. }
  1495. }
  1496. else
  1497. {
  1498. System.Web.HttpContext.Current.Session["MailNotificationsGridState"] = e.LayoutData;
  1499. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  1500. {
  1501. UserId = _userContext.CurrentUser.Id,
  1502. Name = "MailNotificationsGridLayoutState",
  1503. Value = e.LayoutData
  1504. });
  1505. }
  1506. };
  1507. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  1508. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  1509. s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  1510. return s;
  1511. }
  1512. /// <summary>
  1513. /// Creates GridViewSettings for the logs gridView
  1514. /// </summary>
  1515. /// <param name="html">Current HtmlHelper context.</param>
  1516. public static GridViewSettings LogGridViewSettings(this System.Web.Mvc.HtmlHelper html)
  1517. {
  1518. var s = new GridViewSettings();
  1519. s.Name = "devGridViewLog";
  1520. s.KeyFieldName = "Id";
  1521. s.CallbackRouteValues = new { Controller = "Misc", Action = "PartialLogs" };
  1522. s.Width = Unit.Percentage(99);
  1523. s.Settings.ShowHeaderFilterButton = true;
  1524. s.Settings.ShowFilterRow = true;
  1525. s.Settings.ShowFilterRowMenu = true;
  1526. s.Settings.ShowFooter = true;
  1527. s.Settings.ShowGroupPanel = true;
  1528. s.Settings.AutoFilterCondition = AutoFilterCondition.Contains;
  1529. s.Settings.HorizontalScrollBarMode = ScrollBarMode.Auto;
  1530. s.Settings.VerticalScrollBarMode = ScrollBarMode.Auto;
  1531. s.Settings.VerticalScrollableHeight =
  1532. (html.ViewData["ScrollHeight"] == null || (int)html.ViewData["ScrollHeight"] == -1)
  1533. ? 400
  1534. : (int)html.ViewData["ScrollHeight"];
  1535. s.SettingsExport.Landscape = true;
  1536. s.SettingsExport.FileName = "Logliste";
  1537. s.SettingsPopup.CustomizationWindow.Width = new Unit(250, UnitType.Pixel);
  1538. s.SettingsPopup.CustomizationWindow.Height = new Unit(350, UnitType.Pixel);
  1539. s.SettingsPopup.HeaderFilter.Width = new Unit(353, UnitType.Pixel);
  1540. s.SettingsPopup.HeaderFilter.Height = new Unit(360, UnitType.Pixel);
  1541. s.SettingsBehavior.EnableCustomizationWindow = true;
  1542. s.SettingsBehavior.AllowHeaderFilter = true;
  1543. s.SettingsPager.AlwaysShowPager = true;
  1544. s.SettingsResizing.ColumnResizeMode = ColumnResizeMode.Control;
  1545. s.SettingsPager.Position = PagerPosition.Bottom;
  1546. s.SettingsPager.PageSizeItemSettings.Visible = true;
  1547. s.SettingsPager.FirstPageButton.Visible = true;
  1548. s.SettingsPager.LastPageButton.Visible = true;
  1549. s.SettingsPager.NumericButtonCount = 5;
  1550. s.Toolbars.Add(t =>
  1551. {
  1552. var refreshItem = t.Items.Add(GridViewToolbarCommand.Refresh);
  1553. refreshItem.Text = "Aktualisieren";
  1554. var filterItem = t.Items.Add(GridViewToolbarCommand.ClearFilter);
  1555. filterItem.Text = "Filter entfernen";
  1556. t.Items.Add(i =>
  1557. {
  1558. i.Text = "Spalten anzeigen / ausblenden";
  1559. i.Name = "ToggleColumnChooser";
  1560. i.Image.IconID = IconID.OtherViewgridlines16x16gray;
  1561. i.BeginGroup = true;
  1562. });
  1563. t.Items.Add(i =>
  1564. {
  1565. i.Text = "Drucken";
  1566. i.Name = "Print";
  1567. i.Image.IconID = IconID.PrintDefaultprinter16x16;
  1568. i.BeginGroup = true;
  1569. });
  1570. t.Items.Add(i =>
  1571. {
  1572. i.Text = "Zurücksetzen";
  1573. i.Name = "ResetSettings";
  1574. i.Image.IconID = IconID.ActionsReset16x16;
  1575. i.BeginGroup = true;
  1576. });
  1577. });
  1578. s.Columns.Add(column =>
  1579. {
  1580. column.Caption = "#";
  1581. column.SetDataItemTemplateContent(c =>
  1582. {
  1583. html.ViewContext.Writer.Write(
  1584. "<a href=\"#\" onclick=\"viewLog(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Betrachten</a>&nbsp;");
  1585. if (_userContext.CurrentUser.HasFunction("Misc-Logs-Delete"))
  1586. {
  1587. html.ViewContext.Writer.Write(
  1588. "<a href=\"#\" onclick=\"deleteLog(" + DataBinder.Eval(c.DataItem, "Id") + ")\">Löschen</a><br />");
  1589. }
  1590. });
  1591. column.Settings.AllowDragDrop = DefaultBoolean.False;
  1592. column.Settings.AllowSort = DefaultBoolean.False;
  1593. column.MinWidth = 130;
  1594. column.Width = new Unit(160, UnitType.Pixel);
  1595. });
  1596. s.Columns.Add(column =>
  1597. {
  1598. column.Caption = "Level";
  1599. column.FieldName = "LogLevelDescription";
  1600. column.MinWidth = 100;
  1601. column.Width = new Unit(100, UnitType.Pixel);
  1602. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1603. });
  1604. s.Columns.Add(column =>
  1605. {
  1606. column.Caption = "Betreff";
  1607. column.FieldName = "ShortMessage";
  1608. column.MinWidth = 200;
  1609. column.Width = new Unit(220, UnitType.Pixel);
  1610. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1611. });
  1612. s.Columns.Add(column =>
  1613. {
  1614. column.Caption = "Nachricht";
  1615. column.FieldName = "FullMessage";
  1616. column.MinWidth = 200;
  1617. column.Width = new Unit(250, UnitType.Pixel);
  1618. column.SetDataItemTemplateContent(c =>
  1619. {
  1620. var fullMessage = DataBinder.Eval(c.DataItem, "FullMessage");
  1621. var text = fullMessage == null
  1622. ? String.Empty
  1623. : fullMessage.ToString();
  1624. if (text.ToString().Length > 80)
  1625. html.ViewContext.Writer.Write(text.Substring(0, 80) + " ...");
  1626. else
  1627. html.ViewContext.Writer.Write(text);
  1628. });
  1629. });
  1630. s.Columns.Add(column =>
  1631. {
  1632. column.Caption = "IP-Adresse";
  1633. column.FieldName = "IpAddress";
  1634. column.MinWidth = 130;
  1635. column.Width = new Unit(130, UnitType.Pixel);
  1636. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1637. });
  1638. s.Columns.Add(column =>
  1639. {
  1640. column.Caption = "Mitarbeiter";
  1641. column.FieldName = "UserDescription";
  1642. column.MinWidth = 130;
  1643. column.Width = new Unit(160, UnitType.Pixel);
  1644. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1645. });
  1646. s.Columns.Add(column =>
  1647. {
  1648. column.Caption = "Datentyp";
  1649. column.FieldName = "EntityType";
  1650. column.MinWidth = 100;
  1651. column.Width = new Unit(130, UnitType.Pixel);
  1652. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1653. });
  1654. s.Columns.Add(column =>
  1655. {
  1656. column.Caption = "Daten ID";
  1657. column.FieldName = "EntityId";
  1658. column.MinWidth = 100;
  1659. column.Width = new Unit(100, UnitType.Pixel);
  1660. column.SettingsHeaderFilter.Mode = GridHeaderFilterMode.CheckedList;
  1661. });
  1662. s.Columns.Add(column =>
  1663. {
  1664. column.Caption = "Seiten URL";
  1665. column.FieldName = "PageUrl";
  1666. column.MinWidth = 150;
  1667. column.Width = new Unit(150, UnitType.Pixel);
  1668. column.Visible = false;
  1669. });
  1670. s.Columns.Add(column =>
  1671. {
  1672. column.Caption = "Relative URL";
  1673. column.FieldName = "ReferrerUrl";
  1674. column.MinWidth = 100;
  1675. column.Width = new Unit(100, UnitType.Pixel);
  1676. column.Visible = false;
  1677. });
  1678. s.Columns.Add(column =>
  1679. {
  1680. column.Caption = "Zeitpunkt";
  1681. column.FieldName = "CreatedOnLocal";
  1682. column.PropertiesEdit.DisplayFormatString = "dd.MM.yyyy - HH:mm:ss";
  1683. column.MinWidth = 150;
  1684. column.Width = new Unit(160, UnitType.Pixel);
  1685. });
  1686. s.ClientLayout = (sender, e) =>
  1687. {
  1688. if (e.LayoutMode == ClientLayoutMode.Loading)
  1689. {
  1690. if (System.Web.HttpContext.Current.Session["LogGridState"] != null)
  1691. e.LayoutData = (string)System.Web.HttpContext.Current.Session["LogGridState"];
  1692. else
  1693. {
  1694. var userConfigItem = _configurationService.GetUserConfigItemByNameAndUserId("LogGridLayoutState",
  1695. _userContext.CurrentUser.Id);
  1696. if (userConfigItem != null)
  1697. {
  1698. System.Web.HttpContext.Current.Session["LogGridState"] = userConfigItem.Value;
  1699. e.LayoutData = (string)System.Web.HttpContext.Current.Session["LogGridState"];
  1700. }
  1701. }
  1702. }
  1703. else
  1704. {
  1705. System.Web.HttpContext.Current.Session["LogGridState"] = e.LayoutData;
  1706. _configurationService.InsertOrUpdateUserConfigItem(new Core.Domain.Config.UserConfigItem
  1707. {
  1708. UserId = _userContext.CurrentUser.Id,
  1709. Name = "LogGridLayoutState",
  1710. Value = e.LayoutData
  1711. });
  1712. }
  1713. };
  1714. s.PreRender = s.BeforeGetCallbackResult = (sender, e) => {
  1715. MVCxGridView gridView = sender as MVCxGridView;
  1716. System.Web.HttpContext.Current.Session["LogGridViewState"] = new MVCxGridViewState(gridView);
  1717. };
  1718. s.ClientSideEvents.BeginCallback = "function (s, e) { e.customArgs['scrollHeight'] = [ gridScrollHeight ]; }";
  1719. s.ClientSideEvents.ToolbarItemClick = "function (s, e) { onToolbarItemClick(s, e); }";
  1720. s.Styles.AlternatingRow.BackColor = System.Drawing.Color.FromArgb(247, 247, 247);
  1721. return s;
  1722. }
  1723. /// <summary>
  1724. /// Formats the UserDescriptions to single string format
  1725. /// </summary>
  1726. /// <param name="userDescriptions">The UserDescription (Name and Role).</param>
  1727. private static string FormatUserDescriptions(List<string> userDescriptions)
  1728. {
  1729. if (userDescriptions == null) return null;
  1730. var result = String.Empty;
  1731. var counter = 0;
  1732. foreach (var description in userDescriptions)
  1733. {
  1734. if (counter > 1)
  1735. {
  1736. var remainingDescriptions =
  1737. String.Join(
  1738. ", ",
  1739. userDescriptions
  1740. .Skip(2)
  1741. .Take(userDescriptions.Count - 2)
  1742. .Select(u => u.Split('|').Length > 1
  1743. ? String.Format("{0} {1}", u.Split('|')[0], u.Split('|')[1])
  1744. : String.Format("{0}", u.Split('|')[0])));
  1745. result += "<a href='#' title='" + remainingDescriptions + "'>...</a>";
  1746. break;
  1747. }
  1748. else
  1749. {
  1750. var split = description.Split('|');
  1751. if (split.Length > 1)
  1752. result +=
  1753. "<span style=\"float: left\">" + split[0] + "</span>" +
  1754. "<span style=\"float: right\">" + split[1] + "</span><br />";
  1755. else
  1756. result +=
  1757. "<span>" + split[0] + "</span><br />";
  1758. }
  1759. counter++;
  1760. }
  1761. return result;
  1762. }
  1763. }
  1764. }