Skip to content

BrickspaceLab/keystone-toolkit

Repository files navigation

Keystone

Join Discord / Download theme


Overview

This is a kit to help extend and customize the Keystone Shopify theme. You will need to have a valid copy of Keystone installed on your Shopify account in order to use this. Consider applying to our affiliate program for a commision on any Keystone installs.


Features

Keystone has a number of useful features that make it a developer friendly theme to work with out of the box.

  • Fast and reliable: From the very beginning, we've made sure Keystone works fast and reliably by using the latest browser-supported features. Don't worry if you're still using an older browser, our progressive enhancement ensures you'll still have the best experience.
  • Works with JavaScript disabled: We want everyone to have access to your store, so we've minimized the use of JavaScript. Even if someone has disabled JavaScript, we've got you covered with excellent fallbacks for core functionality.
  • Easily extendable: We've built Keystone with a modular approach, so it's super simple to extend and customize. We use Tailwind CSS to give you an easy approach to styling, and Alpine.js to add interactivity without weighing you down.
  • Meets all standards for theme store: Keystone meets all the requirements for the Shopify theme store.

Getting started

Requirements

Make sure all dependencies have been installed before moving on:

Installing

  1. Purchase Keystone from the Shopify theme store and create a duplicate
  2. Clone this repo
  3. Replace brickspacetestingstore.myshopify.com in package.json with your Shopify store URL
  4. Run npm install to install dependencies
  5. Run npm run pull to download the your theme (be sure to select the theme that has Keystone installed)
  6. Run npm run dev to create a development preview
  7. Run npm run build to build production ready assets

Development enviroment

Consider using recommened development envitorment for a consistent experience.

  • Use Cursor
  • Install extensions from .vscode/extensions.json
  • Consider using recommended settings
    • Open cursor settings by clicking CMD + , then clicking Open Settings (JSON)
    • Paste in the settings from below code snippet
{
  "window.commandCenter": 1,
  "editor.fontSize": 14,
  "scm.inputFontSize": 14,
  "debug.console.fontSize": 14,
  "chat.editor.fontSize": 14,
  "terminal.integrated.fontSize": 14,
  "editor.tabSize": 2,
  "explorer.fileNesting.enabled": true,
  "explorer.fileNesting.patterns": {
    "": "",
    "package.json": "package-lock.json, yarn.lock, pnpm-lock.yaml, .gitattributes, .shopifyignore, postcss.config.js, tailwind.config.js, tsconfig.json, vite.config.ts, .gitignore, .theme-check.yml, release-notes.md, next-env.d.ts, turbo.json, vercel.json, *config.cjs, .prettierrc"
  },
  "[liquid]": {
    "editor.defaultFormatter": "esbenp.prettier-vscode",
    "editor.formatOnSave": true
  },
  "editor.formatOnSave": true
}

Automatic code formatting

Automatic code formatting should be enabled by default if you follow above steps.

  1. Install Prettier
  2. Ensure editor.formatOnSave is enabled in Cursor settings. Your settings.json should include the following:
"[liquid]": {
  "editor.defaultFormatter": "esbenp.prettier-vscode",
  "editor.formatOnSave": true
},
 "editor.formatOnSave": true

Command refferance

Task Name Description
npm run dev Run development preview
npm run build Build prodution assets
npm run test Run tests

Making changes

Development previews

Use npm run dev to setup a development preview that refreshes your CSS and JavaScript as you make changes. This is the best way to implement more in-depth changes on Keystone. You should also consider implementing the GitHub integration into your workflow.

Naming coventions

Keystone uses a naming convention to help keep things organized. We use the following prefixes to help identify the files in our /snippet folder.

  • components__: Components are reusable pieces of code that can be used in multiple places. Most of our components are used in multiple places throughout the theme.
  • theme__: Theme files are only ever used in the theme.liquid file. These are global snippets that appear on every page of your theme.
  • script__: Script files contain small snippets of JavaScript that are used throughout the theme.
  • article__, collection__, product__: Article, collection and product files are used in their respecitive templates only.
  • header__: Header files are used to within the header of your theme.

Section files follow a similar naming convention.

  • Section files prefixed with a keyword and a double underscore are only used in their respecitve template files. E.g. collection__banner.liquid is only used in the collection.liquid file.

Tips and tricks

  • Use the theme__styles.liquid file to update or edit theme-wide CSS variables.

Using Alpine.js

  • For debugging there are Chrome and Firefox browser extensions available.
  • For an extensive list of Alpine resources take a look at this repo.

Resources