Spaces:
Running
Running
<script lang="ts"> | |
import { Handle, type NodeProps, useSvelteFlow } from '@xyflow/svelte'; | |
type $$Props = NodeProps; | |
export let id: $$Props['id']; | |
export let data: $$Props['data']; | |
export let dragHandle: $$Props['dragHandle'] = undefined; dragHandle; | |
export let type: $$Props['type'] = undefined; type; | |
export let selected: $$Props['selected'] = undefined; selected; | |
export let isConnectable: $$Props['isConnectable'] = undefined; isConnectable; | |
export let zIndex: $$Props['zIndex'] = undefined; zIndex; | |
export let width: $$Props['width'] = undefined; width; | |
export let height: $$Props['height'] = undefined; height; | |
export let dragging: $$Props['dragging']; dragging; | |
export let targetPosition: $$Props['targetPosition'] = undefined; targetPosition; | |
export let sourcePosition: $$Props['sourcePosition'] = undefined; sourcePosition; | |
export let positionAbsoluteX: $$Props['positionAbsoluteX'] = undefined; positionAbsoluteX; | |
export let positionAbsoluteY: $$Props['positionAbsoluteY'] = undefined; positionAbsoluteY; | |
const { updateNodeData } = useSvelteFlow(); | |
let expanded = true; | |
function titleClicked() { | |
expanded = !expanded; | |
} | |
</script> | |
<div class="node-container"> | |
<div class="lynxkite-node"> | |
<div class="title" on:click={titleClicked}> | |
{data.title} | |
</div> | |
{#if expanded} | |
<slot /> | |
{/if} | |
{#if sourcePosition} | |
<Handle type="source" position={sourcePosition} /> | |
{/if} | |
{#if targetPosition} | |
<Handle type="target" position={targetPosition} /> | |
{/if} | |
</div> | |
</div> | |
<style> | |
.node-container { | |
padding: 8px; | |
} | |
.lynxkite-node { | |
box-shadow: 0px 5px 50px 0px rgba(0, 0, 0, 0.3); | |
background: white; | |
} | |
.title { | |
background: #ff8800; | |
font-weight: bold; | |
padding: 8px; | |
min-width: 170px; | |
max-width: 300px; | |
} | |
</style> | |