diff --git a/lib/com/description.tsx b/lib/com/description.tsx new file mode 100644 index 0000000..97d2d46 --- /dev/null +++ b/lib/com/description.tsx @@ -0,0 +1,53 @@ +import { component } from "../model/components.ts"; +import { Node } from "../model/mod.ts"; +import { objectManaged } from "../model/hooks.ts"; + +@component +export class Description { + text: string; + + constructor() { + this.text = ""; + } + + editor() { + return DescriptionEditor; + } + + static initialize(workbench: Workbench) { + workbench.commands.registerCommand({ + id: "add-description", + title: "Add Description", + when: (ctx: Context) => { + if (!ctx.node) return false; + if (ctx.path.previous && objectManaged(ctx.path.previous)) return false; + if (ctx.node.hasComponent(Description)) return false; + return true; + }, + action: (ctx: Context, name: string) => { + const desc = new Description(); + ctx.node.addComponent(desc); + ctx.node.changed(); + } + }); + } +} + +const DescriptionEditor = { + view({attrs: {node}}) { + const oninput = (e) => { + const desc = node.getComponent(Description); + desc.text = e.target.value; + node.changed(); + } + const onblur = (e) => { + const desc = node.getComponent(Description); + if (desc.text === "") { + node.removeComponent(Description); + } + node.changed(); + } + + return + } +} \ No newline at end of file diff --git a/lib/mod.ts b/lib/mod.ts index c382230..53eb622 100644 --- a/lib/mod.ts +++ b/lib/mod.ts @@ -27,6 +27,7 @@ import { Clock } from "./com/clock.tsx"; import { Tag } from "./com/tag.tsx"; import { Template } from "./com/template.tsx"; import { Document } from "./com/document.tsx"; +import { Description } from "./com/description.tsx"; import { objectManaged } from "./model/hooks.ts"; export { BrowserBackend, SearchIndex_MiniSearch } from "./backend/browser.ts"; @@ -61,6 +62,7 @@ export async function setup(document: Document, target: HTMLElement, backend: Ba Tag, Template, SmartNode, + Description, ].forEach(com => { if (com.initialize) { com.initialize(workbench); @@ -240,6 +242,7 @@ export async function setup(document: Document, target: HTMLElement, backend: Ba title: "Add checkbox", when: (ctx: Context) => { if (!ctx.node) return false; + if (ctx.node.hasComponent(Checkbox)) return false; if (ctx.node.raw.Rel === "Fields") return false; if (ctx.node.parent && ctx.node.parent.hasComponent(Document)) return false; return true; diff --git a/lib/ui/node/editor.tsx b/lib/ui/node/editor.tsx index de959e6..7ca35dc 100644 --- a/lib/ui/node/editor.tsx +++ b/lib/ui/node/editor.tsx @@ -1,5 +1,6 @@ import { objectCall, objectHas } from "../../model/hooks.ts"; import { Document } from "../../com/document.tsx"; +import { Description } from "../../com/description.tsx"; export const NodeEditor: m.Component = { view ({attrs: {workbench, path, onkeydown, oninput, disallowEmpty, editValue, placeholder}, state}) { @@ -45,7 +46,16 @@ export const NodeEditor: m.Component = { if (node.parent && node.parent.hasComponent(Document) && window.Editor) { editor = CodeMirrorEditor; } - return m(editor, {id, getter, setter, display, onkeydown, onfocus, oninput, placeholder, workbench, path}); + let desc = undefined; + if (node.hasComponent(Description)) { + desc = node.getComponent(Description); + } + return ( +