UNPKG

matrix-react-sdk

Version:
124 lines (120 loc) 16 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.PosthogScreenTracker = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = require("react"); var _PageTypes = _interopRequireDefault(require("./PageTypes")); var _Views = _interopRequireDefault(require("./Views")); var _PosthogAnalytics = require("./PosthogAnalytics"); /* Copyright 2024 New Vector Ltd. Copyright 2022 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ const notLoggedInMap = { [_Views.default.LOADING]: "Loading", [_Views.default.CONFIRM_LOCK_THEFT]: "ConfirmStartup", [_Views.default.WELCOME]: "Welcome", [_Views.default.LOGIN]: "Login", [_Views.default.REGISTER]: "Register", [_Views.default.USE_CASE_SELECTION]: "UseCaseSelection", [_Views.default.FORGOT_PASSWORD]: "ForgotPassword", [_Views.default.COMPLETE_SECURITY]: "CompleteSecurity", [_Views.default.E2E_SETUP]: "E2ESetup", [_Views.default.SOFT_LOGOUT]: "SoftLogout", [_Views.default.LOCK_STOLEN]: "SessionLockStolen" }; const loggedInPageTypeMap = { [_PageTypes.default.HomePage]: "Home", [_PageTypes.default.RoomView]: "Room", [_PageTypes.default.UserView]: "User" }; class PosthogTrackers { constructor() { (0, _defineProperty2.default)(this, "view", _Views.default.LOADING); (0, _defineProperty2.default)(this, "pageType", void 0); (0, _defineProperty2.default)(this, "override", void 0); } static get instance() { if (!PosthogTrackers.internalInstance) { PosthogTrackers.internalInstance = new PosthogTrackers(); } return PosthogTrackers.internalInstance; } trackPageChange(view, pageType, durationMs) { this.view = view; this.pageType = pageType; if (this.override) return; this.trackPage(durationMs); } trackPage(durationMs) { const screenName = this.view === _Views.default.LOGGED_IN ? loggedInPageTypeMap[this.pageType] : notLoggedInMap[this.view]; _PosthogAnalytics.PosthogAnalytics.instance.trackEvent({ eventName: "$pageview", $current_url: screenName, durationMs }); } trackOverride(screenName) { if (!screenName) return; this.override = screenName; _PosthogAnalytics.PosthogAnalytics.instance.trackEvent({ eventName: "$pageview", $current_url: screenName }); } clearOverride(screenName) { if (screenName !== this.override) return; this.override = undefined; this.trackPage(); } static trackInteraction(name, ev, index) { let interactionType; if (ev?.type === "click") { interactionType = "Pointer"; } else if (ev?.type.startsWith("key")) { interactionType = "Keyboard"; } _PosthogAnalytics.PosthogAnalytics.instance.trackEvent({ eventName: "Interaction", interactionType, index, name }); } /** * Track a pin or unpin action on a message. * @param kind - Is pin or unpin. * @param from - From where the action is triggered. */ static trackPinUnpinMessage(kind, from) { _PosthogAnalytics.PosthogAnalytics.instance.trackEvent({ eventName: "PinUnpinAction", kind, from }); } } exports.default = PosthogTrackers; (0, _defineProperty2.default)(PosthogTrackers, "internalInstance", void 0); class PosthogScreenTracker extends _react.PureComponent { componentDidMount() { PosthogTrackers.instance.trackOverride(this.props.screenName); } componentDidUpdate() { // We do not clear the old override here so that we do not send the non-override screen as a transition PosthogTrackers.instance.trackOverride(this.props.screenName); } componentWillUnmount() { PosthogTrackers.instance.clearOverride(this.props.screenName); } render() { return null; // no need to render anything, we just need to hook into the React lifecycle } } exports.PosthogScreenTracker = PosthogScreenTracker; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_PageTypes","_interopRequireDefault","_Views","_PosthogAnalytics","notLoggedInMap","Views","LOADING","CONFIRM_LOCK_THEFT","WELCOME","LOGIN","REGISTER","USE_CASE_SELECTION","FORGOT_PASSWORD","COMPLETE_SECURITY","E2E_SETUP","SOFT_LOGOUT","LOCK_STOLEN","loggedInPageTypeMap","PageType","HomePage","RoomView","UserView","PosthogTrackers","constructor","_defineProperty2","default","instance","internalInstance","trackPageChange","view","pageType","durationMs","override","trackPage","screenName","LOGGED_IN","PosthogAnalytics","trackEvent","eventName","$current_url","trackOverride","clearOverride","undefined","trackInteraction","name","ev","index","interactionType","type","startsWith","trackPinUnpinMessage","kind","from","exports","PosthogScreenTracker","PureComponent","componentDidMount","props","componentDidUpdate","componentWillUnmount","render"],"sources":["../src/PosthogTrackers.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport { PureComponent, SyntheticEvent } from \"react\";\nimport { WebScreen as ScreenEvent } from \"@matrix-org/analytics-events/types/typescript/WebScreen\";\nimport { Interaction as InteractionEvent } from \"@matrix-org/analytics-events/types/typescript/Interaction\";\nimport { PinUnpinAction } from \"@matrix-org/analytics-events/types/typescript/PinUnpinAction\";\n\nimport PageType from \"./PageTypes\";\nimport Views from \"./Views\";\nimport { PosthogAnalytics } from \"./PosthogAnalytics\";\n\nexport type ScreenName = ScreenEvent[\"$current_url\"];\nexport type InteractionName = InteractionEvent[\"name\"];\n\nconst notLoggedInMap: Record<Exclude<Views, Views.LOGGED_IN>, ScreenName> = {\n    [Views.LOADING]: \"Loading\",\n    [Views.CONFIRM_LOCK_THEFT]: \"ConfirmStartup\",\n    [Views.WELCOME]: \"Welcome\",\n    [Views.LOGIN]: \"Login\",\n    [Views.REGISTER]: \"Register\",\n    [Views.USE_CASE_SELECTION]: \"UseCaseSelection\",\n    [Views.FORGOT_PASSWORD]: \"ForgotPassword\",\n    [Views.COMPLETE_SECURITY]: \"CompleteSecurity\",\n    [Views.E2E_SETUP]: \"E2ESetup\",\n    [Views.SOFT_LOGOUT]: \"SoftLogout\",\n    [Views.LOCK_STOLEN]: \"SessionLockStolen\",\n};\n\nconst loggedInPageTypeMap: Record<PageType, ScreenName> = {\n    [PageType.HomePage]: \"Home\",\n    [PageType.RoomView]: \"Room\",\n    [PageType.UserView]: \"User\",\n};\n\nexport default class PosthogTrackers {\n    private static internalInstance: PosthogTrackers;\n\n    public static get instance(): PosthogTrackers {\n        if (!PosthogTrackers.internalInstance) {\n            PosthogTrackers.internalInstance = new PosthogTrackers();\n        }\n        return PosthogTrackers.internalInstance;\n    }\n\n    private view: Views = Views.LOADING;\n    private pageType?: PageType;\n    private override?: ScreenName;\n\n    public trackPageChange(view: Views, pageType: PageType | undefined, durationMs: number): void {\n        this.view = view;\n        this.pageType = pageType;\n        if (this.override) return;\n        this.trackPage(durationMs);\n    }\n\n    private trackPage(durationMs?: number): void {\n        const screenName =\n            this.view === Views.LOGGED_IN ? loggedInPageTypeMap[this.pageType!] : notLoggedInMap[this.view];\n        PosthogAnalytics.instance.trackEvent<ScreenEvent>({\n            eventName: \"$pageview\",\n            $current_url: screenName,\n            durationMs,\n        });\n    }\n\n    public trackOverride(screenName: ScreenName): void {\n        if (!screenName) return;\n        this.override = screenName;\n        PosthogAnalytics.instance.trackEvent<ScreenEvent>({\n            eventName: \"$pageview\",\n            $current_url: screenName,\n        });\n    }\n\n    public clearOverride(screenName: ScreenName): void {\n        if (screenName !== this.override) return;\n        this.override = undefined;\n        this.trackPage();\n    }\n\n    public static trackInteraction(name: InteractionName, ev?: SyntheticEvent | Event, index?: number): void {\n        let interactionType: InteractionEvent[\"interactionType\"];\n        if (ev?.type === \"click\") {\n            interactionType = \"Pointer\";\n        } else if (ev?.type.startsWith(\"key\")) {\n            interactionType = \"Keyboard\";\n        }\n\n        PosthogAnalytics.instance.trackEvent<InteractionEvent>({\n            eventName: \"Interaction\",\n            interactionType,\n            index,\n            name,\n        });\n    }\n\n    /**\n     * Track a pin or unpin action on a message.\n     * @param kind - Is pin or unpin.\n     * @param from - From where the action is triggered.\n     */\n    public static trackPinUnpinMessage(kind: PinUnpinAction[\"kind\"], from: PinUnpinAction[\"from\"]): void {\n        PosthogAnalytics.instance.trackEvent<PinUnpinAction>({\n            eventName: \"PinUnpinAction\",\n            kind,\n            from,\n        });\n    }\n}\n\nexport class PosthogScreenTracker extends PureComponent<{ screenName: ScreenName }> {\n    public componentDidMount(): void {\n        PosthogTrackers.instance.trackOverride(this.props.screenName);\n    }\n\n    public componentDidUpdate(): void {\n        // We do not clear the old override here so that we do not send the non-override screen as a transition\n        PosthogTrackers.instance.trackOverride(this.props.screenName);\n    }\n\n    public componentWillUnmount(): void {\n        PosthogTrackers.instance.clearOverride(this.props.screenName);\n    }\n\n    public render(): React.ReactNode {\n        return null; // no need to render anything, we just need to hook into the React lifecycle\n    }\n}\n"],"mappings":"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","ignoreList":[]}