mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 03:22:36 +00:00 
			
		
		
		
	- A lot of substitution to `.requestSubmit()`. - Where possible, rewrite some other jquery to vanilla javascript to ease the linter fix.
		
			
				
	
	
		
			96 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import $ from 'jquery';
 | |
| 
 | |
| function isExclusiveScopeName(name) {
 | |
|   return /.*[^/]\/[^/].*/.test(name);
 | |
| }
 | |
| 
 | |
| function updateExclusiveLabelEdit(form) {
 | |
|   const nameInput = document.querySelector(`${form} .label-name-input`);
 | |
|   const exclusiveField = document.querySelector(`${form} .label-exclusive-input-field`);
 | |
|   const exclusiveCheckbox = document.querySelector(`${form} .label-exclusive-input`);
 | |
|   const exclusiveWarning = document.querySelector(`${form} .label-exclusive-warning`);
 | |
| 
 | |
|   if (isExclusiveScopeName(nameInput.value)) {
 | |
|     exclusiveField?.classList.remove('muted');
 | |
|     exclusiveField?.removeAttribute('aria-disabled');
 | |
|     if (exclusiveCheckbox.checked && exclusiveCheckbox.getAttribute('data-exclusive-warn')) {
 | |
|       exclusiveWarning?.classList.remove('tw-hidden');
 | |
|     } else {
 | |
|       exclusiveWarning?.classList.add('tw-hidden');
 | |
|     }
 | |
|   } else {
 | |
|     exclusiveField?.classList.add('muted');
 | |
|     exclusiveField?.setAttribute('aria-disabled', 'true');
 | |
|     exclusiveWarning?.classList.add('tw-hidden');
 | |
|   }
 | |
| }
 | |
| 
 | |
| export function initCompLabelEdit(selector) {
 | |
|   if (!$(selector).length) return;
 | |
| 
 | |
|   // Create label
 | |
|   $('.new-label.button').on('click', () => {
 | |
|     updateExclusiveLabelEdit('.new-label');
 | |
|     $('.new-label.modal').modal({
 | |
|       onApprove() {
 | |
|         const form = document.querySelector('.new-label.form');
 | |
|         if (!form.checkValidity()) {
 | |
|           form.reportValidity();
 | |
|           return false;
 | |
|         }
 | |
|         document.querySelector('.new-label.form').requestSubmit();
 | |
|       },
 | |
|     }).modal('show');
 | |
|     return false;
 | |
|   });
 | |
| 
 | |
|   // Edit label
 | |
|   $('.edit-label-button').on('click', function () {
 | |
|     $('#label-modal-id').val($(this).data('id'));
 | |
| 
 | |
|     const $nameInput = $('.edit-label .label-name-input');
 | |
|     $nameInput.val($(this).data('title'));
 | |
| 
 | |
|     const $isArchivedCheckbox = $('.edit-label .label-is-archived-input');
 | |
|     $isArchivedCheckbox[0].checked = this.hasAttribute('data-is-archived');
 | |
| 
 | |
|     const $exclusiveCheckbox = $('.edit-label .label-exclusive-input');
 | |
|     $exclusiveCheckbox[0].checked = this.hasAttribute('data-exclusive');
 | |
|     // Warn when label was previously not exclusive and used in issues
 | |
|     $exclusiveCheckbox.data('exclusive-warn',
 | |
|       $(this).data('num-issues') > 0 &&
 | |
|       (!this.hasAttribute('data-exclusive') || !isExclusiveScopeName($nameInput.val())));
 | |
|     updateExclusiveLabelEdit('.edit-label');
 | |
| 
 | |
|     $('.edit-label .label-desc-input').val(this.getAttribute('data-description'));
 | |
| 
 | |
|     const colorInput = document.querySelector('.edit-label .js-color-picker-input input');
 | |
|     colorInput.value = this.getAttribute('data-color');
 | |
|     colorInput.dispatchEvent(new Event('input', {bubbles: true}));
 | |
| 
 | |
|     $('.edit-label.modal').modal({
 | |
|       onApprove() {
 | |
|         const form = document.querySelector('.edit-label.form');
 | |
|         if (!form.checkValidity()) {
 | |
|           form.reportValidity();
 | |
|           return false;
 | |
|         }
 | |
|         document.querySelector('.edit-label.form').requestSubmit();
 | |
|       },
 | |
|     }).modal('show');
 | |
|     return false;
 | |
|   });
 | |
| 
 | |
|   $('.new-label .label-name-input').on('input', () => {
 | |
|     updateExclusiveLabelEdit('.new-label');
 | |
|   });
 | |
|   $('.new-label .label-exclusive-input').on('change', () => {
 | |
|     updateExclusiveLabelEdit('.new-label');
 | |
|   });
 | |
|   $('.edit-label .label-name-input').on('input', () => {
 | |
|     updateExclusiveLabelEdit('.edit-label');
 | |
|   });
 | |
|   $('.edit-label .label-exclusive-input').on('change', () => {
 | |
|     updateExclusiveLabelEdit('.edit-label');
 | |
|   });
 | |
| }
 |