Bean
Bean, named after the best Spore creature out there, is a Jekyll theme made to use in both Esporo and Simulando fansites. It can be used freely by anyone.
Bean is colorful and customizable. You can change how it looks using CSS variables, you can add widgets to the sidebar or scripts easily.
Features
- Make it yours with custom colors, typography and backgrounds.
- Automatic light and dark themes!
- Custom sidebar widgets and scripts with includes.
- Support for pagination, sitemap, SEO tags and archives out of the box.
- Translatable using theme options.
Installation
As a remote theme
You can use this theme with the jekyll-remote-theme
plugin.
On your site repo, run:
$ bundle add jekyll-remote-theme
And add the following to your _config.yml
:
remote_theme: esporo/bean@latest
plugins:
- jekyll-remote-theme
As a gem-theme
You can also use this theme as a gem-based dependency to your Jekyll site.
Add this line to your Jekyll site's Gemfile
:
gem "bean"
And add this line to your Jekyll site's _config.yml
:
theme: bean
And then execute:
$ bundle
Or install it yourself as:
$ gem install bean
Usage
Your theme can be configured using your _config.yml
. You can also customize the theme, sidebar widgets and site-wide scripts by adding them to your Jekyll setup.
Configuration
This is an example of a _config.yml
with all the options available to Bean.
title: Your awesome title
description: >-
Your blog description. It will be shown at the bottom of your website.
tagline: A short-and-sweet tagline.
lang: en
logo: /path/to/your/logo.svg
permalink: "/:year/:month/:day/:title.html"
slug_mode: latin
bean:
show_excerpts: true
copyright_notice: >-
Site built using [Bean](https://github.com/esporo/bean).
date_formats:
day: "%v"
month: "%B, %Y"
year: "%Y"
translations:
jump_to_navigation: "Go to navigation"
jump_to_content: "Go to content"
archive_date_title: "Posts from %s"
archive_tag_title: "Posts with the tag “%s”"
archive_category_title: "Posts filed under “%s”"
post_tagged_with: "Tagged with:"
blog_pagination_title: "Blog Pagination"
blog_pagination_next_page: "Older posts"
blog_pagination_prev_page: "Newer posts"
main_menu:
title: Navigate
items:
- label: Home
path: /
- label: About
path: /about/
- label: Bugs?
path: https://github.com/esporo/bean/issues
- label: Docs
path: hhttps://github.com/esporo/bean?tab=readme-ov-file#readme
footer_menu:
title: Socials
items:
- label: Discord
path: https://discord.gg/
- label: YouTube
path: https://youtube.com/
- label: Facebook
path: https://www.facebook.com/
Plugins
Bean adds support for pagination, archives, feeds and SEO tags, so you can configure the settings following these plugins docs:
Please refer to the full _config.yml
for plugin configurations.
Style Options
You can add a theme.css
in your /assets/css
directory to customize the style options of your site.
Just copy our theme.css
and uncomment the lines of the variables you want to change, and you're good to go. Please note that background and color variables have different values for light and dark color schemes.
theme.css
is also a good place to add custom style rules as well, since it's the last stylesheet called by your theme. It will overwrite any rules set by default.
You can also replace the fonts used in your theme by placing them in your /assets/fonts
directory and declaring them on /assets/fonts/fonts.css
.
Bean has two menus available. One at the header and other at the bottom of your site. Both are set up in your _config.yml
:
main_menu:
title: Navigate
items:
- label: Home
path: /
- label: About
path: /about/
- label: Bugs?
path: https://github.com/esporo/bean/issues
- label: Docs
path: hhttps://github.com/esporo/bean?tab=readme-ov-file#readme
footer_menu:
title: Socials
items:
- label: Discord
path: https://discord.gg/
- label: YouTube
path: https://youtube.com/
- label: GitHub
path: https://github.com/
A menu title is used by screen reader software. It's strongly recommended that you add one to your menus.
Includes
You can customize parts of the theme by adding includes to your repo.
There are three available includes for you to customize:
_includes/below-post.html
: will add content to your post page after the post structure. Useful for comments or notices._includes/widgets.html
: will add widgets to your blog sidebar. See Sidebar below._includes/scripts.html
will add add site-wide scripts like Disqus and analytics stuff at the end of the <body>
tag.
Your blog sidebar can be customized by adding widgets to your _includes/widgets.html
. The theme provides a default layout for widgets.
You can do something like this:
{% assign widget_title = "My beautiful widget" %}
{% capture widget_content %}
<p>This will be shown in my website sidebar! It's useful for a blogroll, useful links, etc.</p>
{% endcapture %}
{% include blog/widget.html title=widget_title content=widget_content %}
You can as many widgets as you want, just repeat the process above.
The sidebar can be hidden in a page with the page
layout. Just add it to your front-matter:
---
layout: page
title: About
hide_sidebar: true
---
Post authors
Bean tries to bring up post author information from the following sources:
- An
author
object in the front-matter of your post:
author:
name: Will Wright
url: https://example.com
- Your
_data/authors.yml
.
It may look like this:
will:
name: Will Wright
url: https://example.com
- A
site.authors
or site.author
object in your _config.yml
.
Something like this will do:
authors:
will:
name: Will Wright
url: https://example.com
lucy:
name: Lucy Bradshaw
url: https://example.net
author:
name: Will Wright
url: "https://willwright.blog"
If none of these sources are available, Bean will just show the value of your post.author
as it is.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/esporo/bean.
Be aware that, as this theme is intended to be used by my own fansite, not every suggestion may be applied. You are free to fork it and change it to fit your needs!
License
The theme is available as open source under the terms of the MIT License.