Widget Builder is a command-line tool that lets you build, edit, and preview custom storefront widgets in real-time outside the context of your BigCommerce store.
This article contains detailed instructions on how to get started with Widget Builder.
- Node.js 18
- npm 9.51
- A BigCommerce store.
- API
access_token
withcontent modify
scope. For information on how to generate store API credentials, see Obtaining store API credentials.
Follow these instructions to install Widget Builder and its dependencies.
-
In a terminal, clone the widget-builder GitHub repo.
-
Navigate to the
widget-builder
directory and install Widget Builder.
npm run install-cli
- To retrieve usage information and view supported options and commands, run the following command:
widget-builder -h
Sample output:
Usage: widget-builder [options] [command]
Options:
-V, --version output the version number
--gen-config generate a config.json file
--gen-query-params generate a queryParams.json file
--auto-open <flag> open browser automatically to the builder
preview (default: "true")
-h, --help display help for command
Commands:
init Initialization of widget builder configuration
start [options] [widgetPath] starts the widget builder locally
validate [options] <file>
create <widget-template-name> Create a blank widget template
publish <widget-template> Releases the widget template to the store
belonging to the env config
help [command] display help for command
Refer to Widget Builder README.MD for the latest supported
node
version.
Once you have installed Widget Builder, the next step is to set up your store's environment. You will need the store's Client ID, Access Token, and API Path to generate appropriate configurations.
To get started, run the following command:
widget-builder init
When prompted, enter your API account credentials. This will create the .env
file with the necessary parameter assignments.
Sample output:
Thank you for using Widget Builder
This guide will help you get your environment set up.
Before continuing, please make sure you've created or received a Store API account.
You'll need those credentials in order to generate the appropriate configurations.
You can find more information here. https://support.bigcommerce.com/s/article/Store-API-Accounts#creating
? Are you ready to continue? You may press any key to continue Yes
? What is the Client ID? xxxxxxxxxxxxx
? What is the Access Token? xxxxxxxxxxxxx
? What is the API Path? https://api.bigcommerce.com/stores/xxxxx/v3/
[2021-09-08T15:12:40.271Z] Successfully created your configuration, you're all set!
If you need to reset the configurations, run the widget-builder init
command to overwrite the existing assignments.
To start Widget Builder locally, open the directory containing your widget template files and run the following command:
widget-builder start [path to widget template]
Your default browser should open automatically on port 8080.
To jump start widget development, Widget Builder provides a blank template with the appropriate files needed to start building widgets. To use the starter template, run the following command:
widget-builder create [widget template name]
Sample output:
[2021-09-08T17:29:38.868Z] Successfully created ./test-widget-one
[2021-09-08T17:29:38.870Z] Successfully created schema.json in ./test-widget-one/schema.json
[2021-09-08T17:29:38.871Z] Successfully created config.json in ./test-widget-one/config.json
[2021-09-08T17:29:38.871Z] Successfully created widget.html in ./test-widget-one/widget.html
[2021-09-08T17:29:39.564Z] Starting widget-builder at http://localhost:8080!
[2021-09-08T17:29:39.887Z] Socket connected.
Your default browser should open automatically and display a text widget on port 8080.
To publish a widget to your BigCommerce store, run the following command:
widget-builder publish [path to widget template]
If you wish to contribute, please refer to our contribution guide and code of conduct for this project.
-
Please include a clear, specific title and replicable description.
-
Please include your environment, OS, and any exceptions/backtraces that occur. The more information that is given, the more likely we can debug and fix the issue.
If you find a security bug, please do not post as an issue. Send directly to [email protected] instead.
Thank you again for your interest in contributing to the Widget Builder!
Copyright (C) 2019-Present BigCommerce Inc. All rights reserved.