_MailNotificationEditPartial.cshtml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. @using GreenTree.Nachtragsmanagement.Web.Extensions
  2. @using GreenTree.Nachtragsmanagement.Core.Plugins
  3. @{
  4. var userContext = GreenTree.Nachtragsmanagement.Core.CommonHelper.UserContext();
  5. }
  6. @model GreenTree.Nachtragsmanagement.Web.Models.Misc.MailNotificationDataModel
  7. <div class="mailNotificationEditContainer">
  8. <script src="~/Scripts/jquery-cron-min.js"></script>
  9. <script>
  10. var textSeparator = ", ";
  11. var pluginSystemName = "@Model.NotificationPluginSystemName";
  12. var cronEditor = null;
  13. var notificationPluginDictionary = {};
  14. var notificationJobDictionary = {};
  15. @foreach (var notificationPlugin in (IEnumerable<INotificationPlugin>)ViewData["AllNotificationPlugins"])
  16. {
  17. ViewContext.Writer.WriteLine("notificationPluginDictionary[\"" + notificationPlugin.SystemName + "\"] = \"" + notificationPlugin.Description + "\";");
  18. foreach (var notificationJob in notificationPlugin.AvailableNotificationJobs)
  19. {
  20. ViewContext.Writer.WriteLine("notificationJobDictionary[\"" + notificationJob.SystemName + "\"] = \"" + notificationJob.Description + "\";");
  21. }
  22. }
  23. cronEditor = $("#cronExpressionEditor").cron({
  24. onChange: function () {
  25. $("#CronExpression").val($(this).cron("value"));
  26. }
  27. });
  28. function changeElementText(selector, textArray) {
  29. for (var i = 0; i < textArray.length; i++) {
  30. $(selector).contents().filter(function () {
  31. return this.nodeType == 3;
  32. })[i].nodeValue = textArray[i];
  33. }
  34. }
  35. $(document).ready(function () {
  36. @if (String.IsNullOrEmpty(Model.CronExpression))
  37. {
  38. ViewContext.Writer.WriteLine("cronEditor.cron('value', '0 6 * * 1');");
  39. }
  40. else
  41. {
  42. ViewContext.Writer.WriteLine("cronEditor.cron('value', '" + Model.CronExpression + "');");
  43. }
  44. changeElementText(".cron-period", ["Jede(r/s) "]);
  45. changeElementText(".cron-block-mins", ["auf der ", " Minute nach der Stunde"]);
  46. changeElementText(".cron-block-time", ["um "]);
  47. changeElementText(".cron-block-dow", ["am "]);
  48. changeElementText(".cron-block-dom", ["am "]);
  49. changeElementText(".cron-block-month", [" des "]);
  50. $('select[name="cron-period"] > option[value="minute"]').text("Minute");
  51. $('select[name="cron-period"] > option[value="hour"]').text("Stunde");
  52. $('select[name="cron-period"] > option[value="day"]').text("Tag");
  53. $('select[name="cron-period"] > option[value="week"]').text("Woche");
  54. $('select[name="cron-period"] > option[value="month"]').text("Monat");
  55. $('select[name="cron-period"] > option[value="year"]').text("Jahr");
  56. $('select[name="cron-dow"] > option[value="0"]').text("Sonntag");
  57. $('select[name="cron-dow"] > option[value="1"]').text("Montag");
  58. $('select[name="cron-dow"] > option[value="2"]').text("Dienstag");
  59. $('select[name="cron-dow"] > option[value="3"]').text("Mittwoch");
  60. $('select[name="cron-dow"] > option[value="4"]').text("Donnerstag");
  61. $('select[name="cron-dow"] > option[value="5"]').text("Freitag");
  62. $('select[name="cron-dow"] > option[value="6"]').text("Samstag");
  63. $('select[name="cron-month"] > option[value="1"]').text("Januar");
  64. $('select[name="cron-month"] > option[value="2"]').text("Februar");
  65. $('select[name="cron-month"] > option[value="3"]').text("März");
  66. $('select[name="cron-month"] > option[value="4"]').text("April");
  67. $('select[name="cron-month"] > option[value="5"]').text("Mai");
  68. $('select[name="cron-month"] > option[value="6"]').text("Juni");
  69. $('select[name="cron-month"] > option[value="7"]').text("Juli");
  70. $('select[name="cron-month"] > option[value="8"]').text("August");
  71. $('select[name="cron-month"] > option[value="9"]').text("September");
  72. $('select[name="cron-month"] > option[value="10"]').text("Oktober");
  73. $('select[name="cron-month"] > option[value="11"]').text("November");
  74. $('select[name="cron-month"] > option[value="12"]').text("Dezember");
  75. for (var i = 1; i <= 31; i++) {
  76. $('select[name="cron-dom"] > option[value="' + i + '"]').text(i + ".");
  77. }
  78. });
  79. function saveMailNotification() {
  80. var form = $("#mailNotificationEditForm");
  81. $(form).submit(function (e) {
  82. $.ajax({
  83. type: "POST",
  84. url: '@Url.Action("EditMailNotification", "Misc")',
  85. data: form.serialize(),
  86. success: function (response) {
  87. setTimeout(function () {
  88. $(".mailNotificationEditContainer").remove();
  89. if (response == "success") {
  90. devGridViewMailNotifications.PerformCallback();
  91. } else {
  92. $("body").append(response);
  93. }
  94. }, 200);
  95. }
  96. });
  97. e.preventDefault();
  98. });
  99. form.submit();
  100. }
  101. function onListBoxSelectionChanged(s, e) {
  102. updateText();
  103. }
  104. function updateText() {
  105. var selectedItems = UserValues.GetSelectedItems();
  106. devDropDownListUserValues.SetText(getSelectedItemsText(selectedItems));
  107. }
  108. function synchronizeListBoxValues(s, e) {
  109. UserValues.UnselectAll();
  110. var texts = s.GetText().split(textSeparator);
  111. var values = getValuesByTexts(texts);
  112. UserValues.SelectValues(values);
  113. updateText();
  114. }
  115. function getSelectedItemsText(items) {
  116. var texts = [];
  117. for (var i = 0; i < items.length; i++)
  118. texts.push(items[i].text);
  119. return texts.join(textSeparator);
  120. }
  121. function getValuesByTexts(texts) {
  122. var actualValues = [];
  123. var item;
  124. for (var i = 0; i < texts.length; i++) {
  125. item = UserValues.FindItemByText(texts[i]);
  126. if (item != null)
  127. actualValues.push(item.value);
  128. }
  129. return actualValues;
  130. }
  131. function onNotificationPluginSelectedIndexChanged() {
  132. pluginSystemName = NotificationPluginSystemName.GetValue();
  133. NotificationJobSystemName.PerformCallback();
  134. $("#notificationPluginDescription").text(notificationPluginDictionary[pluginSystemName]);
  135. }
  136. function onNotificationJobSelectedIndexChanged() {
  137. var jobSystemName = NotificationJobSystemName.GetValue();
  138. $("#notificationJobDescription").text(notificationJobDictionary[jobSystemName]);
  139. }
  140. </script>
  141. <style>
  142. .notificationDescription {
  143. margin-top: 8px;
  144. color: #009688;
  145. font-style: italic;
  146. }
  147. #cronExpressionEditor {
  148. margin-top: 3px;
  149. padding-top: 10px;
  150. border-top: 1px solid #009688;
  151. }
  152. #cronExpressionEditor select {
  153. padding: 6px 4px;
  154. border: 1px solid #DCDCDC;
  155. border-radius: 2px;
  156. -webkit-border-radius: 2px;
  157. -moz-border-radius: 2px;
  158. -o-border-radius: 2px;
  159. -khtml-border-radius: 2px;
  160. }
  161. #cronExpressionEditor select:focus {
  162. border: 1px solid #009688;
  163. }
  164. </style>
  165. @Html.DevExpress().PopupControl(s =>
  166. {
  167. s.Name = "devPopupControlEditMailNotification";
  168. if (Model.Id == -1)
  169. s.HeaderText = "Neue Benachrichtigung erstellen";
  170. else
  171. s.HeaderText = "\"" + Model.NotificationPluginSystemNameDescription + "\" bearbeiten";
  172. s.Modal = true;
  173. s.Width = new Unit(700, UnitType.Pixel);
  174. s.CloseAction = CloseAction.CloseButton;
  175. s.PopupHorizontalAlign = PopupHorizontalAlign.WindowCenter;
  176. s.PopupVerticalAlign = PopupVerticalAlign.TopSides;
  177. s.PopupVerticalOffset = 10;
  178. s.AllowDragging = true;
  179. s.AllowResize = false;
  180. s.ShowMaximizeButton = false;
  181. s.ShowFooter = false;
  182. s.ShowOnPageLoad = true;
  183. s.SetContent(() =>
  184. {
  185. using (Html.BeginForm("EditMailNotification", "Misc", FormMethod.Post, new { id = "mailNotificationEditForm" }))
  186. {
  187. ViewContext.Writer.Write("<div class='editFormWrapper'>");
  188. ViewContext.Writer.Write("<input type=\"hidden\" value=\"" + Model.Id + "\" id=\"Id\" name=\"Id\" />");
  189. ViewContext.Writer.Write("<input type=\"hidden\" value=\"" + Model.CronExpression + "\" id=\"CronExpression\" name=\"CronExpression\" />");
  190. ViewContext.Writer.Write("<div class='inlineModelPropertyContainer'>");
  191. {
  192. ViewContext.Writer.Write("<div class='inlineModelProperty' style='width: 50%'>");
  193. {
  194. ViewContext.Writer.Write(Html.CustomLabelFor(m => m.NotificationPluginSystemName, "Benachrichtigungs-Plugin:"));
  195. ViewContext.Writer.Write(Html.ValidationMessageFor(m => m.NotificationPluginSystemName).ToHtmlString());
  196. Html.DevExpress().ComboBoxFor(m => m.NotificationPluginSystemName, t =>
  197. {
  198. t.Width = new Unit(100, UnitType.Percentage);
  199. t.Properties.ValueField = "SystemName";
  200. t.Properties.ValueType = typeof(string);
  201. t.Properties.TextField = "Name";
  202. t.Properties.ClientSideEvents.SelectedIndexChanged = "function (s, e) { onNotificationPluginSelectedIndexChanged(); }";
  203. }).BindList(ViewData["AllNotificationPlugins"]).Bind(Model.NotificationPluginSystemName).Render();
  204. }
  205. ViewContext.Writer.Write("</div>");
  206. }
  207. ViewContext.Writer.Write("</div>");
  208. ViewContext.Writer.Write("<div class='inlineModelPropertyContainer'>");
  209. {
  210. ViewContext.Writer.Write("<div class='inlineModelProperty' style='width: 100%'>");
  211. {
  212. if (Model == null || (Model != null && Model.NotificationPlugin == null))
  213. ViewContext.Writer.Write("<div id=\"notificationPluginDescription\" class=\"notificationDescription\"></div>");
  214. else
  215. ViewContext.Writer.Write(
  216. "<div id=\"notificationPluginDescription\" class=\"notificationDescription\">" + Model.NotificationPlugin.Description + "</div>");
  217. }
  218. ViewContext.Writer.Write("</div>");
  219. }
  220. ViewContext.Writer.Write("</div>");
  221. ViewContext.Writer.Write("<div class='inlineModelPropertyContainer'>");
  222. {
  223. ViewContext.Writer.Write("<div class='inlineModelProperty' style='width: 50%'>");
  224. {
  225. ViewContext.Writer.Write(Html.CustomLabelFor(m => m.NotificationJobSystemName, "Benachrichtigungs-Job:"));
  226. ViewContext.Writer.Write(Html.ValidationMessageFor(m => m.NotificationJobSystemName).ToHtmlString());
  227. ViewContext.Writer.Write(Html.Partial("~/Views/Misc/_MailNotificationPluginJobsPartial.cshtml", Model).ToHtmlString());
  228. }
  229. ViewContext.Writer.Write("</div>");
  230. }
  231. ViewContext.Writer.Write("</div>");
  232. ViewContext.Writer.Write("<div class='inlineModelPropertyContainer'>");
  233. {
  234. ViewContext.Writer.Write("<div class='inlineModelProperty' style='width: 100%'>");
  235. {
  236. if (Model == null || (Model != null && Model.NotificationPlugin == null))
  237. ViewContext.Writer.Write("<div id=\"notificationJobDescription\" class=\"notificationDescription\"></div>");
  238. else
  239. {
  240. var notificationJob = Model.NotificationPlugin.AvailableNotificationJobs
  241. .FirstOrDefault(j => j.SystemName == Model.NotificationJobSystemName);
  242. if (notificationJob != null)
  243. ViewContext.Writer.Write(
  244. "<div id=\"notificationJobDescription\" class=\"notificationDescription\">" + notificationJob.Description + "</div>");
  245. }
  246. }
  247. ViewContext.Writer.Write("</div>");
  248. }
  249. ViewContext.Writer.Write("</div>");
  250. ViewContext.Writer.Write("<div class='inlineModelPropertyContainer'>");
  251. {
  252. ViewContext.Writer.Write("<div class='inlineModelProperty' style='width: 65%'>");
  253. {
  254. ViewContext.Writer.Write(Html.CustomLabelFor(m => m.UserValues, "Benutzer:"));
  255. ViewContext.Writer.Write(Html.ValidationMessageFor(m => m.UserValues).ToHtmlString());
  256. Html.DevExpress().DropDownEdit(t =>
  257. {
  258. t.Name = "devDropDownListUserValues";
  259. t.Width = new Unit(100, UnitType.Percentage);
  260. t.Text = Model.UserDescription;
  261. t.SetDropDownWindowTemplateContent(l =>
  262. {
  263. Html.DevExpress().ListBox(lb =>
  264. {
  265. lb.Name = "UserValues";
  266. lb.Width = new Unit(100, UnitType.Percentage);
  267. lb.Height = new Unit(250, UnitType.Pixel);
  268. lb.Properties.TextField = "Description";
  269. lb.Properties.ValueField = "Id";
  270. lb.Properties.ValueType = typeof(int);
  271. lb.Properties.SelectionMode = ListEditSelectionMode.CheckColumn;
  272. lb.ControlStyle.Border.BorderStyle = BorderStyle.None;
  273. lb.PreRender = (sender, e) =>
  274. {
  275. var listBox = sender as MVCxListBox;
  276. foreach (ListEditItem listItem in listBox.Items)
  277. {
  278. if (Model.UserValues == null || !Model.UserValues.Any(m => m == (int)listItem.Value)) continue;
  279. listItem.Selected = true;
  280. }
  281. };
  282. lb.Properties.ClientSideEvents.SelectedIndexChanged = "function (s, e) { onListBoxSelectionChanged(s, e); }";
  283. }).BindList(ViewData["AllUsersWithRole"]).Render();
  284. t.Properties.ClientSideEvents.TextChanged = "function (s, e) { synchronizeListBoxValues(s, e); }";
  285. t.Properties.ClientSideEvents.DropDown = "function (s, e) { synchronizeListBoxValues(s, e); }";
  286. });
  287. }).Render();
  288. }
  289. ViewContext.Writer.Write("</div>");
  290. }
  291. ViewContext.Writer.Write("</div>");
  292. ViewContext.Writer.Write("<div class='inlineModelPropertyContainer'>");
  293. {
  294. ViewContext.Writer.Write("<div class='inlineModelProperty' style='width: 100%'>");
  295. {
  296. ViewContext.Writer.Write(Html.CustomLabelFor(m => m.CronExpression, "Interval:"));
  297. ViewContext.Writer.Write(Html.ValidationMessageFor(m => m.CronExpression).ToHtmlString());
  298. ViewContext.Writer.Write("<div id=\"cronExpressionEditor\"></div>");
  299. //Html.DevExpress().AppointmentRecurrenceForm(t =>
  300. //{
  301. // t.Name = "devRecurrenceFormCronExpresseion";
  302. // t.Width = new Unit(100, UnitType.Percentage);
  303. // t.IsRecurring = true;
  304. //}).Render();
  305. }
  306. ViewContext.Writer.Write("</div>");
  307. }
  308. ViewContext.Writer.Write("</div>");
  309. ViewContext.Writer.Write("</div>");
  310. Html.RenderPartial(
  311. "~/Views/Shared/_PopupButtonPanel.cshtml",
  312. new GreenTree.Nachtragsmanagement.Web.Models.Global.PopupModel
  313. {
  314. PopupName = "devPopupControlEditMailNotification",
  315. AcceptFunction = "function (s, e) { saveMailNotification(); }"
  316. }
  317. );
  318. }
  319. });
  320. s.Styles.Content.Paddings.Padding = new Unit(0);
  321. s.Styles.ModalBackground.Opacity = 0;
  322. }).GetHtml()
  323. </div>