obsidian中的excalidraw如何添加标签?
ob中markdown文件可以通过标签搜索,excalidraw文件如何通过标签搜索?
如果指对一个 excalidraw 添加 Tag, 可以做到:
- 运行 OB 命令行
Excalidraw: 在 Excalidraw 和 Markdown 模式之间切换
- 之后该文档变成 markdown, 在 frontmatter 里随便添加 tag 即可
- 弄完后再次运行这个命令, 又变成图
- 此后 Ob 搜索界面以普通的
tag:#my_tag
搜就行
如果指对 excalidraw 的 “具体一个图形要素” 添加 Tag, 这个不知道咋实现
这个好像可以直接编辑文本,在文本中写入#tag_name
你是想在文本里面添加标签吗,我之前弄过类似的,是基于Modal Form表单实现的,目前就单个修改,还没做批量编辑,主要我自己不怎么在里面用标签,所以没怎么折腾了。
在使用这段代码之前,需要确保已安装并启动了 Modal Form 插件,以便正常执行代码逻辑。
【Excalidraw脚本】AddTagsByModalForm
await ea.addElementsToView();
let modalForm;
try {
modalForm = app.plugins.plugins.modalforms.api;
} catch {
new Notice("🔴本脚本依赖Modal Form插件的API,请先安装或启动Modal Form插件!");
return;
}
const api = ea.getExcalidrawAPI();
// ! modalForms 的表单
// 普通的编辑文本框
const editorForm1 = {
"title": "编辑文本",
"name": "editorForm1",
"fields": [
{
"name": "editorContent",
"label": "编辑文本框",
"description": "",
"input": {
"type": "textarea"
}
},
{
"name": "Tags",
"description": "选择标签(可选)",
"input": {
"type": "tag"
}
},
],
};
// ! text 类型
const selectedTextElements = ea.getViewSelectedElements().filter(el => el.type === "text");
if (selectedTextElements.length === 1) {
ea.copyViewElementsToEAforEditing(selectedTextElements);
const el = ea.getElements()[0];
let exText = el.rawText;
// 提取末尾的标签
const tags = exText.match(/\s(#\S+)/gm);
console.log(tags);
// 删除原文中的标签
const textWithoutTags = exText.replace(/\s(#\S+)/gm, '');
let result = await modalForm.openForm(
editorForm1,
{
values: {
Tags: tags ? tags : "",
editorContent: textWithoutTags.trim(),
}
}
);
const getTags = result.getValue('Tags').value;
let tagsStr = "";
if (getTags.length >= 1) {
tagsStr = getTags.map(t => "#" + t.trim().replace("#", "")).join(" ");
}
let editorContent = result.getValue('editorContent').value;
el.originalText = el.rawText = el.text = editorContent.trim() + " " + tagsStr;
// // 文本全部居左,居中
// el.textAlign = "left";
// el.textVerticalAlign = "middle";
ea.refreshTextElementSize(el.id);
await ea.addElementsToView(false, false);
if (el.containerId) {
const containers = ea.getViewElements().filter(e => e.id === el.containerId);
api.updateContainerSize(containers);
ea.selectElementsInView(containers);
}
return;
}
1 个赞
对了,如果是给YAML添加标签应该不要太麻烦,可以借助Quick Tagger插件来添加以及自己设置好Template就行,Quick Tagger插件还可以在图谱里面添加和移除标签,非常好用。