Change style.
This commit is contained in:
parent
4b389f9d9e
commit
7918707dd9
|
@ -1,94 +1,20 @@
|
||||||
use gloo_timers::callback::Interval;
|
|
||||||
use rand::Rng;
|
|
||||||
use yew::prelude::*;
|
use yew::prelude::*;
|
||||||
|
|
||||||
/// The main page `<footer>` element.
|
/// The main page `<footer>` element.
|
||||||
pub(crate) struct PageFooter {
|
pub(crate) struct PageFooter;
|
||||||
/// The handle to the `setInterval`, this is stored so it doesn't get dropped
|
|
||||||
/// and stop the interval from happening.
|
|
||||||
_interval_handle: Interval,
|
|
||||||
/// The number of which square is currently active.
|
|
||||||
active_square: u32,
|
|
||||||
/// The link to this component.
|
|
||||||
link: ComponentLink<Self>,
|
|
||||||
/// The maximum number of squares to render.
|
|
||||||
max_squares: u32,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The possible messages for [`PageFooter`].
|
|
||||||
#[derive(Debug)]
|
|
||||||
pub(crate) enum PageFooterMessage {
|
|
||||||
/// The message to decrease the max squares by 1.
|
|
||||||
DecrementMaxSquares,
|
|
||||||
/// The message to increase the max squares by 1.
|
|
||||||
IncrementMaxSquares,
|
|
||||||
/// The message from the interval to update the active square.
|
|
||||||
TickActiveSquare,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Component for PageFooter {
|
impl Component for PageFooter {
|
||||||
type Message = PageFooterMessage;
|
type Message = ();
|
||||||
type Properties = ();
|
type Properties = ();
|
||||||
|
|
||||||
fn create(_props: Self::Properties, link: ComponentLink<Self>) -> Self {
|
fn create(_props: Self::Properties, _link: ComponentLink<Self>) -> Self {
|
||||||
log::trace!("Creating PageFooter");
|
log::trace!("Creating PageFooter");
|
||||||
|
|
||||||
let interval_handle = {
|
Self
|
||||||
let link = link.clone();
|
|
||||||
Interval::new(1000, move || {
|
|
||||||
link.send_message(Self::Message::TickActiveSquare)
|
|
||||||
})
|
|
||||||
};
|
|
||||||
|
|
||||||
Self {
|
|
||||||
_interval_handle: interval_handle,
|
|
||||||
active_square: 0,
|
|
||||||
link,
|
|
||||||
max_squares: 5,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update(&mut self, msg: Self::Message) -> ShouldRender {
|
fn update(&mut self, _msg: Self::Message) -> ShouldRender {
|
||||||
log::trace!("PageFooterMessage::{:?}", msg);
|
unimplemented!()
|
||||||
|
|
||||||
match msg {
|
|
||||||
Self::Message::DecrementMaxSquares => {
|
|
||||||
if self.max_squares > 1 {
|
|
||||||
self.max_squares -= 1;
|
|
||||||
log::debug!("Max squares set to {}", self.max_squares);
|
|
||||||
true
|
|
||||||
} else {
|
|
||||||
false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Self::Message::IncrementMaxSquares => {
|
|
||||||
if self.max_squares < 360 {
|
|
||||||
self.max_squares += 1;
|
|
||||||
log::debug!("Max squares set to {}", self.max_squares);
|
|
||||||
true
|
|
||||||
} else {
|
|
||||||
false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Self::Message::TickActiveSquare => {
|
|
||||||
if self.max_squares == 1 {
|
|
||||||
if self.active_square == 0 {
|
|
||||||
self.active_square = 1;
|
|
||||||
} else {
|
|
||||||
self.active_square = 0;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
self.active_square += 1;
|
|
||||||
if self.active_square >= self.max_squares {
|
|
||||||
self.active_square = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn change(&mut self, _props: Self::Properties) -> ShouldRender {
|
fn change(&mut self, _props: Self::Properties) -> ShouldRender {
|
||||||
|
@ -96,69 +22,8 @@ impl Component for PageFooter {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn view(&self) -> Html {
|
fn view(&self) -> Html {
|
||||||
let squares = (0..self.max_squares)
|
|
||||||
.into_iter()
|
|
||||||
.map(|square| {
|
|
||||||
let mut classes = classes!("square");
|
|
||||||
if square == self.active_square {
|
|
||||||
classes.push("active");
|
|
||||||
}
|
|
||||||
|
|
||||||
let hue = {
|
|
||||||
if self.max_squares == 1 {
|
|
||||||
rand::thread_rng().gen_range(0..=360)
|
|
||||||
} else {
|
|
||||||
(360 / self.max_squares) * square
|
|
||||||
}
|
|
||||||
};
|
|
||||||
let style = format!("background-color: hsl({}, 100%, 50%);", hue);
|
|
||||||
|
|
||||||
return html! {
|
|
||||||
<div style=style class=classes />
|
|
||||||
};
|
|
||||||
})
|
|
||||||
.collect::<Html>();
|
|
||||||
|
|
||||||
let squares = {
|
|
||||||
let style = format!(
|
|
||||||
"--square-transition: {0}s; --squares: {0};",
|
|
||||||
self.max_squares
|
|
||||||
);
|
|
||||||
let decrement = self
|
|
||||||
.link
|
|
||||||
.callback(|_| PageFooterMessage::DecrementMaxSquares);
|
|
||||||
let increment = self
|
|
||||||
.link
|
|
||||||
.callback(|_| PageFooterMessage::IncrementMaxSquares);
|
|
||||||
|
|
||||||
html! {
|
html! {
|
||||||
<div style=style class="squares">
|
<footer class="page-footer"></footer>
|
||||||
<button onclick=decrement>{"-"}</button>
|
|
||||||
{squares}
|
|
||||||
<button onclick=increment>{"+"}</button>
|
|
||||||
</div>
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
let technologies = html! {
|
|
||||||
<p class="technologies">
|
|
||||||
{"Written in "}
|
|
||||||
<a target="_blank" href="https://www.rust-lang.org">{"Rust"}</a>
|
|
||||||
{" with "}
|
|
||||||
<a target="_blank" href="https://yew.rs">{"Yew"}</a>
|
|
||||||
{" and compiled to "}
|
|
||||||
<a target="_blank" href="https://webassembly.org">{"WebAssembly"}</a>
|
|
||||||
{" with "}
|
|
||||||
<a target="_blank" href="https://trunkrs.dev">{"Trunk"}</a>
|
|
||||||
{"."}
|
|
||||||
</p>
|
|
||||||
};
|
|
||||||
|
|
||||||
html! {
|
|
||||||
<footer class="page-footer">
|
|
||||||
{squares}
|
|
||||||
{technologies}
|
|
||||||
</footer>
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
@mixin responsive-container {
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
width: 1000px;
|
|
||||||
}
|
|
|
@ -1,5 +1,4 @@
|
||||||
.error-404 {
|
.error-404 {
|
||||||
@include responsive-container;
|
|
||||||
align-items: center;
|
align-items: center;
|
||||||
display: flex;
|
display: flex;
|
||||||
height: 100vh;
|
height: 100vh;
|
||||||
|
|
|
@ -1,40 +1,3 @@
|
||||||
.page-footer {
|
.page-footer {
|
||||||
@include responsive-container;
|
|
||||||
margin-top: 1rem;
|
margin-top: 1rem;
|
||||||
|
|
||||||
.squares {
|
|
||||||
display: grid;
|
|
||||||
grid-template-columns: min-content repeat(var(--squares, 5), 1fr) min-content;
|
|
||||||
height: 1rem;
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
|
|
||||||
button {
|
|
||||||
align-items: center;
|
|
||||||
border: none;
|
|
||||||
display: flex;
|
|
||||||
font-family: monospace;
|
|
||||||
font-size: 1rem;
|
|
||||||
height: 100%;
|
|
||||||
justify-content: center;
|
|
||||||
width: 2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.square {
|
|
||||||
height: 100%;
|
|
||||||
|
|
||||||
&.active {
|
|
||||||
opacity: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:not(.active) {
|
|
||||||
opacity: 0%;
|
|
||||||
transition: opacity var(--square-transition, 5s);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.technologies {
|
|
||||||
background-color: #333;
|
|
||||||
padding: 1rem;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,3 @@
|
||||||
.page-header {
|
.page-header {
|
||||||
@include responsive-container;
|
|
||||||
background-color: #333;
|
|
||||||
margin-top: 1rem;
|
|
||||||
padding: 1rem;
|
padding: 1rem;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,4 @@
|
||||||
.page-main {
|
.page-main {
|
||||||
@include responsive-container;
|
|
||||||
background-color: #333;
|
|
||||||
margin-top: 1rem;
|
|
||||||
padding: 1rem;
|
padding: 1rem;
|
||||||
|
|
||||||
.contact-links {
|
.contact-links {
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
padding: 0;
|
padding: 0;
|
||||||
|
|
||||||
.style {
|
.style {
|
||||||
background-color: #333;
|
border: 2px solid #fff;
|
||||||
padding: 1rem;
|
padding: 1rem;
|
||||||
|
|
||||||
.header {
|
.header {
|
||||||
|
@ -26,8 +26,8 @@
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: #ff0;
|
background-color: #fff;
|
||||||
border-color: #ff0;
|
border-color: #fff;
|
||||||
color: #000;
|
color: #000;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +1,18 @@
|
||||||
@import 'reset';
|
@import 'reset';
|
||||||
@import 'mixins';
|
|
||||||
|
|
||||||
html {
|
html {
|
||||||
font-size: 62.5%;
|
font-size: 62.5%;
|
||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
background-color: #111;
|
background-color: #000;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
font-family: sans-serif;
|
font-family: sans-serif;
|
||||||
font-size: 2rem;
|
font-size: 2rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
a {
|
a {
|
||||||
color: #ff0;
|
color: #fff;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue