Start work on search feature with lunr
This commit is contained in:
parent
b199d72e5f
commit
dda0a0eab1
26 changed files with 148 additions and 75 deletions
11
README.md
11
README.md
|
@ -1,7 +1,7 @@
|
||||||
# Hugo Book Theme
|
# Hugo Book Theme
|
||||||
|
|
||||||
[![Build Status](https://travis-ci.org/alex-shpak/hugo-book.svg?branch=master)](https://travis-ci.org/alex-shpak/hugo-book)
|
[![Build Status](https://travis-ci.org/alex-shpak/hugo-book.svg?branch=master)](https://travis-ci.org/alex-shpak/hugo-book)
|
||||||
[![Hugo](https://img.shields.io/badge/hugo-0.48-blue.svg)](https://gohugo.io)
|
[![Hugo](https://img.shields.io/badge/hugo-0.55-blue.svg)](https://gohugo.io)
|
||||||
[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)
|
[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)
|
||||||
|
|
||||||
### [Hugo](https://gohugo.io) documentation theme as simple as plain book
|
### [Hugo](https://gohugo.io) documentation theme as simple as plain book
|
||||||
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
|
|
||||||
- Hugo 0.48 or higher
|
- Hugo 0.55 or higher
|
||||||
- Hugo extended version, read more [here](https://gohugo.io/news/0.48-relnotes/)
|
- Hugo extended version, read more [here](https://gohugo.io/news/0.48-relnotes/)
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
|
@ -139,10 +139,6 @@ BookSection = 'docs'
|
||||||
# (Optional) This value is duplicate of $link-color for making active link highlight in menu bundle mode
|
# (Optional) This value is duplicate of $link-color for making active link highlight in menu bundle mode
|
||||||
# BookMenuBundleActiveLinkColor = '\#004ed0'
|
# BookMenuBundleActiveLinkColor = '\#004ed0'
|
||||||
|
|
||||||
# (Optional, default false) Include JS scripts in pages. Disabled by default.
|
|
||||||
# - Keep side menu on same scroll position during navigation
|
|
||||||
BookEnableJS = true
|
|
||||||
|
|
||||||
# Set source repository location.
|
# Set source repository location.
|
||||||
# Used for 'Last Modified' and 'Edit this page' links.
|
# Used for 'Last Modified' and 'Edit this page' links.
|
||||||
BookRepo = 'https://github.com/alex-shpak/hugo-book'
|
BookRepo = 'https://github.com/alex-shpak/hugo-book'
|
||||||
|
@ -156,6 +152,9 @@ BookEditPath = 'edit/master/exampleSite/content'
|
||||||
# - In git information
|
# - In git information
|
||||||
# - In blog posts
|
# - In blog posts
|
||||||
BookDateFormat = 'Jan 2, 2006'
|
BookDateFormat = 'Jan 2, 2006'
|
||||||
|
|
||||||
|
# (Optional, default true) Enables or disables search function with lunr.js
|
||||||
|
BookSearch = true
|
||||||
```
|
```
|
||||||
|
|
||||||
### Page Configuration
|
### Page Configuration
|
||||||
|
|
|
@ -137,6 +137,23 @@ ul.pagination {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.book-search {
|
||||||
|
border: 0;
|
||||||
|
border-bottom: $padding-1 solid $gray-200;
|
||||||
|
outline: none;
|
||||||
|
// padding: $padding-4 $padding-8 $padding-4 $padding-16+$padding-4;
|
||||||
|
padding: $padding-4 $padding-8 $padding-4 0;
|
||||||
|
margin-bottom: $padding-4;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
// background: url("svg/search.svg") left center no-repeat;
|
||||||
|
// background-size: $padding-16;
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
border-bottom-color: $body-font-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.book-toc {
|
.book-toc {
|
||||||
flex: 0 0 $toc-width;
|
flex: 0 0 $toc-width;
|
||||||
font-size: $font-size-12;
|
font-size: $font-size-12;
|
||||||
|
@ -211,6 +228,7 @@ aside nav,
|
||||||
@media screen and (max-width: $sm-breakpoint) {
|
@media screen and (max-width: $sm-breakpoint) {
|
||||||
.book-menu {
|
.book-menu {
|
||||||
margin-left: -$menu-width;
|
margin-left: -$menu-width;
|
||||||
|
font-size: $font-size-base;
|
||||||
}
|
}
|
||||||
|
|
||||||
.book-header {
|
.book-header {
|
||||||
|
|
41
assets/search.js
Normal file
41
assets/search.js
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
addEventListener("load", function() {
|
||||||
|
let input = document.querySelector("#book-search");
|
||||||
|
let results = document.querySelector("#book-search-results");
|
||||||
|
|
||||||
|
Promise.all([
|
||||||
|
loadScript("{{ "lunr.min.js" | relURL }}"),
|
||||||
|
loadScript("{{ "index.json" | relURL }}")
|
||||||
|
]).then(enableLunr);
|
||||||
|
|
||||||
|
function enableLunr() {
|
||||||
|
results.idx = lunr(function() {
|
||||||
|
this.ref('href')
|
||||||
|
this.field('title')
|
||||||
|
this.field('content')
|
||||||
|
|
||||||
|
window.lunrData.forEach(function (page) {
|
||||||
|
this.add(page)
|
||||||
|
}, this)
|
||||||
|
});
|
||||||
|
input.addEventListener("keyup", search);
|
||||||
|
}
|
||||||
|
|
||||||
|
function search() {
|
||||||
|
if (input.value) {
|
||||||
|
var hits = results.idx.search(`${input.value}*`);
|
||||||
|
results.innerHTML = JSON.stringify(hits);
|
||||||
|
} else {
|
||||||
|
results.innerHTML = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadScript(src) {
|
||||||
|
return new Promise(function(resolve, reject) {
|
||||||
|
let script = document.createElement('script');
|
||||||
|
script.src = src;
|
||||||
|
script.onload = () => resolve(script);
|
||||||
|
|
||||||
|
document.head.append(script);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
|
@ -14,6 +14,9 @@ enableGitInfo = true
|
||||||
# pygmentsStyle = 'monokailight'
|
# pygmentsStyle = 'monokailight'
|
||||||
pygmentsCodeFences = true
|
pygmentsCodeFences = true
|
||||||
|
|
||||||
|
[outputs]
|
||||||
|
home = ["HTML", "JSON"]
|
||||||
|
|
||||||
[params]
|
[params]
|
||||||
# (Optional, default 6) Set how many table of contents levels to be showed on page.
|
# (Optional, default 6) Set how many table of contents levels to be showed on page.
|
||||||
# Use false to hide ToC, note that 0 will default to 6 (https://gohugo.io/functions/default/)
|
# Use false to hide ToC, note that 0 will default to 6 (https://gohugo.io/functions/default/)
|
||||||
|
@ -28,13 +31,9 @@ pygmentsCodeFences = true
|
||||||
# You can also set value to '*' to render all sections to menu
|
# You can also set value to '*' to render all sections to menu
|
||||||
BookSection = 'docs'
|
BookSection = 'docs'
|
||||||
|
|
||||||
# This value is duplicate of $link-color for making active link highlight in menu bundle mode
|
# (Optional) This value is duplicate of $link-color for making active link highlight in menu bundle mode
|
||||||
# BookMenuBundleActiveLinkColor = '\#004ed0'
|
# BookMenuBundleActiveLinkColor = '\#004ed0'
|
||||||
|
|
||||||
# Include JS scripts in pages. Disabled by default.
|
|
||||||
# - Keep side menu on same scroll position during navigation
|
|
||||||
BookEnableJS = true
|
|
||||||
|
|
||||||
# Set source repository location.
|
# Set source repository location.
|
||||||
# Used for 'Last Modified' and 'Edit this page' links.
|
# Used for 'Last Modified' and 'Edit this page' links.
|
||||||
BookRepo = 'https://github.com/alex-shpak/hugo-book'
|
BookRepo = 'https://github.com/alex-shpak/hugo-book'
|
||||||
|
@ -48,3 +47,6 @@ pygmentsCodeFences = true
|
||||||
# - In git information
|
# - In git information
|
||||||
# - In blog posts
|
# - In blog posts
|
||||||
BookDateFormat = 'Jan 2, 2006'
|
BookDateFormat = 'Jan 2, 2006'
|
||||||
|
|
||||||
|
# (Optional, default true) Enables or disables search function with lunr.js
|
||||||
|
BookSearch = true
|
||||||
|
|
|
@ -28,12 +28,8 @@ params:
|
||||||
# You can also set value to '*' to render all sections to menu
|
# You can also set value to '*' to render all sections to menu
|
||||||
BookSection: docs
|
BookSection: docs
|
||||||
|
|
||||||
# This value is duplicate of $link-color for making active link highlight in menu bundle mode
|
# (Optional) This value is duplicate of $link-color for making active link highlight in menu bundle mode
|
||||||
# BookMenuBundleActiveLinkColor: \#004ed0
|
# BookMenuBundleActiveLinkColor: "\#004ed0"
|
||||||
|
|
||||||
# Include JS scripts in pages. Disabled by default.
|
|
||||||
# - Keep side menu on same scroll position during navigation
|
|
||||||
BookEnableJS: true
|
|
||||||
|
|
||||||
# Set source repository location.
|
# Set source repository location.
|
||||||
# Used for 'Last Modified' and 'Edit this page' links.
|
# Used for 'Last Modified' and 'Edit this page' links.
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
addEventListener("load",function(){let input=document.querySelector("#book-search");let results=document.querySelector("#book-search-results");Promise.all([loadScript("/example/lunr.min.js"),loadScript("/example/index.json")]).then(enableLunr);function enableLunr(){results.idx=lunr(function(){this.ref('href')
|
||||||
|
this.field('title')
|
||||||
|
this.field('content')
|
||||||
|
window.lunrData.forEach(function(page){this.add(page)},this)});input.addEventListener("keyup",search);}
|
||||||
|
function search(){if(input.value){var hits=results.idx.search(`${input.value}*`);results.innerHTML=JSON.stringify(hits);}else{results.innerHTML='';}}
|
||||||
|
function loadScript(src){return new Promise(function(resolve,reject){let script=document.createElement('script');script.src=src;script.onload=()=>resolve(script);document.head.append(script);});}});
|
|
@ -0,0 +1 @@
|
||||||
|
{"Target":"search.min.f37565c4baa28364f7b8e1e53c35bdb0ab92f2215165bd3f083f3f4f1ae78c71.js","MediaType":"application/javascript","Data":{"Integrity":"sha256-83VlxLqig2T3uOHlPDW9sKuS8iFRZb0/CD8/TxrnjHE="}}
|
File diff suppressed because one or more lines are too long
|
@ -1 +1 @@
|
||||||
{"Target":"book.min.f4161f5e2de53a2e927f51df1611323a2a12cccb2681f23cb6fc3517852e8643.css","MediaType":"text/css","Data":{"Integrity":"sha256-9BYfXi3lOi6Sf1HfFhEyOioSzMsmgfI8tvw1F4UuhkM="}}
|
{"Target":"book.min.60422b170f7beee5a981f3288523ee2bf275a0b48eba3a8983a3736189b9027f.css","MediaType":"text/css","Data":{"Integrity":"sha256-YEIrFw977uWpgfMohSPuK/J1oLSOujqJg6NzYYm5An8="}}
|
|
@ -1,5 +1,4 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
{{- partial "docs/shared" -}}
|
|
||||||
<html lang="{{ .Site.Language.Lang }}">
|
<html lang="{{ .Site.Language.Lang }}">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
{{- partial "docs/shared" -}}
|
|
||||||
<html lang="{{ .Site.Language.Lang }}">
|
<html lang="{{ .Site.Language.Lang }}">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
{{- partial "docs/shared" -}}
|
|
||||||
<html lang="{{ .Site.Language.Lang }}">
|
<html lang="{{ .Site.Language.Lang }}">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
|
|
10
layouts/home.json
Normal file
10
layouts/home.json
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
window.lunrData = [
|
||||||
|
{{ range $index, $page := .Site.Pages }}
|
||||||
|
{{- if and $index (gt $index 0) -}},{{- end }}
|
||||||
|
{
|
||||||
|
"href": "{{ $page.RelPermalink }}",
|
||||||
|
"title": "{{ htmlEscape $page.Title }}",
|
||||||
|
"content": {{ $page.Plain | jsonify }}
|
||||||
|
}
|
||||||
|
{{- end -}}
|
||||||
|
]
|
|
@ -1,3 +1,3 @@
|
||||||
<h2 class="book-brand">
|
<h2 class="book-brand">
|
||||||
<a href="{{ .Site.BaseURL }}">{{ .Site.Title }}</a>
|
<a href="{{ .Site.BaseURL }}">{{ .Site.Title }}</a>
|
||||||
</h2>
|
</h2>
|
||||||
|
|
|
@ -1,11 +1,14 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>{{- template "title" . }} | {{ .Site.Title -}}</title>
|
<title>{{ partial "docs/title" . }} | {{ .Site.Title -}}</title>
|
||||||
|
|
||||||
<!-- Theme stylesheet, you can customize scss by creatig `assets/custom.scss` in your website -->
|
<!-- Theme stylesheet, you can customize scss by creating `assets/custom.scss` in your website -->
|
||||||
{{ $styles := resources.Get "book.scss" | resources.ToCSS | resources.Minify | resources.Fingerprint }}
|
{{- $styles := resources.Get "book.scss" | resources.ToCSS | resources.Minify | resources.Fingerprint }}
|
||||||
<link rel="stylesheet" href="{{ $styles.RelPermalink }}">
|
<link rel="stylesheet" href="{{ $styles.RelPermalink }}">
|
||||||
|
|
||||||
|
{{- $search := resources.Get "search.js" | resources.ExecuteAsTemplate "search.js" . | resources.Minify | resources.Fingerprint }}
|
||||||
|
<script src="{{ $search.RelPermalink }}"></script>
|
||||||
|
|
||||||
<!-- Favicon -->
|
<!-- Favicon -->
|
||||||
<link rel="icon" href="{{ "favicon.png" | relURL }}" type="image/x-icon">
|
<link rel="icon" href="{{ "favicon.png" | relURL }}" type="image/x-icon">
|
||||||
|
|
||||||
|
|
|
@ -2,3 +2,18 @@
|
||||||
{{ with .Site.GetPage .Site.Params.BookMenuBundle }}
|
{{ with .Site.GetPage .Site.Params.BookMenuBundle }}
|
||||||
{{- .Content -}}
|
{{- .Content -}}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
|
{{ define "hrefhack" }}
|
||||||
|
{{ $attrEq := "$=" }}
|
||||||
|
{{ $attrVal := .RelPermalink }}
|
||||||
|
{{ if eq .RelPermalink "/" }}
|
||||||
|
{{ $attrEq = "=" }}
|
||||||
|
{{ $attrVal = .Permalink }}
|
||||||
|
{{ end }}
|
||||||
|
|
||||||
|
<style>
|
||||||
|
nav ul a[href{{ $attrEq }}"{{ $attrVal }}"] {
|
||||||
|
color: {{ default "#004ed0" .Site.Params.BookMenuBundleActiveLinkColor }};
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
{{ end }}
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
{{ if .Content }}
|
{{ if .Content }}
|
||||||
{{ template "book-page-link" (dict "Page" . "CurrentPage" $.CurrentPage) }}
|
{{ template "book-page-link" (dict "Page" . "CurrentPage" $.CurrentPage) }}
|
||||||
{{ else }}
|
{{ else }}
|
||||||
<span>{{ template "title" . }}</span>
|
<span>{{ partial "docs/title" . }}</span>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
||||||
{{ template "book-section-children" (dict "Section" . "CurrentPage" $.CurrentPage) }}
|
{{ template "book-section-children" (dict "Section" . "CurrentPage" $.CurrentPage) }}
|
||||||
|
@ -53,7 +53,7 @@
|
||||||
{{ define "book-page-link" }}
|
{{ define "book-page-link" }}
|
||||||
{{ with .Page }}
|
{{ with .Page }}
|
||||||
<a href="{{ .RelPermalink }}" {{ if eq $.CurrentPage .Permalink }} class="active"{{ end }}>
|
<a href="{{ .RelPermalink }}" {{ if eq $.CurrentPage .Permalink }} class="active"{{ end }}>
|
||||||
{{ template "title" . }}
|
{{ partial "docs/title" . }}
|
||||||
</a>
|
</a>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
<nav>
|
<nav>
|
||||||
{{ partial "docs/brand" . }}
|
{{ partial "docs/brand" . }}
|
||||||
|
{{ partial "docs/search" . }}
|
||||||
{{ partial "docs/inject/menu-before" . }}
|
{{ partial "docs/inject/menu-before" . }}
|
||||||
|
|
||||||
{{ if .Site.Params.BookMenuBundle }}
|
{{ if .Site.Params.BookMenuBundle }}
|
||||||
|
@ -11,6 +12,13 @@
|
||||||
{{ partial "docs/inject/menu-after" . }}
|
{{ partial "docs/inject/menu-after" . }}
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
{{ if .Site.Params.BookEnableJS }}
|
<!-- Restore menu position as soon as possible to avoid flickering -->
|
||||||
{{ template "jsmenu" . }}
|
<script>
|
||||||
{{ end }}
|
(function() {
|
||||||
|
var menu = document.querySelector("aside.book-menu nav");
|
||||||
|
addEventListener("beforeunload", function(event) {
|
||||||
|
localStorage.setItem("menu.scrollTop", menu.scrollTop);
|
||||||
|
});
|
||||||
|
menu.scrollTop = localStorage.getItem("menu.scrollTop");
|
||||||
|
})();
|
||||||
|
</script>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<header class="align-center justify-between book-header">
|
<header class="flex align-center justify-between book-header">
|
||||||
<label for="menu-control">
|
<label for="menu-control">
|
||||||
<img src="{{ "svg/menu.svg" | relURL }}" alt="Menu" />
|
<img src="{{ "svg/menu.svg" | relURL }}" alt="Menu" />
|
||||||
</label>
|
</label>
|
||||||
<strong>{{- template "title" . }}</strong>
|
<strong>{{ partial "docs/title" . }}</strong>
|
||||||
</header>
|
</header>
|
||||||
|
|
2
layouts/partials/docs/search.html
Normal file
2
layouts/partials/docs/search.html
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
<input type="text" placeholder="Search" class="book-search" id="book-search" />
|
||||||
|
<ul id="book-search-results"></ul>
|
|
@ -1,40 +0,0 @@
|
||||||
{{/*These templates contains some more complex logic and shared between partials*/}}
|
|
||||||
{{ define "title" }}
|
|
||||||
{{ if and .IsSection .File }}
|
|
||||||
{{ $sections := split (trim .File.Dir "/") "/" }}
|
|
||||||
{{ $title := index ($sections | last 1) 0 | humanize | title }}
|
|
||||||
{{ default $title .Title }}
|
|
||||||
{{ else if and .IsPage .File }}
|
|
||||||
{{ $title := .File.BaseFileName | humanize | title }}
|
|
||||||
{{ default $title .Title }}
|
|
||||||
{{ else }}
|
|
||||||
{{ .Title }}
|
|
||||||
{{ end }}
|
|
||||||
{{ end }}
|
|
||||||
|
|
||||||
{{ define "hrefhack" }}
|
|
||||||
{{ $attrEq := "$=" }}
|
|
||||||
{{ $attrVal := .RelPermalink }}
|
|
||||||
{{ if eq .RelPermalink "/" }}
|
|
||||||
{{ $attrEq = "=" }}
|
|
||||||
{{ $attrVal = .Permalink }}
|
|
||||||
{{ end }}
|
|
||||||
|
|
||||||
<style>
|
|
||||||
nav ul a[href{{ $attrEq }}"{{ $attrVal }}"] {
|
|
||||||
color: {{ default "#004ed0" .Site.Params.BookMenuBundleActiveLinkColor }};
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
{{ end }}
|
|
||||||
|
|
||||||
{{ define "jsmenu" }}
|
|
||||||
<script>
|
|
||||||
(function() {
|
|
||||||
var menu = document.querySelector('aside.book-menu nav')
|
|
||||||
addEventListener('beforeunload', function(event) {
|
|
||||||
localStorage.setItem('menu.scrollTop', menu.scrollTop)
|
|
||||||
});
|
|
||||||
menu.scrollTop = localStorage.getItem('menu.scrollTop')
|
|
||||||
})()
|
|
||||||
</script>
|
|
||||||
{{ end }}
|
|
9
layouts/partials/docs/title.html
Normal file
9
layouts/partials/docs/title.html
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
{{ $title := .Title }}
|
||||||
|
{{ if and .IsSection .File }}
|
||||||
|
{{ $sections := split (trim .File.Dir "/") "/" }}
|
||||||
|
{{ $title = index ($sections | last 1) 0 | humanize | title }}
|
||||||
|
{{ else if and .IsPage .File }}
|
||||||
|
{{ $title = .File.BaseFileName | humanize | title }}
|
||||||
|
{{ end }}
|
||||||
|
|
||||||
|
{{ return $title }}
|
|
@ -1,5 +1,4 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
{{- partial "docs/shared" -}}
|
|
||||||
<html lang="{{ .Site.Language.Lang }}">
|
<html lang="{{ .Site.Language.Lang }}">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
|
|
6
static/lunr.min.js
vendored
Normal file
6
static/lunr.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
static/svg/search.svg
Normal file
1
static/svg/search.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/><path d="M0 0h24v24H0z" fill="none"/></svg>
|
After Width: | Height: | Size: 372 B |
|
@ -8,7 +8,7 @@ description = "Hugo documentation theme as simple as plain book"
|
||||||
homepage = "https://github.com/alex-shpak/hugo-book"
|
homepage = "https://github.com/alex-shpak/hugo-book"
|
||||||
tags = ["responsive", "clean", "documentation", "docs", "flexbox"]
|
tags = ["responsive", "clean", "documentation", "docs", "flexbox"]
|
||||||
features = []
|
features = []
|
||||||
min_version = "0.48"
|
min_version = "0.55"
|
||||||
|
|
||||||
[author]
|
[author]
|
||||||
name = "Alex Shpak"
|
name = "Alex Shpak"
|
||||||
|
|
Loading…
Reference in a new issue