debian-mirror-gitlab/app/assets/javascripts/filtered_search/dropdown_user.js

80 lines
2.1 KiB
JavaScript
Raw Normal View History

2017-08-17 22:00:37 +05:30
/* global Flash */
import AjaxFilter from '~/droplab/plugins/ajax_filter';
2017-09-10 17:25:29 +05:30
import './filtered_search_dropdown';
import { addClassIfElementExists } from '../lib/utils/dom_utils';
2017-08-17 22:00:37 +05:30
class DropdownUser extends gl.FilteredSearchDropdown {
2017-09-10 17:25:29 +05:30
constructor(options = {}) {
const { tokenKeys } = options;
super(options);
2017-08-17 22:00:37 +05:30
this.config = {
AjaxFilter: {
endpoint: `${gon.relative_url_root || ''}/autocomplete/users.json`,
searchKey: 'search',
params: {
per_page: 20,
active: true,
project_id: this.getProjectId(),
current_user: true,
},
searchValueFunction: this.getSearchInput.bind(this),
loadingTemplate: this.loadingTemplate,
2017-09-10 17:25:29 +05:30
onLoadingFinished: () => {
this.hideCurrentUser();
},
2017-08-17 22:00:37 +05:30
onError() {
/* eslint-disable no-new */
new Flash('An error occured fetching the dropdown data.');
/* eslint-enable no-new */
},
},
};
2017-09-10 17:25:29 +05:30
this.tokenKeys = tokenKeys;
}
hideCurrentUser() {
addClassIfElementExists(this.dropdown.querySelector('.js-current-user'), 'hidden');
2017-08-17 22:00:37 +05:30
}
itemClicked(e) {
super.itemClicked(e,
selected => selected.querySelector('.dropdown-light-content').innerText.trim());
}
renderContent(forceShowList = false) {
this.droplab.changeHookList(this.hookId, this.dropdown, [AjaxFilter], this.config);
super.renderContent(forceShowList);
}
getProjectId() {
return this.input.getAttribute('data-project-id');
}
getSearchInput() {
const query = gl.DropdownUtils.getSearchInput(this.input);
2017-09-10 17:25:29 +05:30
const { lastToken } = gl.FilteredSearchTokenizer.processTokens(query, this.tokenKeys.get());
2017-08-17 22:00:37 +05:30
let value = lastToken || '';
if (value[0] === '@') {
value = value.slice(1);
}
// Removes the first character if it is a quotation so that we can search
// with multiple words
if (value[0] === '"' || value[0] === '\'') {
value = value.slice(1);
}
return value;
}
init() {
this.droplab.addHook(this.input, this.dropdown, [AjaxFilter], this.config).init();
}
}
window.gl = window.gl || {};
gl.DropdownUser = DropdownUser;