
babel-plugin-sfcc-modules
Babel plugin to handle non-standard module paths used by Salesforce Commerce Cloud (SFCC)
Server-side code for Salesforce Commerce Cloud uses non-standard module resolution patterns:
- first matching cartridge from cartridge path
require('*/cartridge/scripts/foo')
require('^/cartridge/scripts/bar')
Also there is a non-standard extension
module.superModule
to reference the next match in cartridge path for the current module.
For all of this there is no Node.js equivalent. This can cause problems when you need to run this code in a Node.js environment. The most common case should be for unit testing.
This plugin removes the pain of dealing with modules like proxyquire or sandboxed-module.
Install
$ yarn add babel-plugin-sfcc-modules --dev
Usage
Add to your Babel configuration:
"plugins": [
["babel-plugin-sfcc-modules", {
"cartridgePath": [
"app_brand",
"app_core",
"app_storefront_base"
],
"basePath": "./path/to/cartridges"
}]
]
Options
Option | Type | Description |
---|
cartridgePath | Array | the cartridge path used for lookup |
basePath | string | path to the folder containing the cartridges |
️️⚠️️️️⚠️⚠️ Warning ⚠️⚠️⚠️

You shouldn't use it for frontend code. There are better alternatives to dealing witj a cartridge path, NODE_PATH and the handling of frontend assets in sgmf-scripts.
In my opinion the best way to handle frontend code is to have a clean configuration of Webpack aliases.
The cartridge path concept isn't common for Node.js/frontend code. This plugin will work for it but I won't officially support it.
License
MIT © 2019 Jens Simon