import { defineComponent, computed, watch, PropType, ref, Ref, } from 'vue'; import { BlockData } from '../types'; import { SbMode } from '../mode'; import { useResizeObserver, SymBlockDimensions } from '../use-resize-observer'; import { useActivation } from '../use-activation'; import { useBlockTree } from '../use-block-tree'; import { useDynamicBlocks } from '../use-dynamic-blocks'; import SbMissingBlock from './MissingBlock'; import './Block.scss'; export const SbBlock = defineComponent({ name: 'sb-block', props: { block: { type: (null as unknown) as PropType>, required: true, }, sortable: { type: String, default: null, }, onUpdate: { type: Function, default: () => {} }, onPrependBlock: { type: Function, default: () => {} }, onAppendBlock: { type: Function, default: () => {} }, onRemoveSelf: { type: Function, default: () => {} }, onActivatePrevious: { type: Function, default: () => {} }, onActivateNext: { type: Function, default: () => {} }, }, setup(props, context) { const el: Ref = ref(null); const { mode, getBlock } = useDynamicBlocks(); const { isActive, activate, } = useActivation(props.block.id); const classes = computed(() => ({ 'sb-block': true, 'sb-block_active': isActive.value, })); const { triggerSizeCalculation } = useResizeObserver(el, SymBlockDimensions); watch(() => props.block.data, triggerSizeCalculation); const { register } = useBlockTree(); register(props.block); watch(props.block, () => { register(props.block); }); const onChildUpdate = (updated: {[key: string]: any}) => { props.onUpdate({ ...props.block, data: { ...props.block.data, ...updated, }, }); }; return () => { const BlockComponent = getBlock(props.block.name)?.[mode.value] as any; if (!BlockComponent) { const MissingBlock = SbMissingBlock[mode.value]; return ; } if (mode.value === SbMode.Display) { return ; } return
{context.slots['context-toolbar'] ? context.slots['context-toolbar']() : null} { $event.stopPropagation(); activate(); }, ...context.attrs, }} />
; }; }, });