npm install @bigcommerce/stencil-cli

CLI tool to run BigCommerce Stores locally for theme development.

About @bigcommerce/stencil-cli

The "@bigcommerce/stencil-cli" is an essential npm package for developers working on building and customizing themes for BigCommerce stores. This CLI tool enables developers to run a local instance of their BigCommerce store, making it significantly easier to develop and test themes before deploying them to a live environment. The tool offers a wide array of features, such as live reloading and Browsersync, which synchronizes browser testing by automatically refreshing pages as code changes. This ensures a seamless and efficient workflow, reducing the time and effort required for theme development and testing.

By using the command "npm install @bigcommerce/stencil-cli", developers can quickly set up the CLI tool in their development environment. Once installed, it allows for the local rendering of BigCommerce stores, which is invaluable for debugging and enhancing themes in real-time. The CLI also supports the use of Handlebars, Sass, and other modern web technologies, enabling developers to create highly responsive and visually appealing store themes. This package is constantly updated to support the latest features and best practices in web development, ensuring that users always have access to cutting-edge tools.

Moreover, the "@bigcommerce/stencil-cli" integrates seamlessly with BigCommerce's powerful eCommerce platform, providing developers with a robust testing environment that mimics live store conditions. This integration helps in identifying potential issues early in the development cycle, thus minimizing disruptions after deployment. With its comprehensive documentation and supportive community, getting started and troubleshooting issues becomes straightforward, enhancing overall productivity and development experience.

More from bigcommerce

bigcommerce npm packages

Find the best node modules for your project.

Search npm

@bigcommerce/request-sender

HTTP request client for...

Read more
,

@bigcommerce/script-loader

A library for loading JavaScript files...

Read more
,

node-bigcommerce

A node module for authentication and use with the BigCommerce...

Read more
,

@bigcommerce/checkout-sdk

BigCommerce Checkout JavaScript...

Read more
,

@bigcommerce/stencil-styles

Compiles SCSS for the Stencil...

Read more
,

@bigcommerce/stencil-cli

CLI tool to run BigCommerce Stores locally for theme development...

Read more
,

@bigcommerce/eslint-config

Default ESLint configuration used at...

Read more
,

@bigcommerce/eslint-plugin

This plugin contains a few custom eslint rules we use at BigCommerce...

Read more
,

@bigcommerce/bigpay-client

JavaScript client for...

Read more
,

@bigcommerce/stencil-paper-handlebars

A paper plugin to render pages using Handlebars...

Read more
,

@bigcommerce/citadel

A SASS Library based on Foundation with opinionated naming...

Read more
,

@bigcommerce/handlebars-v4

A simple wrapper for handlebars...

Read more

Dependencies

Core dependencies of this npm package and its dev dependencies.

@bigcommerce/stencil-paper, @bigcommerce/stencil-styles, @hapi/boom, @hapi/glue, @hapi/h2o2, @hapi/hapi, @hapi/inert, @octokit/rest, ajv, archiver, async, axios, browser-sync, cheerio, colors, commander, confidence, form-data, front-matter, glob, graceful-fs, husky, image-size, inquirer, js-yaml, lodash, memory-cache, npm-which, nypm, object-to-spawn-args, ora, parse-json, postcss, postcss-safe-parser, postcss-scss, progress, recursive-readdir, semver, simple-git, tarjan-graph, tmp-promise, upath, uuid4, yauzl, @commitlint/cli, @commitlint/config-conventional, @semantic-release/changelog, @semantic-release/commit-analyzer, @semantic-release/git, @semantic-release/github, @semantic-release/npm, @semantic-release/release-notes-generator, axios-mock-adapter, conventional-changelog-cli, eslint, eslint-config-airbnb-base, eslint-config-prettier, eslint-plugin-import, eslint-plugin-jest, eslint-plugin-node, eslint-plugin-prettier, jest, prettier, semantic-release, semantic-release-github-pullrequest

Documentation

A README file for the @bigcommerce/stencil-cli code repository. View Code

Stencil CLI

npm (scoped) tests

The BigCommerce server emulator for local theme development.

Install

Note: Stencil requires the Node.js runtime environment, versions 16.x, 18.x are supported.

Run npm install -g @bigcommerce/stencil-cli.

Visit the installation guide for more details.

Usage

Usage: stencil [options] [command]

Commands:

  init        Interactively create a .stencil file which configures how to run a BigCommerce store locally.
  start       Starts up the BigCommerce storefront local development environment, using theme files in the current directory and data from the live store.
  bundle      Bundles up the theme into a zip file which can be uploaded to BigCommerce.
  release     Create a new release in the theme's github repository.
  push        Bundles up the theme into a zip file and uploads it to your store.
  pull        Pulls the configuration from the active theme on your live store and updates your local configuration.
  download    Downloads the theme files from the active theme on your live store.
  debug       Prints environment and theme settings for debug purposes.
  help [cmd]  display help for [cmd]

Options:

  -h, --help     output usage information
  -V, --version  output the version number

Run stencil init at the top level of your Stencil Theme. It will ask you a few questions to get your started.

Run stencil start to run a local server so you can start developing your theme.

Run with -o or --open to automatically open up a browser.

Run stencil bundle to validate your code and create a zip bundle file that can be uploaded to BigCommerce.

Run stencil release to tag a new version of your theme, create a GitHub release in your theme repository, and upload the zip bundle file to the release assets. This is useful for tracking your changes in your Theme, and is the tool we use to create new releases in BigCommerce Cornerstone theme.

Run stencil push to bundle the local theme and upload it to your store, so it will be available in My Themes. To push the theme and also activate it, use stencil push -a. To automatically delete the oldest theme if you are at your theme limit, use stencil push -d. These can be used together, as stencil push -a -d. You can apply the theme to multiple storefronts, just specify ids of desired storefronts/channels after -c option stencil push -a -c 123 456 789. If you want to apply theme to all available storefronts, just use -allc option: stencil push -a -allc.

Run stencil pull to sync changes to your theme configuration from your live store. For example, if Page Builder has been used to change certain theme settings, this will update those settings in config.json in your theme files so you don't overwrite them on your next upload.

Run stencil debug to get information about runtime environment and the configuration

Features

BrowserSync

Stencil CLI comes packaged with BrowserSync so you can take advantage of all of those amazing goodies! Have a look at their web site for more information.

Sass compiling

You can compile Sass (node-sass) scss files in assets/scss into CSS. For example, add an scss file named theme.scss to assets/scss and {{{stylesheet 'assets/css/theme.css'}}} to your theme HTML template. Stencil-CLI will compile assets/scss/theme.scss to CSS on the fly.

Autoprefixer

Stencil CLI comes packaged with Autoprefixer. You can set which browsers should be targeted, as well as if it should cascade the generated rules in the theme's config.json file with these options:

How to get help or report a bug

If you need any help or experience any bugs, please create a GitHub issue in this repository.

Development

If you would like to improve this project check out the Contributing Guide. Also, you can find the implementation details there.

Running in docker

There is possibility to run stencil-cli in docker. Here are steps to have this functionality.

First, pull the image from Github Packages (docker registry): docker pull ghcr.io/bigcommerce/stencil-cli

Then, you want to run some commands against your theme.

For example docker run -p 3005:3005 -v /bigcommerce/cornerstone:/usr/src/app -it ghcr.io/bigcommerce/stencil-cli stencil init, where 3005 is port number definded in config.stencil.json and /bigcommerce/cornerstone path to where theme is located.

docker run -p 3005:3005 -v /bigcommerce/cornerstone:/usr/src/app -it ghcr.io/bigcommerce/stencil-cli stencil start and so on

License

Copyright (c) 2015-present, BigCommerce Inc. All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
  3. All advertising materials mentioning features or use of this software must display the following acknowledgement: This product includes software developed by BigCommerce Inc.
  4. Neither the name of BigCommerce Inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY BIGCOMMERCE INC ''AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BIGCOMMERCE INC BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.