- Check out the pre-deployed demo here.
- Check out the personalized page based on the inbound campaign here.
- node 14 (required by the Storefront).
- npm 6.14.4+
- Uniform project created, sign up for free here.
- Install and configure the Salesforce B2C Commerce integration for your project as described here.
- Salesforce B2C Commerce instance with connection details.
- Managed Runtime access, login here.
This repo consists of two parts:
-
Storefront: the retail web app under
./storefront
It is based on Salesforce Progressive Web App (PWA) Kit, with Uniform additions enabling visual in-context editing, sourcing marketing content from a headless CMS and edge-side personalization. -
Uniform Proxy found under
./uniform-proxy
is a Next.js app that proxies all requests to Uniform to perform composition enhancement using the following integrations:- Salesforce Commerce Cloud
- Contentful
- Cloudinary
-
cd .\storefront
and create.env
file based on.env.example
. You will need two environment variables for your Uniform project.UNIFORM_API_KEY= UNIFORM_PROJECT_ID=
⚠️ You must ensure the Uniform API key has "Developer" role assigned, which grants full access, so you can write to your Uniform project. -
Run the
npm run uniform:push
command from.\storefront
folder.This command will push required content from
.\storefront\content
into your Uniform project.⚠️ At this moment, your project requires more components than are allowed on the free tier, but if you don't have a paid account, no problem, let us know at [email protected] and we will enable your team with the right trial.
-
Setup your Uniform proxy as described here
-
Update the
host
value of the storefront proxy in this file.\storefront\config\default.js
from the following default value:{ host: 'sfcsfproxy.uniform.app', path: 'uniform' }
to your localhost:3001 and add
protocol: "http"
if you are not running on HTTPS.{ host: 'localhost:3001', path: 'uniform', protocol: "http", }
Learn more about proxying requests here.
-
cd .\storefront
-
npm install
and try opening the site on http://localhost:3000 -
npm start
If the start command times out, make sure you are running Node.js version 14. It is known to not work on newer versions of Node.js. Run
node -v
if you are not sure.
-
First, deploy Uniform proxy as described here
-
Make sure to update the
host
value this line from the default value to a differenthost
of your deployed Uniform proxy, for example:{ host: 'your-deployed-proxy.vercel.app', path: 'uniform', protocol: "https", }
-
Add this proxy to Proxy Configs in Managed Runtime:
- Path:
uniform
- Protocol:
https
- Host:
sfcsfproxy.uniform.app
- Path:
-
Then you can deploy the Storefront as described in this documentation.