Starter Theme and Slate v1 are currently in beta! You should expect potentially breaking changes between updates and more bugs than a finalized release. Slate v1.0 has not yet been tested on Windows.
Starter Theme represents the Shopify Themes Team's opinionated starting point for new Slate theme projects. It strives to include up-to-date best practices and solutions that we have deemed needed for the majority of themes we build. It is a reflection of what’s possible when building a theme!
When launching Starter Theme for the first time, you may notice a lack of CSS styles. Is Starter Theme broken? Definitely not! Keep in mind this was done intentionally. Starter Theme is not a framework but rather a starting point for your project. It contains all the files the Shopify Themes team considers to be the bare essentials to building a Shopify theme.
For templates and snippets, standard Liquid tags and logic have been included with little to no markup, classes, or other code that you will need to remove. The src/styles/theme.scss
file contains extremely limited styling to not get in the way of developers' CSS preferences. The JavaScript files contain most of our helper scripts and lazysizes for responsive image lazy loading.
You'll want to ensure you have the following already installed on your local machine before getting started with Starter theme:
-
Node: The current LTS (long-term support) release. We like to use a Node Version Manager like NVM.
-
NPM 5+ or Yarn: Both of these package managers have ups and downs, choose whichever you prefer. Follow the installation instructions for Yarn or NPM to make sure you're using the latest version.
To get started with Starter Theme, run the following command in your terminal:
$ yarn create slate-theme my-new-theme
For more information on connecting your new project with a Shopify store, see the Slate docs.
Once the scaffolding has been created, your project will consist of the following file structure:
├── .babelrc [1]
├── .env [2]
├── .eslintrc [3]
├── .gitignore
├── .stylelintrc [4]
├── package.json [5]
├── slate.config.js [6]
├── yarn.lock [7]
└── src
├── assets
│ ├── fonts
│ ├── images
│ ├── scripts [8]
│ └── styles [9]
│ └── svg [10]
│ └── static [11]
├── config [12]
├── layout [12]
├── locales [12]
├── sections [12]
├── snippets [12]
└── templates [12]
.babelrc
(optional)
Starter Theme comes with Babel preconfigured with shopify/babel-preset-shopify
. You can modify this config file based on your project requirements, or remove it completely if you do not wish to take advantage of ES6+ transpilation for legacy browser support
.env
Slate will use the environment variables declared in this file to connect to deploy files to your Shopify store. For more information, visit the @shopify/slate-env
docs.
This file, along with any other .env.{environment}
files, contain sensitive information and should not be commited to Github. These environment files are ignored by default in .gitignore
.
.eslintrc
(optional)
Starter Theme comes with ESLint preconfigured with shopify/eslint-plugin-shopify
. You can modify this config file based on your project requirements, or remove it completely if you do not wish to have JavaScript linting in your project.
.stylelintrc
(optional)
Starter Theme comes with Stylelint preconfigured with shopify/stylelint-config-shopify
. You can modify this config file based on your project requirements, or remove it completely if you do not wish to have style linting in your project.
package.json
A copy of the theme package.json
will be included in your new project. It's a good idea to update its contents to match your new project, such as updating the name, version, repository, author and description.
The package.json
includes NPM/Yarn scripts for you to be able to use Slate Tools commands easily (e.g. yarn start
).
slate.config.js
The Slate config file enables users to customize Slate to their specific needs. For more information, visit the @shopify/slate-config
docs.
yarn.lock
The Shopify Themes Team uses Yarn while developing themes because of its speed. However, Starter Theme works with NPM as well. Simply delete the yarn.lock
file and run npm install
to install the list of dependencies.
src/assets/scripts
This folder constains all your JS modules. A theme.js
must be present, as it will act as the entry point for your JS application.
You can use ES6/ES2015's standard, which allows you to require your modules with the import
syntax:
import { contains } from 'lodash';
import Foo from './modules/foo';
// const Bar = require('./modules/bar') is also available if that's your jam!
src/assets/styles
Slate fully supports .css
, .scss
and .sass
files and their syntax, including @import
.
You must include your style index file at the top of your theme.js
file for Webpack to be able to load your styles into its build process. For example:
import '../styles/theme.scss';
Liquid variables are accessible in .css
, .scss
, and .sass
files via CSS custom properties that are declared in the layout/theme.liquid
. For more information, visit the Slate docs.
src/assets/svg
On build, Slate moves all SVGs contained within this folder to the snippets/
folder and renames them to .liquid
files. To use an SVG in your theme, include it like any other snippet:
{% include 'icon-shopify' %}
src/assets/static
Sometimes you need the ability to upload unmodified files to the Shopify server. This is where the static
directory comes in. Any files placed inside this directory will be uploaded, as-is, to Shopify. To reference them in your .liquid
files, you'll want to ensure Webpack doesn't parse your liquid filters when referencing those files.
This special directory can be useful for files added by plugins you've installed, or for when you need to construct an image URL in Liquid.
src/config
, src/layout/theme.liquid
, src/locales
, src/sections
, src/snippets
, src/templates/*.liquid
The aforementioned files and folders are required by Shopify for any given theme.
For help on setting up the repository locally, building, testing, and contributing please see CONTRIBUTING.md.
All developers who wish to contribute through code or issues, take a look at the Code of Conduct.
Copyright © 2018 Shopify. See LICENSE for further details.