Contentstack JavaScript Utils SDK:
Contentstack is a headless CMS with an API-first approach. It is a CMS that developers can use to build powerful cross-platform applications in their favorite languages. Build your application frontend, and Contentstack will take care of the rest. Read More.
This guide will help you get started with Contentstack JavaScript Utils SDK to build apps powered by Contentstack.
Prerequisites
To get started with JavaScript, you will need the following:
SDK Installation and Setup
Note: If you are using JavaScript Contentstack SDK, you don’t need to run the command as ‘@contentstack/utils’ is already imported in the SDK.
Use the following command to install Contentstack JavaScript Utils SDK:
npm i @contentstack/utils
Usage
Let’s learn how you can use Utils SDK to render RTE embedded items and Supercharged RTE Json to HTML.
Create Render Option
To render embedded items on the front-end, use the renderOptions function, and define the UI elements you want to show in the front-end of your website, as shown in the example below:
const renderOptions = {
p: (node, next) => {
`<p class='class-id'>${next(node.children)}</p>`
}
h1: (node, next) => {
`<h1 class='class-id'>${next(node.children)}</h1>`
}
bold: (text) => {
`<b>${next(node.children)}</b>`
}
block: {
'product': (item, metadata) => {
`<div>
<h2 >${item.title}</h2>
<img src=${item.product_image.url} alt=${item.product_image.title}/>
<p>${item.price}</p>
</div>`
},
'$default': (item, metadata) => {
`<div>
<h2>${item.title}</h2>
<p>${item.description}</p>
</div>`
}
},
inline: {
'$default': (item, metadata) => {
`<span><b>${item.title}</b> - ${item.description}</span>`
}
},
link: (item, metadata) => {
`<a href="${metadata.attributes.href}">${metadata.text}</a>`
},
display: (item, metadata) => {
`<img src=${metadata.attributes.src} alt=${metadata.alt} />`
}
}
Basic Queries
Contentstack Utils SDK lets you interact with the Content Delivery APIs and retrieve embedded items from the RTE field of an entry.
Fetch Embedded Item(s) from a Single Entry
Render HTML RTE Embedded object
To get an embedded item of a single entry, you need to provide the stack API key, environment name, delivery token, content type and entry UID. Then, use the includeEmbeddedItems
and Contentstack.Utils.render
functions as shown below:
import * as Contentstack from 'contentstack'
const stack = Contentstack.Stack({
api_key: '<API_KEY>',
delivery_token: '<ENVIRONMENT_SPECIFIC_DELIVERY_TOKEN>',
environment: '<ENVIRONMENT>'})
stack.ContentType('<CONTENT_TYPE_UID>')
.Entry('<ENTRY_UID>')
.toJSON()
.includeEmbeddedItems()
.fetch()
.then(entry => {
Contentstack.Utils.render({ entry, renderOption })
})
If you have multiple RTE fields in an entry and want to fetch the embedded items from a particular RTE field, you need to provide a path of those RTE fields.
Refer to the example code below:
Contentstack.Utils.render({ entry, path: ["rte_fieldUid", "group.rteFieldUID"], renderOption })
Render Supercharged RTE contents
To get a single entry, you need to provide the stack API key, environment name, delivery token, content type and entry UID. Then, use Contentstack.Utils.jsonToHtml
function as shown below:
import * as Contentstack from 'contentstack'
const stack = Contentstack.Stack({
api_key: '<API_KEY>',
delivery_token: '<ENVIRONMENT_SPECIFIC_DELIVERY_TOKEN>',
environment: '<ENVIRONMENT>'})
stack.ContentType('<CONTENT_TYPE_UID>')
.Entry('<ENTRY_UID>')
.toJSON()
.fetch()
.then(entry => {
Contentstack.Utils.jsonToHtml({
entry,
path: ["rte_fieldUid", "group.rteFieldUID"],
renderOption
})
})
Node: Supercharged RTE also supports Embedded items to get all embedded items while fetching entry use includeEmbeddedItems
function.
Fetch Embedded Item(s) from Multiple Entries
Render HTML RTE Embedded object
To get embedded items from multiple entries, you need to provide the content type UID. You can also use the path variable in case the entries have multiple RTE fields.
import Contentstack from 'contentstack'
const stack = Contentstack.Stack({
api_key: '<API_KEY>',
delivery_token: '<ENVIRONMENT_SPECIFIC_DELIVERY_TOKEN>',
environment: '<ENVIRONMENT>'})
stack.ContentType('<CONTENT_TYPE_UID>')
.Query()
.toJSON()
.where('title', '<entry_title_to_search>')
.includeEmbeddedItems()
.find()
.then(result => {
result.forEach(entry => {
Contentstack.Utils.render({
entry,
path: ['rte', 'group.rteFieldUID'],
renderOption
})
})
})
Render Supercharged RTE contents
To get a multiple entries, you need to provide the stack API key, environment name, delivery token, content type and entry UID. Then, use Contentstack.Utils.jsonToHtml
function as shown below:
import * as Contentstack from 'contentstack'
const stack = Contentstack.Stack({
api_key: '<API_KEY>',
delivery_token: '<ENVIRONMENT_SPECIFIC_DELIVERY_TOKEN>',
environment: '<ENVIRONMENT>'})
stack.ContentType('<CONTENT_TYPE_UID>')
.Query()
.toJSON()
.where('title', '<entry_title_to_search>')
.find()
.then(result => {
result.forEach(entry => {
Contentstack.Utils.jsonToHtml({
entry,
path: ["rte_fieldUid", "group.rteFieldUID"],
renderOption
})
})
})
Node: Supercharged RTE also supports Embedded items to get all embedded items while fetching entry use includeEmbeddedItems
function.