32 lines
892 B
TypeScript
32 lines
892 B
TypeScript
![]() |
import { useTypebot } from 'contexts/TypebotContext'
|
||
|
import { Block } from 'models'
|
||
|
import React from 'react'
|
||
|
import { AnswersCount } from 'services/analytics'
|
||
|
import { Edges } from './Edges'
|
||
|
import { BlockNode } from './Nodes/BlockNode'
|
||
|
|
||
|
type Props = {
|
||
|
answersCounts?: AnswersCount[]
|
||
|
onUnlockProPlanClick?: () => void
|
||
|
}
|
||
|
const MyComponent = ({ answersCounts, onUnlockProPlanClick }: Props) => {
|
||
|
const { typebot } = useTypebot()
|
||
|
return (
|
||
|
<>
|
||
|
<Edges
|
||
|
edges={typebot?.edges ?? []}
|
||
|
answersCounts={answersCounts}
|
||
|
onUnlockProPlanClick={onUnlockProPlanClick}
|
||
|
/>
|
||
|
{typebot?.blocks.map((block, idx) => (
|
||
|
<BlockNode block={block as Block} blockIndex={idx} key={block.id} />
|
||
|
))}
|
||
|
</>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
// Performance hack, never rerender when graph (parent) is panned
|
||
|
const areEqual = () => true
|
||
|
|
||
|
export default React.memo(MyComponent, areEqual)
|