Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sampittko/gatsby-starter-intl-blog
Gatsby starter for creating an internationalized personal blog website
https://github.com/sampittko/gatsby-starter-intl-blog
gatsby gatsby-blog gatsby-js gatsby-starter gatsbyjs tailwind tailwind-css tailwindcss
Last synced: about 1 month ago
JSON representation
Gatsby starter for creating an internationalized personal blog website
- Host: GitHub
- URL: https://github.com/sampittko/gatsby-starter-intl-blog
- Owner: sampittko
- License: mit
- Created: 2020-05-15T18:48:49.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2021-01-06T09:58:36.000Z (about 4 years ago)
- Last Synced: 2024-10-30T00:35:54.573Z (3 months ago)
- Topics: gatsby, gatsby-blog, gatsby-js, gatsby-starter, gatsbyjs, tailwind, tailwind-css, tailwindcss
- Language: JavaScript
- Homepage:
- Size: 21.8 MB
- Stars: 2
- Watchers: 0
- Forks: 1
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Gatsby i18lized Blog Starter
Kick off your project with this internationalized personal blog website boilerplate.
## Features
- Supports as many languages as needed
- Extensible so that it fits anyones needs
- Dark mode
- Categorizable blog posts
- Git-hosted content that supports MDX
- Easy navigation
- Simple & clean look achieved with [Tailwind CSS](https://tailwindcss.com/)
- Accessible & fast for great SEO and high usability
- Easy to personalize
- Let visitors know that you are open to work
- Cookie consent for GDPR compliance## Live Demo
Visit [www.gatsby-starter-intl-blog.now.sh](https://gatsby-starter-intl-blog.now.sh/) to see the starter live in action.
## Deploy with one click
Deployment is made simple and fast thanks to providers like [Vercel](https://vercel.com) or [Netlify](https://netfliy.com). Click on one of the buttons below to deploy in seconds.
## Project Structure
```
.
├── content # Markdown files used by Gatsby to generate pages
│ ├── en # Content translated to English langauge
│ └── [language-key] # Content translated to [language-key] language
├── src
│ ├── assets # Static assets (e.g. CSS and images)
│ ├── components # All React and Gatsby-friendly components
│ ├── hooks # React hooks for better reusability
│ ├── locales # Translations for UI components for every supported language
│ ├── pages # Pages that are generated by Gatsby
│ ├── templates # Templates used by Gatsby to generate pages
│ └── utils # Utility functions that are needed across the application
├── CHANGELOG.md
├── CONTRIBUTING.md
├── gatsby-config.js
├── gatsby-node.js
├── LICENSE
├── package.json
├── postcss.config.js
├── README.md
└── tailwind.config.js```
## Internationalization
This starter supports addition of new languages right out of the box.
### Rules
Firstly, you will need to follow certain rules for internationalization to work correctly. Breaking any of the following rules may cause internationalization not to work properly if at all.
1. Keep folders names of individual articles consistent across supported languages (e.g. /content/en/blog/life-hacks/this-is-my-first-blog-post/, /content/sk/blog/life-hacks/this-is-my-first-blog-post/ and /content/si/blog/life-hacks/this-is-my-first-blog-post/)
2. Prefix blog post folder name with it's category name (e.g. life-hacks from the example above)
3. Use **at least** `post_title`, `post_category` and `post_date` in frontmatter of article's MD file
4. Make `post_category` field inside frontmatter consistent across all blog posts in the category's folder
5. Keep formats of `post_date` field inside frontmatter consistent across all blog posts```markdown
---
page_description: This is a super blog post 2 # Use for better SEO
post_title: Hello there
post_category: Reflections
post_date: "2020-04-05"
---
```Suggestion: keep folders names of articles (blog posts titles in other words) and their categories in the default language (e.g. default language of the website in the example mentioned above would be English)
Note: it is not necessary to make a post translation immediately after writing a blog post in any of the supported languages
### Adding Support For a New Language
Replace `[language-key]` with the actual language key that represents the language that is to be added.
1. Open [gatsby-config.js](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/gatsby-config.js) file
1. Extend configuration of gatsby-plugin-intl
- Add a new `[language-key]` to `options.languages` array
- Add a new `[language-key]` to `options.external.languageStrings` array2. Extend configuration of gatsby-source-filesystem by adding the following entry
```javascript
{
resolve: `gatsby-source-filesystem`,
options: {
name: `[language-key]/blog`,
path: `${__dirname}/content/[language-key]/blog`,
},
```2. Open [locales](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/src/locales/) folder and create a new `[language-key].json` file with corresponding translations
3. Open [content](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/content/) folder and create a new `/[language-key]/blog/` folder (ideally with translated existing articles included)
4. Extend existing GraphQL queries in the [hooks](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/src/hooks/) folder by adding the newly added language
5. Extend existing GraphQL page queries in [post.js](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/src/templates/blog/post.js) and [category.js](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/src/templates/blog/category.js) by adding the newly added language
6. **You are done**
### Change Default Language
**Default language** is selected at the very first load of the website if the browser language of a visitor does not match any of the supported languages or it cannot be read correctly. Execute the following steps in order to change it:
1. Open [gatsby-config.js](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/gatsby-config.js) file and navigate to the configuration of gatsby-plugin-intl
2. Change the value of `options.external.defaultLanguage` key with wanted language key
3. **You are done**## Personalize
Make it fully yours by replacing defaults with your personal information. Firstly, open [gatsby-config.js](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/gatsby-config.js) and change `title`, `siteUrl` and properties of `author` object inside `siteMetadata`object.
### Change favicon with profile picture inside header
Replace default [favicon.png](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/src/assets/img/favicon.png) file.
- resolution: square
- format: PNG### Change header image
Replace default [header_image.jpg](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/src/assets/img/header_image.jpg) file.
- resolution: 1024x96
- format: JPEG### Toggle open to work status
Set `openToWork` to either `true` or `false` inside [gatsby-config.js](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/gatsby-config.js).
## Contributing
Check [CONTRIBUTING.md](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/CONTRIBUTING.md) in order to see how to contribute to this open-source project.
## Changelog
Check what is new but also the history of changes for this project in [CHANGELOG.md](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/CHANGELOG.md).
## License
This project is under the MIT license which is great! Read more inside [LICENSE](https://github.com/sampittko/gatsby-starter-intl-blog/blob/main/LICENSE).