Fixes #98
parent
2893fe11a3
commit
232a0d8df8
|
@ -9,6 +9,7 @@ import {
|
||||||
} from "$sb/lib/tree.ts";
|
} from "$sb/lib/tree.ts";
|
||||||
import { resolveAttachmentPath, resolvePath } from "$sb/lib/resolve.ts";
|
import { resolveAttachmentPath, resolvePath } from "$sb/lib/resolve.ts";
|
||||||
import { parsePageRef } from "$sb/lib/page.ts";
|
import { parsePageRef } from "$sb/lib/page.ts";
|
||||||
|
import { tagPrefix } from "../index/constants.ts";
|
||||||
|
|
||||||
async function actionClickOrActionEnter(
|
async function actionClickOrActionEnter(
|
||||||
mdTree: ParseTree | null,
|
mdTree: ParseTree | null,
|
||||||
|
@ -27,6 +28,7 @@ async function actionClickOrActionEnter(
|
||||||
"Link",
|
"Link",
|
||||||
"CommandLink",
|
"CommandLink",
|
||||||
"PageRef",
|
"PageRef",
|
||||||
|
"Hashtag",
|
||||||
]
|
]
|
||||||
.includes(
|
.includes(
|
||||||
t.type!,
|
t.type!,
|
||||||
|
@ -96,6 +98,16 @@ async function actionClickOrActionEnter(
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case "Hashtag": {
|
||||||
|
console.log("Got myself a hash tag", mdTree);
|
||||||
|
const hashtag = mdTree.children![0].text!.slice(1);
|
||||||
|
await editor.navigate(
|
||||||
|
{ page: `${tagPrefix}${hashtag}`, pos: 0 },
|
||||||
|
false,
|
||||||
|
inNewWindow,
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
export const tagPrefix = "📌 ";
|
|
@ -167,3 +167,22 @@ functions:
|
||||||
path: lint.ts:lintYAML
|
path: lint.ts:lintYAML
|
||||||
events:
|
events:
|
||||||
- editor:lint
|
- editor:lint
|
||||||
|
|
||||||
|
# Tag file system
|
||||||
|
readFileTag:
|
||||||
|
path: tag_page.ts:readFileTag
|
||||||
|
pageNamespace:
|
||||||
|
pattern: "📌 .+"
|
||||||
|
operation: readFile
|
||||||
|
|
||||||
|
writePageTag:
|
||||||
|
path: tag_page.ts:writeFileTag
|
||||||
|
pageNamespace:
|
||||||
|
pattern: "📌 .+"
|
||||||
|
operation: readFile
|
||||||
|
|
||||||
|
getPageMetaTag:
|
||||||
|
path: tag_page.ts:getFileMetaTag
|
||||||
|
pageNamespace:
|
||||||
|
pattern: "📌 .+"
|
||||||
|
operation: getFileMeta
|
|
@ -0,0 +1,92 @@
|
||||||
|
import { FileMeta } from "$sb/types.ts";
|
||||||
|
import { markdown, system } from "$sb/syscalls.ts";
|
||||||
|
import { renderToText } from "$sb/lib/tree.ts";
|
||||||
|
import { tagPrefix } from "./constants.ts";
|
||||||
|
|
||||||
|
export async function readFileTag(
|
||||||
|
name: string,
|
||||||
|
): Promise<{ data: Uint8Array; meta: FileMeta }> {
|
||||||
|
const tagName = name.substring(
|
||||||
|
tagPrefix.length,
|
||||||
|
name.length - ".md".length,
|
||||||
|
);
|
||||||
|
const text = `These are all objects in your space tagged with #${tagName}.
|
||||||
|
\`\`\`template
|
||||||
|
template: |
|
||||||
|
{{#if .}}
|
||||||
|
# Pages
|
||||||
|
{{#each .}}
|
||||||
|
* [[{{name}}]]
|
||||||
|
{{/each}}
|
||||||
|
{{/if}}
|
||||||
|
query: |
|
||||||
|
page where tags = "${tagName}"
|
||||||
|
\`\`\`
|
||||||
|
\`\`\`template
|
||||||
|
template: |
|
||||||
|
{{#if .}}
|
||||||
|
# Tasks
|
||||||
|
{{#each .}}
|
||||||
|
* [{{state}}] [[{{ref}}]] {{name}}
|
||||||
|
{{/each}}
|
||||||
|
{{/if}}
|
||||||
|
query: |
|
||||||
|
task where tags = "${tagName}"
|
||||||
|
\`\`\`
|
||||||
|
\`\`\`template
|
||||||
|
template: |
|
||||||
|
{{#if .}}
|
||||||
|
# Items
|
||||||
|
{{#each .}}
|
||||||
|
* [[{{ref}}]] {{name}}
|
||||||
|
{{/each}}
|
||||||
|
{{/if}}
|
||||||
|
query: |
|
||||||
|
item where tags = "${tagName}"
|
||||||
|
\`\`\`
|
||||||
|
\`\`\`template
|
||||||
|
template: |
|
||||||
|
{{#if .}}
|
||||||
|
# Paragraphs
|
||||||
|
{{#each .}}
|
||||||
|
* [[{{ref}}]] {{text}}
|
||||||
|
{{/each}}
|
||||||
|
{{/if}}
|
||||||
|
query: |
|
||||||
|
paragraph where tags = "${tagName}"
|
||||||
|
\`\`\`
|
||||||
|
`;
|
||||||
|
|
||||||
|
let tree = await markdown.parseMarkdown(text);
|
||||||
|
tree = await system.invokeFunction("markdown.expandCodeWidgets", tree, name);
|
||||||
|
|
||||||
|
return {
|
||||||
|
data: new TextEncoder().encode(renderToText(tree)),
|
||||||
|
meta: {
|
||||||
|
name,
|
||||||
|
contentType: "text/markdown",
|
||||||
|
size: text.length,
|
||||||
|
created: 0,
|
||||||
|
lastModified: 0,
|
||||||
|
perm: "ro",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function writeFileTag(
|
||||||
|
name: string,
|
||||||
|
): FileMeta {
|
||||||
|
// Never actually writing this
|
||||||
|
return getFileMetaTag(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getFileMetaTag(name: string): FileMeta {
|
||||||
|
return {
|
||||||
|
name,
|
||||||
|
contentType: "text/markdown",
|
||||||
|
size: -1,
|
||||||
|
created: 0,
|
||||||
|
lastModified: 0,
|
||||||
|
perm: "ro",
|
||||||
|
};
|
||||||
|
}
|
|
@ -6,6 +6,7 @@ import { resolveAttachmentPath } from "$sb/lib/resolve.ts";
|
||||||
import { parse } from "../../common/markdown_parser/parse_tree.ts";
|
import { parse } from "../../common/markdown_parser/parse_tree.ts";
|
||||||
import { parsePageRef } from "$sb/lib/page.ts";
|
import { parsePageRef } from "$sb/lib/page.ts";
|
||||||
import { extendedMarkdownLanguage } from "../../common/markdown_parser/parser.ts";
|
import { extendedMarkdownLanguage } from "../../common/markdown_parser/parser.ts";
|
||||||
|
import { tagPrefix } from "../../plugs/index/constants.ts";
|
||||||
|
|
||||||
const activeWidgets = new Set<MarkdownWidget>();
|
const activeWidgets = new Set<MarkdownWidget>();
|
||||||
|
|
||||||
|
@ -157,6 +158,24 @@ export class MarkdownWidget extends WidgetType {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Attach click handlers to hash tags
|
||||||
|
div.querySelectorAll("span.hashtag").forEach((el_) => {
|
||||||
|
const el = el_ as HTMLElement;
|
||||||
|
// Override default click behavior with a local navigate (faster)
|
||||||
|
console.log("Found hashtag", el.innerText);
|
||||||
|
el.addEventListener("click", (e) => {
|
||||||
|
console.log("Hashtag clicked", el.innerText);
|
||||||
|
if (e.ctrlKey || e.metaKey) {
|
||||||
|
// Don't do anything special for ctrl/meta clicks
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.client.navigate({
|
||||||
|
page: `${tagPrefix}${el.innerText.slice(1)}`,
|
||||||
|
pos: 0,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
div.querySelectorAll("button[data-onclick]").forEach((el_) => {
|
div.querySelectorAll("button[data-onclick]").forEach((el_) => {
|
||||||
const el = el_ as HTMLElement;
|
const el = el_ as HTMLElement;
|
||||||
const onclick = el.dataset.onclick!;
|
const onclick = el.dataset.onclick!;
|
||||||
|
|
|
@ -177,6 +177,7 @@
|
||||||
color: var(--editor-hashtag-color);
|
color: var(--editor-hashtag-color);
|
||||||
background-color: var(--editor-hashtag-background-color);
|
background-color: var(--editor-hashtag-background-color);
|
||||||
border: 1px solid var(--editor-hashtag-border-color);
|
border: 1px solid var(--editor-hashtag-border-color);
|
||||||
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
.sb-line-hr {
|
.sb-line-hr {
|
||||||
|
|
|
@ -6,6 +6,7 @@ release.
|
||||||
## Edge
|
## Edge
|
||||||
_The changes below are not yet released “properly”. To them out early, check out [the docs on edge](https://community.silverbullet.md/t/living-on-the-edge-builds/27)._
|
_The changes below are not yet released “properly”. To them out early, check out [the docs on edge](https://community.silverbullet.md/t/living-on-the-edge-builds/27)._
|
||||||
|
|
||||||
|
* Tag pages: when you click on a #tag you will now be directed to a page that shows all pages, tasks, items and paragraphs tagged with that tag.
|
||||||
* Bug fixes:
|
* Bug fixes:
|
||||||
* Improved Ctrl/Cmd-click (to open links in a new window) behavior: now actually follow `@pos` and `$anchor` links.
|
* Improved Ctrl/Cmd-click (to open links in a new window) behavior: now actually follow `@pos` and `$anchor` links.
|
||||||
* Right-clicking links now opens browser native context menu again
|
* Right-clicking links now opens browser native context menu again
|
||||||
|
|
Loading…
Reference in New Issue