summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/kotlin/moe/nea89/website/KConsole.kt39
-rw-r--r--src/main/kotlin/moe/nea89/website/ShellExecutionContext.kt18
-rw-r--r--src/main/kotlin/moe/nea89/website/index.kt18
-rw-r--r--src/main/resources/images/me.jpegbin0 -> 567270 bytes
-rw-r--r--src/main/resources/images/moisturized.jpgbin0 -> 41960 bytes
-rw-r--r--webpack.config.d/style.js3
6 files changed, 54 insertions, 24 deletions
diff --git a/src/main/kotlin/moe/nea89/website/KConsole.kt b/src/main/kotlin/moe/nea89/website/KConsole.kt
index 6c4f707..95b0e42 100644
--- a/src/main/kotlin/moe/nea89/website/KConsole.kt
+++ b/src/main/kotlin/moe/nea89/website/KConsole.kt
@@ -2,8 +2,11 @@ package moe.nea89.website
import kotlinx.browser.document
import kotlinx.html.dom.append
+import kotlinx.html.dom.create
+import kotlinx.html.js.p
import kotlinx.html.js.pre
import org.w3c.dom.HTMLElement
+import org.w3c.dom.HTMLParagraphElement
import org.w3c.dom.HTMLPreElement
import org.w3c.dom.events.KeyboardEvent
import kotlin.collections.set
@@ -11,7 +14,8 @@ import kotlin.collections.set
class KConsole(
private val root: HTMLElement,
private val text: HTMLPreElement,
- private val fileSystem: KFileSystem?,
+ private val prompt: HTMLElement,
+ fileSystem: KFileSystem?,
) {
val fileAccessor = fileSystem?.let { FileAccessor(it) }
@@ -22,8 +26,9 @@ class KConsole(
fun createFor(element: HTMLElement, fileSystem: KFileSystem? = null): KConsole {
val text = element.append.pre()
+ val prompt = text.append.p()
element.classList.add(Styles.consoleClass)
- val console = KConsole(element, text, fileSystem)
+ val console = KConsole(element, text, prompt, fileSystem)
document.body!!.onkeydown = console::keydown
console.addLine("Starting up terminal.")
console.rerender()
@@ -38,12 +43,10 @@ class KConsole(
var state = ConsoleState.SHELLPROMPT
- val lines = mutableListOf<String>()
-
var input: String = ""
fun addLines(newLines: List<String>) {
- lines.addAll(newLines)
+ newLines.forEach(this::addLine)
}
fun addMultilineText(text: String) {
@@ -51,19 +54,25 @@ class KConsole(
}
fun addLine(line: String) {
- lines.add(line)
+ addLine(document.create.p {
+ text(line)
+ })
}
- fun scrollDown() {
- text.lastElementChild?.scrollIntoView()
+ fun addLine(element: HTMLParagraphElement) {
+ text.insertBefore(element, prompt)
}
fun rerender() {
- var view = lines.joinToString(separator = "\n")
- if (state == ConsoleState.SHELLPROMPT) {
- view += "\n${'$'} $input"
+ if (state == KConsole.ConsoleState.SHELLPROMPT) {
+ prompt.innerText = "${'$'} $input"
+ } else {
+ prompt.innerText = ""
}
- text.innerText = view
+ }
+
+ fun scrollDown() {
+ text.lastElementChild?.scrollIntoView()
}
fun registerCommand(command: Command) {
@@ -77,10 +86,13 @@ class KConsole(
fun executeCommand(commandLine: String) {
val parts = shlex(commandLine)
- if (parts.isNullOrEmpty()) {
+ if (parts == null) {
addLine("Syntax Error")
return
}
+ if (parts.isEmpty()) {
+ return
+ }
val command = parts[0]
println("Running command: $command")
val arguments = parts.drop(1)
@@ -127,6 +139,7 @@ class KConsole(
if (event.key.length == 1 || event.key.any { it !in 'a'..'z' && it !in 'A'..'Z' })
input += event.key
}
+ event.preventDefault()
rerender()
scrollDown()
}
diff --git a/src/main/kotlin/moe/nea89/website/ShellExecutionContext.kt b/src/main/kotlin/moe/nea89/website/ShellExecutionContext.kt
index cec0b9e..bd72421 100644
--- a/src/main/kotlin/moe/nea89/website/ShellExecutionContext.kt
+++ b/src/main/kotlin/moe/nea89/website/ShellExecutionContext.kt
@@ -35,15 +35,17 @@ class ShellExecutionContext(
) {
console.state = KConsole.ConsoleState.IN_PROGRAM
val se = ShellExecutionContext(console, name, args)
- command.runner.createCoroutine(se, object : Continuation<Unit> {
- override val context: CoroutineContext
- get() = EmptyCoroutineContext
+ window.requestAnimationFrame {
+ command.runner.createCoroutine(se, object : Continuation<Unit> {
+ override val context: CoroutineContext
+ get() = EmptyCoroutineContext
- override fun resumeWith(result: Result<Unit>) {
- console.state = KConsole.ConsoleState.SHELLPROMPT
- console.rerender()
- }
- }).resume(Unit)
+ override fun resumeWith(result: Result<Unit>) {
+ console.state = KConsole.ConsoleState.SHELLPROMPT
+ console.rerender()
+ }
+ }).resume(Unit)
+ }
}
}
}
diff --git a/src/main/kotlin/moe/nea89/website/index.kt b/src/main/kotlin/moe/nea89/website/index.kt
index 4a69a14..4eea755 100644
--- a/src/main/kotlin/moe/nea89/website/index.kt
+++ b/src/main/kotlin/moe/nea89/website/index.kt
@@ -3,7 +3,11 @@ package moe.nea89.website
import kotlinext.js.require
import kotlinx.browser.document
import kotlinx.html.dom.append
+import kotlinx.html.dom.create
+import kotlinx.html.img
+import kotlinx.html.js.a
import kotlinx.html.js.div
+import kotlinx.html.js.p
import styled.injectGlobal
import kotlin.time.Duration.Companion.milliseconds
@@ -17,6 +21,8 @@ val defaultFileSystem = fileSystem {
| - finish this website
| - convince the general public that comic sans is a viable font
""".trimMargin()
+ "moisturized" image require("images/moisturized.jpg")
+ "download" download require("images/me.jpeg")
}
"flag" text "CTF{12345abcdefghijklmonp3.1.4.1.5.9.2.8}"
}
@@ -88,8 +94,16 @@ fun main() {
when (file) {
is KFile.Directory -> console.addLine("cat: Is a directory")
is KFile.Text -> console.addMultilineText(file.text)
- is KFile.Image -> console.addMultilineText("Imagine here was an image: ${file.url}")
- is KFile.Download -> console.addMultilineText("Imageine here was a download: ${file.url}")
+ is KFile.Image -> console.addLine(document.create.p {
+ img(src = file.url)
+ })
+ is KFile.Download -> {
+ val link = document.create.a(file.url)
+ link.download = file.name.last()
+ document.body!!.append(link)
+ link.click()
+ link.remove()
+ }
}
})
console.registerCommand(command("dick", "cock") {
diff --git a/src/main/resources/images/me.jpeg b/src/main/resources/images/me.jpeg
new file mode 100644
index 0000000..1d829fa
--- /dev/null
+++ b/src/main/resources/images/me.jpeg
Binary files differ
diff --git a/src/main/resources/images/moisturized.jpg b/src/main/resources/images/moisturized.jpg
new file mode 100644
index 0000000..89767ea
--- /dev/null
+++ b/src/main/resources/images/moisturized.jpg
Binary files differ
diff --git a/webpack.config.d/style.js b/webpack.config.d/style.js
index 0e46452..0b521a8 100644
--- a/webpack.config.d/style.js
+++ b/webpack.config.d/style.js
@@ -1,2 +1,3 @@
config.resolve.modules.push("src/main/resources/")
-config.module.rules.push({test: /\.txt$/, type: 'asset/source'}) \ No newline at end of file
+config.module.rules.push({test: /\.txt$/, type: 'asset/source'})
+config.module.rules.push({test: /\.(png|jpg|jpeg|svg|gif)$/i, type: 'asset/resource'}) \ No newline at end of file