822 lines
22 KiB
Markdown
822 lines
22 KiB
Markdown
# Zzo theme for Hugo
|
||
|
||
🚨🚨🚨최소로 지원가능한 Hugo 버전이 0.60.0으로 변경되었습니다. 이전 버전과는 다르게 아예 마크다운 렌더링 라이브러리 자체가 변경되어(blackfridy에서 goldmark로), 혹여 이전버전을 사용하고 계시다면, 최신 Hugo 버전을 설치하시는걸 권장드립니다.🚨🚨🚨
|
||
|
||
클릭해 주셔서 감사합니다. Zzo theme은 많은 기능을 지원하고있고 있습니다. 기술 블로그를 운영하기에 최적화 되어있습니다!(적어도 제생각엔...)
|
||
Zzo theme을 이용할 시 가장 매력적인 포인트 한가지는, 한글로 저와 소통할 수 있다는 점? 입니다.
|
||
|
||
## Table of contents
|
||
|
||
* [기능](#features)
|
||
* [최소 휴고 버전](#minimum-hugo-version)
|
||
* [설치](#installation)
|
||
* [업데이트](#updating)
|
||
* [예제 사이트 돌리기](#run-example-site)
|
||
* [설정](#configuration)
|
||
* [레이아웃](#layout)
|
||
* [갤러리](#gallery)
|
||
* [다국어](#multi-language)
|
||
* [커스터마이징](#customizing)
|
||
* [외부 라이브러리 사용](#external-library)
|
||
* [Shortcodes](#shortcodes)
|
||
|
||
## Features
|
||
|
||
* 다양한 스킨 지원(dark, light, solarized, hacker)
|
||
* 모바일 메뉴
|
||
* 최신 HTML5, CSS 기술 이용
|
||
* 심플한 블로그
|
||
* 검색 엔진 최적화 (SEO)
|
||
* 다국어 지원 (i18n)
|
||
* 반응형 디자인
|
||
* RSS feed 지원
|
||
* 검색 (지원 예정)
|
||
* 갤러리 지원
|
||
* 코드 하이라이트
|
||
|
||
## Minimum Hugo version
|
||
|
||
최소 요구 Hugo 버전은 0.60.0 입니다.
|
||
|
||
## Installation
|
||
|
||
우선 설정 파일을 만드셔야 합니다. 설정파일이 없거나 설정값이 잘못 될 경우, 실행이 안되실 수 있습니다.
|
||
[설정](#configuration) 링크를 참조하여 설정파일을 만들어주세요.
|
||
|
||
설정 파일을 다 만드셨으면, theme 폴더에 zzo 폴더를 만들고, 그곳에 이 레포지토리를 다운로드 하신 파일을 복사 붙여넣기 하시면 됩니다.
|
||
이렇게 파일을 복사 붙여넣기 하시면, 나중에 제가 여러가지 버그나 이슈를 업데이트 했을 때, 님이 만드신 블로그를 최신 Zzo theme으로
|
||
업데이트 하고 싶으시면 해당 Zzo theme을 지우고 다시 다운로드 한 다음, 복붙하시면 되겠습니다.
|
||
|
||
```bash
|
||
$ git clone https://github.com/zzossig/hugo-theme-zzo.git themes/zzo
|
||
```
|
||
|
||
깃헙을 이용하여 블로그를 관리하신다면, 섭모듈을 사용하여 Zzo theme을 쉽게 최신버전으로 유지하실 수 있습니다.
|
||
|
||
루트 폴더에서 다음 코드를 입력해주시면 submodule로써 Zzo theme이 설치됩니다:
|
||
|
||
```bash
|
||
git submodule add https://github.com/zzossig/hugo-theme-zzo.git themes/zzo
|
||
```
|
||
|
||
## Updating
|
||
|
||
From the root of your site:
|
||
|
||
```bash
|
||
git submodule update --remote --merge
|
||
```
|
||
|
||
## Run example site
|
||
|
||
From the root of themes/zzo/exampleSite:
|
||
|
||
```bash
|
||
hugo server --themesDir ../..
|
||
```
|
||
|
||
## Configuration
|
||
|
||
0. 저같은 경우, 디렉토리 하나를 만들고 그곳에 다음과같이 사이트를 만듭니다.
|
||
|
||
```bash
|
||
hugo new site .
|
||
```
|
||
|
||
1. 0번 단계에서 만드신 디렉토리로 들어가주세요.
|
||
config.toml 파일이 보이신다면, 과감하게 지워주세요. 아래 단계들은 제가 사용하는 config 파일들입니다.
|
||
모두 그냥 복사, 붙여넣기 해서 파일을 만드시면 되는데, 귀찮으신 분들은 exampleSite 폴더에 있는 config 폴더를
|
||
루트 디렉토리에 그냥 복사 붙여넣기 하셔도 됩니다.
|
||
|
||
아래는 설정 파일 구조구요.
|
||
|
||
```bash
|
||
root
|
||
├── config
|
||
│ ├── _default
|
||
│ │ ├── config.toml
|
||
│ │ ├── languages.toml
|
||
│ │ ├── menus.en.toml
|
||
│ │ ├── params.toml
|
||
```
|
||
|
||
2. config.toml
|
||
|
||
```bash
|
||
baseURL = "http://example.org/" # The URL of your site.
|
||
title = "Hugo Zzo Theme" # Title of your site
|
||
theme = "zzo" # Name of Zzo theme folder in `themes/`.
|
||
|
||
defaultContentLanguage = "en" # Default language to use (if you setup multilingual)
|
||
defaultContentLanguageInSubdir = true # baseURL/en/, baseURL/kr/ ...
|
||
hasCJKLanguage = true # Set `true` for Chinese/Japanese/Korean languages.
|
||
|
||
summaryLength = 70 # The length of a post description on a list page.
|
||
|
||
copyright = "©{year}, All Rights Reserved" # copyright symbol: $copy; current year: {year}
|
||
timeout = 10000
|
||
enableEmoji = true
|
||
paginate = 13 # Number of items per page in paginated lists.
|
||
rssLimit = 100
|
||
|
||
googleAnalytics = ""
|
||
|
||
[markup]
|
||
[markup.goldmark]
|
||
[markup.goldmark.renderer]
|
||
hardWraps = true
|
||
unsafe = true
|
||
xHTML = true
|
||
[markup.highlight]
|
||
codeFences = true
|
||
lineNos = true
|
||
lineNumbersInTable = true
|
||
noClasses = false
|
||
|
||
[outputs]
|
||
home = ["HTML", "RSS", "JSON", "WEBMANIFEST"]
|
||
|
||
[mediaTypes."application/manifest+json"]
|
||
suffixes = ["webmanifest"]
|
||
|
||
[outputFormats.webmanifest]
|
||
name = "webmanifest"
|
||
baseName = "webmanifest"
|
||
mediaType = "application/manifest+json"
|
||
rel = "manifest"
|
||
|
||
[taxonomies]
|
||
category = "categories"
|
||
tag = "tags"
|
||
series = "series"
|
||
```
|
||
|
||
3. languages.toml
|
||
|
||
```bash
|
||
[en]
|
||
title = "Hugo Zzo Theme"
|
||
languageName = "English"
|
||
weight = 1
|
||
|
||
[ko]
|
||
title = "Hugo Zzo Theme"
|
||
languageName = "한국어"
|
||
weight = 2
|
||
```
|
||
|
||
4. menus.en.toml
|
||
|
||
You shoud make your own menu.
|
||
|
||
```bash
|
||
[[main]]
|
||
identifier = "about"
|
||
name = "about"
|
||
url = "about"
|
||
weight = 1
|
||
|
||
[[main]]
|
||
identifier = "archive"
|
||
name = "archive"
|
||
url = "archive"
|
||
weight = 2
|
||
|
||
[[main]]
|
||
identifier = "gallery"
|
||
name = "gallery"
|
||
url = "gallery"
|
||
weight = 3
|
||
|
||
[[main]]
|
||
parent = "gallery"
|
||
name = "cartoon"
|
||
url = "gallery/cartoon"
|
||
|
||
[[main]]
|
||
parent = "gallery"
|
||
name = "photo"
|
||
url = "gallery/photo"
|
||
|
||
[[main]]
|
||
identifier = "posts"
|
||
name = "posts"
|
||
url = "posts"
|
||
weight = 4
|
||
|
||
[[main]]
|
||
identifier = "notes"
|
||
name = "notes"
|
||
url = "notes"
|
||
weight = 5
|
||
...
|
||
```
|
||
|
||
5. params.toml
|
||
|
||
```bash
|
||
logoText = "Zzo" # Logo text that appears in the site navigation bar.
|
||
description = "The Zzo theme for Hugo example site." # for SEO
|
||
custom_css = [] # custom_css = ["scss/custom.scss"] and then make file at root/assets/scss/custom.scss
|
||
custom_js = [] # custom_js = ["js/custom.js"] and then make file at root/assets/js/custom.js
|
||
|
||
# header
|
||
homeHeaderType = "text" # text, img, slide
|
||
|
||
# navbar
|
||
enableThemeChange = true # site color theme
|
||
|
||
# body
|
||
enableBreadcrumb = true # breadcrumb for list, single page
|
||
enablePhotoSwipe = true # image viewer for gallery, single page
|
||
enableSearch = true # site search with fuse
|
||
enableGoToTop = true # scroll to top
|
||
enableWhoami = true # at the end of single page
|
||
summaryShape = "classic" # card, classic, compact
|
||
archiveGroupByDate = "2006" # "2006-01": group by month, "2006": group by year
|
||
archivePaginate = 13 # items per page
|
||
paginateWindow = 1 # setting it to 1 gives 7 buttons, 2 gives 9, etc. If set 1: [1 ... 4 5 6 ... 356] [1 2 3 4 5 ... 356] etc
|
||
|
||
# whoami: usage - home page sidebar, single page bottom of post. all values can be empty
|
||
myname = "zzossig"
|
||
email = "zzossig@gmail.com"
|
||
whoami = "Web Developer"
|
||
useGravatar = false
|
||
location = "Seoul, Korea"
|
||
organization = "Hugo"
|
||
link = "https://github.com/zzossig/hugo-theme-zzo"
|
||
|
||
# sidebar
|
||
enableBio = true # home page sidebar
|
||
enableSidebar = true # Set to false to create the full width of the content.
|
||
enableSidebarTags = true # if you want to use tags.
|
||
enableSidebarSeries = true
|
||
enableSidebarCategories = true
|
||
enableToc = true # single page table of contents
|
||
enableTocSwitch = true # single page table of contents visibility switch
|
||
itemsPerCategory = 5 # maximum number of posts shown in the sidebar.
|
||
|
||
# footer
|
||
showPoweredBy = true # show footer text: Powered by Hugo and Zzo theme
|
||
showFeedLinks = true # RSS Feed
|
||
showSocialLinks = true # email, facebook, twitter ...
|
||
enableLangChange = true # show button at bottom left of footer.
|
||
themeOptions = ["dark", "light", "hacker", "solarized", "custom"] # select options for site color theme
|
||
|
||
# service
|
||
baiduAnalytics = "" # alternative of google analytics
|
||
enableBusuanzi = false # if set true, total page view, total unique visitors show up in the footer.
|
||
busuanziSiteUV = true # unique visitors (total number of visitors)
|
||
busuanziSitePV = true # site total page view count
|
||
busuanziPagePV = true # post view count
|
||
|
||
# comment
|
||
enableComment = true
|
||
disqus_shortname = ""
|
||
commento = false
|
||
|
||
[gitment] # Gitment is a comment system based on GitHub issues. see https://github.com/imsun/gitment
|
||
owner = "" # Your GitHub ID
|
||
repo = "" # The repo to store comments
|
||
clientId = "" # Your client ID
|
||
clientSecret = "" # Your client secret
|
||
|
||
[utterances] # https://utteranc.es/
|
||
owner = "" # Your GitHub ID
|
||
repo = "" # The repo to store comments
|
||
|
||
[gitalk] # Gitalk is a comment system based on GitHub issues. see https://github.com/gitalk/gitalk
|
||
owner = "" # Your GitHub ID
|
||
repo = "" # The repo to store comments
|
||
clientId = "" # Your client ID
|
||
clientSecret = "" # Your client secret
|
||
|
||
# Valine.
|
||
# You can get your appid and appkey from https://leancloud.cn
|
||
# more info please open https://valine.js.org
|
||
[valine]
|
||
enable = false
|
||
appId = '你的appId'
|
||
appKey = '你的appKey'
|
||
notify = false # mail notifier , https://github.com/xCss/Valine/wiki
|
||
verify = false # Verification code
|
||
avatar = 'mm'
|
||
placeholder = '说点什么吧...'
|
||
visitor = false
|
||
|
||
[changyan]
|
||
changyanAppid = "" # Changyan app id # 畅言
|
||
changyanAppkey = "" # Changyan app key
|
||
|
||
[livere]
|
||
livereUID = "" # LiveRe UID # 来必力
|
||
|
||
# Isso: https://posativ.org/isso/
|
||
[isso]
|
||
enable = false
|
||
scriptSrc = "" # "https://isso.example.com/js/embed.min.js"
|
||
dataAttrs = "" # "data-isso='https://isso.example.com' data-isso-require-author='true'"
|
||
|
||
[socialOptions] # if set, social icons will show up.
|
||
email = "mailto:your@email.com"
|
||
facebook = "http://example.org/"
|
||
twitter = "http://example.org/"
|
||
github = "https://github.com/zzossig/hugo-theme-zzo"
|
||
stack-overflow = ""
|
||
instagram = ""
|
||
google-plus = ""
|
||
youtube = ""
|
||
medium = ""
|
||
tumblr = ""
|
||
linkedin = ""
|
||
pinterest = ""
|
||
stack-exchange = ""
|
||
telegram = ""
|
||
steam = ""
|
||
|
||
[donationOptions]
|
||
enable = false # if set, the donation button will show up on the single page.
|
||
alipay = "" # Alipay QR Code image (example path: images/donation/alipay-qrcode.png) and put your file at root/static/images/donation/
|
||
wechat = "" # Wechat pay QR Code image (example path: same as above)
|
||
paypal = "" # Paypal URL
|
||
patreon = "" # Patreon URL
|
||
```
|
||
|
||
## Layout
|
||
|
||
### CSS grid for layout
|
||
|
||
이 프로젝트의 레이아웃은 css의 grid란 걸 사용해서 잡았습니다. 혹시나 커스터마이징 하실 때 알아야 할 수도 있을 것 같아서 알려드립니다.
|
||
|
||
### grid structure
|
||
|
||
| left | right |
|
||
|--- |--- |
|
||
| 1 | 2 |
|
||
| 3 | 4 |
|
||
| 5 | 6 |
|
||
| 7 | 8 |
|
||
|
||
* left, right column width ratio => 5 : 2
|
||
* 1 => .navbar-main
|
||
* 2 => .navbar-side
|
||
* 1 + 2 => .navbar
|
||
* 3 => .header-main
|
||
* 4 => .header-side
|
||
* 3 + 4 => .header
|
||
* 5 => .main-main
|
||
* 6 => .main-side
|
||
* 5 + 6 => .main
|
||
* 7 => .footer-main
|
||
* 8 => .footer-side
|
||
* 7 + 8 => .footer
|
||
|
||
### grid structure example applied in home page
|
||
|
||
```html
|
||
<div class="navbar"></div>
|
||
<div class="header"></div>
|
||
<div>
|
||
<div class="main-main"></div>
|
||
<div class="main-side"></div>
|
||
</div>
|
||
<div class="footer></div>
|
||
```
|
||
|
||
## Gallery
|
||
|
||
갤러리는 두가지 모두가 존재해요. 하나씩 올리거나 한번에 올리거나.
|
||
|
||
```bash
|
||
content/gallery/anygalleryname/index.md
|
||
|
||
---
|
||
title: "{{ replace .Name "-" " " | title }}"
|
||
date: {{ .Date }}
|
||
description:
|
||
type: gallery
|
||
mode: one-by-one # at-once or one-by-one
|
||
tags:
|
||
-
|
||
series:
|
||
-
|
||
categories:
|
||
-
|
||
images: # when mode is one-by-one, images front-matter variable works
|
||
- image: image1.jpg
|
||
caption: caption1
|
||
- image: image2.jpg
|
||
caption: caption2
|
||
...
|
||
---
|
||
|
||
```
|
||
|
||
갤러리를 만드시려면 우선 type을 갤러리로 하셔야 하구요, mode를 one-by-one으로 하시면 images에 이미지를 위와 같이 하나씩 입력해주셔야 해요.
|
||
그럼 이미지가 위에 적힌 순서대로 나타날거에요. mode를 at-once로 하시면, static 폴더에 있는 이미지를 전부 불러올거에요. 예를들어 위의 코드에서 mode를 at-once로 했다면,
|
||
static/gallery/anygalleryname 폴더에 있는 이미지를 전부 읽어 갤러리 페이지에 나타날 거에요.
|
||
|
||
1. Make a gallery folder under the content folder
|
||
|
||
```bash
|
||
root
|
||
├── content
|
||
│ ├── gallery
|
||
```
|
||
|
||
2. Make a sub folder under the gallery folder
|
||
|
||
```bash
|
||
root
|
||
├── content
|
||
│ ├── gallery
|
||
│ │ ├── anygalleryname
|
||
```
|
||
|
||
3. Make a index.md file under the sub folder using this command
|
||
|
||
```bash
|
||
hugo new --kind gallery gallery/anygalleryname/index.md
|
||
```
|
||
|
||
4. Put your images in static folder
|
||
|
||
```bash
|
||
root
|
||
├── static
|
||
│ ├── gallery
|
||
│ │ ├── anygalleryname
|
||
│ │ │ ├── ...your images here
|
||
```
|
||
|
||
## Multi Language
|
||
|
||
Zzo theme의 기본 언어는 영어입니다. 한국어로 바꾸시려면 다음과 같이 해주세요.
|
||
|
||
1. 우선 메뉴파일을 만듭니다.
|
||
|
||
```bash
|
||
root
|
||
├── config
|
||
│ ├── _default
|
||
│ │ ├── ...
|
||
│ │ ├── menus.ko.toml
|
||
```
|
||
|
||
```bash
|
||
config/_default/menus.ko.toml
|
||
|
||
[[main]]
|
||
identifier = "about"
|
||
name = "about"
|
||
url = "/about/"
|
||
weight = 1
|
||
|
||
[[main]]
|
||
identifier = "archive"
|
||
name = "archive"
|
||
url = "/archive/"
|
||
weight = 2
|
||
...
|
||
```
|
||
|
||
2. content 폴더에 마크다운 파일을 작성하실 때, 확장자 앞에 ko를 붙여주세요!
|
||
|
||
```bash
|
||
hugo new about/index.ko.md
|
||
hugo new posts/markdown-syntax.ko.md
|
||
...
|
||
```
|
||
|
||
3. i18n 파일을 만듭니다.
|
||
|
||
```bash
|
||
i18n/ko.toml
|
||
|
||
[search-placeholder]
|
||
other = "검색..."
|
||
|
||
[summary-dateformat]
|
||
other = "2006년 01월 02일"
|
||
|
||
[taxo-tags]
|
||
other = "태그"
|
||
|
||
...
|
||
```
|
||
|
||
4. 설정 파일에 기본언어 항목 값을 변경해줍니다.
|
||
|
||
```bash
|
||
defaultContentLanguage = "ko"
|
||
defaultContentLanguageInSubdir = true
|
||
hasCJKLanguage = true
|
||
```
|
||
|
||
## Customizing
|
||
|
||
기본적으로 theme 폴더안에 있는 내용은 안건드시는게 좋지만, 건드신다면 나중에 theme을 업데이트 하는게 복잡해 질 수도 있습니다. 현재 상태로 별로 업데이트가 필요 없다고 느끼신다면 theme에 있는 파일을 마음대로 고치셔도 됩니다. 그게 아니라면 아래에 있는 방식으로 커스터마이징 하시기를 추천드립니다.
|
||
|
||
추가로, custom css나 custom js를 아래의 방식대로 이용하시면, 페이지 로드 속도가 약간 더 느려지는 것을
|
||
발견했습니다.
|
||
|
||
### custom css
|
||
|
||
1. config 폴더의 params.toml 파일에 아래와같이 커스텀 스타일 파일을 명시해주세요.
|
||
|
||
```bash
|
||
config/_default/params.toml
|
||
|
||
...
|
||
custom_css = ["css/custom.css", "scss/custom.scss", ...]
|
||
...
|
||
```
|
||
|
||
2. 위 설정파일에 명시한 대로 실제 파일을 만들어 주세요.
|
||
|
||
```bash
|
||
assets/scss/custom.scss
|
||
assets/css/custom.css
|
||
```
|
||
|
||
3. 만약 특정 색상을 변경하고 싶으시면, 위에 만든 커스텀 스타일 파일에 해당 부분의 스타일을 오버라이드 해줘야 합니다. 예를들어 backdrop 색상을 변경하고자 하시면, 다음과 같이 해주셔야 합니다.
|
||
|
||
```css
|
||
assets/scss/custom.scss or assets/css/custom.css
|
||
|
||
...
|
||
#body {
|
||
background-color: red !important;
|
||
}
|
||
...
|
||
```
|
||
|
||
### custom js
|
||
|
||
1. config 폴더의 params.toml 파일에 아래와같이 커스텀 파일을 명시해주세요.
|
||
|
||
```bash
|
||
config/_default/params.toml
|
||
|
||
...
|
||
custom_js = ["js/custom.js", ...]
|
||
...
|
||
```
|
||
|
||
2. 실제 파일을 생성해 주시구요.
|
||
|
||
```bash
|
||
assets/js/custom.js
|
||
```
|
||
|
||
### custom skin(sub theme)
|
||
|
||
1. data폴더에 skin.toml 파일을 만들어주세요. (data/skin.toml)
|
||
|
||
2. custom_theme_primary_color항목의 값을 변경해주세요. 값의 범위는 "0" 부터 "359" 까지 입니다.
|
||
|
||
3. 변경 후, 휴고를 다시 시작해주세요. 안그러면 변경사항이 적용 안될 수도 있습니다.
|
||
|
||
### custom syntax highlighting
|
||
|
||
1. root/data 폴더에 skin.toml파일을 만들어주세요. chroma_theme항목의 값을 원하시는 코드 하이라이트 테마값으로 변경해주세요. [이 링크](https://xyproto.github.io/splash/docs/all.html)를 참조해서 값을 변경하시면 됩니다. 만약 chroma_theme 값에 - 나 _ 같은 특수문자가 있다면 지워주세요.
|
||
예를들어, solarized-dark256 값을 입력하시려면, 다음과 같이 해주세요.
|
||
|
||
```
|
||
root/data/skin.toml
|
||
|
||
chroma_theme = "solarizeddark256"
|
||
```
|
||
|
||
2. 특정 색상을 변경하고 싶으시다면, [[custom-css](#custom-css)]에서 만든 파일에 chroma class를 오버라이드 해야합니다. 잘 모르겠으면 문의주세요!
|
||
|
||
```
|
||
root/assets/scss/custom.scss
|
||
|
||
.chroma {
|
||
background-color: #123456 !important;
|
||
}
|
||
```
|
||
|
||
### custom header
|
||
|
||
홈페이지에서 헤더 부분에 4가지 종류의 헤더를 입힐 수 있습니다. 슬라이더, 이미지, 텍스트, 그리고 아무것도 입력 안하시면 빈공간이 됩니다.
|
||
|
||
1. config/_default/params.toml 설정파일에 homeHeaderType 값을 변경해주세요. 가능한 값은 slide, img, text입니다.
|
||
|
||
2. root/content/_index.md에 _index.md 파일을 만들어주세요 그리고 아래 내용을 복붙해주세요.
|
||
|
||
3. 변수의 이름만으로 의미가 전달된다고 생각합니다. 값을 하나씩 변경해보면서 원하시는 대로 커스터마이징 해주세요.
|
||
|
||
```yaml
|
||
---
|
||
header:
|
||
- type: text
|
||
height: 200
|
||
paddingX: 50
|
||
paddingY: 0
|
||
align: center
|
||
title:
|
||
- HUGO
|
||
subtitle:
|
||
- The world’s fastest framework for building websites
|
||
titleFontSize: 44
|
||
subtitleFontSize: 16
|
||
spaceBetweenTitleSubtitle: 20
|
||
|
||
- type: img
|
||
imageSrc: images/header/background.jpg # your image file path: root/static/images/header/background.jpg
|
||
imageSize: cover # auto|length|cover|contain|initial|inherit
|
||
imageRepeat: no-repeat # repeat|repeat-x|repeat-y|no-repeat|initial|inherit
|
||
imagePosition: center # x% y%| xpos ypos| left top| center bottom| ...
|
||
height: 235
|
||
paddingX: 50
|
||
paddingY: 0
|
||
align: center
|
||
title:
|
||
-
|
||
subtitle:
|
||
-
|
||
titleFontSize: 44
|
||
subtitleFontSize: 16
|
||
spaceBetweenTitleSubtitle: 20
|
||
|
||
- type: slide
|
||
height: 235
|
||
slide:
|
||
- paddingX: 50
|
||
paddingY: 0
|
||
align: left
|
||
imageSrc: images/header/background.jpg
|
||
imageSize: cover
|
||
imageRepeat: no-repeat
|
||
imagePosition: center
|
||
title:
|
||
- header title1
|
||
subtitle:
|
||
- header subtitle1
|
||
titleFontSize: 44
|
||
subtitleFontSize: 16
|
||
spaceBetweenTitleSubtitle: 20
|
||
|
||
- paddingX: 50
|
||
paddingY: 0
|
||
align: center
|
||
imageSrc: images/header/background.jpg
|
||
imageSize: cover
|
||
imageRepeat: no-repeat
|
||
imagePosition: center
|
||
title:
|
||
- header title2
|
||
subtitle:
|
||
- header subtitle2
|
||
titleFontSize: 44
|
||
subtitleFontSize: 16
|
||
spaceBetweenTitleSubtitle: 20
|
||
|
||
- paddingX: 50
|
||
paddingY: 0
|
||
align: right
|
||
imageSrc: images/header/background.jpg
|
||
imageSize: cover
|
||
imageRepeat: no-repeat
|
||
imagePosition: center
|
||
title:
|
||
- header title3
|
||
subtitle:
|
||
- header subtitle3
|
||
titleFontSize: 44
|
||
subtitleFontSize: 16
|
||
spaceBetweenTitleSubtitle: 20
|
||
---
|
||
```
|
||
|
||
### custom grid
|
||
|
||
1. 폴더에 grid.toml 파일을 만들어주세요. (data/grid.toml)
|
||
|
||
2. themes/zzo/data/grid.toml 파일에 있는 내용을 위에서 만든 파일에 복붙해주세요.
|
||
|
||
3. 원하시는 대로 값을 변경해주세요.
|
||
|
||
4. 변경 후, 휴고를 재시작 해주세요.
|
||
|
||
```toml
|
||
data/grid.toml example
|
||
|
||
grid_max_width = "960"
|
||
grid_max_unit = "px" # "px", "\"%\"" Using% is limited to using full width.
|
||
grid_main_main_width = "5"
|
||
grid_main_main_unit = "fr" # "fr", "px"
|
||
grid_main_side_width = "2"
|
||
grid_main_side_unit = "fr" # "fr", "px"
|
||
grid_column_gap_width = "32"
|
||
grid_column_gap_unit = "px" # "px"
|
||
grid_navbar_height = "50px" # "px"
|
||
grid_row_gap = "0"
|
||
```
|
||
|
||
### custom font
|
||
|
||
1. 커스텀 css 파일을 만들어주세요.
|
||
|
||
```bash
|
||
config/_default/params.toml
|
||
|
||
...
|
||
custom_css = ["css/font.css"]
|
||
...
|
||
```
|
||
|
||
2. font.css 파일에, font-face를 아래와 같이 만들어주세요.
|
||
|
||
```css
|
||
@font-face {
|
||
font-family: 'Montserrat';
|
||
src: url('../fonts/montserrat-black.woff2') format('woff2'),
|
||
url('../fonts/montserrat-black.woff') format('woff');
|
||
font-weight: 900;
|
||
font-style: normal;
|
||
}
|
||
|
||
@font-face {
|
||
font-family: 'Merriweather';
|
||
src: url('../fonts/merriweather-regular.woff2') format('woff2'),
|
||
url('../fonts/merriweather-regular.woff') format('woff');
|
||
font-weight: 400;
|
||
font-style: normal;
|
||
}
|
||
```
|
||
|
||
3. root/static/fonts/myfont.xxx 폰트 파일을 static 폴더에 넣어주세요. (If your url in step2 is ('../fonts/myfont.xxx')).
|
||
|
||
4. root/data/font.toml 에 font.toml 파일을 만들어주세요. 그리고 아래와 같이 내용을 입력해주세요.
|
||
|
||
```toml
|
||
title_font = "\"Montserrat\", sans-serif"
|
||
content_font = "\"Merriweather\", serif"
|
||
```
|
||
|
||
5. 다른 방식
|
||
|
||
root/layouts/partials/head/custom-head.html 경로에 파일을 만드시고 폰트를 그곳에서 로드해주세요.
|
||
|
||
```html
|
||
<link href="https://fonts.googleapis.com/css?family=Noto+Sans+KR:400,700&display=swap&subset=korean" rel="stylesheet">
|
||
```
|
||
|
||
## External Library
|
||
|
||
현재 지원하는 외부 라이브러리는 Katex, MathJax, Mermaid, Flowchart.js, chart.js, viz-graph, wavedrom, js-sequence-diagram 입니다. front-matter에 값을 넣어주시면 해당 라이브러리가 로드됩니다.
|
||
|
||
```bash
|
||
---
|
||
title: "{{ replace .Name "-" " " | title }}"
|
||
date: {{ .Date }}
|
||
...
|
||
libraries:
|
||
- katex
|
||
- mathjax
|
||
- chart
|
||
- flowchartjs
|
||
- msc
|
||
- katex
|
||
- mermaid
|
||
- viz
|
||
- wavedrom
|
||
---
|
||
|
||
```
|
||
|
||
## Shortcodes
|
||
|
||
### warning
|
||
|
||
```bash
|
||
{{% alert theme="info" %}}**this** is a text{{% /alert %}}
|
||
{{% alert theme="success" %}}**Yeahhh !** is a text{{% /alert %}}
|
||
{{% alert theme="warning" %}}**Be carefull** is a text{{% /alert %}}
|
||
{{% alert theme="danger" %}}**Beware !** is a text{{% /alert %}}
|
||
```
|
||
|
||
### expand
|
||
|
||
```bash
|
||
{{%expand "Expand me" %}}Good job{{% /expand%}}
|
||
```
|
||
|
||
### img
|
||
|
||
```bash
|
||
// path: static/images/whoami/avatar.jpg
|
||
{{< img src="/images/whoami/avatar.jpg" title="Image4" caption="Image description" alt="image alt" >}} // you can set width, height also
|
||
```
|
||
|
||
### notice
|
||
|
||
```bash
|
||
{{% notice note %}} # note, info, tip, warning
|
||
A notice disclaimer
|
||
{{% /notice %}}
|
||
```
|