Files
destruction-of-legacy/text_horror/app.js
2023-05-27 22:15:39 +02:00

83 lines
3.1 KiB
JavaScript

var speed = 50;
var typeindex = 0;
var dlgPointer = 0;
var dlgFile;
let dlgLines;
var answers;
var keys;
//BUG: You cant put anything other than a string at the beginning of a dialogue array
//TODO: Save last Object in a temp variable before setting the new dialogue from the answerbox to make a way back funtion possible
function load() {
fetch("text_horror/dialogue.json")
.then(Response => Response.json())
.then(data => {
dlgFile = data;
changeDlg("start");
})
}
function changeDlg(dlgKey) {
dlgPointer = 0;
typeindex = 0;
speed = 50;
dlgLines = dlgFile[dlgKey];
document.getElementById("dlg-text").innerHTML = "";
typeWriter();
}
function typeWriter() {
if (document.getElementById("dlg-text").innerHTML.length < dlgLines[dlgPointer].length) {
document.getElementById("dlg-text").innerHTML += dlgLines[dlgPointer].charAt(typeindex);
typeindex++;
document.getElementById("triangle").hidden = document.getElementById("dlg-text").innerHTML.length != dlgLines[dlgPointer].length
setTimeout(typeWriter, speed); //loops because of running "typeWriter" after waiting
}
}
function nextDlg() {
document.getElementById("triangle").hidden = true;
if (document.getElementById("dlg-text").innerHTML.length == dlgLines[dlgPointer].length) { //check if text is typed out
if (dlgPointer < dlgLines.length - 1) { //check if dlgPointer is not at the array end
do {
dlgPointer++;
if (typeof dlgLines[dlgPointer] === 'number')
speed = 50 / dlgLines[dlgPointer];
else if (typeof dlgLines[dlgPointer] === 'object') {
document.getElementById("answer-box").hidden = false;
document.getElementById("bubble").onclick = null;
answers = document.getElementsByClassName("answer");
keys = Object.keys(dlgLines[dlgPointer]);
for (let j = 0; j < keys.length; j++) { //why is the length one smaller? Does javascript make any sense someday?
answers.item(j).innerHTML = keys[j];
}
break;
}
else if (typeof dlgLines[dlgPointer] === 'string' && dlgLines[dlgPointer].startsWith("_")) {
if (dlgLines[dlgPointer].split(":")[0] === "_title")
document.getElementById("title").innerHTML = dlgLines[dlgPointer].split(':')[1];
}
}
while (!(typeof dlgLines[dlgPointer] === 'string') || dlgLines[dlgPointer].startsWith("_")) //again if it's not string
if (typeof dlgLines[dlgPointer] === 'string') {
typeindex = 0;
document.getElementById("dlg-text").innerHTML = "";
typeWriter();
}
} else {
document.getElementById("bubble").hidden = true;
document.getElementById("answer-box").hidden = true;
}
}
}
function answered(answerId) {
dlgFile = dlgLines[dlgPointer];
document.getElementById("bubble").addEventListener("click", nextDlg);
document.getElementById("answer-box").hidden = true;
changeDlg(document.getElementById(answerId).innerHTML);
for (let j = 0; j < keys.length; j++) { //why is the length one smaller? Does javascript make any sense someday?
answers.item(j).innerHTML = "";
}
}