思源笔记折腾记录 - 用 wechatsync 一键发布笔记到各个平台

本贴最后更新于 988 天前,其中的信息可能已经事过境迁

一、前情提要:

我们之前实现了在思源中加载自定义菜单,就像这样:

思源笔记折腾记录-快速移动文档 - 知乎 (zhihu.com)

image

但是这个菜单只有移动文档的功能,有点不太给力。

刚好我之前到处翻翻找找的时候发现了这个:

微信公众号同步助手 - 公众号文章多平台同步 Typora Markdown 写作 一文多发 自媒体内容同步、内容营销、分发工具,自媒体助手,一键同步发布,支持微博头条、掘金、CSDN、今日头条、豆瓣、WordPress 博客、知乎专栏、简书、Typecho 博客等各大内容平台 (wechatsync.com)

发现好像有点给力欸。

所以我们来尝试对接一个吧。

二、实现过程

显然这是个浏览器插件,虽然我也可以尝试自己撸一遍移植到思源里,但是着实有点妹得必要。。。。。

所以我们就直接想办法对接一下吧。

然后在这个插件的作者的 GitHub 上找到了这个 SDK:

wechatsync/article-syncjs (github.com)

好耶~~~~~

不过这个好像不是很合适直接挪到思源里,所以我们稍微改一下它:

import noobApi from "../noobApi/index.js"; if(window.$syncer){ let allAccounts = [] window.$syncer.getAccounts(function (resp) { console.log('allAccounts', resp) allAccounts = resp 注册菜单项(allAccounts) }) } function 注册菜单项(账户列表){ noobApi.自定义菜单.块标菜单.注册自定义菜单项( { id:'wechatSync', 文字:`使用wechatSync发布`, 图标:'#iconInbox', } ) 账户列表.forEach( 账户=>{ noobApi.自定义菜单.块标菜单.注册自定义子菜单项( (菜单项) => { return 菜单项.id == "wechatSync" }, { id:账户.uid, 文字:`${账户.title}`, 图标:'#iconInbox', 点击回调函数:()=>{发布文档到(账户)} } ) } ) } async function 发布文档到(账户){ let 块id = noobApi.自定义菜单.块标菜单.菜单状态.当前块id let stmt = `select * from blocks where id in (select root_id from blocks where id = "${块id}" )` let 文档数据 = (await noobApi.核心api.sql({ stmt: stmt }))[0] let 文档内容 = await noobApi.核心api.exportPreview( { "id": 文档数据.id } ) let 文档属性 = await noobApi.核心api.getDocInfo( { "id": 文档数据.id } ) let 发布数据 = {} 发布数据.title = 文档属性.ial.title 发布数据.markdown = 文档数据.markdown 发布数据.content = 转换图片地址(文档内容) 发布数据.desc = 文档属性.ial.memo 发布数据.thumb = 文档属性.ial['title-img'] noobApi.核心api.pushMsg({ "msg": `准备同步${文档数据.hpath}${账户.title}`, "timeout": 1000 } , "" ) 添加任务(发布数据,账户) } function 转换图片地址(文档内容){ let div = document.createElement('div') div.innerHTML = 文档内容.content ? 文档内容.content : 文档内容.html div.querySelectorAll('[src]').forEach( el=>{ if(el.getAttribute('src').startsWith('assets')) { el.setAttribute('src',window.location.origin+'/'+el.getAttribute('src')) } } ) div.innerHTML+='<p>本文使用<a href="https://b3log.org/siyuan/">思源笔记</a>写作</p>' div.innerHTML+='<p>本文使用<a href="http://publish.chuanchengsheji.com/">椽承设计</a><a href="https://github.com/leolee9086/snippets">小工具</a>配合同步</p>' return div.innerHTML } function 添加任务(发布数据,账户){ window.$syncer.addTask( { post: 生成任务(发布数据,账户), accounts: [账户], }, function (status) { status.accounts.forEach(account => { if (account.editResp) { let a = document.createElement('a') a.setAttribute('href', account.editResp.draftLink) a.setAttribute('target', "_blank") a.setAttribute("referrerPolicy", "no-referrer") a.click() a.remove() } }); }, function () { noobApi.核心api.pushMsg({ "msg": `同步${文档数据.hpath}${账户.title}完成`, "timeout": 1000 }) } ) } function 生成任务(发布数据,账户) { var post = {} post.title = 发布数据.title if (发布数据.content) { post.content = 发布数据.content } else if (发布数据.markdown) { post.markdown = 发布数据.markdown } if (发布数据.thumb) { post.thumb = 发布数据.thumb } if (发布数据.desc) { post.desc = 发布数据.desc } else { post.desc = 发布数据.content ? 发布数据.content.substring(0, 20) : 发布数据.markdown.substring(0, 20) } return post }

代码超短的蛤。

一点点说一下:

首先这里是判断有没有 wechatSync 的代码注入,如果有的话才进行下面的步骤

if(window.$syncer){ let allAccounts = [] window.$syncer.getAccounts(function (resp) { console.log('allAccounts', resp) allAccounts = resp 注册菜单项(allAccounts) }) }

然后注册一个菜单项,并且把所有能用的同步项加载到它的子菜单(这里偷了个懒,就不动态生成了)

noobApi.自定义菜单.块标菜单.注册自定义菜单项( { id:'wechatSync', 文字:`使用wechatSync发布`, 图标:'#iconInbox', } ) 账户列表.forEach( 账户=>{ noobApi.自定义菜单.块标菜单.注册自定义子菜单项( (菜单项) => { return 菜单项.id == "wechatSync" }, { id:账户.uid, 文字:`${账户.title}`, 图标:'#iconInbox', 点击回调函数:()=>{发布文档到(账户)} } ) } )

后面的没有什么好说的,就是获取一下文档内容,之类的。

需要说明一下的是这两个地方:

function 转换图片地址(文档内容){ let div = document.createElement('div') div.innerHTML = 文档内容.content ? 文档内容.content : 文档内容.html div.querySelectorAll('[src]').forEach( el=>{ if(el.getAttribute('src').startsWith('assets')) { el.setAttribute('src',window.location.origin+'/'+el.getAttribute('src')) } } ) //这里你可以换成自己喜欢的蛤 div.innerHTML+='<p>本文使用<a href="https://b3log.org/siyuan/">思源笔记</a>写作</p>' div.innerHTML+='<p>本文使用<a href="http://publish.chuanchengsheji.com/">椽承设计</a><a href="https://github.com/leolee9086/snippets">小工具</a>配合同步</p>' return div.innerHTML }

这里对思源的 assets 中的图片做了一下转换,让 wechatSync 能够拉取这些图片,否则会上传不了。

noobApi.核心api.pushMsg({ "msg": `同步${文档数据.hpath}${账户.title}完成`, "timeout": 1000 })

pushMsg 这个 api 我们之前还没有用过,不过意思很明显,就是推送消息到各端。

最后的成果效果就像是这样(没错这篇文档就是这么发出来的):

一键发布到各个平台


代码片段全部内容参考这里

leolee9086/snippets (github.com)

  • 思源笔记

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

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

    26732 引用 • 111367 回帖 • 1 关注

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖
  • Swift

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

    34 引用 • 37 回帖 • 555 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 12 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 259 关注
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 279 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖 • 6 关注
  • 印象笔记
    3 引用 • 16 回帖
  • Q&A

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

    10321 引用 • 46860 回帖 • 61 关注
  • CodeMirror
    2 引用 • 17 回帖 • 177 关注
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 451 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    61 引用 • 29 回帖 • 6 关注
  • Electron

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

    15 引用 • 136 回帖 • 4 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 412 关注
  • 新人

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

    52 引用 • 228 回帖
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖
  • Dubbo

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

    60 引用 • 82 回帖 • 618 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    694 引用 • 537 回帖
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    46 引用 • 114 回帖 • 159 关注
  • C

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

    86 引用 • 165 回帖 • 1 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    2 引用 • 32 回帖
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    142 引用 • 442 回帖
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 675 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    101 引用 • 905 回帖
  • abitmean

    有点意思就行了

    33 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2389 回帖 • 4 关注
  • JSON

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

    53 引用 • 190 回帖 • 3 关注