2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* The `SubtreeRetainer` class keeps track of a number of pieces of data,
|
|
|
|
* comparing the values of these pieces at every iteration.
|
|
|
|
*
|
|
|
|
* This is useful for preventing redraws to relatively static (or huge)
|
|
|
|
* components whose VDOM only depends on very few values, when none of them
|
|
|
|
* have changed.
|
|
|
|
*
|
|
|
|
* @example
|
|
|
|
* // Check two callbacks for changes on each update
|
|
|
|
* this.subtree = new SubtreeRetainer(
|
|
|
|
* () => this.attrs.post.freshness,
|
|
|
|
* () => this.showing
|
|
|
|
* );
|
|
|
|
*
|
|
|
|
* // Add more callbacks to be checked for updates
|
|
|
|
* this.subtree.check(() => this.attrs.user.freshness);
|
|
|
|
*
|
|
|
|
* // In a component's onbeforeupdate() method:
|
|
|
|
* return this.subtree.needsRebuild()
|
|
|
|
*
|
|
|
|
* @see https://mithril.js.org/lifecycle-methods.html#onbeforeupdate
|
|
|
|
*/
|
|
|
|
export default class SubtreeRetainer {
|
2021-10-31 06:31:34 +08:00
|
|
|
protected callbacks: (() => any)[];
|
|
|
|
protected data: Record<string, any>;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* @param callbacks Functions returning data to keep track of.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
constructor(...callbacks: (() => any)[]);
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Return whether any data has changed since the last check.
|
|
|
|
* If so, Mithril needs to re-diff the vnode and its children.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
needsRebuild(): boolean;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
|
|
|
* Add another callback to be checked.
|
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
check(...callbacks: (() => any)[]): void;
|
2021-05-13 07:29:46 +08:00
|
|
|
/**
|
2021-10-31 06:31:34 +08:00
|
|
|
* Invalidate the subtree, forcing it to be redrawn.
|
2021-05-13 07:29:46 +08:00
|
|
|
*/
|
2021-10-31 06:31:34 +08:00
|
|
|
invalidate(): void;
|
2021-05-13 07:29:46 +08:00
|
|
|
}
|