2017-01-11 23:27:41 -05:00
|
|
|
/* eslint-disable func-names, space-before-function-paren, no-var, prefer-rest-params, wrap-iife, no-unused-vars, consistent-return, one-var, one-var-declaration-per-line, quotes, prefer-template, object-shorthand, comma-dangle, no-else-return, no-param-reassign, max-len */
|
2016-12-14 00:26:26 -05:00
|
|
|
/* global Cookies */
|
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
(function() {
|
2017-01-11 23:27:41 -05:00
|
|
|
var bind = function(fn, me) { return function() { return fn.apply(me, arguments); }; };
|
2016-07-24 16:45:11 -04:00
|
|
|
|
|
|
|
this.Sidebar = (function() {
|
|
|
|
function Sidebar(currentUser) {
|
|
|
|
this.toggleTodo = bind(this.toggleTodo, this);
|
|
|
|
this.sidebar = $('aside');
|
2016-10-05 03:49:40 -04:00
|
|
|
this.removeListeners();
|
2016-07-24 16:45:11 -04:00
|
|
|
this.addEventListeners();
|
|
|
|
}
|
|
|
|
|
2016-10-05 03:49:40 -04:00
|
|
|
Sidebar.prototype.removeListeners = function () {
|
|
|
|
this.sidebar.off('click', '.sidebar-collapsed-icon');
|
|
|
|
$('.dropdown').off('hidden.gl.dropdown');
|
|
|
|
$('.dropdown').off('loading.gl.dropdown');
|
|
|
|
$('.dropdown').off('loaded.gl.dropdown');
|
|
|
|
$(document).off('click', '.js-sidebar-toggle');
|
2017-01-10 17:54:56 -05:00
|
|
|
};
|
2016-10-05 03:49:40 -04:00
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
Sidebar.prototype.addEventListeners = function() {
|
2017-02-16 14:17:27 -05:00
|
|
|
const $document = $(document);
|
|
|
|
const throttledSetSidebarHeight = _.throttle(this.setSidebarHeight, 10);
|
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
this.sidebar.on('click', '.sidebar-collapsed-icon', this, this.sidebarCollapseClicked);
|
|
|
|
$('.dropdown').on('hidden.gl.dropdown', this, this.onSidebarDropdownHidden);
|
|
|
|
$('.dropdown').on('loading.gl.dropdown', this.sidebarDropdownLoading);
|
|
|
|
$('.dropdown').on('loaded.gl.dropdown', this.sidebarDropdownLoaded);
|
2017-02-16 14:17:27 -05:00
|
|
|
$(window).on('resize', () => throttledSetSidebarHeight());
|
|
|
|
$document.on('scroll', () => throttledSetSidebarHeight());
|
|
|
|
$document.on('click', '.js-sidebar-toggle', function(e, triggered) {
|
2016-07-24 16:45:11 -04:00
|
|
|
var $allGutterToggleIcons, $this, $thisIcon;
|
|
|
|
e.preventDefault();
|
|
|
|
$this = $(this);
|
|
|
|
$thisIcon = $this.find('i');
|
|
|
|
$allGutterToggleIcons = $('.js-sidebar-toggle i');
|
|
|
|
if ($thisIcon.hasClass('fa-angle-double-right')) {
|
|
|
|
$allGutterToggleIcons.removeClass('fa-angle-double-right').addClass('fa-angle-double-left');
|
|
|
|
$('aside.right-sidebar').removeClass('right-sidebar-expanded').addClass('right-sidebar-collapsed');
|
|
|
|
$('.page-with-sidebar').removeClass('right-sidebar-expanded').addClass('right-sidebar-collapsed');
|
|
|
|
} else {
|
|
|
|
$allGutterToggleIcons.removeClass('fa-angle-double-left').addClass('fa-angle-double-right');
|
|
|
|
$('aside.right-sidebar').removeClass('right-sidebar-collapsed').addClass('right-sidebar-expanded');
|
|
|
|
$('.page-with-sidebar').removeClass('right-sidebar-collapsed').addClass('right-sidebar-expanded');
|
|
|
|
}
|
|
|
|
if (!triggered) {
|
2016-10-24 17:54:38 -04:00
|
|
|
return Cookies.set("collapsed_gutter", $('.right-sidebar').hasClass('right-sidebar-collapsed'));
|
2016-07-24 16:45:11 -04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
return $(document).off('click', '.js-issuable-todo').on('click', '.js-issuable-todo', this.toggleTodo);
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.toggleTodo = function(e) {
|
|
|
|
var $btnText, $this, $todoLoading, ajaxType, url;
|
|
|
|
$this = $(e.currentTarget);
|
|
|
|
$todoLoading = $('.js-issuable-todo-loading');
|
|
|
|
$btnText = $('.js-issuable-todo-text', $this);
|
|
|
|
ajaxType = $this.attr('data-delete-path') ? 'DELETE' : 'POST';
|
|
|
|
if ($this.attr('data-delete-path')) {
|
|
|
|
url = "" + ($this.attr('data-delete-path'));
|
|
|
|
} else {
|
|
|
|
url = "" + ($this.data('url'));
|
|
|
|
}
|
|
|
|
return $.ajax({
|
|
|
|
url: url,
|
|
|
|
type: ajaxType,
|
|
|
|
dataType: 'json',
|
|
|
|
data: {
|
|
|
|
issuable_id: $this.data('issuable-id'),
|
|
|
|
issuable_type: $this.data('issuable-type')
|
|
|
|
},
|
|
|
|
beforeSend: (function(_this) {
|
|
|
|
return function() {
|
|
|
|
return _this.beforeTodoSend($this, $todoLoading);
|
|
|
|
};
|
|
|
|
})(this)
|
|
|
|
}).done((function(_this) {
|
|
|
|
return function(data) {
|
|
|
|
return _this.todoUpdateDone(data, $this, $btnText, $todoLoading);
|
|
|
|
};
|
|
|
|
})(this));
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.beforeTodoSend = function($btn, $todoLoading) {
|
|
|
|
$btn.disable();
|
|
|
|
return $todoLoading.removeClass('hidden');
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.todoUpdateDone = function(data, $btn, $btnText, $todoLoading) {
|
2016-08-08 17:19:46 -04:00
|
|
|
$(document).trigger('todo:toggle', data.count);
|
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
$btn.enable();
|
|
|
|
$todoLoading.addClass('hidden');
|
2016-08-08 17:19:46 -04:00
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
if (data.delete_path != null) {
|
|
|
|
$btn.attr('aria-label', $btn.data('mark-text')).attr('data-delete-path', data.delete_path);
|
|
|
|
return $btnText.text($btn.data('mark-text'));
|
|
|
|
} else {
|
|
|
|
$btn.attr('aria-label', $btn.data('todo-text')).removeAttr('data-delete-path');
|
|
|
|
return $btnText.text($btn.data('todo-text'));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.sidebarDropdownLoading = function(e) {
|
|
|
|
var $loading, $sidebarCollapsedIcon, i, img;
|
|
|
|
$sidebarCollapsedIcon = $(this).closest('.block').find('.sidebar-collapsed-icon');
|
|
|
|
img = $sidebarCollapsedIcon.find('img');
|
|
|
|
i = $sidebarCollapsedIcon.find('i');
|
|
|
|
$loading = $('<i class="fa fa-spinner fa-spin"></i>');
|
|
|
|
if (img.length) {
|
|
|
|
img.before($loading);
|
|
|
|
return img.hide();
|
|
|
|
} else if (i.length) {
|
|
|
|
i.before($loading);
|
|
|
|
return i.hide();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.sidebarDropdownLoaded = function(e) {
|
|
|
|
var $sidebarCollapsedIcon, i, img;
|
|
|
|
$sidebarCollapsedIcon = $(this).closest('.block').find('.sidebar-collapsed-icon');
|
|
|
|
img = $sidebarCollapsedIcon.find('img');
|
|
|
|
$sidebarCollapsedIcon.find('i.fa-spin').remove();
|
|
|
|
i = $sidebarCollapsedIcon.find('i');
|
|
|
|
if (img.length) {
|
|
|
|
return img.show();
|
|
|
|
} else {
|
|
|
|
return i.show();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.sidebarCollapseClicked = function(e) {
|
|
|
|
var $block, sidebar;
|
|
|
|
if ($(e.currentTarget).hasClass('dont-change-state')) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
sidebar = e.data;
|
|
|
|
e.preventDefault();
|
|
|
|
$block = $(this).closest('.block');
|
|
|
|
return sidebar.openDropdown($block);
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.openDropdown = function(blockOrName) {
|
|
|
|
var $block;
|
|
|
|
$block = _.isString(blockOrName) ? this.getBlock(blockOrName) : blockOrName;
|
|
|
|
$block.find('.edit-link').trigger('click');
|
|
|
|
if (!this.isOpen()) {
|
|
|
|
this.setCollapseAfterUpdate($block);
|
|
|
|
return this.toggleSidebar('open');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.setCollapseAfterUpdate = function($block) {
|
|
|
|
$block.addClass('collapse-after-update');
|
|
|
|
return $('.page-with-sidebar').addClass('with-overlay');
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.onSidebarDropdownHidden = function(e) {
|
|
|
|
var $block, sidebar;
|
|
|
|
sidebar = e.data;
|
|
|
|
e.preventDefault();
|
|
|
|
$block = $(this).closest('.block');
|
|
|
|
return sidebar.sidebarDropdownHidden($block);
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.sidebarDropdownHidden = function($block) {
|
|
|
|
if ($block.hasClass('collapse-after-update')) {
|
|
|
|
$block.removeClass('collapse-after-update');
|
|
|
|
$('.page-with-sidebar').removeClass('with-overlay');
|
|
|
|
return this.toggleSidebar('hide');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.triggerOpenSidebar = function() {
|
|
|
|
return this.sidebar.find('.js-sidebar-toggle').trigger('click');
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.toggleSidebar = function(action) {
|
|
|
|
if (action == null) {
|
|
|
|
action = 'toggle';
|
|
|
|
}
|
|
|
|
if (action === 'toggle') {
|
|
|
|
this.triggerOpenSidebar();
|
|
|
|
}
|
|
|
|
if (action === 'open') {
|
|
|
|
if (!this.isOpen()) {
|
|
|
|
this.triggerOpenSidebar();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (action === 'hide') {
|
|
|
|
if (this.isOpen()) {
|
|
|
|
return this.triggerOpenSidebar();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-02-15 16:56:02 -05:00
|
|
|
Sidebar.prototype.setSidebarHeight = function() {
|
|
|
|
const $navHeight = $('.navbar-gitlab').outerHeight() + $('.layout-nav').outerHeight();
|
2017-02-16 14:17:27 -05:00
|
|
|
const $rightSidebar = $('.js-right-sidebar');
|
2017-02-15 16:56:02 -05:00
|
|
|
const diff = $navHeight - $('body').scrollTop();
|
|
|
|
if (diff > 0) {
|
2017-02-16 14:17:27 -05:00
|
|
|
$rightSidebar.outerHeight($(window).height() - diff);
|
2017-02-15 16:56:02 -05:00
|
|
|
} else {
|
2017-02-16 14:17:27 -05:00
|
|
|
$rightSidebar.outerHeight('100%');
|
2017-02-15 16:56:02 -05:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
Sidebar.prototype.isOpen = function() {
|
|
|
|
return this.sidebar.is('.right-sidebar-expanded');
|
|
|
|
};
|
|
|
|
|
|
|
|
Sidebar.prototype.getBlock = function(name) {
|
|
|
|
return this.sidebar.find(".block." + name);
|
|
|
|
};
|
|
|
|
|
|
|
|
return Sidebar;
|
|
|
|
})();
|
2017-02-10 01:50:50 -05:00
|
|
|
}).call(window);
|