The promos client provides a placement engine for placing promos into slots on a page.
The placement engine is responsible for filtering promos based on certain rules (e.g. constraints). It returns a promise that resolves to an object with the following shape:
promos
: The list of placed promos.onClick
: The callback function that should be called if the user clicks a promo.onClose
: The callback function that should be called if the user dismisses a promo.onView
: The callback function that should be called if the user views a promo.
import { placementEngine } from '@theconversation/promos-client'
const promos = [
{ promoId: 1, groupId: 1, slotId: 1, constraints: '...' },
{ promoId: 2, groupId: 1, slotId: 1, constraints: '...' },
{ promoId: 3, groupId: 2, slotId: 2, constraints: '...' }
]
placementEngine(storage, promos).then(({ promos, onClick, onClose, onView }) => {
// Render the promos.
})
Promos can define constraints using our custom constraint query language (CQL). They are filtered by their constraints when placing the candidate promos. Let's have a look at a few CQL query examples.
Place the promo if the user has visited the site more than three times:
user.visits > 3
Place the promo if the user is on the home page:
window.location.pathname = "/"
Place the promo if the user is viewing the site with the Google Chrome browser:
browser.name = "Chrome"
Place the promo if the user has visited the site more than three times and they have not blocked the current promo:
(user.visits > 3) AND (promoId NOT IN user.blocked.promos)
This project is licensed under the MIT licence. See the LICENCE file for more details.