refactor: interactive button

This commit is contained in:
MapleLeaf
2021-12-25 01:52:55 -06:00
parent 99430e0edc
commit 18bcf4828c
9 changed files with 145 additions and 93 deletions

View File

@@ -3,20 +3,20 @@ import ReactReconciler from "react-reconciler"
import { raise } from "../src/helpers/raise.js"
import { ButtonNode } from "./components/button.js"
import type { Node } from "./node.js"
import type { RootNode } from "./root-node.js"
import type { Renderer } from "./renderer.js"
import { TextNode } from "./text-node.js"
const config: HostConfig<
string, // Type,
Record<string, unknown>, // Props,
RootNode, // Container,
Renderer, // Container,
Node, // Instance,
TextNode, // TextInstance,
never, // SuspenseInstance,
never, // HydratableInstance,
never, // PublicInstance,
{}, // HostContext,
never, // UpdatePayload,
true, // UpdatePayload,
never, // ChildSet,
number, // TimeoutHandle,
number // NoTimeout,
@@ -41,27 +41,29 @@ const config: HostConfig<
createTextInstance: (text) => new TextNode(text),
shouldSetTextContent: () => false,
clearContainer: (root) => {
root.clear()
clearContainer: (renderer) => {
renderer.clear()
},
appendChildToContainer: (root, child) => {
root.add(child)
appendChildToContainer: (renderer, child) => {
renderer.add(child)
},
removeChildFromContainer: (root, child) => {
root.remove(child)
removeChildFromContainer: (renderer, child) => {
renderer.remove(child)
},
// eslint-disable-next-line unicorn/no-null
prepareUpdate: () => null,
commitUpdate: () => {},
prepareUpdate: () => true,
commitUpdate: (node, payload, type, oldProps, newProps) => {
node.props = newProps
},
commitTextUpdate: (node, oldText, newText) => {
node.text = newText
},
// eslint-disable-next-line unicorn/no-null
prepareForCommit: () => null,
resetAfterCommit: (root) => {
root.render()
resetAfterCommit: (renderer) => {
renderer.render()
},
preparePortalMount: () => raise("Portals are not supported"),