dispatcher.js 14 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 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
/* global UsernameValidator */
/* global ActiveTabMemoizer */
/* global ShortcutsNavigation */
/* global Build */
/* global Issuable */
/* global ShortcutsIssuable */
/* global ZenMode */
/* global Milestone */
/* global IssuableForm */
/* global LabelsSelect */
/* global MilestoneSelect */
/* global MergedButtons */
/* global Commit */
/* global NotificationsForm */
/* global TreeView */
/* global NotificationsDropdown */
/* global UsersSelect */
/* global GroupAvatar */
/* global LineHighlighter */
/* global ProjectFork */
/* global BuildArtifacts */
/* global GroupsSelect */
/* global Search */
/* global Admin */
/* global NamespaceSelects */
/* global ShortcutsDashboardNavigation */
/* global Project */
/* global ProjectAvatar */
/* global CompareAutocomplete */
/* global ProjectNew */
/* global Star */
/* global ProjectShow */
/* global Labels */
/* global Shortcuts */
36
import Issue from './issue';
37

Z.J. van de Weg's avatar
Z.J. van de Weg committed
38
import BindInOut from './behaviors/bind_in_out';
Sam Rose's avatar
Sam Rose committed
39
import GroupName from './group_name';
40
import GroupsList from './groups_list';
41
import ProjectsList from './projects_list';
42
import MiniPipelineGraph from './mini_pipeline_graph_dropdown';
43
import BlobLinePermalinkUpdater from './blob/blob_line_permalink_updater';
Mike Greiling's avatar
Mike Greiling committed
44
import UserCallout from './user_callout';
45

46 47
const ShortcutsBlob = require('./shortcuts_blob');

Fatih Acet's avatar
Fatih Acet committed
48 49 50 51 52 53 54 55 56 57
(function() {
  var Dispatcher;

  $(function() {
    return new Dispatcher();
  });

  Dispatcher = (function() {
    function Dispatcher() {
      this.initSearch();
58
      this.initFieldErrors();
Fatih Acet's avatar
Fatih Acet committed
59 60 61 62
      this.initPageScripts();
    }

    Dispatcher.prototype.initPageScripts = function() {
63
      var page, path, shortcut_handler, fileBlobPermalinkUrlElement, fileBlobPermalinkUrl;
Fatih Acet's avatar
Fatih Acet committed
64 65 66 67 68 69
      page = $('body').attr('data-page');
      if (!page) {
        return false;
      }
      path = page.split(':');
      shortcut_handler = null;
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88

      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,
        });
      }

Fatih Acet's avatar
Fatih Acet committed
89
      switch (page) {
90 91
        case 'sessions:new':
          new UsernameValidator();
92
          new ActiveTabMemoizer();
93
          break;
94
        case 'projects:boards:show':
95
        case 'projects:boards:index':
96 97
          shortcut_handler = new ShortcutsNavigation();
          break;
98 99 100
        case 'projects:builds:show':
          new Build();
          break;
101
        case 'projects:merge_requests:index':
Fatih Acet's avatar
Fatih Acet committed
102
        case 'projects:issues:index':
Clement Ho's avatar
Clement Ho committed
103
          if (gl.FilteredSearchManager) {
104
            new gl.FilteredSearchManager(page === 'projects:issues:index' ? 'issues' : 'merge_requests');
Clement Ho's avatar
Clement Ho committed
105
          }
Fatih Acet's avatar
Fatih Acet committed
106
          Issuable.init();
107
          new gl.IssuableBulkActions({
Alfredo Sumaran's avatar
Alfredo Sumaran committed
108
            prefixId: page === 'projects:merge_requests:index' ? 'merge_request_' : 'issue_',
109
          });
Fatih Acet's avatar
Fatih Acet committed
110 111 112 113 114 115 116 117 118 119 120 121 122
          shortcut_handler = new ShortcutsNavigation();
          break;
        case 'projects:issues:show':
          new Issue();
          shortcut_handler = new ShortcutsIssuable();
          new ZenMode();
          break;
        case 'projects:milestones:show':
        case 'groups:milestones:show':
        case 'dashboard:milestones:show':
          new Milestone();
          break;
        case 'dashboard:todos:index':
Bryce Johnson's avatar
Bryce Johnson committed
123
          new gl.Todos();
Fatih Acet's avatar
Fatih Acet committed
124
          break;
125 126 127 128 129 130 131 132
        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;
133 134 135 136
        case 'dashboard:groups:index':
        case 'explore:groups:index':
          new GroupsList();
          break;
Fatih Acet's avatar
Fatih Acet committed
137 138
        case 'projects:milestones:new':
        case 'projects:milestones:edit':
139
        case 'projects:milestones:update':
Fatih Acet's avatar
Fatih Acet committed
140
          new ZenMode();
141
          new gl.DueDateSelectors();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
142
          new gl.GLForm($('.milestone-form'));
Fatih Acet's avatar
Fatih Acet committed
143 144 145 146 147
          break;
        case 'groups:milestones:new':
          new ZenMode();
          break;
        case 'projects:compare:show':
148
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
149
          break;
150 151 152
        case 'projects:branches:index':
          gl.AjaxLoadingSpinner.init();
          break;
Fatih Acet's avatar
Fatih Acet committed
153 154 155
        case 'projects:issues:new':
        case 'projects:issues:edit':
          shortcut_handler = new ShortcutsNavigation();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
156
          new gl.GLForm($('.issue-form'));
Fatih Acet's avatar
Fatih Acet committed
157
          new IssuableForm($('.issue-form'));
158 159
          new LabelsSelect();
          new MilestoneSelect();
160
          new gl.IssuableTemplateSelectors();
Fatih Acet's avatar
Fatih Acet committed
161 162
          break;
        case 'projects:merge_requests:new':
163
        case 'projects:merge_requests:new_diffs':
Fatih Acet's avatar
Fatih Acet committed
164
        case 'projects:merge_requests:edit':
165
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
166
          shortcut_handler = new ShortcutsNavigation();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
167
          new gl.GLForm($('.merge-request-form'));
Fatih Acet's avatar
Fatih Acet committed
168
          new IssuableForm($('.merge-request-form'));
169 170
          new LabelsSelect();
          new MilestoneSelect();
171
          new gl.IssuableTemplateSelectors();
Fatih Acet's avatar
Fatih Acet committed
172 173 174
          break;
        case 'projects:tags:new':
          new ZenMode();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
175
          new gl.GLForm($('.tag-form'));
Fatih Acet's avatar
Fatih Acet committed
176 177 178
          break;
        case 'projects:releases:edit':
          new ZenMode();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
179
          new gl.GLForm($('.release-form'));
Fatih Acet's avatar
Fatih Acet committed
180 181
          break;
        case 'projects:merge_requests:show':
182
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
183 184 185 186 187 188 189 190
          shortcut_handler = new ShortcutsIssuable(true);
          new ZenMode();
          new MergedButtons();
          break;
        case 'projects:merge_requests:commits':
          new MergedButtons();
          break;
        case "projects:merge_requests:diffs":
191
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
192 193 194 195
          new ZenMode();
          new MergedButtons();
          break;
        case 'dashboard:activity':
196
          new gl.Activities();
Fatih Acet's avatar
Fatih Acet committed
197 198 199
          break;
        case 'projects:commit:show':
          new Commit();
200
          new gl.Diff();
Fatih Acet's avatar
Fatih Acet committed
201 202
          new ZenMode();
          shortcut_handler = new ShortcutsNavigation();
203 204 205
          new MiniPipelineGraph({
            container: '.js-commit-pipeline-graph',
          }).bindEvents();
Fatih Acet's avatar
Fatih Acet committed
206
          break;
207
        case 'projects:commit:pipelines':
208
          new MiniPipelineGraph({
209
            container: '.js-commit-pipeline-graph',
210 211
          }).bindEvents();
          break;
Fatih Acet's avatar
Fatih Acet committed
212 213 214 215 216 217 218 219 220 221 222
        case 'projects:commits:show':
        case 'projects:activity':
          shortcut_handler = new ShortcutsNavigation();
          break;
        case 'projects:show':
          shortcut_handler = new ShortcutsNavigation();
          new NotificationsForm();
          if ($('#tree-slider').length) {
            new TreeView();
          }
          break;
Filipa Lacerda's avatar
Filipa Lacerda committed
223
        case 'projects:pipelines:builds':
Luke Bennett's avatar
Luke Bennett committed
224
        case 'projects:pipelines:show':
Filipa Lacerda's avatar
Filipa Lacerda committed
225
          const { controllerAction } = document.querySelector('.js-pipeline-container').dataset;
Filipa Lacerda's avatar
Filipa Lacerda committed
226 227 228 229 230 231 232 233 234

          new gl.Pipelines({
            initTabs: true,
            tabsOptions: {
              action: controllerAction,
              defaultAction: 'pipelines',
              parentEl: '.pipelines-tabs',
            },
          });
Luke Bennett's avatar
Luke Bennett committed
235
          break;
Fatih Acet's avatar
Fatih Acet committed
236
        case 'groups:activity':
237
          new gl.Activities();
Fatih Acet's avatar
Fatih Acet committed
238 239 240 241 242
          break;
        case 'groups:show':
          shortcut_handler = new ShortcutsNavigation();
          new NotificationsForm();
          new NotificationsDropdown();
243
          new ProjectsList();
Fatih Acet's avatar
Fatih Acet committed
244 245
          break;
        case 'groups:group_members:index':
246
          new gl.MemberExpirationDate();
247
          new gl.Members();
Fatih Acet's avatar
Fatih Acet committed
248 249
          new UsersSelect();
          break;
250
        case 'projects:members:show':
251 252
          new gl.MemberExpirationDate('.js-access-expiration-date-groups');
          new GroupsSelect();
253
          new gl.MemberExpirationDate();
254
          new gl.Members();
Fatih Acet's avatar
Fatih Acet committed
255 256 257
          new UsersSelect();
          break;
        case 'groups:new':
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
258
        case 'admin:groups:new':
259 260
        case 'groups:create':
        case 'admin:groups:create':
Z.J. van de Weg's avatar
Z.J. van de Weg committed
261
          BindInOut.initAll();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
262 263
        case 'groups:new':
        case 'admin:groups:new':
Fatih Acet's avatar
Fatih Acet committed
264 265 266 267 268 269 270
        case 'groups:edit':
        case 'admin:groups:edit':
          new GroupAvatar();
          break;
        case 'projects:tree:show':
          shortcut_handler = new ShortcutsNavigation();
          new TreeView();
271
          gl.TargetBranchDropDown.bootstrap();
Fatih Acet's avatar
Fatih Acet committed
272 273 274 275
          break;
        case 'projects:find_file:show':
          shortcut_handler = true;
          break;
276 277 278 279 280 281
        case 'projects:blob:new':
          gl.TargetBranchDropDown.bootstrap();
          break;
        case 'projects:blob:create':
          gl.TargetBranchDropDown.bootstrap();
          break;
Fatih Acet's avatar
Fatih Acet committed
282
        case 'projects:blob:show':
283
          gl.TargetBranchDropDown.bootstrap();
284
          initBlob();
285 286 287 288
          break;
        case 'projects:blob:edit':
          gl.TargetBranchDropDown.bootstrap();
          break;
Fatih Acet's avatar
Fatih Acet committed
289
        case 'projects:blame:show':
290
          initBlob();
Fatih Acet's avatar
Fatih Acet committed
291
          break;
292 293
        case 'groups:labels:new':
        case 'groups:labels:edit':
Fatih Acet's avatar
Fatih Acet committed
294 295 296 297 298 299
        case 'projects:labels:new':
        case 'projects:labels:edit':
          new Labels();
          break;
        case 'projects:labels:index':
          if ($('.prioritized-labels').length) {
300
            new gl.LabelManager();
Fatih Acet's avatar
Fatih Acet committed
301 302 303
          }
          break;
        case 'projects:network:show':
304 305
          // 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
306 307 308 309 310 311 312 313
          shortcut_handler = true;
          break;
        case 'projects:forks:new':
          new ProjectFork();
          break;
        case 'projects:artifacts:browse':
          new BuildArtifacts();
          break;
314 315 316
        case 'help:index':
          gl.VersionCheckImage.bindErrorEvent($('img.js-version-status-badge'));
          break;
Fatih Acet's avatar
Fatih Acet committed
317 318
        case 'search:show':
          new Search();
319
          break;
320
        case 'projects:repository:show':
321 322
          new gl.ProtectedBranchCreate();
          new gl.ProtectedBranchEditList();
323
          break;
324
        case 'projects:ci_cd:show':
325 326
          new gl.ProjectVariables();
          break;
327 328 329 330
        case 'ci:lints:create':
        case 'ci:lints:show':
          new gl.CILintEditor();
          break;
331 332 333
        case 'users:show':
          new UserCallout();
          break;
Fatih Acet's avatar
Fatih Acet committed
334 335
      }
      switch (path.first()) {
336 337 338 339 340 341 342 343 344 345 346
        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
347 348 349 350 351 352 353 354
        case 'admin':
          new Admin();
          switch (path[1]) {
            case 'groups':
              new UsersSelect();
              break;
            case 'projects':
              new NamespaceSelects();
355 356
              break;
            case 'labels':
357
              switch (path[2]) {
358
                case 'new':
359 360 361
                case 'edit':
                  new Labels();
              }
362
            case 'abuse_reports':
363
              new gl.AbuseReports();
364
              break;
Fatih Acet's avatar
Fatih Acet committed
365 366 367 368 369
          }
          break;
        case 'dashboard':
        case 'root':
          shortcut_handler = new ShortcutsDashboardNavigation();
370
          new UserCallout();
Fatih Acet's avatar
Fatih Acet committed
371
          break;
Sam Rose's avatar
Sam Rose committed
372 373 374
        case 'groups':
          new GroupName();
          break;
Fatih Acet's avatar
Fatih Acet committed
375 376 377 378 379 380 381
        case 'profiles':
          new NotificationsForm();
          new NotificationsDropdown();
          break;
        case 'projects':
          new Project();
          new ProjectAvatar();
Sam Rose's avatar
Sam Rose committed
382
          new GroupName();
Fatih Acet's avatar
Fatih Acet committed
383 384 385 386 387 388 389 390 391 392 393 394
          switch (path[1]) {
            case 'compare':
              new CompareAutocomplete();
              break;
            case 'edit':
              shortcut_handler = new ShortcutsNavigation();
              new ProjectNew();
              break;
            case 'new':
              new ProjectNew();
              break;
            case 'show':
395
              new Star();
Fatih Acet's avatar
Fatih Acet committed
396 397 398 399 400
              new ProjectNew();
              new ProjectShow();
              new NotificationsDropdown();
              break;
            case 'wikis':
401
              new gl.Wikis();
Fatih Acet's avatar
Fatih Acet committed
402 403
              shortcut_handler = new ShortcutsNavigation();
              new ZenMode();
Luke "Jared" Bennett's avatar
Luke "Jared" Bennett committed
404
              new gl.GLForm($('.wiki-form'));
Fatih Acet's avatar
Fatih Acet committed
405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426
              break;
            case 'snippets':
              shortcut_handler = new ShortcutsNavigation();
              if (path[2] === 'show') {
                new ZenMode();
              }
              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();
          }
      }
427
      // If we haven't installed a custom shortcut handler, install the default one
Fatih Acet's avatar
Fatih Acet committed
428
      if (!shortcut_handler) {
429
        new Shortcuts();
Fatih Acet's avatar
Fatih Acet committed
430 431 432 433
      }
    };

    Dispatcher.prototype.initSearch = function() {
434
      // Only when search form is present
Fatih Acet's avatar
Fatih Acet committed
435
      if ($('.search').length) {
436
        return new gl.SearchAutocomplete();
Fatih Acet's avatar
Fatih Acet committed
437 438 439
      }
    };

440
    Dispatcher.prototype.initFieldErrors = function() {
441
      $('.gl-show-field-errors').each((i, form) => {
442 443
        new gl.GlFieldErrors(form);
      });
444 445
    };

Fatih Acet's avatar
Fatih Acet committed
446 447
    return Dispatcher;
  })();
448
}).call(window);