hugo-theme-terminal/README.md

232 lines
8.5 KiB
Markdown
Raw Normal View History

2019-01-28 03:11:02 +03:00
# Terminal
![Terminal](https://github.com/panr/hugo-theme-terminal/blob/master/images/screenshot.png?raw=true)
### DEMO - https://hugo-terminal.now.sh/
2020-06-13 16:56:57 +03:00
<a href="https://www.buymeacoffee.com/panr" target="_blank"><img src="https://res.cloudinary.com/panr/image/upload/v1579374705/buymeacoffee_y6yvov.svg" alt="Buy Me A Coffee" ></a>
2019-03-06 03:13:31 +03:00
---
- [Features](#features)
- [Built-in shortcodes](#built-in-shortcodes)
- [Code highlighting](#code-highlighting)
- [How to start](#how-to-start)
- [How to configure](#how-to-configure)
2019-03-31 20:30:56 +03:00
- [Post archetype](#post-archetype)
2019-03-06 03:13:31 +03:00
- [Add-ons](#add-ons)
- [How to run your site](#how-to-run-your-site)
- [How to edit the theme](#how-to-edit-the-theme)
- [How to contribute](#how-to-contribute)
- [Terminal theme user?](#terminal-theme-user)
2020-01-18 21:38:49 +03:00
- [Sponsoring](#sponsoring)
2019-03-06 03:13:31 +03:00
- [Licence](#licence)
2019-01-28 03:11:02 +03:00
## Features
- **5 duetone themes**, depending on your preferences (orange is default, red, blue, green, pink)
2019-01-28 03:28:30 +03:00
- [**Fira Code**](https://github.com/tonsky/FiraCode) as default monospaced font. It's gorgeous!
- **really nice duotone**, custom syntax highlighting based on [**PrismJS**](https://prismjs.com)
2019-01-28 03:11:02 +03:00
- fully responsive
#### Built-in shortcodes
- **`image`** (prop required: **`src`**; props optional: **`alt`**, **`position`** (**left** is default | center | right), **`style`**)
- eg: `{{< image src="/img/hello.png" alt="Hello Friend" position="center" style="border-radius: 8px;" >}}`
2020-06-10 01:16:28 +03:00
- **`figure`** (same as `image`, plus few optional props: **`caption`**, **`captionPosition`** (left | **center** is default | right), **`captionStyle`**)
2019-01-28 03:11:02 +03:00
- eg: `{{< figure src="/img/hello.png" alt="Hello Friend" position="center" style="border-radius: 8px;" caption="Hello Friend!" captionPosition="right" captionStyle="color: red;" >}}`
- **`code`** (prop required: **`language`**; props optional: **`title`**, **`id`**, **`expand`** (default "△"), **`collapse`** (default "▽"), **`isCollapsed`**)
2020-06-10 01:16:28 +03:00
- eg:
```go
2020-06-18 01:21:15 +03:00
{{< code language="css" title="Really cool snippet" id="1" expand="Show" collapse="Hide" isCollapsed="true" >}}
2020-06-10 01:16:28 +03:00
pre {
background: #1a1a1d;
padding: 20px;
border-radius: 8px;
font-size: 1rem;
overflow: auto;
@media (--phone) {
white-space: pre-wrap;
word-wrap: break-word;
}
code {
background: none !important;
color: #ccc;
padding: 0;
font-size: inherit;
}
}
{{< /code >}}
```
2019-01-28 03:11:02 +03:00
#### Code highlighting
A custom syntax highlighting based on PrismJS. All you need to do is to wrap you code like this:
2019-08-08 22:56:16 +03:00
````
2019-01-28 03:11:02 +03:00
```html
// your code here
```
2019-08-08 22:56:16 +03:00
````
2019-01-28 03:11:02 +03:00
**Supported languages**: bash/shell, css, clike, javascript, apacheconf, actionscript, applescript, c, csharp, cpp, coffeescript, ruby, csp, css-extras, diff, django, docker, elixir, elm, markup-templating, erlang, fsharp, flow, git, go, graphql, less, handlebars, haskell, http, java, json, kotlin, latex, markdown, makefile, objectivec, ocaml, perl, php, php-extras, r, sql, processing, scss, python, jsx, typescript, toml, reason, textile, rust, sass, stylus, scheme, pug, swift, yaml, haml, twig, tsx, vim, visual-basic, wasm.
## How to start
You can download the theme manually by going to [https://github.com/panr/hugo-theme-terminal.git](https://github.com/panr/hugo-theme-terminal.git) and pasting it to `themes/terminal` in your root directory.
You can also clone it directly to your Hugo folder:
```
$ git clone https://github.com/panr/hugo-theme-terminal.git themes/terminal
```
If you don't want to make any radical changes, it's the best option, because you can get new updates when they are available. You can also include it as a git submodule:
```
$ git submodule add https://github.com/panr/hugo-theme-terminal.git themes/terminal
```
## How to configure
The theme doesn't require any advanced configuration. Just copy:
2020-01-06 15:34:17 +03:00
```toml
2019-01-28 03:11:02 +03:00
baseurl = "/"
languageCode = "en-us"
theme = "terminal"
paginate = 5
[params]
2020-06-17 17:55:32 +03:00
# dir name of your main content (default is `content/posts`).
# the list of set content will show up on your index page (baseurl).
2019-01-28 03:11:02 +03:00
contentTypeName = "posts"
2019-01-28 03:11:02 +03:00
# ["orange", "blue", "red", "green", "pink"]
themeColor = "orange"
2019-02-01 12:15:28 +03:00
# if you set this to 0, only submenu trigger will be visible
showMenuItems = 2
# show selector to switch language
showLanguageSelector = false
# set theme to full screen width
2019-03-02 03:13:27 +03:00
fullWidthTheme = false
# center theme with default width
2019-03-02 03:13:27 +03:00
centerTheme = false
2019-03-13 04:40:07 +03:00
# set a custom favicon (default is a `themeColor` square)
# favicon = "favicon.ico"
# set post to show the last updated
# If you use git, you can set `enableGitInfo` to `true` and then post will automatically get the last updated
showLastUpdated = false
# Provide a string as a prefix for the last update date. By default, it looks like this: 2020-xx-xx [Updated: 2020-xx-xx] :: Author
# updatedDatePrefix = "Updated"
2019-01-28 03:11:02 +03:00
# set all headings to their default size (depending on browser settings)
# it's set to `true` by default
# oneHeadingSize = false
2020-03-18 14:20:39 +03:00
[params.twitter]
# set Twitter handles for Twitter cards
# see https://developer.twitter.com/en/docs/tweets/optimize-with-cards/guides/getting-started#card-and-content-attribution
# do not include @
creator = ""
site = ""
2019-01-28 03:11:02 +03:00
[languages]
[languages.en]
2019-08-13 17:41:24 +03:00
languageName = "English"
2019-01-28 03:11:02 +03:00
title = "Terminal"
subtitle = "A simple, retro theme for Hugo"
owner = ""
2019-01-28 03:11:02 +03:00
keywords = ""
copyright = ""
2019-02-01 12:15:28 +03:00
menuMore = "Show more"
2019-01-28 03:11:02 +03:00
readMore = "Read more"
readOtherPosts = "Read other posts"
2020-05-29 01:07:58 +03:00
missingContentMessage = "Page not found..."
missingBackButtonLabel = "Back to home page"
2019-01-28 03:11:02 +03:00
[languages.en.params.logo]
2019-01-29 11:10:06 +03:00
logoText = "Terminal"
2019-01-28 03:11:02 +03:00
logoHomeLink = "/"
[languages.en.menu]
[[languages.en.menu.main]]
identifier = "about"
name = "About"
url = "/about"
[[languages.en.menu.main]]
identifier = "showcase"
name = "Showcase"
url = "/showcase"
```
2019-01-28 03:36:15 +03:00
to `config.toml` file in your Hugo root directory and change params fields. In case you need, here's [a YAML version](https://gist.github.com/panr/9eeea6f595c257febdadc11763e3a6d1).
2019-01-28 03:11:02 +03:00
2019-02-01 10:39:12 +03:00
**NOTE:** Please keep in mind that currently `main menu` doesn't support nesting.
2019-03-31 20:30:56 +03:00
## Post archetype
2019-07-27 22:23:53 +03:00
See the basic `post` file params supported by the theme — https://github.com/panr/hugo-theme-terminal/blob/master/archetypes/posts.md
2019-03-31 20:30:56 +03:00
2019-03-06 03:00:08 +03:00
## Add-ons
2019-08-08 22:56:16 +03:00
- **Comments** — for adding comments to your blog posts please take a look at `layouts/partials/comments.html` https://github.com/panr/hugo-theme-terminal/blob/master/layouts/partials/comments.html.
- **Extended Head** — please take a look at `layouts/partials/extended_head.html` https://github.com/panr/hugo-theme-terminal/blob/master/layouts/partials/extended_head.html
2019-03-06 03:00:08 +03:00
- **Extended Footer** — please take a look at `layouts/partials/extended_footer.html` https://github.com/panr/hugo-theme-terminal/blob/master/layouts/partials/extended_footer.html
2019-01-28 03:11:02 +03:00
## How to run your site
From your Hugo root directory run:
```
$ hugo server -t terminal
```
and go to `localhost:1313` in your browser. From now on all the changes you make will go live, so you don't need to refresh your browser every single time.
## How to edit the theme
2019-02-25 23:13:28 +03:00
If you have to override some of the styles, **you can do this easily** by adding `static/style.css` in your root directory and point things you want to change.
2019-01-28 18:41:56 +03:00
2019-02-01 10:39:12 +03:00
Otherwise, if you really want to edit the theme, you need to install Node dependencies. To do so, go to the theme directory (from your Hugo root directory):
2019-01-28 03:11:02 +03:00
```
$ cd themes/terminal
```
and then run:
```
$ npm install
$ npm i yarn
$ yarn
```
## How to contribute
If you spot any bugs, please use [Issue Tracker](https://github.com/panr/hugo-theme-terminal/issues) or if you want to add a new feature directly please create a new [Pull Request](https://github.com/panr/hugo-theme-terminal/pulls).
2019-03-06 03:01:50 +03:00
## Terminal theme user?
2019-03-06 03:03:29 +03:00
I'd be happy to know more about you and what you are doing. If you want to share it, please make a contribution and [add your site to the list](https://github.com/panr/hugo-theme-terminal/blob/master/USERS.md)! 🤗
2019-03-06 03:01:50 +03:00
2020-01-18 21:38:49 +03:00
## Sponsoring
If you like my work and want to support the development of the project, now you can! Just:
2020-01-18 22:13:29 +03:00
2020-01-18 22:13:03 +03:00
<a href="https://www.buymeacoffee.com/panr" target="_blank"><img src="https://res.cloudinary.com/panr/image/upload/v1579374705/buymeacoffee_y6yvov.svg" alt="Buy Me A Coffee" ></a>
2020-01-18 21:38:49 +03:00
## License
2019-01-28 03:11:02 +03:00
Copyright © 2019 Radosław Kozieł ([@panr](https://twitter.com/panr))
The theme is released under the MIT License. Check the [original theme license](https://github.com/panr/hugo-theme-terminal/blob/master/LICENSE.md) for additional licensing information.