Compare commits
3 commits
main
...
html-proof
Author | SHA1 | Date | |
---|---|---|---|
|
7691a4692e | ||
|
b22c606137 | ||
|
0a84f2773a |
126 changed files with 1483 additions and 4798 deletions
6
.github/workflows/autoprefixer.yml
vendored
6
.github/workflows/autoprefixer.yml
vendored
|
@ -8,12 +8,12 @@ jobs:
|
|||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout to latest commit
|
||||
uses: actions/checkout@v4.2.2
|
||||
uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Setup Node
|
||||
uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: "20.x"
|
||||
node-version: "15.x"
|
||||
|
||||
- name: Run autoprefixer
|
||||
run: |
|
||||
|
@ -21,7 +21,7 @@ jobs:
|
|||
npm run autoprefixer
|
||||
|
||||
- name: Create Pull Request
|
||||
uses: peter-evans/create-pull-request@v7
|
||||
uses: peter-evans/create-pull-request@v5
|
||||
with:
|
||||
branch: autoprefixer
|
||||
branch-suffix: timestamp
|
||||
|
|
2
.github/workflows/codeql-analysis.yml
vendored
2
.github/workflows/codeql-analysis.yml
vendored
|
@ -39,7 +39,7 @@ jobs:
|
|||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4.2.2
|
||||
uses: actions/checkout@v4.1.1
|
||||
|
||||
# Initializes the CodeQL tools for scanning.
|
||||
- name: Initialize CodeQL
|
||||
|
|
16
.github/workflows/enforce-lablel.yml
vendored
16
.github/workflows/enforce-lablel.yml
vendored
|
@ -1,16 +0,0 @@
|
|||
name: Label Enforcer
|
||||
|
||||
# Run action on pull request creation, reopening, or label changes
|
||||
on:
|
||||
pull_request:
|
||||
types: [opened, reopened, labeled, unlabeled]
|
||||
|
||||
jobs:
|
||||
# Ensure that PR has desired labels
|
||||
enforce-label:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: yogevbd/enforce-label-action@2.2.2
|
||||
with:
|
||||
REQUIRED_LABELS_ANY: "automerge,breaking-change,bug-fix,enhancement,feature,translation"
|
||||
REQUIRED_LABELS_ANY_DESCRIPTION: "The PR must have at least one these labels: ['automerge','breaking-change','bug-fix','enhancement','feature','translation']"
|
2
.github/workflows/merge-to-main.yml
vendored
2
.github/workflows/merge-to-main.yml
vendored
|
@ -10,6 +10,6 @@ jobs:
|
|||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
# Create/Update release draft
|
||||
- uses: release-drafter/release-drafter@v6.1.0
|
||||
- uses: release-drafter/release-drafter@v5.25.0
|
||||
env:
|
||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
|
57
.github/workflows/pull-request.yml
vendored
57
.github/workflows/pull-request.yml
vendored
|
@ -10,18 +10,18 @@ jobs:
|
|||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
# checkout to the commit that has been pushed
|
||||
- uses: actions/checkout@v4.2.2
|
||||
- uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Setup Node
|
||||
uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 20
|
||||
node-version: 18
|
||||
|
||||
- name: Install node modules
|
||||
run: npm install
|
||||
|
||||
- name: Setup Hugo
|
||||
uses: peaceiris/actions-hugo@v3.0.0
|
||||
uses: peaceiris/actions-hugo@v2.6.0
|
||||
with:
|
||||
hugo-version: 'latest'
|
||||
extended: true
|
||||
|
@ -35,12 +35,12 @@ jobs:
|
|||
lint:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4.2.2
|
||||
- uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Setup Node
|
||||
uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 20
|
||||
node-version: 18
|
||||
|
||||
- name: Install node modules
|
||||
run: npm install
|
||||
|
@ -62,7 +62,7 @@ jobs:
|
|||
NETLIFY_TOKEN: ${{secrets.NETLIFY_TOKEN}}
|
||||
|
||||
- name: Run Lighthouse
|
||||
uses: foo-software/lighthouse-check-action@v12.0.1
|
||||
uses: foo-software/lighthouse-check-action@v10.0.0
|
||||
id: lighthouseCheck
|
||||
with:
|
||||
accessToken: ${{ secrets.LIGHTHOUSE_TOKEN }}
|
||||
|
@ -73,11 +73,52 @@ jobs:
|
|||
timeout: 5
|
||||
urls: "${{ steps.preview.outputs.url }},${{ steps.preview.outputs.url }}/posts/,${{ steps.preview.outputs.url }}/posts/markdown-sample/,${{ steps.preview.outputs.url }}/posts/shortcodes/"
|
||||
|
||||
# Ensure that PR has desired labels
|
||||
enforce-label:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: yogevbd/enforce-label-action@2.2.2
|
||||
with:
|
||||
REQUIRED_LABELS_ANY: "automerge,breaking-change,bug-fix,enhancement,feature,translation"
|
||||
REQUIRED_LABELS_ANY_DESCRIPTION: "The PR must have at least one these labels: ['automerge','breaking-change','bug-fix','enhancement','feature','translation']"
|
||||
|
||||
# Check for any broken links
|
||||
markdown-link-check:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
# checkout to latest commit
|
||||
- uses: actions/checkout@v4.2.2
|
||||
- uses: actions/checkout@v4.1.1
|
||||
# run markdown linter
|
||||
- uses: gaurav-nelson/github-action-markdown-link-check@1.0.17
|
||||
- uses: gaurav-nelson/github-action-markdown-link-check@1.0.15
|
||||
|
||||
proof-html:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
# checkout to the commit that has been pushed
|
||||
- uses: actions/checkout@v4.1.1
|
||||
|
||||
- name: Setup Node
|
||||
uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 18
|
||||
|
||||
- name: Install node modules
|
||||
run: npm install
|
||||
|
||||
- name: Setup Hugo
|
||||
uses: peaceiris/actions-hugo@v2.6.0
|
||||
with:
|
||||
hugo-version: 'latest'
|
||||
extended: true
|
||||
|
||||
- name: Build
|
||||
run: |
|
||||
cd exampleSite
|
||||
hugo --minify
|
||||
|
||||
# Run HTML Proofer
|
||||
- uses: anishathalye/proof-html@v2.1.2
|
||||
with:
|
||||
directory: exampleSite/public
|
||||
enforce_https: false
|
||||
ignore_url: "#"
|
||||
|
|
100
README.md
100
README.md
|
@ -1,6 +1,3 @@
|
|||
> [!IMPORTANT]
|
||||
> If you are migrating from v3 (`git submodule` based) theme to v4 (`hugo modules` based) theme, please read this [migration guide](https://toha-guides.netlify.app/posts/update-v3-to-v4/).
|
||||
|
||||
# Toha
|
||||
|
||||
[](https://app.netlify.com/sites/toha/deploys)
|
||||
|
@ -38,7 +35,6 @@ A [Hugo](https://gohugo.io/) theme for a personal portfolio with minimalist desi
|
|||
- counter.dev
|
||||
- Google Analytics
|
||||
- Matomo/Piwik
|
||||
- [Umami](https://umami.is/)
|
||||
- Comment Support
|
||||
- [Disqus](https://disqus.com/)
|
||||
- [Valine](https://valine.js.org/)
|
||||
|
@ -56,7 +52,6 @@ For more details about the features please visit [here](https://toha-guides.netl
|
|||
- Deutsch
|
||||
- Español
|
||||
- 简体中文
|
||||
- 繁體中文
|
||||
- हिन्दी
|
||||
- Italiano
|
||||
- 日本語
|
||||
|
@ -64,14 +59,11 @@ For more details about the features please visit [here](https://toha-guides.netl
|
|||
- русский
|
||||
- suomi
|
||||
- Tiếng Việt
|
||||
- Azerbaijan
|
||||
- Turkish
|
||||
- Arabic (العربية)
|
||||
- Português Europeu
|
||||
- Català
|
||||
- Português Brasileiro
|
||||
- Nederlands
|
||||
- Hebrew
|
||||
|
||||
To know more about how to translate your site, please visit [here](https://toha-guides.netlify.app/posts/translation/). Follow, the data and post format from this [example site](https://hugo-toha.github.io).
|
||||
|
||||
|
@ -93,7 +85,7 @@ Here are few screenshots from the [example site](https://hugo-toha.github.io).
|
|||
|
||||
## Requirements
|
||||
|
||||
- Hugo Version 0.128.0 (extended) or higher
|
||||
- Hugo Version 0.118.0 (extended) or higher
|
||||
- Go language 1.18 or higher (require for hugo modules)
|
||||
- Node version v18.x or later and npm 8.x or later.
|
||||
|
||||
|
@ -113,7 +105,7 @@ hugo mod init github.com/<your username>/<your repo name>
|
|||
|
||||
##### 2. Add this theme as your module dependency
|
||||
|
||||
Now, in your `hugo.yaml` file, add a `module` section.
|
||||
Now, in your `config.yaml` file, add a `module` section.
|
||||
|
||||
```yaml
|
||||
# Use Hugo modules to add theme
|
||||
|
@ -122,7 +114,7 @@ module:
|
|||
- path: github.com/hugo-toha/toha/v4
|
||||
```
|
||||
|
||||
Check this sample [hugo.yaml](https://github.com/hugo-toha/hugo-toha.github.io/blob/main/hugo.yaml) for further reference.
|
||||
Check this sample [config.yaml](https://github.com/hugo-toha/hugo-toha.github.io/blob/main/config.yaml) for further reference.
|
||||
|
||||
##### 3. Update your module
|
||||
|
||||
|
@ -193,72 +185,34 @@ For local development, you can make changes in the theme submodule and test the
|
|||
|
||||
At first, fork [this repo](https://github.com/hugo-toha/toha). Then, follow the following steps to use the forked theme for local developments,
|
||||
|
||||
#### Running the forked theme against the example site
|
||||
**Using the forked theme in your own site:**
|
||||
|
||||
If you want to run your local development against your own site, follow the following steps:
|
||||
|
||||
```bash
|
||||
# add the original theme as a submodule of your site if you haven't done already
|
||||
$ git submodule add https://github.com/hugo-toha/toha.git themes/toha
|
||||
# navigate into the toha theme folder
|
||||
$ cd themes/toha
|
||||
# add your own fork as a remote
|
||||
$ git remote add my-fork https://github.com/<your-github-user>/toha
|
||||
# create a new branch for your changes
|
||||
$ git checkout -b my-feature-branch
|
||||
```
|
||||
|
||||
**Using the forked theme in the example site:**
|
||||
|
||||
If your want to run your local development against this [example site](https://github.com/hugo-toha/hugo-toha.github.io), follow the following steps:
|
||||
|
||||
```bash
|
||||
# go to exampleSite directory
|
||||
$ cd exampleSite
|
||||
# install hugo modules
|
||||
$ hugo mod tidy
|
||||
# install dependencies
|
||||
$ hugo mod npm pack
|
||||
$ npm install
|
||||
# run the example site locally
|
||||
$ hugo server -w
|
||||
```
|
||||
|
||||
Now, you can make change in the theme and they will be reflected immediately on the running site. If you need to change any configuration, you can do that in the `hugo.yaml` file inside `exampleSite` folder. If you need to add any content or data, you can create the respective folder inside `exampleSite` directory and add your desired content or data there.
|
||||
|
||||
#### Running the forked theme against your own site
|
||||
|
||||
If you want to run your local development against your own site, follow the following steps:
|
||||
|
||||
**Replace the theme module:**
|
||||
|
||||
Open your site's `go.mod` file and replace the `github.com/hugo-toha/toha/v4` with your forked repo's path. For example, if your forked repo is `github.com/<your-github-user>/toha`, then replace the `github.com/hugo-toha/toha/v4` with `github.com/<your-github-user>/toha/v4`.
|
||||
|
||||
```go
|
||||
module github.com/hugo-toha/hugo-toha.github.io
|
||||
|
||||
go 1.19
|
||||
|
||||
require github.com/hugo-toha/toha/v4 v4.0.1-0.20231229170427-d3968ca711ef // indirect
|
||||
|
||||
replace(
|
||||
github.com/hugo-toha/toha/v4 => github.com/<your-github-user>/toha/v4 <git branch>
|
||||
)
|
||||
```
|
||||
|
||||
For interactive development, you can replace the theme with your locally cloned fork. For example, if you have cloned your fork in `/home/my-projects/toha`, then replace the `github.com/hugo-toha/toha/v4` with `/home/my-projects/toha`.
|
||||
|
||||
```go
|
||||
module github.com/hugo-toha/hugo-toha.github.io
|
||||
|
||||
go 1.19
|
||||
|
||||
require github.com/hugo-toha/toha/v4 v4.0.1-0.20231229170427-d3968ca711ef // indirect
|
||||
|
||||
replace(
|
||||
github.com/hugo-toha/toha/v4 => /home/my-projects/toha
|
||||
)
|
||||
```
|
||||
|
||||
**Update dependencies:**
|
||||
|
||||
```bash
|
||||
# update hugo modules
|
||||
$ hugo mod tidy
|
||||
# install dependencies
|
||||
$ hugo mod npm pack
|
||||
$ npm install
|
||||
```
|
||||
|
||||
**Run your site locally:**
|
||||
|
||||
```bash
|
||||
$ hugo server -w
|
||||
# clone the example site along with the submodules
|
||||
$ git clone git@github.com:hugo-toha/hugo-toha.github.io.git --recursive
|
||||
# navigate into the toha theme folder
|
||||
$ cd themes/toha
|
||||
# add your own fork as a remote
|
||||
$ git remote add my-fork https://github.com/<your-github-user>/toha
|
||||
# create a new branch for your changes
|
||||
$ git checkout -b my-feature-branch
|
||||
```
|
||||
|
||||
From there you can make changes to the source code of the theme while testing with your running Hugo site or the example site.
|
||||
|
|
|
@ -1,9 +0,0 @@
|
|||
let theme = localStorage.getItem('theme-scheme') || localStorage.getItem('darkmode:color-scheme') || 'light'
|
||||
if (theme === 'system') {
|
||||
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
||||
theme = 'dark'
|
||||
} else {
|
||||
theme = 'light'
|
||||
}
|
||||
}
|
||||
document.documentElement.setAttribute('data-theme', theme)
|
|
@ -1,22 +0,0 @@
|
|||
addCopyButtons(navigator.clipboard)
|
||||
|
||||
function addCopyButtons(clipboard) {
|
||||
document.querySelectorAll('pre > code').forEach(function (codeBlock) {
|
||||
const button = document.createElement('button')
|
||||
button.title = "Copy"
|
||||
button.className = 'copy-code-button btn btn-sm'
|
||||
button.innerHTML = "<i class='fa-regular fa-copy'></i>"
|
||||
|
||||
button.addEventListener('click', function () {
|
||||
clipboard.writeText(codeBlock.innerText)
|
||||
})
|
||||
|
||||
const pre = codeBlock.parentNode
|
||||
if (pre.parentNode.classList.contains('highlight')) {
|
||||
const highlight = pre.parentNode
|
||||
highlight.parentNode.insertBefore(button, highlight)
|
||||
} else {
|
||||
pre.parentNode.insertBefore(button, pre)
|
||||
}
|
||||
})
|
||||
}
|
|
@ -1 +0,0 @@
|
|||
import './copyCode'
|
|
@ -39,8 +39,6 @@ window.addEventListener('load', async () => {
|
|||
|
||||
// save preference to local storage
|
||||
saveScheme(newScheme)
|
||||
|
||||
setImages(theme)
|
||||
}
|
||||
|
||||
setScheme(loadScheme())
|
||||
|
@ -52,19 +50,3 @@ window.addEventListener('load', async () => {
|
|||
})
|
||||
})
|
||||
})
|
||||
|
||||
function setImages(newScheme) {
|
||||
const els = Array.from(document.getElementsByClassName('logo-holder'));
|
||||
for (const el of els) {
|
||||
const light = el.querySelector('.light-logo');
|
||||
const dark = el.querySelector('.dark-logo');
|
||||
if (newScheme === "dark" && dark !== null) {
|
||||
if (light !== null) light.style.display = 'none'
|
||||
dark.style.display = 'inline'
|
||||
}
|
||||
else {
|
||||
if (light !== null) light.style.display = 'inline'
|
||||
if (dark !== null) dark.style.display = 'none'
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -10,10 +10,6 @@ if (process.env.FEATURE_DARKMODE === '1') {
|
|||
import('./darkmode')
|
||||
}
|
||||
|
||||
if (process.env.FEATURE_THEME === '1') {
|
||||
import('./theme')
|
||||
}
|
||||
|
||||
if (process.env.FEATURE_FLOWCHART === '1') {
|
||||
import('./flowchart')
|
||||
}
|
||||
|
@ -29,7 +25,3 @@ if (process.env.FEATURE_MATH === '1') {
|
|||
if (process.env.FEATURE_EMBEDPDF === '1') {
|
||||
import('./embedpdf')
|
||||
}
|
||||
|
||||
if (process.env.FEATURE_COPYCODEBUTTON === '1') {
|
||||
import('./copyCode')
|
||||
}
|
||||
|
|
|
@ -1,88 +0,0 @@
|
|||
import * as params from '@params';
|
||||
const PERSISTENCE_KEY = 'theme-scheme'
|
||||
|
||||
const themeOptions = params.theme || {}
|
||||
const THEME_DARK = typeof themeOptions.dark === 'undefined' ? true : themeOptions.dark;
|
||||
const THEME_LIGHT = typeof themeOptions.light === 'undefined' ? true : themeOptions.light;
|
||||
const THEME_DEFAULT = typeof themeOptions.default === 'undefined' ? "system" : themeOptions.default;
|
||||
|
||||
window.addEventListener('load', async () => {
|
||||
const menu = document.getElementById('themeMenu')
|
||||
const $icon = document.getElementById('navbar-theme-icon-svg')
|
||||
if (menu == null || $icon == null) return
|
||||
|
||||
const btns = menu.getElementsByTagName('a')
|
||||
const iconMap = Array.from(btns).reduce((map, btn) => {
|
||||
const $img = btn.getElementsByTagName('img')[0]
|
||||
map[btn.dataset.scheme] = $img.src
|
||||
return map
|
||||
}, {})
|
||||
|
||||
|
||||
function checkScheme(scheme) {
|
||||
if (THEME_LIGHT === false) return "dark"
|
||||
if (THEME_DARK === false) return "light"
|
||||
return scheme
|
||||
}
|
||||
|
||||
function loadScheme() {
|
||||
return localStorage.getItem(PERSISTENCE_KEY) || loadDefaultScheme()
|
||||
}
|
||||
|
||||
function loadDefaultScheme() {
|
||||
return THEME_DEFAULT || "system"
|
||||
}
|
||||
|
||||
function saveScheme(scheme) {
|
||||
localStorage.setItem(PERSISTENCE_KEY, scheme)
|
||||
}
|
||||
|
||||
function getPreferredColorScheme() {
|
||||
const isDarkMode = window.matchMedia("(prefers-color-scheme: dark)").matches;
|
||||
return isDarkMode ? "dark" : "light";
|
||||
}
|
||||
|
||||
function setScheme(newScheme) {
|
||||
let theme = newScheme
|
||||
if (newScheme === 'system') {
|
||||
theme = getPreferredColorScheme()
|
||||
}
|
||||
// set data-theme attribute on html tag
|
||||
document.querySelector("html").dataset.theme = theme;
|
||||
|
||||
// update icon
|
||||
$icon.src = iconMap[newScheme]
|
||||
|
||||
// save preference to local storage
|
||||
saveScheme(newScheme)
|
||||
|
||||
setImages(theme)
|
||||
}
|
||||
|
||||
const checkedScheme = checkScheme(loadScheme())
|
||||
setScheme(checkedScheme)
|
||||
|
||||
Array.from(menu.getElementsByTagName('a')).forEach((btn) => {
|
||||
btn.addEventListener('click', () => {
|
||||
const { scheme } = btn.dataset
|
||||
setScheme(scheme)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
function setImages(newScheme) {
|
||||
const els = Array.from(document.getElementsByClassName('logo-holder'));
|
||||
for (const el of els) {
|
||||
const light = el.querySelector('.light-logo');
|
||||
const dark = el.querySelector('.dark-logo');
|
||||
|
||||
if (newScheme === "dark" && dark !== null) {
|
||||
if (light !== null) light.style.display = 'none'
|
||||
dark.style.display = 'inline'
|
||||
}
|
||||
else {
|
||||
if (light !== null) light.style.display = 'inline'
|
||||
if (dark !== null) dark.style.display = 'none'
|
||||
}
|
||||
}
|
||||
}
|
|
@ -7,7 +7,7 @@ window.addEventListener('DOMContentLoaded', () => {
|
|||
const fuseOptions = {
|
||||
shouldSort: true,
|
||||
includeMatches: true,
|
||||
threshold: 0.1,
|
||||
threshold: 0.0,
|
||||
tokenize: true,
|
||||
location: 0,
|
||||
distance: 100,
|
||||
|
@ -79,13 +79,6 @@ window.addEventListener('DOMContentLoaded', () => {
|
|||
// pull template from hugo template definition
|
||||
const templateDefinition = document.getElementById('search-result-template').innerHTML
|
||||
// replace values
|
||||
function adaptTags() {
|
||||
const tags = value.item.tags;
|
||||
let string = '';
|
||||
if (tags) tags.forEach((t) => {string += '<li class="rounded"><a href="/tags/' + t.toLowerCase() + '/" class="btn btn-sm btn-info">' + t + "</a></li>"});
|
||||
return string;
|
||||
}
|
||||
|
||||
const output = render(templateDefinition, {
|
||||
key,
|
||||
title: value.item.title,
|
||||
|
@ -93,7 +86,7 @@ window.addEventListener('DOMContentLoaded', () => {
|
|||
date: value.item.date,
|
||||
summary: value.item.summary,
|
||||
link: value.item.permalink,
|
||||
tags: adaptTags(),
|
||||
tags: value.item.tags,
|
||||
categories: value.item.categories,
|
||||
snippet
|
||||
})
|
||||
|
|
|
@ -15,7 +15,7 @@ window.addEventListener('DOMContentLoaded', () => {
|
|||
}
|
||||
}
|
||||
|
||||
// =============== Make TOC Compatible with Bootstrap Scroll Spy ========
|
||||
// =============== Make TOC Compatible wit Bootstrap Scroll Spy ========
|
||||
// add "navbar" class to the "nav" element
|
||||
const toc = document.getElementById('TableOfContents')
|
||||
if (toc) {
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import { getDeviceState } from '../core'
|
||||
|
||||
function fourColumnRow (gallery, entries, i) {
|
||||
function fourColumRow (gallery, entries, i) {
|
||||
const entry1 = document.createElement('div')
|
||||
entry1.classList.add('col-lg-6', 'm-0', 'p-0')
|
||||
entry1.appendChild(entries[i].cloneNode(true))
|
||||
|
@ -140,7 +140,7 @@ function showAchievements () {
|
|||
if (isLaptop) {
|
||||
if (i + 4 <= len) {
|
||||
if (rowNumber % 2) {
|
||||
fourColumnRow(gallery, entries, i)
|
||||
fourColumRow(gallery, entries, i)
|
||||
} else {
|
||||
fourColumnReversedRow(gallery, entries, i)
|
||||
}
|
||||
|
|
|
@ -4,5 +4,4 @@ import './sidebar'
|
|||
import './education'
|
||||
import './achievements'
|
||||
import './projects'
|
||||
import './skills'
|
||||
import './publications'
|
||||
|
|
|
@ -54,9 +54,8 @@ document.addEventListener('DOMContentLoaded', function () {
|
|||
const navMain = document.getElementsByClassName('navbar-collapse')
|
||||
Array.from(navMain).forEach(function (el) {
|
||||
el.addEventListener('click', function (e) {
|
||||
if (e.target.tagName === 'A' && !e.target.classList.contains("dropdown-toggle")) {
|
||||
if (e.target.tagName === 'A') {
|
||||
el.classList.add('collapse')
|
||||
el.classList.remove('show')
|
||||
}
|
||||
})
|
||||
})
|
||||
|
|
|
@ -1,15 +0,0 @@
|
|||
import Filterizr from 'filterizr'
|
||||
|
||||
document.addEventListener('DOMContentLoaded', () => {
|
||||
// ================== Skill cards =====================
|
||||
|
||||
// setup skill filter buttons
|
||||
const skillCardHolder = document.getElementById('skill-card-holder')
|
||||
if (skillCardHolder != null && skillCardHolder.children.length !== 0) {
|
||||
// eslint-disable-next-line no-new
|
||||
new Filterizr('.filtr-skills', {
|
||||
layout: 'sameWidth',
|
||||
controlsSelector: '.skill-filtr-control'
|
||||
})
|
||||
}
|
||||
})
|
|
@ -49,15 +49,6 @@
|
|||
color: get-light-color('muted-text-color');
|
||||
}
|
||||
|
||||
.navbar-toggler {
|
||||
border: none;
|
||||
&:focus {
|
||||
border: none;
|
||||
outline: none !important;
|
||||
box-shadow: none;
|
||||
}
|
||||
}
|
||||
|
||||
.tags {
|
||||
text-align: left;
|
||||
padding-top: 0.5em;
|
||||
|
@ -65,12 +56,14 @@
|
|||
font-size: 0.5em;
|
||||
list-style-type: none;
|
||||
display: inline-block;
|
||||
background: get-light-color('accent-color');
|
||||
margin-left: 0.2em;
|
||||
margin-right: 0.2em;
|
||||
margin-top: 0.6em;
|
||||
margin-bottom: 0.6em;
|
||||
}
|
||||
a {
|
||||
color: get-light-color('text-over-accent-color');
|
||||
text-decoration: none !important;
|
||||
}
|
||||
}
|
||||
|
@ -102,40 +95,6 @@
|
|||
}
|
||||
}
|
||||
|
||||
.copy-code-button {
|
||||
float: right;
|
||||
margin-top: 0.5em;
|
||||
margin-left: -2.6em;
|
||||
margin-right: 3em;
|
||||
|
||||
background-color: get-light-color('text-color') !important;
|
||||
color: get-light-color('inverse-text-color') !important;
|
||||
padding: 0.25rem 0.5rem;
|
||||
line-height: 1.5;
|
||||
border-radius: 0.2rem;
|
||||
border: none;
|
||||
|
||||
&:hover,
|
||||
&:focus {
|
||||
background-color: get-light-color('accent-color') !important;
|
||||
color: get-light-color('text-over-accent-color') !important;
|
||||
@include transition();
|
||||
}
|
||||
&:focus {
|
||||
&::before {
|
||||
content: 'Copied!';
|
||||
position: absolute;
|
||||
padding: 0.3em;
|
||||
border-radius: 0.2em;
|
||||
margin-left: -5em;
|
||||
margin-top: -0.2em;
|
||||
background-color: get-light-color('accent-color') !important;
|
||||
color: get-light-color('text-over-accent-color') !important;
|
||||
@include transition();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
html[data-theme='dark'] {
|
||||
.btn-dark {
|
||||
background-color: get-dark-color('accent-color') !important;
|
||||
|
@ -184,6 +143,17 @@ html[data-theme='dark'] {
|
|||
color: get-dark-color('muted-text-color');
|
||||
}
|
||||
|
||||
.tags {
|
||||
li {
|
||||
background: get-dark-color('accent-color');
|
||||
a {
|
||||
background-color: get-dark-color('bg-card');
|
||||
border: 1px solid get-dark-color('muted-text-color');
|
||||
color: get-dark-color('text-over-accent-color');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.icon-button {
|
||||
background-color: get-dark-color('muted-text-color');
|
||||
color: get-dark-color('text-over-accent-color') !important;
|
||||
|
@ -203,15 +173,4 @@ html[data-theme='dark'] {
|
|||
background-color: get-dark-color('hover-over-accent-color') !important;
|
||||
}
|
||||
}
|
||||
.copy-code-button {
|
||||
background-color: get-dark-color('bg-primary') !important;
|
||||
color: get-dark-color('muted-text-color') !important;
|
||||
|
||||
&:hover,
|
||||
&:focus,
|
||||
&::before {
|
||||
background-color: get-dark-color('accent-color') !important;
|
||||
color: get-dark-color('text-over-accent-color') !important;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -9,11 +9,6 @@
|
|||
box-shadow: $box-shadow;
|
||||
border: 1px solid get-light-color('bg-primary');
|
||||
@include transition();
|
||||
.card-img-top {
|
||||
transform: scale(1.2);
|
||||
object-fit: cover;
|
||||
@include transition();
|
||||
}
|
||||
}
|
||||
|
||||
.card-head {
|
||||
|
@ -22,17 +17,12 @@
|
|||
overflow: hidden;
|
||||
}
|
||||
|
||||
.card-title {
|
||||
font-size: large;
|
||||
}
|
||||
|
||||
.card-body {
|
||||
text-align: left;
|
||||
text-align: justify;
|
||||
}
|
||||
|
||||
.card-img-top {
|
||||
-o-object-fit: cover;
|
||||
object-fit: cover;
|
||||
object-fit: cover;
|
||||
@include transition();
|
||||
}
|
||||
|
||||
|
@ -60,7 +50,6 @@
|
|||
|
||||
.post-card-link {
|
||||
text-decoration: none !important;
|
||||
color: get-light-color('text-color');
|
||||
}
|
||||
|
||||
.card {
|
||||
|
@ -71,8 +60,7 @@
|
|||
&:focus {
|
||||
.card-img-top {
|
||||
transform: scale(1.2);
|
||||
-o-object-fit: cover;
|
||||
object-fit: cover;
|
||||
object-fit: cover;
|
||||
@include transition();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -46,31 +46,3 @@ html[data-theme='dark'] {
|
|||
.svg-inverted {
|
||||
filter: invert(1);
|
||||
}
|
||||
|
||||
.logo-holder {
|
||||
height: 64px;
|
||||
margin-bottom: 1em;
|
||||
}
|
||||
|
||||
.company-logo {
|
||||
max-height: 100%;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.light-logo {
|
||||
display: inline;
|
||||
}
|
||||
|
||||
.dark-logo {
|
||||
display: none;
|
||||
}
|
||||
|
||||
html[data-theme='dark'] {
|
||||
.light-logo {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.dark-logo {
|
||||
display: inline;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -2,24 +2,18 @@ a {
|
|||
color: get-light-color('accent-color');
|
||||
@include transition();
|
||||
|
||||
&:link {
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
&:hover,
|
||||
&:focus {
|
||||
-webkit-text-decoration: get-light-color('hover-over-accent-color') underline;
|
||||
text-decoration: get-light-color('hover-over-accent-color') underline;
|
||||
text-decoration: get-light-color('hover-over-accent-color') underline;
|
||||
color: get-light-color('hover-over-accent-color');
|
||||
@include transition();
|
||||
}
|
||||
}
|
||||
|
||||
.list-link, .taxonomy-term {
|
||||
.list-link {
|
||||
text-decoration: none !important;
|
||||
color: get-light-color('text-color');
|
||||
@include transition();
|
||||
|
||||
&.active {
|
||||
display: inline;
|
||||
color: get-light-color('accent-color');
|
||||
|
@ -35,7 +29,6 @@ a {
|
|||
a.header-anchor {
|
||||
text-decoration: none;
|
||||
color: get-light-color('heading-color');
|
||||
|
||||
i,
|
||||
svg {
|
||||
font-size: 10pt;
|
||||
|
@ -43,15 +36,12 @@ a.header-anchor {
|
|||
display: none;
|
||||
margin-left: 0.5rem;
|
||||
}
|
||||
|
||||
&:hover {
|
||||
|
||||
i,
|
||||
svg {
|
||||
display: inline-block;
|
||||
}
|
||||
}
|
||||
|
||||
code {
|
||||
color: get-light-color('inline-code-color');
|
||||
}
|
||||
|
@ -64,34 +54,26 @@ a.header-anchor {
|
|||
html[data-theme='dark'] {
|
||||
a {
|
||||
color: get-dark-color('accent-color');
|
||||
|
||||
&:hover,
|
||||
&:focus {
|
||||
-webkit-text-decoration: get-dark-color('hover-over-accent-color') underline;
|
||||
text-decoration: get-dark-color('hover-over-accent-color') underline;
|
||||
text-decoration: get-dark-color('hover-over-accent-color') underline;
|
||||
color: get-dark-color('hover-over-accent-color');
|
||||
}
|
||||
}
|
||||
|
||||
.list-link, .taxonomy-term {
|
||||
.list-link {
|
||||
color: get-dark-color('text-color');
|
||||
|
||||
&:hover,
|
||||
&.active {
|
||||
&:hover {
|
||||
color: get-dark-color('accent-color');
|
||||
}
|
||||
}
|
||||
|
||||
a.header-anchor {
|
||||
color: get-dark-color('heading-color');
|
||||
|
||||
i,
|
||||
svg {
|
||||
color: get-dark-color('text-color');
|
||||
}
|
||||
|
||||
code {
|
||||
color: get-dark-color('inline-code-color');
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -96,10 +96,6 @@ html[data-theme='dark'] {
|
|||
}
|
||||
}
|
||||
.gist {
|
||||
&::-moz-selection{
|
||||
background: get-dark-color('text-color');
|
||||
color: get-dark-color('inverse-text-color');
|
||||
}
|
||||
&::selection{
|
||||
background: get-dark-color('text-color');
|
||||
color: get-dark-color('inverse-text-color');
|
||||
|
|
|
@ -12,7 +12,7 @@ strong {
|
|||
|
||||
p {
|
||||
color: get-light-color('text-color');
|
||||
text-align: left;
|
||||
text-align: justify;
|
||||
text-justify: inter-word;
|
||||
}
|
||||
|
||||
|
@ -33,10 +33,6 @@ blockquote {
|
|||
}
|
||||
}
|
||||
|
||||
.text-justify {
|
||||
text-align: justify;
|
||||
}
|
||||
|
||||
.text-muted {
|
||||
color: get-light-color('muted-text-color') !important;
|
||||
}
|
||||
|
@ -76,8 +72,7 @@ html[data-theme='dark'] {
|
|||
h2,
|
||||
h3,
|
||||
h4,
|
||||
h5,
|
||||
h6 {
|
||||
h5 {
|
||||
color: get-dark-color('heading-color');
|
||||
}
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
/* in Hugo, Page kind can be either "section" or "page".*/
|
||||
/* if it is section, then it's a page with a list of items, for example /posts*/
|
||||
/* if it is page, then it is a single page.*/
|
||||
// in Hugo, Page kind can be either "section" or "page".
|
||||
// if it is section, then it's a page with a list of items, for example /posts
|
||||
// if it is page, then it is a single page.
|
||||
body.kind-section,
|
||||
body.kind-term,
|
||||
body.kind-page {
|
||||
|
|
|
@ -53,6 +53,7 @@ body {
|
|||
ol > ol,
|
||||
li > ol,
|
||||
li > ul {
|
||||
-webkit-padding-start: 1rem;
|
||||
padding-inline-start: 1rem;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -184,7 +184,6 @@ body.kind-page {
|
|||
|
||||
#scroll-to-top {
|
||||
position: fixed;
|
||||
border: none;
|
||||
bottom: 0rem;
|
||||
right: 1rem;
|
||||
color: get-light-color('accent-color');
|
||||
|
|
|
@ -27,7 +27,6 @@
|
|||
|
||||
.navbar-brand {
|
||||
color: get-light-color('heading-color');
|
||||
text-decoration: none !important;
|
||||
font-weight: 600;
|
||||
img {
|
||||
width: 42px;
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
/* override this file for custom css */
|
||||
|
||||
/* you can import bootstrap mixins */
|
||||
/* you can import boostrap mixins */
|
||||
// @import 'bootstrap/scss/mixins';
|
||||
// Example usage
|
||||
// .some-class {
|
||||
|
|
|
@ -129,12 +129,6 @@
|
|||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
|
||||
.custom-section {
|
||||
.custom-content {
|
||||
padding-bottom: 0.5em;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -229,11 +223,6 @@ html[data-theme='dark'] {
|
|||
border-left: 2px solid get-dark-color('accent-color');
|
||||
}
|
||||
}
|
||||
.custom-section {
|
||||
.custom-content {
|
||||
color: get-dark-color('text-color');
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -32,14 +32,14 @@
|
|||
|
||||
&::after {
|
||||
content: '';
|
||||
position: relative;
|
||||
position: absolute;
|
||||
border-left: 3px solid get-light-color('accent-color');
|
||||
z-index: 1;
|
||||
height: 100%;
|
||||
left: -23px;
|
||||
left: 50%;
|
||||
}
|
||||
&:nth-child(even)::after {
|
||||
left: -26px;
|
||||
left: calc(50% - 3px) !important;
|
||||
}
|
||||
}
|
||||
.horizontal-line {
|
||||
|
@ -52,7 +52,6 @@
|
|||
margin: 0;
|
||||
top: 17px;
|
||||
position: relative;
|
||||
opacity: 1;
|
||||
}
|
||||
.timeline-side-div {
|
||||
display: flex;
|
||||
|
@ -93,16 +92,6 @@
|
|||
}
|
||||
}
|
||||
|
||||
.company-heading {
|
||||
h5 {
|
||||
display: inline;
|
||||
margin-right: 0.25em;
|
||||
}
|
||||
p {
|
||||
display: inline;
|
||||
}
|
||||
}
|
||||
|
||||
@include media('<=medium') {
|
||||
.container {
|
||||
max-width: 100%;
|
||||
|
|
|
@ -13,8 +13,7 @@
|
|||
@include transition();
|
||||
&:hover {
|
||||
margin-left: 5px;
|
||||
-webkit-text-decoration: get-light-color('muted-text-color') underline;
|
||||
text-decoration: get-light-color('muted-text-color') underline;
|
||||
text-decoration: get-light-color('muted-text-color') underline;
|
||||
@include transition();
|
||||
}
|
||||
}
|
||||
|
@ -80,8 +79,7 @@ html[data-theme='dark'] {
|
|||
a {
|
||||
color: get-dark-color('muted-text-color');
|
||||
&:hover {
|
||||
-webkit-text-decoration: get-dark-color('muted-text-color') underline;
|
||||
text-decoration: get-dark-color('muted-text-color') underline;
|
||||
text-decoration: get-dark-color('muted-text-color') underline;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -97,10 +95,6 @@ html[data-theme='dark'] {
|
|||
background-color: get-dark-color('bg-primary');
|
||||
&:focus {
|
||||
background-color: get-dark-color('bg-secondary');
|
||||
color: get-dark-color('text-color');
|
||||
}
|
||||
&::placeholder {
|
||||
color: get-dark-color('muted-text-color');
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -42,4 +42,7 @@
|
|||
@keyframes spin {
|
||||
to { -webkit-transform: rotate(360deg); }
|
||||
}
|
||||
@-webkit-keyframes spin {
|
||||
to { -webkit-transform: rotate(360deg); }
|
||||
}
|
||||
}
|
|
@ -35,10 +35,6 @@
|
|||
|
||||
.project-card-footer {
|
||||
display: flex;
|
||||
.badge {
|
||||
margin-left: 0.1em;
|
||||
margin-right: 0.1em;
|
||||
}
|
||||
}
|
||||
|
||||
.project-tags-holder {
|
||||
|
|
|
@ -24,14 +24,6 @@
|
|||
float: right !important;
|
||||
}
|
||||
}
|
||||
|
||||
a[href] {
|
||||
text-decoration: underline; /* Underline only when href is present */
|
||||
}
|
||||
|
||||
a:not([href]) {
|
||||
text-decoration: none; /* No underline when href is absent */
|
||||
}
|
||||
}
|
||||
|
||||
.card-body {
|
||||
|
|
|
@ -1,7 +1,4 @@
|
|||
module:
|
||||
hugoVersion:
|
||||
min: "0.146.0"
|
||||
extended: true
|
||||
mounts:
|
||||
- source: content
|
||||
target: content
|
||||
|
@ -17,9 +14,9 @@ module:
|
|||
target: i18n
|
||||
- source: archetypes
|
||||
target: archetypes
|
||||
- source: ../../node_modules/flag-icons/flags
|
||||
- source: ../../node_modules/flag-icon-css/flags
|
||||
target: static/flags
|
||||
- source: ../../node_modules/@fontsource/mulish/files
|
||||
target: static/files
|
||||
- source: ../../node_modules/katex/dist/fonts
|
||||
target: static/fonts
|
||||
target: static/fonts
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -24,7 +24,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
---
|
||||
title: "Suchergebnisse"
|
||||
title: "Search Results"
|
||||
date: 2010-06-08T08:06:25+06:00
|
||||
weight: 999999
|
||||
sitemap:
|
||||
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ Search depends on additional output content type of JSON in config.toml
|
|||
home = ["HTML", "JSON"]
|
||||
\```
|
||||
|
||||
## Searching additional fields
|
||||
## Searching additional fileds
|
||||
|
||||
To search additional fields defined in front matter, you must add it in 2 places.
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
flags:
|
||||
styles:
|
||||
- flag-icons/css/flag-icons
|
||||
- flag-icon-css/css/flag-icons
|
||||
|
||||
videoplayer:
|
||||
services:
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
|
||||
baseURL: http://example.org/
|
||||
languageCode: en-us
|
||||
title: Example Site
|
||||
|
@ -21,7 +22,7 @@ module:
|
|||
mounts:
|
||||
- source: static/files
|
||||
target: static/files
|
||||
- source: ./node_modules/flag-icons/flags
|
||||
- source: ./node_modules/flag-icon-css/flags
|
||||
target: static/flags
|
||||
- source: ./node_modules/@fontsource/mulish/files
|
||||
target: static/files
|
||||
|
@ -32,18 +33,14 @@ module:
|
|||
# For any more details, you can check the official documentation: https://gohugo.io/content-management/multilingual/
|
||||
languages:
|
||||
en:
|
||||
languageCode: en
|
||||
languageName: English
|
||||
title: "John's Blog"
|
||||
weight: 1
|
||||
bn:
|
||||
languageCode: bn
|
||||
languageName: বাংলা
|
||||
title: "জনের ব্লগ"
|
||||
weight: 2
|
||||
weight: 3
|
||||
|
||||
# default language for the content
|
||||
defaultContentLanguage: en
|
||||
# Force a locale to be use, really useful to develop the application ! Should be commented in production, the "weight" should rocks.
|
||||
# DefaultContentLanguage: bn
|
||||
|
||||
# Allow raw html in markdown file
|
||||
markup:
|
||||
|
@ -63,12 +60,6 @@ outputs:
|
|||
- RSS
|
||||
- JSON
|
||||
|
||||
# Configure custom path for RSS feed. Default is "index.xml"
|
||||
# Ref: https://gohugo.io/templates/output-formats/
|
||||
outputFormats:
|
||||
rss:
|
||||
baseName: rss # default is index
|
||||
|
||||
# Enable global emoji support
|
||||
enableEmoji: true
|
||||
|
||||
|
@ -98,20 +89,7 @@ params:
|
|||
|
||||
# Enable dark theme
|
||||
darkMode:
|
||||
|
||||
# [Deprecated] Enable dark theme
|
||||
# This is a deprecated setting, but has not been removed to maintain backward compatibility
|
||||
# If `theme` is set, the `darkMode` setting will be discarded.
|
||||
# darkMode:
|
||||
# enable: true
|
||||
|
||||
# Configure theme color settings
|
||||
theme:
|
||||
enable: true
|
||||
services:
|
||||
light: true # enable light theme. default "true"
|
||||
dark: true # enable dark theme. default "true"
|
||||
default: system # can be either light, dark or system. default "system"
|
||||
|
||||
# Enable and configure portfolio
|
||||
portfolio:
|
||||
|
@ -120,7 +98,6 @@ params:
|
|||
# Enable and configure blog posts
|
||||
blog:
|
||||
enable: true
|
||||
showAuthor: true
|
||||
# Share post on different social media
|
||||
shareButtons:
|
||||
facebook: true
|
||||
|
@ -192,16 +169,7 @@ params:
|
|||
# matomo:
|
||||
# instance: matomo.example.com
|
||||
# siteId: 1 # Or any other number
|
||||
# # Umami
|
||||
# umami:
|
||||
# scheme: https
|
||||
# instance: umami.example.com
|
||||
# id: <your umami site id>
|
||||
# # Statcounter
|
||||
# statcounter:
|
||||
# project: 1234567890
|
||||
# invisible: 1
|
||||
# security: deadbeef
|
||||
|
||||
# Enable Support
|
||||
support:
|
||||
enable: false
|
||||
|
@ -296,15 +264,12 @@ params:
|
|||
plyr:
|
||||
# options doc: https://github.com/sampotts/plyr#options
|
||||
# fullscreen: true
|
||||
|
||||
# Enables copy code button
|
||||
copyCodeButton:
|
||||
enable: true
|
||||
|
||||
|
||||
# Enable reading time support in post cards and in post pages
|
||||
readingTime:
|
||||
enable: true
|
||||
|
||||
|
||||
# Provide footer configuration.
|
||||
footer:
|
||||
enable: true
|
|
@ -1,10 +1,10 @@
|
|||
module github.com/hugo-toha/toha/exampleSite
|
||||
|
||||
go 1.21
|
||||
|
||||
replace github.com/hugo-toha/toha/v4 => ../
|
||||
go 1.19
|
||||
|
||||
require (
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20241018183051-dd13c36f46b4 // indirect
|
||||
github.com/hugo-toha/toha/v4 v4.7.0 // indirect
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20231031082630-2c32a26d2207 // indirect
|
||||
github.com/hugo-toha/toha/v4 v4.0.0-20231113175302-e5230e8c93d8 // indirect
|
||||
)
|
||||
|
||||
replace github.com/hugo-toha/toha/v4 => ../
|
||||
|
|
|
@ -1,2 +1,4 @@
|
|||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20241018183051-dd13c36f46b4 h1:Yc5SJ5NJx1xu3YO2gQZPeADXqhGdJgUGWiDxgEDuUrQ=
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20241018183051-dd13c36f46b4/go.mod h1:3N7k1DSQGy5Zn5IVp5nQ3QJ/VWh5dSxXO6stUS7txrg=
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20221228191121-007f31838bd6 h1:TPFhOZAnuH4wjLIdzimswCRa2qCcc1teKVTatADJU2g=
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20221228191121-007f31838bd6/go.mod h1:OMMaP9Hh9NsKd41lVIazBQRPa0s6Z57AfJoY3DcCNNY=
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20231031082630-2c32a26d2207 h1:T71lEaGpHYpdy8yKM5vaVwm+CJGt8wjHvPgVM+GjCJM=
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20231031082630-2c32a26d2207/go.mod h1:aTn1lQX1rbcbfbwNuWHG/L5DPtD+bEzQro49QyFlbEg=
|
||||
|
|
1459
exampleSite/package-lock.json
generated
1459
exampleSite/package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
@ -15,7 +15,7 @@
|
|||
"eslint-plugin-promise": "github.com/hugo-toha/toha/v4",
|
||||
"feather-icons": "github.com/hugo-toha/toha/v4",
|
||||
"filterizr": "github.com/hugo-toha/toha/v4",
|
||||
"flag-icons": "github.com/hugo-toha/toha/v4",
|
||||
"flag-icon-css": "github.com/hugo-toha/toha/v4",
|
||||
"fuse.js": "github.com/hugo-toha/toha/v4",
|
||||
"highlight.js": "github.com/hugo-toha/toha/v4",
|
||||
"imagesloaded": "github.com/hugo-toha/toha/v4",
|
||||
|
@ -30,11 +30,12 @@
|
|||
"postcss-cli": "github.com/hugo-toha/toha/v4"
|
||||
}
|
||||
},
|
||||
"dependencies": {},
|
||||
"devDependencies": {
|
||||
"@fontsource/mulish": "4.5.13",
|
||||
"@fortawesome/fontawesome-free": "^6.6.0",
|
||||
"autoprefixer": "^10.4.20",
|
||||
"bootstrap": "^5.3.3",
|
||||
"@fortawesome/fontawesome-free": "^6.2.0",
|
||||
"autoprefixer": "^10.4.13",
|
||||
"bootstrap": "^4.6.2",
|
||||
"eslint": "^8.31.0",
|
||||
"eslint-config-prettier": "^8.6.0",
|
||||
"eslint-config-standard": "^17.0.0",
|
||||
|
@ -44,19 +45,19 @@
|
|||
"eslint-plugin-promise": "^6.1.1",
|
||||
"feather-icons": "^4.29.1",
|
||||
"filterizr": "^2.2.4",
|
||||
"flag-icons": "^7.2.3",
|
||||
"flag-icon-css": "^4.1.7",
|
||||
"fuse.js": "^6.6.2",
|
||||
"highlight.js": "^11.6.0",
|
||||
"imagesloaded": "^5.0.0",
|
||||
"include-media": "^1.4.10",
|
||||
"ityped": "^1.0.3",
|
||||
"katex": "^0.16.11",
|
||||
"katex": "^0.16.3",
|
||||
"mark.js": "^8.11.1",
|
||||
"mermaid": "^11.6.0",
|
||||
"mermaid": "^9.2.1",
|
||||
"plyr": "^3.7.2",
|
||||
"popper.js": "^1.16.1",
|
||||
"postcss": "^8.4.41",
|
||||
"postcss-cli": "^11.0.0"
|
||||
"postcss": "^8.4.21",
|
||||
"postcss-cli": "^8.3.1"
|
||||
},
|
||||
"name": "exampleSite",
|
||||
"version": "0.1.0"
|
||||
|
|
2
go.mod
2
go.mod
|
@ -1,3 +1,3 @@
|
|||
module github.com/hugo-toha/toha/v4
|
||||
|
||||
go 1.21
|
||||
go 1.19
|
||||
|
|
2
go.sum
2
go.sum
|
@ -1,2 +0,0 @@
|
|||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20240730212302-83b19f7bd3b7 h1:RRonNzaf6/Ou9PqfXeKiRywkd+9KY7SVgfGBQXqXshM=
|
||||
github.com/hugo-toha/hugo-toha.github.io v0.0.0-20240730212302-83b19f7bd3b7/go.mod h1:yWw1t3trnfzv4t1lA9zh5pSsI0+kqqyg58ir8/kt6zk=
|
130
i18n/az.toml
130
i18n/az.toml
|
@ -1,130 +0,0 @@
|
|||
# More documentation here: https://github.com/nicksnyder/go-i18n
|
||||
[home]
|
||||
other = "Əsas Səhifə"
|
||||
|
||||
[posts]
|
||||
other = "Yazılar"
|
||||
|
||||
[toc_heading]
|
||||
other = "Məzmun Cədvəli"
|
||||
|
||||
[tags]
|
||||
other = "Etiketlər"
|
||||
|
||||
[categories]
|
||||
other = "Kateqoriyalar"
|
||||
|
||||
[at]
|
||||
other = ","
|
||||
|
||||
[resume]
|
||||
other = "CV"
|
||||
|
||||
[navigation]
|
||||
other = "Menyu"
|
||||
|
||||
[contact_me]
|
||||
other = "Əlaqə:"
|
||||
|
||||
[email]
|
||||
other = "E-Poçt"
|
||||
|
||||
[phone]
|
||||
other = "Telefon"
|
||||
|
||||
[newsletter_text]
|
||||
other = "Yeni məzmunlardan xəbərdar olmaq üçün E-Poçt ünvanınızı daxil edin."
|
||||
|
||||
[newsletter_input_placeholder]
|
||||
other = "E-Poçt ünvanını daxil edin."
|
||||
|
||||
[newsletter_warning]
|
||||
other = "E-Poçt ünvanınızı daxil etsəniz, bu veb saytın xəbər bülletenini almağı qəbul etmiş olursunuz."
|
||||
|
||||
[submit]
|
||||
other = "Təsdiqlə"
|
||||
|
||||
[hugoAttributionText]
|
||||
other = ""
|
||||
|
||||
[prev]
|
||||
other = "Əvvəlki"
|
||||
|
||||
[next]
|
||||
other = "Sonraki"
|
||||
|
||||
[share_on]
|
||||
other = "Paylaş"
|
||||
|
||||
[improve_this_page]
|
||||
other = "Bu səhifəyə töhfə verin"
|
||||
|
||||
[out_of]
|
||||
other = "/"
|
||||
|
||||
[publications]
|
||||
other = "Akademik Nəşrlər"
|
||||
|
||||
[taken_courses]
|
||||
other = "Keçirilmiş Kurslar"
|
||||
|
||||
[course_name]
|
||||
other = "Kursun Adı"
|
||||
|
||||
[total_credit]
|
||||
other = "Ümumi Kredit"
|
||||
|
||||
[obtained_credit]
|
||||
other = "Qazandırılmış Kredit"
|
||||
|
||||
[extracurricular_activities]
|
||||
other = "Kursdankənar Fəaliyyətlər"
|
||||
|
||||
[show_more]
|
||||
other = "Daha Çox Göstər"
|
||||
|
||||
[show_less]
|
||||
other = "Gizlət"
|
||||
|
||||
[responsibilities]
|
||||
other = "Məsuliyyətlər:"
|
||||
|
||||
[present]
|
||||
other = "Hal-hazırda"
|
||||
|
||||
[comments_javascript]
|
||||
other = "Görmək üçün xahiş edirəm JavaScript-i aktiv edin"
|
||||
|
||||
[comments_by]
|
||||
other = "Şərh edən"
|
||||
|
||||
[read]
|
||||
other = "Oxu"
|
||||
|
||||
[project_star]
|
||||
other = "Ulduz"
|
||||
|
||||
[project_details]
|
||||
other = "Təfərrüatlar"
|
||||
|
||||
[err_404]
|
||||
other = "Axtardığınız səhifə tapılmadı."
|
||||
|
||||
[more]
|
||||
other = "Daha Çox"
|
||||
|
||||
[view_certificate]
|
||||
other = "Sertifikatı Görüntülə"
|
||||
|
||||
[notes]
|
||||
other = "Qeydlər"
|
||||
|
||||
[disclaimer_text]
|
||||
other = "Məsuliyyət İnkarı"
|
||||
|
||||
[search]
|
||||
other = "Axtar"
|
||||
|
||||
[minute]
|
||||
one = "dəqiqə"
|
||||
other = "dəqiqə"
|
|
@ -96,7 +96,7 @@ other = "heute"
|
|||
other = "Bitte aktiviere JavaScript um die Kommentare zu sehen"
|
||||
|
||||
[comments_by]
|
||||
other = "Kommentare unterstützt von"
|
||||
other = "Kommentare Unterstützt von"
|
||||
|
||||
[read]
|
||||
other = "Lesen"
|
||||
|
@ -124,7 +124,3 @@ other = "Haftungshinweis"
|
|||
|
||||
[search]
|
||||
other = "Suche"
|
||||
|
||||
[minute]
|
||||
one = "Minute"
|
||||
other = "Minuten"
|
|
@ -124,7 +124,3 @@ other = "Vastuuilmoitus"
|
|||
|
||||
[search]
|
||||
other = "Haku"
|
||||
|
||||
[minute]
|
||||
one = "minuutti"
|
||||
other = "minuuttia"
|
||||
|
|
|
@ -117,7 +117,7 @@ other = "Suite"
|
|||
other = "Afficher le certificat"
|
||||
|
||||
[notes]
|
||||
other = "Notes"
|
||||
other = "Remarques"
|
||||
|
||||
[disclaimer_text]
|
||||
other = "Avis de responsabilité"
|
||||
|
@ -127,4 +127,4 @@ other = "Chercher"
|
|||
|
||||
[minute]
|
||||
one = "minute"
|
||||
other = "minutes"
|
||||
other = "minutes"
|
126
i18n/he.toml
126
i18n/he.toml
|
@ -1,126 +0,0 @@
|
|||
# More documentation here: https://github.com/nicksnyder/go-i18n
|
||||
[home]
|
||||
other = "בית"
|
||||
|
||||
[posts]
|
||||
other = "פוסטים"
|
||||
|
||||
[toc_heading]
|
||||
other = "תוכן העניינים"
|
||||
|
||||
[tags]
|
||||
other = "תגים"
|
||||
|
||||
[categories]
|
||||
other = "קטגוריות"
|
||||
|
||||
[at]
|
||||
other = "ב"
|
||||
|
||||
[resume]
|
||||
other = "הקורות החיים שלי"
|
||||
|
||||
[navigation]
|
||||
other = "ניווט"
|
||||
|
||||
[contact_me]
|
||||
other = "צור קשר:"
|
||||
|
||||
[email]
|
||||
other = "דוא\"ל"
|
||||
|
||||
[phone]
|
||||
other = "טלפון"
|
||||
|
||||
[newsletter_text]
|
||||
other = "הישאר מעודכן עם התראות בדוא\"ל"
|
||||
|
||||
[newsletter_input_placeholder]
|
||||
other = "הכנס דוא\"ל"
|
||||
|
||||
[newsletter_warning]
|
||||
other = "על ידי הזנת כתובת הדוא\"ל שלך, אתה מסכים לקבל את הניוזלטר של אתר זה."
|
||||
|
||||
[submit]
|
||||
other = "שלח"
|
||||
|
||||
[hugoAttributionText]
|
||||
other = "מופעל ע\"י"
|
||||
|
||||
[prev]
|
||||
other = "הקודם"
|
||||
|
||||
[next]
|
||||
other = "הבא"
|
||||
|
||||
[share_on]
|
||||
other = "שתף ב"
|
||||
|
||||
[improve_this_page]
|
||||
other = "שפר את הדף הזה"
|
||||
|
||||
[out_of]
|
||||
other = "מתוך"
|
||||
|
||||
[publications]
|
||||
other = "פרסומים"
|
||||
|
||||
[taken_courses]
|
||||
other = "קורסים"
|
||||
|
||||
[course_name]
|
||||
other = "שם הקורס"
|
||||
|
||||
[total_credit]
|
||||
other = "נקודות זכות סך הכל"
|
||||
|
||||
[obtained_credit]
|
||||
other = "נקודות זכות שהושגו"
|
||||
|
||||
[extracurricular_activities]
|
||||
other = "פעילויות חוץ לימודיות"
|
||||
|
||||
[show_more]
|
||||
other = "הצג יותר"
|
||||
|
||||
[show_less]
|
||||
other = "הצג פחות"
|
||||
|
||||
[responsibilities]
|
||||
other = "אחריות:"
|
||||
|
||||
[present]
|
||||
other = "נוכחי"
|
||||
|
||||
[comments_javascript]
|
||||
other = "אנא הפעל את JavaScript כדי לראות את"
|
||||
|
||||
[comments_by]
|
||||
other = "תגובות מופעלות ע\"י"
|
||||
|
||||
[read]
|
||||
other = "קרא"
|
||||
|
||||
[project_star]
|
||||
other = "כוכב"
|
||||
|
||||
[project_details]
|
||||
other = "פרטים"
|
||||
|
||||
[err_404]
|
||||
other = "הדף שאתה מחפש אינו קיים עדיין."
|
||||
|
||||
[more]
|
||||
other = "עוד"
|
||||
|
||||
[view_certificate]
|
||||
other = "צפה בתעודה"
|
||||
|
||||
[notes]
|
||||
other = "הערות"
|
||||
|
||||
[disclaimer_text]
|
||||
other = "הבהרת אחריות"
|
||||
|
||||
[search]
|
||||
other = "חיפוש"
|
10
i18n/tr.toml
10
i18n/tr.toml
|
@ -93,16 +93,16 @@ other = "Sorumluluklar:"
|
|||
other = "Halen"
|
||||
|
||||
[comments_javascript]
|
||||
other = "Görüntüleyebilmek için lüften JavaScript etkinleştirin"
|
||||
other = "Görüntüleyebilmek için lüften Javascript etkinleştirin"
|
||||
|
||||
[comments_by]
|
||||
other = "Yorum sağlayıcı"
|
||||
other = "comments powered by"
|
||||
|
||||
[read]
|
||||
other = "Oku"
|
||||
|
||||
[project_star]
|
||||
other = "Yıldız"
|
||||
other = "Star"
|
||||
|
||||
[project_details]
|
||||
other = "Detaylar"
|
||||
|
@ -124,7 +124,3 @@ other = "Yükümlülük Bildirisi"
|
|||
|
||||
[search]
|
||||
other = "Ara"
|
||||
|
||||
[minute]
|
||||
one = "dakika"
|
||||
other = "dakika"
|
||||
|
|
|
@ -124,7 +124,3 @@ other = "免责声明"
|
|||
|
||||
[search]
|
||||
other = "搜索"
|
||||
|
||||
[minute]
|
||||
one = "分钟"
|
||||
other = "分钟"
|
||||
|
|
|
@ -9,10 +9,10 @@ other = "文章"
|
|||
other = "目錄"
|
||||
|
||||
[tags]
|
||||
other = "標籤"
|
||||
other = "标签"
|
||||
|
||||
[categories]
|
||||
other = "類別"
|
||||
other = "类别"
|
||||
|
||||
[at]
|
||||
other = "at"
|
||||
|
@ -42,7 +42,7 @@ other = "在此輸入您的電子郵件地址"
|
|||
other = "輸入您的電子郵件地址,即表示您同意接受本網站的最新消息"
|
||||
|
||||
[submit]
|
||||
other = "送出"
|
||||
other = "提交"
|
||||
|
||||
[hugoAttributionText]
|
||||
other = "Powered by"
|
||||
|
@ -63,10 +63,10 @@ other = "改善此頁面"
|
|||
other = "/"
|
||||
|
||||
[publications]
|
||||
other = "著作"
|
||||
other = "出版"
|
||||
|
||||
[taken_courses]
|
||||
other = "修課內容"
|
||||
other = "修習課程"
|
||||
|
||||
[course_name]
|
||||
other = "課程名稱"
|
||||
|
@ -123,8 +123,4 @@ other = "筆記"
|
|||
other = "免責聲明"
|
||||
|
||||
[search]
|
||||
other = "搜尋"
|
||||
|
||||
[minute]
|
||||
one = "分鐘"
|
||||
other = "分鐘"
|
||||
other = "搜索"
|
||||
|
|
|
@ -4,20 +4,27 @@
|
|||
<title>{{ .Page.Title }}</title>
|
||||
<!------ ADD COMMON HEADERS -------->
|
||||
{{- partial "header.html" . -}}
|
||||
{{- partial "opengraph.html" . -}}
|
||||
{{ template "_internal/opengraph.html" . }}
|
||||
{{ template "_internal/twitter_cards.html" . }}
|
||||
<!------ ADD PAGE SPECIFIC HEADERS ------->
|
||||
{{ block "header" . }} {{ end }}
|
||||
|
||||
<!--================= add analytics if enabled =========================-->
|
||||
{{- partial "analytics.html" . -}}
|
||||
{{ with resources.Get "scripts/core/theme-scheme.js" | fingerprint }}
|
||||
<script integrity="{{.Data.Integrity}}">
|
||||
{{ .Content | safeJS }}
|
||||
<script>
|
||||
theme = localStorage.getItem('darkmode:color-scheme') || 'system';
|
||||
if (theme == 'system') {
|
||||
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
||||
theme = 'dark';
|
||||
} else {
|
||||
theme = 'light';
|
||||
}
|
||||
}
|
||||
document.documentElement.setAttribute('data-theme', theme);
|
||||
</script>
|
||||
{{ end }}
|
||||
</head>
|
||||
|
||||
<body class="type-{{ .Page.Type }} kind-{{ .Page.Kind }}" data-bs-spy="scroll" data-bs-target="#TableOfContents" data-bs-offset="80">
|
||||
<body class="type-{{ .Page.Type }} kind-{{ .Page.Kind }}" data-spy="scroll" data-target="#TableOfContents" data-offset="80">
|
||||
<div class="container-fluid bg-secondary wrapper">
|
||||
<!----- ADD NAVBAR --------------->
|
||||
{{ block "navbar" . }} {{ end }}
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
{{ define "sidebar" }}
|
||||
{{ $homePage:="#" }}
|
||||
{{ if hugo.IsMultilingual }}
|
||||
{{ if site.IsMultiLingual }}
|
||||
{{ $homePage = (path.Join (cond ( eq .Language.Lang "en") "" .Language.Lang) .Type) }}
|
||||
{{ end }}
|
||||
|
||||
|
@ -32,8 +32,7 @@
|
|||
<div class="content container-fluid" id="content">
|
||||
<div class="container-fluid post-card-holder" id="post-card-holder">
|
||||
{{ $posts := where .RegularPagesRecursive "Layout" "!=" "search" }}
|
||||
{{ $numShow := site.Params.features.pagination.maxPostsPerPage | default 12}}
|
||||
{{ $paginator := .Paginate $posts $numShow }}
|
||||
{{ $paginator := .Paginate $posts 12 }}
|
||||
{{ range $paginator.Pages }}
|
||||
{{ if .Layout }}
|
||||
{{/* ignore the search.md file*/}}
|
||||
|
@ -43,7 +42,7 @@
|
|||
{{ end }}
|
||||
</div>
|
||||
<div class="paginator">
|
||||
{{ partial "pagination.html" . }}
|
||||
{{ template "_internal/pagination.html" . }}
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
|
|
|
@ -19,9 +19,9 @@
|
|||
<link>{{ .Permalink }}</link>
|
||||
<description>Recent content {{ if ne .Title .Site.Title }}{{ with .Title }}in {{.}} {{ end }}{{ end }}on {{ .Site.Title }}</description>
|
||||
<generator>Hugo -- gohugo.io</generator>{{ with .Site.LanguageCode }}
|
||||
<language>{{.}}</language>{{end}}{{ with .Site.Params.Author.email }}
|
||||
<managingEditor>{{.}}{{ with $.Site.Params.Author.name }} ({{.}}){{end}}</managingEditor>{{end}}{{ with .Site.Params.Author.email }}
|
||||
<webMaster>{{.}}{{ with $.Site.Params.Author.name }} ({{.}}){{end}}</webMaster>{{end}}{{ with .Site.Copyright }}
|
||||
<language>{{.}}</language>{{end}}{{ with .Site.Author.email }}
|
||||
<managingEditor>{{.}}{{ with $.Site.Author.name }} ({{.}}){{end}}</managingEditor>{{end}}{{ with .Site.Author.email }}
|
||||
<webMaster>{{.}}{{ with $.Site.Author.name }} ({{.}}){{end}}</webMaster>{{end}}{{ with .Site.Copyright }}
|
||||
<copyright>{{.}}</copyright>{{end}}{{ if not .Date.IsZero }}
|
||||
<lastBuildDate>{{ .Date.Format "Mon, 02 Jan 2006 15:04:05 -0700" | safeHTML }}</lastBuildDate>{{ end }}
|
||||
{{- with .OutputFormats.Get "RSS" -}}
|
||||
|
@ -33,7 +33,7 @@
|
|||
<title>{{ .Title }}</title>
|
||||
<link>{{ .Permalink }}</link>
|
||||
<pubDate>{{ .Date.Format "Mon, 02 Jan 2006 15:04:05 -0700" | safeHTML }}</pubDate>
|
||||
{{ with .Site.Params.Author.email }}<author>{{.}}{{ with $.Site.Params.Author.name }} ({{.}}){{end}}</author>{{end}}
|
||||
{{ with .Site.Author.email }}<author>{{.}}{{ with $.Site.Author.name }} ({{.}}){{end}}</author>{{end}}
|
||||
<guid>{{ .Permalink }}</guid>
|
||||
<description>{{ .Summary | html }}</description>
|
||||
</item>
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
{{ define "sidebar" }}
|
||||
{{ $homePage:="#" }}
|
||||
{{ if hugo.IsMultilingual }}
|
||||
{{ if site.IsMultiLingual }}
|
||||
{{ $homePage = (path.Join (cond ( eq .Language.Lang "en") "" .Language.Lang) .Type) }}
|
||||
{{ end }}
|
||||
|
||||
|
@ -28,40 +28,28 @@
|
|||
{{ end }}
|
||||
|
||||
{{ define "content" }}
|
||||
<script>
|
||||
document.body.classList.replace('kind-page', 'kind-section');
|
||||
</script>
|
||||
<section class="content-section" id="content-section">
|
||||
<div class="content container-fluid" id="content">
|
||||
<div class="container-fluid post-card-holder" id="post-card-holder">
|
||||
<div id="search-results" style="display: flex; flex-wrap: wrap;">
|
||||
<div id="search-results">
|
||||
|
||||
<script id="search-result-template" type="text/x-js-template">
|
||||
<div class="post-card">
|
||||
<div class="card">
|
||||
<a href="${link}" class="post-card-link">
|
||||
<div class="card" style="min-height: 352px;"><a href="${link}" class="post-card-link">
|
||||
<div class="card-head">
|
||||
<a href="${link}" class="post-card-link">
|
||||
<img class="card-img-top" src="${hero}" alt="Card Heading Image">
|
||||
</a>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<a href="${link}" class="post-card-link">
|
||||
<h5 class="card-title">${title}</h5>
|
||||
<p class="card-text post-summary">${summary}</p>
|
||||
</a>
|
||||
{{ if site.Params.features.tags.on_card }}
|
||||
<div class="tags">
|
||||
<ul style="padding-left: 0;">
|
||||
${tags}
|
||||
</ul>
|
||||
</div>
|
||||
{{ end }}
|
||||
<h5 class="card-title">${title}</h5>
|
||||
<p class="card-text post-summary">${summary}</p>
|
||||
</div>
|
||||
<div class="card-footer">
|
||||
<span class="float-start">${date}</span>
|
||||
<a href="${link}" class="float-end btn btn-outline-info btn-sm">Read</a>
|
||||
<span class="float-left">${date}</span>
|
||||
<a href="${link}" class="float-right btn btn-outline-info btn-sm">Read</a>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
|
|
|
@ -1,8 +1,5 @@
|
|||
{{ define "header" }}
|
||||
<meta name="description" content="{{ if .Description }}{{ .Description }}{{ else }}{{ .Title }}{{ end }}" />
|
||||
{{ with .Params.relcanonical }}
|
||||
<link rel="canonical" href="{{ . | relLangURL }}" itemprop="url" />
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
||||
{{ define "navbar" }}
|
||||
|
@ -39,26 +36,15 @@
|
|||
|
||||
<!--Content Start-->
|
||||
<div class="page-content">
|
||||
{{ if site.Params.features.blog.showAuthor | default true }}
|
||||
<div class="author-profile ms-auto align-self-lg-center">
|
||||
<div class="author-profile ml-auto align-self-lg-center">
|
||||
<img class="rounded-circle" src='{{ partial "helpers/get-author-image.html" . }}' alt="Author Image">
|
||||
<h5 class="author-name">{{ partial "helpers/get-author-name.html" . }}</h5>
|
||||
<p class="text-muted">{{ .Page.Date | time.Format ":date_full" }}{{ if site.Params.features.readingTime }} | {{ .ReadingTime }} {{i18n "minute" .ReadingTime }}{{ end }}</p>
|
||||
</div>
|
||||
{{ else }}
|
||||
<div style="margin-bottom: 80px;"></div>
|
||||
{{ end }}
|
||||
|
||||
<div class="title">
|
||||
<h1>{{ .Page.Title }}</h1>
|
||||
</div>
|
||||
|
||||
{{ if not (site.Params.features.blog.showAuthor | default true) }}
|
||||
<div class="author-profile ms-auto align-self-lg-center">
|
||||
<p class="text-muted">{{ .Page.Date | time.Format ":date_full" }}{{ if site.Params.features.readingTime }} | {{ .ReadingTime }} {{i18n "minute" .ReadingTime }}{{ end }}</p>
|
||||
</div>
|
||||
{{ end }}
|
||||
|
||||
{{ if site.Params.features.tags.enable }}
|
||||
{{partial "misc/tags.html" .Params.tags }}
|
||||
{{ end }}
|
||||
|
@ -67,7 +53,7 @@
|
|||
</div>
|
||||
|
||||
<!-- Share or Contribute -->
|
||||
<div class="row ps-3 pe-3">
|
||||
<div class="row pl-3 pr-3">
|
||||
<!--Social Media Share Buttons-->
|
||||
<div class="col-md-6 share-buttons">
|
||||
{{ if site.Params.features.blog.shareButtons }}
|
||||
|
@ -160,15 +146,15 @@
|
|||
{{ end }}
|
||||
|
||||
<!-- Keep backward compatibility with old config.yaml -->
|
||||
{{ if .Site.Config.Services.Disqus.Shortname }}
|
||||
{{ partial "comments/disqus.html" (dict (slice "disqus" "shortName") .Site.Config.Services.Disqus.Shortname) }}
|
||||
{{ if site.DisqusShortname }}
|
||||
{{ partial "comments/disqus.html" (dict (slice "disqus" "shortName") site.DisqusShortname) }}
|
||||
{{ end }}
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!--scroll back to top-->
|
||||
<a id="scroll-to-top" class="btn" type="button" data-bs-toggle="tooltip" data-bs-placement="left" title="Scroll to top">
|
||||
<a id="scroll-to-top" class="btn" data-toggle="tooltip" data-placement="left" title="Scroll to top">
|
||||
<i class="fas fa-chevron-circle-up"></i>
|
||||
</a>
|
||||
</section>
|
||||
|
@ -178,7 +164,7 @@
|
|||
<section class="toc-section" id="toc-section">
|
||||
{{ if and site.Params.features.toc.enable ( .Params.enableTOC | default true ) }}
|
||||
<div class="toc-holder">
|
||||
<h5 class="text-center ps-3">{{ i18n "toc_heading" }}</h5>
|
||||
<h5 class="text-center pl-3">{{ i18n "toc_heading" }}</h5>
|
||||
<hr>
|
||||
<div class="toc">
|
||||
{{ .TableOfContents }}
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
{{ define "sidebar" }}
|
||||
{{ $homePage:="#" }}
|
||||
{{ if hugo.IsMultilingual }}
|
||||
{{ if site.IsMultiLingual }}
|
||||
{{ $homePage = (path.Join (cond ( eq .Language.Lang "en") "" .Language.Lang) .Type) }}
|
||||
{{ end }}
|
||||
|
||||
|
@ -33,8 +33,7 @@
|
|||
<div class="content container-fluid" id="content">
|
||||
<div class="container-fluid post-card-holder" id="post-card-holder">
|
||||
{{ $posts := where .RegularPagesRecursive "Layout" "!=" "search" }}
|
||||
{{ $numShow := site.Params.features.pagination.maxPostsPerPage | default 12}}
|
||||
{{ $paginator := .Paginate $posts $numShow }}
|
||||
{{ $paginator := .Paginate $posts 12 }}
|
||||
{{ range $paginator.Pages }}
|
||||
{{ if .Layout }}
|
||||
{{/* ignore the search.md file*/}}
|
||||
|
@ -44,7 +43,7 @@
|
|||
{{ end }}
|
||||
</div>
|
||||
<div class="paginator">
|
||||
{{ partial "pagination.html" . }}
|
||||
{{ template "_internal/pagination.html" . }}
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
|
|
|
@ -17,13 +17,19 @@
|
|||
|
||||
<!--================= add analytics if enabled =========================-->
|
||||
{{- partial "analytics.html" . -}}
|
||||
{{ with resources.Get "scripts/core/theme-scheme.js" | fingerprint }}
|
||||
<script integrity="{{.Data.Integrity}}">
|
||||
{{ .Content | safeJS }}
|
||||
<script>
|
||||
theme = localStorage.getItem('darkmode:color-scheme') || 'system';
|
||||
if (theme == 'system') {
|
||||
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
||||
theme = 'dark';
|
||||
} else {
|
||||
theme = 'light';
|
||||
}
|
||||
}
|
||||
document.documentElement.setAttribute('data-theme', theme);
|
||||
</script>
|
||||
{{ end }}
|
||||
</head>
|
||||
<body data-bs-spy="scroll" data-bs-target="#top-navbar" data-bs-offset="100">
|
||||
<body data-spy="scroll" data-target="#top-navbar" data-offset="100">
|
||||
|
||||
<!--- NAVBAR ------------------------->
|
||||
{{- partial "navigators/navbar.html" . -}}
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
{{ define "sidebar" }}
|
||||
{{ $homePage:="#" }}
|
||||
{{ if hugo.IsMultilingual }}
|
||||
{{ if site.IsMultiLingual }}
|
||||
{{ $homePage = (path.Join (cond ( eq .Language.Lang "en") "" .Language.Lang) .Type) }}
|
||||
{{ end }}
|
||||
|
||||
|
@ -41,7 +41,7 @@
|
|||
{{ end }}
|
||||
</div>
|
||||
<div class="paginator">
|
||||
{{ partial "pagination.html" . }}
|
||||
{{ template "_internal/pagination.html" . }}
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
{{ define "sidebar" }}
|
||||
{{ $homePage:="#" }}
|
||||
{{ if hugo.IsMultilingual }}
|
||||
{{ if site.IsMultiLingual }}
|
||||
{{ $homePage = (path.Join (cond ( eq .Language.Lang "en") "" .Language.Lang) .Type) }}
|
||||
{{ end }}
|
||||
|
||||
|
|
|
@ -2,83 +2,60 @@
|
|||
{{ with site.Params.features.analytics }}
|
||||
{{ if or .enable .enabled }}
|
||||
{{ with .services }}
|
||||
<!-- Google Analytics -->
|
||||
{{ with .google }}
|
||||
{{ partial "google_analytics.html" . }}
|
||||
{{ end }}
|
||||
<!-- Google Analytics -->
|
||||
{{ with .google }}
|
||||
{{ $privacyConfig:= dict (slice "Site" "Config" "Privacy" "GoogleAnalytics") $.Site.Config.Privacy.GoogleAnalytics }}
|
||||
{{ $analyticsConfig := dict (slice "Site" "GoogleAnalytics") .id }}
|
||||
{{ template "_internal/google_analytics.html" (merge $privacyConfig $analyticsConfig) }}
|
||||
{{ end }}
|
||||
|
||||
<!-- Counter.dev -->
|
||||
{{ with .counterDev }}
|
||||
<script src="https://cdn.counter.dev/script.js"
|
||||
data-id="{{ .id }}"
|
||||
data-utcoffset="1"
|
||||
></script>
|
||||
{{ end }}
|
||||
<!-- Counter.dev -->
|
||||
{{ with .counterDev }}
|
||||
<script src="https://cdn.counter.dev/script.js"
|
||||
data-id="{{ .id }}"
|
||||
data-utcoffset="1"
|
||||
></script>
|
||||
{{ end }}
|
||||
|
||||
<!-- GoatCounter -->
|
||||
{{ with .goatCounter }}
|
||||
{{ with .code }}
|
||||
<script data-goatcounter="https://{{ . }}.goatcounter.com/count" async src="//gc.zgo.at/count.js"></script>
|
||||
{{ else }}
|
||||
<script data-goatcounter="https://{{ .instance }}/count" async src="https://{{ .instance }}/count.js"></script>
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
<!-- GoatCounter -->
|
||||
{{ with .goatCounter }}
|
||||
{{ with .code }}
|
||||
<script data-goatcounter="https://{{ . }}.goatcounter.com/count" async src="//gc.zgo.at/count.js"></script>
|
||||
{{ else }}
|
||||
<script data-goatcounter="https://{{ .instance }}/count" async src="https://{{ .instance }}/count.js"></script>
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
||||
<!-- Piwik/Matomo -->
|
||||
{{ with .matomo }}
|
||||
<!-- Matomo -->
|
||||
<script>
|
||||
var _paq = window._paq = window._paq || [];
|
||||
/* tracker methods like "setCustomDimension" should be called before "trackPageView" */
|
||||
_paq.push(['trackPageView']);
|
||||
_paq.push(['enableLinkTracking']);
|
||||
(function() {
|
||||
var u="//{{ .instance }}/";
|
||||
_paq.push(['setTrackerUrl', u+'matomo.php']);
|
||||
_paq.push(['setSiteId', '{{ .siteId }}']);
|
||||
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
|
||||
g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
|
||||
})();
|
||||
</script>
|
||||
{{ end }}
|
||||
|
||||
{{ with .cloudflare }}
|
||||
<!-- Cloudflare Web Analytics -->
|
||||
<script defer src='https://static.cloudflareinsights.com/beacon.min.js'
|
||||
data-cf-beacon='{"token": "{{ .token }}"}'
|
||||
></script>
|
||||
<!-- End Cloudflare Web Analytics -->
|
||||
{{ end }}
|
||||
|
||||
{{ with .umami }}
|
||||
<!-- Umami analytics -->
|
||||
<script defer src='{{ or .scheme "https" }}://{{ or .instance "analytics.eu.umami.is" }}/script.js' data-website-id="{{ .id }}"></script>
|
||||
<!-- End Umami analytics -->
|
||||
{{end}}
|
||||
|
||||
{{ with .statcounter }}
|
||||
<!-- Statcounter analytics -->
|
||||
<script type="text/javascript" src="https://www.statcounter.com/counter/counter.js" async></script>
|
||||
<script type="text/javascript">
|
||||
var sc_project = {{ .project }};
|
||||
var sc_invisible = {{ .invisible }};
|
||||
var sc_security = "{{ .security }}";
|
||||
var scJsHost = (("https:" == document.location.protocol) ?
|
||||
"https://www.statcounter.com/js/" : "https://www.statcounter.com/js/");
|
||||
<!-- Piwik/Matomo -->
|
||||
{{ with .matomo }}
|
||||
<!-- Matomo -->
|
||||
<script>
|
||||
var _paq = window._paq = window._paq || [];
|
||||
/* tracker methods like "setCustomDimension" should be called before "trackPageView" */
|
||||
_paq.push(['trackPageView']);
|
||||
_paq.push(['enableLinkTracking']);
|
||||
(function() {
|
||||
var u="//{{ .instance }}/";
|
||||
_paq.push(['setTrackerUrl', u+'matomo.php']);
|
||||
_paq.push(['setSiteId', '{{ .siteId }}']);
|
||||
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
|
||||
g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
|
||||
})();
|
||||
</script>
|
||||
<noscript>
|
||||
<div class="statcounter"><a title="web counter" href="https://statcounter.com/" target="_blank"><img
|
||||
class="statcounter" src="https://c.statcounter.com/{{ .project }}/0/{{ .security }}/{{ .invisible }}/"
|
||||
alt="web counter" referrerPolicy="no-referrer-when-downgrade"></a></div>
|
||||
<!-- End of Statcounter Code -->
|
||||
</noscript>
|
||||
<!-- End Statcounter analytics -->
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
||||
{{ with .cloudflare }}
|
||||
<!-- Cloudflare Web Analytics -->
|
||||
<script defer src='https://static.cloudflareinsights.com/beacon.min.js'
|
||||
data-cf-beacon='{"token": "{{ .token }}"}'
|
||||
></script>
|
||||
<!-- End Cloudflare Web Analytics -->
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
||||
<!-- Keep backwards compatibility and consistency with HUGO defaults -->
|
||||
{{ if .Site.Config.Services.GoogleAnalytics.ID }}
|
||||
{{ partial "google_analytics.html" . }}
|
||||
{{ if site.GoogleAnalytics }}
|
||||
{{ template "_internal/google_analytics.html" . }}
|
||||
{{ end }}
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
<h5 class="card-title mb-0">{{ .name }}</h5>
|
||||
<div class="sub-title">
|
||||
<span><a href="{{ .organization.url }}" title="{{ .organization.name }}" target="_blank" rel="noopener">{{ .organization.name }}</a></span>
|
||||
<span class="ms-2">{{ .timeline }}</span>
|
||||
<span class="ml-2">{{ .timeline }}</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
|
@ -12,7 +12,7 @@
|
|||
</div>
|
||||
<div class="card-footer">
|
||||
{{ if .certificateURL }}
|
||||
<a class="btn btn-outline-info ms-1 ps-2 mb-2" href="{{ .certificateURL }}" target="_blank" rel="noopener" role="button">{{ i18n "view_certificate"}}</a>
|
||||
<a class="btn btn-outline-info ml-1 pl-2 mb-2" href="{{ .certificateURL }}" target="_blank" rel="noopener" role="button">{{ i18n "view_certificate"}}</a>
|
||||
{{ end }}
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
@ -1,26 +1,24 @@
|
|||
<div class="post-card">
|
||||
<div class="card">
|
||||
<div class="card-head">
|
||||
<a href="{{ .RelPermalink | relLangURL }}" class="post-card-link">
|
||||
<a href="{{ .RelPermalink | relLangURL }}" class="post-card-link">
|
||||
<div class="card">
|
||||
<div class="card-head">
|
||||
<img class="card-img-top" src='{{ partial "helpers/get-hero.html" . }}' alt="Hero Image">
|
||||
</a>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<a href="{{ .RelPermalink | relLangURL }}" class="post-card-link">
|
||||
</div>
|
||||
<div class="card-body">
|
||||
<h5 class="card-title">{{ .Title }}</h5>
|
||||
<p class="card-text post-summary">{{ .Summary | plainify }}</p>
|
||||
</a>
|
||||
{{ if and site.Params.features.tags.enable site.Params.features.tags.on_card }}
|
||||
{{ partial "misc/tags.html" .Params.tags }}
|
||||
{{ end }}
|
||||
<p class="card-text post-summary">{{ .Summary }}</p>
|
||||
{{ if and site.Params.features.tags.enable site.Params.features.tags.on_card }}
|
||||
{{ partial "misc/tags.html" .Params.tags }}
|
||||
{{ end }}
|
||||
</div>
|
||||
<div class="card-footer">
|
||||
<span class="float-left">
|
||||
{{ .Date | time.Format ":date_full" }}
|
||||
{{ if site.Params.features.readingTime }} | {{.ReadingTime}} {{ i18n "minute" .ReadingTime }} {{ end }}</span>
|
||||
<a
|
||||
href="{{ .RelPermalink | relLangURL }}"
|
||||
class="float-right btn btn-outline-info btn-sm">{{ i18n "read" }}</a>
|
||||
</div>
|
||||
</div>
|
||||
<div class="card-footer">
|
||||
<span class="float-start">
|
||||
{{ .Date | time.Format ":date_full" }}
|
||||
{{ if site.Params.features.readingTime }} | {{.ReadingTime}} {{ i18n "minute" .ReadingTime }} {{ end }}</span>
|
||||
<a
|
||||
href="{{ .RelPermalink | relLangURL }}"
|
||||
class="float-end btn btn-outline-info btn-sm">{{ i18n "read" }}</a>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
</div>
|
||||
|
|
|
@ -4,48 +4,26 @@
|
|||
>
|
||||
<div class="card mt-1">
|
||||
<div class="card">
|
||||
<a href="{{ if .repo }}{{ .repo }}{{ else if .url }}{{ .url }}{{ else }}javascript:void(0){{ end }}" {{ if or .repo .url }}target="_blank" rel="noopener"{{ end }}>
|
||||
{{ if .image }}
|
||||
<div class="card-head">
|
||||
{{ $imageImage:= resources.Get .image}}
|
||||
{{ if $imageImage }}
|
||||
<a class="card-header" href="{{ if .repo }}{{ .repo }}{{ else if .url }}{{ .url }}{{ else }}javascript:void(0){{ end }}" {{ if or .repo .url }}target="_blank" rel="noopener"{{ end }}>
|
||||
<div>
|
||||
<div class="d-flex">
|
||||
{{ if .logo }}
|
||||
|
||||
{{ $logoImage:= resources.Get .logo}}
|
||||
{{ if $logoImage }}
|
||||
{{/* svg don't support "Fit" operation */}}
|
||||
{{ if ne $imageImage.MediaType.SubType "svg" }}
|
||||
{{ $imageImage = $imageImage.Fit "1000x1000" }}
|
||||
{{ if ne $logoImage.MediaType.SubType "svg" }}
|
||||
{{ $logoImage = $logoImage.Fit "24x24" }}
|
||||
{{ end }}
|
||||
<img class="card-img-top" src="{{ $imageImage.RelPermalink }}" alt="{{ .name }}" />
|
||||
{{ end }}
|
||||
</div>
|
||||
{{ end }}
|
||||
<div class="card-header">
|
||||
<div>
|
||||
<div class="d-flex">
|
||||
{{ if .logo }}
|
||||
|
||||
{{ if eq (len (findRE ".*/.*" .logo) ) 0 }}
|
||||
|
||||
<i style="padding-right: 0.25em" class="{{.logo}} h4"></i>
|
||||
|
||||
{{ else }}
|
||||
|
||||
{{ $logoImage:= resources.Get .logo}}
|
||||
{{ if $logoImage }}
|
||||
{{/* svg don't support "Fit" operation */}}
|
||||
{{ if ne $logoImage.MediaType.SubType "svg" }}
|
||||
{{ $logoImage = $logoImage.Fit "24x24" }}
|
||||
{{ end }}
|
||||
<img class="card-img-xs" src="{{ $logoImage.RelPermalink }}" alt="{{ .name }}" />
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
|
||||
{{ end }}
|
||||
|
||||
<h5 class="card-title mb-0">{{ .name }}</h5>
|
||||
</div>
|
||||
<div class="sub-title">
|
||||
<span>{{ .role }}</span>
|
||||
<span>{{ .timeline }}</span>
|
||||
</div>
|
||||
<img class="card-img-xs" src="{{ $logoImage.RelPermalink }}" alt="{{ .name }}" />
|
||||
{{ end }}
|
||||
{{ end }}
|
||||
<h5 class="card-title mb-0">{{ .name }}</h5>
|
||||
</div>
|
||||
<div class="sub-title">
|
||||
<span>{{ .role }}</span>
|
||||
<span>{{ .timeline }}</span>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
|
|
|
@ -11,22 +11,12 @@
|
|||
<div class="card-header">
|
||||
<h5 class="card-title mb-0">{{ .title }}</h5>
|
||||
<div class="sub-title">
|
||||
<span>
|
||||
{{ if .publishedIn.url }}
|
||||
<a class="" href="{{.publishedIn.url}}">{{ .publishedIn.name }}</a>
|
||||
{{ else }}
|
||||
<a class="">{{ .publishedIn.name }}</a>
|
||||
{{ end }}
|
||||
</span>
|
||||
<span class="ms-2">{{ .publishedIn.date }}</span>
|
||||
<span><a class="" href="{{.publishedIn.url}}">{{ .publishedIn.name }}</a></span>
|
||||
<span class="ml-2">{{ .publishedIn.date }}</span>
|
||||
</div>
|
||||
<div class="authors">
|
||||
{{ range $index,$author:= .authors }}
|
||||
{{if .url}}
|
||||
<span class="me-2"><a class="" href="{{.url}}">{{ .name }}</a></span>
|
||||
{{ else }}
|
||||
<span class="me-2"><a class="">{{ .name }}</a></span>
|
||||
{{ end }}
|
||||
<span class="mr-2"><a class="" href="{{.url}}">{{ .name }}</a></span>
|
||||
{{ end }}
|
||||
</div>
|
||||
</div>
|
||||
|
@ -36,16 +26,14 @@
|
|||
<div class="card-footer">
|
||||
<div class="tags">
|
||||
{{ range $index,$tag:= .tags }}
|
||||
<span class="btn badge btn-info ms-1 p-2">
|
||||
<span class="btn badge btn-info ml-1 p-2">
|
||||
{{ $tag }}
|
||||
</span>
|
||||
{{ end }}
|
||||
</div>
|
||||
{{ if .paper.url }}
|
||||
<div class="details-btn">
|
||||
<a class="btn btn-outline-info ms-1 ps-2 mb-2" href="{{ .paper.url }}" target="_blank" rel="noopener" role="button">{{ i18n "project_details"}}</a>
|
||||
<a class="btn btn-outline-info ml-1 pl-2 mb-2" href="{{ .paper.url }}" target="_blank" rel="noopener" role="button">{{ i18n "project_details"}}</a>
|
||||
</div>
|
||||
{{ end }}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
@ -1,6 +1,4 @@
|
|||
<div class="col-xs-12 col-sm-6 col-lg-4 pt-2 filtr-item"
|
||||
data-category='all, {{ with .categories }}{{ delimit . ","}}{{ end }}'
|
||||
>
|
||||
<div class="col-xs-12 col-sm-6 col-lg-4 pt-2">
|
||||
<a class="text-decoration-none" {{ if .url }}href="{{ .url }}" title="{{ .name }}" target="_blank" rel="noopener"{{ end }}>
|
||||
<div class="card">
|
||||
<div class="card-head d-flex">
|
||||
|
@ -20,7 +18,7 @@
|
|||
<h5 class="card-title">{{ .name }}</h5>
|
||||
{{ end }}
|
||||
</div>
|
||||
<div class="card-body text-justify pt-1 pb-1">
|
||||
<div class="card-body">
|
||||
<p class="card-text">{{ .summary | markdownify }}</p>
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
@ -66,7 +66,7 @@
|
|||
|
||||
<footer id="footer" class="container-fluid text-center align-content-center footer pb-2">
|
||||
<div class="container pt-5">
|
||||
<div class="row text-start">
|
||||
<div class="row text-left">
|
||||
{{ if $navigationEnabled }}
|
||||
<div class="col-md-4 col-sm-12">
|
||||
<h5>{{ i18n "navigation" }}</h5>
|
||||
|
@ -106,9 +106,7 @@
|
|||
<span><i class="fas fa-envelope"></i></span> <span>{{ $value }}</span>
|
||||
</a></li>
|
||||
{{ else if (eq $key "phone") }}
|
||||
<li><a href={{ printf "tel:%s" $value | safeURL }} target="_blank" rel="noopener">
|
||||
<span><i class="fas fa-phone-alt"></i></span> <span>{{ $value }}</span>
|
||||
</a></li>
|
||||
<li><span><i class="fas fa-phone-alt"></i></span> <span>{{ $value }}</span></li>
|
||||
{{ else if (eq $key "linkedin") }}
|
||||
<li><a href={{ printf "https://www.linkedin.com/in/%s" $value }} target="_blank" rel="noopener">
|
||||
<span><i class="fab fa-linkedin"></i></span> <span>{{ $author.name }}</span>
|
||||
|
@ -117,10 +115,6 @@
|
|||
<li><a href={{ printf "https://github.com/%s" $value }} target="_blank" rel="noopener">
|
||||
<span><i class="fab fa-github"></i></span> <span>{{ $value }}</span>
|
||||
</a></li>
|
||||
{{ else if (eq $key "researchgate") }}
|
||||
<li><a href={{ printf "https://www.researchgate.net/profile/%s" $value }} target="_blank" rel="noopener">
|
||||
<span><i class="fab fa-researchgate"></i></span> <span>{{ $author.name }}</span>
|
||||
</a></li>
|
||||
{{ else if reflect.IsMap $value }}
|
||||
<li>
|
||||
{{ if (and (isset $value "url") (isset $value "icon"))}}
|
||||
|
@ -195,7 +189,7 @@
|
|||
{{ if $credentialsEnabled }}
|
||||
<hr />
|
||||
<div class="container">
|
||||
<div class="row text-start">
|
||||
<div class="row text-left">
|
||||
<div class="col-md-4">
|
||||
<a id="theme" href="https://github.com/hugo-toha/toha" target="_blank" rel="noopener">
|
||||
<img src="{{ $themeLogo }}" alt="Toha Theme Logo">
|
||||
|
@ -203,7 +197,7 @@
|
|||
</a>
|
||||
</div>
|
||||
<div class="col-md-4 text-center">{{ $copyrightNotice | markdownify }}</div>
|
||||
<div class="col-md-4 text-end">
|
||||
<div class="col-md-4 text-right">
|
||||
<a id="hugo" href="https://gohugo.io/" target="_blank" rel="noopener">{{ i18n "hugoAttributionText" }}
|
||||
<img
|
||||
src="{{ $hugoLogo }}"
|
||||
|
|
|
@ -1,22 +0,0 @@
|
|||
{{ if site.Params.features.analytics.enabled }}
|
||||
{{- with site.Params.features.analytics.services.google.id }}
|
||||
{{- if strings.HasPrefix (lower .) "ua-" }}
|
||||
{{- warnf "Google Analytics 4 (GA4) replaced Google Universal Analytics (UA) effective 1 July 2023. See https://support.google.com/analytics/answer/11583528. Create a GA4 property and data stream, then replace the Google Analytics ID in your site configuration with the new value." }}
|
||||
{{- else }}
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id={{ . }}"></script>
|
||||
<script>
|
||||
var doNotTrack = false;
|
||||
if ({{ site.Params.features.analytics.services.google.respectDoNotTrack }}) {
|
||||
var dnt = (navigator.doNotTrack || window.doNotTrack || navigator.msDoNotTrack);
|
||||
var doNotTrack = (dnt == "1" || dnt == "yes");
|
||||
}
|
||||
if (!doNotTrack) {
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag(){dataLayer.push(arguments);}
|
||||
gtag('js', new Date());
|
||||
gtag('config', '{{ . }}');
|
||||
}
|
||||
</script>
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end -}}
|
|
@ -18,7 +18,3 @@
|
|||
|
||||
<link rel="icon" type="image/png" href="{{ $favicon }}" />
|
||||
{{end}}
|
||||
|
||||
{{ with .OutputFormats.Get "rss" -}}
|
||||
{{ printf `<link rel=%q type=%q href=%q title=%q>` .Rel .MediaType.Type .Permalink site.Title | safeHTML }}
|
||||
{{ end }}
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
{{/* Uses the top level site's config for a single author across all locales */}}
|
||||
{{ $authorName:= site.Params.author.name }}
|
||||
|
||||
{{/* Overrides with the locale specific author if provided */}}
|
||||
{{/* Overrides with the locale specifc author if provided */}}
|
||||
{{ if (index site.Data site.Language.Lang).author }}
|
||||
{{ $authorName = (index site.Data site.Language.Lang).author.name }}
|
||||
{{ end }}
|
||||
|
|
|
@ -69,26 +69,15 @@ params:
|
|||
# id: foo
|
||||
# name: bar
|
||||
|
||||
# [Deprecated] The `darkMode` feature
|
||||
# This is a deprecated setting, but has not been removed to maintain backward compatibility
|
||||
# If `theme` is set, the `darkMode` setting will be discarded.
|
||||
darkMode:
|
||||
# The `darkMode` feature
|
||||
darkmode:
|
||||
enable: true
|
||||
|
||||
# The `theme` feature
|
||||
theme:
|
||||
enable: true
|
||||
services:
|
||||
light: true # enable light theme. default "true"
|
||||
dark: true # enable dark theme. default "true"
|
||||
default: system # can be either light, dark or system. default "system"
|
||||
|
||||
This helper will convert the above config into the following env vars:
|
||||
|
||||
* `FEATURE_ANALYTICS=1`
|
||||
* `FEATURE_ANALYTICS_GOOGLE=1`
|
||||
* `FEATURE_DARKMODE=1`
|
||||
* `FEATURE_THEME=1`
|
||||
|
||||
In JS, you can use it like this:
|
||||
|
||||
|
|
|
@ -7,5 +7,5 @@
|
|||
{{- $scss := $template | resources.ExecuteAsTemplate "styles/application.scss" . -}}
|
||||
|
||||
{{/* Bundle application.scss */}}
|
||||
{{- $bundle := $scss | css.Sass $options | fingerprint -}}
|
||||
{{- $bundle := $scss | resources.ToCSS $options | fingerprint -}}
|
||||
<link rel="stylesheet" href="{{ $bundle.RelPermalink }}" integrity="{{ $bundle.Data.Integrity }}" />
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
<div class="tags">
|
||||
<ul style="padding-left: 0;">
|
||||
{{ range . }}
|
||||
{{ $url:= printf "tags/%s/" . }}
|
||||
<li class="rounded"><a href="{{ $url | urlize | relLangURL }}" class="btn btn-sm btn-info">{{ . }}</a></li>
|
||||
{{ end }}
|
||||
</ul>
|
||||
<ul style="padding-left: 0;">
|
||||
{{ range . }}
|
||||
{{ $url:= printf "tags/%s/" . }}
|
||||
<li class="rounded"><a href="{{ $url | urlize | relLangURL }}" class="btn, btn-sm">{{ . }}</a></li>
|
||||
{{ end }}
|
||||
</ul>
|
||||
</div>
|
||||
|
|
|
@ -1,21 +1,21 @@
|
|||
{{ $pageURL:= .RelPermalink }}
|
||||
{{ if hugo.IsMultilingual }}
|
||||
{{ if site.IsMultiLingual }}
|
||||
{{ $pageURL = strings.TrimPrefix (path.Join "/" .Language.Lang) $pageURL }}
|
||||
{{ end }}
|
||||
<li class="nav-item dropdown">
|
||||
<a class="nav-link dropdown-toggle" href="#" id="languageSelector" role="button" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
<a class="nav-link dropdown-toggle" href="#" id="languageSelector" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
{{ if ne site.Params.features.flags.enable false }}
|
||||
{{ $countryCode := partial "helpers/country-code.html" . }}
|
||||
<span class="fi fi-{{$countryCode}}"></span>
|
||||
<span class="flag-icon flag-icon-{{$countryCode}}"></span>
|
||||
{{ end }}
|
||||
{{ site.Language.LanguageName }}
|
||||
</a>
|
||||
<div class="dropdown-menu" aria-labelledby="languageSelector">
|
||||
{{ range site.Home.AllTranslations }}
|
||||
<a class="dropdown-item nav-link languages-item" href="{{ path.Join "/" (cond (eq .Language.Lang $.Sites.Default.Language.Lang) "" .Language.Lang) $pageURL }}">
|
||||
<a class="dropdown-item nav-link languages-item" href="{{ path.Join "/" (cond (eq .Language.Lang "en") "" .Language.Lang) $pageURL }}">
|
||||
{{ if ne site.Params.features.flags.enable false }}
|
||||
{{ $countryCode := partial "helpers/country-code.html" . }}
|
||||
<span class="fi fi-{{$countryCode}}"></span>
|
||||
<span class="flag-icon flag-icon-{{$countryCode}}"></span>
|
||||
{{ end }}
|
||||
{{ .Language.LanguageName }}
|
||||
</a>
|
||||
|
|
|
@ -1,8 +1,6 @@
|
|||
{{/* variables for enabling/disabling various features */}}
|
||||
{{ $blogEnabled := site.Params.features.blog.enable | default false }}
|
||||
{{ $blogTitle := site.Params.features.blog.title | default (i18n "posts") }}
|
||||
{{ $notesEnabled := site.Params.features.notes.enable | default false }}
|
||||
{{ $notesTitle := site.Params.features.notes.title | default (i18n "notes") }}
|
||||
{{ $maxVisibleSections := site.Params.topNavbar.maxVisibleSections | default 5 }}
|
||||
|
||||
{{/* keep backward compatibility for blog post */}}
|
||||
|
@ -13,7 +11,6 @@
|
|||
{{/* by default, don't use any logo */}}
|
||||
{{ $mainLogo := "" }}
|
||||
{{ $invertedLogo := "" }}
|
||||
{{ $darkLogo := "" }}
|
||||
|
||||
{{/* if custom logo has been provided, use them */}}
|
||||
{{ if site.Params.logo.main }}
|
||||
|
@ -22,14 +19,11 @@
|
|||
{{ if site.Params.logo.inverted }}
|
||||
{{ $invertedLogo = site.Params.logo.inverted }}
|
||||
{{ end }}
|
||||
{{ if site.Params.logo.dark }}
|
||||
{{ $darkLogo = site.Params.logo.dark }}
|
||||
{{ end }}
|
||||
|
||||
{{/* resize the logos. don't resize svg because it is not supported */}}
|
||||
{{ if $mainLogo }}
|
||||
{{ $mainLogo = resources.Get $mainLogo}}
|
||||
{{ if and $mainLogo (not (or (eq $mainLogo.MediaType.SubType "svg") (eq $mainLogo.MediaType.SubType "gif"))) }}
|
||||
{{ if and $mainLogo (ne $mainLogo.MediaType.SubType "svg") }}
|
||||
{{ $mainLogo = $mainLogo.Resize "42x" }}
|
||||
{{ end }}
|
||||
{{ $mainLogo = $mainLogo.RelPermalink}}
|
||||
|
@ -37,20 +31,12 @@
|
|||
|
||||
{{ if $invertedLogo }}
|
||||
{{ $invertedLogo = resources.Get $invertedLogo}}
|
||||
{{ if and $invertedLogo (not (or (eq $invertedLogo.MediaType.SubType "svg") (eq $invertedLogo.MediaType.SubType "gif"))) }}
|
||||
{{ if and $invertedLogo (ne $invertedLogo.MediaType.SubType "svg")}}
|
||||
{{ $invertedLogo = $invertedLogo.Resize "42x" }}
|
||||
{{ end }}
|
||||
{{ $invertedLogo = $invertedLogo.RelPermalink}}
|
||||
{{ end }}
|
||||
|
||||
{{ if $darkLogo }}
|
||||
{{ $darkLogo = resources.Get $darkLogo}}
|
||||
{{ if and $darkLogo (not (or (eq $darkLogo.MediaType.SubType "svg") (eq $darkLogo.MediaType.SubType "gif"))) }}
|
||||
{{ $darkLogo = $darkLogo.Resize "42x" }}
|
||||
{{ end }}
|
||||
{{ $darkLogo = $darkLogo.RelPermalink}}
|
||||
{{ end }}
|
||||
|
||||
{{ $logo := $mainLogo }}
|
||||
{{ if .IsHome }}
|
||||
{{ $logo = $invertedLogo }}
|
||||
|
@ -66,11 +52,6 @@
|
|||
{{ $sections = (index site.Data site.Language.Lang).sections }}
|
||||
{{ end }}
|
||||
|
||||
{{ $navBarTitle := (index site.Data site.Language.Lang).site.navBarTitle }}
|
||||
{{ if not $navBarTitle }}
|
||||
{{ $navBarTitle = site.Title }}
|
||||
{{ end }}
|
||||
|
||||
<nav class="navbar navbar-expand-xl top-navbar shadow {{ if .IsHome}}transparent-navbar homepage{{end}}" id="top-navbar">
|
||||
<div class="container">
|
||||
{{ if not .IsHome }}
|
||||
|
@ -82,21 +63,21 @@
|
|||
{{ if $logo }}
|
||||
<img src="{{ $logo }}" id="logo" alt="Logo">
|
||||
{{ end }}
|
||||
{{- $navBarTitle -}}
|
||||
{{- site.Title -}}
|
||||
</a>
|
||||
<button
|
||||
class="navbar-toggler {{if .IsHome}}navbar-dark{{else}}navbar-light{{end}}"
|
||||
id="navbar-toggler"
|
||||
type="button"
|
||||
data-bs-toggle="collapse"
|
||||
data-bs-target="#top-nav-items"
|
||||
data-toggle="collapse"
|
||||
data-target="#top-nav-items"
|
||||
aria-label="menu"
|
||||
>
|
||||
<i data-feather="menu"></i>
|
||||
</button>
|
||||
|
||||
<div class="collapse navbar-collapse dynamic-navbar" id="top-nav-items">
|
||||
<ul class="nav navbar-nav ms-auto">
|
||||
<ul class="nav navbar-nav ml-auto">
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="{{ if .IsHome }}#home{{else}}{{ site.BaseURL | relLangURL }}#home{{end}}">{{ i18n "home" }}</a>
|
||||
</li>
|
||||
|
@ -114,7 +95,7 @@
|
|||
{{- end }}
|
||||
{{ if gt $sectionCount $maxVisibleSections }}
|
||||
<li class="nav-item dropdown">
|
||||
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">{{i18n "more" }}</a>
|
||||
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">{{i18n "more" }}</a>
|
||||
<div class="dropdown-menu" aria-labelledby="navbarDropdown">
|
||||
{{ $sectionCount := 1 }}
|
||||
{{ range sort $sections "section.weight" }}
|
||||
|
@ -135,12 +116,12 @@
|
|||
{{ end }}
|
||||
{{ if $blogEnabled }}
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" id="blog-link" href="{{ path.Join (site.BaseURL | relLangURL) "posts" }}">{{ $blogTitle }}</a>
|
||||
<a class="nav-link" id="blog-link" href="{{ path.Join (site.BaseURL | relLangURL) "posts" }}">{{ i18n "posts" }}</a>
|
||||
</li>
|
||||
{{ end }}
|
||||
{{ if $notesEnabled }}
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" id="note-link" href="{{ path.Join (site.BaseURL | relLangURL) "notes" }}">{{ $notesTitle }}</a>
|
||||
<a class="nav-link" id="note-link" href="{{ path.Join (site.BaseURL | relLangURL) "notes" }}">{{ i18n "notes" }}</a>
|
||||
</li>
|
||||
{{ end }}
|
||||
{{ range $customMenus }}
|
||||
|
@ -153,7 +134,7 @@
|
|||
{{ if .IsTranslated }}
|
||||
{{ partial "navigators/lang-selector.html" . }}
|
||||
{{ end }}
|
||||
{{ if or site.Params.features.darkMode.enable site.Params.features.theme.enable }}
|
||||
{{ if site.Params.features.darkMode.enable }}
|
||||
{{ partial "navigators/theme-selector.html" . }}
|
||||
{{ end }}
|
||||
</ul>
|
||||
|
@ -166,7 +147,4 @@
|
|||
{{ if $invertedLogo }}
|
||||
<img src="{{ $invertedLogo }}" class="d-none" id="inverted-logo" alt="Inverted Logo">
|
||||
{{ end }}
|
||||
{{ if $darkLogo }}
|
||||
<img src="{{ $darkLogo }}" class="d-none" id="dark-logo" alt="Dark Logo">
|
||||
{{ end }}
|
||||
</nav>
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Add table
Add a link
Reference in a new issue