mirror of
https://github.com/go-gitea/gitea
synced 2024-12-22 16:44:26 +00:00
c0e80dbe26
1. Enable [strictFunctionTypes](https://www.typescriptlang.org/tsconfig/#strictFunctionTypes) 2. Introduce `DOMEvent` helper type which sets `e.target`. Surely not totally correct with that `Partial` but seems to work. 3. Various type-related refactors, change objects in `eventsource.sharedworker.ts` to `Map`.
49 lines
1.8 KiB
TypeScript
49 lines
1.8 KiB
TypeScript
import {hideElem, showElem, type DOMEvent} from '../utils/dom.ts';
|
|
|
|
export function initRepoRelease() {
|
|
document.addEventListener('click', (e: DOMEvent<MouseEvent>) => {
|
|
if (e.target.matches('.remove-rel-attach')) {
|
|
const uuid = e.target.getAttribute('data-uuid');
|
|
const id = e.target.getAttribute('data-id');
|
|
document.querySelector<HTMLInputElement>(`input[name='attachment-del-${uuid}']`).value = 'true';
|
|
hideElem(`#attachment-${id}`);
|
|
}
|
|
});
|
|
}
|
|
|
|
export function initRepoReleaseNew() {
|
|
if (!document.querySelector('.repository.new.release')) return;
|
|
|
|
initTagNameEditor();
|
|
}
|
|
|
|
function initTagNameEditor() {
|
|
const el = document.querySelector('#tag-name-editor');
|
|
if (!el) return;
|
|
|
|
const existingTags = JSON.parse(el.getAttribute('data-existing-tags'));
|
|
if (!Array.isArray(existingTags)) return;
|
|
|
|
const defaultTagHelperText = el.getAttribute('data-tag-helper');
|
|
const newTagHelperText = el.getAttribute('data-tag-helper-new');
|
|
const existingTagHelperText = el.getAttribute('data-tag-helper-existing');
|
|
|
|
const tagNameInput = document.querySelector<HTMLInputElement>('#tag-name');
|
|
const hideTargetInput = function(tagNameInput: HTMLInputElement) {
|
|
const value = tagNameInput.value;
|
|
const tagHelper = document.querySelector('#tag-helper');
|
|
if (existingTags.includes(value)) {
|
|
// If the tag already exists, hide the target branch selector.
|
|
hideElem('#tag-target-selector');
|
|
tagHelper.textContent = existingTagHelperText;
|
|
} else {
|
|
showElem('#tag-target-selector');
|
|
tagHelper.textContent = value ? newTagHelperText : defaultTagHelperText;
|
|
}
|
|
};
|
|
hideTargetInput(tagNameInput); // update on page load because the input may have a value
|
|
tagNameInput.addEventListener('input', (e) => {
|
|
hideTargetInput(e.target as HTMLInputElement);
|
|
});
|
|
}
|