63 lines
1.8 KiB
TypeScript
63 lines
1.8 KiB
TypeScript
// eslint-disable-next-line no-restricted-imports
|
|
import { noop } from "lodash";
|
|
import { useIntercom as useIntercomLib } from "react-use-intercom";
|
|
import { z } from "zod";
|
|
|
|
import dayjs from "@calcom/dayjs";
|
|
import { CAL_URL } from "@calcom/lib/constants";
|
|
import { useHasTeamPlan, useHasPaidPlan } from "@calcom/lib/hooks/useHasPaidPlan";
|
|
import { trpc } from "@calcom/trpc/react";
|
|
|
|
// eslint-disable-next-line turbo/no-undeclared-env-vars
|
|
export const isInterComEnabled = z.string().min(1).safeParse(process.env.NEXT_PUBLIC_INTERCOM_APP_ID).success;
|
|
|
|
const useIntercomHook = isInterComEnabled
|
|
? useIntercomLib
|
|
: () => {
|
|
return {
|
|
boot: noop,
|
|
show: noop,
|
|
};
|
|
};
|
|
|
|
export const useIntercom = () => {
|
|
const hookData = useIntercomHook();
|
|
const { data } = trpc.viewer.me.useQuery();
|
|
const { hasPaidPlan } = useHasPaidPlan();
|
|
const { hasTeamPlan } = useHasTeamPlan();
|
|
|
|
const open = async () => {
|
|
let userHash;
|
|
|
|
const req = await fetch(`/api/intercom-hash`);
|
|
const res = await req.json();
|
|
if (res?.hash) {
|
|
userHash = res.hash;
|
|
}
|
|
|
|
hookData.boot({
|
|
...(data && data?.name && { name: data.name }),
|
|
...(data && data?.email && { email: data.email }),
|
|
...(data && data?.id && { userId: data.id }),
|
|
createdAt: String(dayjs(data?.createdDate).unix()),
|
|
...(userHash && { userHash }),
|
|
customAttributes: {
|
|
//keys should be snake cased
|
|
user_name: data?.username,
|
|
link: `${CAL_URL}/${data?.username}`,
|
|
identity_provider: data?.identityProvider,
|
|
timezone: data?.timeZone,
|
|
locale: data?.locale,
|
|
has_paid_plan: hasPaidPlan,
|
|
has_team_plan: hasTeamPlan,
|
|
metadata: data?.metadata,
|
|
is_logged_in: !!data,
|
|
},
|
|
});
|
|
hookData.show();
|
|
};
|
|
return { ...hookData, open };
|
|
};
|
|
|
|
export default useIntercom;
|