tianji/packages/client-sdk/src/tracker.ts

95 lines
1.8 KiB
TypeScript
Raw Normal View History

import loadScript from 'load-script';
interface InjectTrackerOptions {
/**
* your tianji application website
* @example
* https://tianji.example.com
*/
url: string;
/**
* Website id, you can get it from your tianji dashboard
*/
websiteId: string;
/**
* If you modify your tracker name with
*/
customTrackerName?: string;
/**
* is auto track route change and dom
*/
autoTrack?: boolean;
/**
* Whitelist domains, default will report all website
* @example
* example.com, www.example.com
*/
domains?: string[];
disableTrack?: boolean;
}
export async function initTianjiTracker(options: InjectTrackerOptions) {
const trackerName = options.customTrackerName ?? 'tracker.js';
const attrs: Record<string, string> = {
'data-website-id': options.websiteId,
};
if (options.autoTrack === false) {
attrs['data-auto-track'] = 'false';
}
if (Array.isArray(options.domains)) {
attrs['data-domains'] = options.domains.join(',');
}
if (options.disableTrack === true) {
attrs['data-do-not-track'] = 'true';
}
return new Promise<void>((resolve, reject) => {
loadScript(
`${options.url}/${trackerName}`,
{
async: true,
attrs,
},
(err, script) => {
if (err) {
reject(err);
return;
}
resolve();
}
);
});
}
2024-04-12 20:09:16 +00:00
export function reportEvent(eventName: string, data: Record<string, any>) {
const tianji = (window as any).tianji;
if (!tianji) {
return;
}
tianji.report(eventName, data);
}
interface IdentifyPayload {
email?: string;
username?: string;
avatar?: string;
[key: string]: any;
}
export function identify(data: IdentifyPayload) {
const tianji = (window as any).tianji;
if (!tianji) {
return;
}
tianji.identify(data);
}