Custom Head Tags
How to add custom head tags to more resources in Web Engine.
Head tags can be added to content models, views, the instance (global), or content items. They can be used to set facebook open graph tags, twitter cards, script links, css links, favicons, etc.. This document will explain how they works, what they are for, and how to create them with the API.
There are 5 different types of head tags available in Zesty.io. Here is a list of each one with example output:
Meta e.g. <meta name="description" content="my page description" />
Link e.g. <link rel="stylesheet" type="text/css" href="/site.css" />
Script e.g. <script type="text/javascript" src="/site.js?v=43"></script>
Title e.g. <title>My Page Title</title>
Style e.g. <style>body { background: orange } </style>
We are going to go through each one, with a couple example output and how to create them with the API POST calls to the API.
Dynamic Values in Head Tags
Meta, Title, Script, and Link tags may use dynamic reference to globals, settings, and content values.
Even though values shown below use curly braces { } these are not Parsley references.
Settings are accessed like
{settings.general.site_protocol}
Content item values are accessed like
{this.my_title}
Globals are accessed like
{globals.site_name}
Query Params are accessed like
{query_param.key}
or{get_var.key}
Path Parts accessed like
{path_part.0}
e.g./first/part/ {path_part.0} returns 'first'
Multiple like this
"my page is {this.title} from {globals.site_name}"
Examples
Custom Head Tag Loading
Custom head tags load based on their resource type in this order:
Instance Level
View Level
Model Level
Item Level
At each level they ordered in ascending order by their sort_order
Bad Tag References
If a bad tag reference is used, a reference to a global, setting, or content item that doesn't exist, then a warning (#bad reference {this.ref} #)
will be output in preview in the tag, on production sites an empty string will be returned.
Creating a Head Tag with the Rest API
A simple post request to your instances REST API will create a head tag.
Head Tag Creation
POST
https://8-XyZ123-123xYz.api.zesty.io/v1/web/headtags
Post a Request with a raw JSON body. The JSON body requires 3 fields type (meta|link|script|style|title), attributes (key value object), and sortOder (integer). JSON body example given to create meta tag. More specific ones are available under each tag type. This call adds a head tag immediately to Web Engine. A cache refresh in Web Engine is needed to see this the head tag appear. When added head tags to view resources, the tag needs to be added to each version of the view, production and stage. This is necessary for views like 404 pages, but content model views, apply the head tag to the resource ZUID of the content model.
Headers
Name | Type | Description |
---|---|---|
Authorization | string | Bearer XXXXXX (APP_SID Token) |
Request Body
Name | Type | Description |
---|---|---|
raw | object | { "type": "meta", "resourceZUID": "8-XyZ-XyZ" "attributes": { "name": "description", "content": "my page description" }, "sort": 1 } |
Working with Meta Tags
Meta tags are for search engines, social media, browser compatibilities, viewport info, etc. "Meta" tags are essentially became a catch all for all sorts of configuration information. Zesty.io has no restriction on what type of meta tags you can add. Zesty.io also auto generates meta tags for social sharing and search engines based on your content, learn more about that here.
As you can see in the example, meta tags are versatile, everything from search engine info to hidden configurations for iPhone rendering. Meta tags are hidden and are low weight so they minimally affect page load time.
Meta Tag Post Body Examples for the Rest API
Attributes are open ended for meta tags, so any key:value pair can be added. Here are a few post body example to create a few of the examples above.
Working with Script Head Tags
Script tags a used to load javascript files on page. Since head tags can be applied to content models, views, items, or globally, this enables you as the developer to optimize what you load per page.
Example Head Output
Example Post Body to create script head tags with the Rest API
Working with Link Head Tags
Link head tags a used to load CSS files, Icons, Alternate Language URLs, etc.. Like general meta tags, link tags feel like open ended configuration tags, as shown in the example head output. Since head tags can be applied to content models, views, items, or globally, this enables you as the developer to set specific link tags to configure page differently and optimize them for search engines and mobile rendering.
Example Head Output
Example Post Body to Create Links with the Rest API
Attributes are open ended for link tags, so any can be added. Here are a few post body example to create a few of the examples above.
Working with Title Head Tags
Title tags are linear, and offer one type. Title tags only accept one key value attribute "value".
Example Head Output
Example Post Body to create a head tags with the Rest API
Working with Style Head Tags
Style tags are linear, and offer one type and way to use them. Style tags only accept one key value attribute "value".
Example Head Output
Example Post Body to create a style tag with the Rest API
How to See all the Head Tags on a Content Instance
To see all the head tags on a content instance, make a Get request to the REST API endpoint /v1/web/headtags
Get Head Tags
GET
https://8-XyZ123-123xYz.api.zesty.io/v1/web/headtags
This endpoint allows you to view all the head tags you have on a content instance. Note, if you are logged into Zesty.io you can navigate to this get endpoint in your browser. Replace 8-XyZ123-123xYz
with your Instance ZUID.
Headers
Name | Type | Description |
---|---|---|
Authorization | string | Bearer XXXXXXXX (User Session Token) |
Updating a Head Tag
To get a head tag ZUID, call the get endpoint to see all the head tags and their ZUIDs.
Put Head Tag
PUT
https://8-XyZ123-123xYz.api.zesty.io/v1/web/headtags/:headTagZUID
Put updates the head tag in Web Engine immediately. A cache refresh in Web Engine is needed to see an update. Put will replace all attributes with the attributes you pass.
Path Parameters
Name | Type | Description |
---|---|---|
:headTagZUID | string | use the Get All Head Tags call to find the ZUID of the tag you wish to delete. |
Headers
Name | Type | Description |
---|---|---|
Authorization | string | Bearer XXXXXXX (user session token) |
Request Body
Name | Type | Description |
---|---|---|
raw | string | { "type": "meta", "sort" : 2, "attributes" : { "name" : "description", "content" : " hello world" } } |
Deleting a Head Tag
Delete Head Tag
DELETE
https://8-XyZ123-123xYz.api.zesty.io/v1/web/headtags/:headTagZUID
Removes a head tag immediately from Web Engine. A cache refresh in Web Engine is needed to see this update.
Path Parameters
Name | Type | Description |
---|---|---|
:headTagZUID | string | use the Get All Head Tags call to find the ZUID of the tag you wish to delete. |
Headers
Name | Type | Description |
---|---|---|
Authorization | string | Bearer XXXXXXX (user session token) |
Last updated