Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qubitproducts/recommendations
@qubit/recommendations
https://github.com/qubitproducts/recommendations
ceh cmh
Last synced: about 1 month ago
JSON representation
@qubit/recommendations
- Host: GitHub
- URL: https://github.com/qubitproducts/recommendations
- Owner: QubitProducts
- Created: 2018-07-20T10:53:11.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-10-10T09:08:19.000Z (over 1 year ago)
- Last Synced: 2024-04-09T14:38:43.100Z (9 months ago)
- Topics: ceh, cmh
- Language: JavaScript
- Size: 1.19 MB
- Stars: 4
- Watchers: 12
- Forks: 0
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Recommendations
The Recommendations API provides an endpoint to present a visitor with one or more products or content pieces that may be of interest. For example, recommended products to upsell on a basket page.
The API endpoint includes rate-limiting to prevent abuse. Currently, we allow at most 30 requests from the same IP address within a 10 second window.
## Configuration
You can override as little or as much of the configuration as shown in [Usage](#usage) examples below.
### strategy
*type*: `String`
*default*: `'pop'`Can be:
| Strategy Name | Placement |
| --- | --- |
| engagement | Product detail pages, product listing pages |
| recent | Product listing pages, Homepage |
| upsell | Basket pages, checkout pages |
| conversion | Product detail pages |
| trending | Homepage |
| popular | Homepage, search results pages |
| new | Homepage |See our [documentation](https://docs.qubit.com/content/developers/api-recommendations#recommended-use-of-our-strategies) page for more details
### limit
*type*: `Number`
*default*: `10`A `Number` specifying the amount of recommendations you wish to return. The API might respond with less recommendations than the specified limit. If no recommendations are available, the promise will be rejected. See the [timeout](#timeout) section for how to handle errors.
### seed
*type*: `String` or `Array`
*default*: 'all'You can seed (provide context to the recommendations API) with product IDs/SKUs (depending on your setup) and/or product categories. Product IDs/SKUs can be passed as `String`, however product categories must be passed as objects, e.g. `{ category: 'jeans' }`. Place within an `Array` to combine - see [Advanced](#advanced) usage example.
_Please note that if you're passing in seed as an array, the maximum amount of IDs you should pass is 3_. Any more than this, and only the last 3 items passed in will be considered; i.e.
```js
// Product ID 123 will be no be considered in the API response
const idSeeds = ['123','456','789','ABC']// Could process this within the code by doing something like the below:
const recommendations = require('@qubit/recommendations')(options, {
strategy: 'engagement',
limit: 20,
seed: idSeeds.slice(-3) // only take most recent three items in array
})
```### rules
*type*: `Array`
*default*: not includedRules can be globally defined in our backend configuration (see Data tools -> Recommendations in the Qubit app), but sometimes you may want to vary them per request. Refer to http://jsonlogic.com/ for the possible rule combinations.
### timeout
*type*: `Number`
*default*: `0`The default of 0 miliseconds means no timeout will occur. Should you wish to cancel the loading of recommendations after a set time period, pass the timeout key and attach a `catch` block after your `then` to perform an alternate operation.
```js
const recommendations = require('@qubit/recommendations')(options)recommendations.get().then((recs) => {
console.log(recs)
}).catch((e) => {
// perform alternate action
})
```### trackingId
*type*: `String`
*default*: `options.meta.trackingId`Should you wish to request recommendations for a different property (perhaps you are building on staging, but would like to request production recommendations), this can be set here.
### visitorId
*type*: `String`
*default*: `options.meta.visitorId`This package assumes usage within a Qubit experience. If using elsewhere you can specify how the Qubit Visitor ID should be found - typically via the `_qubitTracker` cookie.
### url
*type*: `String`
*default*: `'https://recs.qubit.com/vc/recommend/2.0/'`The Qubit Recommendations API endpoint.
### defaultCurrency
*type*: `String`
*default*: `currency` emitted in QP view eventAllows you to add a fallback currency for the recs endpoint locale; e.g. 'GBP'
### defaultLanguage
*type*: `String`
*default*: `language` emitted in QP view eventAllows you to add a fallback language for the recs endpoint locale; e.g. 'en-gb'
### locale
*type*: `String`
*default*: `undefined`Allows you to override the default locale for the recs endpoint; e.g. 'en-gb'
## Usage
### Basic
Recommendations can be retrieved by only passing through the Experience API (`options`). Recommendations will be returned based on the defaults listed in the [Configuration](https://github.com/QubitProducts/recommendations#configuration) section above.
```js
const recommendations = require('@qubit/recommendations')(options)recommendations.get().then((recs) => {
console.log(recs)
})
```### Standard
If you'll be making only one type of recommendations request where the strategy and number of products you wish to use will be the same, you can define this upfront by providing your own configuration. You can override any key shown in the [Configuration](#configuration) section above.
```js
const productId = options.state.get('productId')const recommendations = require('@qubit/recommendations')(options, {
strategy: 'engagement',
limit: 20,
seed: productId
})recommendations.get().then((recs) => {
console.log(recs)
})
```### Advanced
Sometimes, we're required to implement a more custom recommendations call whereby we specify our configuration at the time of making the request. This approach is useful if you're required to make more than one request on a pageview.
Configuration passed to `get` overrides any configuration you pass when initialising the module (such as in the [Standard](#standard) example above). Any keys you leave out will fallback to the configuration passed when initialised or the defaults described in [Configuration](#configuration) if no initial configuration was used.
```js
const recommendations = require('@qubit/recommendations')(options)recommendations.get({
strategy: 'engagement',
limit: 30,
seed: [{ category: 'jeans' }, 'ABC123', { category: 'blazers' }],
rules: [{
condition: {
'!==': [{
var: 'rec.custom_field'
}, {
var: 'seed.custom_field'
}]
},
factor: 0
}]
}).then((recs) => {
console.log(recs)
})
```## Required events
To enable the metrics and reporting features within the Qubit app for a recommendations experience, implement the following events.
- When a recommendation is shown/rendered onto the page:
```js
recommendations.shown({
id: 'ABC123',
weight: '0.9',
strategy: 'popular'
})
```- When a recommendation is clicked:
```js
recommendations.clicked({
id: 'ABC123',
weight: '0.9',
strategy: 'popular',
position: 1
})
```### Example
`id`, `weight` and `strategy` will be returned for every recommendation, so if you're looping through the API response to render recommendations, this data will be immediately available to make the `shown` call. Here's an example of how you might choose to emit `shown` and `clicked` events:
```js
const recommendations = require('@qubit/recommendations')(options)recommendations.get().then((recs) => {
const $recs = recs.map((product, i) => {
const { details } = productrecommendations.shown(product)
return $(`
`).click(() => {
recommendations.clicked(_.assign({ position: i + 1 }, product))
})
})$(`.product-details`).append($recs)
}).catch(err => {
console.log(err)
})
```## Notes
If you're including this package in a Qubit experience, the `get` call should take place in triggers so you can verify a response prior to activating.