about summary refs log tree commit diff
path: root/script.js
diff options
context:
space:
mode:
Diffstat (limited to 'script.js')
-rw-r--r--script.js119
1 files changed, 119 insertions, 0 deletions
diff --git a/script.js b/script.js
index e69de29..ea4bd12 100644
--- a/script.js
+++ b/script.js
@@ -0,0 +1,119 @@
+class Wednesdayle {
+	constructor() {
+		this.active = true;
+		this.nextBox = 0;
+		this.boxes = new Array();
+		for (let i = 0; i < 9; ++i) {
+			this.boxes.push(document.getElementById('box' + i));
+		}
+
+		this.buttons = new Array();
+		for (let i = 0; i < 7; ++i) {
+			let btn = document.getElementById('key' + i);
+			btn.addEventListener('click', this.buttonPush.bind(this));
+			this.buttons.push(btn);
+		}
+
+		window.addEventListener('keydown', this.keydown.bind(this));
+
+		this.delete = document.getElementById('delete');
+		this.delete.addEventListener('click', this.letterUndid.bind(this));
+
+		this.enter = document.getElementById('enter');
+		this.enter.addEventListener('click', this.submit.bind(this));
+
+		this.dropdown = document.getElementById('dropdown');
+		document.getElementById('close-dropdown').addEventListener('click', this.closeDropdown.bind(this));
+
+		this.theword = document.getElementById('theword');
+		this.notword = document.getElementById('notword');
+	}
+
+	// Terrible function name genny
+	letterDid(letter) {
+		if (!this.active) {
+			return;
+		}
+
+		if (this.nextBox < this.boxes.length) {
+			let up = letter.toUpperCase();
+
+			this.boxes[this.nextBox].innerText = up;
+			if (this.nextBox < this.boxes.length) {
+				this.nextBox++;
+			}
+		}
+	}
+
+	// undid? really? genny,,,
+	letterUndid() {
+		if (!this.active) {
+			return;
+		}
+
+		if (this.nextBox > 0) {
+			this.nextBox--;
+			this.boxes[this.nextBox].innerText = '';
+		}
+	}
+
+	submit() {
+		if (!this.active) {
+			return;
+		}
+
+		let word = "wednesday";
+		for (let i = 0; i < this.boxes.length; ++i) {
+			if (word[i].toUpperCase() != this.boxes[i].innerText.toUpperCase()) {
+				this.notword.style.display = "block";
+				this.active = false;
+				return;
+			}
+		}
+
+		this.theword.style.display = "block";
+		this.active = false;
+	}
+
+	buttonPush(event) {
+		if (!this.active) {
+			return;
+		}
+
+		let btn = event.target;
+		let letter = btn.innerText;
+
+		this.letterDid(letter);
+	}
+
+	keydown(event) {
+		if (!this.active) {
+			return;
+		}
+
+		let allowed = "weyadsn";
+		let key = event.key;
+
+		if (allowed.includes(key)) {
+			this.letterDid(key);
+		} else if (key == "Enter") {
+			this.submit();
+		} else if (key == "Backspace") {
+			this.letterUndid();
+		}
+	}
+
+	closeDropdown() {
+		console.log('thf');
+		this.dropdown.style.display = "none";
+	}
+}
+
+let wednesdayle;
+
+function setup() {
+	console.log("started");
+	wednesdayle = new Wednesdayle();
+}
+
+window.addEventListener('DOMContentLoaded', setup)
\ No newline at end of file