ファイルを開く方法が変わりました。
Room.md
dataviewスクリプトです。
>[!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を指定すれば大丈夫だったようです。 ファイルを開くまでの動作が軽くなりました。
情報を公開してもらえて助かります。
まとめ
応用が利きそうだけど、他にもリンクのスクリプトあったかな。