|
1 |
| -import $ from 'jquery'; |
2 | 1 | import {hideElem, showElem, toggleElem} from '../utils/dom.js';
|
3 | 2 |
|
4 |
| -const $service = $('#service_type'); |
5 |
| -const $user = $('#auth_username'); |
6 |
| -const $pass = $('#auth_password'); |
7 |
| -const $token = $('#auth_token'); |
8 |
| -const $mirror = $('#mirror'); |
9 |
| -const $lfs = $('#lfs'); |
10 |
| -const $lfsSettings = $('#lfs_settings'); |
11 |
| -const $lfsEndpoint = $('#lfs_endpoint'); |
12 |
| -const $items = $('#migrate_items').find('input[type=checkbox]'); |
| 3 | +const service = document.getElementById('service_type'); |
| 4 | +const user = document.getElementById('auth_username'); |
| 5 | +const pass = document.getElementById('auth_password'); |
| 6 | +const token = document.getElementById('auth_token'); |
| 7 | +const mirror = document.getElementById('mirror'); |
| 8 | +const lfs = document.getElementById('lfs'); |
| 9 | +const lfsSettings = document.getElementById('lfs_settings'); |
| 10 | +const lfsEndpoint = document.getElementById('lfs_endpoint'); |
| 11 | +const items = document.querySelectorAll('#migrate_items input[type=checkbox]'); |
13 | 12 |
|
14 | 13 | export function initRepoMigration() {
|
15 | 14 | checkAuth();
|
16 | 15 | setLFSSettingsVisibility();
|
17 | 16 |
|
18 |
| - $user.on('input', () => {checkItems(false)}); |
19 |
| - $pass.on('input', () => {checkItems(false)}); |
20 |
| - $token.on('input', () => {checkItems(true)}); |
21 |
| - $mirror.on('change', () => {checkItems(true)}); |
22 |
| - $('#lfs_settings_show').on('click', () => { showElem($lfsEndpoint); return false }); |
23 |
| - $lfs.on('change', setLFSSettingsVisibility); |
24 |
| - |
25 |
| - const $cloneAddr = $('#clone_addr'); |
26 |
| - $cloneAddr.on('change', () => { |
27 |
| - const $repoName = $('#repo_name'); |
28 |
| - if ($cloneAddr.val().length > 0 && $repoName.val().length === 0) { // Only modify if repo_name input is blank |
29 |
| - $repoName.val($cloneAddr.val().match(/^(.*\/)?((.+?)(\.git)?)$/)[3]); |
| 17 | + user?.addEventListener('input', () => {checkItems(false)}); |
| 18 | + pass?.addEventListener('input', () => {checkItems(false)}); |
| 19 | + token?.addEventListener('input', () => {checkItems(true)}); |
| 20 | + mirror?.addEventListener('change', () => {checkItems(true)}); |
| 21 | + document.getElementById('lfs_settings_show')?.addEventListener('click', (e) => { |
| 22 | + e.preventDefault(); |
| 23 | + e.stopPropagation(); |
| 24 | + showElem(lfsEndpoint); |
| 25 | + }); |
| 26 | + lfs?.addEventListener('change', setLFSSettingsVisibility); |
| 27 | + |
| 28 | + const cloneAddr = document.getElementById('clone_addr'); |
| 29 | + cloneAddr?.addEventListener('change', () => { |
| 30 | + const repoName = document.getElementById('repo_name'); |
| 31 | + if (cloneAddr.value && !repoName?.value) { // Only modify if repo_name input is blank |
| 32 | + repoName.value = cloneAddr.value.match(/^(.*\/)?((.+?)(\.git)?)$/)[3]; |
30 | 33 | }
|
31 | 34 | });
|
32 | 35 | }
|
33 | 36 |
|
34 | 37 | function checkAuth() {
|
35 |
| - const serviceType = $service.val(); |
| 38 | + if (!service) return; |
| 39 | + const serviceType = Number(service.value); |
36 | 40 |
|
37 | 41 | checkItems(serviceType !== 1);
|
38 | 42 | }
|
39 | 43 |
|
40 | 44 | function checkItems(tokenAuth) {
|
41 | 45 | let enableItems;
|
42 | 46 | if (tokenAuth) {
|
43 |
| - enableItems = $token.val() !== ''; |
| 47 | + enableItems = token?.value !== ''; |
44 | 48 | } else {
|
45 |
| - enableItems = $user.val() !== '' || $pass.val() !== ''; |
| 49 | + enableItems = user?.value !== '' || pass?.value !== ''; |
46 | 50 | }
|
47 |
| - if (enableItems && $service.val() > 1) { |
48 |
| - if ($mirror.is(':checked')) { |
49 |
| - $items.not('[name="wiki"]').attr('disabled', true); |
50 |
| - $items.filter('[name="wiki"]').attr('disabled', false); |
| 51 | + if (enableItems && Number(service?.value) > 1) { |
| 52 | + if (mirror?.checked) { |
| 53 | + for (const item of items) { |
| 54 | + item.disabled = item.name !== 'wiki'; |
| 55 | + } |
51 | 56 | return;
|
52 | 57 | }
|
53 |
| - $items.attr('disabled', false); |
| 58 | + for (const item of items) item.disabled = false; |
54 | 59 | } else {
|
55 |
| - $items.attr('disabled', true); |
| 60 | + for (const item of items) item.disabled = true; |
56 | 61 | }
|
57 | 62 | }
|
58 | 63 |
|
59 | 64 | function setLFSSettingsVisibility() {
|
60 |
| - const visible = $lfs.is(':checked'); |
61 |
| - toggleElem($lfsSettings, visible); |
62 |
| - hideElem($lfsEndpoint); |
| 65 | + if (!lfs) return; |
| 66 | + const visible = lfs.checked; |
| 67 | + toggleElem(lfsSettings, visible); |
| 68 | + hideElem(lfsEndpoint); |
63 | 69 | }
|
0 commit comments