sesamy-paywall-wizard
The paywall wizard component is a dynamic paywall that fetches product configuration from the server. I can either be used as a UI in an article paywall or standalone on a landing page.
Basic usage
The paywall wizard can show a list of different products and optionally also sell the current article as a single purchase.
<html> <head></head> <body> <sesamy-paywall-wizard item-src="https://example.com/article" settings-url="https://example.com/paywall-wizard.json"> </sesamy-paywall-wizard> <script type="module"> import "https://assets.sesamy.com/scripts/web-components/sesamy-bundle.min.js"; </script> </body> </html>
The wizard is configured by configuring a link to a json file that either can be statically hosted or served via an api. Below is an example of a configuration file in the new V2 format:
V2 Configuration Example
{
"currency": "SEK",
"settings": {
"template": "ARTICLE",
"useDefaultLogo": true,
"styling": {
"dropShadow": false,
"backgroundColor": "#000000",
"showBackground": false
},
"useDefaultCurrency": false,
"useDefaultColor": true
},
"subscriptions": [
{
"features": [],
"discountCode": "1MAN1KR",
"price": 1,
"periodText": "1 mån",
"discountPrice": 0,
"description": "Efter kampanjperioden 149 kr/mån. Ingen bindningstid!",
"tag": "",
"id": "k4ffLgYs9N5JZ4atJLHvY",
"sku": "sid:aOb7lnY6a3Hq5BJ3NAK9k",
"title": "1 månad för 1 kr!",
"poId": "Y90wv4_rKsvSMGMw81gsc",
"selected": true
},
{
"features": [],
"discountCode": "",
"price": 995,
"periodText": "år",
"discountPrice": 0,
"description": "Du sparar 793 kr. Prenumerationen förnyas automatiskt årsvis.",
"tag": "",
"id": "MSTK7EaXIqzhkbyVy7uut",
"sku": "sid:aOb7lnY6s3Hq5BJ3wAK9k",
"title": "Ett år för 995 kr",
"poId": "5Qtyxxns9LjeM4OqOyCLY",
"selected": false
}
],
"showLoginButton": false,
"vendorId": "demo",
"features": [
"Allt material på hemsidan",
"Tillgång till e-tidningen",
"Tillgång till våra podcasts",
"Nyhetsbrev"
],
"headline": "Läs i 1 månad för bara 1 kr!",
"singlePurchase": {
"description": "Betala och få tillgång till innehållet direkt.",
"title": "Köp artikeln",
"discountCode": "",
"enabled": true
},
"footerPaymentMethods": [
"visa",
"mastercard",
"google-pay",
"apple-pay",
"klarna"
],
"id": "4PsJVaKs8RjCeXu3OAwvt",
"version": 2,
"logoUrl": "https://cdn.example.com/logo.svg",
"mainColor": "#D62802"
}
Key Differences in V2
- Added
version
field to explicitly identify the configuration version
- Renamed several fields for clarity (e.g.,
logoSrc
→logoUrl
)
- Simplified pricing and subscription structures
- Added more flexible configuration options
- Improved type safety and consistency
The V1 version of the format is deprecated but still supported:
{ "logoSrc": "https://example.com/logo.svg", "color": "#D62802", "subscriptionsUrl": "https://www.example.com/prenumerera", "vendorId": "vendorId", "singlePurchase": { "type": "single", "text": "Köp artikeln", "description": "Betala och få tillgång till innehållet direkt.", "currency": "kr", "discountCodes": [] }, "subscriptions": [ { "type": "monthly", "text": "3 månader för 49kr!", "description": "Efter kampanjperioden 149 kr/mån. Ingen bindningstid!", "price": "49", "currency": "kr", "recurringPaymentText": "3 mån", "itemSrc": "itemSrc", "po": "poID", "discountCodes": [] }, { "type": "yearly", "text": "Ett år för 995kr", "description": "Du sparar 793 kr. Prenumerationen förnyas automatiskt årsvis.", "price": "995", "currency": "kr", "recurringPaymentText": "år", "itemSrc": "itemSrc", "po": "poID", "discountCodes": [] } ], "subscriptionFeatures": [ "Tagline 1", "Tagline 2", ], "subscriptionPurchaseText": "3 månader för bara 49 kr!", "termsOfServiceUrl": "https://www.example.com/prenumerationsvillkor", "privacyPolicyUrl": "https://www.example.com/personuppgiftspolicy", "footerPaymentMethods": ["visa", "amex", "mastercard", "klarna", "google-pay", "apple-pay", "swish"], "showLoginButton": true }
API Reference
json-data-id
(String): This attribute specifies theid
of a<script type="application/json">
tag within the HTML document from which to pull JSON data. Default:'paywall-wizard'
.
settings-url
(String): Defines the URL from which to fetch JSON settings. When set, this attribute takes precedence overjson-data-id
, and the component fetches its configuration from the specified URL.
publisher-content-id
(String): The ID of the content on the publisher side. It can be used to fetch data about the content from a sesamy-content-data web component with a matching ID.
item-src
(String): If thesinglePurchase
data is set in the json file, the product displayed in the checkout will be taken from the current URL, if it should be a different product then the product could be got from theitem-src
attribute. The external item could be both, an article on a separate url or a pass.
redirect-url
(String): The redirect URL to go once the checkout is completed. Default:window.location.href
.
currency
(String): The price of the currency purchase item.
price
(String): The price of the single purchase item.
separate-products
(String): Iftrue
, the subscriptions are displayed with a separated between each other. Default:false
.
show-login-button
(String): Iftrue
, it shows the login button at the top of the wizard. Default:false
.
utm-source
(String).
utm-medium
(String).
utm-campaign
(String).
utm-term
(String).
utm-content
(String).
Example
<!-- Pulling settings from URL --> <sesamy-paywall-wizard item-src="https://example.com/article" settings-url="https://example.com/paywall-wizard.json"> <!-- Pulling settings from inline HTML --> <script type="application/json" id="data"> { "data": { // See example JSON data in the Basic Usage section ... } } </script> <sesamy-paywall-wizard item-src="https://example.com/article" json-data-id="data">
Styling
The sesamy-paywall-wizard
element is packaged with base styles, which can be adjusted by modifying CSS custom properties.
The list of CSS custom properties are (the value set is the default
value, if the property is not presented it will take that value):
<style> sesamy-paywall-wizard { --font-family: "Helvetica"; // font family --image-height: 30px; // logo height --primary-color: #000; // background color of the button --button-color: #fff; // text color of the button --form-subtitle-color: var(--color, #3E445F); // text color of the subtitle --form-subtitle-font-weight: 400; // font weight of the subtitle --privacy-text-color: var(--color, #3E445F); // text color of the privacy text --headline-color: var(--color, #000); // text color of the headline --perks-color: var(--color, #3E445F); // text color of the perks --tag-background: #fdc306; // background color of the tag --tag-font-family: 'Times New Roman'; // font family of the tag --tag-color: #000; // text color of the tag } </style>