mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-10-24 11:02:42 +00:00
Closes #6485 Adds a bit of javascript in the template responsible for the "create release" page When typing a name in the "tag name" field, the content will be automatically set in the "Title" field as a placeholder. This way, you can type a version number (ex: `v5.0.2`), and the title will default to it (`v5.0.2` in this case) ## Checklist The [contributor guide](https://forgejo.org/docs/next/contributor/) contains information that will be helpful to first time contributors. There also are a few [conditions for merging Pull Requests in Forgejo repositories](https://codeberg.org/forgejo/governance/src/branch/main/PullRequestsAgreement.md). You are also welcome to join the [Forgejo development chatroom](https://matrix.to/#/#forgejo-development:matrix.org). ### Tests - I added test coverage for Go changes... - [ ] in their respective `*_test.go` for unit tests. - [ ] in the `tests/integration` directory if it involves interactions with a live Forgejo server. - I added test coverage for JavaScript changes... - [ ] in `web_src/js/*.test.js` if it can be unit tested. - [x] in `tests/e2e/*.test.e2e.js` if it requires interactions with a live Forgejo server (see also the [developer guide for JavaScript testing](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/tests/e2e/README.md#end-to-end-tests)). ### Documentation - [ ] I created a pull request [to the documentation](https://codeberg.org/forgejo/docs) to explain to Forgejo users how to use this change. - [x] I did not document these changes and I do not expect someone else to do it. ### Release notes - [x] I do not want this change to show in the release notes. - [ ] I want the title to show in the release notes with a link to this pull request. - [ ] I want the content of the `release-notes/<pull request number>.md` to be be used for the release notes instead of the title. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/6645 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: Litchi Pi <litchi.pi@proton.me> Co-committed-by: Litchi Pi <litchi.pi@proton.me>
98 lines
3.2 KiB
JavaScript
98 lines
3.2 KiB
JavaScript
import {hideElem, showElem} from '../utils/dom.js';
|
|
import {initComboMarkdownEditor} from './comp/ComboMarkdownEditor.js';
|
|
|
|
export function initRepoRelease() {
|
|
for (const el of document.querySelectorAll('.remove-rel-attach')) {
|
|
el.addEventListener('click', (e) => {
|
|
const uuid = e.target.getAttribute('data-uuid');
|
|
const id = e.target.getAttribute('data-id');
|
|
document.querySelector(`input[name='attachment-del-${uuid}']`).value =
|
|
'true';
|
|
hideElem(`#attachment-${id}`);
|
|
});
|
|
}
|
|
}
|
|
|
|
export function initRepoReleaseNew() {
|
|
if (!document.querySelector('.repository.new.release')) return;
|
|
|
|
initTagNameEditor();
|
|
initRepoReleaseEditor();
|
|
initAddExternalLinkButton();
|
|
}
|
|
|
|
function initTagNameEditor() {
|
|
const el = document.getElementById('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');
|
|
|
|
document.getElementById('tag-name').addEventListener('keyup', (e) => {
|
|
const value = e.target.value;
|
|
const tagHelper = document.getElementById('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;
|
|
}
|
|
|
|
const title_input = document.getElementById('release-title');
|
|
title_input.placeholder = value;
|
|
});
|
|
}
|
|
|
|
function initRepoReleaseEditor() {
|
|
const editor = document.querySelector(
|
|
'.repository.new.release .combo-markdown-editor',
|
|
);
|
|
if (!editor) {
|
|
return;
|
|
}
|
|
initComboMarkdownEditor(editor);
|
|
}
|
|
|
|
let newAttachmentCount = 0;
|
|
|
|
function initAddExternalLinkButton() {
|
|
const addExternalLinkButton = document.getElementById('add-external-link');
|
|
if (!addExternalLinkButton) return;
|
|
|
|
addExternalLinkButton.addEventListener('click', () => {
|
|
newAttachmentCount += 1;
|
|
const attachmentTemplate = document.getElementById('attachment-template');
|
|
|
|
const newAttachment = attachmentTemplate.cloneNode(true);
|
|
newAttachment.id = `attachment-N${newAttachmentCount}`;
|
|
newAttachment.classList.remove('tw-hidden');
|
|
|
|
const attachmentName = newAttachment.querySelector(
|
|
'input[name="attachment-template-new-name"]',
|
|
);
|
|
attachmentName.name = `attachment-new-name-${newAttachmentCount}`;
|
|
attachmentName.required = true;
|
|
|
|
const attachmentExtUrl = newAttachment.querySelector(
|
|
'input[name="attachment-template-new-exturl"]',
|
|
);
|
|
attachmentExtUrl.name = `attachment-new-exturl-${newAttachmentCount}`;
|
|
attachmentExtUrl.required = true;
|
|
|
|
const attachmentDel = newAttachment.querySelector('.remove-rel-attach');
|
|
attachmentDel.addEventListener('click', () => {
|
|
newAttachment.remove();
|
|
});
|
|
|
|
attachmentTemplate.parentNode.insertBefore(
|
|
newAttachment,
|
|
attachmentTemplate,
|
|
);
|
|
});
|
|
}
|