This is a simple fork of Hylia by Andy Bell and friends.
While I'm open-sourcing this project because some people might be interested in the styles and custom components I've introduced, if you are making your own blog, I recommend starting with the Hylia base blog rather than forking this repo. I found it easy to configure, and it only took a few evenings of tinkering to style it to my preferences.
If you do want to use this repo as is, please observe the following requests:
- ✅ Do: Feel free to copy the styling, JS, etc.
- ✅ Do: Leave attribution to this repo and Hylia if you fork me
- ❌ Do not: Include any of the copy (text content) contained in this repo in your own website
For your convenience, I've included Hylia's README as an appendix. It does a good job of taking you on a tour of the features and general structure of this project.
- 🎺 Celebrate accomplishments with custom page and homepage preview
- ⚗️ Generates post patterns based on a SHA of each post
- 📷 Social image thumbnails for posts
- 📔 Footnote support in Markdown
- 🎥
asciinema
support allowing easy embedding of terminal-based recordings - 📂 Support for filenames attached to code blocks
- 🎉 100 Lighthouse accessibility scores
- 📄 Additional components for Markdown files like tables
- 💅 Custom theme
Appendix: Hylia's README
Hylia is a lightweight Eleventy starter kit with Netlify CMS pre-configured, so that you can one-click install a progressive, accessible blog in minutes. It also gives you a well organized starting point to extend it for yourself.
Get started now by [deploying Hylia to Netlify.][deploy-to-netlify]
Hylia version 0.7.0 features:
✍️ A pre-configured Netlify CMS setup
🎨 Customisable design tokens to make it your own
🌍 Customisable global data and navigation
📂 Tags and tag archives
✅ Progressively enhanced, semantic and accessible
🎈 Super lightweight front-end
🚰 Sass powered CSS system with utility class generator
⚙️ Service worker that caches pages so people can read your articles offline
🚀 An RSS feed for your posts
💌 A basic contact form, ready for Netlify Forms
💬 Netlify Forms powered comments
💡 Dark/Light mode toggle Added in 0.4.0
🗣 Webmentions
📖 Pagination
🐦 Web sharing API integration
🗒 Offline mode with links to cached pages
📄 Documentation site
💅 Proper Sass documentation
✍️ Proper CMS documentation
🖼 A facility for you to be able to add your logo / branding
You can [deploy Hylia to Netlify with one click][deploy-to-netlify] and you’ll be up and running in minutes!
I recorded a quick start video of me deploying Hylia to Netlify and getting the CMS set up. Check it out here.
- Clone or fork this repo:
git clone https://github.com/hankchizljaw/hylia
cd
into the project directory and runnpm install
- Once all the dependencies are installed run
npm start
- Open your browser at
http://localhost:8080
and away you go!
npm start
npm run production
npm run sass:process
npm run sass:tokens
Before you can use the CMS, you need to do some config in Netlify. Luckily they provide a very handy guide to get started.
In short, though:
- Once you’ve set up the site on Netlify, go to “Settings” > “Identity” and enable Identity
- Scroll down to the “Git Gateway” area, click “Enable Git Gateway” and follow the steps
- Click the “Identity” tab at the top
- Once you’ve enabled identity, click “Invite Users”
- Check the invite link in your inbox and click the link in the email that’s sent to you
- Set a password in the popup box
- Go to
/admin
on your site and login - You’re in and ready to edit your content!
Although Hylia has a pretty simple design, you can configure the core design tokens that control the colours, size ratio and fonts.
Note: Credit must be given to the hard work Jina Anne did in order for the concept of design tokens to even exist. You should watch this video, then read this article and then sign up for this course to expand your knowledge.
To change the design tokens in the CMS, find the “Globals” in the sidebar then in the presented options, select “Theme Settings”.
To change the design tokens directly, edit _src/data/tokens.json
.
The tokens are converted into maps that the Sass uses to compile the front-end CSS, so make sure that you maintain the correct structure of tokens.json
.
Your version of Hylia ships with a Styleguide by default. You can see a demo of the Styleguide at https://hylia.website/styleguide/.
You can edit the Styleguide by opening src/styleguide.njk
. If you don’t want the Styleguide, delete that file and the page will vanish.
Hylia is based on the WIP v2 version of Stalfos, which currently has no documentation (I know, I’m bad). Here is some very basic documentation for elements of the new framework that you will encounter on this project.
The whole Sass system is powered by central config file, which lives here: _src/scss/_config.scss
.
Before Sass is compiled, a _tokens.scss
file is generated from the design tokens config which is required.
Key elements:
$stalfos-size-scale
: A token driven size scale which by default, is a “Major Third” scale$stalfos-colors
: A token driven map of colours$stalfos-util-prefix
: All pre-built, framework utilities will have this prefix. Example: the wrapper utility is '.sf-wrapper' because the default prefix is 'sf-'$metrics
: Various misc metrics to use around the site$stalfos-config
: This powers everything from utility class generation to breakpoints to enabling/disabling pre-built components/utilities
The utility class generator lets you generate whatever you want, with no opinions on class name or properties affected.
To add a new class, add another item to the exists $stalfos-config
map. This example adds a utility for floating elements.
'float':('items':('left':'left','right': 'right'
),
'output': 'responsive',
'property': 'float'
);
The output
is set to responsive
which means every breakpoint will generate a prefixed class for itself. If you only wanted elements to float left in the md
breakpoint, you’d now be able to add a class of md:float-left
to your HTML elements.
If you only want standard utility classes generating, set the output
to standard
.
Function tries to match the passed $key
with the $stalfos-colors
map. Returns null if it can’t find a match.
Returns back a 1 dimensional (key value pair) config value if available.
Function tries to match the passed $ratio-key
with the $stalfos-size-scale
. Returns null if it can’t find a match.
Grabs the property and value of one of the $stalfos-config utilities
that the generator will generate a class for.
Pass in the key of one of your breakpoints set in $stalfos-config['breakpoints']
and this mixin will generate the @media
query with your configured value.
Hylia has Netlify CMS pre-configured as standard. You can customise the configuration by editing src/admin/config.yml
.
The basic CMS setup allows you to edit the following:
- Home page: Edit the content on your homepage
- Posts: Create and edit blog posts
- Generic pages: Create generic pages that use a similar layout to posts
- Global site data: Various bits of