mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-22 18:12:28 +00:00 
			
		
		
		
	## Archived labels This adds the structure to allow for archived labels. Archived labels are, just like closed milestones or projects, a medium to hide information without deleting it. It is especially useful if there are outdated labels that should no longer be used without deleting the label entirely. ## Changes 1. UI and API have been equipped with the support to mark a label as archived 2. The time when a label has been archived will be stored in the DB ## Outsourced for the future There's no special handling for archived labels at the moment. This will be done in the future. ## Screenshots   Part of https://github.com/go-gitea/gitea/issues/25237 --------- Co-authored-by: delvh <dev.lh@web.de> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import $ from 'jquery';
 | |
| import {initCompColorPicker} from './ColorPicker.js';
 | |
| 
 | |
| function isExclusiveScopeName(name) {
 | |
|   return /.*[^/]\/[^/].*/.test(name);
 | |
| }
 | |
| 
 | |
| function updateExclusiveLabelEdit(form) {
 | |
|   const nameInput = $(`${form} .label-name-input`);
 | |
|   const exclusiveField = $(`${form} .label-exclusive-input-field`);
 | |
|   const exclusiveCheckbox = $(`${form} .label-exclusive-input`);
 | |
|   const exclusiveWarning = $(`${form} .label-exclusive-warning`);
 | |
| 
 | |
|   if (isExclusiveScopeName(nameInput.val())) {
 | |
|     exclusiveField.removeClass('muted');
 | |
|     exclusiveField.removeAttr('aria-disabled');
 | |
|     if (exclusiveCheckbox.prop('checked') && exclusiveCheckbox.data('exclusive-warn')) {
 | |
|       exclusiveWarning.removeClass('gt-hidden');
 | |
|     } else {
 | |
|       exclusiveWarning.addClass('gt-hidden');
 | |
|     }
 | |
|   } else {
 | |
|     exclusiveField.addClass('muted');
 | |
|     exclusiveField.attr('aria-disabled', 'true');
 | |
|     exclusiveWarning.addClass('gt-hidden');
 | |
|   }
 | |
| }
 | |
| 
 | |
| export function initCompLabelEdit(selector) {
 | |
|   if (!$(selector).length) return;
 | |
|   initCompColorPicker();
 | |
| 
 | |
|   // Create label
 | |
|   $('.new-label.button').on('click', () => {
 | |
|     updateExclusiveLabelEdit('.new-label');
 | |
|     $('.new-label.modal').modal({
 | |
|       onApprove() {
 | |
|         $('.new-label.form').trigger('submit');
 | |
|       },
 | |
|     }).modal('show');
 | |
|     return false;
 | |
|   });
 | |
| 
 | |
|   // Edit label
 | |
|   $('.edit-label-button').on('click', function () {
 | |
|     $('.edit-label .color-picker').minicolors('value', $(this).data('color'));
 | |
|     $('#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.prop('checked', this.hasAttribute('data-is-archived'));
 | |
| 
 | |
|     const exclusiveCheckbox = $('.edit-label .label-exclusive-input');
 | |
|     exclusiveCheckbox.prop('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).data('description'));
 | |
|     $('.edit-label .color-picker').val($(this).data('color'));
 | |
|     $('.edit-label .minicolors-swatch-color').css('background-color', $(this).data('color'));
 | |
| 
 | |
|     $('.edit-label.modal').modal({
 | |
|       onApprove() {
 | |
|         $('.edit-label.form').trigger('submit');
 | |
|       },
 | |
|     }).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');
 | |
|   });
 | |
| }
 |