dispatcher.js 23 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 */
Phil Hughes's avatar
Phil Hughes committed
2
/* global ProjectSelect */
3
/* global ShortcutsNavigation */
4
/* global IssuableIndex */
5 6 7 8 9 10
/* global ShortcutsIssuable */
/* global Milestone */
/* global IssuableForm */
/* global LabelsSelect */
/* global MilestoneSelect */
/* global Commit */
11
/* global CommitsList */
12
/* global NewBranchForm */
13 14 15 16 17 18 19 20 21 22
/* global NotificationsForm */
/* global NotificationsDropdown */
/* global GroupAvatar */
/* global LineHighlighter */
/* global ProjectFork */
/* global BuildArtifacts */
/* global GroupsSelect */
/* global Search */
/* global Admin */
/* global NamespaceSelects */
23 24
/* global NewCommitForm */
/* global NewBranchForm */
25 26
/* global Project */
/* global ProjectAvatar */
27 28
/* global MergeRequest */
/* global Compare */
29
/* global CompareAutocomplete */
30
/* global ProjectFindFile */
31 32
/* global ProjectNew */
/* global ProjectShow */
33
/* global ProjectImport */
34 35
/* global Labels */
/* global Shortcuts */
36
/* global ShortcutsFindFile */
37
/* global Sidebar */
38
/* global ShortcutsWiki */
39

40
import Issue from './issue';
Z.J. van de Weg's avatar
Z.J. van de Weg committed
41
import BindInOut from './behaviors/bind_in_out';
42
import DeleteModal from './branches/branches_delete_modal';
43
import Group from './group';
44
import GroupsList from './groups_list';
45
import ProjectsList from './projects_list';
46
import setupProjectEdit from './project_edit';
47
import MiniPipelineGraph from './mini_pipeline_graph_dropdown';
48
import BlobLinePermalinkUpdater from './blob/blob_line_permalink_updater';
49
import Landing from './landing';
50
import BlobForkSuggestion from './blob/blob_fork_suggestion';
Mike Greiling's avatar
Mike Greiling committed
51
import UserCallout from './user_callout';
geoandri's avatar
geoandri committed
52
import ShortcutsWiki from './shortcuts_wiki';
53
import Pipelines from './pipelines';
Douwe Maan's avatar
Douwe Maan committed
54
import BlobViewer from './blob/viewer/index';
55
import AutoWidthDropdownSelect from './issuable/auto_width_dropdown_select';
56
import UsersSelect from './users_select';
57
import RefSelectDropdown from './ref_select_dropdown';
58
import GfmAutoComplete from './gfm_auto_complete';
59
import ShortcutsBlob from './shortcuts_blob';
60
import SigninTabsMemoizer from './signin_tabs_memoizer';
61
import Star from './star';
62
import Todos from './todos';
63
import TreeView from './tree';
64
import UsagePing from './usage_ping';
65
import UsernameValidator from './username_validator';
66
import VersionCheckImage from './version_check_image';
67
import Wikis from './wikis';
68
import ZenMode from './zen_mode';
69
import initSettingsPanels from './settings_panels';
70
import initExperimentalFlags from './experimental_flags';
71
import OAuthRememberMe from './oauth_remember_me';
72
import PerformanceBar from './performance_bar';
73 74 75
import initNotes from './init_notes';
import initLegacyFilters from './init_legacy_filters';
import initIssuableSidebar from './init_issuable_sidebar';
76
import initProjectVisibilitySelector from './project_visibility';
77
import GpgBadges from './gpg_badges';
78
import UserFeatureHelper from './helpers/user_feature_helper';
79
import initChangesDropdown from './init_changes_dropdown';
80
import { ajaxGet, convertPermissionToBoolean } from './lib/utils/common_utils';
81

Fatih Acet's avatar
Fatih Acet committed
82 83 84 85 86 87
(function() {
  var Dispatcher;

  Dispatcher = (function() {
    function Dispatcher() {
      this.initSearch();
88
      this.initFieldErrors();
Fatih Acet's avatar
Fatih Acet committed
89 90 91 92
      this.initPageScripts();
    }

    Dispatcher.prototype.initPageScripts = function() {
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
93
      var page, path, shortcut_handler, fileBlobPermalinkUrlElement, fileBlobPermalinkUrl;
Fatih Acet's avatar
Fatih Acet committed
94 95 96 97
      page = $('body').attr('data-page');
      if (!page) {
        return false;
      }
98

Fatih Acet's avatar
Fatih Acet committed
99 100
      path = page.split(':');
      shortcut_handler = null;
101

102
      $('.js-gfm-input:not(.js-vue-textarea)').each((i, el) => {
103
        const gfm = new GfmAutoComplete(gl.GfmAutoComplete && gl.GfmAutoComplete.dataSources);
104
        const enableGFM = convertPermissionToBoolean(el.dataset.supportsAutocomplete);
105 106 107 108 109 110 111 112 113
        gfm.setup($(el), {
          emojis: true,
          members: enableGFM,
          issues: enableGFM,
          milestones: enableGFM,
          mergeRequests: enableGFM,
          labels: enableGFM,
        });
      });
114

115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130
      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,
        });
131

132 133 134 135 136 137
        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'),
138 139
        })
          .init();
140 141
      }

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

Fatih Acet's avatar
Fatih Acet committed
144
      switch (page) {
145 146 147
        case 'profiles:preferences:show':
          initExperimentalFlags();
          break;
148 149
        case 'sessions:new':
          new UsernameValidator();
150
          new SigninTabsMemoizer();
151
          new OAuthRememberMe({ container: $(".omniauth-container") }).bindEvents();
152
          break;
153
        case 'projects:boards:show':
154
        case 'projects:boards:index':
155
          shortcut_handler = new ShortcutsNavigation();
156
          new UsersSelect();
157
          break;
158
        case 'projects:merge_requests:index':
Fatih Acet's avatar
Fatih Acet committed
159
        case 'projects:issues:index':
160
          if (filteredSearchEnabled) {
161 162
            const filteredSearchManager = new gl.FilteredSearchManager(page === 'projects:issues:index' ? 'issues' : 'merge_requests');
            filteredSearchManager.setup();
Clement Ho's avatar
Clement Ho committed
163
          }
164 165 166
          if (page === 'projects:merge_requests:index') {
            new UserCallout({ setCalloutPerProject: true });
          }
167 168 169
          const pagePrefix = page === 'projects:merge_requests:index' ? 'merge_request_' : 'issue_';
          IssuableIndex.init(pagePrefix);

Fatih Acet's avatar
Fatih Acet committed
170
          shortcut_handler = new ShortcutsNavigation();
171
          new UsersSelect();
Fatih Acet's avatar
Fatih Acet committed
172 173 174 175 176
          break;
        case 'projects:issues:show':
          new Issue();
          shortcut_handler = new ShortcutsIssuable();
          new ZenMode();
177
          initIssuableSidebar();
Fatih Acet's avatar
Fatih Acet committed
178
          break;
Phil Hughes's avatar
Phil Hughes committed
179 180 181
        case 'dashboard:milestones:index':
          new ProjectSelect();
          break;
Fatih Acet's avatar
Fatih Acet committed
182 183 184 185
        case 'projects:milestones:show':
        case 'groups:milestones:show':
        case 'dashboard:milestones:show':
          new Milestone();
186
          new Sidebar();
Fatih Acet's avatar
Fatih Acet committed
187
          break;
188 189
        case 'dashboard:issues':
        case 'dashboard:merge_requests':
Phil Hughes's avatar
Phil Hughes committed
190
          new ProjectSelect();
191
          initLegacyFilters();
192
          break;
193
        case 'groups:issues':
194
        case 'groups:merge_requests':
195
          if (filteredSearchEnabled) {
196
            const filteredSearchManager = new gl.FilteredSearchManager(page === 'groups:issues' ? 'issues' : 'merge_requests');
197 198 199 200
            filteredSearchManager.setup();
          }
          new ProjectSelect();
          break;
Fatih Acet's avatar
Fatih Acet committed
201
        case 'dashboard:todos:index':
202
          new Todos();
Fatih Acet's avatar
Fatih Acet committed
203
          break;
204 205 206 207 208 209 210 211
        case 'dashboard:projects:index':
        case 'dashboard:projects:starred':
        case 'explore:projects:index':
        case 'explore:projects:trending':
        case 'explore:projects:starred':
        case 'admin:projects:index':
          new ProjectsList();
          break;
212 213
        case 'explore:groups:index':
          new GroupsList();
214 215 216 217 218 219 220 221
          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();
222
          break;
Fatih Acet's avatar
Fatih Acet committed
223 224
        case 'projects:milestones:new':
        case 'projects:milestones:edit':
225
        case 'projects:milestones:update':
226 227 228
        case 'groups:milestones:new':
        case 'groups:milestones:edit':
        case 'groups:milestones:update':
Fatih Acet's avatar
Fatih Acet committed
229
          new ZenMode();
230
          new gl.DueDateSelectors();
231
          new gl.GLForm($('.milestone-form'), true);
Fatih Acet's avatar
Fatih Acet committed
232 233
          break;
        case 'projects:compare:show':
234
          new gl.Diff();
235
          initChangesDropdown();
Fatih Acet's avatar
Fatih Acet committed
236
          break;
237 238 239 240
        case 'projects:branches:new':
        case 'projects:branches:create':
          new NewBranchForm($('.js-create-branch-form'), JSON.parse(document.getElementById('availableRefs').innerHTML));
          break;
241 242
        case 'projects:branches:index':
          gl.AjaxLoadingSpinner.init();
243
          new DeleteModal();
244
          break;
Fatih Acet's avatar
Fatih Acet committed
245 246 247
        case 'projects:issues:new':
        case 'projects:issues:edit':
          shortcut_handler = new ShortcutsNavigation();
248
          new gl.GLForm($('.issue-form'), true);
Fatih Acet's avatar
Fatih Acet committed
249
          new IssuableForm($('.issue-form'));
250 251
          new LabelsSelect();
          new MilestoneSelect();
252
          new gl.IssuableTemplateSelectors();
Fatih Acet's avatar
Fatih Acet committed
253
          break;
254
        case 'projects:merge_requests:creations:new':
255 256 257 258 259 260 261 262 263 264 265 266 267
          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,
            });
          }
268
        case 'projects:merge_requests:creations:diffs':
Fatih Acet's avatar
Fatih Acet committed
269
        case 'projects:merge_requests:edit':
270
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
271
          shortcut_handler = new ShortcutsNavigation();
272
          new gl.GLForm($('.merge-request-form'), true);
Fatih Acet's avatar
Fatih Acet committed
273
          new IssuableForm($('.merge-request-form'));
274 275
          new LabelsSelect();
          new MilestoneSelect();
276
          new gl.IssuableTemplateSelectors();
277
          new AutoWidthDropdownSelect($('.js-target-branch-select')).init();
Fatih Acet's avatar
Fatih Acet committed
278 279 280
          break;
        case 'projects:tags:new':
          new ZenMode();
281
          new gl.GLForm($('.tag-form'), true);
282
          new RefSelectDropdown($('.js-branch-select'));
Fatih Acet's avatar
Fatih Acet committed
283
          break;
284 285 286
        case 'projects:snippets:show':
          initNotes();
          break;
287 288 289 290
        case 'projects:snippets:new':
        case 'projects:snippets:edit':
        case 'projects:snippets:create':
        case 'projects:snippets:update':
291 292
          new gl.GLForm($('.snippet-form'), true);
          break;
293 294 295 296
        case 'snippets:new':
        case 'snippets:edit':
        case 'snippets:create':
        case 'snippets:update':
297
          new gl.GLForm($('.snippet-form'), false);
298
          break;
Fatih Acet's avatar
Fatih Acet committed
299 300
        case 'projects:releases:edit':
          new ZenMode();
301
          new gl.GLForm($('.release-form'), true);
Fatih Acet's avatar
Fatih Acet committed
302 303
          break;
        case 'projects:merge_requests:show':
304
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
305 306
          shortcut_handler = new ShortcutsIssuable(true);
          new ZenMode();
307

308 309
          initIssuableSidebar();
          initNotes();
310

311 312 313 314
          const mrShowNode = document.querySelector('.merge-request');
          window.mergeRequest = new MergeRequest({
            action: mrShowNode.dataset.mrAction,
          });
Fatih Acet's avatar
Fatih Acet committed
315 316
          break;
        case 'dashboard:activity':
317
          new gl.Activities();
Fatih Acet's avatar
Fatih Acet committed
318 319 320
          break;
        case 'projects:commit:show':
          new Commit();
321
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
322 323
          new ZenMode();
          shortcut_handler = new ShortcutsNavigation();
324 325 326
          new MiniPipelineGraph({
            container: '.js-commit-pipeline-graph',
          }).bindEvents();
327
          initNotes();
328
          initChangesDropdown();
329
          $('.commit-info.branches').load(document.querySelector('.js-commit-box').dataset.commitPath);
Fatih Acet's avatar
Fatih Acet committed
330
          break;
331
        case 'projects:commit:pipelines':
332
          new MiniPipelineGraph({
333
            container: '.js-commit-pipeline-graph',
334
          }).bindEvents();
335
          $('.commit-info.branches').load(document.querySelector('.js-commit-box').dataset.commitPath);
336
          break;
337 338
        case 'projects:activity':
          new gl.Activities();
339 340
          shortcut_handler = new ShortcutsNavigation();
          break;
341 342
        case 'projects:commits:show':
          CommitsList.init(document.querySelector('.js-project-commits-show').dataset.commitsLimit);
Fatih Acet's avatar
Fatih Acet committed
343
          shortcut_handler = new ShortcutsNavigation();
344
          GpgBadges.fetch();
Fatih Acet's avatar
Fatih Acet committed
345 346 347 348
          break;
        case 'projects:show':
          shortcut_handler = new ShortcutsNavigation();
          new NotificationsForm();
349
          new UserCallout({ setCalloutPerProject: true });
350 351

          if ($('#tree-slider').length) new TreeView();
352
          if ($('.blob-viewer').length) new BlobViewer();
353
          if ($('.project-show-activity').length) new gl.Activities();
354
          $('#tree-slider').waitForImages(function() {
355
            ajaxGet(document.querySelector('.js-tree-content').dataset.logsPath);
356
          });
Fatih Acet's avatar
Fatih Acet committed
357
          break;
358
        case 'projects:edit':
359
          setupProjectEdit();
360 361
          // Initialize expandable settings panels
          initSettingsPanels();
362
          break;
363 364 365
        case 'projects:imports:show':
          new ProjectImport();
          break;
366
        case 'projects:pipelines:new':
367
          new NewBranchForm($('.js-new-pipeline-form'));
368
          break;
369
        case 'projects:pipelines:index':
370
          new UserCallout({ setCalloutPerProject: true });
371
          break;
Filipa Lacerda's avatar
Filipa Lacerda committed
372
        case 'projects:pipelines:builds':
373
        case 'projects:pipelines:failures':
Luke Bennett's avatar
Luke Bennett committed
374
        case 'projects:pipelines:show':
Filipa Lacerda's avatar
Filipa Lacerda committed
375
          const { controllerAction } = document.querySelector('.js-pipeline-container').dataset;
376
          const pipelineStatusUrl = `${document.querySelector('.js-pipeline-tab-link a').getAttribute('href')}/status.json`;
Filipa Lacerda's avatar
Filipa Lacerda committed
377

378
          new Pipelines({
Filipa Lacerda's avatar
Filipa Lacerda committed
379
            initTabs: true,
380
            pipelineStatusUrl,
Filipa Lacerda's avatar
Filipa Lacerda committed
381 382 383 384 385 386
            tabsOptions: {
              action: controllerAction,
              defaultAction: 'pipelines',
              parentEl: '.pipelines-tabs',
            },
          });
Luke Bennett's avatar
Luke Bennett committed
387
          break;
Fatih Acet's avatar
Fatih Acet committed
388
        case 'groups:activity':
389
          new gl.Activities();
Fatih Acet's avatar
Fatih Acet committed
390 391 392 393 394
          break;
        case 'groups:show':
          shortcut_handler = new ShortcutsNavigation();
          new NotificationsForm();
          new NotificationsDropdown();
395
          new ProjectsList();
Fatih Acet's avatar
Fatih Acet committed
396 397
          break;
        case 'groups:group_members:index':
398
          new gl.MemberExpirationDate();
399
          new gl.Members();
Fatih Acet's avatar
Fatih Acet committed
400 401
          new UsersSelect();
          break;
402
        case 'projects:project_members:index':
403 404
          new gl.MemberExpirationDate('.js-access-expiration-date-groups');
          new GroupsSelect();
405
          new gl.MemberExpirationDate();
406
          new gl.Members();
Fatih Acet's avatar
Fatih Acet committed
407 408 409
          new UsersSelect();
          break;
        case 'groups:new':
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
410
        case 'admin:groups:new':
411 412
        case 'groups:create':
        case 'admin:groups:create':
Z.J. van de Weg's avatar
Z.J. van de Weg committed
413
          BindInOut.initAll();
414 415 416
          new Group();
          new GroupAvatar();
          break;
Fatih Acet's avatar
Fatih Acet committed
417 418 419 420
        case 'groups:edit':
        case 'admin:groups:edit':
          new GroupAvatar();
          break;
421 422 423
        case 'projects:tree:show':
          shortcut_handler = new ShortcutsNavigation();

424
          if (UserFeatureHelper.isNewRepoEnabled()) break;
425 426 427

          new TreeView();
          new BlobViewer();
428
          new NewCommitForm($('.js-create-dir-form'));
429
          new UserCallout({ setCalloutPerProject: true });
430
          $('#tree-slider').waitForImages(function() {
431
            ajaxGet(document.querySelector('.js-tree-content').dataset.logsPath);
432
          });
433
          break;
Fatih Acet's avatar
Fatih Acet committed
434
        case 'projects:find_file:show':
435 436 437 438 439 440 441
          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);
Fatih Acet's avatar
Fatih Acet committed
442 443
          shortcut_handler = true;
          break;
444
        case 'projects:blob:show':
445
          if (UserFeatureHelper.isNewRepoEnabled()) break;
446 447 448
          new BlobViewer();
          initBlob();
          break;
Fatih Acet's avatar
Fatih Acet committed
449
        case 'projects:blame:show':
450
          initBlob();
Fatih Acet's avatar
Fatih Acet committed
451
          break;
452 453
        case 'groups:labels:new':
        case 'groups:labels:edit':
Fatih Acet's avatar
Fatih Acet committed
454 455 456 457
        case 'projects:labels:new':
        case 'projects:labels:edit':
          new Labels();
          break;
458
        case 'groups:labels:index':
Fatih Acet's avatar
Fatih Acet committed
459 460
        case 'projects:labels:index':
          if ($('.prioritized-labels').length) {
461
            new gl.LabelManager();
Fatih Acet's avatar
Fatih Acet committed
462
          }
463 464 465 466 467 468 469 470 471
          $('.label-subscription').each((i, el) => {
            const $el = $(el);

            if ($el.find('.dropdown-group-label').length) {
              new gl.GroupLabelSubscription($el);
            } else {
              new gl.ProjectLabelSubscription($el);
            }
          });
Fatih Acet's avatar
Fatih Acet committed
472 473
          break;
        case 'projects:network:show':
474 475
          // Ensure we don't create a particular shortcut handler here. This is
          // already created, where the network graph is created.
Fatih Acet's avatar
Fatih Acet committed
476 477 478 479 480 481
          shortcut_handler = true;
          break;
        case 'projects:forks:new':
          new ProjectFork();
          break;
        case 'projects:artifacts:browse':
482
          new ShortcutsNavigation();
Fatih Acet's avatar
Fatih Acet committed
483 484
          new BuildArtifacts();
          break;
485
        case 'projects:artifacts:file':
486
          new ShortcutsNavigation();
487 488
          new BlobViewer();
          break;
489
        case 'help:index':
490
          VersionCheckImage.bindErrorEvent($('img.js-version-status-badge'));
491
          break;
Fatih Acet's avatar
Fatih Acet committed
492 493
        case 'search:show':
          new Search();
494
          break;
495
        case 'projects:settings:repository:show':
496 497
          // Initialize expandable settings panels
          initSettingsPanels();
498
          break;
499
        case 'projects:settings:ci_cd:show':
500 501
          // Initialize expandable settings panels
          initSettingsPanels();
Shinya Maeda's avatar
Shinya Maeda committed
502
        case 'groups:settings:ci_cd:show':
503 504
          new gl.ProjectVariables();
          break;
505 506 507 508
        case 'ci:lints:create':
        case 'ci:lints:show':
          new gl.CILintEditor();
          break;
509 510 511
        case 'users:show':
          new UserCallout();
          break;
512 513 514
        case 'admin:conversational_development_index:show':
          new UserCallout();
          break;
Douwe Maan's avatar
Douwe Maan committed
515 516 517
        case 'snippets:show':
          new LineHighlighter();
          new BlobViewer();
518
          initNotes();
Douwe Maan's avatar
Douwe Maan committed
519
          break;
520 521 522
        case 'import:fogbugz:new_user_map':
          new UsersSelect();
          break;
523 524 525 526
        case 'profiles:personal_access_tokens:index':
        case 'admin:impersonation_tokens:index':
          new gl.DueDateSelectors();
          break;
Fatih Acet's avatar
Fatih Acet committed
527
      }
528
      switch (path[0]) {
529 530 531 532 533 534 535 536 537 538 539
        case 'sessions':
        case 'omniauth_callbacks':
          if (!gon.u2f) break;
          gl.u2fAuthenticate = new gl.U2FAuthenticate(
            $('#js-authenticate-u2f'),
            '#js-login-u2f-form',
            gon.u2f,
            document.querySelector('#js-login-2fa-device'),
            document.querySelector('.js-2fa-form'),
          );
          gl.u2fAuthenticate.start();
Fatih Acet's avatar
Fatih Acet committed
540 541 542
        case 'admin':
          new Admin();
          switch (path[1]) {
543
            case 'cohorts':
544
              new UsagePing();
545
              break;
Fatih Acet's avatar
Fatih Acet committed
546 547 548 549 550
            case 'groups':
              new UsersSelect();
              break;
            case 'projects':
              new NamespaceSelects();
551 552
              break;
            case 'labels':
553
              switch (path[2]) {
554
                case 'new':
555 556 557
                case 'edit':
                  new Labels();
              }
558
            case 'abuse_reports':
559
              new gl.AbuseReports();
560
              break;
Fatih Acet's avatar
Fatih Acet committed
561 562 563 564
          }
          break;
        case 'dashboard':
        case 'root':
565
          new UserCallout();
Fatih Acet's avatar
Fatih Acet committed
566 567 568 569 570 571 572 573 574 575 576 577 578 579 580
          break;
        case 'profiles':
          new NotificationsForm();
          new NotificationsDropdown();
          break;
        case 'projects':
          new Project();
          new ProjectAvatar();
          switch (path[1]) {
            case 'compare':
              new CompareAutocomplete();
              break;
            case 'edit':
              shortcut_handler = new ShortcutsNavigation();
              new ProjectNew();
581 582 583
              import(/* webpackChunkName: 'project_permissions' */ './projects/permissions')
                .then(permissions => permissions.default())
                .catch(() => {});
Fatih Acet's avatar
Fatih Acet committed
584 585 586
              break;
            case 'new':
              new ProjectNew();
587
              initProjectVisibilitySelector();
Fatih Acet's avatar
Fatih Acet committed
588 589
              break;
            case 'show':
590
              new Star();
Fatih Acet's avatar
Fatih Acet committed
591 592 593 594 595
              new ProjectNew();
              new ProjectShow();
              new NotificationsDropdown();
              break;
            case 'wikis':
596
              new Wikis();
597
              shortcut_handler = new ShortcutsWiki();
Fatih Acet's avatar
Fatih Acet committed
598
              new ZenMode();
599
              new gl.GLForm($('.wiki-form'), true);
Fatih Acet's avatar
Fatih Acet committed
600 601 602 603 604
              break;
            case 'snippets':
              shortcut_handler = new ShortcutsNavigation();
              if (path[2] === 'show') {
                new ZenMode();
Douwe Maan's avatar
Douwe Maan committed
605 606
                new LineHighlighter();
                new BlobViewer();
Fatih Acet's avatar
Fatih Acet committed
607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622
              }
              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();
          }
623 624 625 626 627 628 629
          break;
        case 'users':
          const action = path[1];
          import(/* webpackChunkName: 'user_profile' */ './users')
            .then(user => user.default(action))
            .catch(() => {});
          break;
Fatih Acet's avatar
Fatih Acet committed
630
      }
631
      // If we haven't installed a custom shortcut handler, install the default one
Fatih Acet's avatar
Fatih Acet committed
632
      if (!shortcut_handler) {
633
        new Shortcuts();
Fatih Acet's avatar
Fatih Acet committed
634
      }
635 636 637 638

      if (document.querySelector('#peek')) {
        new PerformanceBar({ container: '#peek' });
      }
Fatih Acet's avatar
Fatih Acet committed
639 640 641
    };

    Dispatcher.prototype.initSearch = function() {
642
      // Only when search form is present
Fatih Acet's avatar
Fatih Acet committed
643
      if ($('.search').length) {
644
        return new gl.SearchAutocomplete();
Fatih Acet's avatar
Fatih Acet committed
645 646 647
      }
    };

648
    Dispatcher.prototype.initFieldErrors = function() {
649
      $('.gl-show-field-errors').each((i, form) => {
650 651
        new gl.GlFieldErrors(form);
      });
652 653
    };

Fatih Acet's avatar
Fatih Acet committed
654 655
    return Dispatcher;
  })();
656

657
  $(window).on('load', function() {
658 659
    new Dispatcher();
  });
660
}).call(window);