[js] 创建 dailynote 自动添加到数据库

思源笔记创建 dailynote 很方便,但是我觉得思源笔记还一直欠缺对 dailynote 的全局管理和浏览
不方便从全局的角度来看这几天、这几周、这几个月每天在干什么

我最近几个月开始尝试用数据库来管理 dailynote,存放全年的 dailynote,发现这种方式可以很方便地快速回顾每日日记,可以通过建立视图,设置筛选条件来建立每月日记视图,还可以在数据库中添加打分、状态(灵感来源:微信状态)、总结、反思等列

这个数据库的位置,我会在年、每月的复盘笔记里

PixPin20240926214926.png

不过目前我只能创建 dailynote 后,再将其手动拖到数据库中,要是新建日记的时候,能自动化添加到指定的数据库,就会省心很多

于是提了一个 issue:创建 dailynote 支持自动添加到数据库 · Issue #12587 · siyuan-note/siyuan (github.com)

但暂时还没有回应,不知道官方会不会做

代码片段

看到有大佬写了自动把子文档添加到数据库的功能,见批量导入文档到数据库 0.0.6 版全新发布 - 链滴 (ld246.com)

参考了下,简单写了一个 js 代码片段,对 alt+5 快捷键进行监控(没有对左上方的创建日记按钮进行监控,因为不会),这样创建或打开日记时,就将 dailynote 放进指定的数据库
使用时,只需要配置数据库块 id 即可,变量为 dbBlockId

注意:本代码只会把所有笔记本创建的 dailynote 统统放进一个数据库里,有些人可能有多个笔记本,每个笔记本的 dailynote 如果需要放在不同的数据库,或者只有某个笔记本的 dailynote 才要放进数据库。本代码暂时没对这两种场景做优化,因为个人只用一个笔记本,暂时没有改进需求(代码能用就行哈哈哈)。

(async () => {
    // 标志变量,用于防止重复触发
    let isCreatingDailyNote = false;
    const originalFetch = window.fetch;

    // 重写 fetch 函数
    window.fetch = async function (...args) {
        // 检查是否是我们要监听的API调用
        if (args[0] === '/api/filetree/createDailyNote' && args[1]?.method === 'POST' && !isCreatingDailyNote) {
            console.log('创建每日笔记的API被调用了!');

            // 设置标志位,防止重复进入
            isCreatingDailyNote = true;

            // 执行创建日记后的逻辑
            await dailynoteAddDatabase();

            // 重置标志位
            isCreatingDailyNote = false;
        }

        // 调用原始的 fetch 函数并返回结果
        return originalFetch.apply(this, args);
    };

    // 创建日记的逻辑,监听创建每日笔记的事件时触发
    async function dailynoteAddDatabase() {
        //设置日记自动存放的数据库块id   
        const dbBlockId = '20240911002857-lgav146';
        // 设置哪个笔记本创建日记才添加到数据库,其他笔记本创建日记代码不作用
        const notebookID = '20241028223345-d9ifjv0';

        // 获取当前选择笔记本
        const boxid = window.siyuan.storage["local-dailynoteid"];
        if (boxid === notebookID) {

            // 调用 /api/filetree/createDailyNote 获得日记 ID
            const create_dailynote_result = await fetchSyncPost('/api/filetree/createDailyNote', { notebook: boxid, app: siyuan.ws.app.appId });
            const docID = create_dailynote_result.data.id;

            // 添加日记到数据库中
            const db = await getDataBySql(`SELECT * FROM blocks where type ='av' and id='${dbBlockId}'`);
            if (db.length === 0) {
                console.error("未找到数据库文档块,请检查数据库文档块id是否正确");
                return;
            }

            const avID = db.map(av => getDataAvIdFromHtml(av.markdown))[0];

            // 检测 dailynote 是否已经在数据库里
            let isInResult = await fetchSyncPost("/api/av/getAttributeViewKeys", { id: docID });
            let foundItem = isInResult.data.find(item => item.avID === avID);
            if (foundItem && foundItem.keyValues) {
                console.log(docID + " 已经在数据库");
                return;
            }
            // ------------添加日记到数据库 ------------ // 
            // 组装文档数据参数
            const srcs = [{
                "id": docID,
                "isDetached": false,
            }];

            const input = {
                "avID": avID,
                'srcs': srcs
            };

            await fetchSyncPost('/api/av/addAttributeViewBlocks', input);
            console.log(docID + " 添加到数据库"+avID);


            function getDataAvIdFromHtml(htmlString) {
                // 使用正则表达式匹配data-av-id的值
                const match = htmlString.match(/data-av-id="([^"]+)"/);
                if (match && match[1]) {
                    return match[1]; // 返回匹配的值
                }
                return ""; // 如果没有找到匹配项,则返回空
            }
            async function getDataBySql(sql) {
                const result = await fetchSyncPost('/api/query/sql', { "stmt": sql });
                if (result.code !== 0) {
                    console.error("查询数据库出错", result.msg);
                    return [];
                }
                return result.data;
            }
            async function fetchSyncPost(url, data, returnType = 'json') {
                const init = {
                    method: "POST",
                };
                if (data) {
                    if (data instanceof FormData) {
                        init.body = data;
                    } else {
                        init.body = JSON.stringify(data);
                    }
                }
                try {
                    const res = await fetch(url, init);
                    const res2 = returnType === 'json' ? await res.json() : await res.text();
                    return res2;
                } catch (e) {
                    console.log(e);
                    return returnType === 'json' ? { code: e.code || 1, msg: e.message || "", data: null } : "";
                }
            }
        }
    }
})();


最近对数据库的功能改进期待

之前用 notion,只觉得数据库折腾

现在用思源,才发现数据库,真好用呀真好用

期待下面的 issue,能早日推进

  • 思源笔记

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

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

    24503 引用 • 100255 回帖
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    126 引用 • 847 回帖
4 操作
Achuan-2 在 2024-11-03 12:51:16 更新了该帖
Achuan-2 在 2024-11-03 12:48:21 更新了该帖
Achuan-2 在 2024-09-28 12:17:01 更新了该帖
Achuan-2 在 2024-09-26 22:04:07 更新了该帖

相关帖子

欢迎来到这里!

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

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

    好想法,期待产品实现

  • 其他回帖
  • YRJ0422

    这个好像已经实现了,如果摘录了一个块到数据库会在右侧显示的

    image.png

    要是有个全局数据库能根据所有的文档标签自动化就更好了

    1 回复
  • GloR

    有没有一种可能换个思路:

    1- 创建数据库,自动创建 n 行(自己随便设置)

    2- 主键位置自动填充从今天起的 n 行日期

    3- 固定这个数据库页面,每天打开,点一下对应的日期,写 dailynote

    ⏩ 上面这个较为流畅的流程我已经用 excel 简单地实现了(已实践了 230 天,如图),但奇怪的是似乎没一个笔记软件能做到。

    image.png


    顺便说说 excel 来完成上述流程的优点&痛点(供参考):

    ✅ 优点:

    1- excel 可以轻松支持几万行的数据,保守点说,一张 sheet 写三年没啥问题,卡顿了就再创建一个 sheet 即可。
    2- 支持简单打卡、简单记录、简单时间规划 等多种简单功能

    ❎ 痛点:

    1- 无法与 笔记资料库等联动。
    2- 只能进行简单记录,emoji 都无法显示颜色,比较丑。

    1 回复
  • YRJ0422

    我看已经有人开始制作这方面的插件了,不过 bug 还是挺多的,估计还得等明年把画廊视图做出来了,把整个数据库模块做差不多了再优化优化了

    image.png

  • 查看全部回帖

推荐标签 标签

  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 1 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    267 引用 • 666 回帖 • 2 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    62 引用 • 289 回帖
  • 996
    13 引用 • 200 回帖 • 6 关注
  • 叶归
    5 引用 • 16 回帖 • 9 关注
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    31 引用 • 96 回帖
  • 正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列遵循某个句法规则的字符串。

    31 引用 • 94 回帖 • 4 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 326 关注
  • 以太坊

    以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。

    34 引用 • 367 回帖 • 2 关注
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    27 引用 • 196 回帖 • 27 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 7 关注
  • 前端

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

    245 引用 • 1338 回帖 • 3 关注
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖
  • Electron

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

    15 引用 • 136 回帖 • 6 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 116 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1707 回帖
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 168 关注
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    950 引用 • 943 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    335 引用 • 324 回帖
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 263 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 73 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 20 关注