Other guides
Depict UI migration v2 -> v3
With the major version 3
of the Depict UI there some breaking changes that apply to everyone.
The reason for most of them is that Depict is now designed to own your categories, brand pages, campaign pages, etc. That means that when creating a category, you’d go into Depict. And this in turn means that your routing should have Depict as source of truth. Use the get listings API to know which product listings are available and render the menu and navigation on your site - let us know how we can simplify that part.
As for the Depict UI, you have to do the following things to update to version 3:
- Update all depict packages to the latest version (
@depict-ai/react-ui
to at least version3.0.18
or@depict-ai/js-ui
to at least3.0.16
).
Changes applicable to all Depict UI users
- You now must specify a
locale
object to the provider(s). This locale object now both dictates the UI language as well as the language used in the response of the Depict Backend. Please see the locale selector in the header of demo.depict.ai for what locales you should use. - For product listing pages (the
CategoryPage
component), what products to show is now decided by a new property calledlistingQuery
instead ofcategoryId
. See this excerpt of the integration guide for more details on what to specify. The type of that property looks as follows:/** * The listing to query Depict for. `type` can be `"listingId"` or `"externalId"`.. * If `id` is `"listingId"`, it should be a UUID where Depict is the source of truth, you can get them here: https://api.depict.ai/docs#tag/Listing/operation/Get_Listings_v3_listings_get. * If `id` is `"externalId"`, it should be the id of the product listing in your system - whatever was passed to Depict during data ingestion. */ export type ListingQuery = { type: typeof IdTypes.LISTING_ID | typeof IdTypes.EXTERNAL_ID; id: string; };
Changes that might affect you
- The the type for QuickLinks, BreadCrumbs and Category Suggestions that you receive in the displayTransformers has changed, please refer to the latest type definitions for the new format.
- Every object in the array you return from the displayTransformers now has to contain all data that was originally passed to the displayTransformer. This enables you to fully delete or add objects in the display transformer.
pageURLCreator
has been removed, please migrate your code to usedisplayTransformers
instead.userId
has been removed, there is now only one id used to tie together tracking events for personalisation and analytics:sessionId
. If you specify something falsey as sessionId, Depict will generate a random string and store it inlocalStorage._dep_id
and use that as session id, otherwise the provided value will be used.- The property
disableOverrideQueryId
has been renamed todisableOverrideListingId
onCategoryIdChange
has been renamed toonListingQueryChange
and now receives aListingQuery
instead of astring
for the previous and next query- No
merchant
ormarket
is passed to your ProductCard anymore which you might have received before - The
ProductCardTemplateWithoutMerchantAndMarket
type is no longer exported metaTitleSuffix
is deleted- Some minor changes have been made to the styling to accommodate for supporting product listing pages as sliders, please check your styling to make sure everything looks as expected
Was this page helpful?