Skip to content

TimerEntity

Defined in: TimerEntity.ts:17

A pre-built entity that exposes the ProcessComponent API directly. Useful for scene-level timing without manual component wiring.

const timers = this.spawn(TimerEntity);
timers.run(Process.delay(500, () => { ... }));
const cd = timers.slot({ duration: 300 });

new TimerEntity(name?, tags?): TimerEntity

Defined in: Entity.ts:49

string

Iterable<string, any, any>

TimerEntity

Entity.constructor

readonly id: number

Defined in: Entity.ts:35

Unique auto-incrementing ID.

Entity.id


readonly name: string

Defined in: Entity.ts:37

Display name for debugging.

Entity.name


readonly tags: Set<string>

Defined in: Entity.ts:39

Tags for group queries.

Entity.tags


static [TRAITS_KEY]: Set<symbol>

Defined in: Entity.ts:33

Entity.[TRAITS_KEY]

get children(): ReadonlyMap<string, Entity>

Defined in: Entity.ts:91

Named children as a read-only map. Empty map if no children.

ReadonlyMap<string, Entity>

Entity.children


get isDestroyed(): boolean

Defined in: Entity.ts:81

True if destroy() has been called.

boolean

Entity.isDestroyed


get parent(): Entity | null

Defined in: Entity.ts:86

The parent entity, or null if this is a root entity.

Entity | null

Entity.parent


get scene(): Scene

Defined in: Entity.ts:66

The scene this entity belongs to. Throws if the entity is not attached to a scene — which in practice only happens before scene.spawn / addChild wires it up, or after destroy() tears it down. Inside lifecycle methods (setup, component onAdd, update, etc.) this is always safe to access.

For the rare case where you genuinely need to inspect whether an entity has a scene (e.g. defensive code in systems iterating a query result), use tryScene instead.

Scene

Entity.scene


get tryScene(): Scene | null

Defined in: Entity.ts:76

The scene this entity belongs to, or null if detached.

Scene | null

Entity.tryScene

_performDestroy(): void

Defined in: Entity.ts:316

Internal

Internal: perform actual destruction — remove all components and clear state. Called by Scene during endOfFrame flush.

void

Entity._performDestroy


_setScene(scene, callbacks): void

Defined in: Entity.ts:371

Internal

Internal: set the scene and callbacks. Called by Scene.spawn().

Scene | null

EntityCallbacks | null

void

Entity._setScene


add<C>(component): C

Defined in: Entity.ts:213

Add a component instance. Returns the component for chaining.

C extends Component

C

C

Entity.add


addChild(name, child): void

Defined in: Entity.ts:96

Add a named child entity. Auto-adds to parent’s scene if not already in one.

string

Entity

void

Entity.addChild


optional afterRestore(data, resolve): void

Defined in: Entity.ts:352

Called after components are restored during save/load. Rebuild non-serializable state here.

unknown

SnapshotResolver

void

Entity.afterRestore


cancel(tag?): void

Defined in: TimerEntity.ts:32

string

void


destroy(): void

Defined in: Entity.ts:297

Mark for deferred destruction. Actual cleanup happens at end of frame.

void

Entity.destroy


emit(token): void

Defined in: Entity.ts:275

Emit a typed event on this entity. Bubbles to the scene.

EventToken<void>

void

Entity.emit

emit<T>(token, data): void

Defined in: Entity.ts:276

Emit a typed event on this entity. Bubbles to the scene.

T

EventToken<T>

T

void

Entity.emit


get<C>(cls): C

Defined in: Entity.ts:228

Get a component by class. Throws if not found.

C extends Component

ComponentClass<C>

C

Entity.get


getAll(): Iterable<Component>

Defined in: Entity.ts:292

Get all components as an iterable.

Iterable<Component>

Entity.getAll


getChild(name): Entity

Defined in: Entity.ts:199

Get a child by name. Throws if not found.

string

Entity

Entity.getChild


has(cls): boolean

Defined in: Entity.ts:244

Check if entity has a component of the given class.

ComponentClass

boolean

Entity.has


hasTrait<T>(token): this is TimerEntity & T

Defined in: Entity.ts:355

Check if this entity’s class implements a given trait. Acts as a type guard.

T

TraitToken<T>

this is TimerEntity & T

Entity.hasTrait


on<T>(token, handler): () => void

Defined in: Entity.ts:260

Subscribe to a typed event on this entity. Returns an unsubscribe function.

T

EventToken<T>

(data) => void

() => void

Entity.on


remove(cls): void

Defined in: Entity.ts:249

Remove a component by class.

ComponentClass

void

Entity.remove


removeChild(name): Entity

Defined in: Entity.ts:184

Remove a named child. Returns the detached entity.

string

Entity

Entity.removeChild


run(process, options?): Process

Defined in: TimerEntity.ts:24

Process

string[]

Process


optional serialize(): unknown

Defined in: Entity.ts:349

Return a JSON-serializable snapshot of this entity’s custom state. Used by the save system.

unknown

Entity.serialize


setup(): void

Defined in: TimerEntity.ts:20

Optional setup method. Called by scene.spawn(Class, params) after the entity is wired to its scene, so components can access services. Override in subclasses — do NOT use the constructor for component setup.

void

Entity.setup


slot(config?): ProcessSlot

Defined in: TimerEntity.ts:28

ProcessSlotConfig

ProcessSlot


spawnChild(name): Entity

Defined in: Entity.ts:138

Spawn a new entity in this entity’s scene and add it as a named child. Combines scene.spawn(...) + this.addChild(name, ...) in one call — the idiomatic way to compose entity trees (logical root + visual body

  • UI sibling + …).

Mirrors the overload shape of Scene.spawn: pass an Entity subclass (with optional setup params), a Blueprint, or omit for an anonymous base Entity.

this.spawnChild("body", EnemyBody, { color: 0xff6b6b });
this.spawnChild("hp", EnemyHealthBar);

string

Entity

Entity.spawnChild

spawnChild<E>(name, Class): E

Defined in: Entity.ts:139

Spawn a new entity in this entity’s scene and add it as a named child. Combines scene.spawn(...) + this.addChild(name, ...) in one call — the idiomatic way to compose entity trees (logical root + visual body

  • UI sibling + …).

Mirrors the overload shape of Scene.spawn: pass an Entity subclass (with optional setup params), a Blueprint, or omit for an anonymous base Entity.

this.spawnChild("body", EnemyBody, { color: 0xff6b6b });
this.spawnChild("hp", EnemyHealthBar);

E extends Entity

string

() => E

E

Entity.spawnChild

spawnChild<E, P>(name, Class, params): E

Defined in: Entity.ts:140

Spawn a new entity in this entity’s scene and add it as a named child. Combines scene.spawn(...) + this.addChild(name, ...) in one call — the idiomatic way to compose entity trees (logical root + visual body

  • UI sibling + …).

Mirrors the overload shape of Scene.spawn: pass an Entity subclass (with optional setup params), a Blueprint, or omit for an anonymous base Entity.

this.spawnChild("body", EnemyBody, { color: 0xff6b6b });
this.spawnChild("hp", EnemyHealthBar);

E extends Entity

P

string

() => E & object

P

E

Entity.spawnChild

spawnChild<P>(name, blueprint, params): Entity

Defined in: Entity.ts:145

Spawn a new entity in this entity’s scene and add it as a named child. Combines scene.spawn(...) + this.addChild(name, ...) in one call — the idiomatic way to compose entity trees (logical root + visual body

  • UI sibling + …).

Mirrors the overload shape of Scene.spawn: pass an Entity subclass (with optional setup params), a Blueprint, or omit for an anonymous base Entity.

this.spawnChild("body", EnemyBody, { color: 0xff6b6b });
this.spawnChild("hp", EnemyHealthBar);

P

string

Blueprint<P>

P

Entity

Entity.spawnChild

spawnChild(name, blueprint): Entity

Defined in: Entity.ts:151

Spawn a new entity in this entity’s scene and add it as a named child. Combines scene.spawn(...) + this.addChild(name, ...) in one call — the idiomatic way to compose entity trees (logical root + visual body

  • UI sibling + …).

Mirrors the overload shape of Scene.spawn: pass an Entity subclass (with optional setup params), a Blueprint, or omit for an anonymous base Entity.

this.spawnChild("body", EnemyBody, { color: 0xff6b6b });
this.spawnChild("hp", EnemyHealthBar);

string

Blueprint<void>

Entity

Entity.spawnChild


tryGet<C>(cls): C | undefined

Defined in: Entity.ts:239

Get a component by class, or undefined if not found.

C extends Component

ComponentClass<C>

C | undefined

Entity.tryGet


tryGetChild(name): Entity | undefined

Defined in: Entity.ts:208

Get a child by name, or undefined if not found.

string

Entity | undefined

Entity.tryGetChild