Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/probberechts/hexo-theme-cactus
:cactus: A responsive, clean and simple theme for Hexo.
https://github.com/probberechts/hexo-theme-cactus
blog hexo theme
Last synced: about 2 months ago
JSON representation
:cactus: A responsive, clean and simple theme for Hexo.
- Host: GitHub
- URL: https://github.com/probberechts/hexo-theme-cactus
- Owner: probberechts
- License: mit
- Created: 2016-10-31T21:55:38.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-07-10T13:29:51.000Z (7 months ago)
- Last Synced: 2024-08-05T07:01:09.559Z (6 months ago)
- Topics: blog, hexo, theme
- Language: Stylus
- Homepage: https://probberechts.github.io/hexo-theme-cactus/
- Size: 15 MB
- Stars: 3,101
- Watchers: 34
- Forks: 776
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hexo-themes - probberechts/hexo-theme-cactus
- awesome-hexo-theme - 🔗Doc
README
# Cactus
A responsive, clean and simple [Hexo](http://hexo.io) theme for a personal website.
:cactus: [Demo](https://probberechts.github.io/hexo-theme-cactus/)
![screenshot](https://user-images.githubusercontent.com/2175271/137625287-24a4ac77-fbc9-4c99-a4cd-90455d93d13c.png)
## Summary
- [General](#general)
- [Features](#features)
- [Prerequisites](#prerequisites)
- [Install](#install)
- [Configuration](#configuration)
- [License](#license)## General
- **Version** : 3.0
- **Compatibility** : Hexo 3 or later## Features
- Fully responsive
- Multiple color schemes
- Pick your own code highlighting scheme
- Configurable navigation menu
- Support for local search
- Projects list
- I18n support
- Disqus / Utterances
- Google analytics / Baidu Tongji / [Umami Analytics](https://umami.is)
- Font Awesome icons
- Simplicity## Prerequisites
1. In order to use this theme you must have installed [hexo](https://hexo.io/docs/).
2. Create the `root` directory for the blog by initializing it with hexo:
```sh
$ hexo init my-blog
```3. Navigate into the new directory:
```sh
$ cd my-blog
```## Install
1. In the `root` directory:
```sh
$ git clone https://github.com/probberechts/hexo-theme-cactus.git themes/cactus
```2. Change the `theme` property in the `_config.yml` file.
```yml
# theme: landscape
theme: cactus
```
See below for more information on how to customize this theme.3. Create pages and articles with the `hexo new [layout] ` command.
For example, to create an "about me" page, run:
```sh
$ hexo new page about
```
This will create a new file in `source/about/index.md`
Similarly, you can create a new article with
```sh
$ hexo new post "hello world"
```
and add some interesting content in `source/_posts/hello-world.md`.4. Run: `hexo generate` and `hexo server`
5. [Publish your blog](https://hexo.io/docs/one-command-deployment.html)!
## Configuration
You can (and should) modify a couple of settings. An overview of all settings
can be found in [_config.yml](_config.yml). The most important ones are
discussed below.There are two possible methods to override the defaults. As a first option,
you could fork the theme and maintain a custom branch with your settings.
Alternatively, you can configure it from your site's primary configuration
file. Therefore, define your custom settings under the `theme_config` variable.
For example:```yml
# _config.yml
theme_config:
colorscheme: white
``````yml
# themes/cactus/_config.yml
colorscheme: dark
```This will override the default black colorscheme in `themes/cactus/_config.yml`.
### Color scheme
Currently, this theme is delivered with four color schemes: [dark](https://probberechts.github.io/hexo-theme-cactus/cactus-dark/public/), [light](https://probberechts.github.io/hexo-theme-cactus/cactus-light/public/),
[white](https://probberechts.github.io/hexo-theme-cactus/cactus-white/public/) and [classic](https://probberechts.github.io/hexo-theme-cactus/cactus-classic/public/). Set your preferred color scheme in the `_config.yml` file.```yml
colorscheme: light
```Alternatively, you can easily create your own color scheme by creating a new
file in `source/css/_colors`.### Navigation
Set up the navigation menu in the `_config.yml`:
```yml
nav:
home: /
about: /about/
articles: /archives/
projects: http://github.com/probberechts
LINK_NAME: URL
```### Blog posts list on home page
You have two options for the list of blog posts on the home page:
- Show only the 5 most recent posts (default)
```yml
posts_overview:
show_all_posts: false
post_count: 5
```- Show all posts
```yml
posts_overview:
show_all_posts: true
```### Projects list
Create a projects file `source/_data/projects.json` to show a list of your projects on the index page.
```json
[
{
"name":"Hexo",
"url":"https://hexo.io/",
"desc":"A fast, simple & powerful blog framework"
},
{
"name":"Font Awesome",
"url":"http://fontawesome.io/",
"desc":"The iconic font and CSS toolkit"
}
]
```### Social media links
Cactus can automatically add links to your social media accounts.
Therefore, update the theme's `_config.yml`:```yml
social_links:
-
icon: github
link: your-github-url
-
icon: twitter
label: "@your-twitter-handle"
link: your-twitter-url
-
icon: NAME
label: LABEL
link: your-NAME-url
```where `NAME` is the name of a [Font Awesome icon](https://fontawesome.com/icons?d=gallery&s=brands), and LABEL is an optional value used as a title attribute on the link (NAME value is used if LABEL is missing).
### Copyright years
By default, Cactus will use current year in your copyright year information.
If there is a need to customize, please update `_config.yml`:```yml
copyright:
start_year: 2016
end_year:
```### Language configuration
If you are new to Hexo and internationalization (i18n), please read
[Hexo documentation - internationalization (i18n) section](https://hexo.io/docs/internationalization.html)Currently, the theme is delivered with support for:
- English (en), default
- Arabic (ar)
- Brazilian Portuguese (pt-BR)
- Catalan (ca)
- Chinese (Simplified, PRC) (zh-CN)
- Dutch (nl)
- French (fr)
- German (de)
- Italian (it)
- Korean (kr)
- Persian (fa)
- Polish (pl)
- Russian (ru)
- Spanish (es)
- Taiwanese (Taiwanese Mandarin) (zh-TW)
- Turkish (tr)
- Ukrainian (ua)
- Vietnamese (vi)If you would like to use one the languages listed above, simply set `language`
to the desired language (e.g., `fr`) in `_config.yml`.
Otherwise, you can follow the steps below (E.g., to add a Japanese (ja) translation):1. Set `language` to `ja` in Hexo configuration file `_config.yml`
2. Create a `ja.yml` file in the `themes/cactus/languages/` folder
3. Copy the content of `themes/cactus/languages/default.yml` and paste it it into the `ja.yml` file
4. Replace all English strings by their Japanese translation**Note: Cactus does not support multi-language sites.**
### RTL support
This theme support RTL languages for Persian and Arabic language.
If you would like to use RTL layout, change `direction` attribute in `_config.yml` to `rtl`.
Note that this also will change the font to [Vazir](https://github.com/rastikerdar/vazir-font), which is a Persian font.```
direction: rtl
```### RSS
Set the `rss` field in the `_config.yml` to one of the following values:
1. `rss: false` will totally disable rss (default).
2. `rss: atom.xml` sets a specific feed link.
3. `rss:`leave empty to use the [hexo-generator-feed](https://github.com/hexojs/hexo-generator-feed) plugin.### Analytics
Add you Google, Baidu, Cloudflare or Umami Analytics `tracking_id` to the `_config.yml`.
```yml
google_analytics:
enabled: true
id: 'UA-49627206-1'baidu_analytics:
enabled: true
id: 2e6da3c375c8a87f5b664cea6d4cb29ccloudflare_analytics:
enabled: true
id: 0dabb6e21848405483a237e6a7b6ed04umami_analytics:
enabled: false
id: e77e68be-f6e4-4br3-9365-2b76b57cd571
host: https://analytics.domain.com
script_name: umami.js
```### CDN
Load Javascript and CSS resources from a CDN. Enabled by default, loads all resources from [cdnjs](https://cdnjs.com/).
```yml
cdn:
enable: true
jquery: 'url'
clipboard: 'url'
font_awesome: 'url'
justified_gallery_css: 'url'
justified_gallery_js: 'url'
```Set `enable: false` to completely disable CDN and load all resources from your domain. If you want to disable it only for specific resource(s) then just remove the corresponding entry(s).
```yml
cdn:
enable: true
jquery: 'url'
```Only JQuery will be loaded from the specified CDN.
### Comments
Cactus supports two commenting systems: [Disqus](https://disqus.com) and [Utterances](https://utteranc.es).
#### Disqus
First, create a site on Disqus: [https://disqus.com/admin/create/](http://disqus.com/admin/create/).
Next, update the `_config.yml` file:
```yml
disqus:
enabled: true
shortname: SITENAME
```where `SITENAME` is the name you gave your site on Disqus.
#### Utterances
First, follow the instructions on the [oficial website](https://utteranc.es/) to setup an issue tracker Utterances will connect to.
Next, update the `_config.yml` file:
```yml
utterances:
enabled: true
repo: owner/githubrepo
issue_term: pathname
label: utteranc
theme: themename
```where each of the parameters are the respective values ​​provided during the configuration of the Utterances:
* `repo`: the repository Utterances will connect to.
* `issue_term`: the mapping between blog posts and GitHub issues.
* `label`: the label that will be assigned to issues created by Utterances
* `theme`: the selected Utterances theme.### Code Highlighting
Pick one of [the available colorschemes](https://github.com/probberechts/hexo-theme-cactus/tree/master/source/css/_highlight) and add it to the `_config.yml`:
```yml
highlight: COLORSCHEME_NAME
```### Tags and categories
Tags and categories can be included in the front-matter of your posts. For example:
```markdown
title: Tags and Categories
date: 2017-12-24 23:29:53
tags:
- Foo
- Bar
categories:
- Baz
---This post contains 2 tags and 1 category.
```You can create a page with a tag cloud by running:
```sh
$ hexo new page tags
```Next, add `type: tags` to the front-matter of `source/tags/index.md`. You can also
add a tag cloud to the home page by setting the `tags_overview` option to `true`.Similarly, you can create a page with an overview of all categories by running:
```sh
$ hexo new page categories
```and adding `type: categories` to the front-matter of `source/categories/index.md`.
Finally, don't forget to create a link to these pages, for example in the navigation menu:
```yml
nav:
tag: /tags/
category: /categories/
```### Local search
First, install the [hexo-generate-search](https://www.npmjs.com/package/hexo-generator-search)
plugin, which will generate a search index file.```git
$ npm install hexo-generator-search --save
```Next, create a page to display the search engine:
```sh
$ hexo new page search
```and put `type: search` in the front-matter.
```markdown
title: Search
type: search
---
```Finally, edit the `_config.yml` and add a link to the navigation menu.
```yml
nav:
search: /search/
```## License
MIT