How to create content blocks for Customer Hub
You will learn
Learn how to create content blocks for your Customer Hub. Content blocks are highly customizable and personalizable blocks that have access to Klaviyo profile data which allow you to display integrations (e.g. loyalty point balance), personalized offers, and more.
Customer Hub currently supports Shopify storefronts, including Shopify Headless. Additional eCommerce platform support is planned.
For feedback about Customer Hub functionality, email customerhub@klaviyo.com.
Before you begin
This guide explains how to set up content blocks so they display on your site’s Customer Hub. Before proceeding, ensure that you have the Customer Hub feature enabled in Klaviyo.
Learn more about Customer Hub.
What you can do with content blocksWhat you can do with content blocks
Content blocks help you customize the For you tab of the Customer Hub interface. You can use them to display customer-specific information or encourage visitors to take a certain action, so each person enjoys a tailored experience when interacting with your onsite Customer Hub. You can create your own custom content blocks or use a template from Klaviyo's content block library, which includes pre-configured blocks for common scenarios and surfacing customer data (e.g., loyalty points or subscription status) from various integrations.
Common use cases for content blocksCommon use cases for content blocks
- Encourage actions- Prompt visitors to contact you (e.g., “Email us”)
- Send shoppers to a specific URL or page (e.g., subscription management or referral information pages)
 
- Highlight and guide customer journeys- Promote special offers or exclusive collections for signed-in shoppers
- Showcase a highly-rated product with reviews and images
 
- Display personalized information from a Klaviyo profile- Use personalization tags to dynamically show customer-specific details from their Klaviyo profile. This can be information you’ve collected via Klaviyo, imported, or synced from other platforms or integrations, such as:- Loyalty points
- Subscription status
- Membership tier
 
 
- Use personalization tags to dynamically show customer-specific details from their Klaviyo profile. This can be information you’ve collected via Klaviyo, imported, or synced from other platforms or integrations, such as:
- Advanced personalization- Use if/else conditional logic to control what information displays in a content block based on customer profile data (e.g., display rewards information exclusively to rewards program members and present a default message to everyone else).
 
Content block events
When you create a content block, you must give it a name. Klaviyo tracks each time a site visitor clicks on a content block as a Customer Hub clicked on content block event, using the name you provide for reporting and filtering. For this reason, it’s best to choose names that are familiar and relevant to the content in each block.
Keep in mind, names are for internal use only; they aren’t visible to your customers. You also cannot change a block’s name after it’s created.
Create a new content blockCreate a new content block
There are a few steps to follow to create and publish content blocks to your Customer Hub interface. The next few sections walk through this setup.
Access content blocksAccess content blocks
- Navigate to Service - Customer Hub tab in Klaviyo’s left-hand navigation.
- Click Design.
- In the right-hand side preview, find the "+" button 
- Click the "+" button to choose how to add a content block:- Use a pre-built template from the content block library.- 
Browse the library by category (e.g., loyalty, deals, list growth) or filter by integration. Click Add block on any template to open it in the content block editor with pre-filled, but fully editable fields Integration-specific content blocks require that you have already enabled that respective integration in Klaviyo. 
 
- 
- Build your own content block.- Click Build your own to open the a blank setup menu in the editor
 
- Click Build your own to open the a blank setup menu in the editor
 
- Use a pre-built template from the content block library.
Configure your content block
Once you've chosen your starting point (template or from scratch), the content block will show in the preview. You can click on any content block to edit its configurations.
- Under Content, you can edit:- 
Block title- Write a heading or a call to action (e.g., Shop Spring Collection).
 
- 
Block description- 
Add details or context using regular, static text, or insert personalization tags to pull dynamic, customer-specific information (e.g., available rewards points). Event data is not supported. If you use an integration-specific template, personalization tags are pre-configured to match the platform's custom property names. 
 
- 
- 
Link (Optional)- Provide a URL to direct visitors when they click the block (e.g., to a product page). You can also choose if the link should open in a new tab.
 
- 
Internal name- Create a recognizable name (e.g., “Rewards” for a block showing rewards points). Note that this name is used for reporting and cannot be changed once saved.
 
- 
Banner image (Optional)- Upload an image to display at the top of this content block.
 
 
- 
Block title
- Under Targeting, choose which types of visitors can see the content block:- 
Login status
 Choose which types of visitors can see the content block based on login status.
- 
List/segment membership
 Show or hide the block for certain lists or segments:- Show to: Select lists/segments that should see the block.
- Don’t show to: Select lists/segments that should not see the block.
 
 
- 
Login status
- When you’re finished, click Add.
To preview how your content block looks in your Customer Hub, switch to the Design menu along the left. From here you can view your in the Customer Hub preview canvas, as well as select any content blocks to edit them.
How customers will see your content blocks
How customers will see your content blocks
The content blocks your site visitors see, and the details displayed in those blocks, depend on whether they’ve signed in to their account and if Klaviyo has identified them. Keep in mind that:
- Klaviyo can only display content blocks targeted to specific lists or segments to visitors who have signed in to an account or who have been identified by Klaviyo in another way (e.g., followed a link in an email or filled out a sign-up form). Anonymous, signed-out visitors will not see these blocks.
- Content blocks with personalization tags will only display profile data for signed-in visitors. If a visitor is signed out, the default value will display. If there is no default value, the text will not show.
If you configure a content block to only show to a specific segment, and that segment becomes inactive, the content block will no longer be visible or accessible to anyone. To prevent your segments from becoming deactivated, and ensure continued access to your content blocks, click the star icon next to the segments name in the Segments area in Klaviyo.
Using personalization tags to surface profile data
Content blocks support the use of profile and custom personalization to dynamically pull information from each customer's Klaviyo profile.
The content block library features several integration-specific templates that are already set up with the correct personalization tags for that platform and specific use case. However, if you have a different integration or use case in mind, you can add or modify personalization tags in your content block's description to display the data you need.
Note that event data is not currently supported for content blocks in Customer Hub.
Example use cases with personalization tagsExample use cases with personalization tags
When referencing a custom profile property in a personalization tag, make sure the value in the “lookup” section matches how you’re storing that property in Klaviyo. Custom properties may be formatted or named something different than the examples provided.
- Surface available loyalty points:
 You have{{ person|lookup:'loyalty_points'|default:'0'|floatformat:0 }}points
- Remind a shopper of their membership tier (e.g., Bronze, Silver, Gold):{{ person|lookup:'Membership Tier'|default:'No membership' }}Status
- Prompt a certain shopping journey with personalization:
 Celebrate your{{ person|lookup:'breed_type'|default:'dog' }}
Tip: Keep in mind that when using personalization tags, there may be some visitors who haven’t provided all the data your tags reference. To account for these instances, use default text to prevent blank spaces in place of the missing data.
Using conditional logicUsing conditional logic
For more advanced customization, you can use conditional if statements to control how a block appears to different shoppers based on their profile information.
Example if/else statementsExample if/else statements
- Help members manage their current subscription while incentivizing non-members to start a subscription plan:{% if person.subscription_status not "Cancelled" and person.subscription_status %}Manage your subscription {% else %}Start a subscription & save! {% endif %}
- Engage VIP loyalty members while showing non-members a CTA to join:{% if person|lookup:'Loyalty Points' > 150 %}Hey VIP! You’ve always got free shipping & free returns {% else %}Have you heard about our VIP program? Join today on our website to start earning rewards. {% endif %}
Learn more about if statements.
Additional resources