Refactored project to use Builder pattern.

This commit is contained in:
2025-10-26 22:01:13 +01:00
parent a908bf0e8a
commit 146509efdf
7 changed files with 669 additions and 284 deletions

View File

@@ -1,64 +1,70 @@
use super::BasePage;
use crate::html::Render;
use crate::html::elements::{a, div, h1, h2, link, p};
use crate::html::elements::{Anchor, Heading, Link, Paragraph};
use crate::html::layouts::Division;
use crate::html::pages::BasePage;
use crate::html::{Render, boxed_vec};
use actix_web::{Responder, get, web};
#[get("/projects")]
async fn projects() -> impl Responder {
let mut page = BasePage::new("Projects");
let title = h1::new("My projects");
let desc = h2::new(
"Here you will find all my projects which deserve to be shown<br>\
let title = Heading::builder().text("My projects").build();
let desc = Heading::builder()
.level(2)
.text(
"Here you will find all my projects which deserve to be shown<br>\
(I've done a lot of small projects but they are not worth it.)",
);
let mut website = div::new("project-website", vec!["project"]);
let website_title = h1::new("Website");
let mut info = div::new("project-website-info", vec!["project-info"]);
let website_desc = p::new(
"website-desc",
vec!["project-desc"],
"This project is the website you currently are on.",
);
let view = a::new(
"website-view",
vec!["project-view"],
"/projects/website",
"Learn More",
);
info.append_element(website_desc);
info.append_element(view);
website.append_element(website_title);
website.append_element(info);
let css = link::new("stylesheet", "/static/css/projects.css");
page.append_element_to_head(css);
page.append_element_to_body(title);
page.append_element_to_body(desc);
page.append_element_to_body(website);
)
.build();
let website_title = Heading::builder().text("Website").build();
let website_desc = Paragraph::builder()
.classes(vec!["project-desc"])
.text("This project is the website you currently are on.")
.build();
let view = Anchor::builder().classes(vec!["project-view"]).href("/projects/website").text("Learn More").build();
let info = Division::builder()
.classes(vec!["project-info"])
.elements(boxed_vec![website_desc, view])
.build();
let website = Division::builder()
.classes(vec!["project"])
.elements(boxed_vec![website_title, info])
.build();
let css = Link::builder()
.rel("stylesheet")
.href("/static/css/projects.css")
.build();
let page = BasePage::builder()
.title("Projects")
.head(boxed_vec![css])
.body(boxed_vec![title, desc, website])
.build();
page.render()
}
#[get("/projects/{project}")]
async fn project(project: web::Path<String>) -> impl Responder {
let project = project.into_inner();
let mut page = BasePage::new(format!("Project-{}", project));
let css = Link::builder()
.rel("stylesheet")
.href("/static/css/project.css")
.build();
let mut page = BasePage::builder()
.title(format!("Project-{}", project))
.head(boxed_vec![css])
.build();
match project.as_str() {
"website" => {
let title = h1::new("Website");
let desc = p::new(
"description",
vec!["description"],
let title = Heading::builder().text("Website").build();
let desc = Paragraph::builder().classes(vec!["description"]).text(
"This project, the website you are on, \
is made in Rust such that all the pages are generated by code.<br>\
That is that each html element is represented by a struct which implements the Render trait (as in render the element to html).<br>\
As it is right now the system is not that impressive but I believe it can do amazing things in the futur.<br>\
<br>\
Wish to see more? Check out the gitea repository: ",
);
).build();
page.append_element_to_body(title);
page.append_element_to_body(desc);
}
_ => {}
}
let css = link::new("stylesheet", "/static/css/project.css");
page.append_element_to_head(css);
page.render()
}