This is the MXC blog, built with Gastby, and designed to be easy to work with and maintain. This blog uses Strapi for content management.
This ReadMe needs to be updated with the following:
- Update file structure to include new folders, with Jest integration
-
Clone this Repo and install NPM
Clone this repository with:
git clone [email protected]:stahldom/mxc-blog.git
Then install npm:
npm install
-
For this to build locally for development, you need to create a .env.development and add the keys to the following variables:
STRAPI_USER=
STRAPI_PASSWORD=
GOOGLE_ANALYTICS=
HOTJAR=
COOKIE_HUB=
SITE_URL=
-
Start developing.
Navigate into your new site’s directory and start it up.
cd mxc-blog/ gatsby develop
-
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.Open the
my-hello-world-starter
directory in your code editor of choice and editsrc/pages/index.js
. Save your changes and the browser will update in real time!
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.md
-
/node_modules
: This directory contains all of the modules of code that your project depends on (npm packages) are automatically installed. -
/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”. -
.gitignore
: This file tells git which files it should not track / not maintain a version history for. -
.prettierrc
: This is a configuration file for Prettier. Prettier is a tool to help keep the formatting of your code consistent. -
gatsby-browser.js
: This file is where Gatsby expects to find any usage of the Gatsby browser APIs (if any). These allow customization/extension of default Gatsby settings affecting the browser. -
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 for more detail). -
gatsby-node.js
: This file is where Gatsby expects to find any usage of the Gatsby Node APIs (if any). These allow customization/extension of default Gatsby settings affecting pieces of the site build process. -
gatsby-ssr.js
: This file is where Gatsby expects to find any usage of the Gatsby server-side rendering APIs (if any). These allow customization of default Gatsby settings affecting server-side rendering. -
LICENSE
: Gatsby is licensed under the MIT license. -
package-lock.json
(Seepackage.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). -
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. -
README.md
: A text file containing useful reference information about your project.
We used a number of helper functions while developing this site. You here's a list of what was made, and how to use them. You can find all the helper functions in full detail in /styles.js
.
-
Flexbox
If you're unfamiliar with Flexbox, you can find a full overview here. All options outlined in the Flexbox helper options rely on the standard styles used in Flexbox.
-
Content Position
Use
${setFlex()}
to set content position within a div.Options
X: flex-start | flex-end | center | space-between | space-around | space-evenly | start | end | left | right ... + safe | unsafe; Y: flex-start | flex-end | center | space-between | space-around | space-evenly | start | end | left | right ... + safe | unsafe;
-
-
Media Query
Use
${media.option}
to set your media queries. The Tablet option can be replaced with one of the following options. The words correspond with the pixel number listed. _ phone: 320 _ smallTablet: 481 _ portraitTablet: 641 _ tablet: 961 _ laptop: 1025 _ desktop: 1281 -
setRem Convert pixels to Rem with setRem.
Use
${setRem(60)}
with 60 being the number of pixels. If you leave it empty, it will default at 16 pixels, making it 1 rem. -
Letter Spacing Set the CSS
letter-spacing
using Pixels that will be automatically converted to rem.Use
${setLetterSpacing(60)}
with 60 being the number of pixel. If you leave it empty, it will default to 2 pixels. -
Set a Border Create a border around an item. This use the CSS
border
element.Use
${setBorder()}
to create a border around an element with2px black solid
as your defaults. You can customize these usingwidth="5",color="white",style="solid"
- To build for production locally, you'll need to create a
.env.production
file and include the following variables:
STRAPI_USER=
STRAPI_PASSWORD=
GOOGLE_ANALYTICS=
HOTJAR=
COOKIE_HUB=
SITE_URL=
- Once this file is ready, run
gatsby build
in the root directory. - Use
gatsby serve
to run the build locally