9 let entityTypes = elem.hasAttribute('entity-types') ? elem.getAttribute('entity-types') : 'page,book,chapter';
10 let entityPermission = elem.hasAttribute('entity-permission') ? elem.getAttribute('entity-permission') : 'view';
11 this.searchUrl = window.baseUrl(`/ajax/search/entities?types=${encodeURIComponent(entityTypes)}&permission=${encodeURIComponent(entityPermission)}`);
13 this.input = elem.querySelector('[entity-selector-input]');
14 this.searchInput = elem.querySelector('[entity-selector-search]');
15 this.loading = elem.querySelector('[entity-selector-loading]');
16 this.resultsContainer = elem.querySelector('[entity-selector-results]');
18 this.elem.addEventListener('click', this.onClick.bind(this));
21 this.searchInput.addEventListener('input', event => {
22 lastSearch = Date.now();
25 if (Date.now() - lastSearch < 199) return;
26 this.searchEntities(this.searchInput.value);
29 this.searchInput.addEventListener('keydown', event => {
30 if (event.keyCode === 13) event.preventDefault();
38 this.loading.style.display = 'block';
39 this.resultsContainer.style.display = 'none';
43 this.loading.style.display = 'none';
44 this.resultsContainer.style.display = 'block';
48 window.$http.get(this.searchUrl).then(resp => {
49 this.resultsContainer.innerHTML = resp.data;
54 searchEntities(searchTerm) {
55 this.input.value = '';
56 let url = this.searchUrl + `&term=${encodeURIComponent(searchTerm)}`;
57 window.$http.get(url).then(resp => {
58 this.resultsContainer.innerHTML = resp.data;
65 let answer = now - this.lastClick < 300;
73 if (t.matches('.entity-list-item *')) {
74 event.preventDefault();
75 event.stopPropagation();
76 let item = t.closest('[data-entity-type]');
77 this.selectItem(item);
78 } else if (t.matches('[data-entity-type]')) {
85 let isDblClick = this.isDoubleClick();
86 let type = item.getAttribute('data-entity-type');
87 let id = item.getAttribute('data-entity-id');
88 let isSelected = !item.classList.contains('selected') || isDblClick;
91 this.input.value = isSelected ? `${type}:${id}` : '';
93 if (!isSelected) window.$events.emit('entity-select-change', null);
95 item.classList.add('selected');
96 item.classList.add('primary-background');
98 if (!isDblClick && !isSelected) return;
100 let link = item.querySelector('.entity-list-item-link').getAttribute('href');
101 let name = item.querySelector('.entity-list-item-name').textContent;
102 let data = {id: Number(id), name: name, link: link};
104 if (isDblClick) window.$events.emit('entity-select-confirm', data);
105 if (isSelected) window.$events.emit('entity-select-change', data);
109 let selected = this.elem.querySelectorAll('.selected');
110 for (let i = 0, len = selected.length; i < len; i++) {
111 selected[i].classList.remove('selected');
112 selected[i].classList.remove('primary-background');
118 export default EntitySelector;