Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/niklasmtj/gatsby-starter-julia
A minimal GatsbyJS blog starter with landingpage, estimated reading time, markdown sourcing and much more.
https://github.com/niklasmtj/gatsby-starter-julia
Last synced: 3 months ago
JSON representation
A minimal GatsbyJS blog starter with landingpage, estimated reading time, markdown sourcing and much more.
- Host: GitHub
- URL: https://github.com/niklasmtj/gatsby-starter-julia
- Owner: niklasmtj
- License: mit
- Archived: true
- Created: 2019-03-17T20:42:55.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-03-15T23:56:28.000Z (10 months ago)
- Last Synced: 2024-08-02T06:22:47.082Z (6 months ago)
- Language: JavaScript
- Homepage: https://gatsby-starter-julia.netlify.com/
- Size: 8.74 MB
- Stars: 166
- Watchers: 4
- Forks: 39
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Gatsby Starter Julia[GatsbyJS](https://www.gatsbyjs.com/) is a free and open source static website builder build on React. It's one implementation of the [JAMstack](https://jamstack.org/) idea which creates high speed webpages.
## π Features:
- Landingpage
- Blog overview page
- Markdown sourcing from /content folder
- Estimated reading time for each post
- Styled components with emotion
- Netlify deployment friendly
- Nunito font included as npm module
- Syntax highlighting with prismjs
- Textmarkerstyle headings inspired by Basecamp
- Site meta tags with React Helmet
- Plugins for offline support
- Draft blog posts not published## π¨π»βπ» Customization
Create new pages like an About page in the `/pages` directory.
The minimum code is:```js
import React from "react"import Layout from "../components/layout"
import SEO from "../components/seo"const PageName = () => (
//CONTENT HERE
)export default PageName
```To change the name on the landing page please modify the `title` in `gatsby-config.js`
The Nunito typeface is included as a npm module in `gatsby-browser.js` and in `/components/layout.css`
---
This Gatsby starter is built on top of the official [gatsby-starter-default](https://github.com/gatsbyjs/gatsby-starter-default). You can find a quick start guide in the following lines. There are the most important files explained.
## π Quick start
This starter ships with the main Gatsby configuration files you might need to get up and running blazing fast with the blazing fast app generator for React.
1. **Create a Gatsby site.**
Use the Gatsby CLI to create a new site, specifying the julia starter.
```sh
# create a new Gatsby site using the julia starter
gatsby new julia-starter https://github.com/niklasmtj/gatsby-starter-julia
```1. **Start developing.**
Navigate into your new siteβs directory and start it up.
```sh
cd julia-starter/
gatsby develop
```1. **Open the source code and start editing!**
Your site is now running at `http://localhost:8000`!
_Note: You'll also see a second link: _`http://localhost:8000/___graphql`_. This is a tool you can use to experiment with querying your data. Learn more about using this tool in the [Gatsby tutorial](https://www.gatsbyjs.org/tutorial/part-five/#introducing-graphiql)._
Open the `julia-starter` directory in your code editor of choice and edit `src/pages/index.js` or `src/pages/blog.js`. Save your changes and the browser will update in real time!
## π§ What's inside?
A quick look at the top-level files and directories you'll see in a Gatsby project.
.
βββ node_modules
βββ src
βββ .gitignore
βββ .prettierrc
βββ gatsby-browser.js
βββ gatsby-config.js
βββ gatsby-node.js
βββ gatsby-ssr.js
βββ LICENSE
βββ package-lock.json
βββ package.json
βββ README.md1. **`/node_modules`**: This directory contains all of the modules of code that your project depends on (npm packages) are automatically installed.
2. **`/src`**: This directory will contain all of the code related to what you will see on the front-end of your site (what you see in the browser) such as your site header or a page template. `src` is a convention for βsource codeβ. A short description of what you can find there is below.π¨π»βπ»
3. **`.gitignore`**: This file tells git which files it should not track / not maintain a version history for.
4. **`.prettierrc`**: This is a configuration file for [Prettier](https://prettier.io/). Prettier is a tool to help keep the formatting of your code consistent.
5. **`gatsby-browser.js`**: This file is where Gatsby expects to find any usage of the [Gatsby browser APIs](https://www.gatsbyjs.com/docs/browser-apis/) (if any). These allow customization/extension of default Gatsby settings affecting the browser. For example is the **Nunito** typeface imported here.
6. **`gatsby-config.js`**: This is the main configuration file for a Gatsby site. This is where you can specify information about your site (metadata) like the site title and description, which Gatsby plugins youβd like to include, etc. (Check out the [config docs](https://www.gatsbyjs.com/docs/gatsby-config/) for more detail).
7. **`gatsby-node.js`**: This file is where Gatsby expects to find any usage of the [Gatsby Node APIs](https://www.gatsbyjs.com/docs/node-apis/) (if any). These allow customization/extension of default Gatsby settings affecting pieces of the site build process.
8. **`gatsby-ssr.js`**: This file is where Gatsby expects to find any usage of the [Gatsby server-side rendering APIs](https://www.gatsbyjs.com/docs/ssr-apis/) (if any). These allow customization of default Gatsby settings affecting server-side rendering.
9. **`LICENSE`**: Gatsby is licensed under the MIT license.
10. **`package-lock.json`** (See `package.json` below, first). This is an automatically generated file based on the exact versions of your npm dependencies that were installed for your project. **(You wonβt change this file directly).**
11. **`package.json`**: A manifest file for Node.js projects, which includes things like metadata (the projectβs name, author, etc). This manifest is how npm knows which packages to install for your project.
12. **`README.md`**: A text file containing useful reference information about your project.
### The src directory
.
βββ components
βββ content
βββ images
βββ pages
βββ templates1. **`/components`**: Your React components can be defined here. You can include them from there in your pages.
2. **`/content`**: The filesystem plugin is configured to get the `*.md` files from here. These will be published on the `/blog` page.
3. **`/images`**: This directory is the home for your images that you can query via GraphQL since the filesystem plugin publish them there.
4. **`/pages`**: Here is where your pages like `/blog`, `/about` and also the 404 page lives. An example of the basic structure can be found above.
5. **`/templates`**: You will find the `blog-post.js` template there which defines how every blog-post page is structured.
## π Learning Gatsby
Looking for more guidance? The perfect place to learn more about GatsbyJS is the [website](https://www.gatsbyjs.com/). Here are some places to start:
- **For most developers, we recommend starting with our [in-depth tutorial for creating a site with Gatsby](https://www.gatsbyjs.com/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 our documentation](https://www.gatsbyjs.com/docs/).** In particular, check out the _Guides_, _API Reference_, and _Advanced Tutorials_ sections in the sidebar.
## π« Deploy
You can also directly deploy this starter via Netlify.
[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/niklasmtj/gatsby-starter-julia)