aboutsummaryrefslogtreecommitdiffhomepage
path: root/assets/vintage/js/base.js
diff options
context:
space:
mode:
Diffstat (limited to 'assets/vintage/js/base.js')
-rw-r--r--assets/vintage/js/base.js45
1 files changed, 26 insertions, 19 deletions
diff --git a/assets/vintage/js/base.js b/assets/vintage/js/base.js
index 66830b59..15b664ce 100644
--- a/assets/vintage/js/base.js
+++ b/assets/vintage/js/base.js
@@ -2,29 +2,36 @@ import Awesomplete from 'awesomplete';
2import 'awesomplete/awesomplete.css'; 2import 'awesomplete/awesomplete.css';
3 3
4(() => { 4(() => {
5 const awp = Awesomplete.$;
6 const autocompleteFields = document.querySelectorAll('input[data-multiple]'); 5 const autocompleteFields = document.querySelectorAll('input[data-multiple]');
6 const tagsSeparatorElement = document.querySelector('input[name="tags_separator"]');
7 const tagsSeparator = tagsSeparatorElement ? tagsSeparatorElement.value || " " : " ";
8
7 [...autocompleteFields].forEach((autocompleteField) => { 9 [...autocompleteFields].forEach((autocompleteField) => {
8 const awesomplete = new Awesomplete(awp(autocompleteField)); 10 const awesome = new Awesomplete(Awesomplete.$(autocompleteField));
9 awesomplete.filter = (text, input) => Awesomplete.FILTER_CONTAINS(text, input.match(/[^ ]*$/)[0]);
10 awesomplete.replace = (text) => {
11 const before = awesomplete.input.value.match(/^.+ \s*|/)[0];
12 awesomplete.input.value = `${before}${text} `;
13 };
14 awesomplete.minChars = 1;
15 11
16 autocompleteField.addEventListener('input', () => { 12 // Tags are separated by separator
17 const proposedTags = autocompleteField.getAttribute('data-list').replace(/,/g, '').split(' '); 13 awesome.filter = (text, input) => Awesomplete.FILTER_CONTAINS(
18 const reg = /(\w+) /g; 14 text,
19 let match; 15 input.match(new RegExp(`[^${tagsSeparator}]*$`))[0])
20 while ((match = reg.exec(autocompleteField.value)) !== null) { 16 ;
21 const id = proposedTags.indexOf(match[1]); 17 // Insert new selected tag in the input
22 if (id !== -1) { 18 awesome.replace = (text) => {
23 proposedTags.splice(id, 1); 19 const before = awesome.input.value.match(new RegExp(`^.+${tagsSeparator}+|`))[0];
20 awesome.input.value = `${before}${text}${tagsSeparator}`;
21 };
22 // Highlight found items
23 awesome.item = (text, input) => Awesomplete.ITEM(text, input.match(new RegExp(`[^${tagsSeparator}]*$`))[0]);
24 // Don't display already selected items
25 const reg = new RegExp(`/(\w+)${tagsSeparator}/g`);
26 let match;
27 awesome.data = (item, input) => {
28 while ((match = reg.exec(input))) {
29 if (item === match[1]) {
30 return '';
24 } 31 }
25 } 32 }
26 33 return item;
27 awesomplete.list = proposedTags; 34 };
28 }); 35 awesome.minChars = 1;
29 }); 36 });
30})(); 37})();