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

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

一、前情提要:

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

思源笔记折腾记录-快速移动文档 - 知乎 (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)

  • 思源笔记

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

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

    25482 引用 • 105384 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • MyBatis

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

    173 引用 • 414 回帖 • 365 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 77 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 166 关注
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 141 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 648 关注
  • 浅吟主题

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

    1 引用 • 28 回帖 • 1 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 747 回帖 • 1 关注
  • 以太坊

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

    34 引用 • 367 回帖 • 1 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 7 关注
  • Ngui

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

    7 引用 • 9 回帖 • 397 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 1 关注
  • Hprose

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

    9 引用 • 17 回帖 • 636 关注
  • C

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

    86 引用 • 165 回帖 • 2 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖
  • 智能合约

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

    1 引用 • 11 回帖
  • Scala

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

    13 引用 • 11 回帖 • 157 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    133 引用 • 796 回帖 • 1 关注
  • CongSec

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

    1 引用 • 1 回帖 • 32 关注
  • Lute

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

    29 引用 • 202 回帖 • 28 关注
  • 大疆创新

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

    2 引用 • 14 回帖 • 1 关注
  • 房星科技

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

    6 引用 • 141 回帖 • 591 关注
  • Windows

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

    227 引用 • 476 回帖
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 34 关注
  • 自由行
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    20 引用 • 23 回帖 • 740 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 655 关注