You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.9 KiB
67 lines
1.9 KiB
3 years ago
|
import {createMonaco} from './codeeditor.js';
|
||
|
import {initRepoCommonFilterSearchDropdown} from './repo-common.js';
|
||
|
|
||
|
const {AppSubUrl, csrf} = window.config;
|
||
|
|
||
|
export function initRepoSettingsCollaboration() {
|
||
|
// Change collaborator access mode
|
||
|
$('.access-mode.menu .item').on('click', function () {
|
||
|
const $menu = $(this).parent();
|
||
|
$.post($menu.data('url'), {
|
||
|
_csrf: csrf,
|
||
|
uid: $menu.data('uid'),
|
||
|
mode: $(this).data('value')
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
|
||
|
export function initRepoSettingSearchTeamBox() {
|
||
|
const $searchTeamBox = $('#search-team-box');
|
||
|
$searchTeamBox.search({
|
||
|
minCharacters: 2,
|
||
|
apiSettings: {
|
||
|
url: `${AppSubUrl}/api/v1/orgs/${$searchTeamBox.data('org')}/teams/search?q={query}`,
|
||
|
headers: {'X-Csrf-Token': csrf},
|
||
|
onResponse(response) {
|
||
|
const items = [];
|
||
|
$.each(response.data, (_i, item) => {
|
||
|
const title = `${item.name} (${item.permission} access)`;
|
||
|
items.push({
|
||
|
title,
|
||
|
});
|
||
|
});
|
||
|
|
||
|
return {results: items};
|
||
|
}
|
||
|
},
|
||
|
searchFields: ['name', 'description'],
|
||
|
showNoResults: false
|
||
|
});
|
||
|
}
|
||
|
|
||
|
|
||
|
export async function initRepoSettingGitHook() {
|
||
|
if ($('.edit.githook').length === 0) return;
|
||
|
const filename = document.querySelector('.hook-filename').textContent;
|
||
|
await createMonaco($('#content')[0], filename, {language: 'shell'});
|
||
|
}
|
||
|
|
||
|
export function initRepoSettingBranches() {
|
||
|
// Branches
|
||
|
if ($('.repository.settings.branches').length > 0) {
|
||
|
initRepoCommonFilterSearchDropdown('.protected-branches .dropdown');
|
||
|
$('.enable-protection, .enable-whitelist, .enable-statuscheck').on('change', function () {
|
||
|
if (this.checked) {
|
||
|
$($(this).data('target')).removeClass('disabled');
|
||
|
} else {
|
||
|
$($(this).data('target')).addClass('disabled');
|
||
|
}
|
||
|
});
|
||
|
$('.disable-whitelist').on('change', function () {
|
||
|
if (this.checked) {
|
||
|
$($(this).data('target')).addClass('disabled');
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
}
|