gatsby version of startbootstrap-agency with i18n supported.
This project is migrated to Gatsby@v3, check the latest Gatsby@v2 version here.
https://gatsby-startbootstrap-agency.netlify.app
※ startbootstrap-agency (Original Version)
※ startbootstrap-agency-webpack(Webpack Version)
If you're not interesting in i18n, use StaticQueryVersion instead. StaticQueryVersion gets better performance and better code structure.
This project is using yarn
as the package manager. You have to set yarn as Gatsby-cli's package manager first.
https://www.gatsbyjs.com/docs/glossary/yarn/#using-yarn-as-your-gatsby-package-manager
npm install -g gatsby-cli
gatsby new my-blog-folder https://github.com/thundermiracle/gatsby-startbootstrap-agency
-
Original version is great but have to load too many unnecessary contents from CDN including all components in
bootstrap
, all solid & brands icons infontawesome
. That dramatically slows down the FCP(first contentful paint) in 3G environment.Using Gatsby could tree-shaking unnecessary code, optimizing images which make first contentful paint very fast.
-
Implementation of i18n in original version is not easy and will make a lot of redundant code.
i18n is really easy in Gatsby and i18n is more maintainable.
-
iconName
in Services.md MUST be defined in'config/CustomIcons.jsx'
. -
imageFileName
in markdown MUST be added in'content/assets'
. -
all configurable contents are saved in markdown files in
'content'
folder. -
change
file name's number
in'content/sections'
folder to change the sort order. -
nullable items (if defined):
anchor
in section markdown: display in menu if defined in sections' markdown- items in
social
:twitter, facebook, linkedin, github, medium
jumpToAnchor, jumpToAnchorText
in Top.md: add button in Top section
-
set defaultLang in
'config/site.js'
-
add langTextMap to
'config/site.js'
(LanguageSelector won't display if langTextMap is not defined. Consider using StaticQueryVersion if i18n is not necessary) -
copy markdown files in
'content'
folder, rename it toxxxx.[langKey].md
and translate the contents
This project is licensed under the terms of the MIT license.