Image-heavy photography portfolio with colorful accents & customizable pages. Includes adaptive image grids powered by CSS grid and automatic image integration into projects. Using the Gatsby Theme @lekoarts/gatsby-theme-jodie
.
Also be sure to check out other Free & Open Source Gatsby Themes and my Personal Website.
- MDX
- Fully customizable through the usage of Gatsby Themes (and Theme UI)
- Create a project by creating an MDX file and dropping the images into the same folder
- Extensible custom pages
- Define colors for each page and the sidebar & content will adapt while maintaining WCAG 2 AA contrast ratios
- Google Analytics Support
- SEO (Sitemap, OpenGraph tags, Twitter tags)
- Offline Support & WebApp Manifest
Use git
to clone the site and navigate into it:
git clone https://github.com/LekoArts/gatsby-starter-portfolio-jodie project-name
cd project-name
If you use npm 7 or above use the --legacy-peer-deps
flag. If you use npm 6 you can use npm install
.
npm install --legacy-peer-deps
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 or longer tutorial. The tutorials don't exactly apply to this starter however the concepts are the same.
Important Note: Please read the guide Shadowing in Gatsby Themes to understand how to customize the underlying theme!
This starter creates a new Gatsby site that installs and configures the theme @lekoarts/gatsby-theme-jodie
.
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-jodie/
to shadow/override files. The Theme UI config can be configured by shadowing its files in src/gatsby-plugin-theme-ui/
.
By default, the underlying theme and thus this starter uses "Work 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:
- The configuration for
gatsby-omni-font-loader
=> Responsible for loading the font CSS files - The Theme UI config and its
fonts
key (see Theme UI Typography Docs) => Responsible for setting thefont-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 "Work Sans" with "Roboto Mono".
Create a file at src/gatsby-plugin-theme-ui/index.js
with the following contents:
import { merge } from "theme-ui";
import originalTheme from "@lekoarts/gatsby-theme-jodie/src/gatsby-plugin-theme-ui/index";
const theme = merge(originalTheme, {
fonts: {
body: `"Roboto Mono", monospace`,
},
});
export default theme;
As defined in the Theme Specification body
is the default body font family.
Another example: You didn't replace "Work 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:
import { merge } from "theme-ui";
import originalTheme from "@lekoarts/gatsby-theme-jodie/src/gatsby-plugin-theme-ui/index";
const theme = merge(originalTheme, {
fonts: {
heading: `"Roboto Mono", monospace`,
},
});
export default theme;
The static
folder contains the icons, social media images and robots.txt. Don't forget to change these files, too!
Please open up an issue on the main repository: LekoArts/gatsby-themes. Thanks!
Looking for more guidance? Full documentation for Gatsby lives on Gatsby's website.
- To learn more about Gatsby themes specifically, we recommend checking out the theme docs.
-
For most developers, I recommend starting with the in-depth tutorial for creating a site with Gatsby. 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. In particular, check out the Reference Guides and Gatsby API sections in the sidebar.
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 and share the project with me.
Please star this project, share it on Social Media or consider supporting me on Patreon or GitHub Sponsor!