summaryrefslogtreecommitdiffstats
path: root/web_src/js/features/migration.js
diff options
context:
space:
mode:
Diffstat (limited to 'web_src/js/features/migration.js')
-rw-r--r--web_src/js/features/migration.js53
1 files changed, 53 insertions, 0 deletions
diff --git a/web_src/js/features/migration.js b/web_src/js/features/migration.js
new file mode 100644
index 0000000000..e4c306307f
--- /dev/null
+++ b/web_src/js/features/migration.js
@@ -0,0 +1,53 @@
+const $service = $('#service_type');
+const $user = $('#auth_username');
+const $pass = $('#auth_password');
+const $token = $('#auth_token');
+const $items = $('#migrate_items').find('.field');
+
+export default function initMigration() {
+ checkAuth();
+
+ $service.on('change', checkAuth);
+ $user.on('keyup', () => {checkItems(false)});
+ $pass.on('keyup', () => {checkItems(false)});
+ $token.on('keyup', () => {checkItems(true)});
+
+ const $cloneAddr = $('#clone_addr');
+ $cloneAddr.on('change', () => {
+ const $repoName = $('#repo_name');
+ if ($cloneAddr.val().length > 0 && $repoName.val().length === 0) { // Only modify if repo_name input is blank
+ $repoName.val($cloneAddr.val().match(/^(.*\/)?((.+?)(\.git)?)$/)[3]);
+ }
+ });
+}
+
+function checkAuth() {
+ const serviceType = $service.val();
+ const tokenAuth = $(`#service-${serviceType}`).data('token');
+
+ if (tokenAuth) {
+ $user.parent().addClass('disabled');
+ $pass.parent().addClass('disabled');
+ $token.parent().removeClass('disabled');
+ } else {
+ $user.parent().removeClass('disabled');
+ $pass.parent().removeClass('disabled');
+ $token.parent().addClass('disabled');
+ }
+
+ checkItems(tokenAuth);
+}
+
+function checkItems(tokenAuth) {
+ let enableItems;
+ if (tokenAuth) {
+ enableItems = $token.val() !== '';
+ } else {
+ enableItems = $user.val() !== '' || $pass.val() !== '';
+ }
+ if (enableItems && $service.val() > 1) {
+ $items.removeClass('disabled');
+ } else {
+ $items.addClass('disabled');
+ }
+}