First commit
This commit is contained in:
commit
79b5a7fc44
BIN
assets/alle letters goed.wav
Normal file
BIN
assets/alle letters goed.wav
Normal file
Binary file not shown.
BIN
assets/foute letter.wav
Normal file
BIN
assets/foute letter.wav
Normal file
Binary file not shown.
BIN
assets/goede letter foute plek.wav
Normal file
BIN
assets/goede letter foute plek.wav
Normal file
Binary file not shown.
BIN
assets/goede letter goede plek.wav
Normal file
BIN
assets/goede letter goede plek.wav
Normal file
Binary file not shown.
BIN
assets/keyboard delete letter.wav
Normal file
BIN
assets/keyboard delete letter.wav
Normal file
Binary file not shown.
BIN
assets/send word keyboard.wav
Normal file
BIN
assets/send word keyboard.wav
Normal file
Binary file not shown.
BIN
assets/woord niet geraden.wav
Normal file
BIN
assets/woord niet geraden.wav
Normal file
Binary file not shown.
38
css/index.css
Normal file
38
css/index.css
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
span.letter {
|
||||||
|
font-family: 'Ubuntu', sans-serif;
|
||||||
|
height: 30px;
|
||||||
|
width: 30px;
|
||||||
|
display: inline-block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 25px;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
span.letter.red {
|
||||||
|
background: #ed3746;
|
||||||
|
background: -webkit-gradient(linear, left top, left bottom, from(#ed3746), to(#ed1a2d));
|
||||||
|
background: linear-gradient(to bottom, #ed3746 0%, #ed1a2d 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ed3746', endColorstr='#ed1a2d',GradientType=0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
span.letter.orange {
|
||||||
|
background: #d6b855;
|
||||||
|
background: -webkit-gradient(linear, left top, left bottom, from(#d6b855), to(#d6a400));
|
||||||
|
background: linear-gradient(to bottom, #d6b855 0%, #d6a400 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d6b855', endColorstr='#d6a400',GradientType=0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
span.letter.blue {
|
||||||
|
background: #4094dc;
|
||||||
|
background: -webkit-gradient(linear, left top, left bottom, from(#4094dc), to(#0466c7));
|
||||||
|
background: linear-gradient(to bottom, #4094dc 0%, #0466c7 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4094dc', endColorstr='#0466c7',GradientType=0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
span.letter.grey {
|
||||||
|
background: #838383;
|
||||||
|
background: -webkit-gradient(linear, left top, left bottom, from(#838383), to(#545454));
|
||||||
|
background: linear-gradient(to bottom, #838383 0%, #545454 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#838383', endColorstr='#545454',GradientType=0 );
|
||||||
|
}
|
||||||
|
/*# sourceMappingURL=index.css.map */
|
9
css/index.css.map
Normal file
9
css/index.css.map
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"version": 3,
|
||||||
|
"mappings": "AAAA,AAAA,IAAI,AAAA,OAAO,CAAC;EACR,WAAW,EAAE,oBAAoB;EACjC,MAAM,EAAE,IAAI;EACZ,KAAK,EAAE,IAAI;EACX,OAAO,EAAE,YAAY;EACrB,UAAU,EAAE,MAAM;EAClB,SAAS,EAAE,IAAI;EACf,KAAK,EAAE,KAAK;CA6Bf;;AApCD,AAQI,IARA,AAAA,OAAO,AAQN,IAAI,CAAC;EACF,UAAU,EAAE,OAAO;EACnB,UAAU,EAAE,mDAAoD;EAChE,UAAU,EAAE,sDAAsD;EAClE,UAAU,EAAE,oDAAoD;EAChE,MAAM,EAAE,2GAA2G;CACtH;;AAdL,AAeI,IAfA,AAAA,OAAO,AAeN,OAAO,CAAC;EACL,UAAU,EAAE,OAAO;EACnB,UAAU,EAAE,mDAAoD;EAChE,UAAU,EAAE,sDAAsD;EAClE,UAAU,EAAE,oDAAoD;EAChE,MAAM,EAAE,2GAA2G;CACtH;;AArBL,AAsBI,IAtBA,AAAA,OAAO,AAsBN,KAAK,CAAC;EACH,UAAU,EAAE,OAAO;EACnB,UAAU,EAAE,mDAAoD;EAChE,UAAU,EAAE,sDAAsD;EAClE,UAAU,EAAE,oDAAoD;EAChE,MAAM,EAAE,2GAA2G;CACtH;;AA5BL,AA6BI,IA7BA,AAAA,OAAO,AA6BN,KAAK,CAAC;EACH,UAAU,EAAE,OAAO;EACnB,UAAU,EAAE,mDAAoD;EAChE,UAAU,EAAE,sDAAsD;EAClE,UAAU,EAAE,oDAAoD;EAChE,MAAM,EAAE,2GAA2G;CACtH",
|
||||||
|
"sources": [
|
||||||
|
"index.scss"
|
||||||
|
],
|
||||||
|
"names": [],
|
||||||
|
"file": "index.css"
|
||||||
|
}
|
37
css/index.scss
Normal file
37
css/index.scss
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
span.letter {
|
||||||
|
font-family: 'Ubuntu', sans-serif;
|
||||||
|
height: 30px;
|
||||||
|
width: 30px;
|
||||||
|
display: inline-block;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 25px;
|
||||||
|
color: white;
|
||||||
|
&.red {
|
||||||
|
background: #ed3746;
|
||||||
|
background: -moz-linear-gradient(top, #ed3746 0%, #ed1a2d 100%);
|
||||||
|
background: -webkit-linear-gradient(top, #ed3746 0%,#ed1a2d 100%);
|
||||||
|
background: linear-gradient(to bottom, #ed3746 0%,#ed1a2d 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ed3746', endColorstr='#ed1a2d',GradientType=0 );
|
||||||
|
}
|
||||||
|
&.orange {
|
||||||
|
background: #d6b855;
|
||||||
|
background: -moz-linear-gradient(top, #d6b855 0%, #d6a400 100%);
|
||||||
|
background: -webkit-linear-gradient(top, #d6b855 0%,#d6a400 100%);
|
||||||
|
background: linear-gradient(to bottom, #d6b855 0%,#d6a400 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d6b855', endColorstr='#d6a400',GradientType=0 );
|
||||||
|
}
|
||||||
|
&.blue {
|
||||||
|
background: #4094dc;
|
||||||
|
background: -moz-linear-gradient(top, #4094dc 0%, #0466c7 100%);
|
||||||
|
background: -webkit-linear-gradient(top, #4094dc 0%,#0466c7 100%);
|
||||||
|
background: linear-gradient(to bottom, #4094dc 0%,#0466c7 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4094dc', endColorstr='#0466c7',GradientType=0 );
|
||||||
|
}
|
||||||
|
&.grey {
|
||||||
|
background: #838383;
|
||||||
|
background: -moz-linear-gradient(top, #838383 0%, #545454 100%);
|
||||||
|
background: -webkit-linear-gradient(top, #838383 0%,#545454 100%);
|
||||||
|
background: linear-gradient(to bottom, #838383 0%,#545454 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#838383', endColorstr='#545454',GradientType=0 );
|
||||||
|
}
|
||||||
|
}
|
37
index.html
Normal file
37
index.html
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=Lingo, initial-scale=1.0">
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
||||||
|
<link href="https://fonts.googleapis.com/css?family=Ubuntu:500&display=swap" rel="stylesheet">
|
||||||
|
<link rel="stylesheet" href="./css/index.css">
|
||||||
|
<title>Lingo</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div>
|
||||||
|
<form id="submitForm">
|
||||||
|
<input type="text" id="wordInput" autocomplete="off" placeholder="Submit word">
|
||||||
|
<button type="submit">Versturen</button>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<form id="guessForm" style="display: none;">
|
||||||
|
<input type="text" id="wordInput" autocomplete="off" placeholder="Guess word">
|
||||||
|
<button type="submit">Versturen</button>
|
||||||
|
</form>
|
||||||
|
<button id="restart">Opnieuw beginnen</button>
|
||||||
|
<button id="giveUp">Opgeven</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<span id="letterCount"></span><br>
|
||||||
|
<span id="word"></span><br>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<span id="guesses"></span><br>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<span id="result"></span>
|
||||||
|
|
||||||
|
<script src="./js/index.js"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
132
js/index.js
Normal file
132
js/index.js
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
const submitForm = document.getElementById('submitForm');
|
||||||
|
const guessForm = document.getElementById('guessForm');
|
||||||
|
const guessesList = document.getElementById('guesses');
|
||||||
|
const wordElement = document.getElementById('word');
|
||||||
|
const resultElement = document.getElementById('result');
|
||||||
|
|
||||||
|
var word;
|
||||||
|
var wordArray;
|
||||||
|
var audio = {
|
||||||
|
correctPlace: new Audio('../assets/goede letter goede plek.wav'),
|
||||||
|
correctLetter: new Audio('../assets/goede letter foute plek.wav'),
|
||||||
|
incorrect: new Audio('../assets/foute letter.wav'),
|
||||||
|
allCorrect: new Audio('../assets/alle letters goed.wav'),
|
||||||
|
submitWord: new Audio('../assets/send word keyboard.wav'),
|
||||||
|
giveUp: new Audio('../assets/woord niet geraden.wav'),
|
||||||
|
error: new Audio('../assets/keyboard delete letter.wav')
|
||||||
|
}
|
||||||
|
|
||||||
|
function countInstances(array, value) {
|
||||||
|
var instances = 0;
|
||||||
|
for (let index = 0; index < array.length; index++) {
|
||||||
|
if (array[index] == value) {
|
||||||
|
instances = instances + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return instances;
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkWord(guessArray, wordArray) {
|
||||||
|
var processedLetters = [];
|
||||||
|
var result = [];
|
||||||
|
for (let index = 0; index < wordArray.length; index++) {
|
||||||
|
if (countInstances(processedLetters, guessArray[index]) < countInstances(wordArray, guessArray[index])) {
|
||||||
|
if (wordArray[index] == guessArray[index]) {
|
||||||
|
result.push('blue');
|
||||||
|
} else if (wordArray.indexOf(guessArray[index]) != -1) {
|
||||||
|
result.push('orange');
|
||||||
|
} else {
|
||||||
|
result.push('red');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
result.push('red');
|
||||||
|
}
|
||||||
|
processedLetters.push(guessArray[index]);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
submitForm.addEventListener('submit', function(event) {
|
||||||
|
event.preventDefault();
|
||||||
|
word = submitForm.children[0].value;
|
||||||
|
if (word.split('').length > 0) {
|
||||||
|
word = word.toUpperCase();
|
||||||
|
wordArray = word.split('');
|
||||||
|
resultElement.innerHTML = '';
|
||||||
|
|
||||||
|
if (wordArray.includes(' ')) {
|
||||||
|
audio.error.play();
|
||||||
|
resultElement.innerHTML = "JP: Er mogen geen spaties in een Lingowoord.";
|
||||||
|
} else {
|
||||||
|
audio.submitWord.play();
|
||||||
|
submitForm.style.display = 'none';
|
||||||
|
guessForm.style.display = 'block';
|
||||||
|
document.getElementById('letterCount').innerHTML = wordArray.length + " letter Lingo";
|
||||||
|
for (let index = 0; index < wordArray.length; index++) {
|
||||||
|
if (index == 0) {
|
||||||
|
wordElement.innerHTML += `<span class="letter blue">${wordArray[index]}</span>`;
|
||||||
|
} else {
|
||||||
|
wordElement.innerHTML += `<span class="letter grey">-</span>`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
audio.error.play();
|
||||||
|
resultElement.innerHTML = "JP: Dat woord is wel erg kort.";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
guessForm.addEventListener('submit', function(event) {
|
||||||
|
event.preventDefault();
|
||||||
|
var guess = guessForm.children[0].value;
|
||||||
|
guess = guess.toUpperCase();
|
||||||
|
var guessArray = guess.split('');
|
||||||
|
guessForm.children[0].value = '';
|
||||||
|
resultElement.innerHTML = '';
|
||||||
|
|
||||||
|
if (wordArray != undefined) {
|
||||||
|
if (guess.length == word.length) {
|
||||||
|
var result = checkWord(guessArray, wordArray);
|
||||||
|
if (guessesList.innerHTML != '') {
|
||||||
|
guessesList.innerHTML += '<br>';
|
||||||
|
}
|
||||||
|
let index = 0;
|
||||||
|
function showLetter() {
|
||||||
|
const color = result[index];
|
||||||
|
guessesList.innerHTML += `<span class="letter ${color}">${guessArray[index]}</span>`;
|
||||||
|
if (color == 'blue') {
|
||||||
|
audio.correctPlace.currentTime = 0;
|
||||||
|
audio.correctPlace.play();
|
||||||
|
}
|
||||||
|
else if (color == 'orange') {
|
||||||
|
audio.correctLetter.currentTime = 0;
|
||||||
|
audio.correctLetter.play();
|
||||||
|
}
|
||||||
|
else if (color == 'red') {
|
||||||
|
audio.incorrect.currentTime = 0;
|
||||||
|
audio.incorrect.play();
|
||||||
|
}
|
||||||
|
index++;
|
||||||
|
if(index < guessArray.length){
|
||||||
|
setTimeout(showLetter, 200);
|
||||||
|
} else if (guess == word) {
|
||||||
|
audio.allCorrect.play();
|
||||||
|
resultElement.innerHTML = "JP: Gefeliciteerd, u heeft gewonnen";
|
||||||
|
guessForm.style.display = 'none';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
showLetter();
|
||||||
|
} else {
|
||||||
|
audio.error.play();
|
||||||
|
resultElement.innerHTML = "JP: Dit woord is niet de goede lengte.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
document.getElementById('giveUp').addEventListener('click', function () {
|
||||||
|
audio.giveUp.play();
|
||||||
|
});
|
||||||
|
|
||||||
|
document.getElementById('restart').addEventListener('click', function () {
|
||||||
|
location.reload();
|
||||||
|
});
|
5
package-lock.json
generated
Normal file
5
package-lock.json
generated
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"name": "lingo",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"lockfileVersion": 1
|
||||||
|
}
|
16
package.json
Normal file
16
package.json
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
{
|
||||||
|
"name": "lingo",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "",
|
||||||
|
"main": "index.js",
|
||||||
|
"scripts": {
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "lingo"
|
||||||
|
},
|
||||||
|
"author": "McArn",
|
||||||
|
"license": "ISC",
|
||||||
|
"dependencies": {}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user