Webflow Integration
Helika Web SDK - Webflow Integration
The Helika SDK for Webflow enables full functionality of our Helika Web SDK within a Webflow site.
Features
- Streamline integration with Helika services
- Access to a wide range of Helika APIs
Current Version: 0.2.9
Quick Start
To install the Helika SDK for Webflow, you will need to embed some custom code into the head element of your Webflow site. This will allow you to make calls using helikaSDK.createEvent()
for all desired tracking.
- Please refer to the API Reference for more details.
- There are a few examples of how calls can be made in the Making Event Calls section.
<script type="module">
import Helika, { EventsBaseURL } from "https://cdn.jsdelivr.net/npm/[email protected]/+esm";
const api_key_helika = 'insert_api_key_here' <!-- Replace with your API Key-->
const helikaSDK = new Helika.EVENTS(api_key_helika, 'game_id', EventsBaseURL.EVENTS_DEV);
<!-- game_id must be alphanumeric, only underscore, no spaces -->
window.helikaSDK = helikaSDK;
helikaSDK.startSession();
</script>
Installation Walkthrough
Pre-requisites
- Helika API Key
- You’ll need a Helika API Key in order to use the snippet.
- Please reach out to Your Client Success Manager in order to receive an API key for your organization.
- Event Taxonomy
- We strongly recommend following our suggested Event Taxonomy for game event handling and structure. This is due to how we ingest and store data from your game, in order to make it accessible through our Game Management Platform. By following a standardized format, you will be able to access dashboards and other insights faster within the Helika Portal.
- Please contact your account representative to get support on Event Taxonomy.
Embedding Custom Code in Webflow
-
Log in to your Webflow account and select your desired website. Click Site Settings located on the left-hand side of the Dashboard.
-
After opening the site settings, look for Custom Code and select it. This will take you to the page where custom code can be embedded on a Webflow site.
- For more help with custom code, please refer to the Webflow documentation
-
Copy the Helika SDK Snippet into the Head code section.
<script type="module">
import Helika, { EventsBaseURL } from "https://cdn.jsdelivr.net/npm/[email protected]/+esm";
const api_key_helika = 'insert_api_key_here' <!-- Replace with your API Key-->
const helikaSDK = new Helika.EVENTS(api_key_helika, 'game_id', EventsBaseURL.EVENTS_DEV);
<!-- game_id must be alphanumeric, only underscore, no spaces -->
window.helikaSDK = helikaSDK;
helikaSDK.startSession();
<!-- Event calls for page loads go here. See examples below as reference. -->
</script>
Making Event Calls
Please make sure to follow the recommended Event Taxonomy when using createEvent().
- Event calls on page load can be added in the snippet.
Page Load Example
<script type="module">
import Helika, { EventsBaseURL } from "https://cdn.jsdelivr.net/npm/[email protected]/+esm";
const api_key_helika = 'insert_api_key_here'
const helikaSDK = new Helika.EVENTS(api_key_helika, 'game_id', EventsBaseURL.EVENTS_DEV);
window.helikaSDK = helikaSDK;
helikaSDK.startSession();
<!-- Page load calls below -->
if (window.location.pathname == '/') {
await helikaSDK.createEvent([{
game_id: 'game_id',
event_type: 'event_type_1',
event: {
info: 'extra info',
player_id: 'gamer_1'
}
}, {
game_id: 'game_id',
event_type: 'event_type_2',
event: {
info: 'different info',
timestamp: 'date'
}
}]);
} else if (window.location.pathname == '/second_page') {
await helikaSDK.createEvent([{
game_id: 'game_id',
event_type: 'event_type_3',
event: {
info: 'extra info'
}
}]);
}
</script>
- Event calls can also be made from event listeners, by calling the
helikaSDK.createEvent()
method.- Attach a listener to a button event or wherever you want the event to get called.
Event Listener Example
await window.helikaSDK.createEvent([{
game_id: 'game_id',
event_type: 'async_event',
event: {
user_action: 'async_click'
}
}])
API Reference
Conventions
The EventsBaseURL is an enum that dictates where to send all API requests. The SDK will handle the set-up for you. You just need to provide an API key and select whether it’s for production
or development
.
For testing purposes, you can change EVENTS_DEV
to EVENTS_LOCAL
which logs your events to console.log() instead of sending the events.
enum EventsBaseURL {
EVENTS_LOCAL,
EVENTS_DEV,
EVENTS_PROD
}
Disable Data Settings
You can disable certain information from getting stored by using Events.setDataSettings(DisableDataSettings.All)
enum DisableDataSettings {
None,
BrowserInfo,
DeviceInfo,
IpInfo,
OsInfo,
VpnInfo,
All
}
Game Event Taxonomy
In order for out event processors to parse your events, they must adhere to a specific guideline.
Example Event
{
"game_id": "game_id",
"event_type": "user_download",
"event": {
"userId": "user_1",
"win_number": 1,
"wallet": "0x4kd...."
}
}
Automatic Data Capture
The Helika SDK automatically appends some data fields in the event along side your customized data event.
Field | Type | Required/Optional | Description |
---|---|---|---|
game_id | string | required | The Game Identifier attribute for all events generated for this game. Default is set in the snippet and optionally overridden in the event call. |
created_at | DateTime | required | The timestamp when the event was created. |
session_id | u4 | required | The sdk generates a new Session ID when the Helika Object is created. |
utms | object | optional | The SDK parses the url parameters and records any important or interesting UTMs. |
helika_referral_link | string | optional | The Referral Link ID of the link that the user clicked in order to get to the game’s landing page. |
fp_data | object | optional | We keep track of all possible identifying information for the user. This will be sent on startSession() |
player_id | string | optional | If you'd like to keep track of a user's identifying information (user id, wallet address, in-game player id, etc), you can set the Player ID which get appended to all the events. |
Methods
Name | URL | Parameter | Description |
---|---|---|---|
constructor | helikaSDK() | api_key: string, game_id: string, baseURL: EventsBaseURL | Constructs the Event Service |
Start Session | helikaSDK.startSession() | ||
Create Event | helikaSDK.createEvent() | events: { game_id: string, event_type: string, event: Object }[] | This starts a user session, stores identifying user information, and UTMs that will get appended to events. |
Create UA Event | helikaSDK.createUAEvent() | events: { game_id: string, event_type: string, event: Object }[] | Sends the events to the Helika services |
Set Data Settings | helikaSDK.setDataSettings() | settings: DisableDataSettings | Disables storing certain data such as IP, location, browser info, device info, etc. |
Set Enabled | helikaSDK.setEnabled() | enabled: boolean | Sets whether it's sending the events to our data pipeline or simply logging the event to console.log(). This is used for testing purposes. |
Is Enabled | helikaSDK.isEnabled() | Gets whether the Sending Events is enabled or disabled |
License
The Helika SDK is released under the MIT License.
Updated 3 months ago