[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,能早日推进

  • 思源笔记

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

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

    22179 引用 • 88603 回帖 • 6 关注
  • 代码片段

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

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

    58 引用 • 336 回帖 • 3 关注
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 更新了该帖

相关帖子

欢迎来到这里!

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

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

    我感觉数据库属性显示很重要,但是似乎优先级不高。

    1 回复
  • Achuan-2

    是的,希望早日能在块内显示数据库属性吧

    1 回复
  • YRJ0422

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

    image.png

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

    1 回复
  • Achuan-2

    指的是像 notion 一样,打开数据库里的文档,可以在文档内就显示属性,便于查看和修改

    1 回复
  • xiuchun

    好想法,期待产品实现

  • YRJ0422

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

    image.png

  • GloR

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

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

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

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

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

    image.png


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

    ✅ 优点:

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

    ❎ 痛点:

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

    1 回复
  • Achuan-2

    可以做,我现在基本搞清楚数据库的 API 调用了,但是我不太需要提前创建 dailynote

    1 回复
  • GloR

    emm 对我来说这个不叫“提前创建 dailynote”,而是每年制作一张日历表,用它来 记事 + 全局规划(排日程/TODO),以此替代所有日历 orTODO 类 app

    1 回复
  • Achuan-2

    哦哦明白了,我见过有人这样做的第一列是每天,然后计划每天要干什么,这个或许该叫时间线任务视图,确实看起来很棒

    我之前还叫滴答清单改他们的时间线视图,滴答清单是横着的,看多天任务不是很方便

    1 回复
  • GloR

    是滴是滴,超级方便,用起来特别爽(正反馈感强)~前几天试着用 notion 实现了一下,发现更爽了(我觉得 notion 的本质其实不是笔记软件(我思源才是笔记软件(狗头)),而是一个高度定制化的个人管理软件,也就是说,楼主想要用滴答清单来实现的功能,本质上应该都可以用 notion 来实现,不妨试试~~)

    1 回复
  • Achuan-2

    滴答清单的好处在于多端同步,不仅仅当任务管理软件,也是我的随机笔记,所以我都没用 flomo,直接用滴答清单在手机桌面新建小组件,就可以快速添加笔记

  • 爱了爱了,很早就像用这个了,终于有大佬写出来了 😄

请输入回帖内容 ...
Achuan-2
给时间以生命而不是给生命以时间,如果你喜欢我的分享,欢迎给我买杯咖啡 https://www.yuque.com/achuan-2 上海

推荐标签 标签

  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 28 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 461 关注
  • Linux

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

    940 引用 • 943 回帖
  • C

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

    85 引用 • 165 回帖
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 536 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    70 引用 • 533 回帖 • 779 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    153 引用 • 3782 回帖
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    53 引用 • 37 回帖 • 1 关注
  • BAE

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

    19 引用 • 75 回帖 • 635 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 600 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 624 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 481 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    497 引用 • 1387 回帖 • 285 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 453 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 384 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 761 关注
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    6 引用 • 14 回帖 • 1 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 388 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 21 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 529 关注
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    222 引用 • 473 回帖 • 1 关注
  • 微软

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

    8 引用 • 44 回帖
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 745 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 587 关注
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 527 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 585 关注