On your storefront, we automatically add and update 2 files:
inveterate-theme.liquid
inveterate-checkout.liquid
See Snippets for more information about this.
The Inveterate Storefront code is code used to implement front end solutions involving memberships. It contains useful data and helpful functions we use for our standard features, as well as merchant to merchant custom features.
inveterate
objectAll of the storefront code is contained within a single object called inveterate
, which is attached to the window
object.
To explore everything contained in the inveterate
object, type the following code in your browser console:
Visit the following links for more information about what's contained within the inveterate
object.
All Inveterate properties can be found in the properties
namespace within the inveterate
object.
To view the properties
object paste the following into the browser console:
The above code will display the following object structure:
benefits
: An object of benefits you have enabled/disabled and all of the settings associated with them.
campaigns
- An object of campaigns you have created in association with the Early Access benefit.
constants
- Object is empty at the moment.
customer
- An object containing information about the current signed in customer and their membership status.
pageType
: The type of page you're currently on.
product
: An object containing details about the membership subscription product.
redirectUrl
: The default URL location of the landing page.
referralApiUrl
: URL for making get request to track referrals.
referralData
: An object containing the details of a referral in progress.
referralStorageName
: The name where referral data is stored within localStorage.
This section contains information about how to customize your storefront UI.
Add To Cart ButtonThis is an advanced guide.
Inveterate utilizes Shopify's native subscription functionality to provide a seamless purchasing experience for your customers. We create a normal product in your Shopify instance, but the main differences between this product and other products is it has a selling plan attached to it and it's a subscription-only product. A selling plan is the mechanism Shopify uses to identify how a subscription product should be billed and shipped to the customer. These selling plans have an ID attached to them which is required when adding the product to cart for Shopify to understand it needs to be treated line a subscription.
Normally, when adding a product to cart through Shopify's AJAX Cart API, you would do the following:
As shown above, we are adding one item to cart by passing in its variant ID and quantity in the id
and quantity
fields. For subscription products we would add the following change:
As shown above, we have mostly the same code with one small tweak. In the items
array we've updated the item we're adding to have the selling plan id (seen in the selling_plan
field). As mentioned earlier, this is what lets Shopify know that this is a subscription product and should be treated as such during checkout as well as in Shopify's backend system.
Shopify does not display the selling plan ID in their admin, which makes it a little tougher to find. In our front end JavaScript, we've added some properties to help.
On the front end storefront of your site (any page besides checkout) type inveterate
into your browser console. This should return an Object that looks something like this (if yours looks slightly different you're using a newer version):
If you see an error, that usually means the Inveterate app embed has not been enabled in the theme settings yet. Once enabled, you should be able to see this.
Next, type inveterate.properties.product
. You should see the following:
If you see an error or "falsey" value, that usually means the product either has not been created correctly, is still in "Draft" mode in Shopify or is not in the "Online Store" sales channel. Check those three options before continuing.
With those 2 checks out of the way, you should be able to type in: inveterate.properties.product.selling_plan_groups[0].selling_plans[0].id
which should display something like:
Those numbers are you selling plan ID. This is what you pass along to Shopify when adding the product to cart.
See Shopify's Documentation as well for more information on selling plans.
One last thing to notice in the fetch
code snippet above is that we're passing in a properties
object to Shopify with _inveterate_subscription: true
. This is a useful troubleshooting tool to identify how the membership product was added to cart. This is not required, but strongly recommended to add.
When setting up a landing page with multiple tiers, the process remains the same for each ATC button. As you configure each one, you just need to ensure you select the correct product and selling plan for each ATC button.
You can find the product, variant and selling plan information for each tier in our inveterate.membershipProducts
property.
If you use a custom Landing Page, you will need to adjust the Add To Cart code further in order for the benefit to work properly. In the guide above, only one product was added to the [items] array. In order to configure the Free Gift benefit, all you need to do is add the second (free gift) product to the array as well.
This is an example of one product:
This is an example of two products, e.g. the membership product and the free gift: