Initial commit from gatsby: (https://github.com/LekoArts/gatsby-starter-minimal-blog.git)
8
.github/FUNDING.yml
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
# These are supported funding model platforms
|
||||
|
||||
github: [LekoArts]
|
||||
patreon: lekoarts
|
||||
open_collective: # Replace with a single Open Collective username
|
||||
ko_fi: lekoarts
|
||||
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
|
||||
custom: # Replace with a single custom sponsorship URL
|
69
.gitignore
vendored
Normal file
@ -0,0 +1,69 @@
|
||||
# Logs
|
||||
logs
|
||||
*.log
|
||||
npm-debug.log*
|
||||
yarn-debug.log*
|
||||
yarn-error.log*
|
||||
|
||||
# Runtime data
|
||||
pids
|
||||
*.pid
|
||||
*.seed
|
||||
*.pid.lock
|
||||
|
||||
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||
lib-cov
|
||||
|
||||
# Coverage directory used by tools like istanbul
|
||||
coverage
|
||||
|
||||
# nyc test coverage
|
||||
.nyc_output
|
||||
|
||||
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
|
||||
.grunt
|
||||
|
||||
# Bower dependency directory (https://bower.io/)
|
||||
bower_components
|
||||
|
||||
# node-waf configuration
|
||||
.lock-wscript
|
||||
|
||||
# Compiled binary addons (http://nodejs.org/api/addons.html)
|
||||
build/Release
|
||||
|
||||
# Dependency directories
|
||||
node_modules
|
||||
jspm_packages
|
||||
**/node_modules/**
|
||||
|
||||
# Typescript v1 declaration files
|
||||
typings/
|
||||
|
||||
# Optional npm cache directory
|
||||
.npm
|
||||
|
||||
# Optional eslint cache
|
||||
.eslintcache
|
||||
|
||||
# Optional REPL history
|
||||
.node_repl_history
|
||||
|
||||
# Output of 'npm pack'
|
||||
*.tgz
|
||||
|
||||
# Yarn Integrity file
|
||||
.yarn-integrity
|
||||
|
||||
# dotenv environment variables file
|
||||
.env
|
||||
.env.*
|
||||
!.env.example
|
||||
|
||||
.cache
|
||||
**/.cache
|
||||
public
|
||||
|
||||
.idea
|
||||
.vscode
|
||||
.DS_Store
|
310
CHANGELOG.md
Normal file
@ -0,0 +1,310 @@
|
||||
# Change Log
|
||||
|
||||
## 1.3.12
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [[`1598dd6`](https://github.com/LekoArts/gatsby-themes/commit/1598dd660e3ba795b50c4aeb11550806e0b7b6ba)]:
|
||||
- @lekoarts/gatsby-theme-minimal-blog@4.0.0
|
||||
|
||||
## 1.3.11
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies [[`1785dcf`](https://github.com/LekoArts/gatsby-themes/commit/1785dcfad131ab9270c401e6a3bb450f7cb01288)]:
|
||||
- @lekoarts/gatsby-theme-minimal-blog@3.0.0
|
||||
|
||||
## 1.3.10
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- [`716fde2`](https://github.com/LekoArts/gatsby-themes/commit/716fde287d20e80e834d451825b55af249e0168a) [#579](https://github.com/LekoArts/gatsby-themes/pull/579) Thanks [@LekoArts](https://github.com/LekoArts)! - chore: Add gatsby-plugin-gatsby-cloud to starters
|
||||
|
||||
All notable changes to this project will be documented in this file.
|
||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||
|
||||
## [1.3.9](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.8...minimal-blog@1.3.9) (2020-11-11)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.8](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.7...minimal-blog@1.3.8) (2020-11-04)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.7](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.6...minimal-blog@1.3.7) (2020-11-02)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.6](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.5...minimal-blog@1.3.6) (2020-11-01)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.5](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.4...minimal-blog@1.3.5) (2020-10-25)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.4](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.3...minimal-blog@1.3.4) (2020-10-25)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.3](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.2...minimal-blog@1.3.3) (2020-10-25)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.2](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.1...minimal-blog@1.3.2) (2020-10-10)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.3.1](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.3.0...minimal-blog@1.3.1) (2020-09-25)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
# [1.3.0](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.7...minimal-blog@1.3.0) (2020-09-25)
|
||||
|
||||
### Features
|
||||
|
||||
- **minimal-blog:** Add Canonical URL support ([#494](https://github.com/LekoArts/gatsby-themes/issues/494)) ([0e9d7ac](https://github.com/LekoArts/gatsby-themes/commit/0e9d7ac04fdf9a7d30cca8c7ccf7565d3955502f))
|
||||
|
||||
## [1.2.7](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.6...minimal-blog@1.2.7) (2020-09-25)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.2.6](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.5...minimal-blog@1.2.6) (2020-09-16)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.2.5](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.4...minimal-blog@1.2.5) (2020-09-10)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.2.4](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.3...minimal-blog@1.2.4) (2020-08-28)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.2.3](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.2...minimal-blog@1.2.3) (2020-08-27)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.2.2](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.1...minimal-blog@1.2.2) (2020-08-27)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.2.1](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.2.0...minimal-blog@1.2.1) (2020-08-27)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
# [1.2.0](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.13...minimal-blog@1.2.0) (2020-07-09)
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
- **minimal-blog:** Use function for SpotifyPlayer example component ([bd2c343](https://github.com/LekoArts/gatsby-themes/commit/bd2c343580c041383a98822de2c622a7d944d93d))
|
||||
|
||||
### Features
|
||||
|
||||
- Add bundle-analyzer and lazy-load react-live ([#450](https://github.com/LekoArts/gatsby-themes/issues/450)) ([667fd33](https://github.com/LekoArts/gatsby-themes/commit/667fd33ce6af546cf2250af1e22395a26f45d6a2))
|
||||
|
||||
## [1.1.13](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.12...minimal-blog@1.1.13) (2020-07-09)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.12](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.11...minimal-blog@1.1.12) (2020-07-04)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.11](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.10...minimal-blog@1.1.11) (2020-07-03)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.10](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.9...minimal-blog@1.1.10) (2020-07-02)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.9](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.8...minimal-blog@1.1.9) (2020-06-11)
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
- Normalize CSS in themes & examples ([#422](https://github.com/LekoArts/gatsby-themes/issues/422)) ([9a2600c](https://github.com/LekoArts/gatsby-themes/commit/9a2600cc45d0f6729799183116f1b87d3c943749))
|
||||
|
||||
## [1.1.8](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.7...minimal-blog@1.1.8) (2020-06-11)
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
- **gatsby-theme-minimal-blog:** font-size on mobile iOS ([#421](https://github.com/LekoArts/gatsby-themes/issues/421)) ([ab65ecc](https://github.com/LekoArts/gatsby-themes/commit/ab65ecceaabefc0f2f77c6f9602280a7214c34d1))
|
||||
|
||||
## [1.1.7](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.6...minimal-blog@1.1.7) (2020-06-08)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.6](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.5...minimal-blog@1.1.6) (2020-05-29)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.5](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.4...minimal-blog@1.1.5) (2020-05-12)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.4](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.3...minimal-blog@1.1.4) (2020-05-04)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.3](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.2...minimal-blog@1.1.3) (2020-05-02)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.2](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.1...minimal-blog@1.1.2) (2020-05-02)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.1.1](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.1.0...minimal-blog@1.1.1) (2020-04-28)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
# [1.1.0](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.17...minimal-blog@1.1.0) (2020-04-27)
|
||||
|
||||
### Features
|
||||
|
||||
- Update theme-ui to v0.3.x ([#371](https://github.com/LekoArts/gatsby-themes/issues/371)) ([67a05ac](https://github.com/LekoArts/gatsby-themes/commit/67a05ac3e1deaddfe38591739e7f50f56d49d109)), closes [/theme-ui.com/migrating#v03](https://github.com//theme-ui.com/migrating/issues/v03) [#262](https://github.com/LekoArts/gatsby-themes/issues/262)
|
||||
|
||||
## [1.0.17](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.16...minimal-blog@1.0.17) (2020-04-24)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.16](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.15...minimal-blog@1.0.16) (2020-04-24)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.15](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.14...minimal-blog@1.0.15) (2020-04-13)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.14](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.13...minimal-blog@1.0.14) (2020-04-13)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.13](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.12...minimal-blog@1.0.13) (2020-04-12)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.12](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.11...minimal-blog@1.0.12) (2020-04-12)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.11](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.10...minimal-blog@1.0.11) (2020-04-12)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.10](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.9...minimal-blog@1.0.10) (2020-04-01)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.9](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.8...minimal-blog@1.0.9) (2020-03-31)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.8](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.7...minimal-blog@1.0.8) (2020-03-04)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.7](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.6...minimal-blog@1.0.7) (2020-03-04)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.6](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.5...minimal-blog@1.0.6) (2020-02-29)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.5](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.4...minimal-blog@1.0.5) (2020-02-29)
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
- Add table styles to minimal-blog ([6e3d750](https://github.com/LekoArts/gatsby-themes/commit/6e3d750b01d0398fc2dd5b3d043754389a0f46ff))
|
||||
|
||||
## [1.0.4](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.3...minimal-blog@1.0.4) (2020-02-27)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.3](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.2...minimal-blog@1.0.3) (2020-02-27)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.2](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.1...minimal-blog@1.0.2) (2020-02-16)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [1.0.1](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@1.0.0...minimal-blog@1.0.1) (2020-01-23)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
# [1.0.0](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.2.1...minimal-blog@1.0.0) (2020-01-23)
|
||||
|
||||
### Features
|
||||
|
||||
- Change config format on minimal-blog theme ([#234](https://github.com/LekoArts/gatsby-themes/issues/234)) ([bdeb670](https://github.com/LekoArts/gatsby-themes/commit/bdeb670797da5faa2d4084c3c128f0e38dbbf582))
|
||||
|
||||
### BREAKING CHANGES
|
||||
|
||||
- The navigation and externalLinks options are no longer on the siteMetadata but now in the theme options itself.
|
||||
|
||||
## [0.2.1](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.2.0...minimal-blog@0.2.1) (2020-01-17)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
# [0.2.0](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.8...minimal-blog@0.2.0) (2020-01-07)
|
||||
|
||||
### Features
|
||||
|
||||
- **gatsby-theme-minimal-blog-core:** Custom slug for blog posts via frontmatter ([05cff1e](https://github.com/LekoArts/gatsby-themes/commit/05cff1ec0bcd2ba2fb3b7cfbb8a55f626ab9abd8)), closes [#217](https://github.com/LekoArts/gatsby-themes/issues/217)
|
||||
|
||||
## [0.1.8](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.7...minimal-blog@0.1.8) (2020-01-06)
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
- **gatsby-theme-minimal-blog:** Styling fixes ([240571e](https://github.com/LekoArts/gatsby-themes/commit/240571e39a4b12d6b6585c89062579dd2dc03a0f))
|
||||
|
||||
## [0.1.7](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.6...minimal-blog@0.1.7) (2020-01-04)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.1.6](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.5...minimal-blog@0.1.6) (2020-01-03)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.1.5](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.4...minimal-blog@0.1.5) (2019-12-31)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.1.4](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.3...minimal-blog@0.1.4) (2019-12-03)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.1.3](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.2...minimal-blog@0.1.3) (2019-12-01)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.1.2](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.1...minimal-blog@0.1.2) (2019-11-27)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.1.1](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.1.0...minimal-blog@0.1.1) (2019-11-26)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
# [0.1.0](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.0.4...minimal-blog@0.1.0) (2019-11-25)
|
||||
|
||||
### Features
|
||||
|
||||
- **gatsby-theme-minimal-blog:** Lazy load code component ([#167](https://github.com/LekoArts/gatsby-themes/issues/167)) ([fbfedee](https://github.com/LekoArts/gatsby-themes/commit/fbfedee5988636d2e4a3a2ea817e8bdf8628d4f5)), closes [#161](https://github.com/LekoArts/gatsby-themes/issues/161) [#163](https://github.com/LekoArts/gatsby-themes/issues/163) [#164](https://github.com/LekoArts/gatsby-themes/issues/164) [#165](https://github.com/LekoArts/gatsby-themes/issues/165) [#166](https://github.com/LekoArts/gatsby-themes/issues/166)
|
||||
|
||||
## [0.0.4](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.0.3...minimal-blog@0.0.4) (2019-11-16)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## [0.0.3](https://github.com/LekoArts/gatsby-themes/compare/minimal-blog@0.0.2...minimal-blog@0.0.3) (2019-11-16)
|
||||
|
||||
**Note:** Version bump only for package minimal-blog
|
||||
|
||||
## 0.0.2 (2019-11-16)
|
||||
|
||||
### Features
|
||||
|
||||
- Add gatsby-theme-minimal-blog ([#151](https://github.com/LekoArts/gatsby-themes/issues/151)) ([344a52c](https://github.com/LekoArts/gatsby-themes/commit/344a52c))
|
14
LICENSE
Normal file
@ -0,0 +1,14 @@
|
||||
The BSD Zero Clause License (0BSD)
|
||||
|
||||
Copyright (c) 2020 LekoArts
|
||||
|
||||
Permission to use, copy, modify, and/or distribute this software for any
|
||||
purpose with or without fee is hereby granted.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
||||
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
||||
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
||||
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
PERFORMANCE OF THIS SOFTWARE.
|
286
README.md
Executable file
@ -0,0 +1,286 @@
|
||||
<p align="center">
|
||||
<a href="https://minimal-blog.lekoarts.de">
|
||||
<img alt="LekoArts" src="https://img.lekoarts.de/gatsby/gatsby-site-illustration.png" />
|
||||
</a>
|
||||
</p>
|
||||
<h1 align="center">
|
||||
Gatsby Starter: Minimal Blog
|
||||
</h1>
|
||||
|
||||
<p align="center">
|
||||
<a href="https://github.com/LekoArts/gatsby-starter-minimal-blog/blob/master/LICENSE">
|
||||
<img src="https://img.shields.io/badge/license-0BSD-blue.svg" alt="Minimal Blog is released under the 0BSD license." />
|
||||
</a>
|
||||
<a href="https://github.com/sponsors/LekoArts">
|
||||
<img alt="GitHub Sponsors" src="https://img.shields.io/github/sponsors/LekoArts">
|
||||
</a>
|
||||
<a href="https://www.lekoarts.de?utm_source=minimal-blog&utm_medium=Starter">
|
||||
<img alt="Website" src="https://img.shields.io/badge/-website-blue">
|
||||
</a>
|
||||
<a href="https://twitter.com/intent/follow?screen_name=lekoarts_de">
|
||||
<img src="https://img.shields.io/twitter/follow/lekoarts_de.svg?label=Follow%20@lekoarts_de" alt="Follow @lekoarts_de" />
|
||||
</a>
|
||||
</p>
|
||||
|
||||
Typography driven, feature-rich blogging theme with minimal aesthetics. Includes tags/categories support and extensive features for code blocks such as live preview, line numbers, and line highlighting. Using the Gatsby Theme [`@lekoarts/gatsby-theme-minimal-blog`](https://github.com/LekoArts/gatsby-themes/tree/main/themes/gatsby-theme-minimal-blog).
|
||||
|
||||
[**Demo Website**](https://minimal-blog.lekoarts.de)
|
||||
|
||||
Also be sure to check out other [Free & Open Source Gatsby Themes](https://themes.lekoarts.de) and my [Personal Website](https://www.lekoarts.de?utm_source=minimal-blog&utm_medium=Starter).
|
||||
|
||||
## ✨ Features
|
||||
|
||||
- MDX
|
||||
- Fully customizable through the usage of Gatsby Themes (and Theme UI)
|
||||
- Light Mode / Dark Mode
|
||||
- Typography driven, minimal style
|
||||
- Tags/Categories support
|
||||
- Code highlighting with [prism-react-renderer](https://github.com/FormidableLabs/prism-react-renderer) and [react-live](https://github.com/FormidableLabs/react-live) support. Also allows adding line numbers, line highlighting, language tabs, and file titles.
|
||||
- RSS Feed for blog posts
|
||||
- SEO (Sitemap, OpenGraph tags, Twitter tags)
|
||||
- WebApp Manifest
|
||||
|
||||
## 🚀 Getting Started
|
||||
|
||||
[<img src="https://www.gatsbyjs.com/deploynow.svg" alt="Deploy to Gatsby Cloud">](https://www.gatsbyjs.com/dashboard/deploynow?url=https://github.com/LekoArts/gatsby-starter-minimal-blog)
|
||||
|
||||
### 1. **Create a Gatsby site.**
|
||||
|
||||
Use `git` to clone the site and navigate into it:
|
||||
|
||||
```sh
|
||||
git clone https://github.com/LekoArts/gatsby-starter-minimal-blog project-name
|
||||
cd project-name
|
||||
```
|
||||
|
||||
### 2. **Install dependencies.**
|
||||
|
||||
If you use npm 7 or above use the `--legacy-peer-deps` flag. If you use npm 6 you can use `npm install`.
|
||||
|
||||
```sh
|
||||
npm install --legacy-peer-deps
|
||||
```
|
||||
|
||||
### 3. **Open the code and start customizing!**
|
||||
|
||||
Start the site by running `npm run develop`.
|
||||
|
||||
Your site is now running at `http://localhost:8000`!
|
||||
|
||||
If you want to learn more about how you can use a Gatsby starter that is configured with a Gatsby theme, you can check out this [shorter](https://www.gatsbyjs.com/docs/how-to/plugins-and-themes/using-a-gatsby-theme/) or [longer](https://www.gatsbyjs.com/tutorial/using-a-theme/) tutorial. The tutorials don't exactly apply to this starter however the concepts are the same.
|
||||
|
||||
## 📝 Using and modifying this starter
|
||||
|
||||
**Important Note:** Please read the guide [Shadowing in Gatsby Themes](https://www.gatsbyjs.com/docs/how-to/plugins-and-themes/shadowing/) to understand how to customize the underlying theme!
|
||||
|
||||
This starter creates a new Gatsby site that installs and configures the theme [`@lekoarts/gatsby-theme-minimal-blog`](https://github.com/LekoArts/gatsby-themes/tree/main/themes/gatsby-theme-minimal-blog).
|
||||
|
||||
Have a look at the theme's README and files to see what options are available and how you can shadow the various components including Theme UI. Generally speaking you will want to place your files into `src/@lekoarts/gatsby-theme-minimal-blog/` to shadow/override files. The Theme UI config can be configured by shadowing its files in `src/gatsby-plugin-theme-ui/`.
|
||||
|
||||
### Code Highlighting
|
||||
|
||||
Since the underlying theme ships with [prism-react-renderer](https://github.com/FormidableLabs/prism-react-renderer) and [react-live](https://github.com/FormidableLabs/react-live) certain additional features were added to code blocks. You can find an overview / usage example in the [example repository](https://github.com/LekoArts/gatsby-themes/tree/main/examples/minimal-blog/content/posts/fantastic-beasts-and-where-to-find-them/index.mdx)! If you want to change certain code styles or add additional language tabs, you need to shadow the file `src/@lekoarts/gatsby-theme-minimal-blog/styles/code.js`.
|
||||
|
||||
**Language tabs:**
|
||||
|
||||
When you add a language (such as e.g. `js` or `javascript`) to the code block, a little tab will appear at the top left corner.
|
||||
|
||||
````
|
||||
```js
|
||||
// code goes here
|
||||
```
|
||||
````
|
||||
|
||||
**Code titles:**
|
||||
|
||||
You can display a title (e.g. the file path) above the code block.
|
||||
|
||||
````
|
||||
```jsx:title=your-title
|
||||
// code goes here
|
||||
```
|
||||
````
|
||||
|
||||
Or without a specific language:
|
||||
|
||||
````
|
||||
```:title=your-title
|
||||
// code goes here
|
||||
```
|
||||
````
|
||||
|
||||
**Line highlighting:**
|
||||
|
||||
You can highlight single or multiple (or both) lines in a code block. You need to add a language.
|
||||
|
||||
````
|
||||
```js {2,4-5}
|
||||
const test = 3
|
||||
const foo = 'bar'
|
||||
const harry = 'potter'
|
||||
const hermione = 'granger'
|
||||
const ron = 'weasley'
|
||||
```
|
||||
````
|
||||
|
||||
**Hide line numbers:**
|
||||
|
||||
If you want to hide line numbers you can either globally disable them (see Theme options) or on a block-by-block basis. You can also combine that with the other attributes.
|
||||
|
||||
````
|
||||
```noLineNumbers
|
||||
// code goes here
|
||||
```
|
||||
````
|
||||
|
||||
**react-live:**
|
||||
|
||||
Add `react-live` to the code block (and render the component) to see a preview below it.
|
||||
|
||||
````
|
||||
```js react-live
|
||||
const onClick = () => {
|
||||
alert("You opened me");
|
||||
};
|
||||
render(<button onClick={onClick}>Alohomora!</button>);
|
||||
```
|
||||
````
|
||||
|
||||
### Adding content
|
||||
|
||||
#### Adding a new blog post
|
||||
|
||||
New blog posts will be shown on the index page (the three most recent ones) of this theme and on the blog overview page. They can be added by creating MDX files inside `content/posts`. General setup:
|
||||
|
||||
1. Create a new folder inside `content/posts`
|
||||
1. Create a new `index.mdx` file, and add the frontmatter
|
||||
1. Add images to the created folder (from step 1) you want to reference in your blog post
|
||||
1. Reference an image as your `banner` in the frontmatter
|
||||
1. Write your content below the frontmatter
|
||||
1. Add a `slug` to the frontmatter to use a custom slug, e.g. `slug: "/my-slug"` (Optional)
|
||||
1. Use `defer` to opt-in into Deferred Static Generation (DSG) (optional)
|
||||
|
||||
**Frontmatter reference:**
|
||||
|
||||
```md
|
||||
---
|
||||
title: Introduction to "Defence against the Dark Arts"
|
||||
date: 2019-11-07
|
||||
description: Defence Against the Dark Arts (abbreviated as DADA) is a subject taught at Hogwarts School of Witchcraft and Wizardry and Ilvermorny School of Witchcraft and Wizardry.
|
||||
defer: false
|
||||
tags:
|
||||
- Tutorial
|
||||
- Dark Arts
|
||||
banner: ./defence-against-the-dark-arts.jpg
|
||||
canonicalUrl: https://random-blog-about-curses.com/curses-counter-curses-and-more
|
||||
---
|
||||
```
|
||||
|
||||
**The fields `description`, `banner`, `defer` and `canonicalUrl` are optional!** If no description is provided, an excerpt of the blog post will be used. If no banner is provided, the default `siteImage` (from `siteMetadata`) is used. If no `canonicalUrl` is provided, it will not be included in the header.
|
||||
|
||||
The `date` field has to be written in the format `YYYY-MM-DD`!
|
||||
|
||||
#### Adding a new page
|
||||
|
||||
Additional pages can be created by placing MDX files inside `contents/pages`, e.g. an "About" or "Contact" page. You'll manually need to link to those pages, for example by adding them to the navigation (in `siteMetadata`). General instructions:
|
||||
|
||||
1. Create a new folder inside `content/pages`
|
||||
1. Create a new `index.mdx` file, and add the frontmatter
|
||||
1. Write your content below the frontmatter
|
||||
1. Optionally add files/images to the folder you want to reference from the page
|
||||
1. Use `defer` to opt-in into Deferred Static Generation (DSG) (optional)
|
||||
|
||||
**Frontmatter reference:**
|
||||
|
||||
```md
|
||||
---
|
||||
title: About
|
||||
slug: "/about"
|
||||
defer: false
|
||||
---
|
||||
```
|
||||
|
||||
### Changing the "Hero" text
|
||||
|
||||
To edit the hero text ("Hi, I'm Lupin...), create a file at `src/@lekoarts/gatsby-theme-minimal-blog/texts/hero.mdx` to edit the text.
|
||||
|
||||
### Changing the "Projects" part
|
||||
|
||||
To edit the projects part below "Latest posts", create a file at `src/@lekoarts/gatsby-theme-minimal-blog/texts/bottom.mdx` to edit the contents.
|
||||
|
||||
### Extending the footer of the post
|
||||
|
||||
Inside the [`<Post />` component](https://github.com/LekoArts/gatsby-themes/blob/main/themes/gatsby-theme-minimal-blog/src/components/post.tsx) there's also a `<PostFooter />` component that you can shadow to display elements between the end of the post and the global footer. By default it returns `null`. Create a file at `src/@lekoarts/gatsby-theme-minimal-blog/components/post-footer.jsx` to edit this section. The `<PostFooter />` component receives the complete `post` prop that `<Post />` also receives.
|
||||
|
||||
### Changing your fonts
|
||||
|
||||
By default, the underlying theme and thus this starter uses "IBM Plex Sans" as its font. It's used throughout the site and set as a `font-family` on the `html` element.
|
||||
|
||||
If you want to change your default font or add any additional fonts, you'll need to change two things:
|
||||
|
||||
1. The configuration for `gatsby-omni-font-loader` => Responsible for loading the font CSS files
|
||||
1. The Theme UI config and its `fonts` key (see [Theme UI Typography Docs](https://theme-ui.com/theming#typography)) => Responsible for setting the `font-family` in the example
|
||||
|
||||
After adjusting the configuration for `gatsby-omni-font-loader` you'll need to shadow the theme's Theme UI config and overwrite the `fonts` key. For the sake of this explanation it's assumed that you replaced "IBM Plex Sans" with "Roboto Mono".
|
||||
|
||||
Create a file at `src/gatsby-plugin-theme-ui/index.js` with the following contents:
|
||||
|
||||
```js
|
||||
import { merge } from "theme-ui";
|
||||
import originalTheme from "@lekoarts/gatsby-theme-minimal-blog/src/gatsby-plugin-theme-ui/index";
|
||||
|
||||
const theme = merge(originalTheme, {
|
||||
fonts: {
|
||||
body: `"Roboto Mono", monospace`,
|
||||
},
|
||||
});
|
||||
|
||||
export default theme;
|
||||
```
|
||||
|
||||
As defined in the [Theme Specification](https://theme-ui.com/theme-spec#typography) `body` is the default body font family.
|
||||
|
||||
**Another example:** You didn't replace "IBM Plex Sans" but added "Roboto Mono" additionally since you want to use it for your headings.
|
||||
|
||||
Then you'd not overwrite `body` but add a `heading` key:
|
||||
|
||||
```js
|
||||
import { merge } from "theme-ui";
|
||||
import originalTheme from "@lekoarts/gatsby-theme-minimal-blog/src/gatsby-plugin-theme-ui/index";
|
||||
|
||||
const theme = merge(originalTheme, {
|
||||
fonts: {
|
||||
heading: `"Roboto Mono", monospace`,
|
||||
},
|
||||
});
|
||||
|
||||
export default theme;
|
||||
```
|
||||
|
||||
### Change your `static` folder
|
||||
|
||||
The `static` folder contains the icons, social media images and `robots.txt`. Don't forget to change these files, too! You can use [Real Favicon Generator](https://realfavicongenerator.net/) to generate the image files inside `static`.
|
||||
|
||||
## 🤔 Questions or problems?
|
||||
|
||||
If you have general questions or need help with Gatsby, please go to one of the [support platforms](https://www.gatsbyjs.com/contributing/community/#where-to-get-support) mentioned in Gatsby's documentation. If you have a specific question about this project, you can head to the [GitHub Discussions](https://github.com/LekoArts/gatsby-themes/discussions) of the repository.
|
||||
|
||||
## 🎓 Learning Gatsby
|
||||
|
||||
Looking for more guidance? Full documentation for Gatsby lives [on Gatsby's website](https://www.gatsbyjs.com/).
|
||||
|
||||
### Themes
|
||||
|
||||
To learn more about Gatsby themes specifically, I recommend checking out the [theme docs](https://www.gatsbyjs.com/docs/themes/).
|
||||
|
||||
### General
|
||||
|
||||
- **For most developers, I recommend starting with the [in-depth tutorial for creating a site with Gatsby](https://www.gatsbyjs.com/docs/tutorial/).** It starts with zero assumptions about your level of ability and walks through every step of the process.
|
||||
|
||||
- **To dive straight into code samples, head [to Gatsby's documentation](https://www.gatsbyjs.com/docs/).** In particular, check out the _How-to Guides_ and _Reference_ items in the primary navigation.
|
||||
|
||||
## 🌟 Supporting me
|
||||
|
||||
Thanks for using this project! I'm always interested in seeing what people do with my projects, so don't hesitate to tag me on [Twitter](https://twitter.com/lekoarts_de) and share the project with me.
|
||||
|
||||
Please star this project, share it on Social Media or consider supporting me on [Patreon](https://www.patreon.com/lekoarts) or [GitHub Sponsor](https://github.com/sponsors/LekoArts)!
|
8
content/pages/about/index.mdx
Normal file
@ -0,0 +1,8 @@
|
||||
---
|
||||
title: About
|
||||
slug: "/about"
|
||||
---
|
||||
|
||||
Hi!
|
||||
|
||||
I'm LekoArts, a designer turned software engineer passionate about open source & teaching. Learn more about Gatsby & React on [my website](https://www.lekoarts.de?utm_source=minimal-blog&utm_medium=Starter).
|
12
content/posts/curses-and-counter-courses/index.mdx
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
title: "Curses and Counter-curses (Bewitch Your Friends and Befuddle Your Enemies with the Latest Revenges: Hair Loss, Jelly-Legs, Tongue-Tying, and Much, Much More)"
|
||||
date: 2019-10-25
|
||||
slug: "/curses-counter-curses-and-more"
|
||||
canonicalUrl: "https://random-blog-about-curses.com"
|
||||
---
|
||||
|
||||
Thestral dirigible plums, Viktor Krum hexed memory charm Animagus Invisibility Cloak three-headed Dog. Half-Blood Prince Invisibility Cloak cauldron cakes, hiya Harry! Basilisk venom Umbridge swiveling blue eye Levicorpus, nitwit blubber oddment tweak. Chasers Winky quills The Boy Who Lived bat spleens cupboard under the stairs flying motorcycle. Sirius Black Holyhead Harpies, you’ve got dirt on your nose. Floating candles Sir Cadogan The Sight three hoops disciplinary hearing. Grindlewald pig’s tail Sorcerer's Stone biting teacup. Side-along dragon-scale suits Filch 20 points, Mr. Potter.
|
||||
|
||||
> Mobilicorpus reducto liberacorpus crucio. Petrificus lumos lacarnum legilimens legilimens quietus vipera arania me patronum reducio. Episkey reducio quietus mobilicorpus fidelius aparecium. Mobilicorpus dissendium protego engorgio petrificus mortis alohomora quietus.
|
||||
|
||||
Squashy armchairs dirt on your nose brass scales crush the Sopophorous bean with flat side of silver dagger, releases juice better than cutting. Full moon Whomping Willow three turns should do it lemon drops. Locomotor trunks owl treats that will be 50 points, Mr. Potter. Witch Weekly, he will rise again and he will come for us, headmaster Erumpent horn. Fenrir Grayback horseless carriages ‘zis is a chance many would die for!
|
39
content/posts/fantastic-beasts-and-where-to-find-them/SpotifyPlayer.js
Executable file
@ -0,0 +1,39 @@
|
||||
/* eslint react/no-unknown-property: 0 */
|
||||
/* eslint react/prefer-stateless-function: 0 */
|
||||
|
||||
/**
|
||||
* Spotify player iframe widget
|
||||
*
|
||||
* @author Alexander Wallin <office@alexanderwallin.com>
|
||||
* @see https://developer.spotify.com/technologies/widgets/spotify-play-button/
|
||||
*/
|
||||
|
||||
import * as React from "react"
|
||||
|
||||
// Size presets, defined by Spotify
|
||||
const sizePresets = {
|
||||
large: {
|
||||
width: 300,
|
||||
height: 380,
|
||||
},
|
||||
compact: {
|
||||
width: 300,
|
||||
height: 80,
|
||||
},
|
||||
}
|
||||
|
||||
function SpotifyPlayer({ uri, view, theme, size }) {
|
||||
return (
|
||||
<iframe
|
||||
title="Spotify"
|
||||
className="SpotifyPlayer"
|
||||
src={`https://embed.spotify.com/?uri=${uri}&view=${view}&theme=${theme}`}
|
||||
width={sizePresets[size].width}
|
||||
height={sizePresets[size].height}
|
||||
frameBorder="0"
|
||||
allowtransparency="true"
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
||||
export default SpotifyPlayer
|
212
content/posts/fantastic-beasts-and-where-to-find-them/index.mdx
Executable file
@ -0,0 +1,212 @@
|
||||
---
|
||||
title: Fantastic Beasts and Where to Find Them
|
||||
date: 2019-11-01
|
||||
tags:
|
||||
- Novel
|
||||
---
|
||||
|
||||
import SpotifyPlayer from "./SpotifyPlayer";
|
||||
|
||||
Here will a React component go:
|
||||
|
||||
<SpotifyPlayer
|
||||
uri="spotify:user:bbcamerica:playlist:3w18u69NplCpXVG4fQG726"
|
||||
size="large"
|
||||
theme="black"
|
||||
view="list"
|
||||
/>
|
||||
|
||||
Here will a live code example go:
|
||||
|
||||
```js react-live
|
||||
const onClick = () => {
|
||||
alert("You opened me");
|
||||
};
|
||||
render(<button onClick={onClick}>Alohomora!</button>);
|
||||
```
|
||||
|
||||
Here will a normal code block go:
|
||||
|
||||
```js
|
||||
(function() {
|
||||
|
||||
var cache = {};
|
||||
var form = $('form');
|
||||
var minified = true;
|
||||
|
||||
var dependencies = {};
|
||||
|
||||
var treeURL = 'https://api.github.com/repos/PrismJS/prism/git/trees/gh-pages?recursive=1';
|
||||
var treePromise = new Promise(function(resolve) {
|
||||
$u.xhr({
|
||||
url: treeURL,
|
||||
callback: function(xhr) {
|
||||
if (xhr.status < 400) {
|
||||
resolve(JSON.parse(xhr.responseText).tree);
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
```
|
||||
|
||||
A code block with a JSDoc comment, short, and long comment:
|
||||
|
||||
```js
|
||||
/**
|
||||
* Get value out of string (e.g. rem => px)
|
||||
* If value is px strip the px part
|
||||
* If the input is already a number only return that value
|
||||
* @param {string | number} input
|
||||
* @param {number} [rootFontSize]
|
||||
* @return {number} Number without last three characters
|
||||
* @example removeLastThree('6rem') => 6
|
||||
*/
|
||||
const getValue = (input, rootFontSize = 16) => {
|
||||
if (typeof input === `number`) {
|
||||
return input / rootFontSize;
|
||||
}
|
||||
|
||||
const isPxValue = input.slice(-2) === `px`;
|
||||
|
||||
if (isPxValue) {
|
||||
return parseFloat(input.slice(0, -2));
|
||||
}
|
||||
|
||||
return parseFloat(input.slice(0, -3));
|
||||
};
|
||||
|
||||
// This is a little helper function
|
||||
const helper = (a, b) => a + b;
|
||||
|
||||
// This is also a little helper function but this time with a really long one-line comment that should show some more details
|
||||
const morehelper = (a, b) => a * b;
|
||||
|
||||
export { getValue, helper, morehelper };
|
||||
```
|
||||
|
||||
Normal block without language:
|
||||
|
||||
```
|
||||
import Test from "../components/test"
|
||||
|
||||
const Layout = ({ children }) => (
|
||||
<Test>
|
||||
{children}
|
||||
</Test>
|
||||
)
|
||||
|
||||
export default Layout
|
||||
```
|
||||
|
||||
Code block with code highlighting:
|
||||
|
||||
```jsx:title=src/components/post.jsx {5-7,10}
|
||||
import * as React from "react";
|
||||
|
||||
const Post = ({ data: { post } }) => (
|
||||
<Layout>
|
||||
<Heading variant="h2" as="h2">
|
||||
{post.title}
|
||||
</Heading>
|
||||
<p
|
||||
sx={{
|
||||
color: `secondary`,
|
||||
mt: 3,
|
||||
a: { color: `secondary` },
|
||||
fontSize: [1, 1, 2],
|
||||
}}
|
||||
>
|
||||
<span>{post.date}</span>
|
||||
{post.tags && (
|
||||
<React.Fragment>
|
||||
{` — `}
|
||||
<ItemTags tags={post.tags} />
|
||||
</React.Fragment>
|
||||
)}
|
||||
</p>
|
||||
<section
|
||||
sx={{
|
||||
...CodeStyles,
|
||||
my: 5,
|
||||
".gatsby-resp-image-wrapper": { my: 5, boxShadow: `lg` },
|
||||
}}
|
||||
>
|
||||
<MDXRenderer>{post.body}</MDXRenderer>
|
||||
</section>
|
||||
</Layout>
|
||||
);
|
||||
|
||||
export default Post;
|
||||
```
|
||||
|
||||
Code block without title:
|
||||
|
||||
```
|
||||
Harry Potter and the Philosopher's Stone
|
||||
```
|
||||
|
||||
Code block without lineNumbers (but lang):
|
||||
|
||||
```text noLineNumbers
|
||||
Harry Potter and the Chamber of Secrets
|
||||
```
|
||||
|
||||
Code block without lineNumbers (and without lang):
|
||||
|
||||
```noLineNumbers
|
||||
Harry Potter and the Chamber of Secrets
|
||||
```
|
||||
|
||||
Code block with only the title:
|
||||
|
||||
```:title=src/utils/scream.js
|
||||
const scream = (input) => window.alert(input)
|
||||
```
|
||||
|
||||
Code block with only the title but without lineNumbers:
|
||||
|
||||
```:title=src/utils/scream.js noLineNumbers
|
||||
const scream = (input) => window.alert(input)
|
||||
```
|
||||
|
||||
Line highlighting without code title:
|
||||
|
||||
```js {2,4-5}
|
||||
const test = 3;
|
||||
const foo = "bar";
|
||||
const harry = "potter";
|
||||
const hermione = "granger";
|
||||
const ron = "weasley";
|
||||
```
|
||||
|
||||
Here will `inline code` go, just inside the text. Wow!
|
||||
|
||||
Code block without line numbers but with highlighting, language, and title:
|
||||
|
||||
```tsx:title=src/components/blog.tsx {7-9,16} noLineNumbers
|
||||
import * as React from "react";
|
||||
|
||||
const Blog = ({ posts }: PostsProps) => {
|
||||
const { tagsPath, basePath } = useSiteMetadata();
|
||||
|
||||
return (
|
||||
<Layout>
|
||||
<Flex sx={{ alignItems: `center`, justifyContent: `space-between` }}>
|
||||
<Heading variant="h2" as="h2">
|
||||
Blog
|
||||
</Heading>
|
||||
<Styled.a
|
||||
as={Link}
|
||||
sx={{ variant: `links.secondary` }}
|
||||
to={`/${basePath}/${tagsPath}`.replace(/\/\/+/g, `/`)}
|
||||
>
|
||||
View all tags
|
||||
</Styled.a>
|
||||
</Flex>
|
||||
<Listing posts={posts} sx={{ mt: [4, 5] }} />
|
||||
</Layout>
|
||||
);
|
||||
};
|
||||
|
||||
export default Blog;
|
||||
```
|
210
content/posts/harry-potter-and-the-half-blood-prince/index.mdx
Normal file
@ -0,0 +1,210 @@
|
||||
---
|
||||
title: Harry Potter and the Half-Blood Prince
|
||||
date: 2019-09-01
|
||||
tags:
|
||||
- Novel
|
||||
- Highlight
|
||||
---
|
||||
|
||||
| Number | Title | Year |
|
||||
| ------ | ---------------------------------------- | ---: |
|
||||
| 1 | Harry Potter and the Philosopher’s Stone | 2001 |
|
||||
| 2 | Harry Potter and the Chamber of Secrets | 2002 |
|
||||
| 3 | Harry Potter and the Prisoner of Azkaban | 2004 |
|
||||
|
||||
[View raw (TEST.md)](https://raw.github.com/adamschwartz/github-markdown-kitchen-sink/master/README.md)
|
||||
|
||||
This is a paragraph.
|
||||
|
||||
This is a paragraph.
|
||||
|
||||
# Header 1
|
||||
|
||||
## Header 2
|
||||
|
||||
Header 1
|
||||
========
|
||||
|
||||
Header 2
|
||||
--------
|
||||
|
||||
# Header 1
|
||||
|
||||
## Header 2
|
||||
|
||||
### Header 3
|
||||
|
||||
#### Header 4
|
||||
|
||||
##### Header 5
|
||||
|
||||
###### Header 6
|
||||
|
||||
# Header 1
|
||||
## Header 2
|
||||
### Header 3
|
||||
#### Header 4
|
||||
##### Header 5
|
||||
###### Header 6
|
||||
|
||||
# Header 1
|
||||
|
||||
## Header 2
|
||||
|
||||
### Header 3
|
||||
|
||||
#### Header 4
|
||||
|
||||
##### Header 5
|
||||
|
||||
###### Header 6
|
||||
|
||||
# Header 1 #
|
||||
## Header 2 ##
|
||||
### Header 3 ###
|
||||
#### Header 4 ####
|
||||
##### Header 5 #####
|
||||
###### Header 6 ######
|
||||
|
||||
> Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aliquam hendrerit mi posuere lectus. Vestibulum enim wisi, viverra nec, fringilla in, laoreet vitae, risus.
|
||||
|
||||
> Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aliquam hendrerit mi posuere lectus. Vestibulum enim wisi, viverra nec, fringilla in, laoreet vitae, risus.
|
||||
|
||||
> ## This is a header.
|
||||
>
|
||||
> 1. This is the first list item.
|
||||
> 2. This is the second list item.
|
||||
>
|
||||
> Here's some example code:
|
||||
>
|
||||
> Markdown.generate();
|
||||
|
||||
> ## This is a header.
|
||||
> 1. This is the first list item.
|
||||
> 2. This is the second list item.
|
||||
>
|
||||
> Here's some example code:
|
||||
>
|
||||
> Markdown.generate();
|
||||
|
||||
- Red
|
||||
- Green
|
||||
- Blue
|
||||
|
||||
* Red
|
||||
* Green
|
||||
* Blue
|
||||
|
||||
- Red
|
||||
- Green
|
||||
- Blue
|
||||
|
||||
```markdown
|
||||
- Red
|
||||
- Green
|
||||
- Blue
|
||||
|
||||
* Red
|
||||
* Green
|
||||
* Blue
|
||||
|
||||
- Red
|
||||
- Green
|
||||
- Blue
|
||||
```
|
||||
|
||||
- `code goes` here in this line
|
||||
- **bold** goes here
|
||||
|
||||
```markdown
|
||||
- `code goes` here in this line
|
||||
- **bold** goes here
|
||||
```
|
||||
|
||||
1. Buy flour and salt
|
||||
1. Mix together with water
|
||||
1. Bake
|
||||
|
||||
```markdown
|
||||
1. Buy flour and salt
|
||||
1. Mix together with water
|
||||
1. Bake
|
||||
```
|
||||
|
||||
1. `code goes` here in this line
|
||||
1. **bold** goes here
|
||||
|
||||
```markdown
|
||||
1. `code goes` here in this line
|
||||
1. **bold** goes here
|
||||
```
|
||||
|
||||
Paragraph:
|
||||
|
||||
Code
|
||||
|
||||
<!-- -->
|
||||
|
||||
Paragraph:
|
||||
|
||||
Code
|
||||
|
||||
---
|
||||
|
||||
---
|
||||
|
||||
---
|
||||
|
||||
---
|
||||
|
||||
---
|
||||
|
||||
* * *
|
||||
|
||||
***
|
||||
|
||||
*****
|
||||
|
||||
- - -
|
||||
|
||||
---------------------------------------
|
||||
|
||||
This is [an example](http://example.com "Example") link.
|
||||
|
||||
[This link](http://example.com) has no title attr.
|
||||
|
||||
This is [an example][id] reference-style link.
|
||||
|
||||
[id]: http://example.com "Optional Title"
|
||||
|
||||
This is [an example](http://example.com "Example") link.
|
||||
|
||||
[This link](http://example.com) has no title attr.
|
||||
|
||||
This is [an example] [id] reference-style link.
|
||||
|
||||
[id]: http://example.com "Optional Title"
|
||||
|
||||
_single asterisks_
|
||||
|
||||
_single underscores_
|
||||
|
||||
**double asterisks**
|
||||
|
||||
**double underscores**
|
||||
|
||||
*single asterisks*
|
||||
|
||||
_single underscores_
|
||||
|
||||
**double asterisks**
|
||||
|
||||
__double underscores__
|
||||
|
||||
This paragraph has some `code` in it.
|
||||
|
||||
This paragraph has some `code` in it.
|
||||
|
||||
![Alt Text](https://placehold.it/200x50 "Image Title")
|
||||
|
||||
![Alt Text](https://placehold.it/200x50 "Image Title")
|
After Width: | Height: | Size: 442 KiB |
@ -0,0 +1,37 @@
|
||||
---
|
||||
title: Introduction to "Defence against the Dark Arts"
|
||||
date: 2019-11-07
|
||||
description: Defence Against the Dark Arts (abbreviated as DADA) is a subject taught at Hogwarts School of Witchcraft and Wizardry and Ilvermorny School of Witchcraft and Wizardry. In this class, students study and learn how to defend themselves against all aspects of the Dark Arts, including dark creatures, curses, hexes and jinxes (dark charms), and duelling.
|
||||
tags:
|
||||
- Tutorial
|
||||
- Dark Arts
|
||||
banner: ./defence-against-the-dark-arts.jpg
|
||||
---
|
||||
|
||||
Thestral dirigible plums, Viktor Krum hexed memory charm Animagus Invisibility Cloak three-headed Dog. Half-Blood Prince Invisibility Cloak cauldron cakes, hiya Harry! Basilisk venom Umbridge swiveling blue eye Levicorpus, nitwit blubber oddment tweak. Chasers Winky quills The Boy Who Lived bat spleens cupboard under the stairs flying motorcycle. Sirius Black Holyhead Harpies, you’ve got dirt on your nose. Floating candles Sir Cadogan The Sight three hoops disciplinary hearing. Grindlewald pig’s tail Sorcerer's Stone biting teacup. Side-along dragon-scale suits Filch 20 points, Mr. Potter.
|
||||
|
||||
Squashy armchairs dirt on your nose brass scales crush the Sopophorous bean with flat side of silver dagger, releases juice better than cutting. Full moon Whomping Willow three turns should do it lemon drops. Locomotor trunks owl treats that will be 50 points, Mr. Potter. Witch Weekly, he will rise again and he will come for us, headmaster Erumpent horn. Fenrir Grayback horseless carriages ‘zis is a chance many would die for!
|
||||
|
||||
![Potions Class](./potions.jpg)
|
||||
|
||||
Half-giant jinxes peg-leg gillywater broken glasses large black dog Great Hall. Nearly-Headless Nick now string them together, and answer me this, which creature would you be unwilling to kiss? Poltergeist sticking charm, troll umbrella stand flying cars golden locket Lily Potter. Pumpkin juice Trevor wave your wand out glass orbs, a Grim knitted hats. Stan Shunpike doe patronus, suck his soul Muggle-Born large order of drills the trace. Bred in captivity fell through the veil, quaffle blue flame ickle diddykins Aragog. Yer a wizard, Harry Doxycide the woes of Mrs. Weasley Goblet of Fire.
|
||||
|
||||
## This is a secondary heading
|
||||
|
||||
Exume lumos protego leviosa. Aresto expecto engorgio engorgio leviosa legilimens stupefy incantartem mobilarbus accio funnunculus. Serpensortia locomotor incarcerous aguamenti colloportus. Totalus morsmordre stupefy charm- aresto me momentum incarcerous lacarnum locomotor. Revelio relashio veritaserum impedimenta expecto quietus. Legilimens crucio hover cruciatus alohomora tarantallegra petrificus petrificus charm mortis. Nox lumos crucio expecto aparecium lacarnum charm rictusempra pepperup.
|
||||
|
||||
---
|
||||
|
||||
Sectumsempra aresto exume reducio momentum tarantallegra patronum. Totalus amortentia momentum mortis quietus evanesco. Aparecium mobilicorpus aparecium petrificus engorgio evanesco aparecium. Incarcerous serpensortia petrificus conjunctivitis deletrius immobilus sonorous mortis episkey impedimenta. Immobilus lacarnum totalus protean. Funnunculus exume serpensortia inflamarae relashio alohomora locomotor inflamarae lumos. Skele-gro totalus.
|
||||
|
||||
## Another secondary heading
|
||||
|
||||
### Third heading level
|
||||
|
||||
Legilimens colloportus aparecium aresto aparecium leviosa unctuous inflamarae. Quietus mobilarbus incarcerous stupefy confundus leviosa. Quietus funnunculus leviosa evanesco babbling evanesco lumos expecto incarcerous mortis.
|
||||
|
||||
Reparo reparo alohomora vow. Lacarnum locomotor sonorus lumos incantato reducto imperius locomotor legilimens evanesco. Locomotor patronum stupefy lumos scourgify lacarnum. Portus charm inflamarae leviosa stupefy. Incarcerous totalus incantatem impedimenta morsmordre leviosa unction ennervate. Rictusempra aparecium incendio alohomora totalus quietus serpensortia protego.
|
||||
|
||||
Mobilicorpus reducto liberacorpus crucio. Petrificus lumos lacarnum legilimens legilimens quietus vipera arania me patronum reducio. Episkey reducio quietus mobilicorpus fidelius aparecium. Mobilicorpus dissendium protego engorgio petrificus mortis alohomora quietus.
|
||||
|
||||
Sonorus tarantallegra leviosa wingardium finite stupefy.
|
After Width: | Height: | Size: 218 KiB |
147
gatsby-config.js
Executable file
@ -0,0 +1,147 @@
|
||||
require(`dotenv`).config()
|
||||
|
||||
const shouldAnalyseBundle = process.env.ANALYSE_BUNDLE
|
||||
|
||||
module.exports = {
|
||||
siteMetadata: {
|
||||
// You can overwrite values here that are used for the SEO component
|
||||
// You can also add new values here to query them like usual
|
||||
// See all options: https://github.com/LekoArts/gatsby-themes/blob/main/themes/gatsby-theme-minimal-blog/gatsby-config.js
|
||||
siteTitle: `Minimal Blog`,
|
||||
siteTitleAlt: `Minimal Blog - Gatsby Theme`,
|
||||
siteHeadline: `Minimal Blog - Gatsby Theme from @lekoarts`,
|
||||
siteUrl: `https://minimal-blog.lekoarts.de`,
|
||||
siteDescription: `Typography driven, feature-rich blogging theme with minimal aesthetics. Includes tags/categories support and extensive features for code blocks such as live preview, line numbers, and line highlighting.`,
|
||||
siteLanguage: `en`,
|
||||
siteImage: `/banner.jpg`,
|
||||
author: `@lekoarts_de`,
|
||||
},
|
||||
plugins: [
|
||||
{
|
||||
resolve: `@lekoarts/gatsby-theme-minimal-blog`,
|
||||
// See the theme's README for all available options
|
||||
options: {
|
||||
navigation: [
|
||||
{
|
||||
title: `Blog`,
|
||||
slug: `/blog`,
|
||||
},
|
||||
{
|
||||
title: `About`,
|
||||
slug: `/about`,
|
||||
},
|
||||
],
|
||||
externalLinks: [
|
||||
{
|
||||
name: `Twitter`,
|
||||
url: `https://twitter.com/lekoarts_de`,
|
||||
},
|
||||
{
|
||||
name: `Homepage`,
|
||||
url: `https://www.lekoarts.de?utm_source=minimal-blog&utm_medium=Starter`,
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
{
|
||||
resolve: `gatsby-omni-font-loader`,
|
||||
options: {
|
||||
enableListener: true,
|
||||
preconnect: [`https://fonts.gstatic.com`],
|
||||
// If you plan on changing the font you'll also need to adjust the Theme UI config to edit the CSS
|
||||
// See: https://github.com/LekoArts/gatsby-themes/tree/main/examples/minimal-blog#changing-your-fonts
|
||||
web: [
|
||||
{
|
||||
name: `IBM Plex Sans`,
|
||||
file: `https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&display=swap`,
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
`gatsby-plugin-sitemap`,
|
||||
{
|
||||
resolve: `gatsby-plugin-manifest`,
|
||||
options: {
|
||||
name: `minimal-blog - @lekoarts/gatsby-theme-minimal-blog`,
|
||||
short_name: `minimal-blog`,
|
||||
description: `Typography driven, feature-rich blogging theme with minimal aesthetics. Includes tags/categories support and extensive features for code blocks such as live preview, line numbers, and code highlighting.`,
|
||||
start_url: `/`,
|
||||
background_color: `#fff`,
|
||||
// This will impact how browsers show your PWA/website
|
||||
// https://css-tricks.com/meta-theme-color-and-trickery/
|
||||
// theme_color: `#6B46C1`,
|
||||
display: `standalone`,
|
||||
icons: [
|
||||
{
|
||||
src: `/android-chrome-192x192.png`,
|
||||
sizes: `192x192`,
|
||||
type: `image/png`,
|
||||
},
|
||||
{
|
||||
src: `/android-chrome-512x512.png`,
|
||||
sizes: `512x512`,
|
||||
type: `image/png`,
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
{
|
||||
resolve: `gatsby-plugin-feed`,
|
||||
options: {
|
||||
query: `
|
||||
{
|
||||
site {
|
||||
siteMetadata {
|
||||
title: siteTitle
|
||||
description: siteDescription
|
||||
siteUrl
|
||||
site_url: siteUrl
|
||||
}
|
||||
}
|
||||
}
|
||||
`,
|
||||
feeds: [
|
||||
{
|
||||
serialize: ({ query: { site, allPost } }) =>
|
||||
allPost.nodes.map((post) => {
|
||||
const url = site.siteMetadata.siteUrl + post.slug
|
||||
const content = `<p>${post.excerpt}</p><div style="margin-top: 50px; font-style: italic;"><strong><a href="${url}">Keep reading</a>.</strong></div><br /> <br />`
|
||||
|
||||
return {
|
||||
title: post.title,
|
||||
date: post.date,
|
||||
excerpt: post.excerpt,
|
||||
url,
|
||||
guid: url,
|
||||
custom_elements: [{ "content:encoded": content }],
|
||||
}
|
||||
}),
|
||||
query: `
|
||||
{
|
||||
allPost(sort: { fields: date, order: DESC }) {
|
||||
nodes {
|
||||
title
|
||||
date(formatString: "MMMM D, YYYY")
|
||||
excerpt
|
||||
slug
|
||||
}
|
||||
}
|
||||
}
|
||||
`,
|
||||
output: `rss.xml`,
|
||||
title: `Minimal Blog - @lekoarts/gatsby-theme-minimal-blog`,
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
`gatsby-plugin-gatsby-cloud`,
|
||||
shouldAnalyseBundle && {
|
||||
resolve: `gatsby-plugin-webpack-bundle-analyser-v2`,
|
||||
options: {
|
||||
analyzerMode: `static`,
|
||||
reportFilename: `_bundle.html`,
|
||||
openAnalyzer: false,
|
||||
},
|
||||
},
|
||||
].filter(Boolean),
|
||||
}
|
39853
package-lock.json
generated
Normal file
33
package.json
Executable file
@ -0,0 +1,33 @@
|
||||
{
|
||||
"private": true,
|
||||
"name": "minimal-blog",
|
||||
"description": "Typography driven, feature-rich blogging theme with minimal aesthetics. Includes tags/categories support and extensive features for code blocks such as live preview, line numbers, and line highlighting.",
|
||||
"version": "1.3.12",
|
||||
"author": "LekoArts <hello@lekoarts.de>",
|
||||
"license": "0BSD",
|
||||
"starter-name": "gatsby-starter-minimal-blog",
|
||||
"scripts": {
|
||||
"build": "gatsby build",
|
||||
"develop": "gatsby develop",
|
||||
"develop:cypress": "cross-env CYPRESS_SUPPORT=y yarn develop",
|
||||
"build:cypress": "cross-env CYPRESS_SUPPORT=y yarn build",
|
||||
"start": "gatsby develop",
|
||||
"serve": "gatsby serve",
|
||||
"clean": "gatsby clean"
|
||||
},
|
||||
"dependencies": {
|
||||
"@lekoarts/gatsby-theme-minimal-blog": "^4.0.0",
|
||||
"gatsby": "^4.18.2",
|
||||
"gatsby-omni-font-loader": "^2.0.0",
|
||||
"gatsby-plugin-feed": "^4.18.1",
|
||||
"gatsby-plugin-gatsby-cloud": "^4.18.1",
|
||||
"gatsby-plugin-manifest": "^4.18.1",
|
||||
"gatsby-plugin-sitemap": "^5.18.1",
|
||||
"gatsby-plugin-webpack-bundle-analyser-v2": "^1.1.27",
|
||||
"react": "^18.0.0",
|
||||
"react-dom": "^18.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"cross-env": "^7.0.3"
|
||||
}
|
||||
}
|
4
src/@lekoarts/gatsby-theme-minimal-blog/texts/bottom.mdx
Normal file
@ -0,0 +1,4 @@
|
||||
<Title text="Projects" />
|
||||
|
||||
- [3D Art with Cinema4D](https://www.lekoarts.de/art/3d?utm_source=minimal-blog&utm_medium=Theme)
|
||||
- [Landscape Photography](https://www.lekoarts.de/art/photography?utm_source=minimal-blog&utm_medium=Theme)
|
5
src/@lekoarts/gatsby-theme-minimal-blog/texts/hero.mdx
Normal file
@ -0,0 +1,5 @@
|
||||
<Text sx={{ fontSize: [4, 5, 6], fontWeight: `bold`, color: `heading` }}>
|
||||
Hi.
|
||||
</Text>
|
||||
|
||||
I'm LekoArts, your theme creator. I'm passionate about open source & teaching. Learn more about Gatsby & React on [my website](https://www.lekoarts.de?utm_source=minimal-blog&utm_medium=Starter).
|
11
src/pages/404.jsx
Normal file
@ -0,0 +1,11 @@
|
||||
import * as React from "react"
|
||||
import Layout from "@lekoarts/gatsby-theme-minimal-blog/src/components/layout"
|
||||
|
||||
const NotFound = () => (
|
||||
<Layout>
|
||||
<h1>404 - Page Not Found</h1>
|
||||
<p>Unfortunately we couldn't find what you were looking for :(</p>
|
||||
</Layout>
|
||||
)
|
||||
|
||||
export default NotFound
|
BIN
static/android-chrome-192x192.png
Normal file
After Width: | Height: | Size: 36 KiB |
BIN
static/android-chrome-512x512.png
Normal file
After Width: | Height: | Size: 236 KiB |
BIN
static/apple-touch-icon-precomposed.png
Normal file
After Width: | Height: | Size: 37 KiB |
BIN
static/apple-touch-icon.png
Normal file
After Width: | Height: | Size: 32 KiB |
BIN
static/banner.jpg
Normal file
After Width: | Height: | Size: 103 KiB |
BIN
static/favicon-16x16.png
Normal file
After Width: | Height: | Size: 1.3 KiB |
BIN
static/favicon-32x32.png
Normal file
After Width: | Height: | Size: 2.1 KiB |
BIN
static/favicon.ico
Normal file
After Width: | Height: | Size: 15 KiB |
3
static/robots.txt
Normal file
@ -0,0 +1,3 @@
|
||||
User-agent: *
|
||||
|
||||
sitemap: https://minimal-blog.lekoarts.de/sitemap.xml
|