diff_notes_bundle.js 2.26 KB
Newer Older
1
/* eslint-disable func-names, comma-dangle, new-cap, no-new, max-len */
2
/* global ResolveCount */
Phil Hughes's avatar
Phil Hughes committed
3
/* global ResolveServiceClass */
4

5
import Vue from 'vue';
6 7 8 9 10 11 12 13 14 15 16 17
import './models/discussion';
import './models/note';
import './stores/comments';
import './services/resolve';
import './mixins/discussion';
import './components/comment_resolve_btn';
import './components/jump_to_discussion';
import './components/resolve_btn';
import './components/resolve_count';
import './components/resolve_discussion_btn';
import './components/diff_note_avatars';
import './components/new_issue_for_discussion';
Phil Hughes's avatar
Phil Hughes committed
18

19
export default () => {
20
  const projectPathHolder = document.querySelector('.merge-request') || document.querySelector('.commit-box');
21
  const projectPath = projectPathHolder.dataset.projectPath;
22
  const COMPONENT_SELECTOR = 'resolve-btn, resolve-discussion-btn, jump-to-discussion, comment-and-resolve-btn, new-issue-for-discussion-btn';
23

24 25
  window.gl = window.gl || {};
  window.gl.diffNoteApps = {};
Phil Hughes's avatar
Phil Hughes committed
26

27
  window.ResolveService = new gl.DiffNotesResolveServiceClass(projectPath);
28

29
  gl.diffNotesCompileComponents = () => {
30 31 32 33 34 35 36
    $('diff-note-avatars').each(function () {
      const tmp = Vue.extend({
        template: $(this).get(0).outerHTML
      });
      const tmpApp = new tmp().$mount();

      $(this).replaceWith(tmpApp.$el);
37 38 39 40
      $(tmpApp.$el).one('remove.vue', () => {
        tmpApp.$destroy();
        tmpApp.$el.remove();
      });
41 42
    });

43 44 45
    const $components = $(COMPONENT_SELECTOR).filter(function () {
      return $(this).closest('resolve-count').length !== 1;
    });
46 47 48 49 50

    if ($components) {
      $components.each(function () {
        const $this = $(this);
        const noteId = $this.attr(':note-id');
51 52 53 54
        const discussionId = $this.attr(':discussion-id');

        if ($this.is('comment-and-resolve-btn') && !discussionId) return;

55 56 57 58 59 60 61
        const tmp = Vue.extend({
          template: $this.get(0).outerHTML
        });
        const tmpApp = new tmp().$mount();

        if (noteId) {
          gl.diffNoteApps[`note_${noteId}`] = tmpApp;
62
        }
63 64 65

        $this.replaceWith(tmpApp.$el);
      });
Phil Hughes's avatar
Phil Hughes committed
66
    }
67 68 69
  };

  gl.diffNotesCompileComponents();
Phil Hughes's avatar
Phil Hughes committed
70 71 72 73 74

  new Vue({
    el: '#resolve-count-app',
    components: {
      'resolve-count': ResolveCount
75
    },
Phil Hughes's avatar
Phil Hughes committed
76
  });
77 78

  $(window).trigger('resize.nav');
79
};