Analytics
Learn how to send analytics events from your website.
BaseHub’s Event Block provides a powerful way to know more about how your content is performing. The unique thing about it is that Events that occur throughout your website can be tied directly to a Block—therefore keeping it in context.
While this article focuses on analytics, the Event block is versatile and offers much more functionality, including two different layouts and multiple use cases. For a more complex use case, check out Forms.
The Event Block time-series can be used for tracking things like:
Page views (internal and user facing)
Button/Link Clicks
Feedback forms
Or anything you want, really.
Set up an Event Block and start receiving events
First of all, you’ll need to add a new Event Block to your repo.
Create a new event block
Switch to Time-series layout
Commit your changes (not necessary if you’re working on draft mode)
Get your event’s
ingestKey
ingestKey
vs adminKey
Keep in mind that the Event block exposes two different keys for different type of actions.
Since sending data is the most common, and at the same time the most safe, action in events, it has a distinctive ingestKey
that can be safely used client side.
On the other side, update and read access is reserved for the adminKey
and could be the case that the data stored being sensitive enough to protect that key and only use it server-side.
Send an Event
In order to send an event, you’ll need to first get the ingestKey
of an Event Block from the GraphQL API. Let's look at an example that tracks page views on the homepage. Once we get the page data and its ingestKey
, we’ll import { sendEvent } from "basehub/events"
and run it on mount:
import { Pump } from "basehub/react-pump"
import { draftMode } from "next/headers"
const Homepage = () => {
return (
<Pump
next={{ revalidate: 30 }}
draft={draftMode().isEnabled}
queries={[
{
homepage: {
_title: true,
pageViews: {
ingestKey: true,
}
},
},
]}
>
{async ([{ homepage }]) => {
"use server"
return (
<div>
<PageView ingestKey={homepage.pageViews.ingestKey} />
<h1>{homepage._title}</h1>
</div>
)
}}
</Pump>
)
}
Get an Event count
In case you want to show the Event Count in your website—for example, to render a “view count”—, well, you can! Following up from the <PageView />
component we built previously, we can update it so that it runs getEvents
and renders it:
"use client"
import * as React from "react"
import type { PageViews as PageViewsType } from "~/.basehub/schema"
import { sendEvent, getEvents } from "basehub/events"
export const PageView = ({
ingestKey,
adminKey,
}: {
ingestKey: PageViewsType["ingestKey"],
adminKey: PageViewsType["adminKey"]
}) => {
const [count, setCount] = React.useState()
// On mount, send the event
React.useEffect(() => {
sendEvent({ ingestKey, name: "page_view" })
}, [])
// We also get the event count so we can render it
React.useEffect(() => {
getEvents(key, {
type: 'time-series',
range: 'all-time'
}).then(
(response) => {
if (response.success) {
setCount(response.data)
}
},
)
}, [])
return <div>Views: {count ?? "Loading..."}</div>
}