feat: add basic site
This commit is contained in:
parent
0971cd1c10
commit
9c716bf4db
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
public/
|
||||
node_modules/
|
10
config.toml
Normal file
10
config.toml
Normal file
@ -0,0 +1,10 @@
|
||||
# The URL the site will be built for
|
||||
base_url = "https://blog.kasperhermansen.com"
|
||||
|
||||
[markdown]
|
||||
# Whether to do syntax highlighting
|
||||
# Theme can be customised by setting the `highlight_theme` variable to a theme supported by Zola
|
||||
highlight_code = true
|
||||
|
||||
[extra]
|
||||
# Put all your custom variables here
|
4
content/_index.md
Normal file
4
content/_index.md
Normal file
@ -0,0 +1,4 @@
|
||||
+++
|
||||
[extra]
|
||||
section_path = "posts/_index.md"
|
||||
+++
|
6
content/posts/_index.md
Normal file
6
content/posts/_index.md
Normal file
@ -0,0 +1,6 @@
|
||||
+++
|
||||
title = "Kasper Hermansen"
|
||||
path = "posts"
|
||||
sort_by = "date"
|
||||
paginate_by = 5
|
||||
+++
|
39
content/posts/first.md
Normal file
39
content/posts/first.md
Normal file
@ -0,0 +1,39 @@
|
||||
+++
|
||||
title = "My first post"
|
||||
date = 2019-11-27
|
||||
draft = true
|
||||
+++
|
||||
|
||||
This is my first blog post.
|
||||
|
||||
Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim
|
||||
labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi
|
||||
anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est
|
||||
aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia
|
||||
pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit
|
||||
commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa
|
||||
proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia
|
||||
eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim.
|
||||
Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa
|
||||
duis. <!-- more -->
|
||||
|
||||
Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim
|
||||
labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi
|
||||
anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est
|
||||
aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia
|
||||
pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit
|
||||
commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa
|
||||
proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia
|
||||
eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim.
|
||||
Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa
|
||||
duis.
|
||||
|
||||
```rust
|
||||
fn main() -> eyre::Result<()> {
|
||||
Ok(())
|
||||
}
|
||||
```
|
||||
|
||||
![image](https://images.unsplash.com/photo-1680188591202-22a2f6d7d6af?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1270&q=80)
|
||||
|
||||
|
39
content/posts/second.md
Normal file
39
content/posts/second.md
Normal file
@ -0,0 +1,39 @@
|
||||
+++
|
||||
title = "My second post"
|
||||
date = 2020-11-27
|
||||
draft = true
|
||||
+++
|
||||
|
||||
This is my first blog post.
|
||||
|
||||
Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim
|
||||
labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi
|
||||
anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est
|
||||
aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia
|
||||
pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit
|
||||
commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa
|
||||
proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia
|
||||
eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim.
|
||||
Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa
|
||||
duis.
|
||||
|
||||
Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim
|
||||
labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi
|
||||
anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est
|
||||
aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia
|
||||
pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit
|
||||
commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa
|
||||
proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia
|
||||
eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim.
|
||||
Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa
|
||||
duis.
|
||||
|
||||
```rust
|
||||
fn main() -> eyre::Result<()> {
|
||||
Ok(())
|
||||
}
|
||||
```
|
||||
|
||||
![image](https://images.unsplash.com/photo-1680188591202-22a2f6d7d6af?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1270&q=80)
|
||||
|
||||
|
39
content/posts/third.md
Normal file
39
content/posts/third.md
Normal file
@ -0,0 +1,39 @@
|
||||
+++
|
||||
title = "My second post"
|
||||
date = 2020-12-27
|
||||
draft = true
|
||||
+++
|
||||
|
||||
This is my first blog post.
|
||||
|
||||
Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim
|
||||
labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi
|
||||
anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est
|
||||
aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia
|
||||
pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit
|
||||
commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa
|
||||
proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia
|
||||
eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim.
|
||||
Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa
|
||||
duis.
|
||||
|
||||
Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim
|
||||
labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi
|
||||
anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est
|
||||
aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia
|
||||
pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit
|
||||
commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa
|
||||
proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia
|
||||
eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim.
|
||||
Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa
|
||||
duis.
|
||||
|
||||
```rust
|
||||
fn main() -> eyre::Result<()> {
|
||||
Ok(())
|
||||
}
|
||||
```
|
||||
|
||||
![image](https://images.unsplash.com/photo-1680188591202-22a2f6d7d6af?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1270&q=80)
|
||||
|
||||
|
22
package.json
Normal file
22
package.json
Normal file
@ -0,0 +1,22 @@
|
||||
{
|
||||
"name": "kasperhermansen-blog",
|
||||
"version": "1.0.0",
|
||||
"main": "index.js",
|
||||
"repository": "https://git.front.kjuulh.io/kjuulh/kasperhermansen-blog",
|
||||
"author": "kjuulh <contact@kjuulh.io>",
|
||||
"license": "MIT",
|
||||
"scripts": {
|
||||
"compile": "tailwindcss -i ./styles/styles.css -o ./static/styles/styles.css",
|
||||
"compile:watch": "tailwindcss -i ./styles/styles.css -o ./static/styles/styles.css --watch=always",
|
||||
"serve:watch": "zola serve --drafts",
|
||||
"dev": "yarn compile:watch & yarn serve:watch"
|
||||
},
|
||||
"dependencies": {
|
||||
"@tailwindcss/typography": "^0.5.9",
|
||||
"tailwindcss": "^3.3.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@catppuccin/tailwindcss": "^0.1.1",
|
||||
"@tailwindcss/cli": "^0.1.2"
|
||||
}
|
||||
}
|
2049
static/styles/styles.css
Normal file
2049
static/styles/styles.css
Normal file
File diff suppressed because it is too large
Load Diff
33
styles/styles.css
Normal file
33
styles/styles.css
Normal file
@ -0,0 +1,33 @@
|
||||
@tailwind base;
|
||||
@tailwind components;
|
||||
@tailwind utilities;
|
||||
|
||||
@layer base {
|
||||
html,
|
||||
body,
|
||||
body > div:first-child {
|
||||
@apply h-full bg-base text-text;
|
||||
}
|
||||
}
|
||||
|
||||
.blog-content {
|
||||
@apply prose lg:prose-lg max-w-3xl prose-headings:text-peach prose-p:text-gray-100 prose-a:text-orange-200 prose-strong:text-white;
|
||||
}
|
||||
|
||||
.blog-summary {
|
||||
@apply prose
|
||||
lg:prose-lg
|
||||
prose-headings:text-peach
|
||||
prose-p:text-gray-400
|
||||
prose-a:text-orange-300
|
||||
prose-strong:text-gray-300
|
||||
pl-6
|
||||
ml-6
|
||||
border-l-2
|
||||
border-peach
|
||||
;
|
||||
}
|
||||
|
||||
.blog-summary > p:first-child {
|
||||
@apply mt-0;
|
||||
}
|
14
tailwind.config.js
Normal file
14
tailwind.config.js
Normal file
@ -0,0 +1,14 @@
|
||||
/** @type {import('tailwindcss').Config} */
|
||||
module.exports = {
|
||||
content: ["./templates/**/*.html"],
|
||||
theme: {},
|
||||
variants: {},
|
||||
plugins: [
|
||||
require('@tailwindcss/typography'),
|
||||
require("@catppuccin/tailwindcss")({
|
||||
prefix: false,
|
||||
defaultFlavour: "frappe"
|
||||
}),
|
||||
]
|
||||
}
|
||||
|
22
templates/base.html
Normal file
22
templates/base.html
Normal file
@ -0,0 +1,22 @@
|
||||
{% import "macros/macros.html" as post_macros %}
|
||||
{% import "macros/prev.html" as prev_macros %}
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>kasperhermansen</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||||
|
||||
<link rel="stylesheet" href="{{ get_url(path="styles/styles.css") | safe }}" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<section class="section container mx-auto">
|
||||
{% block content %} {% endblock %}
|
||||
</section>
|
||||
</body>
|
||||
|
||||
</html>
|
1
templates/index.html
Normal file
1
templates/index.html
Normal file
@ -0,0 +1 @@
|
||||
{% extends "section.html" %}
|
36
templates/macros/macros.html
Normal file
36
templates/macros/macros.html
Normal file
@ -0,0 +1,36 @@
|
||||
{% macro list_posts(pages) %}
|
||||
<ul>
|
||||
{%- for page in pages %}
|
||||
<section class="list-item">
|
||||
<h1 class="title text-peach">
|
||||
<a href={{ page.permalink }}>{{page.title}}</a>
|
||||
</h1>
|
||||
|
||||
<div class="meta">
|
||||
{%- if page.date %}
|
||||
<time>{{ page.date | date(format="%Y-%m-%d") }}</time>
|
||||
{% endif -%}
|
||||
{% if page.draft %}
|
||||
<span class="draft-label">DRAFT</span>
|
||||
{% endif %}
|
||||
</div>
|
||||
|
||||
<br />
|
||||
<div class="blog-summary ">
|
||||
{% if page.description %}
|
||||
{{ page.description }}
|
||||
{% elif page.summary %}
|
||||
{{ page.summary | safe }}…
|
||||
{% else %}
|
||||
{% set hide_read_more = true %}
|
||||
{% endif %}
|
||||
</div>
|
||||
|
||||
{% if not hide_read_more %}
|
||||
<a class="readmore text-peach" href={{ page.permalink }}>Read more ⟶</a>
|
||||
{% endif %}
|
||||
</section>
|
||||
|
||||
{% endfor -%}
|
||||
</ul>
|
||||
{% endmacro list_posts %}
|
10
templates/macros/prev.html
Normal file
10
templates/macros/prev.html
Normal file
@ -0,0 +1,10 @@
|
||||
|
||||
{% macro page_back_link(page) %}
|
||||
{% set top_section = get_section(path=page.ancestors | last) %}
|
||||
<a class="previous" href="{{ top_section.permalink }}">‹ back</a>
|
||||
{% endmacro page_back_link %}
|
||||
|
||||
{% macro section_back_link(section) %}
|
||||
{% set top_section = get_section(path=section.ancestors | last) %}
|
||||
<a class="previous" href="{{ top_section.permalink }}">‹ back</a>
|
||||
{% endmacro section_back_link %}
|
29
templates/page.html
Normal file
29
templates/page.html
Normal file
@ -0,0 +1,29 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
{% block content %}
|
||||
|
||||
{{ prev_macros::page_back_link(page=page) }}
|
||||
|
||||
<div class="mx-auto px-4 max-w-3xl py-8">
|
||||
<article class="blog-content">
|
||||
<h1 class="title">
|
||||
{{ page.title }}
|
||||
</h1>
|
||||
<p class="subtitle"><strong>{{ page.date }}</strong></p>
|
||||
{{ page.content | safe }}
|
||||
</article>
|
||||
|
||||
{% if page.lower or page.higher %}
|
||||
<div class="flex place-content-around max-w-lg mx-auto">
|
||||
{% if page.lower %}
|
||||
<a class="previous" href="{{ page.lower.permalink }}">‹ {{ page.lower.title }}</a>
|
||||
{% endif %}
|
||||
{% if page.higher %}
|
||||
<a class="next" href="{{ page.higher.permalink }}">{{ page.higher.title }} ›</a>
|
||||
{% endif %}
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
|
||||
{% endblock content %}
|
||||
|
45
templates/section.html
Normal file
45
templates/section.html
Normal file
@ -0,0 +1,45 @@
|
||||
{% extends "base.html" %}
|
||||
|
||||
|
||||
{% block content %}
|
||||
|
||||
<div class="container mx-auto px-4 max-w-3xl py-8 space-y-4">
|
||||
|
||||
{% if section.ancestors | length > 0 %}
|
||||
{{ prev_macros::section_back_link(section=section) }}
|
||||
{% endif %}
|
||||
|
||||
{% if section.extra.section_path -%}
|
||||
{% set section = get_section(path=section.extra.section_path) %}
|
||||
{% endif -%}
|
||||
<h1 class="title text-peach text-3xl">
|
||||
{{ section.title }}
|
||||
</h1>
|
||||
|
||||
<main>
|
||||
{%- if paginator %}
|
||||
{%- set show_pages = paginator.pages -%}
|
||||
{% else %}
|
||||
{%- set show_pages = section.pages -%}
|
||||
{% endif -%}
|
||||
|
||||
{{ post_macros::list_posts(pages=show_pages) }}
|
||||
</main>
|
||||
{% if paginator %}
|
||||
<ul class="pagination">
|
||||
{% if paginator.previous %}
|
||||
<span class="page-item page-prev">
|
||||
<a href={{ paginator.previous }} class="page-link" aria-label="Previous"><span aria-hidden="true">← Prev</span></a>
|
||||
</span>
|
||||
{% endif %}
|
||||
|
||||
{% if paginator.next %}
|
||||
<span class="page-item page-next">
|
||||
<a href={{ paginator.next }} class="page-link" aria-label="Next"><span aria-hidden="true">Next →</span></a>
|
||||
</span>
|
||||
{% endif %}
|
||||
</ul>
|
||||
{% endif %}
|
||||
|
||||
</div>
|
||||
{% endblock content %}
|
Loading…
Reference in New Issue
Block a user