waow it works :3
Some checks failed
/ build (push) Failing after 15s

This commit is contained in:
vanten-s 2024-12-19 12:24:14 +01:00
parent 5c0810afd0
commit 3ac2beb806
Signed by: vanten-s
GPG key ID: DE3060396884D3F2
4 changed files with 60 additions and 16 deletions

View file

@ -22,3 +22,7 @@ body {
outline: none; outline: none;
box-shadow: none; box-shadow: none;
} }
.terminal {
white-space: pre-wrap;
}

3
src/commands/clear.rs Normal file
View file

@ -0,0 +1,3 @@
pub fn clear(_rader: Vec<String>) -> Vec<String> {
return vec![];
}

17
src/commands/mod.rs Normal file
View file

@ -0,0 +1,17 @@
use log::error;
mod clear;
pub fn run(command: String, rader: Vec<String>) -> Vec<String> {
match command.as_str() {
"" => rader,
"clear" => clear::clear(rader),
unrecognized => unrecognized_command(unrecognized, rader),
}
}
fn unrecognized_command(command: &str, mut rader: Vec<String>) -> Vec<String> {
rader.push(format!("Unrecognized Command \"{command}\""));
error!("Unrecognized Command");
rader
}

View file

@ -1,17 +1,27 @@
use yew::prelude::*;
use log::info; use log::info;
use web_sys::{wasm_bindgen::{JsCast, UnwrapThrowExt}, HtmlInputElement}; use web_sys::{
wasm_bindgen::{JsCast, UnwrapThrowExt},
HtmlInputElement,
};
use yew::prelude::*;
mod commands;
fn get_prompt() -> String {
"[user@vanten-s.com ~]$ ".to_string()
}
#[function_component] #[function_component]
fn App() -> Html { fn App() -> Html {
let rader: UseStateHandle<Vec<String>> = use_state(Vec::new); let rader: UseStateHandle<Vec<String>> = use_state(Vec::new);
let rader_handle = rader.clone(); let rader_handle = rader.clone();
let push_rad = move |rad| { let push_rad = move |rad: String| {
info!("{}", rad); info!("{}", rad);
let handle = rader_handle.clone(); let handle = rader_handle.clone();
let mut val = (*handle).clone(); let mut val = (*handle).clone();
val.push(rad); val.push(get_prompt() + &rad);
val = commands::run(rad, val);
rader_handle.set(val); rader_handle.set(val);
}; };
@ -25,22 +35,28 @@ fn App() -> Html {
#[derive(Properties, PartialEq)] #[derive(Properties, PartialEq)]
struct InputProps { struct InputProps {
pub push_rad: Callback<String> pub push_rad: Callback<String>,
} }
#[function_component] #[function_component]
fn Input(props: &InputProps) -> Html { fn Input(props: &InputProps) -> Html {
let push_rad = props.push_rad.clone(); let push_rad = props.push_rad.clone();
let onchange = move |event: Event| { let onkeydown = move |e: KeyboardEvent| {
let target: HtmlInputElement = event.target().unwrap_throw().dyn_into().unwrap_throw(); if e.code() != "Enter" {
return;
}
let target: HtmlInputElement = e.target().unwrap_throw().dyn_into().unwrap_throw();
let value = target.value(); let value = target.value();
let value = value;
target.set_value(""); target.set_value("");
push_rad.emit(value); push_rad.emit(value);
}; };
html! { html! {
<input { onchange } type="text" class="input"/> <>
<code>{ get_prompt() }</code><input { onkeydown } type="text" class="input"/>
</>
} }
} }
@ -51,14 +67,18 @@ struct TerminalProps {
#[function_component] #[function_component]
fn Terminal(props: &TerminalProps) -> Html { fn Terminal(props: &TerminalProps) -> Html {
let rader: Vec<_> = props.rader.iter().map(|rad| let rader: Vec<_> = props
.rader
.iter()
.map(|rad| {
html! { html! {
<> <>
<span> { rad } </span> <code><wbr /> { rad } </code>
<br /> <br />
</> </>
} }
).collect(); })
.collect();
html! { html! {
<div id="terminal" class="terminal"> <div id="terminal" class="terminal">