Weave
API reference for Weave class
Overview
The Weave class is the central engine of the Weave.js ecosystem. It manages the entire collaborative canvas environment, coordinating the rendering of nodes, handling user interactions, dispatching actions, and orchestrating plugins—all while maintaining real-time synchronization through a connected store.
Designed to be modular, scalable, and collaborative, the Weave class provides the foundation for building dynamic visual tools like whiteboards, diagram editors, and design platforms.
Core responsibilities
- State Management: connects to a store (e.g., WebSocket, Azure Web PubSub) to load, sync, and manage the shared canvas state and awareness events across connected users.
- Canvas Rendering: creates and manages the Stage, Layers, and Nodes hierarchy using the React Reconciler and Konva.js, maintaining a highly performant rendering loop.
- DX System: registers the nodes (elements to render), plugins (power-up functionality) and actions (user workflows to handle interaction).
Built on top of Yjs and SyncedStore, it acts as a bridge between the client-side Weave.js app and the remote backend, handling updates, awareness (presence), and document syncing with minimal setup.
The Weave instance extends the Emittery class.
Import
import { Weave } from "@inditextech/weave-sdk";Instantiation
const instance = new Weave(weaveConfig: WeaveConfig, stageConfig: Konva.StageConfig);Parameters
| Prop | Type | Default |
|---|---|---|
stageConfig | Konva.StageConfig | - |
weaveConfig.logger? | WeaveLoggerConfig | - |
weaveConfig.callbacks? | WeaveCallbacks[] | - |
weaveConfig.fonts? | WeaveFont[] | - |
weaveConfig.actions? | WeaveActionBase[] | - |
weaveConfig.plugins? | WeavePluginBase[] | - |
weaveConfig.nodes? | WeaveNodeBase[] | - |
weaveConfig.store | WeaveStoreBase | - |
Methods
Instance management
start
async start(): voidThis method starts the Weave instance.
getId
getId(): stringThis method gets the id of the Weave instance.
Instance configuration
setNodesDefaultConfiguration
setNodesDefaultConfiguration(config?: WeaveNodeConfiguration): voidThis method set the Node default configuration properties.
By default:
const WEAVE_TRANSFORMER_ANCHORS = {
["TOP_LEFT"]: "top-left",
["TOP_CENTER"]: "top-center",
["TOP_RIGHT"]: "top-right",
["MIDDLE_RIGHT"]: "middle-right",
["MIDDLE_LEFT"]: "middle-left",
["BOTTOM_LEFT"]: "bottom-left",
["BOTTOM_CENTER"]: "bottom-center",
["BOTTOM_RIGHT"]: "bottom-right",
};
const WEAVE_DEFAULT_ENABLED_ANCHORS: string[] = Object.values(
WEAVE_TRANSFORMER_ANCHORS
);
const defaultNodeConfig: WeaveNodeConfiguration = {
transform: {
rotateEnabled: true,
resizeEnabled: true,
enabledAnchors: WEAVE_DEFAULT_ENABLED_ANCHORS,
borderStrokeWidth: 3,
padding: 0,
},
};Events
emitEvent
emitEvent<T>(event: string, payload: T): voidThis method emits an event that can be listen to.
addEventListener
addEventListener<T>(event: string, callback: (payload: T) => void): voidThis method listen to an specific event emitted by the Weave instance.
removeEventListener
removeEventListener<T>(event: string, callback: (payload: T) => void): voidThis method remove an specific event listener previously instantiated on the Weave instance.
Logging
getMainLogger
getMainLogger(): LoggerThis method get's the main logger child instance of the Weave instance.
getChildLogger
getChildLogger(name: string): pino.Logger<never, boolean>This method returns a new Pino child logger from the logging instance of the Weave instance.
Stage management
getStage
getStage(): StageThis method returns the current Stage of the Konva internals for the actual Weave instance.
getMainLayer
getMainLayer(): Konva.Layer | undefinedThis method returns the mainLayer Layer of the Konva internals for the actual Weave instance.
getInstanceRecursive
getInstanceRecursive(
instance: Konva.Node,
filterInstanceType: string[] = []
): Konva.NodeThis method transverse the internal Konva instance nodes tree from the specified node instance, giving the ability to filter by an specific node. The found node is returned.
getContainerNodes
getContainerNodes(): WeaveElementInstance[]This method return all the containers nodes (i.e. frame nodes).
Actions management
getActiveAction
getActiveAction(): string | undefined;This method return the Action name of the active action, if no action is active undefined is returned.
triggerAction
triggerAction<T>(actionName: string, params?: T): unknownThis method triggers a registered Action.
getPropsAction
getPropsAction(actionName: string) {
return this.actionsManager.getPropsAction(actionName);
}: WeaveElementAttributesThis method returns the current properties of a registered action.
updatePropsAction
updatePropsAction(actionName: string, params: WeaveElementAttributes): voidThis method updated the properties of a registered action.
cancelAction
cancelAction(actionName: string): voidThis method cancels the specified action if is active.
State management
findNodeById
findNodeById(
tree: WeaveStateElement,
key: string,
parent: WeaveStateElement | null = null,
index = -1
): {
node: WeaveStateElement | null;
parent: WeaveStateElement | null;
index: number;
}This method transverse the shared-state searching for a node with and id specified on the key property.
findNodesByType
findNodesByType(
tree: WeaveStateElement,
nodeType: string
): WeaveStateElement[]This method transverse the shared-state searching for a node with an specific type.
getNode
getNode(nodeKey: string): {
node: WeaveStateElement | null;
parent: WeaveStateElement | null;
index: number;
}This method gets a node by its key, the method returns the node, parent and index (relative) to its parent if found.
addNode
addNode(
node: WeaveStateElement,
parentId = 'mainLayer',
index: number | undefined = undefined
): voidThis method adds a node to the shared-state, at the specified layer (parentId, being
the mainLayer the default layer to add).
You can also specify in which index (children array order) to put the node, and if you need it to just update the shared-state without refreshing the rendering life-cycle.
updateNode
updateNode(node: WeaveStateElement): voidThis method updates a node on the shared-state.
If you need it to just update the shared-state without refreshing the rendering life-cycle.
removeNode
removeNode(node: WeaveStateElement): voidThis method removes a node from the shared-state.
If you need it to just update the shared-state without refreshing the rendering life-cycle.
removeNodes
removeNodes(nodes: WeaveStateElement[]): voidThis method removes a list of nodes from the shared-state.
moveNode
moveNode(node: WeaveStateElement, position: WeavePosition): voidThis method moves the node position relative to its parent on the shared-state.
If you need it to just update the shared-state without refreshing the rendering life-cycle.
getElementsTree
getElementsTree(): WeaveStateElement[]This method returns the children of the mainLayer. Useful to render a tree view of the elements
in the canvas.
isEmpty
isEmpty(): booleanThis method returns true if the mainLayer has no elements in it (its empty), false otherwise.
Z-Index management
moveUp
moveUp(node: WeaveElementInstance): voidThis method moves up the node one position on the z-axis. This mean the node is more close to the user as other nodes behind it.
moveDown
moveDown(node: WeaveElementInstance): voidThis method moves down the node one position on the z-axis. This mean the node is further to the user as other nodes in front of it.
sendToBack
sendToBack(node: WeaveElementInstance | WeaveElementInstance[]): voidThis method moves down the node to the back of the z-axis, being the further node from the user perspective.
bringToFront
bringToFront(node: WeaveElementInstance | WeaveElementInstance[]): voidThis method brings up the node to the front of the z-axis, being the closest node from the user perspective.
Group management
group
group(nodes: WeaveStateElement[]): voidThis method groups the nodes defined in a single unit, now all transformations or selections are made to the whole group instead of the nodes that the group contains.
unGroup
unGroup(group: WeaveStateElement): voidThis method un-groups the nodes defined in a group, this destroys the groups and now all nodes can be selected again. The nodes maintain their position, rotation and scale when the group is destroyed.
Targeting management
pointIntersectsContainerElement
pointIntersectsContainerElement(point?: Vector2d): Konva.Node | undefinedThis method get the container element (i.e. a Frame) that intersect the provided point. If no point is provided the relative mouse position towards the Stage is used instead.
getMousePointer
getMousePointer(point?: Vector2d): {
mousePoint: Vector2d;
container: Layer | Group | undefined;
measureContainer: Layer | Group | undefined;
}This method get the mouse pointer position relative to the canvas and its container layer. Used normally when the user clicks on the canvas and we want to know the point clicked relative ti the canvas and not to the viewport.
getMousePointerRelativeToContainer
getMousePointerRelativeToContainer(container: Konva.Group | Konva.Layer): {
mousePoint: {
x: number;
y: number;
};
container: Layer | Group;
}This method get the mouse pointer position relative to a container layer. Used normally when the user clicks on a container (Layer, Frame) and we want to know the point clicked relative relative to that container.
selectNodesByKey
selectNodesByKey(nodesIds: string[]): voidThis method set selected the nodes ids passed as parameter. Must have registered the WeaveNodesSelectionPlugin, if not registered no selection is performed.
Clone nodes
nodesToGroupSerialized
nodesToGroupSerialized(instancesToClone: Konva.Node[]): {
serializedNodes: WeaveStateElement[];
minPoint: Vector2d;
} | undefinedThis method maps a Konva node instances list to its serialized form (the one used on the shared-state). Also returns the minimum point for all the nodes on the list.
cloneNodes
cloneNodes(
instancesToClone: Konva.Node[],
targetContainer: Konva.Layer | Konva.Group | undefined,
onPoint: Vector2d
): voidThis method clone the Konva nodes instances defined in the list to the target container defined on the point provided.
Fonts management
getFonts
getFonts(): WeaveFont[]This method return the Fonts available on the Weave instance.
Export management
exportNodes
exportNodes(
nodes: WeaveElementInstance[],
boundingNodes: (nodes: Konva.Node[]) => Konva.Node[],
options: WeaveExportNodeOptions
): Promise<HTMLImageElement>This method exports the specified nodes as an image. You can define the exportation options and also define which nodes should be allowed on the bounding box calculations.
exportNodesServerSide
exportNodesServerSide(
nodes: WeaveElementInstance[],
boundingNodes: (nodes: Konva.Node[]) => Konva.Node[],
options: WeaveExportNodeOptions
): Promise<{
composites: { input: Buffer; left: number; top: number }[];
width: number;
height: number;
}>This method exports the specified nodes (normally server-side). You receive the final image width and height, and also the final image segments, the function renders using N segments in order to avoid OOM from the canvas side. With this information you can use a tool like sharp to composite the final image, and probably zip it to send it to the client.
Lock / Unlock management
allNodesLocked
allNodesLocked(nodes: Konva.Node[]): booleanThis method return true if all nodes provided are not locked.
allNodesUnlocked
allNodesUnlocked(nodes: Konva.Node[]): booleanThis method return true if all nodes provided are locked.
lockNode
lockNode(node: Konva.Node): voidThis method locks the provided node, lock means to set an attribute named locked to true and in
that state, the node cannot be selected, dragged or transformed.
lockNodes
lockNodes(nodes: Konva.Node[]): voidThis method locks the provided nodes, lock means to set an attribute named locked to true and in
that state, the nodes cannot be selected, dragged or transformed.
unlockNode
unlockNode(node: Konva.Node): voidThis method unlocks the provided node, unlock means to set an attribute named locked to false and in
that state, the node can be selected, dragged or transformed.
unlockNodes
unlockNodes(nodes: Konva.Node[]): voidThis method unlocks the provided nodes, unlock means to set an attribute named locked to false and in
that state, the nodes can be selected, dragged or transformed.
Visibility management
allNodesVisible
allNodesVisible(nodes: Konva.Node[]): booleanThis method return true if all nodes provided are visible.
allNodesHidden
allNodesHidden(nodes: Konva.Node[]): booleanThis method return true if all nodes provided are not visible.
hideNode
hideNode(node: Konva.Node): voidThis method hides (makes it invisible) the provided node, hidden means to set an attribute named visible to false and in
that state, the node is hidden (not visible) from the canvas.
hideNodes
hideNodes(nodes: Konva.Node[]): voidThis method hides (makes them invisible) the provided nodes, hidden means to set an attribute named visible to false and in
that state, nodes are hidden (not visible) from the canvas.
showNode
showNode(node: Konva.Node): voidThis method shows (makes it visible) the provided node, show means to set an attribute named visible to true and in
that state, the node is shown (visible) on the canvas.
showNodes
showNodes(nodes: Konva.Node[]): voidThis method shows (makes them visible) the provided nodes, show means to set an attribute named visible to true and in
that state, nodes are shown (visible) on the canvas.
TypeScript types
export type WeaveFont = {
id: string;
name: string;
};
export type WeaveElementInstance = Konva.Layer | Konva.Group | Konva.Shape;
export declare type WeaveElementAttributes = {
[key: string]: any;
id?: string;
nodeType?: string;
children?: WeaveStateElement[];
};
export declare type WeaveStateElement = {
key: string;
type: string;
props: WeaveElementAttributes;
};
export type WeaveState = {
weave:
| {
key: "stage";
type: "stage";
props: {
[key: string]: unknown;
id: "stage";
children: WeaveStateElement[];
};
}
| Record<string, WeaveStateElement>;
};
export declare type WeaveAwarenessChange<K extends string, T> = {
[key in K]: T;
};
export declare interface WeaveStoreBase {
connect(): void;
disconnect(): void;
onAwarenessChange<K extends string, T>(
callback: (changes: WeaveAwarenessChange<K, T>[]) => void
): void;
setAwarenessInfo(field: string, value: unknown): void;
}
export declare interface WeaveNodeBase {
createNode(id: string, props: WeaveElementAttributes): WeaveStateElement;
createInstance(props: WeaveElementAttributes): WeaveElementInstance;
updateInstance(
instance: WeaveElementInstance,
nextProps: WeaveElementAttributes
): void;
removeInstance(instance: WeaveElementInstance): void;
toNode(instance: WeaveElementInstance): WeaveStateElement;
}
export declare interface WeaveActionBase {
init?(): void;
trigger(cancelAction: () => void, params?: unknown): unknown;
internalUpdate?(): void;
cleanup?(): void;
}
export declare interface WeavePluginBase {
init?(): void;
render?(): void;
enable(): void;
disable(): void;
isEnabled(): boolean;
}
export type WeaveUndoRedoChange = {
canRedo: boolean;
canUndo: boolean;
redoStackLength: number;
undoStackLength: number;
};
export type WeaveLoggerConfig = {
disabled?: boolean;
level?: "debug" | "info" | "warn" | "error";
};
export declare type WeaveConfig = {
store: WeaveStoreBase;
nodes?: WeaveNodeBase[];
actions?: WeaveActionBase[];
plugins?: WeavePluginBase[];
fonts?: WeaveFont[];
callbacks?: WeaveCallbacks;
logger?: WeaveLoggerConfig;
};