From 5765540a3a07e6106a71d86b6843e3d0e9bc8c16 Mon Sep 17 00:00:00 2001 From: Zef Hemel Date: Wed, 16 Oct 2024 20:50:38 +0200 Subject: [PATCH] Widget: alt-click to move cursor into widget --- web/cm_plugins/lua_widget.ts | 9 +++++---- web/cm_plugins/markdown_widget.ts | 5 +++-- web/cm_plugins/widget_util.ts | 12 +++++++++++- website/Space Lua.md | 4 ++-- 4 files changed, 21 insertions(+), 9 deletions(-) diff --git a/web/cm_plugins/lua_widget.ts b/web/cm_plugins/lua_widget.ts index 33894c69..ae7aa138 100644 --- a/web/cm_plugins/lua_widget.ts +++ b/web/cm_plugins/lua_widget.ts @@ -49,7 +49,7 @@ export class LuaWidget extends WidgetType { if (cacheItem) { div.innerHTML = cacheItem.html; if (cacheItem.html) { - attachWidgetEventHandlers(div, this.client); + attachWidgetEventHandlers(div, this.client, this.from); } } @@ -92,7 +92,7 @@ export class LuaWidget extends WidgetType { } else { div.style.display = "inline"; } - attachWidgetEventHandlers(div, this.client); + attachWidgetEventHandlers(div, this.client, this.from); this.client.setWidgetCache( this.cacheKey, { height: div.clientHeight, html }, @@ -157,7 +157,7 @@ export class LuaWidget extends WidgetType { } div.innerHTML = html; if (html) { - attachWidgetEventHandlers(div, this.client); + attachWidgetEventHandlers(div, this.client, this.from); } } @@ -187,7 +187,8 @@ export class LuaWidget extends WidgetType { override eq(other: WidgetType): boolean { return ( other instanceof LuaWidget && - other.bodyText === this.bodyText && other.cacheKey === this.cacheKey + other.bodyText === this.bodyText && other.cacheKey === this.cacheKey && + this.from === other.from ); } } diff --git a/web/cm_plugins/markdown_widget.ts b/web/cm_plugins/markdown_widget.ts index 52cdb351..a1805b61 100644 --- a/web/cm_plugins/markdown_widget.ts +++ b/web/cm_plugins/markdown_widget.ts @@ -181,7 +181,7 @@ export class MarkdownWidget extends WidgetType { } private attachListeners(div: HTMLElement, buttons?: CodeWidgetButton[]) { - attachWidgetEventHandlers(div, this.client); + attachWidgetEventHandlers(div, this.client, this.from); if (!buttons) { buttons = []; @@ -225,7 +225,8 @@ export class MarkdownWidget extends WidgetType { override eq(other: WidgetType): boolean { return ( other instanceof MarkdownWidget && - other.bodyText === this.bodyText && other.cacheKey === this.cacheKey + other.bodyText === this.bodyText && other.cacheKey === this.cacheKey && + this.from === other.from ); } } diff --git a/web/cm_plugins/widget_util.ts b/web/cm_plugins/widget_util.ts index 8c358fa8..f2765ddf 100644 --- a/web/cm_plugins/widget_util.ts +++ b/web/cm_plugins/widget_util.ts @@ -2,8 +2,18 @@ import { parsePageRef } from "@silverbulletmd/silverbullet/lib/page_ref"; import type { Client } from "../client.ts"; import { tagPrefix } from "../../plugs/index/constants.ts"; -export function attachWidgetEventHandlers(div: HTMLElement, client: Client) { +export function attachWidgetEventHandlers( + div: HTMLElement, + client: Client, + pos?: number, +) { div.addEventListener("mousedown", (e) => { + if (e.altKey) { + // Move cursor there + client.editorView.dispatch({ selection: { anchor: pos! } }); + client.editorView.focus(); + e.preventDefault(); + } // CodeMirror overrides mousedown on parent elements to implement its own selection highlighting. // That's nice, but not for markdown widgets, so let's not propagate the event to CodeMirror here. e.stopPropagation(); diff --git a/website/Space Lua.md b/website/Space Lua.md index 27555480..bc6443b1 100644 --- a/website/Space Lua.md +++ b/website/Space Lua.md @@ -1,4 +1,4 @@ -> **warning** Warning +> **warning** Experimental > This is a **highly experimental** feature still under active development. It is documented here primarily for the real early adopters as this feature develops. Space Lua is a custom implementation of the [Lua programming language](https://lua.org/) embedded in SilverBullet. @@ -25,7 +25,7 @@ Each `space-lua` block has its own local scope, however when functions and varia A new syntax introduced with Space Lua is the `${lua expression}` syntax that you can use in your pages, this syntax will [[Live Preview]] to the evaluation of that expression. -Example: 10 + 2 = ${adder(10, 2)} (move into this value to see the expression using the just defined `adder` function to calculate this). +Example: 10 + 2 = ${adder(10, 2)} (Alt-click on this value to see the expression using the just defined `adder` function to calculate this). ## Widgets The `${lua expression}` syntax can be used to implement simple widgets. If the lua expression evaluates to a simple string, it will live preview as that string rendered as simple markdown. However, if the expression returns a Lua table with specific keys, you can do some cooler stuff. The following keys are supported: