BigW Consortium Gitlab

gl_form.js 1.84 KB
Newer Older
Fatih Acet committed
1 2 3 4 5
(function() {
  this.GLForm = (function() {
    function GLForm(form) {
      this.form = form;
      this.textarea = this.form.find('textarea.js-gfm-input');
6
      // Before we start, we should clean up any previous data for this form
Fatih Acet committed
7
      this.destroy();
8
      // Setup the form
Fatih Acet committed
9 10 11 12 13
      this.setupForm();
      this.form.data('gl-form', this);
    }

    GLForm.prototype.destroy = function() {
14
      // Clean form listeners
Fatih Acet committed
15 16 17 18 19 20 21 22 23 24 25 26
      this.clearEventListeners();
      return this.form.data('gl-form', null);
    };

    GLForm.prototype.setupForm = function() {
      var isNewForm;
      isNewForm = this.form.is(':not(.gfm-form)');
      this.form.removeClass('js-new-note-form');
      if (isNewForm) {
        this.form.find('.div-dropzone').remove();
        this.form.addClass('gfm-form');
        disableButtonIfEmptyField(this.form.find('.js-note-text'), this.form.find('.js-comment-button'));
27
        // remove notify commit author checkbox for non-commit notes
28
        GitLab.GfmAutoComplete.setup(this.form.find('.js-gfm-input'));
Fatih Acet committed
29 30
        new DropzoneInput(this.form);
        autosize(this.textarea);
31
        // form and textarea event listeners
Fatih Acet committed
32 33 34
        this.addEventListeners();
        gl.text.init(this.form);
      }
35
      // hide discard button
Fatih Acet committed
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
      this.form.find('.js-note-discard').hide();
      return this.form.show();
    };

    GLForm.prototype.clearEventListeners = function() {
      this.textarea.off('focus');
      this.textarea.off('blur');
      return gl.text.removeListeners(this.form);
    };

    GLForm.prototype.addEventListeners = function() {
      this.textarea.on('focus', function() {
        return $(this).closest('.md-area').addClass('is-focused');
      });
      return this.textarea.on('blur', function() {
        return $(this).closest('.md-area').removeClass('is-focused');
      });
    };

    return GLForm;

  })();

}).call(this);