Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/PaulieScanlon/gatsby-theme-terminal
A zero component Gatsby theme for developers 🔋
https://github.com/PaulieScanlon/gatsby-theme-terminal
gatsby gatsby-theme gatsbyjs mdx
Last synced: 2 months ago
JSON representation
A zero component Gatsby theme for developers 🔋
- Host: GitHub
- URL: https://github.com/PaulieScanlon/gatsby-theme-terminal
- Owner: PaulieScanlon
- Archived: true
- Created: 2020-02-16T05:43:08.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2022-07-07T16:38:09.000Z (over 2 years ago)
- Last Synced: 2024-05-16T19:02:34.802Z (8 months ago)
- Topics: gatsby, gatsby-theme, gatsbyjs, mdx
- Language: JavaScript
- Homepage: https://gatsbythemeterminal.gatsbyjs.io/
- Size: 7.61 MB
- Stars: 311
- Watchers: 5
- Forks: 35
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
## gatsby-theme-terminal
Gatsby Theme Terminal aims to be a **zero component theme**. It provides _data_ components to aid in the abstraction of
presentational and data layers which together provide the most flexibilityThe theme handles the data but how it's displayed is up to you!
You can create any page layout or component combination you like using your own components or components provided by
[theme-ui/components](https://theme-ui.com/components)## 👀 Preview
- [Live Demo](https://gatsbythemeterminal.gatsbyjs.io/)
## 🚀 Getting started
To help you get started you can either clone the starter
[gatsby-starter-terminal](https://github.com/PaulieScanlon/gatsby-starter-terminal) or read the below.### Install
```
npm install @pauliescanlon/gatsby-theme-terminal
```### Install Peer Dependencies
```
npm install @mdx-js/mdx @mdx-js/react gatsby gatsby-plugin-mdx gatsby-source-filesystem react react-dom
```## Setup
### gatsby-config.js
Add the `siteMetaData` and `@pauliescanlon/gatsby-theme-terminal` to your `gatsby-config.js`
```
// gatsby-config.js
module.exports = {
siteMetadata: {
name: "Your blog title",
description: "I like tech",
keywords: ["tech", "blog", "boop"],
siteUrl: 'https://gatsby-theme-terminal.netlify.com',
siteImage: 'name-of-open-graph-image.jpg', // pop an image in the static folder to use it as the og:image,
profileImage: 'name-of-profile-image.jpg'
lang: `eng`,
config: {
sidebarWidth: 240 // optional,
},
},
plugins: ['@pauliescanlon/gatsby-theme-terminal']
}
```### directory structure
To add pages create `.mdx` files in the `src/pages` directory. You need at least one file called `index.mdx` located at
`src/pages` or you'll see a GraphQL error.```
|-- src
|-- pages
|-- index.mdx
|-- about.mdx
|-- contact.mdx```
### frontmatter setup
#### Pages
Pages must include `navigationLabel` in the `frontmatter`
```
// src/pages/about.mdx
---
navigationLabel: About
---# About
This is about page
```
#### Theme options
Additional `.mdx` can be sourced from _anywhere_ outside the `pages` directory but you need to tell the theme where to
source these files from.Use the `source` option in `gatsby-config.js`
```
// gatsby-config.js
...
plugins: [
{
resolve: `@pauliescanlon/gatsby-theme-terminal`,
options: {
source: [
{
name: "posts",
dir: "posts",
},
{
name: "projects",
dir: "projects",
},
] // can be an object or array of objects},
},
],
}
```Then create the relevant files and directories
```
|-- src
|-- pages
...
|-- posts
|--2020
|--02
|-- some-post.mdx
|-- featuredImage: markus-spiske-466ENaLuhLY-unsplash.jpg
|-- markus-spiske-FXFz-sW0uwo-unsplash.jpg
|-- projects
|-- some-project.mdx```
Any file that is _not_ sourced from `pages` can contain any of the following `frontmatter` but a `title` is required,
this is how the theme distinguishes between pages and other `.mdx` files```
// src/posts/2020/02/some-post.mdx
---
title: Some Post
tags: ["JavaScript", "React", "GatsbyJs", "HTML", "CSS", "theme-ui"]
date: 2020-01-01
dateModified: 20-20-2020
author: Paul Scanlon
status: draft // => means it won't be rendered
isPrivate: // => it will be rendered but you can use this prop as a filter
url: "https://example.com" // => could be an external url
misc: "Ahoy" // => use how you wish
pinned: false // => Could be used as a filter for pinned posts
featuredImage: markus-spiske-466ENaLuhLY-unsplash.jpg
featuredImageUrl: https://via.placeholder.com/936x528
embeddedImages:
- markus-spiske-FXFz-sW0uwo-unsplash.jpg
embeddedImageUrls:
- https://via.placeholder.com/468x264
---
```### Embedded Images
By using the The `` component from `gatsby-plugin-image` you can pass the image data queried by GraphQL
and pass it on via the `image` propThe `gatsbyImageData`, data is available via `props.embedded.image(n)`
```
```
You can also use the Theme UI `` component by passing it a `src`
```
```
`image1` in this example would be `markus-spiske-FXFz-sW0uwo-unsplash.jpg`
EmbeddedImages can also be sourced from a remote url, in this case use the `` component and pass it the same
props```
```
### markdown
The theme supports the complete markdown spec and you can see how to use markdown in the
[demo](https://gatsbythemeterminal.gatsbyjs.io/markdown/)### theme-ui/components
The theme supports _all_ the components provided by [theme-ui/components](https://theme-ui.com/components) and you can
see in the [demo](https://gatsbythemeterminal.gatsbyjs.io/theme-ui-components/) how they are used.### gatsby-theme-terminal/components
The theme also comes with it's own components _but_... These are purely to provide access to the source nodes. What you
choose to render is completely up to you!For example to display a list of _all_ files sourced from the `source` theme option you _could_ do something like this.
This component can be used in ANY `.mdx` file 😎```javascript
{(source) => (
- {title}
{source.map((edge, index) => {
const {
frontmatter: { title },
} = edge.node
return
})}
)}
```
You can see more about how to use the theme components in the
[demo](https://gatsbythemeterminal.gatsbyjs.io/components/)
### Component Shadowing
There is very little to shadow because almost everything is exposed by the components but you might want to add your own
logo.
To do this create the following directories `@pauliescanlon/gatsby-theme-terminal/components/Logo` in the `src`
directory of your project and then create a `Logo.js` file. You can do anything you like in here.
```
|-- src
|-- @pauliescanlon
|-- gatsby-theme-terminal
|-- components
|-- Logo
|-- Logo.js
```
If you would like to customize any part of the theme you can do so by shadowing the theme file.
To do this create the following directory `src/gatsby-plugin-theme-ui` and then create an `index.js`
```javascript
// src/gatsby-plugin-theme-ui/index.js
import baseTheme from '@pauliescanlon/gatsby-theme-terminal/src/gatsby-plugin-theme-ui'
export default {
...baseTheme,
colors: {
...baseTheme.colors,
primary: '#FF4081',
secondary: '#03A9F4',
success: '#FFEB3B',
background: '#232323',
surface: '#393939',
},
}
```
### favicon
favicon(s) need to be saved in `static/images` and named `favicon-16x16.png` and `favicon-32x32.png` along with an
`.icon` file called `favicon.ico`
If you're using **gatsby-theme-terminal** in your project i'd love to hear from you
[@pauliescanlon](https://twitter.com/PaulieScanlon)
[![ko-fi](https://www.ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/P5P31B7G8)