mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-10-24 02:52:37 +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');
|
|
});
|
|
}
|