static website generator
from Im_old@lemmy.world to selfhosted@lemmy.world on 28 Sep 2024 09:45
https://lemmy.world/post/20271833

Hello everyone! I was thinking about starting a website where to dump some guides on stuff Iearn about selfhosting and general IT stuff.

I don’t want a WordPress or similar. I want static pages (but I’m ok with some JavaScript for navigation maybe, or for proper display on different kind of devices). Ideally I’d like to host it on an AWS S3 bucket since it has the built-in option for static hosting.

I could even go back to the '90s and do it myself from scratch in textedit and html by hand, but I’m pretty sure there are better options out there.

I took a look at Hugo but even that it seems overly complicated for what I need.

Any ideas or suggestions?

Thanks!

#selfhosted

threaded - newest

yggdar@lemmy.world on 28 Sep 2024 09:52 next collapse

DocFx could do what you’re looking for. You would write your stuff in markdown and it generates an interactive and customizable site.

hperrin@lemmy.world on 28 Sep 2024 09:56 next collapse

What I use for a lot of my sites is SvelteKit. It has a static site generator. If you like writing the HTML by hand, it’s great. Also HTML5 Up is where I get my templates. I made the nymph.io website this way. And sveltematerialui.com.

l_b_i@yiffit.net on 28 Sep 2024 10:07 next collapse

how about jekyll? Lots of customization available.

KaninchenSpeed@sh.itjust.works on 28 Sep 2024 10:07 next collapse

I’m currently using Astro for that. You can write the pages in markdown, html or one of the many js frameworks. It also allows you to mix them.

By default it generates static websites with out any js, but it allows you to add js where needed. Optional server side features are wip, if you decide to need them later on.

They also have pre made themes on their website if you don’t feel like writing css.

thisfro@slrpnk.net on 28 Sep 2024 10:09 next collapse

You could write your content in markdown and use pandoc to generate a html file. Add header/footer in template if you want

wizardbeard@lemmy.dbzer0.com on 28 Sep 2024 12:46 collapse

This is probably the simplest option. I’ve seen a good number of simple yet functional and pretty sites built in markdown and converted to html via some simple tool like pamdoc.

pixxelkick@lemmy.world on 28 Sep 2024 10:17 next collapse

I use Hugo, it’s not super complicated.

You basically just define templates in pseudo html for common content (header, nav panel, footer, etc), and then you write your articles in markdown and Hugo combines the two and outputs actual html files.

You also have a content folder for js, css, and images which get output as is.

That’s about all there is to it, it’s a pretty minimalist static site generator.

Hosting wise you can just put it on github pages for free.

godber@lemmy.az.social on 28 Sep 2024 12:13 collapse

The other advantage of Hugo is that it’s just a single binary executable. Using something like Jekyll means you have to manage a ruby environment over the long term. Which sucks. I’d recommend trying Hugo again and getting past the pain points.

JetpackJackson@feddit.org on 28 Sep 2024 10:36 next collapse

Currently using Jekyll but working on switching to Haunt cause I like Scheme

mbirth@lemmy.ml on 28 Sep 2024 10:44 next collapse

GitHub supports Jekyll page generation. Or at least did this a few years ago.

And please make sure to also generate an RSS feed for us feed reader users. ;)

mountainCalledMonkey@lemmy.world on 28 Sep 2024 11:00 next collapse

Grav may fit your needs.

anguo@lemmy.ca on 28 Sep 2024 11:02 next collapse

If you don’t want to code it, give Publii a look. Otherwise, my go-to is Eleventy, simple and clean.

poVoq@slrpnk.net on 28 Sep 2024 11:08 next collapse

Maybe picocms.org

But Hugo is fine, no need to use all the advanced features.

halm@leminal.space on 28 Sep 2024 17:35 collapse

I’ve been eyeing Pico, but it doesn’t seem to be super well maintained? Do you know if it’s still active?

nutbutter@discuss.tchncs.de on 28 Sep 2024 11:17 next collapse

i recommend using Jekyll to make the website, and for hosting I recommend codeberg pages.

rand_alpha19@moist.catsweat.com on 28 Sep 2024 11:20 next collapse

Have you considered a wiki instead? I use OtterWiki and I like it a lot. It has version control using Git too.

There are several dozen different wiki softwares out there, you can compare their features using this site.

rsolva@lemmy.world on 28 Sep 2024 15:07 collapse

OtterWiki looks awesome! The combination of markdown, git and a web interface is powerful.

rand_alpha19@moist.catsweat.com on 28 Sep 2024 22:49 collapse

Yeah! It lets me focus on content instead of building the actual site so I thought I would suggest it given OP's use case.

Also the CSS can be modified with a separate file that overrides the default, so it's pretty customizable without touching the actual config files at all.

Moonrise2473@feddit.it on 28 Sep 2024 11:27 next collapse

What about Publii?

WYSIWYG static site generator but personally I like to keep the content in markdown pages in a git repository so i can keep unlimited edit history; this saves everything in a local sqlite database.

Unfortunately the most powerful one that checks all the boxes, including automatic upload to s3 is hugo, but as you said the learning curve is high. Maybe try to see if you can run the example site of this theme, install hugo in your system, then go in the examplesite directory and run hugo serve. Slowly edit the files until you understand how it works.

adam@doomscroll.n8e.dev on 28 Sep 2024 11:32 next collapse

Hugo can be as simple as installing it, configuring a site with some yaml that points at a really available theme and writing your markdown content.

It gets admittedly more complex if you’re wanting to write your own theme though.

But I think this realistically applies to most all static site generators.

atzanteol@sh.itjust.works on 28 Sep 2024 12:15 next collapse

I like jbake. Create templates, pages are either html or markdown. Pretty easy to use.

mike_wooskey@lemmy.thewooskeys.com on 28 Sep 2024 12:17 next collapse

I think most of the other suggestions seem like a better solution than WordPress, but there is a plugin for WordPress that exports static websites.

rutrum@lm.paradisus.day on 28 Sep 2024 12:53 next collapse

I recently built a site with hugo. Its very easy. You pick a theme, then write some markdown files. And when you need flexibility, you have it for later. I also think it’s the most popular right now, which lends to a lot of themes to pick from and a lot of cpmmunity support.

thayerw@lemmy.ca on 28 Sep 2024 14:08 next collapse

Lots of great responses here already. In terms of simplicity and ease of maintenance, Hugo is going to be the best solution with its single binary, built-in features, and ease of setup/use.

fubarx@lemmy.ml on 28 Sep 2024 14:44 next collapse

If you use github pages, you can create, deploy, and host static websites for free. Only cost, if you want your own URL, is for a custom DNS name.

You can use their default Jekyll static rendering engine, and create the content using Markdown. And with github actions, all you need to update the content is create markdown, then push the change to the same repo. After a few minutes, the new content shows up.

pages.github.com

Hugo can also be used, but it takes a few extra steps: gohugo.io/…/hosting-on-github/

You can also find ‘themes’ to customize the look and feel of the site, specific to the site generation tool.

If you want a lot of extra features, Docusaurus is pretty much as good as it gets, and you can set it up to push out to GH pages: docusaurus.io/docs/deployment

StringPotatoTheory@lemmy.world on 28 Sep 2024 17:18 next collapse

I’ve been meaning to change my website from Hugo to Zola. It has a few good themes to choose from and it’s easy to set up. Hugo has way more themes though.

You might want to check out a lot of SSGs to see what themes each has, and pick the one you like the most.

manuel2258@lemy.lol on 29 Sep 2024 09:16 next collapse

I build my website using Zola, which worked pretty good. However I wasn’t satisfied with the existing templates so I did build my own using DaisyUI. That also worked pretty good most of the time and was a pleasant experience!

exception4289@lemmy.world on 30 Sep 2024 13:14 collapse

My vote goes to Zola, too.
I recently migrated my Hugo blog to Zola.

2xsaiko@discuss.tchncs.de on 28 Sep 2024 20:06 next collapse

How about GNU M4 + Make (output)?

(to be clear this is a joke suggestion. but yes it is what I legitimately use)

Irf23@eviltoast.org on 29 Sep 2024 06:05 next collapse

Big fan of 11ty www.11ty.dev

Kcg@lemmy.ml on 29 Sep 2024 09:22 next collapse

Mkdocs is great! Used by many different OS projects. Simple markdown to HTML site.

acockworkorange@mander.xyz on 29 Sep 2024 10:31 next collapse

LibreOffice Write, a template, save as HTML, FTP to your host.

keyez@lemmy.world on 29 Sep 2024 17:00 next collapse

I had a workflow a few years ago where I ran and configured a local drupal instance, then ran this HTTrack tool which would export all the pages and images to flat HTML which I then zipped and pushed to an S3 bucket to host the website. Worked great because it just needed to host info, no comments or accounts or anything.

www.httrack.com

chips@startrek.website on 01 Oct 2024 10:27 next collapse

Hey there! For a friendly and simple static site generator, you might wanna check out Jekyll. It’s pretty lightweight, works great with Markdown, and has a nice community. Plus, it’s super easy to deploy on S3. You can still hand-code if you want, but Jekyll will save you a bunch of time!

daco@lemm.ee on 03 Oct 2024 17:40 collapse

I use Nikola and it hasn’t let me down. It just works and supports all the ways I write content: markdown, asciidoc, rest, Jupiter Notebooks, html and so on. It does not have so many themes, but the default one works and it’s not hard to customise if needed. If you like to use python it’s also easy to extend. I’ve written a bit about Nikola here in case it picks your interest.

I’ve deployed it to CloudFlare pages, but GitHub pages, Gitlab pages and any other provider also work.