Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/brianruizy/gatsby-medium-blog

πŸ“ Gatsby.js starter blog template using a Medium theme; with features like Algolia Search, post claps, Prism highlighting, contact form, dark mode, +more.
https://github.com/brianruizy/gatsby-medium-blog

blog gatsby gatsby-blog gatsby-starter gatsbyjs material-ui mdx mui react starter template

Last synced: 3 months ago
JSON representation

πŸ“ Gatsby.js starter blog template using a Medium theme; with features like Algolia Search, post claps, Prism highlighting, contact form, dark mode, +more.

Awesome Lists containing this project

README

        


Gatsby.js Medium Blog











![Cover](https://user-images.githubusercontent.com/23439187/177675013-db3b69f2-7c63-4424-9caa-b619c56deffc.png)
![Cover (1)](https://user-images.githubusercontent.com/23439187/177679060-97c9ec32-475d-4e44-8baa-9cf28e160983.png)

Don't forget to leave a star ⭐!

## Features

- πŸ“² PWA ready, installable on Android and iOS
- πŸ”Ž Algolia Search, search by all attributes
- πŸ“§ Getform.io contact form with easy setup.
- πŸ“ Blog ready, easily add your blog posts with MDX
- πŸŒ— Togglable dark mode
- πŸ’» SEO ready, option to Add meta description

## Getting Started

Before developing and working with the codebase on your IDE of choice, there are some services to set up to get the project running successfully.

### 1. Algolia Search

Algolia Search environment variables are required in the project's `.env` file.

You will need to provide some information that identifies your account to the Algolia plugin and authorizes it to write data to it. If you don’t already have an Algolia account, create one [here](https://www.algolia.com/users/sign_up). Then, go to the **API Keys** section of your Algolia profile.

There is already a file named `.env.example` in the project's root directory. You can rename this to `.env` and fill in the values or you can copy the contents of the file and paste them into your `.env` file as shown below.

```.env
GATSBY_ALGOLIA_APP_ID=
GATSBY_ALGOLIA_SEARCH_KEY=
ALGOLIA_ADMIN_KEY=

```

### 2. GetForm

contact form is super easy to set up with getform.io.
Simply add your API / endpoint URL to the action attribute of your form and you're good to go. See https://app.getform.io/forms for documentation. The location for this component is `src/components/ContactDrawer.js`.

```jsx

...

```

## Run the project

Not you must have already installed [Node.JS](https://www.gatsbyjs.com/docs/tutorial/part-zero/#install-nodejs-for-your-appropriate-operating-system) and [Gatsby CLI](https://www.gatsbyjs.com/docs/tutorial/part-zero/#install-nodejs-for-your-appropriate-operating-system). See Gatsby's [Development Environment Setup](https://www.gatsbyjs.com/docs/tutorial/part-zero/) documentation for more details or if you have issues with the CLI installation.

```bash
nvm install 18
nvm use 18

npm install -g gatsby-cli
```

1. Install project dependencies ```npm install```. If having problems installing try with legacy peer dependencies, ```npm install --legacy-peer-deps```.

2. Start Developing. Navigate into your new site’s directory and start up the local server ```gatsby develop``` πŸŽ‰.

See the [reference guide](https://www.gatsbyjs.com/docs/reference/gatsby-cli/) to read more on other commands you can use with the Gatsby CLI.

## Adding your blog posts

Adding your own content is super simple with the Jamstack design of the project. You won't need to write any HTML or CSS, just markdown (although you absolutely can if you wish to change the design or add your own features). The MDX posts are found in the `content/posts/` directory. With MDX you can even add react components to your posts as found below.

Visit [mdxjs.com](https://mdxjs.com) to see what other cool things you can implement.

```mdx
## Example header here

lorem ipsum dolor sit amet consectetur adipisicing elit. Quisquam, quidem quisquam.

Visit here for docs and examples.

```
![image](https://user-images.githubusercontent.com/23439187/179371961-520835ab-e4ef-4086-90d7-791e26934732.png)