2022-10-14 21:11:33 +08:00
|
|
|
import type { ClickEvent } from "$sb/app_event.ts";
|
|
|
|
import { editor, markdown, system } from "$sb/silverbullet-syscall/mod.ts";
|
2022-11-18 23:04:37 +08:00
|
|
|
import {
|
|
|
|
addParentPointers,
|
|
|
|
findParentMatching,
|
|
|
|
nodeAtPos,
|
|
|
|
ParseTree,
|
|
|
|
} from "$sb/lib/tree.ts";
|
2022-03-29 23:02:28 +08:00
|
|
|
|
2022-09-06 20:36:06 +08:00
|
|
|
// Checks if the URL contains a protocol, if so keeps it, otherwise assumes an attachment
|
|
|
|
function patchUrl(url: string): string {
|
|
|
|
if (url.indexOf("://") === -1) {
|
2022-09-12 20:50:37 +08:00
|
|
|
return `fs/${url}`;
|
2022-09-06 20:36:06 +08:00
|
|
|
}
|
|
|
|
return url;
|
|
|
|
}
|
|
|
|
|
2022-10-29 15:23:12 +08:00
|
|
|
async function actionClickOrActionEnter(
|
|
|
|
mdTree: ParseTree | null,
|
|
|
|
inNewWindow = false,
|
|
|
|
) {
|
2022-04-04 00:42:12 +08:00
|
|
|
if (!mdTree) {
|
2022-02-28 21:58:18 +08:00
|
|
|
return;
|
|
|
|
}
|
2022-11-18 23:04:37 +08:00
|
|
|
const navigationNodeFinder = (t: ParseTree) =>
|
2022-12-19 20:16:22 +08:00
|
|
|
["WikiLink", "Link", "Image", "URL", "NakedURL", "Link", "CommandLink"]
|
|
|
|
.includes(
|
|
|
|
t.type!,
|
|
|
|
);
|
2022-11-18 23:04:37 +08:00
|
|
|
if (!navigationNodeFinder(mdTree)) {
|
|
|
|
mdTree = findParentMatching(mdTree, navigationNodeFinder);
|
|
|
|
if (!mdTree) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2022-04-04 00:42:12 +08:00
|
|
|
switch (mdTree.type) {
|
2022-11-18 23:04:37 +08:00
|
|
|
case "WikiLink": {
|
|
|
|
let pageLink = mdTree.children![1]!.children![0].text!;
|
2022-08-30 16:44:20 +08:00
|
|
|
let pos;
|
2022-03-28 21:25:05 +08:00
|
|
|
if (pageLink.includes("@")) {
|
2022-04-04 00:42:12 +08:00
|
|
|
[pageLink, pos] = pageLink.split("@");
|
2022-08-30 16:44:20 +08:00
|
|
|
if (pos.match(/^\d+$/)) {
|
|
|
|
pos = +pos;
|
|
|
|
}
|
2022-03-28 21:25:05 +08:00
|
|
|
}
|
2022-08-30 16:44:20 +08:00
|
|
|
if (!pageLink) {
|
2022-10-14 21:11:33 +08:00
|
|
|
pageLink = await editor.getCurrentPage();
|
2022-08-30 16:44:20 +08:00
|
|
|
}
|
2022-10-29 15:23:12 +08:00
|
|
|
await editor.navigate(pageLink, pos, false, inNewWindow);
|
2022-02-28 21:58:18 +08:00
|
|
|
break;
|
2022-10-10 20:50:21 +08:00
|
|
|
}
|
2022-04-12 19:33:07 +08:00
|
|
|
case "NakedURL":
|
2022-10-14 21:11:33 +08:00
|
|
|
await editor.openUrl(patchUrl(mdTree.children![0].text!));
|
2022-02-28 21:58:18 +08:00
|
|
|
break;
|
2022-12-19 20:16:22 +08:00
|
|
|
case "Image":
|
2022-10-10 20:50:21 +08:00
|
|
|
case "Link": {
|
2022-09-06 20:36:06 +08:00
|
|
|
const url = patchUrl(mdTree.children![4].children![0].text!);
|
2022-08-29 21:40:38 +08:00
|
|
|
if (url.length <= 1) {
|
2022-10-14 21:11:33 +08:00
|
|
|
return editor.flashNotification("Empty link, ignoring", "error");
|
2022-08-29 21:40:38 +08:00
|
|
|
}
|
2022-10-14 21:11:33 +08:00
|
|
|
await editor.openUrl(url);
|
2022-03-07 17:21:02 +08:00
|
|
|
break;
|
2022-10-10 20:50:21 +08:00
|
|
|
}
|
|
|
|
case "CommandLink": {
|
2022-11-18 23:04:37 +08:00
|
|
|
const commandName = mdTree.children![1]!.children![0].text!;
|
|
|
|
await system.invokeCommand(commandName);
|
2022-07-18 22:44:43 +08:00
|
|
|
break;
|
2022-10-10 20:50:21 +08:00
|
|
|
}
|
2022-02-27 00:50:50 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-28 21:58:18 +08:00
|
|
|
export async function linkNavigate() {
|
2022-10-14 21:11:33 +08:00
|
|
|
const mdTree = await markdown.parseMarkdown(await editor.getText());
|
|
|
|
const newNode = nodeAtPos(mdTree, await editor.getCursor());
|
2022-11-18 23:04:37 +08:00
|
|
|
addParentPointers(mdTree);
|
2022-04-04 00:42:12 +08:00
|
|
|
await actionClickOrActionEnter(newNode);
|
2022-02-28 21:58:18 +08:00
|
|
|
}
|
2022-02-27 00:50:50 +08:00
|
|
|
|
2022-02-28 21:58:18 +08:00
|
|
|
export async function clickNavigate(event: ClickEvent) {
|
2022-10-29 15:23:12 +08:00
|
|
|
// Navigate by default, don't navigate when Alt is held
|
|
|
|
if (event.altKey) {
|
2022-04-12 02:34:09 +08:00
|
|
|
return;
|
2022-02-27 00:50:50 +08:00
|
|
|
}
|
2022-10-14 21:11:33 +08:00
|
|
|
const mdTree = await markdown.parseMarkdown(await editor.getText());
|
2022-11-18 23:04:37 +08:00
|
|
|
addParentPointers(mdTree);
|
2022-10-10 20:50:21 +08:00
|
|
|
const newNode = nodeAtPos(mdTree, event.pos);
|
2022-10-29 15:23:12 +08:00
|
|
|
await actionClickOrActionEnter(newNode, event.ctrlKey || event.metaKey);
|
2022-02-27 00:50:50 +08:00
|
|
|
}
|
2022-07-04 17:52:09 +08:00
|
|
|
|
|
|
|
export async function navigateCommand(cmdDef: any) {
|
2022-10-14 21:11:33 +08:00
|
|
|
await editor.navigate(cmdDef.page);
|
2022-07-04 17:52:09 +08:00
|
|
|
}
|