Fix hashtag parsing bug, re-added item indexing

pull/3/head
Zef Hemel 2022-07-08 09:50:26 +02:00
parent cce5be43e1
commit ca86f75e16
2 changed files with 32 additions and 7 deletions

View File

@ -3,7 +3,7 @@ syntax:
Hashtag:
firstCharacters:
- "#"
regex: "#[^#\\d\\s]+\\w"
regex: "#[^#\\d\\s]+\\w+"
styles:
color: blue
NakedURL:
@ -36,7 +36,6 @@ functions:
reindexSpace:
path: "./page.ts:reindexSpace"
env: server
deletePage:
path: "./page.ts:deletePage"
command:
@ -63,6 +62,16 @@ functions:
events:
- page:complete
# Item indexing
indexItem:
path: "./item.ts:indexItems"
events:
- page:index
itemQueryProvider:
path: "./item.ts:queryProvider"
events:
- query:item
# Navigation
linkNavigate:
path: "./navigate.ts:linkNavigate"

View File

@ -5,9 +5,11 @@ import {
queryPrefix,
} from "@silverbulletmd/plugos-silverbullet-syscall/index";
import {
collectNodesMatching,
collectNodesOfType,
ParseTree,
renderToText,
replaceNodesMatching,
} from "@silverbulletmd/common/tree";
import { removeQueries } from "../query/util";
import { applyQuery, QueryProviderEvent } from "../query/engine";
@ -15,6 +17,7 @@ import { applyQuery, QueryProviderEvent } from "../query/engine";
export type Item = {
name: string;
nested?: string;
tags?: string[];
// Not stored in DB
page?: string;
pos?: number;
@ -32,6 +35,11 @@ export async function indexItems({ name, tree }: IndexTreeEvent) {
if (!n.children) {
return;
}
if (collectNodesOfType(n, "Task").length > 0) {
// This is a task item, skip it
return;
}
let textNodes: ParseTree[] = [];
let nested: string | undefined;
for (let child of n.children!.slice(1)) {
@ -41,16 +49,24 @@ export async function indexItems({ name, tree }: IndexTreeEvent) {
}
textNodes.push(child);
}
let item = textNodes.map(renderToText).join("").trim();
let value: Item = {
name: item,
let itemText = textNodes.map(renderToText).join("").trim();
let item: Item = {
name: itemText,
};
if (nested) {
value.nested = nested;
item.nested = nested;
}
collectNodesOfType(n, "Hashtag").forEach((h) => {
if (!item.tags) {
item.tags = [];
}
item.tags.push(h.children![0].text!);
});
items.push({
key: `it:${n.from}`,
value,
value: item,
});
});
console.log("Found", items.length, "item(s)");