blob: 123a2f1c816207024bbd1eaf5139cdbd22e4372b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
const fuzzy = require('fuzzy')
const getUsers = require('./getUsers')
const getURLOfUser = require('./getURLOfUser')
const searchNode = document.querySelector('#search')
const inputNode = searchNode.querySelector('input[type="text"]')
const autocompleteNode = document.querySelector('.autocomplete')
const scheduleIframe = document.querySelector('#schedule')
let selectedResult = -1
let results
let matches
getUsers().then(function (users) {
// console.log(users)
searchNode.addEventListener('keydown', function (e) {
if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {
e.preventDefault()
if (document.querySelector('.selected')) document.querySelector('.selected').classList.remove('selected')
const change = e.key === 'ArrowDown' ? 1 : -1
selectedResult += change
if (selectedResult < -1) selectedResult = matches.length - 1
else if (selectedResult > matches.length - 1) selectedResult = -1
if (selectedResult !== -1) autocompleteNode.children[selectedResult].classList.add('selected')
}
})
searchNode.addEventListener('keyup', function (e) {
// console.log(e)
if (!(e.key === 'Enter' || e.key === 'ArrowDown' || e.key === 'ArrowUp' || e.key === 'ArrowLeft' || e.key === 'ArrowRight')) {
autocompleteNode.innerHTML = ''
if (inputNode.value.trim() === '') return
selectedResult = -1
results = fuzzy.filter(inputNode.value, users, {
pre: '<strong>',
post: '</strong>',
extract: el => el.value
}).slice(0, 7)
matches = results.map(function (el) { return el.string })
matches.forEach(function (match) {
const resultNode = document.createElement('li')
resultNode.innerHTML = match
autocompleteNode.appendChild(resultNode)
})
}
})
searchNode.addEventListener('submit', function (e) {
e.preventDefault()
const indexInResult = selectedResult === -1 ? 0 : selectedResult
const selectedUser = users[results[indexInResult].index]
inputNode.value = selectedUser.value
autocompleteNode.innerHTML = ''
inputNode.blur()
scheduleIframe.src = getURLOfUser(0, selectedUser.type, selectedUser.index + 1)
})
})
inputNode.addEventListener('click', function () {
inputNode.select()
})
|