dispatcher.js 26.8 KB
Newer Older
1
/* eslint-disable func-names, space-before-function-paren, no-var, prefer-arrow-callback, wrap-iife, no-shadow, consistent-return, one-var, one-var-declaration-per-line, camelcase, default-case, no-new, quotes, no-duplicate-case, no-case-declarations, no-fallthrough, max-len */
2
import { s__ } from './locale';
3
import projectSelect from './project_select';
F
Filipa Lacerda 已提交
4
import IssuableIndex from './issuable_index';
F
Filipa Lacerda 已提交
5
import Milestone from './milestone';
6
import IssuableForm from './issuable_form';
7
import LabelsSelect from './labels_select';
C
Constance Okoghenun 已提交
8
import MilestoneSelect from './milestone_select';
F
Filipa Lacerda 已提交
9
import NewBranchForm from './new_branch_form';
P
Phil Hughes 已提交
10 11
import NotificationsForm from './notifications_form';
import notificationsDropdown from './notifications_dropdown';
12 13
import groupAvatar from './group_avatar';
import GroupLabelSubscription from './group_label_subscription';
P
Phil Hughes 已提交
14
import LineHighlighter from './line_highlighter';
15
import CILintEditor from './ci_lint_editor';
16
import groupsSelect from './groups_select';
F
Filipa Lacerda 已提交
17
import Search from './search';
18
import initAdmin from './admin';
W
Winnie Hellmann 已提交
19
import NamespaceSelect from './namespace_select';
F
Filipa Lacerda 已提交
20
import NewCommitForm from './new_commit_form';
21 22
import Project from './project';
import projectAvatar from './project_avatar';
P
Phil Hughes 已提交
23
import MergeRequest from './merge_request';
24
import Compare from './compare';
25
import initCompareAutocomplete from './compare_autocomplete';
F
Filipa Lacerda 已提交
26
import ProjectFindFile from './project_find_file';
27
import ProjectNew from './project_new';
28
import projectImport from './project_import';
29 30
import Labels from './labels';
import LabelManager from './label_manager';
P
Phil Hughes 已提交
31
import Sidebar from './right_sidebar';
32
import IssuableTemplateSelectors from './templates/issuable_template_selectors';
33
import Flash from './flash';
34
import CommitsList from './commits';
35
import Issue from './issue';
Z
Z.J. van de Weg 已提交
36
import BindInOut from './behaviors/bind_in_out';
37
import SecretValues from './behaviors/secret_values';
38
import DeleteModal from './branches/branches_delete_modal';
39
import Group from './group';
F
Filipa Lacerda 已提交
40
import GroupsList from './groups_list';
41
import ProjectsList from './projects_list';
42
import setupProjectEdit from './project_edit';
43
import MiniPipelineGraph from './mini_pipeline_graph_dropdown';
44
import BlobLinePermalinkUpdater from './blob/blob_line_permalink_updater';
45
import Landing from './landing';
E
Eric Eastwood 已提交
46
import BlobForkSuggestion from './blob/blob_fork_suggestion';
M
Mike Greiling 已提交
47
import UserCallout from './user_callout';
G
geoandri 已提交
48
import ShortcutsWiki from './shortcuts_wiki';
49
import Pipelines from './pipelines';
D
Douwe Maan 已提交
50
import BlobViewer from './blob/viewer/index';
51
import AutoWidthDropdownSelect from './issuable/auto_width_dropdown_select';
52
import UsersSelect from './users_select';
53
import RefSelectDropdown from './ref_select_dropdown';
54
import GfmAutoComplete from './gfm_auto_complete';
55
import ShortcutsBlob from './shortcuts_blob';
56
import SigninTabsMemoizer from './signin_tabs_memoizer';
57
import Star from './star';
58
import TreeView from './tree';
59
import UsagePing from './usage_ping';
60
import UsernameValidator from './username_validator';
61
import VersionCheckImage from './version_check_image';
62
import Wikis from './wikis';
63
import ZenMode from './zen_mode';
64
import initSettingsPanels from './settings_panels';
65
import initExperimentalFlags from './experimental_flags';
66
import OAuthRememberMe from './oauth_remember_me';
67
import PerformanceBar from './performance_bar';
M
Mike Greiling 已提交
68
import initBroadcastMessagesForm from './broadcast_message';
P
Phil Hughes 已提交
69 70 71
import initNotes from './init_notes';
import initLegacyFilters from './init_legacy_filters';
import initIssuableSidebar from './init_issuable_sidebar';
72
import initProjectVisibilitySelector from './project_visibility';
73
import GpgBadges from './gpg_badges';
74
import initChangesDropdown from './init_changes_dropdown';
75
import NewGroupChild from './groups/new_group_child';
76
import AbuseReports from './abuse_reports';
77
import { ajaxGet, convertPermissionToBoolean } from './lib/utils/common_utils';
78
import AjaxLoadingSpinner from './ajax_loading_spinner';
79 80
import GlFieldErrors from './gl_field_errors';
import GLForm from './gl_form';
81 82 83 84
import Shortcuts from './shortcuts';
import ShortcutsNavigation from './shortcuts_navigation';
import ShortcutsFindFile from './shortcuts_find_file';
import ShortcutsIssuable from './shortcuts_issuable';
F
Filipa Lacerda 已提交
85
import U2FAuthenticate from './u2f/authenticate';
86 87
import Members from './members';
import memberExpirationDate from './member_expiration_date';
F
Filipa Lacerda 已提交
88
import DueDateSelectors from './due_date_select';
89
import Diff from './diff';
90
import ProjectLabelSubscription from './project_label_subscription';
F
Filipa Lacerda 已提交
91
import SearchAutocomplete from './search_autocomplete';
92
import Activities from './activities';
93

F
Fatih Acet 已提交
94 95 96 97 98 99
(function() {
  var Dispatcher;

  Dispatcher = (function() {
    function Dispatcher() {
      this.initSearch();
100
      this.initFieldErrors();
F
Fatih Acet 已提交
101 102 103 104
      this.initPageScripts();
    }

    Dispatcher.prototype.initPageScripts = function() {
105 106
      var path, shortcut_handler, fileBlobPermalinkUrlElement, fileBlobPermalinkUrl;
      const page = $('body').attr('data-page');
F
Fatih Acet 已提交
107 108 109
      if (!page) {
        return false;
      }
110

111
      const fail = () => Flash('Error loading dynamic module');
112
      const callDefault = m => m.default();
113

F
Fatih Acet 已提交
114 115
      path = page.split(':');
      shortcut_handler = null;
116

F
Filipa Lacerda 已提交
117
      $('.js-gfm-input:not(.js-vue-textarea)').each((i, el) => {
118
        const gfm = new GfmAutoComplete(gl.GfmAutoComplete && gl.GfmAutoComplete.dataSources);
119
        const enableGFM = convertPermissionToBoolean(el.dataset.supportsAutocomplete);
120 121 122 123 124 125 126 127 128
        gfm.setup($(el), {
          emojis: true,
          members: enableGFM,
          issues: enableGFM,
          milestones: enableGFM,
          mergeRequests: enableGFM,
          labels: enableGFM,
        });
      });
129

130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
      function initBlob() {
        new LineHighlighter();

        new BlobLinePermalinkUpdater(
          document.querySelector('#blob-content-holder'),
          '.diff-line-num[data-line-number]',
          document.querySelectorAll('.js-data-file-blob-permalink-url, .js-blob-blame-link'),
        );

        shortcut_handler = new ShortcutsNavigation();
        fileBlobPermalinkUrlElement = document.querySelector('.js-data-file-blob-permalink-url');
        fileBlobPermalinkUrl = fileBlobPermalinkUrlElement && fileBlobPermalinkUrlElement.getAttribute('href');
        new ShortcutsBlob({
          skipResetBindings: true,
          fileBlobPermalinkUrl,
        });
E
Eric Eastwood 已提交
146

147 148 149 150 151 152
        new BlobForkSuggestion({
          openButtons: document.querySelectorAll('.js-edit-blob-link-fork-toggler'),
          forkButtons: document.querySelectorAll('.js-fork-suggestion-button'),
          cancelButtons: document.querySelectorAll('.js-cancel-fork-suggestion-button'),
          suggestionSections: document.querySelectorAll('.js-file-fork-suggestion-section'),
          actionTextPieces: document.querySelectorAll('.js-file-fork-suggestion-section-action'),
153 154
        })
          .init();
155 156
      }

157 158
      const filteredSearchEnabled = gl.FilteredSearchManager && document.querySelector('.filtered-search');

F
Fatih Acet 已提交
159
      switch (page) {
160 161 162
        case 'profiles:preferences:show':
          initExperimentalFlags();
          break;
163 164
        case 'sessions:new':
          new UsernameValidator();
165
          new SigninTabsMemoizer();
166
          new OAuthRememberMe({ container: $(".omniauth-container") }).bindEvents();
167
          break;
168
        case 'projects:boards:show':
169
        case 'projects:boards:index':
170
          shortcut_handler = new ShortcutsNavigation();
171
          new UsersSelect();
172
          break;
173
        case 'projects:merge_requests:index':
F
Fatih Acet 已提交
174
        case 'projects:issues:index':
175
          if (filteredSearchEnabled) {
176 177
            const filteredSearchManager = new gl.FilteredSearchManager(page === 'projects:issues:index' ? 'issues' : 'merge_requests');
            filteredSearchManager.setup();
C
Clement Ho 已提交
178
          }
179
          const pagePrefix = page === 'projects:merge_requests:index' ? 'merge_request_' : 'issue_';
F
Filipa Lacerda 已提交
180
          new IssuableIndex(pagePrefix);
181

F
Fatih Acet 已提交
182
          shortcut_handler = new ShortcutsNavigation();
183
          new UsersSelect();
F
Fatih Acet 已提交
184 185 186 187 188
          break;
        case 'projects:issues:show':
          new Issue();
          shortcut_handler = new ShortcutsIssuable();
          new ZenMode();
189
          initIssuableSidebar();
F
Fatih Acet 已提交
190
          break;
P
Phil Hughes 已提交
191
        case 'dashboard:milestones:index':
192 193 194
          import('./pages/dashboard/milestones/index')
            .then(callDefault)
            .catch(fail);
P
Phil Hughes 已提交
195
          break;
F
Fatih Acet 已提交
196 197 198
        case 'projects:milestones:show':
        case 'groups:milestones:show':
          new Milestone();
199
          new Sidebar();
F
Fatih Acet 已提交
200
          break;
201 202 203 204 205
        case 'dashboard:milestones:show':
          import('./pages/dashboard/milestones/show')
            .then(callDefault)
            .catch(fail);
          break;
206
        case 'dashboard:issues':
C
Clement Ho 已提交
207 208 209
          import('./pages/dashboard/issues')
            .then(callDefault)
            .catch(fail);
C
Clement Ho 已提交
210
          break;
211
        case 'dashboard:merge_requests':
212
          projectSelect();
213
          initLegacyFilters();
214
          break;
215
        case 'groups:issues':
216
        case 'groups:merge_requests':
217
          if (filteredSearchEnabled) {
218
            const filteredSearchManager = new gl.FilteredSearchManager(page === 'groups:issues' ? 'issues' : 'merge_requests');
219 220
            filteredSearchManager.setup();
          }
221
          projectSelect();
222
          break;
F
Fatih Acet 已提交
223
        case 'dashboard:todos:index':
224
          import('./pages/dashboard/todos/index').then(callDefault).catch(fail);
F
Fatih Acet 已提交
225
          break;
226 227
        case 'dashboard:projects:index':
        case 'dashboard:projects:starred':
C
Clement Ho 已提交
228 229 230
          import('./pages/dashboard/projects')
            .then(callDefault)
            .catch(fail);
231
          break;
232 233 234 235 236 237
        case 'explore:projects:index':
        case 'explore:projects:trending':
        case 'explore:projects:starred':
        case 'admin:projects:index':
          new ProjectsList();
          break;
F
Filipa Lacerda 已提交
238 239
        case 'explore:groups:index':
          new GroupsList();
240 241 242 243 244 245 246 247
          const landingElement = document.querySelector('.js-explore-groups-landing');
          if (!landingElement) break;
          const exploreGroupsLanding = new Landing(
            landingElement,
            landingElement.querySelector('.dismiss-button'),
            'explore_groups_landing_dismissed',
          );
          exploreGroupsLanding.toggle();
F
Filipa Lacerda 已提交
248
          break;
F
Fatih Acet 已提交
249 250
        case 'projects:milestones:new':
        case 'projects:milestones:edit':
251
        case 'projects:milestones:update':
252 253 254 255
          new ZenMode();
          new DueDateSelectors();
          new GLForm($('.milestone-form'), true);
          break;
256 257 258
        case 'groups:milestones:new':
        case 'groups:milestones:edit':
        case 'groups:milestones:update':
F
Fatih Acet 已提交
259
          new ZenMode();
F
Filipa Lacerda 已提交
260
          new DueDateSelectors();
261
          new GLForm($('.milestone-form'), false);
F
Fatih Acet 已提交
262 263
          break;
        case 'projects:compare:show':
264
          new Diff();
265 266
          const paddingTop = 16;
          initChangesDropdown(document.querySelector('.navbar-gitlab').offsetHeight - paddingTop);
F
Fatih Acet 已提交
267
          break;
268 269 270 271
        case 'projects:branches:new':
        case 'projects:branches:create':
          new NewBranchForm($('.js-create-branch-form'), JSON.parse(document.getElementById('availableRefs').innerHTML));
          break;
272
        case 'projects:branches:index':
273
          AjaxLoadingSpinner.init();
274
          new DeleteModal();
275
          break;
F
Fatih Acet 已提交
276 277 278
        case 'projects:issues:new':
        case 'projects:issues:edit':
          shortcut_handler = new ShortcutsNavigation();
279
          new GLForm($('.issue-form'), true);
F
Fatih Acet 已提交
280
          new IssuableForm($('.issue-form'));
281 282
          new LabelsSelect();
          new MilestoneSelect();
283
          new IssuableTemplateSelectors();
F
Fatih Acet 已提交
284
          break;
D
Douwe Maan 已提交
285
        case 'projects:merge_requests:creations:new':
286 287 288 289 290 291 292 293 294 295 296 297 298
          const mrNewCompareNode = document.querySelector('.js-merge-request-new-compare');
          if (mrNewCompareNode) {
            new Compare({
              targetProjectUrl: mrNewCompareNode.dataset.targetProjectUrl,
              sourceBranchUrl: mrNewCompareNode.dataset.sourceBranchUrl,
              targetBranchUrl: mrNewCompareNode.dataset.targetBranchUrl,
            });
          } else {
            const mrNewSubmitNode = document.querySelector('.js-merge-request-new-submit');
            new MergeRequest({
              action: mrNewSubmitNode.dataset.mrSubmitAction,
            });
          }
D
Douwe Maan 已提交
299
        case 'projects:merge_requests:creations:diffs':
F
Fatih Acet 已提交
300
        case 'projects:merge_requests:edit':
301
          new Diff();
F
Fatih Acet 已提交
302
          shortcut_handler = new ShortcutsNavigation();
303
          new GLForm($('.merge-request-form'), true);
F
Fatih Acet 已提交
304
          new IssuableForm($('.merge-request-form'));
305 306
          new LabelsSelect();
          new MilestoneSelect();
307
          new IssuableTemplateSelectors();
308
          new AutoWidthDropdownSelect($('.js-target-branch-select')).init();
F
Fatih Acet 已提交
309 310 311
          break;
        case 'projects:tags:new':
          new ZenMode();
312
          new GLForm($('.tag-form'), true);
313
          new RefSelectDropdown($('.js-branch-select'));
F
Fatih Acet 已提交
314
          break;
315 316
        case 'projects:snippets:show':
          initNotes();
F
Filipa Lacerda 已提交
317
          new ZenMode();
318
          break;
319 320 321 322
        case 'projects:snippets:new':
        case 'projects:snippets:edit':
        case 'projects:snippets:create':
        case 'projects:snippets:update':
323
          new GLForm($('.snippet-form'), true);
F
Filipa Lacerda 已提交
324
          new ZenMode();
325
          break;
326 327 328 329
        case 'snippets:new':
        case 'snippets:edit':
        case 'snippets:create':
        case 'snippets:update':
330
          new GLForm($('.snippet-form'), false);
F
Filipa Lacerda 已提交
331
          new ZenMode();
332
          break;
F
Fatih Acet 已提交
333 334
        case 'projects:releases:edit':
          new ZenMode();
335
          new GLForm($('.release-form'), true);
F
Fatih Acet 已提交
336 337
          break;
        case 'projects:merge_requests:show':
338
          new Diff();
F
Fatih Acet 已提交
339
          new ZenMode();
340

341 342
          initIssuableSidebar();
          initNotes();
343

344 345 346 347
          const mrShowNode = document.querySelector('.merge-request');
          window.mergeRequest = new MergeRequest({
            action: mrShowNode.dataset.mrAction,
          });
348 349

          shortcut_handler = new ShortcutsIssuable(true);
F
Fatih Acet 已提交
350 351
          break;
        case 'dashboard:activity':
352
          new Activities();
F
Fatih Acet 已提交
353 354
          break;
        case 'projects:commit:show':
355
          new Diff();
F
Fatih Acet 已提交
356 357
          new ZenMode();
          shortcut_handler = new ShortcutsNavigation();
358 359 360
          new MiniPipelineGraph({
            container: '.js-commit-pipeline-graph',
          }).bindEvents();
361
          initNotes();
P
Phil Hughes 已提交
362 363
          const stickyBarPaddingTop = 16;
          initChangesDropdown(document.querySelector('.navbar-gitlab').offsetHeight - stickyBarPaddingTop);
364
          $('.commit-info.branches').load(document.querySelector('.js-commit-box').dataset.commitPath);
F
Fatih Acet 已提交
365
          break;
366
        case 'projects:commit:pipelines':
367
          new MiniPipelineGraph({
368
            container: '.js-commit-pipeline-graph',
369
          }).bindEvents();
370
          $('.commit-info.branches').load(document.querySelector('.js-commit-box').dataset.commitPath);
371
          break;
372
        case 'projects:activity':
373 374 375 376
          import('./pages/projects/activity')
          .then(callDefault)
          .catch(fail);
          shortcut_handler = true;
377
          break;
378 379
        case 'projects:commits:show':
          CommitsList.init(document.querySelector('.js-project-commits-show').dataset.commitsLimit);
F
Fatih Acet 已提交
380
          shortcut_handler = new ShortcutsNavigation();
381
          GpgBadges.fetch();
F
Fatih Acet 已提交
382 383 384 385
          break;
        case 'projects:show':
          shortcut_handler = new ShortcutsNavigation();
          new NotificationsForm();
F
Filipa Lacerda 已提交
386 387 388 389
          new UserCallout({
            setCalloutPerProject: true,
            className: 'js-autodevops-banner',
          });
390 391

          if ($('#tree-slider').length) new TreeView();
392
          if ($('.blob-viewer').length) new BlobViewer();
393
          if ($('.project-show-activity').length) new Activities();
394
          $('#tree-slider').waitForImages(function() {
F
Filipa Lacerda 已提交
395
            ajaxGet(document.querySelector('.js-tree-content').dataset.logsPath);
396
          });
F
Fatih Acet 已提交
397
          break;
398
        case 'projects:edit':
399
          setupProjectEdit();
400 401
          // Initialize expandable settings panels
          initSettingsPanels();
402
          break;
403
        case 'projects:imports:show':
404
          projectImport();
405
          break;
406
        case 'projects:pipelines:new':
407
        case 'projects:pipelines:create':
408
          new NewBranchForm($('.js-new-pipeline-form'));
409
          break;
F
Filipa Lacerda 已提交
410
        case 'projects:pipelines:builds':
411
        case 'projects:pipelines:failures':
L
Luke Bennett 已提交
412
        case 'projects:pipelines:show':
F
Filipa Lacerda 已提交
413
          const { controllerAction } = document.querySelector('.js-pipeline-container').dataset;
414
          const pipelineStatusUrl = `${document.querySelector('.js-pipeline-tab-link a').getAttribute('href')}/status.json`;
F
Filipa Lacerda 已提交
415

416
          new Pipelines({
F
Filipa Lacerda 已提交
417
            initTabs: true,
418
            pipelineStatusUrl,
F
Filipa Lacerda 已提交
419 420 421 422 423 424
            tabsOptions: {
              action: controllerAction,
              defaultAction: 'pipelines',
              parentEl: '.pipelines-tabs',
            },
          });
L
Luke Bennett 已提交
425
          break;
F
Fatih Acet 已提交
426
        case 'groups:activity':
427
          new Activities();
F
Fatih Acet 已提交
428 429
          break;
        case 'groups:show':
430
          const newGroupChildWrapper = document.querySelector('.js-new-project-subgroup');
F
Fatih Acet 已提交
431 432
          shortcut_handler = new ShortcutsNavigation();
          new NotificationsForm();
P
Phil Hughes 已提交
433
          notificationsDropdown();
434
          new ProjectsList();
435 436 437 438

          if (newGroupChildWrapper) {
            new NewGroupChild(newGroupChildWrapper);
          }
F
Fatih Acet 已提交
439 440
          break;
        case 'groups:group_members:index':
441 442
          memberExpirationDate();
          new Members();
F
Fatih Acet 已提交
443 444
          new UsersSelect();
          break;
445
        case 'projects:project_members:index':
446
          memberExpirationDate('.js-access-expiration-date-groups');
447
          groupsSelect();
448 449
          memberExpirationDate();
          new Members();
F
Fatih Acet 已提交
450 451 452
          new UsersSelect();
          break;
        case 'groups:new':
L
Luke "Jared" Bennett 已提交
453
        case 'admin:groups:new':
454 455
        case 'groups:create':
        case 'admin:groups:create':
Z
Z.J. van de Weg 已提交
456
          BindInOut.initAll();
457
          new Group();
458
          groupAvatar();
459
          break;
F
Fatih Acet 已提交
460 461
        case 'groups:edit':
        case 'admin:groups:edit':
462
          groupAvatar();
F
Fatih Acet 已提交
463
          break;
464 465 466 467
        case 'projects:tree:show':
          shortcut_handler = new ShortcutsNavigation();
          new TreeView();
          new BlobViewer();
468
          new NewCommitForm($('.js-create-dir-form'));
T
Tim Zallmann 已提交
469
          $('#tree-slider').waitForImages(function() {
F
Filipa Lacerda 已提交
470
            ajaxGet(document.querySelector('.js-tree-content').dataset.logsPath);
T
Tim Zallmann 已提交
471
          });
472
          break;
F
Fatih Acet 已提交
473
        case 'projects:find_file:show':
474 475 476 477 478 479 480
          const findElement = document.querySelector('.js-file-finder');
          const projectFindFile = new ProjectFindFile($(".file-finder-holder"), {
            url: findElement.dataset.fileFindUrl,
            treeUrl: findElement.dataset.findTreeUrl,
            blobUrlTemplate: findElement.dataset.blobUrlTemplate,
          });
          new ShortcutsFindFile(projectFindFile);
F
Fatih Acet 已提交
481 482
          shortcut_handler = true;
          break;
483 484 485 486
        case 'projects:blob:show':
          new BlobViewer();
          initBlob();
          break;
F
Fatih Acet 已提交
487
        case 'projects:blame:show':
488
          initBlob();
F
Fatih Acet 已提交
489
          break;
490 491
        case 'groups:labels:new':
        case 'groups:labels:edit':
F
Fatih Acet 已提交
492 493 494 495
        case 'projects:labels:new':
        case 'projects:labels:edit':
          new Labels();
          break;
496
        case 'groups:labels:index':
F
Fatih Acet 已提交
497 498
        case 'projects:labels:index':
          if ($('.prioritized-labels').length) {
499
            new LabelManager();
F
Fatih Acet 已提交
500
          }
501 502 503 504
          $('.label-subscription').each((i, el) => {
            const $el = $(el);

            if ($el.find('.dropdown-group-label').length) {
505
              new GroupLabelSubscription($el);
506
            } else {
507
              new ProjectLabelSubscription($el);
508 509
            }
          });
F
Fatih Acet 已提交
510 511
          break;
        case 'projects:network:show':
512 513
          // Ensure we don't create a particular shortcut handler here. This is
          // already created, where the network graph is created.
F
Fatih Acet 已提交
514 515 516
          shortcut_handler = true;
          break;
        case 'projects:forks:new':
517 518 519
          import(/* webpackChunkName: 'project_fork' */ './project_fork')
            .then(fork => fork.default())
            .catch(() => {});
F
Fatih Acet 已提交
520 521
          break;
        case 'projects:artifacts:browse':
522 523 524 525
          import('./pages/projects/artifacts/browse')
          .then(callDefault)
          .catch(fail);
          shortcut_handler = true;
F
Fatih Acet 已提交
526
          break;
527
        case 'projects:artifacts:file':
528 529 530 531
          import('./pages/projects/artifacts/file')
          .then(callDefault)
          .catch(fail);
          shortcut_handler = true;
532
          break;
533
        case 'help:index':
534
          VersionCheckImage.bindErrorEvent($('img.js-version-status-badge'));
535
          break;
F
Fatih Acet 已提交
536 537
        case 'search:show':
          new Search();
538
          break;
D
Douwe Maan 已提交
539
        case 'projects:settings:repository:show':
540 541
          // Initialize expandable settings panels
          initSettingsPanels();
542
          break;
D
Douwe Maan 已提交
543
        case 'projects:settings:ci_cd:show':
544 545
          // Initialize expandable settings panels
          initSettingsPanels();
546 547 548 549 550 551

          const runnerToken = document.querySelector('.js-secret-runner-token');
          if (runnerToken) {
            const runnerTokenSecretValue = new SecretValues(runnerToken);
            runnerTokenSecretValue.init();
          }
S
Shinya Maeda 已提交
552
        case 'groups:settings:ci_cd:show':
553 554 555 556 557
          const secretVariableTable = document.querySelector('.js-secret-variable-table');
          if (secretVariableTable) {
            const secretVariableTableValues = new SecretValues(secretVariableTable);
            secretVariableTableValues.init();
          }
S
Stan Hu 已提交
558
          break;
559 560
        case 'ci:lints:create':
        case 'ci:lints:show':
561
          import('./pages/ci/lints').then(m => m.default()).catch(fail);
562
          break;
563
        case 'users:show':
564
          import('./pages/users/show').then(callDefault).catch(fail);
565
          break;
566
        case 'admin:conversational_development_index:show':
567
          import('./pages/admin/conversational_development_index/show').then(m => m.default()).catch(fail);
568
          break;
D
Douwe Maan 已提交
569
        case 'snippets:show':
570
          import('./pages/snippets/show').then(m => m.default()).catch(fail);
D
Douwe Maan 已提交
571
          break;
572
        case 'import:fogbugz:new_user_map':
573
          import('./pages/import/fogbugz/new_user_map').then(m => m.default()).catch(fail);
574
          break;
575 576
        case 'profiles:personal_access_tokens:index':
        case 'admin:impersonation_tokens:index':
F
Filipa Lacerda 已提交
577
          new DueDateSelectors();
578
          break;
F
Filipa Lacerda 已提交
579
        case 'projects:clusters:show':
580
          import(/* webpackChunkName: "clusters" */ './clusters/clusters_bundle')
F
Filipa Lacerda 已提交
581
            .then(cluster => new cluster.default()) // eslint-disable-line new-cap
582
            .catch((err) => {
583 584 585 586 587 588
              Flash(s__('ClusterIntegration|Problem setting up the cluster'));
              throw err;
            });
          break;
        case 'projects:clusters:index':
          import(/* webpackChunkName: "clusters_index" */ './clusters/clusters_index')
589
            .then(clusterIndex => clusterIndex.default())
590 591
            .catch((err) => {
              Flash(s__('ClusterIntegration|Problem setting up the clusters list'));
592 593
              throw err;
            });
F
Filipa Lacerda 已提交
594
          break;
F
Fatih Acet 已提交
595
      }
596
      switch (path[0]) {
597 598 599
        case 'sessions':
        case 'omniauth_callbacks':
          if (!gon.u2f) break;
F
Filipa Lacerda 已提交
600
          const u2fAuthenticate = new U2FAuthenticate(
601 602 603 604 605 606
            $('#js-authenticate-u2f'),
            '#js-login-u2f-form',
            gon.u2f,
            document.querySelector('#js-login-2fa-device'),
            document.querySelector('.js-2fa-form'),
          );
F
Filipa Lacerda 已提交
607 608 609
          u2fAuthenticate.start();
          // needed in rspec
          gl.u2fAuthenticate = u2fAuthenticate;
F
Fatih Acet 已提交
610
        case 'admin':
611
          initAdmin();
F
Fatih Acet 已提交
612
          switch (path[1]) {
M
Mike Greiling 已提交
613 614 615
            case 'broadcast_messages':
              initBroadcastMessagesForm();
              break;
S
Sean McGivern 已提交
616
            case 'cohorts':
617
              new UsagePing();
618
              break;
F
Fatih Acet 已提交
619 620 621 622
            case 'groups':
              new UsersSelect();
              break;
            case 'projects':
W
Winnie Hellmann 已提交
623 624
              document.querySelectorAll('.js-namespace-select')
                .forEach(dropdown => new NamespaceSelect({ dropdown }));
625 626
              break;
            case 'labels':
627
              switch (path[2]) {
628
                case 'new':
629 630 631
                case 'edit':
                  new Labels();
              }
632
            case 'abuse_reports':
633
              new AbuseReports();
634
              break;
F
Fatih Acet 已提交
635 636 637 638
          }
          break;
        case 'dashboard':
        case 'root':
639
          new UserCallout();
F
Fatih Acet 已提交
640 641 642
          break;
        case 'profiles':
          new NotificationsForm();
P
Phil Hughes 已提交
643
          notificationsDropdown();
F
Fatih Acet 已提交
644 645 646
          break;
        case 'projects':
          new Project();
647
          projectAvatar();
F
Fatih Acet 已提交
648 649
          switch (path[1]) {
            case 'compare':
650
              initCompareAutocomplete();
F
Fatih Acet 已提交
651 652 653 654
              break;
            case 'edit':
              shortcut_handler = new ShortcutsNavigation();
              new ProjectNew();
655 656 657
              import(/* webpackChunkName: 'project_permissions' */ './projects/permissions')
                .then(permissions => permissions.default())
                .catch(() => {});
F
Fatih Acet 已提交
658 659 660
              break;
            case 'new':
              new ProjectNew();
661
              initProjectVisibilitySelector();
F
Fatih Acet 已提交
662 663
              break;
            case 'show':
664
              new Star();
F
Fatih Acet 已提交
665
              new ProjectNew();
P
Phil Hughes 已提交
666
              notificationsDropdown();
F
Fatih Acet 已提交
667 668
              break;
            case 'wikis':
669
              new Wikis();
670
              shortcut_handler = new ShortcutsWiki();
F
Fatih Acet 已提交
671
              new ZenMode();
672
              new GLForm($('.wiki-form'), true);
F
Fatih Acet 已提交
673 674 675 676 677
              break;
            case 'snippets':
              shortcut_handler = new ShortcutsNavigation();
              if (path[2] === 'show') {
                new ZenMode();
D
Douwe Maan 已提交
678 679
                new LineHighlighter();
                new BlobViewer();
F
Fatih Acet 已提交
680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695
              }
              break;
            case 'labels':
            case 'graphs':
            case 'compare':
            case 'pipelines':
            case 'forks':
            case 'milestones':
            case 'project_members':
            case 'deploy_keys':
            case 'builds':
            case 'hooks':
            case 'services':
            case 'protected_branches':
              shortcut_handler = new ShortcutsNavigation();
          }
696
          break;
F
Fatih Acet 已提交
697
      }
698
      // If we haven't installed a custom shortcut handler, install the default one
F
Fatih Acet 已提交
699
      if (!shortcut_handler) {
700
        new Shortcuts();
F
Fatih Acet 已提交
701
      }
702 703 704 705

      if (document.querySelector('#peek')) {
        new PerformanceBar({ container: '#peek' });
      }
F
Fatih Acet 已提交
706 707 708
    };

    Dispatcher.prototype.initSearch = function() {
709
      // Only when search form is present
F
Fatih Acet 已提交
710
      if ($('.search').length) {
F
Filipa Lacerda 已提交
711
        return new SearchAutocomplete();
F
Fatih Acet 已提交
712 713 714
      }
    };

715
    Dispatcher.prototype.initFieldErrors = function() {
716
      $('.gl-show-field-errors').each((i, form) => {
717
        new GlFieldErrors(form);
718
      });
719 720
    };

F
Fatih Acet 已提交
721 722
    return Dispatcher;
  })();
723

724
  $(window).on('load', function() {
725 726
    new Dispatcher();
  });
727
}).call(window);