dd5e46ab69
Add ESLint ## What does this MR do? - create `package.json` - add ESLint dependencies to `package.json` - add JavaScript linting to CI - add Rake task `lint:javascript`as alias for `eslint` (which itself is an alias for `npm run eslint`) ## Are there points in the code the reviewer needs to double check? Probably not. ## Why was this MR needed? My hovercraft was full of eels. ## What are the relevant issue numbers? - https://gitlab.com/gitlab-org/gitlab-ce/issues/13224#note_12537431 - https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/5006#note_13255658 See merge request !5445
52 lines
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
/* eslint-disable */
|
|
(function() {
|
|
var bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; };
|
|
|
|
this.Subscription = (function() {
|
|
function Subscription(container) {
|
|
this.toggleSubscription = bind(this.toggleSubscription, this);
|
|
var $container;
|
|
this.$container = $(container);
|
|
this.url = this.$container.attr('data-url');
|
|
this.subscribe_button = this.$container.find('.js-subscribe-button');
|
|
this.subscription_status = this.$container.find('.subscription-status');
|
|
this.subscribe_button.unbind('click').click(this.toggleSubscription);
|
|
}
|
|
|
|
Subscription.prototype.toggleSubscription = function(event) {
|
|
var action, btn, current_status;
|
|
btn = $(event.currentTarget);
|
|
action = btn.find('span').text();
|
|
current_status = this.subscription_status.attr('data-status');
|
|
btn.addClass('disabled');
|
|
|
|
if ($('html').hasClass('issue-boards-page')) {
|
|
this.url = this.$container.attr('data-url');
|
|
}
|
|
|
|
return $.post(this.url, (function(_this) {
|
|
return function() {
|
|
var status;
|
|
btn.removeClass('disabled');
|
|
|
|
if ($('html').hasClass('issue-boards-page')) {
|
|
Vue.set(gl.issueBoards.BoardsStore.detail.issue, 'subscribed', !gl.issueBoards.BoardsStore.detail.issue.subscribed);
|
|
} else {
|
|
status = current_status === 'subscribed' ? 'unsubscribed' : 'subscribed';
|
|
_this.subscription_status.attr('data-status', status);
|
|
action = status === 'subscribed' ? 'Unsubscribe' : 'Subscribe';
|
|
btn.find('span').text(action);
|
|
_this.subscription_status.find('>div').toggleClass('hidden');
|
|
if (btn.attr('data-original-title')) {
|
|
return btn.tooltip('hide').attr('data-original-title', action).tooltip('fixTitle');
|
|
}
|
|
}
|
|
};
|
|
})(this));
|
|
};
|
|
|
|
return Subscription;
|
|
|
|
})();
|
|
|
|
}).call(this);
|