Set up a Yew login page
This commit is contained in:
parent
2ff981e28a
commit
ca89455d4d
10
Cargo.lock
generated
10
Cargo.lock
generated
@ -5475,6 +5475,16 @@ version = "0.9.5"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a"
|
checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "visions-client"
|
||||||
|
version = "0.1.0"
|
||||||
|
dependencies = [
|
||||||
|
"gloo-net 0.6.0",
|
||||||
|
"serde 1.0.217",
|
||||||
|
"wasm-bindgen-futures",
|
||||||
|
"yew",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wait-timeout"
|
name = "wait-timeout"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
|
@ -33,4 +33,4 @@ members = [
|
|||||||
"tree",
|
"tree",
|
||||||
"visions/server",
|
"visions/server",
|
||||||
"gm-dash/server"
|
"gm-dash/server"
|
||||||
, "visions/yew-app"]
|
, "visions/yew-app", "visions/ui"]
|
||||||
|
11
visions/ui/Cargo.toml
Normal file
11
visions/ui/Cargo.toml
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
[package]
|
||||||
|
name = "visions-client"
|
||||||
|
version = "0.1.0"
|
||||||
|
edition = "2021"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
gloo-net = "0.6.0"
|
||||||
|
serde = { version = "1.0.217", features = ["derive"] }
|
||||||
|
wasm-bindgen-futures = "0.4.50"
|
||||||
|
yew = { git = "https://github.com/yewstack/yew/", features = ["csr"] }
|
||||||
|
|
36
visions/ui/design.css
Normal file
36
visions/ui/design.css
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
:root {
|
||||||
|
--spacing-s: 4px;
|
||||||
|
--spacing-m: 8px;
|
||||||
|
--shadow-shallow: 2px 2px 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
background-color: hsl(0, 0%, 95%);
|
||||||
|
font-family: Ariel, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
.card {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: space-between;
|
||||||
|
border: 1px solid black;
|
||||||
|
box-shadow: var(--shadow-shallow);
|
||||||
|
border-radius: var(--spacing-s);
|
||||||
|
padding: var(--spacing-m);
|
||||||
|
}
|
||||||
|
|
||||||
|
.card > h1 {
|
||||||
|
margin: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.card > * {
|
||||||
|
margin-top: var(--spacing-s);
|
||||||
|
margin-bottom: var(--spacing-s);
|
||||||
|
}
|
||||||
|
|
||||||
|
.login-form {
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
height: 100vh;
|
||||||
|
}
|
9
visions/ui/index.html
Normal file
9
visions/ui/index.html
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<!doctype html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8" />
|
||||||
|
<title>Visions Client Demo</title>
|
||||||
|
<link data-trunk rel="css" href="design.css" />
|
||||||
|
</head>
|
||||||
|
<body></body>
|
||||||
|
</html>
|
25
visions/ui/src/main.rs
Normal file
25
visions/ui/src/main.rs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
use yew::prelude::*;
|
||||||
|
|
||||||
|
#[function_component]
|
||||||
|
fn Login() -> Html {
|
||||||
|
html! {
|
||||||
|
<div class="login-form">
|
||||||
|
<div class="card">
|
||||||
|
<h1>{"Welcome to Visions VTT"}</h1>
|
||||||
|
<input type="text" name="username" placeholder="username" />
|
||||||
|
<input type="password" name="password" placeholder="password" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[function_component]
|
||||||
|
fn App() -> Html {
|
||||||
|
html! {
|
||||||
|
<Login />
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
yew::Renderer::<App>::new().render();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user