Skip to content

Latest commit

 

History

History
315 lines (225 loc) · 10.8 KB

README.md

File metadata and controls

315 lines (225 loc) · 10.8 KB

Shopify-starter-kit

Shopify starter kit is the starter theme and development environment for the largest Shopify stores. Repository makes it easier to work with the distribution of files in the project and automates some tasks. Shopify starter kit based on Shopify Themekit and inspired by Shopify Slate and popular front-end frameworks like a React and Vue.

Shopify starter kit buildede with using technologies and tools:

  • Node.js
  • Webpack
  • Scss
  • Eslint, Stylelint
  • Git hooks with prettier + lint-staged
  • Shopify Themekit

Table of contents

General info

Shopify starter kit is a tool for comfortable team development of Shopify stores. The main goal of our team was to facilitate the start of new projects. For us, this means a quick start, the use of latest js standards and the use of teamwork tools. We tried to collect the most important things in one place - this is how the Shopify starter kit turned out.

Shopify starter kit is supported to 2 ways to use: basic and advanced modes.

Basic mode

Basic Mode provides a Shopify starter kit to expand current functionality for existing Shopify repositories. For using this mode, you need to follow a few simple steps:

  1. Clone this repo to own project folder
  2. Install dependencies
  3. Clean src folder to keep only “scripts” folder
  4. Set actual data to the config.yml file
  5. Download current shopify store with command npm run download:theme
  6. Then all your store files will be placed into the ./theme folder and everything is ready to go.

All new functionality (scripts and styles) you can add directly to ./src folder. After the build they must be processed and placed in ./dist/assets as build artifacts. We are using webpack: mini-css-extract-plugin for build style files, and it should work at this point.

NOTE: After removing ./src folder you must get build error. It happens because webpack look at srctipts in the ./src/scripts folder. For fix this problem please open webpcak.config.js and remove the line in entry block with code ...makeJsEntryPoints('src/scripts').

Advanced mode

Advanced Mode provides a powerful suite for building Shopify stores. This mode makes it easier to work with store pages. An advanced file structure allows you to separate the code between pages and load only the necessary functionality on the page, which increases the speed of the site. The structure also makes it easier to find and fix problems in the code, which speeds up the work of developers.

The advanced mode allows you to use all the features of the Shopify starter kit:

  • Separation of scripts and styles by pages.
  • Fixed component structure support
  • CLI for generating components of this structure
  • Separation of styles between pages, which allows to optimize loading of styles and scripts, code splitting
  • Using inside styles to speed up page loading
  • Using linting and code styling tools
  • Customized auto-corrections style code at the time of commit creation

All templates in ./src folder based on shopify starter theme and provide BEM naming methodology (Block, Element, Modificator). Advanced mode supports partial relocation to the new structure and all files in ./theme folder will work fine.

NOTE: This mod is only suitable for those stores where no code changes are expected in the admin panel. In advanced mode, at the moment there is no way to do full syncing with the existing store. All files downloaded from the existing store will be placed in the ./theme folder and there will be no replacement in the structure


Getting Started

For starting core of project you need to do few simple steps:

  1. Clone this repo,
  2. Install dependencies using npm or yarn. npm install,
  3. Then you need to create config.yml with correct settings. Possible copy and rename file config.example.yml,
  4. Start you project using npm or yarn npm run start or npm run start:prod.

After build all changes will be applied into you selected Shopify theme. Additional information you can find in the Shopify Themekit block.

Do not forget to check theme ids before launching theme kit watcher! Watch starts a process that will watch the directory for changes and upload them to Shopify.

Configuration for Themekit

After cloning the repo, copy config.example.yml and rename the copy to config.yml. config.yml should contain production credentials (the current live theme) and development credentials (the current feature theme).

The current feature theme is the developers's own theme. Starting to work on a new feature the developer must change the development theme_id to the corresponding one every time.

development:
  store: [your-store].myshopify.com
  password: [your-api-password]
  theme_id: "[your-theme-id]"
  proxy: http://localhost:3000

Commands

The Shopify starter kit contains many commands for working on a project. Most of the commands for working with the theme are shortnames for the Shopify Themekit. However, most of it allows you to work with the project itself. Just a few basic commands are described below. A complete list of commands can be found in the package.json file.

Commands short list:

Download

The commands for download existing shopify stores. We have 2 command to download theme:

npm run theme:download

or

npm run theme:download:prod

theme:download related to development environment part of your config.yml file,

theme:download:prod related to production part.


Start

Start command will run webpack watcher, Themekit deploy watcher and open development store in new browser window. By default, this command runs only for development environment. You can modify it own remo after doing clone.

npm run start

Build

Build command prepare all files for deploy. All files will be processed and placed into ./dist folder. Supported development and production modes

npm run build

or

npm run build:prod

Build command it is shorthand for webpack. By default it starts with a --progress flag.


Deploy

Command for upload all files from ./dist folder to shopify store. Based on Themekit functionality.

npm run deploy

or

npm run deploy:prod

Deploy command it is shorthand of few base commands: lint, build, and Themekit deploy.


Create component

The Shopify starter kit provides the CLI to creating new entities in own structures. CLI based on yeoman generator and can be started with the yo command. CLI supported to create style, script and liquid files for templates, section, snippets. All templates already contain import scripts and styles inside liquid file. You can change it in generator folder after clone shopify starter kit.

npm run gen

Analyze

It is CLI command for profiling js assets. Analyze is the shortcut for who commands: webpack --profile and run webpack-bundle-analyzer. You can find more details about profiling in webpack docs webpack profile.

npm run analyze

or

npm run analyze:prod

File Structure Contract

This file structure contract is main feature of Shopify starter kit. It is used in advanced mode and doesn't support syncing with shopify store.

/src
 ├── assets
 |    └── index.js
 ├── customers
 |    └── customer-template
 |         ├── section-name
 |         |    ├── section-name.js
 |         |    ├── section-name.liquid
 |         |    └── section-name.scss
 |         ├── customer-template.js
 |         ├── customer-template.liquid
 |         └── customer-template.scss
 ├── templates
 |    ├── common
 |    |    └── common-section-name
 |    |         ├── common-section-name.js
 |    |         ├── common-section-name.liquid
 |    |         └── common-section-name.scss
 |    └── template-name
 |         ├── section-name
 |         |    ├── section-name.js
 |         |    ├── section-name.liquid
 |         |    └── section-name.scss
 |         ├── template-name.js
 |         ├── template-name.liquid
 |         └── template-name.scss
 ├── scripts
 └── snippets
      └── snippet-name
           ├── snippet-name.js
           ├── snippet-name.luqiid
           └── snippet-name.scss
/theme

Folders descriptions:

./src/assets - folder for assets. It might be images, fonts, any necessary files for shopify store. By default, files from this folder will be copied to dist without changes. In production mode images will be compressed.

./src/customers - folders for customer templates. Can be empty.

./src/templates - include all store pages with necessary styles and scripts. All page should include own sections. By default, all templates use scripts and styles as webpack entry points.

./src/snippets - are regular snippets with own styles. Style of each snippet can be included in section, template or theme. By default, snippets styles or scripts are unwatched.

./src/scripts - the main folder functionality. All js files in this folder will be processed with wabpack and placed in ./dist/assets. Can't be empty.

./theme - folder for all shopify files, used in base mode. All files from this folder will be copied to dist without changes. It is recommended to use the npm run gen command to add new components.


Contributing

For help on setting up the repo locally, building, testing, and contributing please see CONTRIBUTING.md.

Code of Conduct

All developers who wish to contribute through code or issues, take a look at the CODE_OF_CONDUCT.md.

License

Copyright (c) 2021 SpiralScout. See LICENSE for further details.