his package allows to easily implement Spearly in your jQuery codes!
- Install with the following command:
// npm $ npm i -S @spearly/jquery-plugin // yarn $ yarn add @spearly/jquery-plugin
- Add the following to
webpack.config.js
:... plugins: [ new webpack.ProvidePlugin({ $: 'jquery', jQuery: 'jquery', 'window.jQuery': 'jquery', }), ], ...
- Add an import statement to your js file.
import '@spearly/jquery-plugin'
Put the following code under the jQuery script tag.
<script src="/jquery.js"></script>
<script src="https://cdn.jsdelivr.net/npm/@spearly/jquery-plugin/dist/spearly-plugin.js" defer></script>
Get the API Key from Spearly CMS and set up as follows.
$(function() {
$.spearly.init({ apiKey: 'YOUR_API_KEY' })
})
async function() {
// basic
const contents = await $.spearly.getList(CONTENT_TYPE_ID)
// when using some options
const filteredContents = await $.spearly.getList(CONTENT_TYPE_ID, { limit: 10, offset: 20 })
}
limit
(number, 10)offset
(number, 0)order
('desc' | 'asc', 'desc')orderBy
('latest' | 'popular' | string)filterBy
(string)filterValue
(string)filterRef
(string)rangeTo
(string)rangeFrom
(string)distinctId
(string)sessionId
(string)patternName
('a' | 'b')
async function() {
// basic
const content = await $.spearly.getContent(CONTENT_TYPE_ID, CONTENT_ID)
// when using some options
const optionalContent = await $.spearly.getContent(CONTENT_TYPE_ID, CONTENT_ID, { distinctId: DISTINCT_ID })
}
distinctId
(string)patternName
('a' | 'b')
async function() {
const content = await $.spearly.getContentPreview(CONTENT_TYPE_ID, CONTENT_ID, PREVIEW_TOKEN)
}
PREVIEW_TOKEN
can be obtained on the content edit page of the Spearly CMS.
async function() {
const form = await $.spearly.getFormLatest(FORM_ID)
}
FORM_ID
is for Form ID for embedding in Spearly CMS.
async function() {
const submit = await $.spearly.postFormAnswers(FORM_VERSION_ID, { ...YOUR_FORM_FIRLD_ANSWERS, _spearly_gotcha: '' })
}
FORM_VERSION_ID
is the ID to be obtained by Get Form.YOUR_FORM_FIELD_ANSWERS
is an object whose key is the form field ID and whose value is the content.
For example, If the form has name, email, and content, and you answer 'James', '[email protected]', and 'Hello world!', here is:{ name: 'James', email: '[email protected]', content: 'Hello world!' }
_spearly_gotcha
is an anti-spam field. Be sure to add it to YOUR_FORM_FIELD_ANSWERS.
Don't forget to install it in an invisible field on your form.
If you are using A/B testing, you can run the following code on page load to count impressions.
const content = await $.spearly.getContent(CONTENT_ID)
$.spearly.pageView({
patternName: content.attributes.patternName,
contentId: content.id,
})
If you are using A/B testing, you can count conversions by using the conversion method as follows
const content = await $.spearly.getContent(CONTENT_ID)
$('#submit').on('submit', () => {
$.spearly.conversion({
patternName: content.attributes.patternName,
contentId: content.id,
})
});