2023-02-13 21:45:09 -03:00
|
|
|
# ᕦʕ •ᴥ•ʔᕤ Bear Cub
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
[data:image/s3,"s3://crabby-images/19977/19977302ae2b6979efc1674e7f2272e8e395d2ba" alt="github pages"](https://github.com/clente/hugo-bearcub/actions/workflows/gh-pages.yml)
|
|
|
|
[data:image/s3,"s3://crabby-images/1d0fe/1d0fe6b3f0f2498b16a6ff86b1ef197f6753fe29" alt="MIT license"](https://github.com/clente/hugo-bearcub/blob/main/LICENSE)
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
## Overview
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
🐻 A lightweight [Hugo](https://gohugo.io/) theme based on [Bear
|
|
|
|
Blog](https://bearblog.dev) and [Hugo Bear
|
|
|
|
Blog](https://github.com/janraasch/hugo-bearblog).
|
2020-10-01 16:02:12 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
**Bear Cub** takes care of speed and optimization, so you can focus on writing
|
|
|
|
good content. It is free, multilingual, optimized for search engines,
|
|
|
|
no-nonsense, responsive, light, and fast. Really fast.
|
2020-10-01 15:53:45 +02:00
|
|
|
|
2020-08-31 15:40:11 +02:00
|
|
|
## Installation
|
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
Follow Hugo's [quick start](https://gohugo.io/getting-started/quick-start/) to
|
|
|
|
create an empty website and then clone **Bear Cub** into the themes directory as
|
|
|
|
a [Git submodule](https://git-scm.com/book/en/v2/Git-Tools-Submodules):
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
```sh
|
|
|
|
git submodule add https://github.com/clente/hugo-bearcub themes/hugo-bearcub
|
2020-08-31 15:40:11 +02:00
|
|
|
```
|
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
To finish off, append a line to the site configuration file:
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
```sh
|
2024-03-04 16:13:03 -03:00
|
|
|
echo 'theme = "hugo-bearcub"' >> hugo.toml
|
2023-02-13 21:45:09 -03:00
|
|
|
```
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
## Features
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
Like [Bear Blog](https://bearblog.dev), this theme:
|
|
|
|
- Is free and open source
|
|
|
|
- Looks great on any device
|
|
|
|
- Makes tiny (~5kb), optimized, and awesome pages
|
|
|
|
- Has no trackers, ads, or scripts
|
|
|
|
- Automatically generates an RSS feed
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
But that's not all! **Bear Cub** is also...
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
### Accessible
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
**Bear Cub** has a few accessibility upgrades when compared to its predecessors.
|
|
|
|
The color palette has been overhauled to make sure everything is
|
|
|
|
[readable](https://web.dev/color-and-contrast-accessibility/) for users with low
|
|
|
|
vision impairments or color deficiencies, and some interactive elements were
|
|
|
|
made bigger to facilitate [clicking](https://web.dev/accessible-tap-targets/)
|
|
|
|
for users with a motor impairment.
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
These small changes mean that **Bear Cub** passes Google's [PageSpeed
|
|
|
|
test](https://pagespeed.web.dev/report?url=https%3A%2F%2Fclente.github.io%2Fhugo-bearcub%2F)
|
|
|
|
with flying colors.
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
data:image/s3,"s3://crabby-images/9b1b0/9b1b03e6e20ca9a30d55120e981659cc714ef9f2" alt="PageSpeed score"
|
2020-09-04 08:54:19 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
### Secure
|
2020-09-04 08:54:19 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
[**Bear Cub**'s demo](https://clente.github.io/hugo-bearcub/) is hosted on GitHub
|
|
|
|
and therefore I'm not in control of its [Content Security
|
|
|
|
Policy](https://infosec.mozilla.org/guidelines/web_security#content-security-policy).
|
|
|
|
However, the theme itself was made with security in mind: there are no inline
|
|
|
|
styles and it uses no JavaScript at all.
|
2020-09-04 08:54:19 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
If you want to improve your [Mozilla
|
|
|
|
Observatory](https://observatory.mozilla.org/) score even further, you should be
|
|
|
|
able to simply add a few headers to your hosting service's configuration (e.g.
|
|
|
|
[Netlify](https://docs.netlify.com/routing/headers/) or [Cloudflare
|
|
|
|
Pages](https://developers.cloudflare.com/pages/platform/headers/)) and never
|
|
|
|
have to think about it again. My `_headers` file, for example, looks like this:
|
2020-09-04 08:54:19 +02:00
|
|
|
|
|
|
|
```
|
2023-02-13 21:45:09 -03:00
|
|
|
/*
|
|
|
|
X-Content-Type-Options: nosniff
|
|
|
|
Strict-Transport-Security: "max-age=31536000; includeSubDomains; preload" env=HTTPS
|
|
|
|
Cache-Control: max-age=31536000, public
|
|
|
|
X-Frame-Options: deny
|
|
|
|
Referrer-Policy: no-referrer
|
|
|
|
Feature-Policy: microphone 'none'; payment 'none'; geolocation 'none'; midi 'none'; sync-xhr 'none'; camera 'none'; magnetometer 'none'; gyroscope 'none'
|
|
|
|
Content-Security-Policy: default-src 'none'; manifest-src 'self'; font-src 'self'; img-src 'self'; style-src 'self'; form-action 'none'; frame-ancestors 'none'; base-uri 'none'
|
|
|
|
X-XSS-Protection: 1; mode=block
|
2020-09-04 08:54:19 +02:00
|
|
|
```
|
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
### Multilingual
|
|
|
|
|
|
|
|
If you need to write a blog that supports more than one language, **Bear Cub**
|
2024-03-04 16:13:03 -03:00
|
|
|
has you covered! Check out the demo's [`hugo.toml`
|
|
|
|
file](https://github.com/clente/hugo-bearcub/blob/main/exampleSite/hugo.toml)
|
2023-02-13 21:45:09 -03:00
|
|
|
for a sample of how you can setup multilingual support.
|
|
|
|
|
|
|
|
By default, the theme creates a translation button that gets disabled when the
|
|
|
|
current page is only available in any other language. You can also choose to
|
|
|
|
hide this button (instead of disabling it) by setting `hideUntranslated =
|
2024-03-26 22:22:42 +00:00
|
|
|
true`.
|
2023-02-13 21:45:09 -03:00
|
|
|
|
|
|
|
### More
|
|
|
|
|
|
|
|
Every once in a while, as I keep using **Bear Cub**, I notice that there is some
|
|
|
|
functionality missing. Currently, these are the "advanced features" that I have
|
|
|
|
already implemented:
|
|
|
|
|
2023-10-17 15:41:36 -03:00
|
|
|
- Full-text RSS feed: an enhanced RSS feed template that includes the (properly
|
|
|
|
encoded) full content of your posts in the feed itself.
|
2023-02-13 21:45:09 -03:00
|
|
|
- Static content: you can create empty blog entries that act as links to static
|
|
|
|
files by including `link: "{url}"` in a post's [front
|
2023-10-16 23:47:27 -03:00
|
|
|
matter](https://gohugo.io/content-management/front-matter/). You can also add
|
|
|
|
`render: false` to your [build
|
|
|
|
options](https://gohugo.io/content-management/build-options/#readout) to avoid
|
2023-11-03 00:17:13 -03:00
|
|
|
rendering blank posts.
|
2023-09-29 20:05:14 -03:00
|
|
|
- Skip link: a "skip to main content" link that is temporarily invisible, but
|
|
|
|
can be focused by people who need a keyboard to navigate the web (see [PR
|
|
|
|
#5](https://github.com/clente/hugo-bearcub/pull/5) by
|
|
|
|
[@2kool4idkwhat](https://github.com/2kool4idkwhat) for more information).
|
2023-10-17 01:10:22 -03:00
|
|
|
- Reply by email: if you supply an email address, the theme creates a "Reply to
|
|
|
|
this post by email" button at the end of every post (see Kev Quirk's [original
|
|
|
|
implementation](https://kevquirk.com/adding-the-post-title-to-my-reply-by-email-button)).
|
2024-06-21 16:26:22 -03:00
|
|
|
This button can be suppressed on a case-by-case by setting `hideReply: true`
|
|
|
|
in a post's [front matter](https://gohugo.io/content-management/front-matter/)
|
|
|
|
(see [PR #18](https://github.com/clente/hugo-bearcub/pull/18) by
|
|
|
|
[@chrsmutti](https://github.com/chrsmutti)).
|
2024-01-04 23:24:51 -03:00
|
|
|
- `absfigure` shortcode: a shortcut to use the `figure` shortcode that also
|
|
|
|
converts relative URLs into absolute URLs by using the `absURL` function.
|
2023-02-13 21:45:09 -03:00
|
|
|
- Single-use CSS (EXPERIMENTAL): you can add some styles to a single page by
|
|
|
|
writing the CSS you need in `assets/{custom_css}.css` and then including
|
|
|
|
`style: "{custom_css}.css"` in the [front
|
|
|
|
matter](https://gohugo.io/content-management/front-matter/) of said page.
|
2023-10-27 19:30:53 -03:00
|
|
|
- Conditional CSS (EXPERIMENTAL): since **Bear Cub** does syntax highlighting
|
2024-03-04 16:13:03 -03:00
|
|
|
without inline styles (see `hugo.toml` for more information), it only load its
|
|
|
|
`syntax.css` if, and only if, a code block is actually present in the current
|
|
|
|
page.
|
2024-03-04 17:16:00 -03:00
|
|
|
- Alternative "Herman" style (EXPERIMENTAL): if you want to check out a more
|
|
|
|
modern CSS style, you can change the `themeStyle` parameter to `"herman"` in
|
|
|
|
order to activate [Herman Martinus's](https://herman.bearblog.dev/) version of
|
|
|
|
the [Blogster Minimal](https://blogster-minimal.netlify.app/) theme for
|
|
|
|
[Astro](https://astro.build/).
|
2023-03-04 15:08:11 -03:00
|
|
|
- Dynamic social card generation (EXPERIMENTAL): if you don't add preview images
|
|
|
|
to a post, this template will generate one based on the title. You can see an
|
|
|
|
example below.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/77b6b/77b6b4bf15e3b299b80679435fe529f742b64fc3" alt="Social card example"
|
2023-02-13 21:45:09 -03:00
|
|
|
|
|
|
|
## Configuration
|
|
|
|
|
2024-03-04 16:13:03 -03:00
|
|
|
**Bear Cub** can be customized with a `hugo.toml` file. Check out the
|
|
|
|
[configuration](https://github.com/clente/hugo-bearcub/blob/main/exampleSite/hugo.toml)
|
2023-02-13 21:45:09 -03:00
|
|
|
of the [demo](https://clente.github.io/hugo-bearcub/) for more information.
|
|
|
|
|
|
|
|
```toml
|
|
|
|
# Basic config
|
|
|
|
baseURL = "https://example.com"
|
|
|
|
theme = "hugo-bearcub"
|
|
|
|
copyright = "John Doe (CC BY 4.0)"
|
|
|
|
defaultContentLanguage = "en"
|
|
|
|
|
|
|
|
# Generate a nice robots.txt for SEO
|
|
|
|
enableRobotsTXT = true
|
|
|
|
|
|
|
|
# Setup syntax highlighting without inline styles. For more information about
|
|
|
|
# why you'd want to avoid inline styles, see
|
|
|
|
# https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/style-src#unsafe_inline_styles
|
|
|
|
[markup]
|
|
|
|
[markup.highlight]
|
|
|
|
lineNos = true
|
|
|
|
lineNumbersInTable = false
|
|
|
|
# This allows Bear Cub to use a variation of Dracula that is more accessible
|
|
|
|
# to people with poor eyesight. For more information about color contrast
|
|
|
|
# and accessibility, see https://web.dev/color-and-contrast-accessibility/
|
|
|
|
noClasses = false
|
|
|
|
|
|
|
|
# Multilingual mode config. More for information about how to setup translation,
|
|
|
|
# see https://gohugo.io/content-management/multilingual/
|
|
|
|
[languages]
|
|
|
|
[languages.en]
|
2023-02-13 21:47:21 -03:00
|
|
|
title = "Bear Cub"
|
|
|
|
languageName = "en-US 🇺🇸"
|
2023-02-13 21:45:09 -03:00
|
|
|
LanguageCode = "en-US"
|
|
|
|
contentDir = "content"
|
|
|
|
[languages.en.params]
|
|
|
|
madeWith = "Made with [Bear Cub](https://github.com/clente/hugo-bearcub)"
|
|
|
|
[languages.pt]
|
2023-02-13 21:47:21 -03:00
|
|
|
title = "Bear Cub"
|
|
|
|
languageName = "pt-BR 🇧🇷"
|
2023-02-13 21:45:09 -03:00
|
|
|
LanguageCode = "pt-BR"
|
|
|
|
contentDir = "content.pt"
|
|
|
|
[languages.pt.params]
|
|
|
|
madeWith = "Feito com [Bear Cub](https://github.com/clente/hugo-bearcub)"
|
|
|
|
|
|
|
|
[params]
|
|
|
|
# The description of your website
|
|
|
|
description = "Bear Cub Demo"
|
|
|
|
|
|
|
|
# The path to your favicon
|
|
|
|
favicon = "images/favicon.png"
|
|
|
|
|
|
|
|
# These images will show up when services want to generate a preview of a link
|
2023-03-04 15:08:11 -03:00
|
|
|
# to your site. Ignored if `generateSocialCard = true`. For more information
|
|
|
|
# about previews, see https://gohugo.io/templates/internal#twitter-cards and
|
2023-02-13 21:45:09 -03:00
|
|
|
# https://gohugo.io/templates/internal#open-graph
|
2023-10-18 23:36:03 -03:00
|
|
|
images = ["images/share.webp"]
|
2023-02-13 21:45:09 -03:00
|
|
|
|
|
|
|
# This title is used as the site_name on the Hugo's internal opengraph
|
|
|
|
# structured data template
|
2023-02-13 21:47:21 -03:00
|
|
|
title = "Bear Cub"
|
2023-02-13 21:45:09 -03:00
|
|
|
|
|
|
|
# Dates are displayed following the format below. For more information about
|
|
|
|
# formatting, see https://gohugo.io/functions/format/
|
|
|
|
dateFormat = "2006-01-02"
|
|
|
|
|
|
|
|
# If your blog is multilingual but you haven't translated a page, this theme
|
|
|
|
# will create a disabled link. By setting `hideUntranslated` to true, you can
|
|
|
|
# have the theme simply not show any link
|
|
|
|
hideUntranslated = false
|
|
|
|
|
2024-03-04 17:16:00 -03:00
|
|
|
# (EXPERIMENTAL) This theme has two options for its CSS styles: "original" and
|
|
|
|
# "herman". The former is what you see on Bear Cub's demo (an optimized
|
|
|
|
# version of Hugo Bear Blog), while the latter has a more modern look based on
|
|
|
|
# Herman Martinus's version of the Blogster Minimal theme for Astro.
|
|
|
|
themeStyle = "original"
|
|
|
|
|
2023-03-04 15:08:11 -03:00
|
|
|
# (EXPERIMENTAL) This theme is capable of dynamically generating social cards
|
2023-03-04 16:36:06 -03:00
|
|
|
# for posts that don't have `images` defined in their front matter; By setting
|
2023-03-04 15:08:11 -03:00
|
|
|
# `generateSocialCard` to false, you can prevent this behavior. For more
|
2024-02-06 13:39:01 -03:00
|
|
|
# information see layouts/partials/social_card.html
|
2023-03-04 15:08:11 -03:00
|
|
|
generateSocialCard = true
|
|
|
|
|
|
|
|
# Social media. Delete any item you aren't using to make sure it won't show up
|
|
|
|
# in your website's metadata.
|
2024-01-04 17:03:02 -03:00
|
|
|
[params.social]
|
2023-03-04 15:08:11 -03:00
|
|
|
twitter = "example" # Twitter handle (without '@')
|
|
|
|
facebook_admin = "0000000000" # Facebook Page Admin ID
|
2024-01-04 17:32:06 -03:00
|
|
|
|
|
|
|
# Author metadata. This is mostly used for the RSS feed of your site, but the
|
2024-06-21 16:21:25 -03:00
|
|
|
# email is also added to the footer of each post. You can hide the "reply to"
|
|
|
|
# link by using a `hideReply` param in front matter.
|
2024-01-04 17:32:06 -03:00
|
|
|
[params.author]
|
|
|
|
name = "John Doe" # Your name as shown in the RSS feed metadata
|
|
|
|
email = "me@example.com" # Added to the footer so readers can reply to posts
|
2020-08-31 15:40:11 +02:00
|
|
|
```
|
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
## Contributing
|
2020-08-31 15:40:11 +02:00
|
|
|
|
2023-02-13 21:45:09 -03:00
|
|
|
If you come across any problems while using **Bear Cub**, you can file an
|
|
|
|
[issue](https://github.com/clente/hugo-bearcub/issues) or create a [pull
|
|
|
|
request](https://github.com/clente/hugo-bearcub/pulls).
|