一、前情提要:
我们之前实现了在思源中加载自定义菜单,就像这样:
思源笔记折腾记录-快速移动文档 - 知乎 (zhihu.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 我们之前还没有用过,不过意思很明显,就是推送消息到各端。
最后的成果效果就像是这样(没错这篇文档就是这么发出来的):
代码片段全部内容参考这里
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于