macroblog.rs @ b4472b41214eeeacce071df41bf0f782e1f16d6d

feat: Move from pico to custom css

Use css from my current blog, which is a lot smaller. The text itself
looks good but the code still breaks the page.

Metrics:

- hyper: 16.37 KB / 16.47 KB transferred
- 1 request
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
deleted file mode 100644
index dd3bba47c37ec95c989d8367cae13b63402c66d7..0000000000000000000000000000000000000000
--- a/.gitlab-ci.yml
+++ /dev/null
@@ -1,62 +0,0 @@
-stages:
-    - test
-    - production
-    - prepare
-    - release
-
-test:
-    image: rust:alpine
-    stage: test
-    script:
-        - apk add musl-dev
-        - cargo install cargo2junit
-        - cargo test -- -Z unstable-options --format json --report-time | cargo2junit > results.xml
-    only:
-        - master
-    artifacts:
-        reports:
-            junit: results.xml
-
-production:
-    stage: production
-    image: ruby:latest
-    needs:
-      - test
-    script:
-        - apt-get update -qy
-        - apt-get install -y ruby-dev
-        - gem install dpl
-        - gem install faraday -v 1.8.0
-        - dpl --provider=heroku --app=$HEROKU_APP --api-key=$HEROKU_API_KEY
-    only:
-        - master
-
-prepare_job:
-  stage: prepare
-  image: rust:alpine
-  rules:
-    - if: $CI_COMMIT_TAG
-  script:
-    - echo "running release_job"
-    - apk add musl-dev
-    - cargo build --release
-  artifacts:
-    paths:
-      - target/release/hyper
-      - target/release/actix
-
-release_job:
-  stage: release
-  image: registry.gitlab.com/gitlab-org/release-cli:latest
-  rules:
-    - if: $CI_COMMIT_TAG
-  script:
-    - echo "running release_job for $TAG"
-  needs:
-    - job: prepare_job
-      artifacts: true
-  release:
-    name: 'Release $CI_COMMIT_TAG'
-    description: 'New macroblog version'
-    tag_name: '$CI_COMMIT_TAG'
-    ref: '$CI_COMMIT_TAG'
diff --git a/Procfile b/Procfile
deleted file mode 100644
index 51c4728eb99f1e7da51cd1de9cc2b6ef2d19578e..0000000000000000000000000000000000000000
--- a/Procfile
+++ /dev/null
@@ -1 +0,0 @@
-web: ./target/release/actix
diff --git a/content/posts/2020-07-12Road_to_local_K8S.html b/content/posts/2020-07-12Road_to_local_K8S.html
index 5d34b27775f6d3c0c5d80da76ab4d5372aba440d..52820b3a59f6fcff401ca6c19b6990cf0a36c485 100644
--- a/content/posts/2020-07-12Road_to_local_K8S.html
+++ b/content/posts/2020-07-12Road_to_local_K8S.html
@@ -1,43 +1,43 @@
 <section>
-  <h3>Goal</h3>
-  <p>
+    <h3>Goal</h3>
+    <p>
     The goal is to deploy kubernetes on my local networks, and keep everything
     as reproducible as possible.
-  </p>
-  <h3>Stack</h3>
-  <p>
+    </p>
+    <h3>Stack</h3>
+    <p>
     I'll use Fedora Core OS, Matchbox and Terraform
     <sup><a href="#footnotes">1</a></sup>, a match the requirements for
     Tectonic<sup><a href="#footnotes">2</a></sup>.</p>
-  <h3>Steps</h3>
-  <ul>
-    <li>Network Setup DHCP/TFTP/DNS<sup><a href="#footnotes">3</a></sup></li>
-    <li>Matchbox<sup><a href="#footnotes">4</a></sup></li>
-    <li>PXE nextwork boot evnrionment</li>
-    <li>Terraform Tectonic<sup><a href="#footnotes">5</a></sup></li>
-  </ul>
-  <h3>Network Setup DHCP/TFTP/DNS</h3>
-  <p>First learning the basics</p>
-  <ul>
-    <li>
-      <a href="https://linuxhint.com/install_dhcp_server_ubuntu/">
-        https://linuxhint.com/install_dhcp_server_ubuntu/
-      </a>
-    </li>
-    <li>
-      <a href="https://www.youtube.com/watch?v=XQ3T14SIlV4">
-        https://www.youtube.com/watch?v=XQ3T14SIlV4
-      </a>
-    </li>
-  </ul>
-  <p>
+    <h3>Steps</h3>
+    <ul>
+        <li>Network Setup DHCP/TFTP/DNS<sup><a href="#footnotes">3</a></sup></li>
+        <li>Matchbox<sup><a href="#footnotes">4</a></sup></li>
+        <li>PXE nextwork boot evnrionment</li>
+        <li>Terraform Tectonic<sup><a href="#footnotes">5</a></sup></li>
+    </ul>
+    <h3>Network Setup DHCP/TFTP/DNS</h3>
+    <p>First learning the basics</p>
+    <ul>
+        <li>
+            <a href="https://linuxhint.com/install_dhcp_server_ubuntu/">
+                https://linuxhint.com/install_dhcp_server_ubuntu/
+            </a>
+        </li>
+        <li>
+            <a href="https://www.youtube.com/watch?v=XQ3T14SIlV4">
+                https://www.youtube.com/watch?v=XQ3T14SIlV4
+            </a>
+        </li>
+    </ul>
+    <p>
     To check open ports
-<pre><code>lsof -Pni | grep LISTEN</code></pre>
-  </p>
-  <p>
+    <pre><code>lsof -Pni | grep LISTEN</code></pre>
+    </p>
+    <p>
     Run the provided<sup><a href="#footnotes">6</a></sup> image with dnsmasq and
     PXE toolkit
-<pre><code>docker run --rm --cap-add=NET_ADMIN --net=host quay.io/coreos/dnsmasq \
+    <pre><code>docker run --rm --cap-add=NET_ADMIN --net=host quay.io/coreos/dnsmasq \
   -d -q \
   --dhcp-range=192.168.1.3,192.168.1.254 \
   --enable-tftp --tftp-root=/var/lib/tftpboot \
@@ -54,48 +54,48 @@   --dhcp-boot=tag:ipxe,http://matchbox.example.com:8080/boot.ipxe \
   --address=/matchbox.example/192.168.1.2 \
   --log-queries \
   --log-dhcp</code></pre>
-  </p>
-  <h3>Matchbox</h3>
-  <p>...</p>
-  <h3>PXE network boot enviroment</h3>
-  <p>...</p>
-  <h3>Terraform Tectonic</h3>
-  <p>...</p>
-  <h3 id="footnotes">Links</h3>
-  <div >
-    <sup>1</sup>
-    <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html">
-      https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html
-    </a>
-  <div>
-  <div>
-    <sup>2</sup>
-    <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html">
-      https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html
-    </a>
-  <div>
-  <div>
-    <sup>3</sup>
-    <a href="https://coreos.com/matchbox/docs/latest/network-setup.html">
-      https://coreos.com/matchbox/docs/latest/network-setup.html
-    </a>
-  <div>
-  <div>
-    <sup>4</sup>
-    <a href="https://coreos.com/matchbox/docs/latest/deployment.html">
-      https://coreos.com/matchbox/docs/latest/deployment.html
-    </a>
-  <div>
-  <div>
-    <sup>5</sup>
-    <a href="https://coreos.com/tectonic/releases/">
-      https://coreos.com/tectonic/releases/
-    </a>
-  <div>
-  <div>
-    <sup>6</sup>
-    <a href="https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq">
-      https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq
-    </a>
-  <div>
+    </p>
+    <h3>Matchbox</h3>
+    <p>...</p>
+    <h3>PXE network boot enviroment</h3>
+    <p>...</p>
+    <h3>Terraform Tectonic</h3>
+    <p>...</p>
+    <h3 id="footnotes">Links</h3>
+    <div >
+        <sup>1</sup>
+        <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html">
+            https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html
+        </a>
+        <div>
+            <div>
+                <sup>2</sup>
+                <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html">
+                    https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html
+                </a>
+                <div>
+                    <div>
+                        <sup>3</sup>
+                        <a href="https://coreos.com/matchbox/docs/latest/network-setup.html">
+                            https://coreos.com/matchbox/docs/latest/network-setup.html
+                        </a>
+                        <div>
+                            <div>
+                                <sup>4</sup>
+                                <a href="https://coreos.com/matchbox/docs/latest/deployment.html">
+                                    https://coreos.com/matchbox/docs/latest/deployment.html
+                                </a>
+                                <div>
+                                    <div>
+                                        <sup>5</sup>
+                                        <a href="https://coreos.com/tectonic/releases/">
+                                            https://coreos.com/tectonic/releases/
+                                        </a>
+                                        <div>
+                                            <div>
+                                                <sup>6</sup>
+                                                <a href="https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq">
+                                                    https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq
+                                                </a>
+                                                <div>
 </section>
diff --git a/src/blog.rs b/src/blog.rs
index 6bbda4996f521103a23a5b6667ed3db8c9388ae1..0fa9543d0587f6369870ffe56a30084a0beec241 100644
--- a/src/blog.rs
+++ b/src/blog.rs
@@ -1,16 +1,15 @@
+use chrono::NaiveDate;
+use regex::Regex;
 use rust_embed::RustEmbed;
 use sailfish::TemplateOnce;
-use chrono::NaiveDate;
-use regex::{Regex};
+use std::cmp::{Eq, Ord, PartialEq, PartialOrd};
 use std::str;
-use std::cmp::{PartialOrd, Ord, PartialEq, Eq};
 
 const BLOG_REGEX: &str = r"(?P<date>[\d]{4}-[\d]{2}-[\d]{2})(?P<title>[a-zA-Z0-9-_]*)";
 
 #[derive(RustEmbed)]
 #[folder = "content/posts/"]
 struct PostAsset;
-
 
 #[derive(TemplateOnce)]
 #[template(path = "index.html")]
@@ -23,7 +22,7 @@ #[template(path = "post.html")]
 struct PostTemplate {
     content: String,
     title: String,
-    date: String
+    date: String,
 }
 
 #[derive(PartialEq, Eq, PartialOrd, Ord)]
@@ -43,12 +42,11 @@
         BlogEntry {
             title: String::from(title),
             file: String::from(path),
-            datetime: NaiveDate::parse_from_str(date, "%Y-%m-%d").unwrap()
+            datetime: NaiveDate::parse_from_str(date, "%Y-%m-%d").unwrap(),
         }
     }
 
     pub fn read_assets() -> Vec<BlogEntry> {
-
         let mut entries: Vec<BlogEntry> = PostAsset::iter()
             .map(|e| format!("{}", e))
             .map(|e| BlogEntry::new(&e))
@@ -61,14 +59,10 @@     }
 }
 
 fn get_file_content(path: &str) -> String {
-    let buffer = PostAsset::get(path)
-        .unwrap()
-        .data
-        .into_owned();
+    let buffer = PostAsset::get(path).unwrap().data.into_owned();
 
     return String::from_utf8(buffer).unwrap();
 }
-
 
 pub fn render_post_page(path: &String) -> String {
     let blog = BlogEntry::new(path);
@@ -76,14 +70,16 @@
     PostTemplate {
         content: get_file_content(path),
         title: blog.title,
-        date: blog.datetime.format("%Y-%m-%d").to_string()
+        date: blog.datetime.format("%Y-%m-%d").to_string(),
     }
-        .render_once()
-        .unwrap()
+    .render_once()
+    .unwrap()
 }
 
 pub fn render_index_page() -> String {
-    IndexTemplate { posts: BlogEntry::read_assets() }
-        .render_once()
-        .unwrap()
+    IndexTemplate {
+        posts: BlogEntry::read_assets(),
+    }
+    .render_once()
+    .unwrap()
 }
diff --git a/src/router.rs b/src/router.rs
index 0bba091cb8533672e794fd3b48c9dac9cdd2e6a0..35fdf3e8bed96a76bda385f0242e4757bfa06553 100644
--- a/src/router.rs
+++ b/src/router.rs
@@ -1,4 +1,4 @@
-use regex::{Regex};
+use regex::Regex;
 
 const ACTION_REGEX: &str = r"/{0,1}(?P<action>\w*)/(?P<id>.+)";
 
@@ -14,14 +14,15 @@         let re = Regex::new(ACTION_REGEX).unwrap();
         let caps = re.captures(path);
         let action = match caps {
             Some(ref value) => &value["action"],
-            None => "index"
+            None => "index",
         };
 
         match action {
-            "posts" => Router::Post { page: caps.unwrap()["id"].to_string() },
+            "posts" => Router::Post {
+                page: caps.unwrap()["id"].to_string(),
+            },
             "index" => Router::Index,
-            _ => Router::NotFound
+            _ => Router::NotFound,
         }
     }
 }
-
diff --git a/templates/head.html b/templates/head.html
index c054157d1cca5c47cf8b8fc57f0cb15d5c9753d7..3492eda3a3d46094ceefe503b72da649081712b5 100644
--- a/templates/head.html
+++ b/templates/head.html
@@ -3,5 +3,5 @@ <meta name="viewport" content="width=device-width, initial-scale=1">
 <title>Yet Another Blog</title>
 <link rel="icon" type="image/x-icon" href="">
 <style>
-    <% include!("pico.min.css"); %>
+<% include!("main.css"); %>
 </style>
diff --git a/templates/header.html b/templates/header.html
index 1340aa1711011046f6730f8e278513acd64228b5..c830273fec5e96c3e65e4832315f6ab9d164aec4 100644
--- a/templates/header.html
+++ b/templates/header.html
@@ -1,10 +1,12 @@
 <header class="container">
-    <nav class="container-fluid">
-        <ul>
-            <li><h2><a href="/">Yet Another Blog</a></h2></li>
-        </ul>
-        <ul>
-            <li><a href="https://gitlab.com/gabrielgio/cv/-/raw/main/cv.pdf?inline=false" class="secondary">Resume</a></li>
-        </ul>
-    </nav>
+    <div class="title-wrapper">
+        <a href="/">
+            <h2 class="title">Yet Another Blog</h2>
+        </a>
+        <nav class="container-fluid">
+            <ul>
+                <li><a href="https://gitlab.com/gabrielgio/cv/-/raw/main/cv.pdf?inline=false" class="secondary">Resume</a></li>
+            </ul>
+        </nav>
+    </div>
 </header>
diff --git a/templates/index.html b/templates/index.html
index 006643a237521f0b87c035d7114c6e2e3faf5aaa..f6f3ca982b6751d9de2f0c3d94df228b02b95591 100644
--- a/templates/index.html
+++ b/templates/index.html
@@ -1,22 +1,28 @@
 <!DOCTYPE html>
 <html data-theme="light" lang="en">
-<head>
-    <% include!("head.html"); %>
-</head>
-<body>
-<% include!("header.html"); %>
-<main class="container">
-    <section>
-            A gathering of information about some things I do on my spare time.
-            You can find me on gitlab, twitter and linkedin.
-    </section>
-    <section>
-        <ul>
-        <% for p in &posts { %>
-            <li><a href="/posts/<%- p.file %>"><%- p.title %></a></li>
-        <% } %>
-        </ul>
-    </section>
-</main>
-</body>
+    <head>
+        <% include!("head.html"); %>
+    </head>
+    <body>
+        <div class="layout">
+            <% include!("header.html"); %>
+            <main>
+                <div class="slim-description">
+                    A gathering of information about some things I do on my
+                    spare time. You can find me on gitlab, twitter and
+                    linkedin.
+                </div>
+                <div class="blog-list">
+                    <% for p in &posts { %>
+                    <article class="list-item">
+                        <div class="post-title">
+                            <a href="/posts/<%- p.file %>"><%- p.title %></a>
+                        </div>
+                        <span classname="data-label"><%- p.datetime | disp %></span>
+                    </article>
+                    <% } %>
+                </div>
+            </main>
+        </div>
+    </body>
 </html>
diff --git a/templates/main.css b/templates/main.css
new file mode 100644
index 0000000000000000000000000000000000000000..f056a50c86db44dcce5364e35447b7733d795510
--- /dev/null
+++ b/templates/main.css
@@ -0,0 +1,263 @@
+* {
+    box-sizing: border-box;
+    font-family: dejavu sans;
+}
+body {
+    margin: 0;
+}
+h1,
+h2,
+h3,
+h4 {
+    font-weight: 400;
+}
+code[class*="language-"],
+nav,
+.blog-list {
+    font-style: normal;
+    font-weight: 400;
+    font-size: 1.025rem;
+}
+code {
+    font-family: dejavu sans mono;
+}
+tags {
+    font-family: dejavu sans mono;
+}
+.list-item {
+    font-family: dejavu sans mono;
+}
+html {
+    font-size: 16px;
+}
+body {
+    line-height: 1.8em;
+    color: #333;
+    background: #fefefe;
+}
+.post-title,
+.date-label {
+    letter-spacing: 0.025rem;
+}
+p,
+sub,
+nav {
+    letter-spacing: 0.05rem;
+}
+.title-wrapper,
+.title {
+    letter-spacing: 0.075rem;
+}
+a {
+    text-decoration: none;
+}
+.brand-icon {
+    color: #f93a3a;
+    display: inline-flex;
+    border-bottom: 1px solid;
+}
+.brand-icon:hover {
+    border-bottom: none;
+}
+.layout {
+    max-width: 48rem;
+    margin-left: auto;
+    margin-right: auto;
+    padding: 2.625rem 1.3125rem;
+}
+.layout .title-wrapper {
+    display: flex;
+    flex-direction: column;
+    align-items: center;
+    margin-bottom: 0.5rem;
+}
+.layout .title {
+    color: #333;
+    text-align: left;
+    display: block;
+    font-size: 1.875rem;
+    margin: 0;
+}
+nav {
+    font-size: 1.025rem;
+    text-align: center;
+}
+nav ul {
+    display: block;
+    padding: 0;
+}
+nav ul li {
+    display: inline;
+    list-style-type: none;
+}
+nav ul li a {
+    color: #333;
+    display: inline-block;
+    padding-top: 0.5rem;
+    padding-bottom: 0.5rem;
+    border-bottom: 1px solid #fefefe;
+}
+nav ul li a:hover {
+    color: #f93a3a;
+}
+nav ul li:not(:last-child) {
+    padding: 0 1rem 0 0;
+}
+.slim-description {
+    margin-bottom: calc(16px * 2);
+    color: #666;
+}
+.blog-post-content a {
+    color: #f93a3a;
+    text-decoration: none;
+    border-bottom: 1px solid;
+}
+.blog-post-content a:hover {
+    border-bottom: none;
+}
+.blog-list .list-item {
+    display: flex;
+    flex-direction: column-reverse;
+    align-items: baseline;
+    padding: 0.5rem 0.5rem 0.5rem 0;
+}
+.blog-list .post-title a {
+    text-decoration: none;
+    color: #333;
+    border-bottom: none;
+}
+.blog-list .post-title a:hover {
+    border-bottom: 1px solid;
+}
+.blog-list .date-label {
+    font-size: 80%;
+    margin-right: 1rem;
+}
+.content .title {
+    font-size: 1.275rem;
+}
+.blog-post-content a {
+    color: #f93a3a;
+    text-decoration: none;
+    border-bottom: 1px solid;
+}
+.blog-post-content a:hover {
+    border-bottom: none;
+}
+.blog-post-content img {
+    width: 100%;
+}
+.post-image {
+    margin-left: calc(-1.3125rem);
+    margin-right: calc(-1.3125rem);
+}
+.post-image img {
+    width: 100%;
+}
+.tags {
+    font-size: 0.9em;
+    text-align: left;
+}
+.tags ul {
+    display: block;
+    padding: 0;
+}
+.tags ul li {
+    display: inline;
+    list-style-type: none;
+    text-align: center;
+}
+.tags ul li a {
+    border: 1px solid #f93a3a;
+    border-radius: 3px;
+    background: #f93a3a;
+    padding: 0.2em;
+    color: #fff;
+    margin: 10px 2px 10px 0;
+    line-height: 1em;
+}
+.tags ul li a:hover {
+    background: #fefefe;
+    color: #f93a3a;
+}
+.tags ul li:not(:last-child) {
+    padding: 0 0.1rem 0 0;
+}
+.highlight {
+    margin-left: calc(-1.3125rem);
+    margin-right: calc(-1.3125rem);
+}
+.highlight pre {
+    line-height: 1.2rem;
+    border: 1px solid #ddd;
+    border-radius: 5px;
+    overflow: auto;
+    padding: 1.3125rem;
+    margin: 0;
+}
+.highlight pre code[class*="language-"] {
+    font-size: 0.9em;
+}
+.highlight pre .token.comment {
+    font-style: italic;
+}
+blockquote {
+    background: #f9f9f9;
+    border-left: 5px solid #333;
+    margin: 1.5em 10px;
+    padding: 0.5em 10px;
+    quotes: "“" "”" "‘" "’";
+}
+blockquote:before {
+    color: #333;
+    content: open-quote;
+    font-size: 4em;
+    line-height: 0.1em;
+    margin-right: 0.25em;
+    vertical-align: -0.4em;
+}
+blockquote p {
+    display: inline;
+}
+time {
+    font-size: 80%;
+    margin-right: 1rem;
+}
+@media only screen and (min-width: 600px) {
+    .layout .title-wrapper {
+        display: flex;
+        justify-content: space-between;
+        align-items: center;
+        flex-direction: row;
+    }
+    .layout .title {
+        margin-block-start: 0.83em;
+        margin-block-end: 0.83em;
+        margin-inline-start: 0;
+        margin-inline-end: 0;
+    }
+    .blog-list .list-item {
+        display: flex;
+        justify-content: space-between;
+        align-items: center;
+        flex-direction: unset;
+        padding: 0;
+        margin-bottom: 0.5rem;
+    }
+    .blog-list .date-label {
+        font-size: 100%;
+        margin-right: 0;
+    }
+    .project-board {
+        grid-template-columns: 1fr 1fr;
+    }
+    .highlight {
+        margin-left: 0;
+        margin-right: 0;
+    }
+    .post-image {
+        margin-left: 0;
+        margin-right: 0;
+    }
+}
+
diff --git a/templates/post.html b/templates/post.html
index 7e0a909a4d894a4bb21020e25283e8a3fff97dcc..99a7852ec2df5ca8c82cd5af3fde2abf6bc2a5b1 100644
--- a/templates/post.html
+++ b/templates/post.html
@@ -1,18 +1,20 @@
 <!DOCTYPE html>
 <html data-theme="light" lang="en">
-<head>
-    <% include!("head.html"); %>
-</head>
-<body>
-<% include!("header.html"); %>
-<main class="container">
-    <h2><%- title %></h2>
-    <h5>Created At: <%- date %></h2>
-    <%- content %>
-    </section>
-</main>
-</body>
-
-<script>
-</script>
+    <head>
+        <% include!("head.html"); %>
+    </head>
+    <body>
+        <div class="layout">
+            <% include!("header.html"); %>
+            <main>
+                <article>
+                    <h1><%- title %></h1>
+                    <time>Created At: <%- date %></time>
+                    <div class="blog-post-content">
+                        <%- content %>
+                    </div>
+                </article>
+            </main>
+        </div>
+    </body>
 </html>