2020-09-02 17:34:02 +00:00
+++
title = "DeepThought"
description = "A simple blog theme focused on writing powered by Bulma and Zola."
template = "theme.html"
2023-04-17 14:59:14 +00:00
date = 2023-04-16T21:40:29+02:00
2020-09-02 17:34:02 +00:00
[extra]
2023-04-17 14:59:14 +00:00
created = 2023-04-16T21:40:29+02:00
updated = 2023-04-16T21:40:29+02:00
2020-09-02 17:34:02 +00:00
repository = "https://github.com/RatanShreshtha/DeepThought.git"
homepage = "https://github.com/RatanShreshtha/DeepThought"
2022-06-06 08:46:29 +00:00
minimum_version = "0.14.1"
2020-09-02 17:34:02 +00:00
license = "MIT"
2021-02-03 12:13:49 +00:00
demo = "https://deepthought-theme.netlify.app/"
2020-09-02 17:34:02 +00:00
[extra.author]
name = "Ratan Kulshreshtha"
homepage = "https://ratanshreshtha.dev"
+++
2021-09-12 19:44:45 +00:00
< p align = "center" >
< a href = "https://github.com/RatanShreshtha/DeepThought" >
< img src = "static/images/avatar.png" alt = "Logo" width = "80" height = "80" >
< / a >
2020-09-02 17:34:02 +00:00
2021-09-12 19:44:45 +00:00
< h3 align = "center" > DeepThought< / h3 >
2020-09-02 17:34:02 +00:00
2021-09-12 19:44:45 +00:00
< p align = "center" >
A simple blog theme focused on writing powered by Bulma and Zola.
< br / >
< a href = "https://deepthought-theme.netlify.app/docs/" > < strong > Explore the docs »< / strong > < / a >
< br / >
< br / >
< a href = "https://github.com/RatanShreshtha/DeepThought" > Code Repository< / a >
·
< a href = "https://github.com/RatanShreshtha/DeepThought/issues" > Report Bug< / a >
·
< a href = "https://github.com/RatanShreshtha/DeepThought/issues" > Request Feature< / a >
< / p >
< / p >
2020-09-02 17:34:02 +00:00
2021-09-12 19:44:45 +00:00
< details open = "open" >
< summary > < h2 style = "display: inline-block" > Table of Contents< / h2 > < / summary >
< ol >
< li >
< a href = "#about-the-project" > About The Project< / a >
< ul >
< li > < a href = "#built-with" > Built With< / a > < / li >
< / ul >
< / li >
< li >
< a href = "#getting-started" > Getting Started< / a >
< ul >
< li > < a href = "#prerequisites" > Prerequisites< / a > < / li >
< li > < a href = "#installation" > Installation< / a > < / li >
< / ul >
< / li >
< li > < a href = "#usage" > Usage< / a > < / li >
< li > < a href = "#roadmap" > Roadmap< / a > < / li >
< li > < a href = "#contributing" > Contributing< / a > < / li >
< li > < a href = "#license" > License< / a > < / li >
< li > < a href = "#contact" > Contact< / a > < / li >
< li > < a href = "#acknowledgements" > Acknowledgements< / a > < / li >
< / ol >
< / details >
## About The Project
[![DeepThought ](./screenshot.png )](https://deepthought-theme.netlify.app/)
> A simple blog theme focused on writing powered by Bulma and Zola.
### Features
2022-06-06 08:46:29 +00:00
2021-09-12 19:44:45 +00:00
- [x] Dark Mode
- [x] Pagination
- [x] Search
- [x] Charts
- [x] Maps
- [x] Diagrams
- [x] Galleria
- [x] Analytics
- [x] Comments
- [x] Categories
- [x] Social Links
- [x] Multilingual Navbar
- [x] Katex
### Built With
2022-06-06 08:46:29 +00:00
- [Zola ](https://www.getzola.org/ )
- [Bulma ](https://bulma.io/ )
2021-09-12 19:44:45 +00:00
## Getting Started
To get a local copy up and running follow these simple steps.
### Prerequisites
You need static site generator (SSG) [Zola ](https://www.getzola.org/documentation/getting-started/installation/ ) installed in your machine to use this theme follow their guide on [getting started ](https://www.getzola.org/documentation/getting-started/overview/ ).
### Installation
Follow zola's guide on [installing a theme ](https://www.getzola.org/documentation/themes/installing-and-using-themes/ ).
2020-09-02 17:34:02 +00:00
Make sure to add `theme = "DeepThought"` to your `config.toml`
2021-02-18 21:33:11 +00:00
**Check zola version (only 0.9.0+)**
2022-06-06 08:46:29 +00:00
Just to double-check to make sure you have the right version. It is not supported to use this theme with a version under 0.14.1.
2021-09-12 19:44:45 +00:00
## Usage
### How to serve?
2022-06-06 08:46:29 +00:00
2021-09-12 19:44:45 +00:00
Go into your sites directory and type `zola serve` . You should see your new site at `localhost:1111` .
2020-09-02 17:34:02 +00:00
2022-06-06 08:46:29 +00:00
**NOTE**: you must provide the theme options variables in `config.toml` to serve a functioning site
2021-02-18 21:33:11 +00:00
2021-09-12 19:44:45 +00:00
### Deployment
2022-06-06 08:46:29 +00:00
2020-09-02 17:34:02 +00:00
[Zola ](https://www.getzola.org ) already has great documentation for deploying to [Netlify ](https://www.getzola.org/documentation/deployment/netlify/ ) or [Github Pages ](https://www.getzola.org/documentation/deployment/github-pages/ ). I won't bore you with a regurgitated explanation.
2021-09-12 19:44:45 +00:00
### Theme Options
2022-06-06 08:46:29 +00:00
2020-09-02 17:34:02 +00:00
```toml
2022-06-06 08:46:29 +00:00
# Enable external libraries
[extra]
katex.enabled = true
katex.auto_render = true
chart.enabled = true
mermaid.enabled = true
galleria.enabled = true
2021-02-18 21:33:11 +00:00
navbar_items = [
2021-09-12 19:44:45 +00:00
{ code = "en", nav_items = [
{ url = "$BASE_URL/", name = "Home" },
{ url = "$BASE_URL/posts", name = "Posts" },
{ url = "$BASE_URL/docs", name = "Docs" },
{ url = "$BASE_URL/tags", name = "Tags" },
{ url = "$BASE_URL/categories", name = "Categories" },
]},
2021-02-18 21:33:11 +00:00
]
# Add links to favicon, you can use https://realfavicongenerator.net/ to generate favicon for your site
2020-09-02 17:34:02 +00:00
[extra.favicon]
favicon_16x16 = "/icons/favicon-16x16.png"
favicon_32x32 = "/icons/favicon-32x32.png"
apple_touch_icon = "/icons/apple-touch-icon.png"
safari_pinned_tab = "/icons/safari-pinned-tab.svg"
webmanifest = "/icons/site.webmanifest"
# Author details
[extra.author]
name = "DeepThought"
avatar = "/images/avatar.png"
2021-02-18 21:33:11 +00:00
# Social links
2020-09-02 17:34:02 +00:00
[extra.social]
2021-02-18 21:33:11 +00:00
email = "< email_id > "
2020-09-02 17:34:02 +00:00
facebook = "< facebook_username > "
github = "< github_username > "
2021-02-18 21:33:11 +00:00
gitlab = "< gitlab_username > "
2020-09-02 17:34:02 +00:00
keybase = "< keybase_username > "
linkedin = "< linkedin_username > "
stackoverflow = "< stackoverflow_userid > "
twitter = "< twitter_username > "
2022-06-06 08:46:29 +00:00
instagram = "< instagram_username > "
2021-09-12 19:44:45 +00:00
behance = "< behance_username > "
2022-06-06 08:46:29 +00:00
google_scholar = "< googlescholar_userid > "
orcid = "< orcid_userid > "
mastodon = "< mastadon_username > "
2021-09-12 19:44:45 +00:00
2020-09-02 17:34:02 +00:00
# To add google analytics
[extra.analytics]
google = "< your_gtag > "
2021-09-12 19:44:45 +00:00
# To add disqus comments
2020-09-02 17:34:02 +00:00
[extra.commenting]
2021-09-12 19:44:45 +00:00
disqus = "< your_disqus_shortname > "
2020-09-02 17:34:02 +00:00
# To enable mapbox maps
[extra.mapbox]
2022-06-06 08:46:29 +00:00
enabled = true
2020-09-02 17:34:02 +00:00
access_token = "< your_access_token > "
```
2021-09-12 19:44:45 +00:00
#### Multilingual Navbar
If you want to have a multilingual navbar on your blog, you must add your new code language in the [languages ](https://www.getzola.org/documentation/content/multilingual/#configuration ) array in the `config.toml` file.
**NOTE**: Don't add you default language to this array
```toml
languages = [
2022-06-06 08:46:29 +00:00
{code = "fr"},
2021-09-12 19:44:45 +00:00
{code = "es"},
]
```
And then create and array of nav item for each language:
**NOTE**: Include your default language in this array
```toml
navbar_items = [
{ code = "en", nav_items = [
{ url = "$BASE_URL/", name = "Home" },
{ url = "$BASE_URL/posts", name = "Posts" },
{ url = "$BASE_URL/docs", name = "Docs" },
{ url = "$BASE_URL/tags", name = "Tags" },
{ url = "$BASE_URL/categories", name = "Categories" },
]},
{ code = "fr", nav_items = [
{ url = "$BASE_URL/", name = "Connexion" },
]},
{ code = "es", nav_items = [
{ url = "$BASE_URL/", name = "Publicationes" },
{ url = "$BASE_URL/", name = "Registrar" },
]}
]
```
en:
![DeepThought ](./screenshot_navbar_en.png )
fr:
![DeepThought ](./screenshot_navbar_fr.png )
2022-06-06 08:46:29 +00:00
es:
2021-09-12 19:44:45 +00:00
![DeepThought ](./screenshot_navbar_es.png )
### KaTeX math formula support
This theme contains math formula support using [KaTeX ](https://katex.org/ ),
which can be enabled by setting `katex.enabled = true` in the `extra` section
2022-06-06 08:46:29 +00:00
of `config.toml` .
2021-09-12 19:44:45 +00:00
After enabling this extension, the `katex` short code can be used in documents:
2022-06-06 08:46:29 +00:00
- `{{/* katex(body="\KaTeX") */}}` to typeset a math formula inlined into a text,
2021-09-12 19:44:45 +00:00
similar to `$...$` in LaTeX
2022-06-06 08:46:29 +00:00
- `{%/* katex(block=true) */%}\KaTeX{%/* end */%}` to typeset a block of math formulas,
2021-09-12 19:44:45 +00:00
similar to `$$...$$` in LaTeX
#### Automatic rendering without short codes
Optionally, `\\( \KaTeX \\)` / `$ \KaTeX $` inline and `\\[ \KaTeX \\]` / `$$ \KaTeX $$`
2022-06-06 08:46:29 +00:00
block-style automatic rendering is also supported, if enabled in the config
by setting `katex.auto_render = true` .
2021-09-12 19:44:45 +00:00
2022-06-06 08:46:29 +00:00
### Elasticlunr search in other language
Zola use [Elasticlunr.js ](https://github.com/weixsong/elasticlunr.js ) to add full-text search feature.
To use languages other than en (English), you need to add some javascript files. See the Zola's issue [#1349 ](https://github.com/getzola/zola/issues/1349 ).
By placing the `templates/base.html` on your project and using the `other_lang_search_js` block, you can load the required additional javascript files in the right timing.
e.g. `templates/base.html`
```html
{%/* extends "DeepThought/templates/base.html" */%} {%/* block other_lang_search_js */%}
< script src = "{{/* get_url(path='js/lunr.stemmer.support.js') */}}" > < / script >
< script src = "{{/* get_url(path='js/tinyseg.js') */}}" > < / script >
< script src = "{{/* get_url(path='js/lunr.' ~ lang ~ '.js') */}}" > < / script >
< script src = "{{/* get_url(path='js/search.js') */}}" > < / script >
{%/* endblock */%}
2021-09-12 19:44:45 +00:00
```
2022-06-06 08:46:29 +00:00
More detailed explanations are aound in [elasticlunr's documents ](https://github.com/weixsong/elasticlunr.js#other-languages-example-in-browser ).
2021-09-12 19:44:45 +00:00
## Roadmap
See the [open issues ](https://github.com/RatanShreshtha/DeepThought/issues ) for a list of proposed features (and known issues).
## Contributing
Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated** .
1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request
## License
Distributed under the MIT License. See `LICENSE` for more information.
## Contact
Ratan Kulshreshtha - [@RatanShreshtha ](https://twitter.com/RatanShreshtha )>
Project Link: [https://github.com/RatanShreshtha/DeepThought ](https://github.com/RatanShreshtha/DeepThought )
## Acknowledgements
2022-06-06 08:46:29 +00:00
- [GitHub Emoji Cheat Sheet ](https://www.webpagefx.com/tools/emoji-cheat-sheet )
- [Choose an Open Source License ](https://choosealicense.com )
- [Slick Carousel ](https://kenwheeler.github.io/slick )
- [Font Awesome ](https://fontawesome.com )
- [Unsplash ](https://unsplash.com/ )
2020-09-02 17:34:02 +00:00