Chairome is a minimalist, highly-versatile theme for Hugo adapted from @victoriadrake's hugo-theme-introduction. It can be configured as a single page, or as a full-featured site with multiple sections. It is multilingual, responsive, and includes a light and dark theme.
Extra Chairome features:
- Logo in the hero
- Blog posts can be rendered as grid structures of squares, circles or hexagons, with a features image
- Multiple projects/blog sections given the section type is set as
projects
orblog
in the front matter yaml - Any section type that is
home
,projects
orblog
will be rendered on the landing page
Additionally, there are the features of the theme that come from the original Introduction theme.
Features:
- Multilingual - supports side-by-side content in different language versions
- Custom index page sections from Markdown files
- Projects and Blog sections
- Page load fade-in CSS effect and smooth scrolling to anchor links
- Straightforward customization via
config.toml
- Styled Markdown throughout, including post titles
- Syntax highlighting
Developer-friendly:
- Sass files included with instant compiling to CSS thanks to Hugo Pipes and PostCSS
- Thoughtful use of Sass variables makes creating new colour schemes easy
- Requires extended version of Hugo (latest version recommended)
To make changes to the theme CSS, extended Hugo's PostCSS requires JavaScript packages to compile the styles. You'll need postcss
, postcss-cli
, and autoprefixer
which you can install using npm
.
To temporarily address this issue, please pin autoprefixer@9.8.6
.
npm i -g postcss postcss-cli autoprefixer@9.8.6
Learn how to install and use npm here.
Note: If you are using Hugo as a snap app, the above two Node.js packages have to be installed locally inside exampleSite
.
cd exampleSite/
npm i -g postcss postcss-cli autoprefixer
If you see an error message like:
Error: Error building site: POSTCSS: failed to transform "css/main.css" (text/css): resource "sass/sass/style..." not found in file cache
You may need to install these dependencies globally. See issue #210 for more information.
Run from the root of your Hugo site:
git clone https://github.com/Athanasiamo/hugo-chairome.git themes/chairome
Alternatively, you can include this repository as a git submodule. This makes it easier to update this theme if you have your Hugo site in git as well:
git submodule add https://github.com/Athanasiamo/hugo-chairome.git themes/chairome
Introduction ships with an fully configured example site. For a quick preview:
cd themes/chairome/exampleSite/
hugo serve --themesDir ../..
Then visit http://localhost:1313/
in your browser to view the example site.
The following explains how to add content to your Hugo site. You can find sample content in the exampleSite/
folder.
Create index.md
:
hugo new home/index.md
The title
frontmatter will be the first large heading.
The content of index.md
will be shown as a subtitle line.
You might want to set headless
to true
in the frontmatter. See headless bundles for more information.
Content for the home page lives under content/home/
. You may add as many files as you want to in markdown format.
Each markdown file will show as a section on the home page and can be ordered by the weight
value in the file's frontmatter. You can set image
to show an image on the left side of the section. The image file must be in the content/home/
folder.
You may add a contact section by creating
contact.md
:
hugo new home/contact.md
This will always be shown as the last section on the home page.
Introduction provides an easy way to showcase your projects. Each project can even have its own gallery, shown as an image carousel.
Start by creating an index file for the projects section:
hugo new projects/_index.md
Add a title
and some optional content to the file.
Add an optional weight
for ordering projects section.
To create a project, run:
hugo new projects/YourProjectName/index.md
The frontmatter of your new file contains some comments to help your configure your project.
You can set external_link
to make the project link to another website.
Add images to your project by placing image files in the YourProjectName/
folder. If you add more then one photo, they will display as a carousel gallery. Images will be ordered by filename. The first image will be shown as the project preview image. You can change the order of your images by adding a weight
to that resource's parameters:
resources:
- src: NameOfYourImage.jpg
params:
weight: -100
Create an index file for the blog:
hugo new blog/_index.md
Add an optional weight
for ordering blog section on your homepage
Create a new blog post with:
hugo new blog/YourEntryTitle/index.md
Posts will also display in the Blog section of the home page.
From exampleSite/
, copy config.toml
to the root folder of your Hugo site and change the fields as you like. Helpful comments are provided.
Introduction currently ships with support for many languages. Contributions for other language translations are welcome.
To create a new language translation, add the .toml
file to the i18n/
folder. See the existing files for the necessary fields.
See the hugo documentation for more details.
Introduction contains a default menu. If you want to override this, you can do so by defining a menu.main
in config.toml
.
Set googleAnalytics
in config.toml
to activate Hugo's internal Google Analytics template.
Set disqusshortname
in config.toml
to activate Hugo's internal Disqus template.
You can add custom CSS files by placing them under assets/
and adding the paths to the files to the customCSS
list in config.toml
.
You can add custom JavaScript files by placing them under assets/
and adding the paths to the files to the customJS
list in config.toml
.
If you have a question or get stuck, please open an issue for help and to help those who come after you. The more information you can provide, the better!
Contributions for new translations, fixes, and features are welcome.
This theme would not be nearly as awesome without its amazing community of open source contributors. Thank you so much! 🖤
Copyright (C) 2017-2020 Victoria Drake
Licensed under Apache-2.0