求助一个 quicker 动作、思源按钮或快捷键,手动选中思源笔记的连续多个块时,点击思源按钮或 quicker 动作,实现以下功能:
- 将选中的多个块转换成引述或超级块。
- 将这个整体的引述或超级块折叠。
求助一个 quicker 动作、思源按钮或快捷键,手动选中思源笔记的连续多个块时,点击思源按钮或 quicker 动作,实现以下功能:
选中后 ctrl+q
触发, 触发后会将选中的内容转换成引用, 过程中会有点卡顿, 因为不知道为啥, 延时低了就会报错, 所以只能先让 sleep 时间长一点
触发前, , 触发后,
(()=>{
// 延迟执行
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
function press_once(keyInit, selector = null) {
keyInit["bubbles"] = true;
if (selector == null) {
selector = document.querySelector('[data-type="wnd"].layout__wnd--active .protyle:not(.fn__none) .protyle-wysiwyg.protyle-wysiwyg--attr')
}
else if (typeof selector === 'function') {
selector = selector()
}
else if (typeof selector === 'string') {
selector = document.querySelector(selector)
}
if (!selector) return
selector.dispatchEvent(new KeyboardEvent('keydown', keyInit));
selector.dispatchEvent(new KeyboardEvent('keyup', keyInit));
}
async function add_new_line_before() {
press_once({
key: 'Enter',
ctrlKey: true,
shiftKey: true,
keyCode: 13, // 不推荐使用,但某些情况下需要
});
}
function click_right(ele) {
// 创建一个右键点击的 MouseEvent
const rightClickEvent = new MouseEvent('contextmenu', {
bubbles: true,
cancelable: true,
view: window,
button: 2
});
ele.dispatchEvent(rightClickEvent);
}
// 获取光标所在的元素
function getElementAtCursor() {
const selection = window.getSelection();
if (selection.rangeCount > 0) {
const range = selection.getRangeAt(0);
const startContainer = range.startContainer;
// 如果是文本节点,获取其父元素
const element = startContainer.nodeType === 3 ? startContainer.parentNode : startContainer;
return element;
}
return null; // 如果没有选中内容或光标位置无效
}
// 获取当前选中的文本
async function get_selected_data() {
// 触发 ctrl+c, 复制选中的块
document.execCommand('copy');
// 获取剪贴板文本
return await navigator.clipboard.readText();
}
// 设置文本
async function paste_data(data) {
// 将处理后的文本复制到剪贴板
await navigator.clipboard.writeText(data);
// 触发 ctrl+v, 粘贴处理后的内容
document.execCommand('paste');
await sleep(20)
}
// 清空选中的内容: 先剪切, 再增加空行
async function clear_selected_data() {
// 触发 ctrl+x, 剪切选中的块, 目的是删除原有内容
document.execCommand('cut');
await add_new_line_before()
}
// 转换引用 - 使用系统自带的转换功能
function convert_quote_from_sys(event) {
click_right(event.target)
// 创建 mouseover 事件
const mouseOverEvent = new MouseEvent('mouseover', {
view: window,
bubbles: true,
cancelable: true,
});
let turn_ele = document.querySelector('.b3-menu__items>[data-id="turnInto"]')
turn_ele?.dispatchEvent(mouseOverEvent);
turn_ele = turn_ele?.querySelector('.b3-menu__submenu>.b3-menu__items>[data-id="quote"]')
if (!turn_ele) return false
turn_ele.click()
return true
}
// 转换引用 - 使用自己实现的的转换功能
async function convert_quote_from_my(clipboardText) {
// 删除原有内容, 并增加空行
await clear_selected_data()
let clipboardTextRet = clipboardText
.split('\n')
.map(line => "> " + line)
.join('\n')
// 粘贴处理后的文本
await paste_data(clipboardTextRet);
}
async function fold_block() {
await sleep(300);
let ele = getElementAtCursor();
if (!ele) return
while (!ele.parentNode.classList.contains("protyle-wysiwyg--attr") && ele.getAttribute('data-type') != 'NodeBlockquote') {
ele = ele.parentNode
}
click_right(ele)
await sleep(300)
document.querySelector('.b3-menu__items>[data-id="fold"]')?.click()
}
// 合并选中的块
async function handle_merge(event) {
// 获取当前选中的文本
let clipboardText = await get_selected_data();
// 如果不需要处理, 则直接返回
if (clipboardText == "") {
console.log("不需要处理")
return;
}
if (convert_quote_from_sys(event)) {
console.log("系统转换成功")
}
else {
await convert_quote_from_my(clipboardText)
console.log("自定义转换成功")
}
await fold_block();
}
// 事件监听
document.addEventListener('keydown', async (event) => {
// 检查是否按下了 Ctrl + q
if (event.ctrlKey && event.key === 'q') {
// event.preventDefault(); // 防止快捷键默认行为
await handle_merge(event);
}
});
})()
选中后 ctrl+q
触发, 触发后会将选中的内容转换成引用, 过程中会有点卡顿, 因为不知道为啥, 延时低了就会报错, 所以只能先让 sleep 时间长一点
触发前, , 触发后,
(()=>{
// 延迟执行
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
function press_once(keyInit, selector = null) {
keyInit["bubbles"] = true;
if (selector == null) {
selector = document.querySelector('[data-type="wnd"].layout__wnd--active .protyle:not(.fn__none) .protyle-wysiwyg.protyle-wysiwyg--attr')
}
else if (typeof selector === 'function') {
selector = selector()
}
else if (typeof selector === 'string') {
selector = document.querySelector(selector)
}
if (!selector) return
selector.dispatchEvent(new KeyboardEvent('keydown', keyInit));
selector.dispatchEvent(new KeyboardEvent('keyup', keyInit));
}
async function add_new_line_before() {
press_once({
key: 'Enter',
ctrlKey: true,
shiftKey: true,
keyCode: 13, // 不推荐使用,但某些情况下需要
});
}
function click_right(ele) {
// 创建一个右键点击的 MouseEvent
const rightClickEvent = new MouseEvent('contextmenu', {
bubbles: true,
cancelable: true,
view: window,
button: 2
});
ele.dispatchEvent(rightClickEvent);
}
// 获取光标所在的元素
function getElementAtCursor() {
const selection = window.getSelection();
if (selection.rangeCount > 0) {
const range = selection.getRangeAt(0);
const startContainer = range.startContainer;
// 如果是文本节点,获取其父元素
const element = startContainer.nodeType === 3 ? startContainer.parentNode : startContainer;
return element;
}
return null; // 如果没有选中内容或光标位置无效
}
// 获取当前选中的文本
async function get_selected_data() {
// 触发 ctrl+c, 复制选中的块
document.execCommand('copy');
// 获取剪贴板文本
return await navigator.clipboard.readText();
}
// 设置文本
async function paste_data(data) {
// 将处理后的文本复制到剪贴板
await navigator.clipboard.writeText(data);
// 触发 ctrl+v, 粘贴处理后的内容
document.execCommand('paste');
await sleep(20)
}
// 清空选中的内容: 先剪切, 再增加空行
async function clear_selected_data() {
// 触发 ctrl+x, 剪切选中的块, 目的是删除原有内容
document.execCommand('cut');
await add_new_line_before()
}
// 转换引用 - 使用系统自带的转换功能
function convert_quote_from_sys(event) {
click_right(event.target)
// 创建 mouseover 事件
const mouseOverEvent = new MouseEvent('mouseover', {
view: window,
bubbles: true,
cancelable: true,
});
let turn_ele = document.querySelector('.b3-menu__items>[data-id="turnInto"]')
turn_ele?.dispatchEvent(mouseOverEvent);
turn_ele = turn_ele?.querySelector('.b3-menu__submenu>.b3-menu__items>[data-id="quote"]')
if (!turn_ele) return false
turn_ele.click()
return true
}
// 转换引用 - 使用自己实现的的转换功能
async function convert_quote_from_my(clipboardText) {
// 删除原有内容, 并增加空行
await clear_selected_data()
let clipboardTextRet = clipboardText
.split('\n')
.map(line => "> " + line)
.join('\n')
// 粘贴处理后的文本
await paste_data(clipboardTextRet);
}
async function fold_block() {
await sleep(300);
let ele = getElementAtCursor();
if (!ele) return
while (!ele.parentNode.classList.contains("protyle-wysiwyg--attr") && ele.getAttribute('data-type') != 'NodeBlockquote') {
ele = ele.parentNode
}
click_right(ele)
await sleep(300)
document.querySelector('.b3-menu__items>[data-id="fold"]')?.click()
}
// 合并选中的块
async function handle_merge(event) {
// 获取当前选中的文本
let clipboardText = await get_selected_data();
// 如果不需要处理, 则直接返回
if (clipboardText == "") {
console.log("不需要处理")
return;
}
if (convert_quote_from_sys(event)) {
console.log("系统转换成功")
}
else {
await convert_quote_from_my(clipboardText)
console.log("自定义转换成功")
}
await fold_block();
}
// 事件监听
document.addEventListener('keydown', async (event) => {
// 检查是否按下了 Ctrl + q
if (event.ctrlKey && event.key === 'q') {
// event.preventDefault(); // 防止快捷键默认行为
await handle_merge(event);
}
});
})()
RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。
Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。
Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。
React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。
单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。
应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。
Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。
设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。
Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。
NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。
ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。
Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。
有什么新发现就分享给大家吧!
域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。
互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。
本标签主要用于分享网络空间安全专业的学习笔记
Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。
JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA。
iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。
Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用 。
1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。
IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。
微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。