mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 12:26:05 +01:00 
			
		
		
		
	Close #22847 This PR: * introduce Gitea's own `showElem` and related functions * remove jQuery show/hide * remove .hide class * remove inline style=display:none From now on: do not use: * "[hidden]" attribute: it's too weak, can not be applied to an element with "display: flex" * ".hidden" class: it has been polluted by Fomantic UI in many cases * inline style="display: none": it's difficult to tweak * jQuery's show/hide/toggle: it can not show/hide elements with "display: xxx !important" only use: * this ".gt-hidden" class * showElem/hideElem/toggleElem functions in "utils/dom.js" cc: @silverwind , this is the all-in-one PR
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import $ from 'jquery';
 | 
						|
import {hideElem, showElem, toggleElem} from '../../utils/dom.js';
 | 
						|
 | 
						|
const {csrfToken} = window.config;
 | 
						|
 | 
						|
export function initCompWebHookEditor() {
 | 
						|
  if ($('.new.webhook').length === 0) {
 | 
						|
    return;
 | 
						|
  }
 | 
						|
 | 
						|
  $('.events.checkbox input').on('change', function () {
 | 
						|
    if ($(this).is(':checked')) {
 | 
						|
      showElem($('.events.fields'));
 | 
						|
    }
 | 
						|
  });
 | 
						|
  $('.non-events.checkbox input').on('change', function () {
 | 
						|
    if ($(this).is(':checked')) {
 | 
						|
      hideElem($('.events.fields'));
 | 
						|
    }
 | 
						|
  });
 | 
						|
 | 
						|
  const updateContentType = function () {
 | 
						|
    const visible = $('#http_method').val() === 'POST';
 | 
						|
    toggleElem($('#content_type').parent().parent(), visible);
 | 
						|
  };
 | 
						|
  updateContentType();
 | 
						|
  $('#http_method').on('change', () => {
 | 
						|
    updateContentType();
 | 
						|
  });
 | 
						|
 | 
						|
  // Test delivery
 | 
						|
  $('#test-delivery').on('click', function () {
 | 
						|
    const $this = $(this);
 | 
						|
    $this.addClass('loading disabled');
 | 
						|
    $.post($this.data('link'), {
 | 
						|
      _csrf: csrfToken
 | 
						|
    }).done(
 | 
						|
      setTimeout(() => {
 | 
						|
        window.location.href = $this.data('redirect');
 | 
						|
      }, 5000)
 | 
						|
    );
 | 
						|
  });
 | 
						|
}
 |