2021-12-16 10:43:49 +01:00
|
|
|
import { chakra } from '@chakra-ui/system'
|
2022-01-06 09:40:56 +01:00
|
|
|
import { useTypebot } from 'contexts/TypebotContext/TypebotContext'
|
2021-12-16 10:43:49 +01:00
|
|
|
import React, { useMemo } from 'react'
|
2022-01-06 09:40:56 +01:00
|
|
|
import { isDefined } from 'utils'
|
2021-12-16 10:43:49 +01:00
|
|
|
import { DrawingEdge } from './DrawingEdge'
|
2022-01-06 09:40:56 +01:00
|
|
|
import { Edge } from './Edge'
|
2021-12-16 10:43:49 +01:00
|
|
|
|
|
|
|
export const Edges = () => {
|
2021-12-22 14:59:07 +01:00
|
|
|
const { typebot } = useTypebot()
|
2022-01-06 09:40:56 +01:00
|
|
|
const stepIdsWithTarget: string[] = useMemo(() => {
|
|
|
|
if (!typebot) return []
|
|
|
|
return typebot.steps.allIds.filter((stepId) =>
|
|
|
|
isDefined(typebot.steps.byId[stepId].target)
|
|
|
|
)
|
|
|
|
}, [typebot])
|
2021-12-16 10:43:49 +01:00
|
|
|
|
|
|
|
return (
|
|
|
|
<chakra.svg
|
|
|
|
width="full"
|
|
|
|
height="full"
|
|
|
|
overflow="visible"
|
|
|
|
pos="absolute"
|
|
|
|
left="0"
|
|
|
|
top="0"
|
|
|
|
>
|
|
|
|
<DrawingEdge />
|
2022-01-06 09:40:56 +01:00
|
|
|
{stepIdsWithTarget.map((stepId) => (
|
|
|
|
<Edge key={stepId} stepId={stepId} />
|
2021-12-16 10:43:49 +01:00
|
|
|
))}
|
|
|
|
<marker
|
|
|
|
id={'arrow'}
|
|
|
|
refX="8"
|
|
|
|
refY="4"
|
|
|
|
orient="auto"
|
|
|
|
viewBox="0 0 20 20"
|
|
|
|
markerUnits="userSpaceOnUse"
|
|
|
|
markerWidth="20"
|
|
|
|
markerHeight="20"
|
|
|
|
>
|
|
|
|
<path
|
|
|
|
d="M7.07138888,5.50174526 L2.43017246,7.82235347 C1.60067988,8.23709976 0.592024983,7.90088146 0.177278692,7.07138888 C0.0606951226,6.83822174 0,6.58111307 0,6.32042429 L0,1.67920787 C0,0.751806973 0.751806973,0 1.67920787,0 C1.93989666,0 2.19700532,0.0606951226 2.43017246,0.177278692 L7,3 C7.82949258,3.41474629 8.23709976,3.92128809 7.82235347,4.75078067 C7.6598671,5.07575341 7.39636161,5.33925889 7.07138888,5.50174526 Z"
|
|
|
|
fill="#718096"
|
|
|
|
/>
|
|
|
|
</marker>
|
|
|
|
</chakra.svg>
|
|
|
|
)
|
|
|
|
}
|