Before implementing a Dynamic Product Flow, make sure you're familiar with embedding a regular, static Flow as described in this article.
Dynamic Product Flows are a great way to dynamically extend your regular Flows by displaying posts connected to specific products.
Dynamic Product Flows will search for posts that include a specific product across all the existing Static Flows in your account. Keep in mind that for Dynamic Product Flows to work, you need to have had assigned products to posts. Otherwise, the Dynamic Product Flow will have no content to display.
Start out by including the flowbox.js
script on your page. Copy this snippet and paste it in the <head>
element. This script declares all the required methods for Flowbox to run, so it always needs to be executed first:
<script>
(function(d, id) {
if (!window.flowbox) { var f = function () { f.q.push(arguments); }; f.q = []; window.flowbox = f; }
if (d.getElementById(id)) {return;}
var s = d.createElement('script'), fjs = d.scripts[d.scripts.length - 1]; s.id = id; s.async = true;
s.src = 'https://connect.getflowbox.com/flowbox.js';
fjs.parentNode.insertBefore(s, fjs);
})(document, 'flowbox-js-embed');
</script>
The next step is to use the window.flowbox
function to display your Flows by adding the embed script to your HTML source. It's the same as for static Flows, but with one small change; you also pass in a productId
property when calling the init
method:
<div id="js-flowbox-flow"></div>
<script>
window.flowbox('init', {
container: '#js-flowbox-flow',
key: 'Your-Flow-Key',
locale: 'language-COUNTRY',
productId: 'product-1234' // Display posts that have 'product-1234' assigned
})
</script>
The productId property refers to the product whose assigned photos will be displayed. The value for this property needs to be equal to the product identifiers that you have available in your Catalogs. If you don't know the values, you can check them by clicking on Flowbox's "Products" section.
Dynamic Product Flows only support one productId
per request.
The container property refers to an element on your page, in this case the
div
element with the"js-flowbox-flow"
id.
βThe key property is the Flow key. The easiest way to find this is copying it from the "Copy Flow Key" option in the triple dot menu in the Flows section in Flowbox:
The locale property needs to be a combination of
language
andregion
codes: e.g.sv-SE
ores-ES
. It serves two purposes. Firstly, it is used to translate the texts within the Flow to the selected language, except for the CTA button, which needs to be changed separately in the catalog configuration window or in the posts themselves. Secondly, it specifies the catalog from which the Flow should fetch data for assigned products, such as product titles, currency, and product links.
Please also make sure to use language-COUNTRY
instead of language_COUNTRY
. For more info on which languages we support, please visit this page. If you pass in an unsupported locale, buttons and text will be displayed in English.
Setting up the Flow dynamically
Since the Dynamic Product Flow function is made with the express purpose of displaying posts related to specific products, you will benefit the most by setting the value of the productId
property dynamically. One way of doing this is adding this script to a template in your CMS or Ecommerce system. This will vary greatly depending on which platform you're using, but most have separate templates for product pages.
Then, you'll need to dynamically retrieve the value of the productId
. Here's an example on how the window.flowbox('init')
could look in a platform that uses handlebars-style templating:
window.flowbox('init', {
container: '#js-flowbox-flow',
key: 'Your-Flow-Key',
locale: 'language-COUNTRY',
productId: {{ $product->id }} // Product-ID must be a string in the final output. See example in snippet above.
})
Hopefully, this can give you a hint on how to implement Dynamic Flows in your site's platform.
Using Sequences
Flowbox gives users full control over fallback content in Dynamic Product Flows. You can customize sequences of content which will be served, in their respective order after the product specific content, based on almost all the fields available in your product feed. Read more here. This is particularly useful if you don't have enough content to display for some products, as it allows you to "backfill" the Flows with additional content.
Preview your Dynamic Product Flow
When you create a new Dynamic Product Flow, you can preview it directly in the Flow's settings to see exactly how it would look on that product page, and see what content will be served, including Sequences and Fallback Flow.
In order to preview the Dynamic Product Flow, you need to:
First, create/set up your Dynamic Product Flow.
Then click to open the Flow's Settings menu in the top right-hand corner.
Enter the product identifier/search for your product in the 'Preview Product' field.
Flowbox will automatically load a preview of the Flow showing your tagged content and any fallback content.
Posts tagged with products in Dynamic Product Flows are always displayed chronologically with the most recently published posts displaying first, unless you have enabled our Flowscore AI algorithm to automatically sort content based on engagement.
β
As an example - you have 2 posts that you wish to assign with the same product.:
Post A was posted online an hour ago, you assign a product to it first.
Post B was shared online yesterday. You assign a product to this post second.
These posts will be sorted based on which one was published most recently. Even though you assigned the product(s) in Post B last, since Post A was collected by Flowbox more recently, Post A will always show up first in your Dynamic Product Flow.
Content Security Policy (CSP) Error
Content Security Policy (CSP) is a W3C standard providing a layer of protection against Cross-Site Scripting (XSS). CSP policy allows blocking/allowing content from specified domains and avoiding the content coming from unapproved origin.
If you see an error message that states that the Flowbox script could not load due to Content Security Policy, you will need to add Flowbox to your CDN whitelist.
Additional resources
Embedding a Flow on your website: https://help.getflowbox.com/en/articles/2550100-embedding-a-flowbox-flow-on-your-website
Embedding multiple Flows on one page: http://help.getflowbox.com/embedding-flowbox-on-your-site/embedding-multiple-flows-on-one-page
Implementing and embedding a Dynamic Tag Flow: http://help.getflowbox.com/embedding-flowbox-on-your-site/implementing-and-embedding-a-dynamic-tag-flow