UNPKG

@xyflow/svelte

Version:

Svelte Flow - A highly customizable Svelte library for building node-based editors, workflow systems, diagrams and more.

19 lines (18 loc) 911 B
import { key } from '../store'; import { getContext } from 'svelte'; /** * Warns the user that they should use $derived() when calling a hook. * This is not neccessarry when the hook is called inside a child of <SvelteFlowFlow />, * however exceptions can be made if you don't want to return a closure. * @param functionName - The name of the function that is being called * @param force - If true, the warning will be shown regardless if child of <SvelteFlowFlow /> */ export function derivedWarning(functionName) { const storeContext = getContext(key); if (!storeContext) { throw new Error(`In order to use ${functionName}() you need to wrap your component in a <SvelteFlowProvider />`); } if (storeContext.provider && typeof window === 'object' && !$effect.tracking()) { throw new Error(`Use $derived(${functionName}()) to receive updates when values change.`); } }