React Marketing Tools are a set of tools to make it easier for you to implement analytics and track user journeys, interactions throughout your App. using dataLayer/Google Tag Manager, GA4 fetch directly or coming soon facebook pixel.
- Have a look at the PR template doc for best approach to getting your pr merged.
- You can view it here
- Setting up config without provider is also an option, in this case you will only need to import buildConfig
import React from 'react'
import ReactDOM from 'react-dom/client'
import {
ReactMarketingProvider,
buildConfig,
BuildConfigOptions,
Tokens,
} from 'react-marketing-tools'
import App from './App'
/*
TOKENS are optional
const TOKENS: Tokens = {
// if withServerLocationInfo is true you must supply this token.
IP_INFO_TOKEN: 'SOME_TOKEN',
// if analyticsType = analyticsPlatform.GOOGLE the below tokens must be supplied.
GA4_PUBLIC_API_SECRET: 'SOME_TOKEN',
GA4_PUBLIC_MEASUREMENT_ID: 'SOME_TOKEN',
}
*/
// These are the keys for the values you want to include from your user data
// these must be included for any user data to be collected by analytics event if user data is hardcoded when passed in.
const includeUserKeys = [
'firstName',
'lastName',
]
const analyticsConfig: BuildConfigOptions = {
appName: 'my-awesome-app', // required
appSessionCookieName: 'APP_SESSION',
eventActionPrefix: { // this will extend the default values of eventActionPrefix
ACTION: 'ACTION',
OTHER_EVENT_NAME_TYPE: 'OTHER_EVENT_NAME_TYPE'
},
globalEventActionList: { // this will extend the default values of globalEventActionList
SIGN_IN: 'SIGN_IN',
SIGN_UP: 'SIGN_UP',
IMPORTANT_BUTTON_CLICKED: 'IMPORTANT_BUTTON_CLICKED'
},
// TOKENS // (optional),
includeUserKeys,
showMissingUserAttributesInConsole: false, // a boolean condition to show or hide "user" attributes that are not included in the "includeUserKeys" array, by console logging in dev tools.
withDeviceInfo: true, // (optional) has default value
withServerLocationInfo: false, // (optional) has default value
}
/**
* @type {Object} buildConfig -> options: all attributes of the options object must have a value, other than withDeviceInfo.
* @property {string} appName: the name of your app this value must be passed in.
* @property {string} appSessionCookieName This is used to get the cookie from storage based on a key you use, the value from the cookie will be used in "client_id:"
* @property {Object} eventActionPrefix: is a { key: 'value' } object that allows you to extend "analyticsEventActionPrefixList" object with custom eventActionPrefix. To see the build in list call the function showMeBuildInEventActionPrefixList().
* @property {Object} globalEventActionList: is a { key: 'value' } object that allows you to extend "analyticsGlobalEventActionList" object with custom eventActionNames. To see the build in list call the function showMeBuildInGlobalEventActionList().
* @property {Array} includeUserKeys: is an array of strings that represent keys from your user data that you want to whitelist, user data you wan to hash.
* @property {Boolean} showMissingUserAttributesInConsole a boolean condition to show or hide "user" attributes that are not included in the "includeUserKeys" array, by console logging in dev tools.
* @property {Object} TOKENS: is a { key: 'value' } object that includes the following keys, IP_INFO_TOKEN, GA4_PUBLIC_API_SECRET, GA4_PUBLIC_MEASUREMENT_ID, depending on if you need these features enabled.
* @property {Boolean} withDeviceInfo: if you want device information added to "globalVars" set this to true false by default.
* @property {Boolean} withServerLocationInfo: if you want server information added to "journeyProps" set this to true false by default.
*/
buildConfig(analyticsConfig)
ReactDOM.createRoot(document.getElementById('root')).render(
<React.StrictMode>
<ReactMarketingProvider>
<App />
</ReactMarketingProvider>
</React.StrictMode>
)
import { useState, useEffect, useCallback, useRef } from 'react'
import {
useMarketingApi,
useMarketingState,
EventNameInfo,
TrackAnalyticsEventOptions,
ProviderApiProps,
ProviderStateProps,
} from 'react-marketing-tools'
function App() {
const [count, setCount] = useState(0)
const {
analyticsPlatform,
appSessionCookieName,
eventActionPrefixList,
analyticsGlobalEventActionList,
}: ProviderStateProps = useMarketingState()
const {
trackAnalyticsEvent
/*
NOTE: If you want to see built in config items and your added items, use one of the following functions to the body of your functional component or useEffect/function
call it like so showMeBuildInAnalyticsPlatform() then check your console, in dev tools.
showMeBuildInAnalyticsPlatform,
showMeBuildInEventActionPrefixList,
showMeBuildInGlobalEventActionList,
*/
}: ProviderApiProps = useMarketingApi()
useEffect(function appLoadPageLandingWelcome() {
// create session cookie, useful for unauthenticated user tracking and other things
document.cookie = `${appSessionCookieName}=${uuid()};max-age=${70};SameSite=Strict;Secure`
const sendAnalyticsEvent = async () => {
const eventNameInfo: EventNameInfo = {
// If this is not passed in the event name will be a combination of actionPrefix & globalAppEvent
// J_UNAUTHENTICATED
eventName: 'Welcome Landing',
actionPrefix: eventActionPrefixList.JOURNEY,
globalAppEvent: analyticsGlobalEventActionList.UNAUTHENTICATED,
}
const trackingData: TrackAnalyticsEventOptions = {
data: {},
eventNameInfo,
analyticsType: analyticsPlatform.DATALAYER_PUSH,
dataLayerCheck: true,
userDataKeysToHashArray: null,
}
await trackAnalyticsEvent(trackingData)
}
sendAnalyticsEvent()
}, [])
const handleButtonClick = useCallback(async () => {
const countActual = count + 1
setCount(countActual)
const eventNameInfo: EventNameInfo = {
// If this is not passed in the event name will be a combination of actionPrefix & globalAppEvent
// I_AUTHENTICATED
eventName: 'count button click',
actionPrefix: eventActionPrefixList.INTERACTION,
globalAppEvent: analyticsGlobalEventActionList.AUTHENTICATED,
previousGlobalAppEvent: analyticsGlobalEventActionList.UNAUTHENTICATED,
}
const trackingData: TrackAnalyticsEventOptions = {
data: {
count: countActual,
// firstName: 'bob',
lastName: 'yeah nah',
email: '[email protected]',
},
eventNameInfo,
analyticsType: analyticsPlatform.DATALAYER_PUSH,
consoleLogData: {
showJourneyPropsPayload: true,
},
dataLayerCheck: false,
userDataKeysToHashArray: null,
}
await trackAnalyticsEvent(trackingData)
}, [count])
/* Example: use GA4 directly
const handleButtonClick = useCallback(async () => {
const countActual = count + 1
setCount(countActual)
const eventNameInfo: EventNameInfo = {
eventName: 'count button click',
actionPrefix: eventActionPrefixList.INTERACTION,
globalAppEvent: analyticsGlobalEventActionList.AUTHENTICATED,
previousGlobalAppEvent: analyticsGlobalEventActionList.UNAUTHENTICATED,
}
const trackingData: TrackAnalyticsEventOptions = {
data: {
count: countActual,
firstName: 'bob',
lastName: 'yeah nah',
email: '[email protected]',
},
eventNameInfo,
analyticsType: analyticsPlatform.GOOGLE,
userDataKeysToHashArray: ['email', 'firstName', 'lastName'],
consoleLogData: {
showJourneyPropsPayload: true,
},
}
await trackAnalyticsEvent(trackingData)
}, [count])
*/
...
return (
...
)
}
To view implementation and usage without the React Context/Provider visit this codepen