CollaboratorCursorOverlayUtil

See source code
Table of contents

Extends OverlayUtil<TLCollaboratorCursorOverlay>.

Overlay util for collaborator cursors (arrow + name tag + chat message).

class CollaboratorCursorOverlayUtil extends OverlayUtil<TLCollaboratorCursorOverlay> {}

Constructor

Constructs a new instance of the OverlayUtil class

Parameters

NameDescription

editor

Editor;

Properties

type

static
static type: string;

editor

editor: Editor;

options

options: {
  chatMaxWidth: number;
  fontSize: number;
  nameMaxWidth: number;
  zIndex: number;
};

Methods

configure( )

static

Create a new overlay util class with the given options merged in.

static configure<T extends TLOverlayUtilConstructor<any>>(
  this: T,
  options: T extends new (...args: any[]) => {
    options: infer Options;
  }
    ? Partial<Options>
    : never,
): T;

Example

const MyBrush = BrushOverlayUtil.configure({ fill: "rgba(0,0,255,0.1)" });

Parameters

NameDescription

this

T;

options

T extends new (...args: any[]) => {
  options: infer Options;
}
  ? Partial<Options>
  : never;

Returns

T;

getCursor( )

Returns the cursor type to show when hovering this overlay.

getCursor(_overlay: T): TLCursorType | undefined;

Parameters

NameDescription

_overlay

T;

Returns

TLCursorType | undefined;

getGeometry( )

Returns hit-test geometry for an overlay instance, in page coordinates. Return null for non-interactive overlays (e.g. snap indicators, scribbles).

getGeometry(_overlay: T): Geometry2d | null;

Parameters

NameDescription

_overlay

T;

Returns

Geometry2d | null;

getOverlays( )

getOverlays(): TLCollaboratorCursorOverlay[];

isActive( )

isActive(): boolean;

onPointerDown( )

optional

Called when the user points down on this overlay, before the default routing runs. Acts as an interrupt: define it to take over the event.

Return false to continue with the default behavior (e.g. the built-in rotate/resize handle transitions or shape-handle dispatch). Return true — or nothing at all — to skip the default. In other words, once you override this method you own the event unless you explicitly opt back in by returning false.

onPointerDown?(overlay: T, info: TLPointerEventInfo): boolean | void;

Parameters

NameDescription

overlay

T;

info

Returns

boolean | void;

render( )

render(
  ctx: CanvasRenderingContext2D,
  overlays: TLCollaboratorCursorOverlay[],
): void;

Parameters

NameDescription

ctx

CanvasRenderingContext2D;

overlays

Returns

void;

renderMinimap( )

renderMinimap(
  ctx: CanvasRenderingContext2D,
  overlays: TLCollaboratorCursorOverlay[],
  zoom: number,
): void;

Parameters

NameDescription

ctx

CanvasRenderingContext2D;

overlays

zoom

number;

Returns

void;

Prev
CollaboratorBrushOverlayUtil
Next
CollaboratorHintOverlayUtil