Jazzと読書の日々

iPadを筆記具として使う方法を模索します

Obsidian Roomが軽くなりました

ファイルを開く方法が変わりました。

Room.md

dataviewスクリプトです。

Import Obsidian: Room

>[!example]- Room
>```dataview
>task where !completed group by file.link
>```

```dataviewjs
s = "background:ivory;width:120px;height:112px;border:1px solid #eee;border-top:8px solid gold;text-decoration:none;padding:3px;border-radius:3px;margin:3px;overflow:hidden;float:left;"

const p = dv.el("input")
p.placeholder = "..."
p.style = "font-size:18px;background:whitesmoke;border-radius:3px;"
const btn = dv.el("button","+")
btn.style = "font-size:12px;margin:5px;width:40px;"
dv.paragraph("---")
const b = dv.el("div","")
b.style = "font-size:small;font-weight:bold;height:5000px;"
disp()

p.onkeyup = function(){
  disp()
}

btn.onclick = function(){
  s = encodeURI(p.value)
  open("obsidian://new?file=" + s + "&content=" + s)
}

function disp(){
  r = new RegExp("("+ p.value +")","i")
 d = dv.array(Object.entries(dv.app.metadataCache.fileCache))
    .filter(([x,y]) => r.test(x))
    .sort(([x,y]) => y.mtime, "desc")
    .limit(200)
    .map(([x,y]) => "<a class=internal-link style='" + s + "' href='" + x + "'>" + x.split("/").pop().replace(".md","") + "</a>")
  b.innerHTML = d.join("\n")
}
```

使い方

ファイル履歴がカード形式で表示されます。 これを検索欄で絞り込めます。

「+」をタップすると新規作成です。 検索欄をファイル名にします。

内部リンク

なるほどなあ。 URLスキームを使っていたのですが、実はクラスにinternal-linkを指定すれば大丈夫だったようです。 ファイルを開くまでの動作が軽くなりました。

情報を公開してもらえて助かります。

まとめ

応用が利きそうだけど、他にもリンクのスクリプトあったかな。