dispatcher.js 27.5 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 groupsSelect from './groups_select';
F
Filipa Lacerda 已提交
16
import NewCommitForm from './new_commit_form';
17 18
import Project from './project';
import projectAvatar from './project_avatar';
P
Phil Hughes 已提交
19
import MergeRequest from './merge_request';
20
import Compare from './compare';
21
import initCompareAutocomplete from './compare_autocomplete';
F
Filipa Lacerda 已提交
22
import ProjectFindFile from './project_find_file';
23
import ProjectNew from './project_new';
24
import projectImport from './project_import';
25 26
import Labels from './labels';
import LabelManager from './label_manager';
P
Phil Hughes 已提交
27
import Sidebar from './right_sidebar';
28
import IssuableTemplateSelectors from './templates/issuable_template_selectors';
29
import Flash from './flash';
30
import CommitsList from './commits';
31
import Issue from './issue';
Z
Z.J. van de Weg 已提交
32
import BindInOut from './behaviors/bind_in_out';
33
import SecretValues from './behaviors/secret_values';
34
import DeleteModal from './branches/branches_delete_modal';
35
import Group from './group';
36
import ProjectsList from './projects_list';
37
import setupProjectEdit from './project_edit';
38
import MiniPipelineGraph from './mini_pipeline_graph_dropdown';
39
import BlobLinePermalinkUpdater from './blob/blob_line_permalink_updater';
E
Eric Eastwood 已提交
40
import BlobForkSuggestion from './blob/blob_fork_suggestion';
M
Mike Greiling 已提交
41
import UserCallout from './user_callout';
G
geoandri 已提交
42
import ShortcutsWiki from './shortcuts_wiki';
43
import Pipelines from './pipelines';
D
Douwe Maan 已提交
44
import BlobViewer from './blob/viewer/index';
45
import AutoWidthDropdownSelect from './issuable/auto_width_dropdown_select';
46
import UsersSelect from './users_select';
47
import RefSelectDropdown from './ref_select_dropdown';
48
import GfmAutoComplete from './gfm_auto_complete';
49
import ShortcutsBlob from './shortcuts_blob';
50
import Star from './star';
51
import TreeView from './tree';
52
import VersionCheckImage from './version_check_image';
53
import Wikis from './wikis';
54
import ZenMode from './zen_mode';
55
import initSettingsPanels from './settings_panels';
56
import initExperimentalFlags from './experimental_flags';
57
import PerformanceBar from './performance_bar';
P
Phil Hughes 已提交
58 59 60
import initNotes from './init_notes';
import initLegacyFilters from './init_legacy_filters';
import initIssuableSidebar from './init_issuable_sidebar';
61
import initProjectVisibilitySelector from './project_visibility';
62
import GpgBadges from './gpg_badges';
63
import initChangesDropdown from './init_changes_dropdown';
64
import NewGroupChild from './groups/new_group_child';
65
import { ajaxGet, convertPermissionToBoolean } from './lib/utils/common_utils';
66
import AjaxLoadingSpinner from './ajax_loading_spinner';
67 68
import GlFieldErrors from './gl_field_errors';
import GLForm from './gl_form';
69 70 71 72
import Shortcuts from './shortcuts';
import ShortcutsNavigation from './shortcuts_navigation';
import ShortcutsFindFile from './shortcuts_find_file';
import ShortcutsIssuable from './shortcuts_issuable';
F
Filipa Lacerda 已提交
73
import U2FAuthenticate from './u2f/authenticate';
74 75
import Members from './members';
import memberExpirationDate from './member_expiration_date';
F
Filipa Lacerda 已提交
76
import DueDateSelectors from './due_date_select';
77
import Diff from './diff';
78
import ProjectLabelSubscription from './project_label_subscription';
F
Filipa Lacerda 已提交
79
import SearchAutocomplete from './search_autocomplete';
80
import Activities from './activities';
81

F
Fatih Acet 已提交
82 83 84 85 86 87
(function() {
  var Dispatcher;

  Dispatcher = (function() {
    function Dispatcher() {
      this.initSearch();
88
      this.initFieldErrors();
F
Fatih Acet 已提交
89 90 91 92
      this.initPageScripts();
    }

    Dispatcher.prototype.initPageScripts = function() {
93 94
      var path, shortcut_handler, fileBlobPermalinkUrlElement, fileBlobPermalinkUrl;
      const page = $('body').attr('data-page');
F
Fatih Acet 已提交
95 96 97
      if (!page) {
        return false;
      }
98

99
      const fail = () => Flash('Error loading dynamic module');
100
      const callDefault = m => m.default();
101

F
Fatih Acet 已提交
102 103
      path = page.split(':');
      shortcut_handler = null;
104

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

118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133
      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 已提交
134

135 136 137 138 139 140
        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'),
141 142
        })
          .init();
143 144
      }

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

F
Fatih Acet 已提交
147
      switch (page) {
148 149 150
        case 'profiles:preferences:show':
          initExperimentalFlags();
          break;
151
        case 'sessions:new':
C
Clement Ho 已提交
152 153 154
          import('./pages/sessions/new')
            .then(callDefault)
            .catch(fail);
155
          break;
156
        case 'projects:boards:show':
157
        case 'projects:boards:index':
158
          shortcut_handler = new ShortcutsNavigation();
159
          new UsersSelect();
160
          break;
161
        case 'projects:merge_requests:index':
F
Fatih Acet 已提交
162
        case 'projects:issues:index':
163
          if (filteredSearchEnabled) {
164 165
            const filteredSearchManager = new gl.FilteredSearchManager(page === 'projects:issues:index' ? 'issues' : 'merge_requests');
            filteredSearchManager.setup();
C
Clement Ho 已提交
166
          }
167
          const pagePrefix = page === 'projects:merge_requests:index' ? 'merge_request_' : 'issue_';
F
Filipa Lacerda 已提交
168
          new IssuableIndex(pagePrefix);
169

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

337 338
          initIssuableSidebar();
          initNotes();
339

340 341 342 343
          const mrShowNode = document.querySelector('.merge-request');
          window.mergeRequest = new MergeRequest({
            action: mrShowNode.dataset.mrAction,
          });
344 345

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

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

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

          if (newGroupChildWrapper) {
            new NewGroupChild(newGroupChildWrapper);
          }
F
Fatih Acet 已提交
437 438
          break;
        case 'groups:group_members:index':
439 440
          memberExpirationDate();
          new Members();
F
Fatih Acet 已提交
441 442
          new UsersSelect();
          break;
443
        case 'projects:project_members:index':
444
          memberExpirationDate('.js-access-expiration-date-groups');
445
          groupsSelect();
446 447
          memberExpirationDate();
          new Members();
F
Fatih Acet 已提交
448 449 450
          new UsersSelect();
          break;
        case 'groups:new':
451
        case 'groups:create':
Z
Z.J. van de Weg 已提交
452
          BindInOut.initAll();
453
          new Group();
454
          groupAvatar();
455
          break;
P
Phil Hughes 已提交
456 457
        case 'admin:groups:create':
        case 'admin:groups:new':
P
Phil Hughes 已提交
458 459 460
          import('./pages/admin/groups/new')
            .then(callDefault)
            .catch(fail);
P
Phil Hughes 已提交
461
          break;
F
Fatih Acet 已提交
462
        case 'admin:groups:edit':
P
Phil Hughes 已提交
463 464 465
          import('./pages/admin/groups/edit')
            .then(callDefault)
            .catch(fail);
P
Phil Hughes 已提交
466 467
          break;
        case 'groups:edit':
468
          groupAvatar();
F
Fatih Acet 已提交
469
          break;
470 471 472 473
        case 'projects:tree:show':
          shortcut_handler = new ShortcutsNavigation();
          new TreeView();
          new BlobViewer();
474
          new NewCommitForm($('.js-create-dir-form'));
T
Tim Zallmann 已提交
475
          $('#tree-slider').waitForImages(function() {
F
Filipa Lacerda 已提交
476
            ajaxGet(document.querySelector('.js-tree-content').dataset.logsPath);
T
Tim Zallmann 已提交
477
          });
478
          break;
F
Fatih Acet 已提交
479
        case 'projects:find_file:show':
480 481 482 483 484 485 486
          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 已提交
487 488
          shortcut_handler = true;
          break;
489 490 491 492
        case 'projects:blob:show':
          new BlobViewer();
          initBlob();
          break;
F
Fatih Acet 已提交
493
        case 'projects:blame:show':
494
          initBlob();
F
Fatih Acet 已提交
495
          break;
496 497
        case 'groups:labels:new':
        case 'groups:labels:edit':
F
Fatih Acet 已提交
498 499 500 501
        case 'projects:labels:new':
        case 'projects:labels:edit':
          new Labels();
          break;
502
        case 'groups:labels:index':
F
Fatih Acet 已提交
503 504
        case 'projects:labels:index':
          if ($('.prioritized-labels').length) {
505
            new LabelManager();
F
Fatih Acet 已提交
506
          }
507 508 509 510
          $('.label-subscription').each((i, el) => {
            const $el = $(el);

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

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

      if (document.querySelector('#peek')) {
        new PerformanceBar({ container: '#peek' });
      }
F
Fatih Acet 已提交
740 741 742
    };

    Dispatcher.prototype.initSearch = function() {
743
      // Only when search form is present
F
Fatih Acet 已提交
744
      if ($('.search').length) {
F
Filipa Lacerda 已提交
745
        return new SearchAutocomplete();
F
Fatih Acet 已提交
746 747 748
      }
    };

749
    Dispatcher.prototype.initFieldErrors = function() {
750
      $('.gl-show-field-errors').each((i, form) => {
751
        new GlFieldErrors(form);
752
      });
753 754
    };

F
Fatih Acet 已提交
755 756
    return Dispatcher;
  })();
757

758
  $(window).on('load', function() {
759 760
    new Dispatcher();
  });
761
}).call(window);