@adobe/target-react-component

Adobe Target React component

Usage no npm install needed!

<script type="module">
  import adobeTargetReactComponent from 'https://cdn.skypack.dev/@adobe/target-react-component';
</script>

README

target-react-component

React Component Adobe Target at.js extension
This extension returns a React component, to be used as container for content delivered by at.js

Overview

The extension returns a React component, that acts as a container for offers delivered by at.js.
Initially, it renders a hidden <div> element, which is later made visible once the offer content is successfully fetched by adobe.target.getOffer() and applied by adobe.target.applyOffer().
The returned React component is to be composed into React apps, e.g.: <Target />
The component is available as a UMD module, to be included into Webpack/Browserify builds.

Installation

Install with npm i @adobe/target-react-component

Usage

import createTargetComponent from '@adobe/target-react-component';
const Target = createTargetComponent(React);

...

<Target data-mbox="testMbox">
  Default mbox content
</Target>

Options

The following options can be set on the component as data- attributes:

Key Type Mandatory Description
mbox String Yes mbox name. It is mandatory if you want to track clicks. If not provided, an error will be logged and tracking event won't be attached.
params Object No mbox parameters - an object of key-value pairs, that has the following structure:
{
"param1": "value1",
"param2": "value2"
}
timeout Number No timeout in milliseconds. If not specified, default adobe.target will be used. Default timeout is the one set in the at.js settings. This value can be configured using in the Target UI the on Setup->Implementation->at.js Settings page.

Notes

  • at.js must be included in the page before the React app using React components
  • Server-side rendering is not yet supported, the extension is intended to be used solely on the client-side
  • React Component state updating is disabled (once Target has updated component, app can’t update component)
  • params attributes can be set as follows: <Target data-mbox="myMbox" data-param1="value1" data-param2="value2" data-timeout="3000"/>

License

Apache-2.0 Adobe Systems, Inc.