ShopAR Plugin
Plugin for the Web that seamlessly integrates into your webpage to create embedded virtual try-on and 3D preview capabilities.
Powered and developed by DeepAR.
Table of contents
Getting started
Create an account in the ShopAR Dashboard.
Add some models to your account. Make sure the models' plugin SKUs match the product IDs on your website.
Installation
There are two distinct ways of integrating the plugin: via Script tag and via NPM.
via Script tag
Add the following script to your HTML.
<script src="https://cdn.jsdelivr.net/npm/shopar-plugin@0.8.4/dist/shopar-plugin.js"></script>
It is possible to use a different CDN instead of jsDelivr (e.g. cdnjs, unpkg), or even a relative path if the plugin is distributed as a static asset to your app. Just make sure to set the baseUrl
parameter accordingly (see setup options for more details).
via NPM
Add shopar-plugin
to your project:
npm install shopar-plugin
# or
yarn add shopar-plugin
Usage
Paste the following snippet in your HTML.
<script>
ShopAR.plugin.setup({
apiKey: 'API_KEY',
sku: 'PRODUCT_ID',
targetElement: 'TARGET_ELEMENT',
});
</script>
- Replace
API_KEY
with your API key. You can find it in the ShopAR Dashboard. - Replace
PRODUCT_ID
with the ID of the product. Make sure it matches the plugin SKU of the model in the ShopAR Dashboard. - Replace
TARGET_ELEMENT
with the HTML element you wish to embed the plugin's UI into.
To change the look-and-feel of the plugin's UI, modify the following CSS classes:
.shopar-btn-container {
}
.shopar-btn {
}
.shopar-btn:hover {
}
.shopar-loading-container {
}
.shopar-loading-text {
}
.shopar-loading-bar-bg {
}
.shopar-loading-bar-fg {
}
.shopar-loading-bar-fg.active {
}
.shopar-qr {
}
.shopar-ar-prompt {
}
.shopar-ar-prompt-text {
}
.shopar-ar-prompt-img {
}
Alternatively, use your own UI:
const shopAR = await ShopAR.plugin.setup({
defaultUI: false,
});
myARButton.onclick = shopAR.launchAR;
myARButton.disabled = shopAR.launchAR === undefined;
my3DButton.onclick = shopAR.launch3D;
myARButton.disabled = shopAR.launch3D === undefined;
myCloseARButton.onclick = shopAR.closeAR;
myCloseARButton.disabled = shopAR.closeAR === undefined;
myClose3DButton.onclick = shopAR.close3D;
myClose3DButton.disabled = shopAR.close3D === undefined;
myCloseButton.onclick = shopAR.close;
myCloseButton.disabled = shopAR.close === undefined;
If you wish to change the SKU or target element at runtime, simply call setup()
with different parameters.
API
ShopAR.plugin.setup(options)
This method fetches the specified product from the ShopAR Dashboard and renders the plugin's UI.
Options used for the plugin setup:
apiKey
- Type:
string
- API key found in the ShopAR dashboard.
sku
- Type:
string
- Product identifier.
targetElement
- Type:
HTMLElement
- The element to inflate with ShopAR UI.
- Its CSS position property must be either
static
or relative
.
initialState
(optional)
- Type:
'AR' | '3D'
- If provided, defines which preview type the plugin initializes to.
baseUrl
(optional)
- Type:
string
- If provided, defines where the additional ShopAR plugin files are fetched from.
- Default value:
https://cdn.jsdelivr.net/npm/shopar-plugin@0.8.4/dist
defaultUI
(optional)
- Type:
boolean
- If provided and set to
false
, disables the default UI such as buttons, loading and error views. - Default value:
true
interactive
(optional)
- Type:
boolean
- If provided and set to
false
, disables user interactivity by ignoring input events. - Default value:
true
zoomEnabled
(optional)
- Type:
boolean
- If provided and set to
false
, disables zoom in 3D by ignoring mouse scroll or pinch touch events. - Default value:
true
alwaysTransparentBackground
(optional)
- Type:
boolean
- If provided and set to
true
, transparent background will always be used in 3D.
initialAnimation
(optional)
- Type:
string
or KeyFrameConfig[]
- If provided, replaces the default interactivity animation in 3D with a custom one.
strings
(optional)
- Type:
object
- If provided, overrides strings in the UI.
- Default values:
loading.ar
: Loading Try On...
loading.3d
: Loading 3D...
License
Please see: https://developer.deepar.ai/customer-agreement