gitlab-org--gitlab-foss/app/assets/javascripts/filtered_search/dropdown_hint.js

78 lines
2.3 KiB
JavaScript
Raw Normal View History

2017-04-07 13:57:03 +00:00
import Filter from '~/droplab/plugins/filter';
import './filtered_search_dropdown';
2016-12-14 03:55:25 +00:00
class DropdownHint extends gl.FilteredSearchDropdown {
2017-05-23 16:35:54 +00:00
constructor(droplab, dropdown, input, tokenKeys, filter) {
super(droplab, dropdown, input, filter);
this.config = {
Filter: {
template: 'hint',
2017-05-23 16:35:54 +00:00
filterFunction: gl.DropdownUtils.filterHint.bind(null, {
input,
allowedKeys: tokenKeys.getKeys(),
}),
},
};
2017-05-23 16:35:54 +00:00
this.tokenKeys = tokenKeys;
}
itemClicked(e) {
const { selected } = e.detail;
2016-11-30 21:25:10 +00:00
if (selected.tagName === 'LI') {
if (selected.hasAttribute('data-value')) {
this.dismissDropdown();
} else if (selected.getAttribute('data-action') === 'submit') {
this.dismissDropdown();
this.dispatchFormSubmitEvent();
} else {
const token = selected.querySelector('.js-filter-hint').innerText.trim();
const tag = selected.querySelector('.js-filter-tag').innerText.trim();
2017-01-30 22:53:18 +00:00
if (tag.length) {
// Get previous input values in the input field and convert them into visual tokens
const previousInputValues = this.input.value.split(' ');
const searchTerms = [];
2017-01-30 22:53:18 +00:00
previousInputValues.forEach((value, index) => {
searchTerms.push(value);
2017-01-30 22:53:18 +00:00
if (index === previousInputValues.length - 1
&& token.indexOf(value.toLowerCase()) !== -1) {
searchTerms.pop();
2017-01-30 22:53:18 +00:00
}
});
2017-01-30 22:53:18 +00:00
if (searchTerms.length > 0) {
gl.FilteredSearchVisualTokens.addSearchVisualToken(searchTerms.join(' '));
}
gl.FilteredSearchDropdownManager.addWordToInput(token.replace(':', ''), '', false, this.container);
2016-12-09 17:44:09 +00:00
}
this.dismissDropdown();
this.dispatchInputEvent();
2016-11-30 21:25:10 +00:00
}
}
}
2016-11-30 21:25:10 +00:00
renderContent() {
const dropdownData = this.tokenKeys.get()
2017-05-18 20:30:16 +00:00
.map(tokenKey => ({
icon: `fa-${tokenKey.icon}`,
hint: tokenKey.key,
tag: `<${tokenKey.symbol}${tokenKey.key}>`,
type: tokenKey.type,
}));
this.droplab.changeHookList(this.hookId, this.dropdown, [Filter], this.config);
this.droplab.setData(this.hookId, dropdownData);
}
2016-12-06 22:23:04 +00:00
init() {
this.droplab.addHook(this.input, this.dropdown, [Filter], this.config).init();
2016-11-30 21:25:10 +00:00
}
}
2016-11-30 21:25:10 +00:00
window.gl = window.gl || {};
gl.DropdownHint = DropdownHint;