2020-03-03 07:02:53 +00:00
|
|
|
// Events
|
2020-04-10 08:48:00 +00:00
|
|
|
import * as log from "loglevel";
|
2020-05-28 18:10:26 +00:00
|
|
|
import FeatureFlag from "./featureFlags";
|
2020-04-10 08:48:00 +00:00
|
|
|
|
2019-09-09 09:08:54 +00:00
|
|
|
export type EventName =
|
2020-03-11 13:59:46 +00:00
|
|
|
| "LOGIN_CLICK"
|
|
|
|
|
| "SIGNUP_CLICK"
|
2019-09-09 09:08:54 +00:00
|
|
|
| "PAGE_VIEW"
|
|
|
|
|
| "ADD_COMPONENT"
|
|
|
|
|
| "DELETE_COMPONENT"
|
2020-03-03 07:02:53 +00:00
|
|
|
| "RESIZE_COMPONENT"
|
|
|
|
|
| "WIDGET_DRAG"
|
|
|
|
|
| "WIDGET_DROP"
|
|
|
|
|
| "WIDGET_DELETE"
|
|
|
|
|
| "WIDGET_RESIZE_START"
|
|
|
|
|
| "WIDGET_RESIZE_END"
|
|
|
|
|
| "WIDGET_PROPERTY_UPDATE"
|
|
|
|
|
| "WIDGET_TOGGLE_JS_PROP"
|
|
|
|
|
| "WIDGET_CARD_DRAG"
|
|
|
|
|
| "WIDGET_CARD_DROP"
|
|
|
|
|
| "CREATE_PAGE"
|
|
|
|
|
| "PAGE_RENAME"
|
|
|
|
|
| "PAGE_SWITCH"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "DELETE_PAGE"
|
|
|
|
|
| "SIDEBAR_NAVIGATION"
|
|
|
|
|
| "PUBLISH_APP"
|
|
|
|
|
| "PREVIEW_APP"
|
|
|
|
|
| "EDITOR_OPEN"
|
|
|
|
|
| "CREATE_API"
|
2020-05-05 07:50:30 +00:00
|
|
|
| "IMPORT_API"
|
|
|
|
|
| "IMPORT_API_CLICK"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "SAVE_API"
|
2020-03-11 13:59:46 +00:00
|
|
|
| "SAVE_API_CLICK"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "RUN_API"
|
2020-03-11 13:59:46 +00:00
|
|
|
| "RUN_API_CLICK"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "DELETE_API"
|
2020-03-11 13:59:46 +00:00
|
|
|
| "DELETE_API_CLICK"
|
2020-05-05 13:21:17 +00:00
|
|
|
| "DUPLICATE_API_CLICK"
|
|
|
|
|
| "IMPORT_API"
|
|
|
|
|
| "EXPAND_API"
|
|
|
|
|
| "IMPORT_API_CLICK"
|
|
|
|
|
| "MOVE_API_CLICK"
|
|
|
|
|
| "ADD_API_PAGE"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "DUPLICATE_API"
|
2020-05-05 07:50:30 +00:00
|
|
|
| "DUPLICATE_API_CLICK"
|
|
|
|
|
| "RUN_QUERY"
|
|
|
|
|
| "DELETE_QUERY"
|
|
|
|
|
| "SAVE_QUERY"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "MOVE_API"
|
2020-05-05 13:21:17 +00:00
|
|
|
| "3P_PROVIDER_CLICK"
|
2020-03-06 04:59:24 +00:00
|
|
|
| "API_SELECT"
|
|
|
|
|
| "CREATE_API_CLICK"
|
|
|
|
|
| "AUTO_COMPELTE_SHOW"
|
|
|
|
|
| "AUTO_COMPLETE_SELECT"
|
|
|
|
|
| "CREATE_APP_CLICK"
|
|
|
|
|
| "CREATE_APP"
|
|
|
|
|
| "CREATE_DATA_SOURCE_CLICK"
|
2020-03-11 13:59:46 +00:00
|
|
|
| "SAVE_DATA_SOURCE"
|
2020-05-05 07:50:30 +00:00
|
|
|
| "CREATE_QUERY_CLICK"
|
2020-03-11 13:59:46 +00:00
|
|
|
| "NAVIGATE"
|
|
|
|
|
| "PAGE_LOAD"
|
2020-03-18 14:31:30 +00:00
|
|
|
| "NAVIGATE_EDITOR"
|
|
|
|
|
| "PROPERTY_PANE_OPEN"
|
|
|
|
|
| "PROPERTY_PANE_CLOSE"
|
|
|
|
|
| "PROPERTY_PANE_OPEN_CLICK"
|
|
|
|
|
| "PROPERTY_PANE_CLOSE_CLICK";
|
2020-03-03 07:02:53 +00:00
|
|
|
|
2019-09-09 09:08:54 +00:00
|
|
|
export type Gender = "MALE" | "FEMALE";
|
2019-08-30 11:23:42 +00:00
|
|
|
export interface User {
|
2019-09-09 09:08:54 +00:00
|
|
|
userId: string;
|
|
|
|
|
name: string;
|
|
|
|
|
email: string;
|
|
|
|
|
gender: Gender;
|
2019-08-30 11:23:42 +00:00
|
|
|
}
|
|
|
|
|
|
2020-03-09 05:46:32 +00:00
|
|
|
function getApplicationId(location: Location) {
|
|
|
|
|
const pathSplit = location.pathname.split("/");
|
|
|
|
|
const applicationsIndex = pathSplit.findIndex(
|
|
|
|
|
path => path === "applications",
|
|
|
|
|
);
|
|
|
|
|
const appId = pathSplit[applicationsIndex + 1];
|
|
|
|
|
|
|
|
|
|
return appId;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-30 11:23:42 +00:00
|
|
|
class AnalyticsUtil {
|
2020-03-11 13:59:46 +00:00
|
|
|
static user: any = undefined;
|
2019-09-09 09:08:54 +00:00
|
|
|
static initializeHotjar(id: string, sv: string) {
|
|
|
|
|
(function init(h: any, o: any, t: any, j: any, a?: any, r?: any) {
|
|
|
|
|
h.hj =
|
|
|
|
|
h.hj ||
|
|
|
|
|
function() {
|
|
|
|
|
(h.hj.q = h.hj.q || []).push(arguments); //eslint-disable-line prefer-rest-params
|
|
|
|
|
};
|
|
|
|
|
h._hjSettings = { hjid: id, hjsv: sv };
|
|
|
|
|
a = o.getElementsByTagName("head")[0];
|
|
|
|
|
r = o.createElement("script");
|
|
|
|
|
r.async = 1;
|
|
|
|
|
r.src = t + h._hjSettings.hjid + j + h._hjSettings.hjsv;
|
|
|
|
|
a.appendChild(r);
|
|
|
|
|
})(window, document, "//static.hotjar.com/c/hotjar-", ".js?sv=");
|
|
|
|
|
}
|
2019-08-30 11:23:42 +00:00
|
|
|
|
2020-03-06 08:14:59 +00:00
|
|
|
static initializeSegment(key: string) {
|
2019-09-09 09:08:54 +00:00
|
|
|
(function init(window: any) {
|
|
|
|
|
const analytics = (window.analytics = window.analytics || []);
|
|
|
|
|
if (!analytics.initialize) {
|
|
|
|
|
if (analytics.invoked) {
|
|
|
|
|
window.console &&
|
|
|
|
|
console.error &&
|
|
|
|
|
console.error("Segment snippet included twice.");
|
|
|
|
|
} else {
|
|
|
|
|
analytics.invoked = !0;
|
|
|
|
|
analytics.methods = [
|
|
|
|
|
"trackSubmit",
|
|
|
|
|
"trackClick",
|
|
|
|
|
"trackLink",
|
|
|
|
|
"trackForm",
|
|
|
|
|
"pageview",
|
|
|
|
|
"identify",
|
|
|
|
|
"reset",
|
|
|
|
|
"group",
|
|
|
|
|
"track",
|
|
|
|
|
"ready",
|
|
|
|
|
"alias",
|
|
|
|
|
"debug",
|
|
|
|
|
"page",
|
|
|
|
|
"once",
|
|
|
|
|
"off",
|
|
|
|
|
"on",
|
|
|
|
|
];
|
|
|
|
|
analytics.factory = function(t: any) {
|
|
|
|
|
return function() {
|
|
|
|
|
const e = Array.prototype.slice.call(arguments); //eslint-disable-line prefer-rest-params
|
|
|
|
|
e.unshift(t);
|
|
|
|
|
analytics.push(e);
|
|
|
|
|
return analytics;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
for (let t: any = 0; t < analytics.methods.length; t++) {
|
|
|
|
|
const e = analytics.methods[t];
|
|
|
|
|
analytics[e] = analytics.factory(e);
|
|
|
|
|
}
|
|
|
|
|
analytics.load = function(t: any, e: any) {
|
|
|
|
|
const n = document.createElement("script");
|
|
|
|
|
n.type = "text/javascript";
|
|
|
|
|
n.async = !0;
|
|
|
|
|
n.src =
|
|
|
|
|
"https://cdn.segment.com/analytics.js/v1/" +
|
|
|
|
|
t +
|
|
|
|
|
"/analytics.min.js";
|
|
|
|
|
const a: any = document.getElementsByTagName("script")[0];
|
|
|
|
|
a.parentNode.insertBefore(n, a);
|
|
|
|
|
analytics._loadOptions = e;
|
|
|
|
|
};
|
|
|
|
|
analytics.SNIPPET_VERSION = "4.1.0";
|
2020-03-06 08:14:59 +00:00
|
|
|
analytics.load(key);
|
2019-09-09 09:08:54 +00:00
|
|
|
analytics.page();
|
|
|
|
|
}
|
|
|
|
|
})(window);
|
|
|
|
|
}
|
2019-08-30 11:23:42 +00:00
|
|
|
|
2019-09-09 09:08:54 +00:00
|
|
|
static logEvent(eventName: EventName, eventData: any) {
|
|
|
|
|
const windowDoc: any = window;
|
2020-03-06 04:59:24 +00:00
|
|
|
let finalEventData = eventData;
|
|
|
|
|
const userData = AnalyticsUtil.user;
|
2020-03-09 05:46:32 +00:00
|
|
|
const appId = getApplicationId(windowDoc.location);
|
2020-03-06 04:59:24 +00:00
|
|
|
if (userData) {
|
2020-03-11 13:59:46 +00:00
|
|
|
const app = (userData.applications || []).find(
|
|
|
|
|
(app: any) => app.id === appId,
|
|
|
|
|
);
|
2020-03-06 04:59:24 +00:00
|
|
|
finalEventData = {
|
|
|
|
|
...finalEventData,
|
|
|
|
|
userData: {
|
2020-03-09 05:46:32 +00:00
|
|
|
userId: userData.id,
|
2020-03-06 04:59:24 +00:00
|
|
|
email: userData.email,
|
2020-08-04 12:27:25 +00:00
|
|
|
currentOrgId: userData.currentOrganizationId,
|
2020-03-09 05:46:32 +00:00
|
|
|
appId: appId,
|
|
|
|
|
appName: app ? app.name : undefined,
|
2020-03-06 04:59:24 +00:00
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
}
|
2020-03-03 07:02:53 +00:00
|
|
|
if (windowDoc.analytics) {
|
2020-03-06 04:59:24 +00:00
|
|
|
windowDoc.analytics.track(eventName, finalEventData);
|
2020-03-03 07:02:53 +00:00
|
|
|
} else {
|
2020-04-10 08:48:00 +00:00
|
|
|
log.debug("Event fired", eventName, finalEventData);
|
2020-03-03 07:02:53 +00:00
|
|
|
}
|
2019-09-09 09:08:54 +00:00
|
|
|
}
|
2019-08-30 11:23:42 +00:00
|
|
|
|
2019-09-09 09:08:54 +00:00
|
|
|
static identifyUser(userId: string, userData: User) {
|
|
|
|
|
const windowDoc: any = window;
|
2020-03-06 04:59:24 +00:00
|
|
|
AnalyticsUtil.user = userData;
|
2020-05-28 18:10:26 +00:00
|
|
|
FeatureFlag.identify(userData);
|
2020-03-03 07:02:53 +00:00
|
|
|
if (windowDoc.analytics) {
|
|
|
|
|
windowDoc.analytics.identify(userId, userData);
|
|
|
|
|
}
|
2019-09-09 09:08:54 +00:00
|
|
|
}
|
2020-04-08 08:43:56 +00:00
|
|
|
|
|
|
|
|
static reset() {
|
|
|
|
|
const windowDoc: any = window;
|
2020-04-15 14:19:39 +00:00
|
|
|
windowDoc.analytics && windowDoc.analytics.reset();
|
|
|
|
|
windowDoc.mixpanel && windowDoc.mixpanel.reset();
|
2020-04-08 08:43:56 +00:00
|
|
|
}
|
2019-08-30 11:23:42 +00:00
|
|
|
}
|
|
|
|
|
|
2019-09-09 09:08:54 +00:00
|
|
|
export default AnalyticsUtil;
|