隐藏frontmatter段的CSS代码

我实际上最近采用悬浮侧边栏的形式来操作,参考这篇Obsidian样式-悬浮侧边栏悬浮右侧栏后,在侧边栏编辑。

今天研究了下这个关闭重复标签的问题,可以通过以下代码实现(放到ii-quicker的js代码片段中即可):

this.app.workspace.onLayoutReady(() => {
	this.app.workspace.on("active-leaf-change", (activeLeaf) => {
		const filePath = activeLeaf?.view.getState().file;
		if (!filePath) return;
		const viewType = activeLeaf?.view.getViewType();
		// 获取已存在的其他叶子
		let repeatLeaves = this.app.workspace.getLeavesOfType(viewType).filter((leaf) =>
			// 不包含新打开的叶子
			leaf !== activeLeaf &&
			// 限制同一个分割窗口下的叶子
			//leaf.parent.id === activeLeaf.parent.id &&
			// 筛选文件路径相同的叶子
			leaf.view?.getState().file === filePath
		)
		if(repeatLeaves.length > 0) {
			repeatLeaves.push(activeLeaf)
			// 排序规则,pinned优先,相同条件下,最先打开的优先
			repeatLeaves = repeatLeaves.sort((leaf1, leaf2) => {
				// 如果 leaf1 被固定但 leaf2 没有,leaf1 在前
				if (leaf1.pinned && !leaf2.pinned) return -1;
				// 如果 leaf2 被固定但 leaf1 没有,leaf2 在前
				if (!leaf1.pinned && leaf2.pinned) return 1;
				// 当两者都 pinned 或者都没有 pinned 的情况,根据 activeTime 排序
				const leaf2ActiveTime =leaf2.activeTime || Date.now()
				if (leaf1.activeTime !== leaf2ActiveTime) {
					// 时间早的在前
					return leaf1.activeTime - leaf2ActiveTime;
				}
				// activeTime 相同的情况下,保持原顺序
				return 0;
			});
	
			// 激活排序后的第一个叶子
			const newActiveLeaf = repeatLeaves.shift();
			this.app.workspace.setActiveLeaf(newActiveLeaf, { focus: true });
	
			// 关闭排序后的其他叶子
			repeatLeaves.forEach((leaf) => {
				leaf?.detach()
			});
		}
	})
})

这个激活的规则是:锁定的叶子优先,相同条件下,最先打开的优先,其他的关闭。这样就保证了仅关闭最后打开的叶子,并激活之前已打开的叶子。

注意:按住CTRL重复打开某个文件,控制台可能会出现以下错误,
app.js:1 RangeError: Field is not present in this state,这是因为叶子结点已销毁了,但ob销毁前要把叶子插入到访问历史,但又找不到对象引起的,这个应该是官方的bug,目前无法避免,但这个错误在使用中并没什么影响,按道理讲重复打开同一个文件也不应该产生很多重复的历史才对。

是粘贴到隐藏和显示指定文档属性的代码后面吗?

对的,二者是并列关系,不要嵌套,放到最后面即可。

能出一个ii轻版本,只包括禅模式和执行javascript代码片段?把禅模式的进入和退出,加到右键菜单里。
BTW: 禅模式,似乎对移动端没有作用。

移动端目前不支持,感觉手机端的使用场景不多;ii的所有功能都可以通过设置里的开关关闭;右键菜单推荐commander插件,这个插件功能很强大,不仅仅是右键菜单,你想加到哪里都可以。

commander 我有使用。安卓端似乎调不出右键菜单。

/输入命令我在设置里禁用了,我试度开启这个看看效果。

手机端右键菜单都调不出吧,你可以加到右侧这个菜单里,在手机端就方便调用了。

image

或者加到左侧ribbon那里也可以。

看了你的代码,受到启发,是否也可以实现文档阅读位置保存到属性里,流程大概这样:
激活leaf时,若文档属性里有保存cursor位置,就调用
app.workspace.activeLeaf.setEphemeralState(cursorstate);
恢复编辑阅读位置;
若关闭leaf或离开leaf时,调用
cursorstate = app.workspace.activeLeaf.getEphemeralState();
把cursorstate保存到文档属性里。

这样,即使是用同步工具,也可以保证跨平台,恢复到阅读位置。

又,由于dataviewjs聚合时,不适合这样保存和恢复位置,加个排除列表,比如排除指定目录的文档,不保存和恢复位置。

手机端我有使用commander在page header添加命令按钮,和在file menu里添加。
但我往page header添加多几个按钮时,竖屏下那个三点按钮会不显示出来。
讨论在这里:

能通过js调整吗?

右键菜单没有快速打开和关闭禅模式的选项,配置里也没有。
每次用ctrl-p iiz不太方便。

有个问题,有时需要左右分屏,对照文档编辑。
右击一个leaf,选择左右分屏,被自动关闭了。

试取消注释也不成:
//leaf.parent.id === activeLeaf.parent.id &&

别加到header里,加到菜单里(右上角那个,点开菜单),如下:
image

这个功能还可以设置仅在手机或pc显示等,你研究下,可以不同端显示到不同的地方,方便使用。

右键菜单没有快速打开和关闭禅模式的选项,配置里也没有。
每次用ctrl-p iiz不太方便。

配合commander添加命令到你想要的地方或者设置快捷键。

如果需要左右分屏,去掉这个可以的,但你要重启下obsidian,因为这个js是匿名函数,你修改后会在内存生成一个副本,之前的代码还是会存在的,后面如果修改ii插件的话考虑通过赋值变量覆盖的方式试试。

明白了,我也试验出来了。

关于阅读位置跨平台和保存。

remember cursor position这个插件应该支持跨平台的。

你要自定义话可以参考下它的代码,保存的话,他是保存到文件中,不建议保存到文档属性中,建议按照remember cursor position的方式存储到文件中,它这个文件默认是保存到.obsidian/plugins文件目录下,如果不方便同步配置文件的话,可以在插件配置里修改保存文件路径。

排除的话应该在restoreEphemeralState()函数里,根据文件名或目录跳过即可。

插件源码:obsidian-remember-cursor-position/main.ts at master · dy-sh/obsidian-remember-cursor-position · GitHub

windows下,如何方便编辑调试,github上的项目?给个详细指引,打算以后就在obsidian平台上做些自己的个性化需求,现在在obsidian写改代码都很不方便。半甲子之人了,玩不动新事物了。

remember cursor这个插件,刚接触obsidian就用上了,也把它保存的文件改到vault root下了。
但似乎这个文件修改频繁,同步时总是冲突。所以,一直想改下,把位置保存到各个md里。

其实,我是想不要太多插件,比如ii一个插件加js片段能搞定的,就不多安装一个。