思源笔记折腾记录 - 快速合并子文档到父文档

本贴最后更新于 452 天前,其中的信息可能已经时异事殊

首先实现一个函数, 用来把文档转换成目标文档的一个标题

import 自定义菜单 from 'siyuan-noob@1.3.33/customMenu/index.js'
import 核心api from "siyuan-noob@1.3.33/utilKernel/kernelApi.js"
import {Dialog} from "siyuan-noob@1.3.33/customDialog/index.js"  

首先实现一下菜单:

自定义菜单.编辑器菜单.注册自定义菜单项({
	id:"转换子文档为标题",
	文字:"转换所有子文档为标题(前置)",
	点击回调函数:async(e)=>{
		let 当前块id=自定义菜单.编辑器菜单.菜单状态.当前块id
		显示遮罩()
		await 转换所有子文档为标题(当前块id)
		隐藏遮罩()
		window.location.reload()
	}
})
自定义菜单.编辑器菜单.注册自定义菜单项({
	id:"转换子文档为标题后置",
	文字:"转换所有子文档为标题(后置)",
	点击回调函数:async(e)=>{
		let 当前块id=自定义菜单.编辑器菜单.菜单状态.当前块id
		显示遮罩()
		await 转换所有子文档为标题(当前块id,true)
		隐藏遮罩()
		window.location.reload()
	}
})
自定义菜单.文档树菜单.注册自定义菜单项({
	id:"转换子文档为标题",
	文字:"转换所有子文档为标题(前置)",
	点击回调函数:async(e)=>{
		let 当前块id=自定义菜单.文档树菜单.菜单状态.当前文档id
		显示遮罩()
		await 转换所有子文档为标题(当前块id)
		隐藏遮罩()
		window.location.reload()
	}
})
自定义菜单.文档树菜单.注册自定义菜单项({
	id:"转换子文档为标题后置",
	文字:"转换所有子文档为标题(后置)",
	点击回调函数:async(e)=>{
	
		let 当前块id=自定义菜单.文档树菜单.菜单状态.当前文档id
		显示遮罩()
		await 转换所有子文档为标题(当前块id,true)
		隐藏遮罩()
		window.location.reload()
	}
})

搞个遮罩防止编辑,因为转换过程还是要一会儿嘛


let dialog 
function 显示遮罩(){
	 dialog=new Dialog({
	      title: "正在执行操作",
	      content: '<div id="custom-dialogContent"></div>',
	      width: "90vw",
	      destroyCallback: async () => { },
	      disableClose:true
	    });
	dialog.initElement();
	dialog.show()
	dialog.appendMsg=(content)=>{
		dialog.element.querySelector('.b3-dialog__form').innerHTML+=content
	}
}
function 隐藏遮罩(){
	dialog.destroy()
}

首先实现一个转换函数:

export async function 转换文档为目标文档标题(文档id, 目标文档id,后置,插入位置) {
  let 目标文档内容 = await 核心api.getDoc({
    id: 目标文档id,
    size: 102400,
  });
  let div = document.createElement("div");
  div.innerHTML = 目标文档内容.content;
  let 目标块id = div
    .querySelector("[data-node-id]")
    .getAttribute("data-node-id");
  if(后置){
  
      		目标块id =Array.from(div
		.querySelectorAll("[data-node-id]:not(div[data-node-id] div[data-node-id])")
		).pop()
    		.getAttribute("data-node-id");

  }
  let data = await 核心api.doc2Heading({
    srcID: 文档id,
    after: 后置?true:false,
    targetID: 目标块id,
  });
  dialog.appendMsg(`
	      <label class="b3-label fn__flex">
	      <div class="fn__flex-1">
	          <div class="b3-label__text">
	转换文档${文档id}${目标文档id}内标题完成
	</div>
	      </div>
	      <div class="fn__space"></div>
	`)
}

然后我们来批处理一下

export async function 批量转换文档为标题(文档组,文档id,后置){
  	//这里为啥要倒一下
	for await(let 文档属性 of !后置?文档组.reverse():文档组){
		if(文档属性.subFileCount){
		await 转换所有子文档为标题(文档属性.id,后置)
		}
		await  转换文档为目标文档标题(文档属性.id,文档id,后置)
	}
}
export async function 转换所有子文档为标题(文档id,后置){
	let 文档属性 = await 核心api.sql({stmt:`select * from blocks where id = '${文档id}'`})
	let 子文档列表 = await 核心api.listDocsByPath(
		{
		notebook:文档属性[0].box,
                path: 文档属性[0].path,
                sort: window.siyuan.config.fileTree.sort
		}
	)
	await 批量转换文档为标题(子文档列表.files,文档id,后置)
}

使用方法

还是一样,你可以剪藏这篇笔记,通过:

思源笔记折腾记录 - 运行你的笔记 - 链滴 (ld246.com)

里面的代码片段来直接运行笔记内容就可以了.


水完收工,如果这玩意对你有用可以去爱发电给我买杯咖啡哒

leolee9086 正在创作一些简单的技术教程和小工具,以及设计方面内容 | 爱发电 (afdian.net)

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    19810 引用 • 75844 回帖 • 1 关注
2 操作
leolee 在 2023-04-08 03:19:41 更新了该帖
leolee 在 2023-04-07 21:29:25 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 5 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 610 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 20 关注
  • danl
    89 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    6886 引用 • 31047 回帖 • 231 关注
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    171 引用 • 813 回帖 • 1 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    69 引用 • 190 回帖 • 483 关注
  • 安全

    安全永远都不是一个小问题。

    191 引用 • 813 回帖
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 111 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 618 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4599 回帖 • 690 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 12 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 683 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    285 引用 • 4482 回帖 • 660 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    14 引用 • 7 回帖
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    328 引用 • 1706 回帖
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 155 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    83 引用 • 165 回帖 • 12 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    21 引用 • 37 回帖 • 518 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    51 引用 • 190 回帖 • 2 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 422 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    35 引用 • 35 回帖 • 4 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 10 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    122 引用 • 73 回帖 • 1 关注