From d35ae7827fb10c79988e9a1a4b628c1b736b6015 Mon Sep 17 00:00:00 2001 From: Tymoteusz Czech <2625371+Tymek@users.noreply.github.com> Date: Wed, 13 Mar 2024 10:45:42 +0100 Subject: [PATCH] feat: insights share events (#6480) Figure out how many people are using and sharing insights in Beta. https://linear.app/unleash/issue/1-2145/track-number-of-opened-share-links --------- Signed-off-by: andreas-unleash Co-authored-by: andreas-unleash --- .../admin/users/LinkField/LinkField.tsx | 3 ++ .../DashboardHeader/ShareLink/ShareLink.tsx | 41 +++++++++++++++++-- frontend/src/hooks/usePlausibleTracker.ts | 3 +- 3 files changed, 42 insertions(+), 5 deletions(-) diff --git a/frontend/src/component/admin/users/LinkField/LinkField.tsx b/frontend/src/component/admin/users/LinkField/LinkField.tsx index d58f22ce8b..101266f691 100644 --- a/frontend/src/component/admin/users/LinkField/LinkField.tsx +++ b/frontend/src/component/admin/users/LinkField/LinkField.tsx @@ -7,6 +7,7 @@ interface ILinkFieldProps { small?: boolean; successTitle?: string; errorTitle?: string; + onCopy?: () => void; } export const LinkField = ({ @@ -14,6 +15,7 @@ export const LinkField = ({ small, successTitle = 'Successfully copied invite link.', errorTitle = 'Could not copy invite link.', + onCopy, }: ILinkFieldProps) => { const { setToastData } = useToast(); @@ -32,6 +34,7 @@ export const LinkField = ({ type: 'success', title: successTitle, }); + onCopy?.(); }) .catch(() => { setError(); diff --git a/frontend/src/component/executiveDashboard/components/DashboardHeader/ShareLink/ShareLink.tsx b/frontend/src/component/executiveDashboard/components/DashboardHeader/ShareLink/ShareLink.tsx index edc614e3d6..2d9053278e 100644 --- a/frontend/src/component/executiveDashboard/components/DashboardHeader/ShareLink/ShareLink.tsx +++ b/frontend/src/component/executiveDashboard/components/DashboardHeader/ShareLink/ShareLink.tsx @@ -1,13 +1,45 @@ -import { VFC, useState } from 'react'; +import { VFC, useEffect, useState } from 'react'; import Share from '@mui/icons-material/Share'; import { Box, Button, Typography } from '@mui/material'; import { Dialogue } from 'component/common/Dialogue/Dialogue'; import { LinkField } from 'component/admin/users/LinkField/LinkField'; +import { useSearchParams } from 'react-router-dom'; +import { usePlausibleTracker } from 'hooks/usePlausibleTracker'; + +const createShareLink = () => { + const url = new URL(window.location.href); + url.searchParams.set('share', 'true'); + return url.toString(); +}; export const ShareLink: VFC = () => { const [isOpen, setIsOpen] = useState(false); - const url = new URL(window.location.href); - url.searchParams.set('share', 'true'); + const [searchParams, setSearchParams] = useSearchParams(); + const { trackEvent } = usePlausibleTracker(); + + useEffect(() => { + if (searchParams.get('share')) { + // Remove share query param from URL + setSearchParams((params) => { + params.delete('share'); + return params; + }); + + trackEvent('insights-share', { + props: { + eventType: 'link-opened', + }, + }); + } + }, [searchParams]); + + const onCopyEvent = () => { + trackEvent('insights-share', { + props: { + eventType: 'link-copied', + }, + }); + }; return ( <> @@ -30,9 +62,10 @@ export const ShareLink: VFC = () => { currently selected filter. diff --git a/frontend/src/hooks/usePlausibleTracker.ts b/frontend/src/hooks/usePlausibleTracker.ts index e72ca4793a..6ffa71b96e 100644 --- a/frontend/src/hooks/usePlausibleTracker.ts +++ b/frontend/src/hooks/usePlausibleTracker.ts @@ -57,7 +57,8 @@ export type CustomEvents = | 'feedback' | 'feature-metrics' | 'search-bar' - | 'sdk-reporting'; + | 'sdk-reporting' + | 'insights-share'; export const usePlausibleTracker = () => { const plausible = useContext(PlausibleContext);