mirror of
https://github.com/go-gitea/gitea.git
synced 2026-04-22 22:40:59 +02:00
137 lines
6.0 KiB
TypeScript
137 lines
6.0 KiB
TypeScript
import {hideElem, querySingleVisibleElem, showElem, toggleElem} from '../utils/dom.ts';
|
|
import {html, htmlEscape} from '../utils/html.ts';
|
|
import {fomanticQuery} from '../modules/fomantic/base.ts';
|
|
import {sanitizeRepoName} from './repo-common.ts';
|
|
|
|
const {appSubUrl} = window.config;
|
|
function initRepoNewTemplateSearch(form: HTMLFormElement) {
|
|
const elSubmitButton = querySingleVisibleElem<HTMLInputElement>(form, '.ui.primary.button')!;
|
|
const elCreateRepoErrorMessage = form.querySelector('#create-repo-error-message')!;
|
|
const elRepoOwnerDropdown = form.querySelector('#repo_owner_dropdown')!;
|
|
const elRepoTemplateDropdown = form.querySelector<HTMLInputElement>('#repo_template_search')!;
|
|
const inputRepoTemplate = form.querySelector<HTMLInputElement>('#repo_template')!;
|
|
const elTemplateUnits = form.querySelector('#template_units')!;
|
|
const elNonTemplate = form.querySelector('#non_template')!;
|
|
const checkTemplate = function () {
|
|
const hasSelectedTemplate = inputRepoTemplate.value !== '' && inputRepoTemplate.value !== '0';
|
|
toggleElem(elTemplateUnits, hasSelectedTemplate);
|
|
toggleElem(elNonTemplate, !hasSelectedTemplate);
|
|
};
|
|
inputRepoTemplate.addEventListener('change', checkTemplate);
|
|
checkTemplate();
|
|
|
|
const $repoOwnerDropdown = fomanticQuery(elRepoOwnerDropdown);
|
|
const $repoTemplateDropdown = fomanticQuery(elRepoTemplateDropdown);
|
|
const onChangeOwner = function () {
|
|
const ownerId = $repoOwnerDropdown.dropdown('get value');
|
|
const $ownerItem = $repoOwnerDropdown.dropdown('get item', ownerId);
|
|
hideElem(elCreateRepoErrorMessage);
|
|
elSubmitButton.disabled = false;
|
|
if ($ownerItem?.length) {
|
|
const elOwnerItem = $ownerItem[0];
|
|
elCreateRepoErrorMessage.textContent = elOwnerItem.getAttribute('data-create-repo-disallowed-prompt') ?? '';
|
|
const hasError = Boolean(elCreateRepoErrorMessage.textContent);
|
|
toggleElem(elCreateRepoErrorMessage, hasError);
|
|
elSubmitButton.disabled = hasError;
|
|
}
|
|
$repoTemplateDropdown.dropdown('setting', {
|
|
apiSettings: {
|
|
url: `${appSubUrl}/repo/search?q={query}&template=true&priority_owner_id=${ownerId}`,
|
|
onResponse(response: any) {
|
|
const results = [];
|
|
results.push({name: '', value: ''}); // empty item means not using template
|
|
for (const tmplRepo of response.data) {
|
|
results.push({
|
|
name: htmlEscape(tmplRepo.repository.full_name),
|
|
value: String(tmplRepo.repository.id),
|
|
});
|
|
}
|
|
$repoTemplateDropdown.fomanticExt.onResponseKeepSelectedItem($repoTemplateDropdown, inputRepoTemplate.value);
|
|
return {results};
|
|
},
|
|
cache: false,
|
|
},
|
|
});
|
|
};
|
|
$repoOwnerDropdown.dropdown('setting', 'onChange', onChangeOwner);
|
|
onChangeOwner();
|
|
}
|
|
|
|
function initRepoGroupSelector(form: HTMLFormElement) {
|
|
const inputRepoOwnerUid = form.querySelector<HTMLInputElement>('input[name="uid"]');
|
|
const elGroupDropdown = form.querySelector<HTMLInputElement>('#group_selector');
|
|
const $dropdown = fomanticQuery(elGroupDropdown);
|
|
const onChangeRepoOwner = function () {
|
|
$dropdown.dropdown({
|
|
keepSearchTerm: true,
|
|
fireOnInit: true,
|
|
saveRemoteData: false,
|
|
apiSettings: {
|
|
url: `${appSubUrl}/group/search?uid=${inputRepoOwnerUid.value}&recurse=true`,
|
|
onResponse(response: {data: any}) {
|
|
const results = [];
|
|
results.push({name: '', value: '0'});
|
|
const forEachFn = function ({group, subgroups}: {group: any, subgroups: any[]}, depth: number) {
|
|
results.push({
|
|
// eslint-disable-next-line github/unescaped-html-literal
|
|
name: `<span style="margin-left: ${depth + 1}rem">${html`${group.name}`}</span>`,
|
|
value: String(group.id),
|
|
});
|
|
for (const sg of subgroups) {
|
|
forEachFn(sg, depth + 1);
|
|
}
|
|
};
|
|
for (const g of response.data.subgroups) {
|
|
forEachFn(g, 0);
|
|
}
|
|
return {results};
|
|
},
|
|
cache: false,
|
|
},
|
|
});
|
|
};
|
|
inputRepoOwnerUid.addEventListener('change', onChangeRepoOwner);
|
|
onChangeRepoOwner();
|
|
}
|
|
|
|
export function initRepoNew() {
|
|
const pageContent = document.querySelector('.page-content.repository.new-repo');
|
|
if (!pageContent) return;
|
|
|
|
const form = document.querySelector<HTMLFormElement>('.new-repo-form')!;
|
|
const inputGitIgnores = form.querySelector<HTMLInputElement>('input[name="gitignores"]')!;
|
|
const inputLicense = form.querySelector<HTMLInputElement>('input[name="license"]')!;
|
|
const inputAutoInit = form.querySelector<HTMLInputElement>('input[name="auto_init"]')!;
|
|
const updateUiAutoInit = () => {
|
|
inputAutoInit.checked = Boolean(inputGitIgnores.value || inputLicense.value);
|
|
};
|
|
inputGitIgnores.addEventListener('change', updateUiAutoInit);
|
|
inputLicense.addEventListener('change', updateUiAutoInit);
|
|
updateUiAutoInit();
|
|
|
|
const inputRepoName = form.querySelector<HTMLInputElement>('input[name="repo_name"]')!;
|
|
const inputPrivate = form.querySelector<HTMLInputElement>('input[name="private"]')!;
|
|
const updateUiRepoName = () => {
|
|
const helps = form.querySelectorAll(`.help[data-help-for-repo-name]`);
|
|
hideElem(helps);
|
|
let help = form.querySelector(`.help[data-help-for-repo-name="${CSS.escape(inputRepoName.value)}"]`);
|
|
if (!help) help = form.querySelector(`.help[data-help-for-repo-name=""]`)!;
|
|
showElem(help);
|
|
const repoNamePreferPrivate: Record<string, boolean> = {'.profile': false, '.profile-private': true};
|
|
const preferPrivate = repoNamePreferPrivate[inputRepoName.value];
|
|
// inputPrivate might be disabled because site admin "force private"
|
|
if (preferPrivate !== undefined && !inputPrivate.closest('.disabled, [disabled]')) {
|
|
inputPrivate.checked = preferPrivate;
|
|
}
|
|
};
|
|
inputRepoName.addEventListener('input', updateUiRepoName);
|
|
inputRepoName.addEventListener('change', () => {
|
|
inputRepoName.value = sanitizeRepoName(inputRepoName.value);
|
|
updateUiRepoName();
|
|
});
|
|
updateUiRepoName();
|
|
|
|
initRepoNewTemplateSearch(form);
|
|
initRepoGroupSelector(form);
|
|
}
|