-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathuserInput.js
71 lines (59 loc) · 1.85 KB
/
userInput.js
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
70
71
var words = document.getElementById("tenWords");
words.innerHTML = '';
var definition = document.getElementById("definition");
definition.innerHTML = '';
function checkInputIsLongerThanThreeletters() {
var userInput = document.getElementById("search").value;
if (userInput.length > 3 && /^[a-zA-Z]+$/.test(userInput)) {
sendInputToRequestWords(userInput);
}
}
var correct;
var wordsArray;
function sendInputToRequestWords(userInput) {
var request = new XMLHttpRequest();
request.onreadystatechange = function() {
if (request.readyState === 4) {
fullArray = request.responseText.split('£');
wordsArray = fullArray[0];
var def = fullArray[1];
correct = parseInt(fullArray[2]);
wordsArray = wordsArray.replace(/[\[]*["]*[\]]*/g, '').split(',');
setListToZero(words);
addWords(wordsArray);
setListToZero(definition);
getDefinition(def);
}
};
request.open("GET", "/define/" + userInput, true);
request.send(userInput);
}
document.getElementById("search").addEventListener("keyup", function(e) {
checkInputIsLongerThanThreeletters();
});
function setListToZero(element) {
element.innerHTML = '';
element.innerHTML += '<ul id="words"></ul>';
}
function addWords(wordsArray) {
var words = document.getElementById('tenWords');
for (i = 0; i < 10; i++) {
if (wordsArray[i] === undefined) {
wordsArray[i] = '';
} else {
words.innerHTML += '<li class="words" id="words' + i + '" onclick="chooseClass(this.id)">' + wordsArray[i] + '</li>';
}
}
}
function getDefinition(def) {
var definintion = document.getElementById('definintion');
definition.innerHTML += def;
}
function chooseClass(id) {
var choice = id.slice(-1);
if (choice == correct) {
document.getElementById(id).className = 'green';
} else {
document.getElementById(id).className = 'red';
}
}