edit.js 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. $(document).ready(function() {
  2. $(".arrow-toggle").on('click', function(e) { e.preventDefault(); $(this).find('.arrow').toggleClass("animation"); });
  3. $("#pushover_delete").click(function() { return confirm(lang.delete_ays); });
  4. $(".goto_checkbox").click(function( event ) {
  5. $("form[data-id='editalias'] .goto_checkbox").not(this).prop('checked', false);
  6. if ($("form[data-id='editalias'] .goto_checkbox:checked").length > 0) {
  7. $('#textarea_alias_goto').prop('disabled', true);
  8. }
  9. else {
  10. $("#textarea_alias_goto").removeAttr('disabled');
  11. }
  12. });
  13. $("#disable_sender_check").click(function( event ) {
  14. if ($("form[data-id='editmailbox'] #disable_sender_check:checked").length > 0) {
  15. $('#editSelectSenderACL').prop('disabled', true);
  16. $('#editSelectSenderACL').selectpicker('refresh');
  17. }
  18. else {
  19. $('#editSelectSenderACL').prop('disabled', false);
  20. $('#editSelectSenderACL').selectpicker('refresh');
  21. }
  22. });
  23. if ($("form[data-id='editalias'] .goto_checkbox:checked").length > 0) {
  24. $('#textarea_alias_goto').prop('disabled', true);
  25. }
  26. $("#mailbox-password-warning-close").click(function( event ) {
  27. $('#mailbox-passwd-hidden-info').addClass('hidden');
  28. $('#mailbox-passwd-form-groups').removeClass('hidden');
  29. });
  30. // Sender ACL
  31. if ($("#editSelectSenderACL option[value='\*']:selected").length > 0){
  32. $("#sender_acl_disabled").show();
  33. }
  34. $('#editSelectSenderACL').change(function() {
  35. if ($("#editSelectSenderACL option[value='\*']:selected").length > 0){
  36. $("#sender_acl_disabled").show();
  37. }
  38. else {
  39. $("#sender_acl_disabled").hide();
  40. }
  41. });
  42. // Resources
  43. if ($("#editSelectMultipleBookings").val() == "custom") {
  44. $("#multiple_bookings_custom_div").show();
  45. $('input[name=multiple_bookings]').val($("#multiple_bookings_custom").val());
  46. }
  47. $("#editSelectMultipleBookings").change(function() {
  48. $('input[name=multiple_bookings]').val($("#editSelectMultipleBookings").val());
  49. if ($('input[name=multiple_bookings]').val() == "custom") {
  50. $("#multiple_bookings_custom_div").show();
  51. }
  52. else {
  53. $("#multiple_bookings_custom_div").hide();
  54. }
  55. });
  56. $("#multiple_bookings_custom").bind("change keypress keyup blur", function() {
  57. $('input[name=multiple_bookings]').val($("#multiple_bookings_custom").val());
  58. });
  59. });
  60. jQuery(function($){
  61. // http://stackoverflow.com/questions/46155/validate-email-address-in-javascript
  62. function validateEmail(email) {
  63. var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
  64. return re.test(email);
  65. }
  66. function draw_wl_policy_domain_table() {
  67. $('#wl_policy_domain_table').DataTable({
  68. processing: true,
  69. serverSide: false,
  70. language: lang_datatables,
  71. ajax: {
  72. type: "GET",
  73. url: '/api/v1/get/policy_wl_domain/' + table_for_domain,
  74. dataSrc: function(data){
  75. $.each(data, function (i, item) {
  76. if (!validateEmail(item.object)) {
  77. item.chkbox = '<input type="checkbox" data-id="policy_wl_domain" name="multi_select" value="' + item.prefid + '" />';
  78. }
  79. else {
  80. item.chkbox = '<input type="checkbox" disabled title="' + lang_user.spamfilter_table_domain_policy + '" />';
  81. }
  82. });
  83. return data;
  84. }
  85. },
  86. columns: [
  87. {
  88. // placeholder, so checkbox will not block child row toggle
  89. title: '',
  90. data: null,
  91. searchable: false,
  92. orderable: false,
  93. defaultContent: ''
  94. },
  95. {
  96. title: '',
  97. data: 'chkbox',
  98. searchable: false,
  99. orderable: false,
  100. defaultContent: ''
  101. },
  102. {
  103. title: 'ID',
  104. data: 'prefid',
  105. },
  106. {
  107. title: lang_user.spamfilter_table_rule,
  108. data: 'value'
  109. },
  110. {
  111. title: 'Scope',
  112. data: 'object'
  113. }
  114. ]
  115. });
  116. }
  117. function draw_bl_policy_domain_table() {
  118. $('#bl_policy_domain_table').DataTable({
  119. processing: true,
  120. serverSide: false,
  121. language: lang_datatables,
  122. ajax: {
  123. type: "GET",
  124. url: '/api/v1/get/policy_bl_domain/' + table_for_domain,
  125. dataSrc: function(data){
  126. $.each(data, function (i, item) {
  127. if (!validateEmail(item.object)) {
  128. item.chkbox = '<input type="checkbox" data-id="policy_bl_domain" name="multi_select" value="' + item.prefid + '" />';
  129. }
  130. else {
  131. item.chkbox = '<input type="checkbox" disabled tooltip="' + lang_user.spamfilter_table_domain_policy + '" />';
  132. }
  133. });
  134. return data;
  135. }
  136. },
  137. columns: [
  138. {
  139. // placeholder, so checkbox will not block child row toggle
  140. title: '',
  141. data: null,
  142. searchable: false,
  143. orderable: false,
  144. defaultContent: ''
  145. },
  146. {
  147. title: '',
  148. data: 'chkbox',
  149. searchable: false,
  150. orderable: false,
  151. defaultContent: ''
  152. },
  153. {
  154. title: 'ID',
  155. data: 'prefid',
  156. },
  157. {
  158. title: lang_user.spamfilter_table_rule,
  159. data: 'value'
  160. },
  161. {
  162. title: 'Scope',
  163. data: 'object'
  164. }
  165. ]
  166. });
  167. }
  168. // detect element visibility changes
  169. function onVisible(element, callback) {
  170. $(element).ready(function() {
  171. element_object = document.querySelector(element)
  172. new IntersectionObserver((entries, observer) => {
  173. entries.forEach(entry => {
  174. if(entry.intersectionRatio > 0) {
  175. callback(element_object);
  176. observer.disconnect();
  177. }
  178. });
  179. }).observe(element_object);
  180. });
  181. }
  182. // Draw Table if tab is active
  183. onVisible("[id^=wl_policy_domain_table]", () => draw_wl_policy_domain_table());
  184. onVisible("[id^=bl_policy_domain_table]", () => draw_bl_policy_domain_table());
  185. });