obsidian中的excalidraw如何添加标签

obsidian中的excalidraw如何添加标签?
ob中markdown文件可以通过标签搜索,excalidraw文件如何通过标签搜索?

如果指对一个 excalidraw 添加 Tag, 可以做到:

  • 运行 OB 命令行 Excalidraw: 在 Excalidraw 和 Markdown 模式之间切换
  • 之后该文档变成 markdown, 在 frontmatter 里随便添加 tag 即可
  • 弄完后再次运行这个命令, 又变成图
  • 此后 Ob 搜索界面以普通的 tag:#my_tag 搜就行

如果指对 excalidraw 的 “具体一个图形要素” 添加 Tag, 这个不知道咋实现

这个好像可以直接编辑文本,在文本中写入#tag_name

你是想在文本里面添加标签吗,我之前弄过类似的,是基于Modal Form表单实现的,目前就单个修改,还没做批量编辑,主要我自己不怎么在里面用标签,所以没怎么折腾了。

自定义Excalidraw脚本-给Excalidraw添加标签_IMG-1

在使用这段代码之前,需要确保已安装并启动了 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插件还可以在图谱里面添加和移除标签,非常好用。