Skip to content

Commit

Permalink
Added hook to tap into the frameTick event.
Browse files Browse the repository at this point in the history
  • Loading branch information
michielvandergeest committed Feb 14, 2024
1 parent 50c8785 commit fa7a4d1
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 8 deletions.
18 changes: 12 additions & 6 deletions src/component.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,13 @@ declare namespace Component {
/**
* Fires when the Component is being destroyed and removed.
*/
destroy?: (this: ComponentInstance) => void
destroy?: (this: ComponentInstance) => void,
/**
* Fires upon each frame start (allowing you to tap directly into the renderloop)
*
* Note: This hook will fire continuously, multiple times per second!
*/
frameTick?: (this: ComponentInstance) => void
}

export interface ComponentInstance {
Expand All @@ -142,22 +148,22 @@ declare namespace Component {
* Set a timeout that is automatically cleaned upon component destroy
*/
$setTimeout: (callback: (args: any) => void, ms?: number | undefined) => ReturnType<typeof setTimeout>

/**
* Clear a timeout
* Clear a timeout
*/
$clearTimeout: (id: ReturnType<typeof setTimeout>) => void

/**
* Set an interval that is automatically cleaned upon component destroy
*/
$setInterval: (callback: (args: any) => void, ms?: number | undefined) => ReturnType<typeof setInterval>

/**
* Clear a interval
* Clear a interval
*/
$clearInterval: (id: ReturnType<typeof setInterval>) => void

/**
* Log to the console with prettier output and configurable debug levels in Settings
*/
Expand Down
4 changes: 4 additions & 0 deletions src/component.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import parser from './lib/templateparser/parser.js'
import codegenerator from './lib/codegenerator/generator.js'

import element from './element.js'
import { renderer } from './launch.js'

import { createHumanReadableId, createInternalId } from './lib/componentId.js'
import { registerHooks, emit, privateEmit } from './lib/hooks.js'
Expand Down Expand Up @@ -117,6 +118,9 @@ const Component = (name = required('name'), config = required('config')) => {
if (!component.setup) {
setupComponent(this.lifecycle, parentComponent)
}
if (config.hooks && config.hooks.frameTick) {
renderer.on('frameTick', (r, data) => emit('frameTick', name, this, [data]))
}

this.parent = parentComponent
this[symbols.wrapper] = parentEl
Expand Down
4 changes: 2 additions & 2 deletions src/lib/hooks.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ import symbols from './symbols.js'

const cbs = {}

export const emit = (hook, name, scope) => {
cbs[name] && cbs[name][hook] && cbs[name][hook].apply(scope)
export const emit = (hook, name, scope, data = []) => {
cbs[name] && cbs[name][hook] && cbs[name][hook].apply(scope, data)
}

export const privateEmit = (hook, name, scope) => {
Expand Down

0 comments on commit fa7a4d1

Please sign in to comment.