debian-mirror-gitlab/app/assets/javascripts/protected_branches/protected_branch_dropdown.js

91 lines
2.4 KiB
JavaScript
Raw Normal View History

2017-09-10 17:25:29 +05:30
import _ from 'underscore';
2017-08-17 22:00:37 +05:30
2017-09-10 17:25:29 +05:30
export default class ProtectedBranchDropdown {
/**
* @param {Object} options containing
* `$dropdown` target element
* `onSelect` event callback
* $dropdown must be an element created using `dropdown_branch()` rails helper
*/
2016-09-13 17:45:13 +05:30
constructor(options) {
this.onSelect = options.onSelect;
this.$dropdown = options.$dropdown;
this.$dropdownContainer = this.$dropdown.parent();
this.$dropdownFooter = this.$dropdownContainer.find('.dropdown-footer');
2017-08-17 22:00:37 +05:30
this.$protectedBranch = this.$dropdownContainer.find('.js-create-new-protected-branch');
2016-09-13 17:45:13 +05:30
this.buildDropdown();
this.bindEvents();
// Hide footer
2017-09-10 17:25:29 +05:30
this.toggleFooter(true);
2016-09-13 17:45:13 +05:30
}
buildDropdown() {
this.$dropdown.glDropdown({
data: this.getProtectedBranches.bind(this),
filterable: true,
remote: false,
search: {
2017-09-10 17:25:29 +05:30
fields: ['title'],
2016-09-13 17:45:13 +05:30
},
selectable: true,
toggleLabel(selected) {
return (selected && 'id' in selected) ? selected.title : 'Protected Branch';
},
fieldName: 'protected_branch[name]',
text(protectedBranch) {
return _.escape(protectedBranch.title);
},
id(protectedBranch) {
return _.escape(protectedBranch.id);
},
onFilter: this.toggleCreateNewButton.bind(this),
2017-08-17 22:00:37 +05:30
clicked: (options) => {
2017-09-10 17:25:29 +05:30
options.e.preventDefault();
2016-09-13 17:45:13 +05:30
this.onSelect();
2017-09-10 17:25:29 +05:30
},
2016-09-13 17:45:13 +05:30
});
}
bindEvents() {
this.$protectedBranch.on('click', this.onClickCreateWildcard.bind(this));
}
2017-08-17 22:00:37 +05:30
onClickCreateWildcard(e) {
e.preventDefault();
2016-09-29 09:46:39 +05:30
// Refresh the dropdown's data, which ends up calling `getProtectedBranches`
2016-09-13 17:45:13 +05:30
this.$dropdown.data('glDropdown').remote.execute();
2017-08-17 22:00:37 +05:30
this.$dropdown.data('glDropdown').selectRowAtIndex();
2016-09-13 17:45:13 +05:30
}
getProtectedBranches(term, callback) {
if (this.selectedBranch) {
callback(gon.open_branches.concat(this.selectedBranch));
} else {
callback(gon.open_branches);
}
}
toggleCreateNewButton(branchName) {
if (branchName) {
2017-09-10 17:25:29 +05:30
this.selectedBranch = {
title: branchName,
id: branchName,
text: branchName,
};
2016-09-13 17:45:13 +05:30
this.$dropdownContainer
2017-08-17 22:00:37 +05:30
.find('.js-create-new-protected-branch code')
2016-09-13 17:45:13 +05:30
.text(branchName);
}
2017-09-10 17:25:29 +05:30
this.toggleFooter(!branchName);
2016-09-13 17:45:13 +05:30
}
2017-08-17 22:00:37 +05:30
2017-09-10 17:25:29 +05:30
toggleFooter(toggleState) {
this.$dropdownFooter.toggleClass('hidden', toggleState);
}
}