Added: able to write keystrokes into command line
This commit is contained in:
parent
f137aceb6e
commit
e7e8b78904
4
content/console.md
Normal file
4
content/console.md
Normal file
@ -0,0 +1,4 @@
|
||||
+++
|
||||
title = "Console"
|
||||
template = "console.html"
|
||||
+++
|
5
sass/console.scss
Normal file
5
sass/console.scss
Normal file
@ -0,0 +1,5 @@
|
||||
.console {
|
||||
background: gray;
|
||||
width: 80vw;
|
||||
min-height: 20vh;
|
||||
}
|
43
static/js/console.js
Normal file
43
static/js/console.js
Normal file
@ -0,0 +1,43 @@
|
||||
const c = document.querySelector(".console")
|
||||
const ps1 = "[fr@website ~]$ "
|
||||
|
||||
function write(key) {
|
||||
console.log("KEY:", key)
|
||||
switch(key) {
|
||||
case "Enter":
|
||||
c.innerHTML += "<br>"
|
||||
c.innerHTML += ps1
|
||||
return
|
||||
case "000ctrll":
|
||||
c.innerHTML = ""
|
||||
c.innerHTML += ps1
|
||||
return
|
||||
default:
|
||||
c.innerHTML += key
|
||||
}
|
||||
}
|
||||
|
||||
function customCtrlShortcuts(plusKey) {
|
||||
document.addEventListener("keydown", e => {
|
||||
if(e.ctrlKey && e.key == plusKey) {
|
||||
e.preventDefault()
|
||||
write("000ctrl"+plusKey)
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
// On load init the terminal
|
||||
window.addEventListener("load", () => {
|
||||
write("000ctrll")
|
||||
})
|
||||
|
||||
// Capture the keypress
|
||||
window.addEventListener("keypress", e => {
|
||||
console.log(e)
|
||||
write(e.key)
|
||||
})
|
||||
|
||||
// Register custom ctrl shortcuts
|
||||
customCtrlShortcuts("l") // ctrl + l
|
||||
customCtrlShortcuts("c") // ctrl + c
|
||||
|
11
templates/console.html
Normal file
11
templates/console.html
Normal file
@ -0,0 +1,11 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
{% block styles %}
|
||||
<link rel="stylesheet" href="/console.css">
|
||||
{% endblock styles %}
|
||||
|
||||
{% block content %}
|
||||
<section class="console content">
|
||||
</section>
|
||||
<script src="/js/console.js" defer></script>
|
||||
{% endblock content %}
|
Loading…
Reference in New Issue
Block a user