♻️ Introduce typebot v6 with events (#1013)

Closes #885
This commit is contained in:
Baptiste Arnaud
2023-11-08 15:34:16 +01:00
committed by GitHub
parent 68e4fc71fb
commit 35300eaf34
634 changed files with 58971 additions and 31449 deletions

View File

@@ -10,11 +10,10 @@ import React, { useEffect, useRef, useState } from 'react'
import {
BubbleBlock,
BubbleBlockContent,
DraggableBlock,
Block,
BlockWithOptions,
TextBubbleBlock,
LogicBlockType,
BlockV6,
} from '@typebot.io/schemas'
import {
isBubbleBlock,
@@ -25,7 +24,7 @@ import {
import { BlockNodeContent } from './BlockNodeContent'
import { BlockSettings, SettingsPopoverContent } from './SettingsPopoverContent'
import { BlockNodeContextMenu } from './BlockNodeContextMenu'
import { SourceEndpoint } from '../../endpoints/SourceEndpoint'
import { BlockSourceEndpoint } from '../../endpoints/BlockSourceEndpoint'
import { useRouter } from 'next/router'
import { MediaBubblePopoverContent } from './MediaBubblePopoverContent'
import { ContextMenu } from '@/components/ContextMenu'
@@ -44,6 +43,7 @@ import { setMultipleRefs } from '@/helpers/setMultipleRefs'
import { TargetEndpoint } from '../../endpoints/TargetEndpoint'
import { SettingsModal } from './SettingsModal'
import { TElement } from '@udecode/plate-common'
import { LogicBlockType } from '@typebot.io/schemas/features/blocks/logic/constants'
export const BlockNode = ({
block,
@@ -51,10 +51,10 @@ export const BlockNode = ({
indices,
onMouseDown,
}: {
block: Block
block: BlockV6
isConnectable: boolean
indices: { blockIndex: number; groupIndex: number }
onMouseDown?: (blockNodePosition: NodePosition, block: DraggableBlock) => void
onMouseDown?: (blockNodePosition: NodePosition, block: BlockV6) => void
}) => {
const bg = useColorModeValue('gray.50', 'gray.850')
const previewingBorderColor = useColorModeValue('blue.400', 'blue.300')
@@ -78,7 +78,7 @@ export const BlockNode = ({
openedBlockId === block.id
)
const [isEditing, setIsEditing] = useState<boolean>(
isTextBubbleBlock(block) && block.content.richText.length === 0
isTextBubbleBlock(block) && (block.content?.richText?.length ?? 0) === 0
)
const blockRef = useRef<HTMLDivElement | null>(null)
@@ -87,15 +87,17 @@ export const BlockNode = ({
previewingEdge?.to.blockId === block.id ||
previewingBlock?.id === block.id
const groupId = typebot?.groups[indices.groupIndex].id
const onDrag = (position: NodePosition) => {
if (block.type === 'start' || !onMouseDown) return
if (!onMouseDown) return
onMouseDown(position, block)
}
useDragDistance({
ref: blockRef,
onDrag,
isDisabled: !onMouseDown || block.type === 'start',
isDisabled: !onMouseDown,
})
const {
@@ -110,10 +112,10 @@ export const BlockNode = ({
useEffect(() => {
setIsConnecting(
connectingIds?.target?.groupId === block.groupId &&
connectingIds?.target?.groupId === groupId &&
connectingIds?.target?.blockId === block.id
)
}, [connectingIds, block.groupId, block.id])
}, [connectingIds, block.id, groupId])
const handleModalClose = () => {
updateBlock(indices, { ...block })
@@ -124,10 +126,10 @@ export const BlockNode = ({
if (isReadOnly) return
if (mouseOverBlock?.id !== block.id && blockRef.current)
setMouseOverBlock({ id: block.id, element: blockRef.current })
if (connectingIds)
if (connectingIds && groupId)
setConnectingIds({
...connectingIds,
target: { groupId: block.groupId, blockId: block.id },
target: { groupId, blockId: block.id },
})
}
@@ -147,7 +149,7 @@ export const BlockNode = ({
}
const handleClick = (e: React.MouseEvent) => {
setFocusedGroupId(block.groupId)
setFocusedGroupId(groupId)
e.stopPropagation()
if (isTextBubbleBlock(block)) setIsEditing(true)
setOpenedBlockId(block.id)
@@ -187,7 +189,7 @@ export const BlockNode = ({
return isEditing && isTextBubbleBlock(block) ? (
<TextBubbleEditor
id={block.id}
initialValue={block.content.richText}
initialValue={block.content?.richText ?? []}
onClose={handleCloseEditor}
/>
) : (
@@ -244,18 +246,18 @@ export const BlockNode = ({
left="-34px"
top="16px"
blockId={block.id}
groupId={block.groupId}
groupId={groupId}
/>
)}
{(isConnectable ||
(pathname.endsWith('analytics') && isInputBlock(block))) &&
hasDefaultConnector(block) &&
block.type !== LogicBlockType.JUMP && (
<SourceEndpoint
<BlockSourceEndpoint
source={{
groupId: block.groupId,
blockId: block.id,
}}
groupId={groupId}
pos="absolute"
right="-34px"
bottom="10px"
@@ -269,6 +271,7 @@ export const BlockNode = ({
<>
<SettingsPopoverContent
block={block}
groupId={groupId}
onExpandClick={handleExpandClick}
onBlockChange={handleBlockUpdate}
/>
@@ -276,6 +279,7 @@ export const BlockNode = ({
<SettingsModal isOpen={isModalOpen} onClose={handleModalClose}>
<BlockSettings
block={block}
groupId={groupId}
onBlockChange={handleBlockUpdate}
/>
</SettingsModal>
@@ -299,10 +303,10 @@ export const BlockNode = ({
)
}
const hasSettingsPopover = (block: Block): block is BlockWithOptions =>
const hasSettingsPopover = (block: BlockV6): block is BlockWithOptions =>
!isBubbleBlock(block) && block.type !== LogicBlockType.CONDITION
const isMediaBubbleBlock = (
block: Block
block: BlockV6
): block is Exclude<BubbleBlock, TextBubbleBlock> =>
isBubbleBlock(block) && !isTextBubbleBlock(block)