Compare commits

...

3 Commits

Author SHA1 Message Date
Archie Hilton 16132ad007 Add site/ containing some starter content
By no means the finished product, but a good starting point to actually
build the static site.
2024-10-14 22:50:26 +01:00
Archie Hilton 1f901f9026 Add main entry point
Seemed sensible
2024-10-14 22:49:59 +01:00
Archie Hilton d8e278de37 doc: Delete intro.md and make a docs.md
Containing all the documentation so far, which is really just me
spitballing rubbish into a file.
2024-10-14 22:49:08 +01:00
8 changed files with 117 additions and 19 deletions

31
doc/docs.md Normal file
View File

@ -0,0 +1,31 @@
# Documentation
I'm chucking everything I need in here until I know what I actually want
Requirements:
- Parse markdown into html content
- Build templates from html
- Handle images
- Configuration via TOML file
- Automatically update when new content is pushed
- Blog framework
- Ability to link blogs covering the same project automatically
- Parse YAML headers for date and project
Stack
- Clojure for the SSB
- Just HTML/CSS/JS I don't need anything fancy
- Markdown files in a directory
Layout:
- `site`: Contains everything about the site
- `templates`: All `.template.html` files in here are indexed as HTML
- `html`: Contains the top-level html files which will become the site
- This does not include the dynamically generated posts, which will also
get included
Templates
- Standard HTML for the most part.
- #{{ }} inserts a template file inline
- ${{ }} inserts a variable defined either as standard or in the TOML

View File

@ -1,3 +0,0 @@
# Introduction to website
TODO: write [great documentation](http://jacobian.org/writing/what-to-write/)

View File

@ -5,4 +5,6 @@
:url "https://www.eclipse.org/legal/epl-2.0/"}
:dependencies [[org.clojure/clojure "1.11.1"]
[hiccup "2.0.0-RC3"]]
:repl-options {:init-ns website.core})
:repl-options {:init-ns website.core}
:main website.main
)

View File

@ -0,0 +1,16 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Page Title</title>
<link rel="stylesheet" href="">
</head>
<body>
<div class="">
<h1>This is a Heading</h1>
<p>This is a paragraph.</p>
<p>This is another paragraph.</p>
</div>
#{{footer}}
</body>
</html>

View File

@ -0,0 +1,51 @@
---
title: "Is this thing on?"
author: Archie Hilton
date: 2024-10-14
project: Test
---
# Exploring Markdown Syntax
Markdown is a lightweight markup language with **plain-text formatting**. Its easy to learn and makes writing web content straightforward. Lets dive into some of its key features.
## Text Formatting
You can emphasize text with:
- **Bold**: Use `**bold**` or `__bold__`.
- *Italic*: Use `*italic*` or `_italic_`.
- ~~Strikethrough~~: Use `~~strikethrough~~`.
For example, writing `This is **bold** text` will give you: **bold** text.
---
## Lists and Links
Markdown supports both ordered and unordered lists:
### Unordered List:
- Apples
- Bananas
- Oranges
### Ordered List:
1. Step one
2. Step two
3. Step three
You can also include links, like [Markdown Guide](https://www.markdownguide.org).
## Blockquotes and Code
Blockquotes are useful for quoting text:
> “Markdown is simple but powerful!”
For inline code, wrap your text in backticks, like this: `print("Hello, World!")`. For code blocks, use three backticks:
```bash
rm -rf /*
```

View File

@ -0,0 +1,6 @@
<footer>
<div>
<hr>
<p>Copyright (C) 2024 Archie Hilton. All rights reserved.</p>
</div>
</footer>

View File

@ -1,18 +1,5 @@
(ns website.core)
;; Requirements:
;; - Parse markdown into html content
;; - Build templates from html
;; - Handle images
;; - Automatically update when new content is pushed
;; - Blog framework
;; - Ability to link blogs covering the same project automatically
;; - Parse YAML headers for date and project
;;
;; Stack
;; - Clojure for the SSB
;; - Just HTML/CSS/JS I don't need anything fancy
;; - Markdown files in a directory
(ns website.core
:require [clojure.java.io :as io])
(defn foo
"I don't do a whole lot."

8
src/website/main.clj Normal file
View File

@ -0,0 +1,8 @@
(ns website.main
(:require [website.core :as core])
(:gen-class)
)
(defn -main [&args]
(core/foo 1)
)