The purpose of the Astro Theme is to be a starting point for MindArc developers to build client-centric Shopify stores. It is not a plug and play theme where most things can be configured from the theme settings. The theme settings should be reserved for client data or anything the client would like to edit themselves with minimal risk. Design customisations such as topography and colours should be in code as this is not likely to change frequently.
This project is based off shopify/slate and shopify/starter-theme.
Slate is a command line tool for developing Shopify Themes. See Slate docs for more information. However, we have decided to remove Slate tools and use webpack directly.
Starter Theme is the opinionated theme developed by the Shopify Themes Team for Slate projects. We will be modifying and building upon this to suit our needs.
The following items are required before the initial git commit.
-
Create private GitHub repo for the new project
-
Setup the Shopify development store - please follow MindArc's store URL and naming convention
-
Create private app for theme development and storefront API
-
Update
config.yml
-
Update values in
src/js/utils/api.js
-
Clean up new project README
- Remove section above --- Remove above after cloning ---
- Fill in project information placeholders
- Remove the current git history
rm -rf .git
- Recreate git and link to your new repo
git init
git remote add origin https://github.com/mindarc/<new_project>.git
- Initial commit to new project
💡 Get the Astro version fron https://github.com/mindarc/astro/releases
git add .
git commit -m "Astro <version>"
git push -u origin master
If replacing an existing theme e.g. Debut, you will need to clear the config first.
-
Do this from Shopify admin > Online Store > Theme actions > Edit code > config/settings_data.json
-
Replace content with
{}
- Deploy theme
yarn install
yarn build-dev
theme deploy
------------------------ Remove above after cloning ------------------------
- DEV - <dev_url>
- PROD - <prod_url>
This project is based off mindarc/astro.
Assumed knowledge:
- Shopify store setup for theme development
- Basic understanding of ThemeKit
- Frontend development using Liquid, Sass and VueJS
- Nodejs.org
- Yarn
- ThemeKit - Please understand the commands and features of ThemeKit
- Add Styleguide page
- Enable customers and payment
- Create private app for theme development and storefront API
From your project root, run:
$ yarn install
yarn install
? Try running the following and try again. More information here.
yarn cache clean
Setup config.yml
file. See here for instructions.
Deploy your theme to your store. See here for instructions.
config/settings_data.json
should be replaced with {}
. Do this from Shopify admin > Online Store > Theme actions > Edit code.
Open 2 terminals from your project root and run the following in separate terminals
yarn watch
theme watch
💡 Hint theme
commands without environment -e
specified, defaults to -e development
.
Build the production ready assets with
yarn build-prod
Then use Theme Kit to deploy
theme deploy -e <env>
(Excluding Slate Libraries)