2
0
Files
bot/apps/builder/components/analytics/graph/blocks/DropOffBlock.tsx

71 lines
2.1 KiB
TypeScript
Raw Normal View History

2022-01-03 17:39:59 +01:00
import { Tag, Text, VStack } from '@chakra-ui/react'
import { useAnalyticsGraph } from 'contexts/AnalyticsGraphProvider'
import React, { useMemo } from 'react'
import { AnswersCount } from 'services/analytics'
import { computeSourceCoordinates } from 'services/graph'
type Props = {
answersCounts: AnswersCount[]
blockId: string
}
export const DropOffBlock = ({ answersCounts, blockId }: Props) => {
const { typebot } = useAnalyticsGraph()
const totalAnswers = useMemo(
() => answersCounts.find((a) => a.blockId === blockId)?.totalAnswers,
[answersCounts, blockId]
)
const { totalDroppedUser, dropOffRate } = useMemo(() => {
if (!typebot || totalAnswers === undefined)
return { previousTotal: undefined, dropOffRate: undefined }
2022-01-06 09:40:56 +01:00
const previousBlockIds = typebot.blocks.allIds.filter(() =>
typebot.steps.allIds.find(
(sId) => typebot.steps.byId[sId].target?.blockId === blockId
2022-01-03 17:39:59 +01:00
)
2022-01-06 09:40:56 +01:00
)
const previousTotal = answersCounts
.filter((a) => previousBlockIds.includes(a.blockId))
2022-01-03 17:39:59 +01:00
.reduce((prev, acc) => acc.totalAnswers + prev, 0)
if (previousTotal === 0)
return { previousTotal: undefined, dropOffRate: undefined }
const totalDroppedUser = previousTotal - totalAnswers
return {
totalDroppedUser,
dropOffRate: Math.round((totalDroppedUser / previousTotal) * 100),
}
}, [answersCounts, blockId, totalAnswers, typebot])
const labelCoordinates = useMemo(() => {
if (!typebot) return { x: 0, y: 0 }
2022-01-06 09:40:56 +01:00
const sourceBlock = typebot?.blocks.byId[blockId]
2022-01-03 17:39:59 +01:00
if (!sourceBlock) return
return computeSourceCoordinates(
sourceBlock?.graphCoordinates,
2022-01-06 09:40:56 +01:00
sourceBlock?.stepIds.length - 1
2022-01-03 17:39:59 +01:00
)
}, [blockId, typebot])
if (!labelCoordinates) return <></>
return (
<VStack
bgColor={'red.500'}
color="white"
rounded="md"
p="2"
justifyContent="center"
style={{
transform: `translate(${labelCoordinates.x - 20}px, ${
labelCoordinates.y + 80
}px)`,
}}
pos="absolute"
>
<Text>{dropOffRate}%</Text>
<Tag colorScheme="red">{totalDroppedUser} users</Tag>
</VStack>
)
}