(function() {
  this.DueDateSelect = (function() {
    function DueDateSelect() {
      var $datePicker, $dueDate, $loading;
      $datePicker = $('.datepicker');
      if ($datePicker.length) {
        $dueDate = $('#milestone_due_date');
        $datePicker.datepicker({
          dateFormat: 'yy-mm-dd',
          onSelect: function(dateText, inst) {
            return $dueDate.val(dateText);
          }
        }).datepicker('setDate', $.datepicker.parseDate('yy-mm-dd', $dueDate.val()));
      }
      $('.js-clear-due-date').on('click', function(e) {
        e.preventDefault();
        return $.datepicker._clearDate($datePicker);
      });
      $loading = $('.js-issuable-update .due_date').find('.block-loading').hide();
      $('.js-due-date-select').each(function(i, dropdown) {
        var $block, $dropdown, $dropdownParent, $selectbox, $sidebarValue, $value, $valueContent, abilityName, addDueDate, fieldName, issueUpdateURL;
        $dropdown = $(dropdown);
        $dropdownParent = $dropdown.closest('.dropdown');
        $datePicker = $dropdownParent.find('.js-due-date-calendar');
        $block = $dropdown.closest('.block');
        $selectbox = $dropdown.closest('.selectbox');
        $value = $block.find('.value');
        $valueContent = $block.find('.value-content');
        $sidebarValue = $('.js-due-date-sidebar-value', $block);
        fieldName = $dropdown.data('field-name');
        abilityName = $dropdown.data('ability-name');
        issueUpdateURL = $dropdown.data('issue-update');
        $dropdown.glDropdown({
          hidden: function() {
            $selectbox.hide();
            return $value.css('display', '');
          }
        });
        addDueDate = function(isDropdown) {
          var data, date, mediumDate, value;
          value = $("input[name='" + fieldName + "']").val();
          if (value !== '') {
            date = new Date(value.replace(new RegExp('-', 'g'), ','));
            mediumDate = $.datepicker.formatDate('M d, yy', date);
          } else {
            mediumDate = 'No due date';
          }
          data = {};
          data[abilityName] = {};
          data[abilityName].due_date = value;
          return $.ajax({
            type: 'PUT',
            url: issueUpdateURL,
            data: data,
            dataType: 'json',
            beforeSend: function() {
              var cssClass;
              $loading.fadeIn();
              if (isDropdown) {
                $dropdown.trigger('loading.gl.dropdown');
                $selectbox.hide();
              }
              $value.css('display', '');
              cssClass = Date.parse(mediumDate) ? 'bold' : 'no-value';
              $valueContent.html("<span class='" + cssClass + "'>" + mediumDate + "</span>");
              $sidebarValue.html(mediumDate);
              if (value !== '') {
                return $('.js-remove-due-date-holder').removeClass('hidden');
              } else {
                return $('.js-remove-due-date-holder').addClass('hidden');
              }
            }
          }).done(function(data) {
            if (isDropdown) {
              $dropdown.trigger('loaded.gl.dropdown');
              $dropdown.dropdown('toggle');
            }
            return $loading.fadeOut();
          });
        };
        $block.on('click', '.js-remove-due-date', function(e) {
          e.preventDefault();
          $("input[name='" + fieldName + "']").val('');
          return addDueDate(false);
        });
        return $datePicker.datepicker({
          dateFormat: 'yy-mm-dd',
          defaultDate: $("input[name='" + fieldName + "']").val(),
          altField: "input[name='" + fieldName + "']",
          onSelect: function() {
            return addDueDate(true);
          }
        });
      });
      $(document).off('click', '.ui-datepicker-header a').on('click', '.ui-datepicker-header a', function(e) {
        return e.stopImmediatePropagation();
      });
    }

    return DueDateSelect;

  })();

}).call(this);